Skip to content
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

Migrate code into Typescript #411

Merged
merged 5 commits into from
May 24, 2022
Merged

Migrate code into Typescript #411

merged 5 commits into from
May 24, 2022

Conversation

Jianrong-Yu
Copy link
Contributor

Similar to #169, I tried to migrate everything to TypeScript in this PR.

Some changes:

  • Vite is replaced to tsc to generate both ESM and CommonJS package

@vercel
Copy link

vercel bot commented May 17, 2022

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated
react-stick ✅ Ready (Inspect) Visit Preview May 24, 2022 at 4:47PM (UTC)

@codecov-commenter
Copy link

codecov-commenter commented May 17, 2022

Codecov Report

Merging #411 (8c6533d) into master (de83389) will decrease coverage by 5.16%.
The diff coverage is 91.17%.

@@            Coverage Diff             @@
##           master     #411      +/-   ##
==========================================
- Coverage   96.09%   90.93%   -5.17%     
==========================================
  Files          13       13              
  Lines         282      309      +27     
  Branches        0       92      +92     
==========================================
+ Hits          271      281      +10     
- Misses         11       17       +6     
- Partials        0       11      +11     
Impacted Files Coverage Δ
src/defaultPosition.ts 100.00% <ø> (ø)
src/utils/fit.ts 100.00% <ø> (ø)
src/utils/getDefaultAlign.ts 100.00% <ø> (ø)
src/utils/getModifiers.ts 66.66% <ø> (ø)
src/utils/scroll.ts 50.00% <ø> (ø)
src/utils/uniqueId.ts 100.00% <ø> (ø)
src/hooks/useAutoFlip.ts 97.10% <80.00%> (ø)
src/StickPortal.tsx 83.72% <83.33%> (ø)
src/Stick.tsx 92.77% <100.00%> (ø)
src/StickContext.ts 100.00% <100.00%> (ø)
... and 9 more

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 191c0d6...8c6533d. Read the comment docs.

@crecotun
Copy link
Contributor

Hi @Jianrong-Yu
Thank you for doing this.
Would you mind making sure this is going to be marked as Breaking Change and result in a major version update?

@tzimmermann
Copy link
Contributor

Just published this as 5.0.0-rc1 under next tag on NPM: https://www.npmjs.com/package/react-stick/v/5.0.0-rc1
To test in your app, use npm install --save react-stick@next

@tzimmermann
Copy link
Contributor

I've checked so far

  • Prettier & Eslint commit hooks are working as expected.
  • Usage of 5.0.0-rc1 in our app (pex-client) and in glucose works as expected.
  • Compared the sample HTML pages and could not spot any differences to master.

What I haven't checked:

  • All the JS->TS transformations (I am no TS expert). Does it even make sense to review them, or did you generate them with flowts @Jianrong-Yu ?

@crecotun
Copy link
Contributor

I am not sure about replacing Vite with tsc.
My idea was to move our demos from webpack to Vite.
Vite does support TypeScript out of the box, so replacing the existing functionality simply doesn't bring any value.
I'd consider reverting this change.
What do you think @tzimmermann @Jianrong-Yu ?

.vscode/extensions.json Show resolved Hide resolved
"prettier.semi": false,
"prettier.singleQuote": true,
"prettier.trailingComma": "es5"
"editor.formatOnSave": true,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This one, ideally, too

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You mean editor.formatOnSave one? Or prettier config moved to eslint?
We can remove formatOnSave if you don't like it. The format will be fixed by lint-staged when the code is committing anyway.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, I should provide more context here.

All the editor settings that you're adding will change the developer's IDE normal behavior and I usually tend to avoid doing this as everyone has their preferences.

What we can do and we already are doing — add some pre-commit hooks to ensure code passes eslint and prettier.

And it's not fair to add settings for vscode, and completely ignore WebStorm, for example. Having settings for all IDE will just pollute the project.

What do you think?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, I should provide more context here.

All the editor settings that you're adding will change the developer's IDE normal behavior and I usually tend to avoid doing this as everyone has their preferences.

What we can do and we already are doing — add some pre-commit hooks to ensure code passes eslint and prettier.

And it's not fair to add settings for vscode, and completely ignore WebStorm, for example. Having settings for all IDE will just pollute the project.

What do you think?

@crecotun I agree it's not fair to have settings for vscode only, but since vscode is almost the de facto editor in front-end community, I think it's good to have the vscode only settings. The Typescript is also opinionated, but it's also the de facto javascript static typing solution now: the developers are still able to use react-stick in Javascript, but they will get better support if they are using Typescript; just like users of VSCode will get more support, but the users of other editor will still get the formatting by Husky and Lint-staged in committing.
BTW, the vscode settings.json is already there before this PR, I just added a few new items in it.

@Jianrong-Yu
Copy link
Contributor Author

What I haven't checked:

  • All the JS->TS transformations (I am no TS expert). Does it even make sense to review them, or did you generate them with flowts @Jianrong-Yu ?

Hi @tzimmermann Yes the type is guaranteed by flowts, the only change on type is the StickPropsT now have also all the attributes of an HTMLElement (like onMouseEnter and onMouseLeave used in demo/src/regressions/StickOnHover.tsx). It's because I found the ...rest always passed to the container:

    <Component
      {...rest}
      {...styles}

