-
Notifications
You must be signed in to change notification settings - Fork 1.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support optional chaining #4303
Comments
this is super important to make the code more readable. i'd love to have this. |
this feature is really important for project i am working for. waiting for implementation! |
This is really important for dealing with JSON responses without having to write a plethora of null checks. +1 |
Note that optional chaining is still a stage 1 proposal and has gone through a number of changes since the Babel plugin was implemented. It's very likely that there will be changes to both the syntax and the behavior before the final JS feature is released. See various other discussions: |
Can be a simple case of optional chaining (optional static property access) implemented today under option's flag esproposal or experemental? I say about simple property reading from nested objects a?.b?.c, which will be an amazing improvement in the code for React components. Eg when reading graphql responses. And leave dynamic and function/method calls uncovered while it in stage-1. |
would love to see that! we could remove tons of code and checks if flow also supports this syntax. thanks @nodkz and @alangpierce for having an eye on that. |
looks like this will be in the next version 🎉763ffb5 |
@cloudkite looks like only parsing will be supported. Type support isn't landing, as the feature has been marked as experimental. |
I've added (most) type support for optional chaining in 0.71.0 (gated behind the |
This is amazing, I've been waiting for this. In the following situation it complains about dash.exampleLogs[x] on line 319 because dash.exampleLogs might be undefined, however given that this code will only run if line 318 is true, shouldn't Flow realize that this cannot be undefined in this context? Cannot get dash.exampleLogs[x] because an indexer property is missing in undefined [1].
frog/imports/ui/Preview/ShowDashExample.js
316│ const dash = aTdashs[this.state.example];
317│ let data;
318│ if (dash?.exampleLogs?.[x].type === 'state') {
319│ data = dash.exampleLogs[x].state;
320│ } else if (dash.prepareDataForDisplay) {
321│ data = dash.prepareDataForDisplay(
322│ dash.initData,
frog-utils/dist/types.js.flow
[1] 157│ | {
158│ type: 'logs',
159│ title: string,
160│ path: string,
161│ activityMerge?: Object,
162│ instances?: number
163│ }
164│ | { title: string, type: 'state', activityMerge?: Object, state: any }
165│ )[] |
@houshuang We could potentially do that, but Flow doesn't currently perform that refinement. |
@houshuang feel free to create a separate issue to track and discuss that |
@houshuang @fishythefish @mrkev was a separate issue ever created? I too am finding it hard to make use of optional chaining when flow complains that I haven't checked for |
I haven't seen one. |
Babel 7 RC has been released - it would be nice to have this and null coalescing ready when Babel 7 is fully released |
Babel 7 is being released this week: |
Any progress on this? Babel 7 is now fully released: https://babeljs.io/blog/2018/08/27/7.0.0 |
I can only speculate as I'm not a core contributor to Flow but Just because babel supports a feature, doesn't mean Flow will or wont support it. optional chaining happens to be partially supported in Flow already but function calls are not yet supported. Maybe someone from the Flow core team could comment on if adding full support is planned? Or is this a feature the core team would be willing to merge but not prioritized? |
function calls not supported and typing also. the optional property become |
@eshikerya If typing is broken, that would be an issue but as far as I've seen, typing when using optional chaining is working as expected. Here's an example. Could you provide an example that demonstrates the issue you're seeing? function func(prop1 : ? { prop2?: string }) {
return prop1?.prop2;
}
// no error
(func({bar: { bar : 'wow' }}): ?string);
// errors as expected
(func({bar: { bar : 'wow' }}): ?number); |
cc @samwgoldman or @avikchaudhuri |
@vicapow it seems that basic property access work, but methods do not: |
with [email protected] it works as expected type Dictionary<K, V> = { [id: K]: V };
type enmWorkspaceUserRoleType =
| "Nobody"
| "Resource"
| "Spectator"
| "Participant"
| "Leader"
| "Owner";
type WorkspaceUserInfoType = {
id: ID,
name: string,
role: enmWorkspaceUserRoleType
};
type WorkspaceInfoType = {
id: ID,
name: string,
workspaceUser?: WorkspaceUserInfoType
};
const workspaces: Dictionary<string, WorkspaceInfoType> = {
testId: {
id: "testId",
name: "Test Workspace",
workspaceUser: {
id: "userId",
name: "Test User",
role: "Owner"
}
}
};
console.log(workspaces.testId?.workspaceUser?.role); expected error will be reported in case: console.log(workspaces.testId?.workspaceUser.role);
Cannot get `workspaces.testId?.workspaceUser.role` because property `role` is missing in undefined [1]. [1] |
Assuming the proposal remains unchanged, the plan is to eventually add support for calls in optional chains. However, we're waiting for the proposal to progress beyond stage 1, since it's unclear whether optional calls will make it into the final proposal and, if so, what semantics they will have; see tc39/proposal-optional-chaining#59. |
Are we at the point where an implementation PR would be accepted? I'd be happy to take a shot at getting it working if that's the only hurdle left. |
IIRC this was waiting for the proposal to go through, though I might be wrong. Someone in the team might know better. @dsainati1 |
I'm not an expert on this unfortunately so I don't have any new information. |
@dsainati1 who would know if this is something that can be added? |
Not sure honestly. Maybe @nmote? |
Optional chaining has been brought to stage-2 yesterday. Can we move forward now, Flow? tc39/proposals@effb785 |
Update: Optional chaining has moved to Stage 3 tc39/proposals@25f8d6a |
@kenrick95 that was fast |
@mroch is it possible to support optional calls? |
It is now supported by v8. |
Sorry – typo. It was supposed to say:
Edited. |
At this point it's just a matter of prioritization. The worry with implementing early-stage proposals is that we will implement something that does not match the final specification of the feature, leading to a painful non-backwards-compatible change down the road. At this point, I wouldn't worry about that with optional chaining. |
Is it possible to change |
Any update on the priority of proper support for optional chaining? We (or at least I) think that flow is really great and we love using it, but sometimes you can't help but ask yourself if it's time to move to TypeScript, which now support optional chaining and null coalescing. |
@ovidb Flow supports both for a long time. Optional calls support was introduced in the latest release. |
@TrySound I apologise for not checking the release notes, but I am on the latest version and the reason I thought it's still not supported is because whenever you use optional chaining inside an if statement, flow doesn't seem to understand that that maybe value has been checked for. Is this a bug or a known fact? On the bright side, thanks for letting us know that calls support is now working. Thats amazing news!!! |
@ovidb This works: https://flow.org/try/#0C4TwDgpgBA8mwEsD2A7AhgGygXigbwCgoo0B+ALnyKgEgAjSgZ2ACcEUBzAGmoF8D+BAGYBXFAGNEqKMAjM4U9BgAUSeMiWUFGzAEoqxNYswA6MibongSAMqt2HZboDc1BEKir1qU2igBCXBQRDAx9QmIaIx0MMwsrW3tOJ1difl4gA Must be something about using optional chaining in conditionals. |
Yes, currently refinement is not preserved. So you need to cache optional chaining result in variable or use null check in if statement. |
FTR in case it's helpful for anyone else, it looks like v0.112.0 was the release that introduced support for method calls in optional chains. I determined that using this handy demo from a comment above: and a quick binary search. It's also mentioned in the release notes under v0.112.0, though not very definitively. |
Prompted by discussion on zulip#4101 [1]. Flow started supporting method calls in optional chains in v0.112.0 [2], but ESLint isn't yet on board [3]; it gives a false positive for `no-unused-expressions`. A comment on the ESLint issue [4] suggests we could be more systematic by using an ESLint plugin from Babel, instead of one-off suppressions of `no-unused-expressions` like this one. That plugin moved from (on NPM) `babel-eslint-plugin` to `@babel/eslint-plugin`. We can't use the new one until we're on ESLint 7 (see zulip#4254), but we could probably use the old one. [1] zulip#4101 (comment) [2] facebook/flow#4303 [3] eslint/eslint#11045 [4] eslint/eslint#11045 (comment)
Prompted by discussion on zulip#4101 [1]. Flow started supporting method calls in optional chains in v0.112.0 [2], but ESLint isn't yet on board [3]; it gives a false positive for `no-unused-expressions`. A comment on the ESLint issue [4] suggests we could be more systematic by using an ESLint plugin from Babel, instead of one-off suppressions of `no-unused-expressions` like this one. That plugin moved from (on NPM) `babel-eslint-plugin` to `@babel/eslint-plugin`. We can't use the new one until we're on ESLint 7 (see zulip#4254), but we could probably use the old one. [1] zulip#4101 (comment) [2] facebook/flow#4303 [3] eslint/eslint#11045 [4] eslint/eslint#11045 (comment)
Prompted by discussion on zulip#4101 [1]. Flow started supporting method calls in optional chains in v0.112.0 [2], but ESLint isn't yet on board [3]; it gives a false positive for `no-unused-expressions`. A comment on the ESLint issue [4] suggests we could be more systematic by using an ESLint plugin from Babel, instead of one-off suppressions of `no-unused-expressions` like this one. That plugin moved from (on NPM) `babel-eslint-plugin` to `@babel/eslint-plugin`. We can't use the new one until we're on ESLint 7 (see zulip#4254), but we could probably use the old one. [1] zulip#4101 (comment) [2] facebook/flow#4303 [3] eslint/eslint#11045 [4] eslint/eslint#11045 (comment)
Prompted by discussion on zulip#4101 [1]. Flow started supporting method calls in optional chains in v0.112.0 [2], but ESLint isn't yet on board [3]; it gives a false positive for `no-unused-expressions`. A comment on the ESLint issue [4] suggests we could be more systematic by using an ESLint plugin from Babel, instead of one-off suppressions of `no-unused-expressions` like this one. That plugin moved from (on NPM) `babel-eslint-plugin` to `@babel/eslint-plugin`. We can't use the new one until we're on ESLint 7 (see zulip#4254), but we could probably use the old one. [1] zulip#4101 (comment) [2] facebook/flow#4303 [3] eslint/eslint#11045 [4] eslint/eslint#11045 (comment)
When could we expect optional chaining support.
It will be released soon with babel@7.
babel/babylon#545
The text was updated successfully, but these errors were encountered: