-
Notifications
You must be signed in to change notification settings - Fork 786
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nice 👍 some minor comments
} | ||
|
||
export default function graphql( | ||
export default function graphql<TResult = {}, TProps = {}, TChildProps = DefaultChildProps<TProps, TResult>>( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i think you'll need to bump typescript to 2.3 in package.json
for the default generics
src/graphql.tsx
Outdated
@@ -142,7 +153,7 @@ export default function graphql( | |||
// However, this is an unlikely scenario. | |||
const recycler = new ObservableQueryRecycler(); | |||
|
|||
class GraphQL extends Component<any, any> { | |||
class GraphQL extends Component<TProps, any> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
not important, but can probably set state to {}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks dope!
Changelog.md
Outdated
@@ -4,6 +4,9 @@ Expect active development and potentially significant breaking changes in the `0 | |||
|
|||
### vNext | |||
|
|||
### 1.4.0 | |||
- Feature: Enhanced typescript definitions to allow for more valid type checking of graphql HOC |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this will be a breaking change for TS devs, right? Might be worth a mention in the changelog.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@stubailo for sure! I'll add that and note it in the release as well
mutate?: MutationFunc<TResult>; | ||
} | ||
|
||
export type DefaultChildProps<P, R> = P & { data?: QueryProps & R, mutate?: MutationFunc<R> }; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wow this is dope
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
right? I'm wondering if I setup some overloads if we can get it to correctly type mutation / query / subscription. Going to try my hand at it tonight
src/graphql.tsx
Outdated
@@ -142,7 +157,7 @@ export default function graphql( | |||
// However, this is an unlikely scenario. | |||
const recycler = new ObservableQueryRecycler(); | |||
|
|||
class GraphQL extends Component<any, any> { | |||
class GraphQL extends Component<TProps, {}> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit, but I think void
would be more appropriate for the type of State here.
skip?: boolean | ((props: any) => boolean); | ||
name?: string; | ||
withRef?: boolean; | ||
shouldResubscribe?: (props: TProps, nextProps: TProps) => boolean; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would props
and nextProps
not be optional here?
i.e.
{
//...
shouldSubscribe: () => true //should be OK
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
that should still be fine, they should only be optional if the call can pass the variables as undefined
interface Test {
testFn (x: string, y: string): boolean;
}
let z: Test = {
// this is fine
testFn: () => true
};
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I only took a look at the Flow typings but generally what are your thoughts about adding more specific constraints on the generics for things that are exported? It may help produce more useful errors when types don't line up in usage.
index.flow.js
Outdated
): void; | ||
|
||
declare export function getDataFromTree( | ||
rootElement: any, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
these are consistent with the ts types, but should these be React$Element<*>?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@lewisf yeah the server needs better typings all around, I'll update the PR for typescript and flow typings tonight for it
index.flow.js
Outdated
props: P | ||
) => QueryOptions | MutationOptions; | ||
|
||
declare export interface OperationOption<TProps, TResult> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it may be useful to give any exported things that use generics more specific types
interface OperationOption<TProps: {}, TResult: {}>
index.flow.js
Outdated
|
||
declare export interface OperationComponent< | ||
TResult: mixed = {}, | ||
TOwnProps: mixed = {}, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Does it make sense to do Object
here instead of mixed
?
src/graphql.tsx
Outdated
error?: ApolloError; | ||
networkStatus: number; | ||
loading: boolean; | ||
variables: { | ||
variables?: { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i think this should not have the ?
it looks like if there's no variables it's an empty object, not undefined
This is ready to go for a first release in my opinion after apollographql/apollo-client#1688 is merged and released |
This looks great! Let's get that PR on apollo-client merged! 🎉 |
@helfer I'll have tests written for flow typings tomorrow so we can merge and release AC, then we can bump the version here, release, write a blog post, then 🎉 |
This looks great! |
It looks like |
@jbaxleyiii ping, any more news? Can I help? |
@stubailo I wanted to make sure I had the availability to support this release and apollographql/apollo-client#1688 with quick responsiveness after release so I held off until I was certain I could do that. 👍 I've updated the AC PR and will tweak this one next to make sure they are ready since I will be able to support the next few releases well! |
@jbaxleyiii still trying to understand flow, but should types be committed to https://github.com/flowtype/flow-typed as well? So from the command line |
Perhaps I'm dense or am lacking sleep, but I can't get this change to work with a combination of decorators, https://github.com/aliemteam/aliemcards/blob/master/app/cards/Card.tsx Has this PR been tested enough to merge? I only see a few situations of this being used in the associated test files and the changes are quite complex. Any help here would be thoroughly appreciated. Edit: Looks like all the decorator tests are wrapping components that are given the @graphql(query)
class Container extends React.Component<any, any> {} |
Also, one other thing I suppose I should mention. I'm using visual studio code. Until now, I've never had a situation where my editor freezes up and lags. Exclusively the new I appreciate the hard work, but IMHO, the types are too strict. Maybe we could work on a happy medium? I'd be happy to collaborate on a PR. |
@jbaxleyiii Just pulled the repo, did a Does this file work for you guys? |
What does this mean exactly? The types should restrict invalid code, but allow valid code. Can you provide some examples of where this does not happen? |
@ianks Maybe a poor choice of words on my part. Strictness is a good thing, I agree. But the complexity of the generics in this PR don't appear to have been tested thoroughly enough. Also, I'm wondering what the added value of adding all this complexity brings to the table? I admittedly have not used all the functionality of react-apollo, so I can't say with certainty that there isn't added value here, but what I can say is that the strictness I was able to get with the old types was perfectly fine for the features that I was using. Also, the changes appear to have been crippling to the typescript language server due to how deeply dependent some of the generics are on each other. For example, just tracing the graphql generic quickly, I'm seeing at least 4 unions, 4-5 intersections, and 3-4 levels of sub-generics. It's a great showcase of Typescripts new generic defaults, but it cripples the typescript language server in visual studio code. Change one value inside the graphql function or change a type that is used somewhere in the generic chain, and the language server has to dive into all that complexity every single time to check. I'm in no way trying to lessen the value of @jbaxleyiii's work on this PR, and really appreciate all the other work he's done, so please don't take this the wrong way. All I'm saying is that it appears that this change could warrant tests in a handful of different situations to make sure that all the added complexity added by these types has been thoroughly tested. Also, I'm wondering if there might be a way to break apart the length of the type dependency chain to make it less of a workload on the typescript language server for those of us who utilize it for real-time warnings (vscode users, for example). Thanks for considering. Again, happy to help in any way if needed. |
@dsifford what version of typescript are you on? |
@ianks Latest, stable in the project that I linked to above.
|
@dsifford can you make a minimal reproduction of this? essentially a dir with a yarn.lock and a file which causes this bug? EDIT: Nevermind I see you provided a file for this |
Yep, I'd be glad to! I appreciate the hospitality 😄 Gotta run to class now though. Can we hold that thought until maybe tomorrow afternoon? Also, just to confirm: You aren't able to reproduce the error in this repo that I'm seeing? If not, that's pretty strange... I'd feel pretty silly if this ended up being an issue with my system or something! 😖 |
Same errors for me, I thought i was going insane trying to get these types to compile. Can confirm that a simple |
@dsifford and @alexzielenski I'm hoping to take a look at your issues this week. Could you please open a new issue for tracking it? |
Sorry for the delay @jbaxleyiii! Just opened #786 for this. Thanks in advance! 😄 |
Does documentation exist for how to use this yet? Say, setting up an example project with all the type benefits described in the original post? The post by @alexzielenski in #786 does a good job of explaining how to get something working, and could be used as a starting point for documentation. I love what you guys are doing here! Thanks so much for all the hard work! |
This is a PR I'm super excited about. It should make typescript and flow users very happy! 🎉
Following the discussion in #394, this PR seeks to make adding types easy to the
graphql
HOC for both flow and typescriptExamples:
Typescript
Type query results and expect their values in the the wrapped component
Safely use the
options
function based on props passed to wrapped componentSafely build props based on result data, passed props, and what react-apollo passes down
Flow
Type query results and expect their values in the the wrapped component
Safely use the
options
function based on props passed to wrapped componentSafely build props based on result data, passed props, and what react-apollo passes down
Known flow issues
QueryProps & ?R
but then I couldn't get flow to pass something likedata.code && // use data.code
. If you have any knowledge here I'd love it!For the flow typings, we will need to move the AC ones to AC and do a release first. I'd love to do a tagged release with them bundled with the lib so they are automatic like typescript typings are. If it works (fingers crossed), we can do the same for RA.
I would love feedback from @helfer @ianks and @brettjurgens if they are willing. This is a breaking typescript change so I've bumped the minor version. I hope that works for people!
I'll probably play around with overloads for typescript to detect mutation / query / subscription. I'm not totally sure how to do that in flow.