-
Notifications
You must be signed in to change notification settings - Fork 433
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
Add typescript support to issue-tracker #122
base: main
Are you sure you want to change the base?
Conversation
Hi renanmav! Thank you for your pull request and welcome to our community. We require contributors to sign our Contributor License Agreement, and we don't seem to have you on file.In order for us to review and merge your code, please sign at https://code.facebook.com/cla. If you are contributing on behalf of someone else (eg your employer), the individual CLA may not be sufficient and your employer may need to sign the corporate CLA. If you have received this in error or have any questions, please contact us at [email protected]. Thanks! |
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.
Thanks so much for working on this! I think this could really help folks understand the code. The overall theme of my feedback is to keep the changes focused on adding TypeScript support: please revert arbitrary naming, content, and formatting changes.
It should be next to RouteComponent, which is the component that uses this type
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.
Awesome, thanks for the updates! There's still a few things around the types and extraneous changes - also looks your editor really wants to automatically "correct" the capitalization in "GitHub" for some reason!
issue-tracker/src/Root.tsx
Outdated
|
||
export default function Root(props) { | ||
const Root = (props: Props) => { |
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.
just curious, why the change here?
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.
Tangentially related—usually when declaring functional components in TypeScript, I tend to use const
declarations with a React.FC<Props>
generic type annotation. This both enforces the return type of your function, as well as correctly typing the Props
interface. This current definition is actually a bit misleading—with the way this is declared you will not have a children
prop. This may not matter now, but it becomes annoying the second you want to add it. Using React.FC
will add those additional properties for you on top of your generic argument.
const Root: React.FC<Props> = (props) => {} // props is typed with our generic + children
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.
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've also come across that medium article once, and even if some of the tips are useful, I'd still go with the official way of typing react functional components, like most people are used to, with React.FC<Props>
just like @ksaldana1 suggested.
exact?: boolean; | ||
strict?: boolean; | ||
component: Resource<any>; | ||
prepare: (params: { |
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 know it's not dead necessary for this example, but how about making prepare
optional, so we can use the router for non-relay routes also?
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 agree with you, but a comment made by @josephsavona:
this could be non-optional
|
||
/** | ||
* An alternative to react-router's Link component that works with | ||
* our custom RoutingContext. | ||
*/ | ||
export default function Link(props) { | ||
const Link: React.FC<Props> = props => { |
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.
Any reason for not destructuring the props eg. const Link: React.FC<Props> = ({ children, to }) => {}
? Same with all other instaces of React.FC
Also children is already defined by the FC
type, so no reason to define it again in Props
interface.
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 destructures are really necessary? I think that they add an unnecessary complexity.
no reason to define it again
Thanks!
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.
Isn't destructing props in functional components the standard? How is this complexity? If you did that you could remove 8 unnecessary props.
just in that component.
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.
Yeah, but I would add 8 unnecessary new lines to destructure. I'd have 16 lines between destructuring and usage against 8 lines with actual strategy.
In fact, using props.<propName>
enforces that this data comes as props.
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.
So... I guess this is pretty basic stuff but...
Changing const Link: React.FC<Props> = props => {}
to const Link: React.FC<Props> = ({ children, to }) => {}
means that, in just that Link component, you can remove props.
from 7 instances of props.to
and 1 instance of props.
from props.children
... how is this adding complexity to you... or 16 new lines. If anything it reduces redundancy (or what am I not seeing here?)
Sorry, what you say makes no sense to me. Thought everyone was doing it since ES2015. Maybe read this.
…mples into feat/issue-tracker-ts
I think we are ready @josephsavona @jstejada |
@renanmav Awesome, thank you again for your contributions. I'll check this out locally and experiment a bit and may make a few minor tweaks before landing, but this looks great. EDIT: With the combination of holidays and some personal/family issues I didn't get a chance to follow-up on this, my apologies. |
I'm interested in seeing this working too, let me know if there's any work to be done so I can jump in |
What's missing for this one to be merged? |
Ahhhh everything in this repo seems abandoned :/ |
Hi @daig, |
Just noting that we haven't added many changes here because the example is flushed out and complete. We fully intend to keep this example up-to-date as our APIs evolve, but so far that hasn't warranted any changes because these APIs are now fairly stable. TypeScript support - this PR - would certainly be nice to have, but I already spent a lot of time reviewing this and simply ran out of steam. This PR is probably going to have to wait until I or someone else on the team have enough free personal time to review again, make edits, and land. |
There are still many things that could be improved so good that you did not merge it yet. It makes somewhat sense to make this pr overwrite the existing js code during development to document the changes/diffs. But may I suggest to keep both a js and ts version by making one final commit where the folder is renamed to something like issue-tracker-ts or moved to a ts and then bring back the js version - after this PR is in a good state and approved of course. |
what about keep here Flow examples, and create https://github.com/relay-tools/relay-examples-typescript? so we can move faster and iterate more there, as relay team is not using typescript |
A separate repo for the TS version makes a lot of sense. Please post back here as you make progress, so that we can take a look and provide feedback, and also add a link to it! |
Thank you for signing our Contributor License Agreement. We can now accept your code for this (and any) Meta Open Source project. Thanks! |
As talked with @jstejada, @josephsavona and @ksaldana1, we would like to add typescript support to issue-tracker example.
And here it is.
Just a minor problem. When we add the Concurrent mode like this, the
Root.tsx
component with header isn't rendered anymore. To be honest, I don't know why this is happening. Any help?