react-codemod
Cycle.js
react-codemod | Cycle.js | |
---|---|---|
9 | 11 | |
4,059 | 10,235 | |
0.1% | -0.0% | |
3.2 | 4.1 | |
3 days ago | 5 months ago | |
JavaScript | TypeScript | |
MIT License | MIT License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
react-codemod
-
Converting class based components into functional ones
You can convert the “easy” render-only class components to function components using the pure-component codemod.
-
Front-end Guide
Developer Experience - There are a number of tools that improves the development experience with React. React Developer Tools is a browser extension that allows you to inspect your component, view and manipulate its props and state. Hot reloading with webpack allows you to view changes to your code in your browser, without you having to refresh the browser. Front end development involves a lot of tweaking code, saving and then refreshing the browser. Hot reloading helps you by eliminating the last step. When there are library updates, Facebook provides codemod scripts to help you migrate your code to the new APIs. This makes the upgrading process relatively pain-free. Kudos to the Facebook team for their dedication in making the development experience with React great.
-
A new way to ship Codemods
Like most popular libraries, e.g. React, Next.js and more, which provide codemods to help move their huge user base across versions, we needed a bespoke and fairly simple CLI wrapper of jscodeshift, that would provide a means of publishing, downloading and running codemods. So we created a custom 'codemod-cli', our first piece of internal codemod infrastructure.
-
React v18.0
If you'd like to migrate them, the React team maintains some awesome codemods:
https://github.com/reactjs/react-codemod
-
[AskJS] How do you release libraries updates with breaking changes?
Codemods - providing automated tooling to change old patterns to new ones can go a long way in helping drive adoption of the new version. The most notable example of doing this is react-codemod (many other examples exist)
-
All about Abstract Syntax Tree
Sometimes you need to migrate from one version of a library to another, for example, when React has updated to version 15.5 the PropTypes has moved to different package and the react-developers provides codemod for migration.
-
Modern JavaScript:Everything you missed over the last 10 years(ECMAScript 2020)
Can you point me towards examples of the usage of AST rewriting tools that are actively being used by open-source library maintainers in other ecosystems to help their consumers do upgrades in large code-bases (e.g. I can see that `clang` has AST tooling, but I don't see examples online of this being widely used: https://devblogs.microsoft.com/cppblog/exploring-clang-tooli...).
Within the JavaScript ecosystem this is quite popular (1. https://github.com/reactjs/react-codemod; 2. https://github.com/mui-org/material-ui/tree/HEAD/packages/ma... 3. https://github.com/emotion-js/emotion/tree/main/packages/esl... etc.) Teams that maintain huge codebases have tooling to safely automate their upgrades and the best library maintainers provide their consumers with these AST transformations.
> Don't tell that to anyone who uses
-
Introducing Astra: A Tool for Refactoring Java Programs at Scale
Agree. I know js has a similar tool, jscodeshift. https://github.com/reactjs/react-codemod and https://github.com/cpojer/js-codemod/tree/master/transforms have some ideas for js.
- React 17 DOM tree inside of React 16.2 DOM
Cycle.js
- Could angular possibly compile rxjs Ahead Of Time?
-
Can be the future of JSX be Functional first?
Seems like you might be interested in this
-
Front-end Guide
Cycle
-
[AskJS] Opinions In Favor of Coding Document Fragments in JS?
This is the standard way of going about things in Mithril and Cycle. Elm as well doesn't use an XML knockoff for view code- and as a fun fact, the original version of React didn't either.
- What is a really cool thing you would want to write in Rust but don't have enough time, energy or bravery for?
- Solid.js feels like what I always wanted React to be
-
callbag-rs: An implementation of the callbag spec
For example, an FRP framework (created by the same author who later wrote the callbag spec): https://cycle.js.org/
-
Does it make sense to use Scala.js/Laminar in the context of a startup?
TypeScript is relatively mainstream at this point, and I think that's good news. If you want to crank the type-safety and pure FP dials on it to 11, you certainly can do that. I have a project that I've based largely on this post, including the "hardcore" section. However, instead of Redux and otherwise plain React, I've chosen to use Cycle.js and the lessons from this post to use React in a very purely Functional Reactive Programming Way.
-
Flame: A PureScript front-end framework inspired by the Elm architecture
This post links to a PureScript project that is probably the easiest PS framework around.
ReScript + rescript-react is a good alternative. Less safe, waaaay more verbose; but backed by Facebook.
This is quite cute (in TypeScript though): https://github.com/cyclejs/cyclejs
And Yew is super cool, it goes the WASM route (in Rust): https://github.com/yewstack/yew
-
My Open Source Journey
From now on I was on what I would call a typical open source trajectory. I used the Cycle.js framework to rewrite my frontend and in that process I hit some walls. I eventually figured that the error was on my side and that I was just missing some information to avoid the error. To spare others the hours of debugging I started to contribute small patches to the documentation. At the same time I also found some missing features that I voiced in GitHub issues.
What are some alternatives?
jscodeshift - A JavaScript codemod toolkit.
RxJS - A reactive programming library for JavaScript
Acorn - A small, fast, JavaScript-based JavaScript parser
MobX - Simple, scalable state management.
react-gradual-upgrade-demo - Demonstration of how to gradually upgrade an app to a new version of React
Bacon - Functional reactive programming library for TypeScript and JavaScript
codemod-example - Codemod for my article: https://blog.paulcodes.tech/all-about-abstract-syntax-tree
Most.js - Ultra-high performance reactive programming
betaflight-configurator - Cross platform configuration tool for the Betaflight firmware
Cycle.js (react-native) - Cycle.js driver that uses React Native to render
js-codemod - Codemod scripts to transform code to next generation JS
Elm - Compiler for Elm, a functional language for reliable webapps.