Hi @Jianrong-Yu Thank you for doing this. Would you mind making sure this is going to be marked as Breaking Change and result in a major version update?

Hi @crecotun The API didn't change, so from the aspect of users there is no breaking change for react-stick.

I am not sure about replacing Vite with tsc. My idea was to move our demos from webpack to Vite. Vite does support TypeScript out of the box, so replacing the existing functionality simply doesn't bring any value. I'd consider reverting this change. What do you think @tzimmermann @Jianrong-Yu ?

  • Bundling: I tried Typescript in Vite before I replaced it with tsc. Vite itself will not do the bundling for package; the bundling is done by rollup. To make the rollup working for typescript, plugin @rollup/plugin-typescript must be installed and put in the Vite configuration. Since it can be done just by using tsc, why choose another tool wrapped twice to do almose the same thing?
  • Testing: Testing must be done by Karma since it's the best choice for the unit-tests in a real browser. Jest is not working well in this case. And webpack with babel is the only combination I tried successfully on TypeScript/Coverage support in Karma, so webpack and babel (used in tests/karma.conf.js) are also required.
  • Demo: Since the webpack is required by testing, I don't think it's a good idea to migrate Demo into Vite. We always need webpack so why not reuse it in Demo?

@@ -0,0 +1,13 @@
{
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I believe this shouldn't end up in the codebase

"prettier.semi": false,
"prettier.singleQuote": true,
"prettier.trailingComma": "es5"
"editor.formatOnSave": true,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, I should provide more context here.

All the editor settings that you're adding will change the developer's IDE normal behavior and I usually tend to avoid doing this as everyone has their preferences.

What we can do and we already are doing — add some pre-commit hooks to ensure code passes eslint and prettier.

And it's not fair to add settings for vscode, and completely ignore WebStorm, for example. Having settings for all IDE will just pollute the project.

What do you think?

@crecotun
Copy link
Contributor

@Jianrong-Yu I wouldn't agree that for users there was no change, you replaced Flow with TypeScript, so end-user is affected and this is a major change. I might be wrong here.

Regarding the webpack.
Yes, it does make sense. I wasn't aware that for making it work with rollup we have to install an additional plugin.
So I'd say yes, we can live with webpack and tsc compiler as long as they do their job.

Testing.
One thing to mention here, I'd consider moving from Karma to Cypress + Jest if that makes sense. Cypress allows testing components in isolation.

@Jianrong-Yu
Copy link
Contributor Author

Jianrong-Yu commented May 18, 2022

@Jianrong-Yu I wouldn't agree that for users there was no change, you replaced Flow with TypeScript, so end-user is affected and this is a major change. I might be wrong here.

@crecotun Yes, I agree there are some breaking changes. The .flow files will not be generated anymore and old projects written in flowJs will lose the typing protection. It should be a major version update with breaking change notice for the flowjs users. Thanks @tzimmermann released it in beta tag.

Testing. One thing to mention here, I'd consider moving from Karma to Cypress + Jest if that makes sense. Cypress allows testing components in isolation.

It's a good idea to move the cases from Karma to Cypress (I'm not sure if Cypress is able to work with jest), Since it may changes the testing cases a lot, I didn't try it in this PR, we should try it later.

crecotun
crecotun previously approved these changes May 21, 2022
@Jianrong-Yu
Copy link
Contributor Author

@crecotun @tzimmermann commitlint is added in these new commits, can you do a review on them? Thanks.

BTW should I merge this PR once it's approved? The version number will be jump to 5.0 since it's a breaking change on typing.

@crecotun
Copy link
Contributor

@Jianrong-Yu Could you explain why you added commitlint to the circleci?

@Jianrong-Yu
Copy link
Contributor Author

@Jianrong-Yu Could you explain why you added commitlint to the circleci?

@crecotun I found all my old commits did't meet the requirements of semantic-release but it passed the circleCI check, I think it's better to have this check in CI so the developer will get notification for the comment if it's not met the requirement. The husky with lint-staged is useful for developers to push changes on local env but it cannot notify the user for any change done on Github web site directly.
If you think it's a bit overkill, I'll revert the change on circleCI.

@crecotun
Copy link
Contributor

@Jianrong-Yu I'd rather keep this pr about TS only and if you don't mind, create another PR with commit lint improvements.
Would that work for you?

@Jianrong-Yu
Copy link
Contributor Author

@Jianrong-Yu I'd rather keep this pr about TS only and if you don't mind, create another PR with commit lint improvements. Would that work for you?

@crecotun I agree we should avoid introducing new things into this PR. I've reset it to the commit before commitlint and did a force push. Sorry a new approval is required since the branch is updated 😂

@Jianrong-Yu Jianrong-Yu merged commit f5ce353 into master May 24, 2022
@Jianrong-Yu Jianrong-Yu deleted the migrate/typescript branch May 24, 2022 16:54
@pex-bot
Copy link
Collaborator

pex-bot commented May 24, 2022

🎉 This PR is included in version 5.0.0 🎉

The release is available on:

Your semantic-release bot 📦🚀

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants