Coder Social home page Coder Social logo

react-native-community / upgrade-helper Goto Github PK

View Code? Open in Web Editor NEW
3.6K 24.0 109.0 38.66 MB

⚛️ A web tool to support React Native developers in upgrading their apps.

Home Page: https://react-native-community.github.io/upgrade-helper

License: MIT License

HTML 1.11% CSS 0.34% JavaScript 1.93% Dockerfile 0.17% TypeScript 96.46%
react-native react upgrade-tool rn-diff rn-diff-purge

upgrade-helper's People

Contributors

acoates-ms avatar benomatis avatar bethea28 avatar blakef avatar cortinico avatar craigramey avatar dependabot-preview[bot] avatar dependabot[bot] avatar fxamauri avatar iamrestrepo avatar jeanmsilva89 avatar jinuk-rarajob avatar jmporchet avatar kelset avatar limaaniceto avatar lucasbento avatar markrickert avatar matt-oakes avatar mausworks avatar mhmdaljefri avatar naturalclar avatar passerbyloo avatar pvinis avatar renovate-bot avatar shubh73 avatar szymonrybczak avatar ukcasso avatar vinnya3 avatar yfunk avatar zoontek avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

upgrade-helper's Issues

Diff doesn't show section changes / misleads on where changes appear

Bug

As screen in this screenshot, the context for the !debug.keystone change shows under the "# IntelliJ" section which is quite misleading. By looking at the line numbers you may notice that they are not linear - there is a jump from line 25 to 39. However there is no notice of this, so the context lines appears together with the wrong section header.

Screen Shot 2019-10-04 at 13 51 53

Since some changes are context sensitive, it may cause problems for people while upgrading. In this particular example (.gitignore) the context isn't important beyond readability and future upgrade diffs.

React Native versions

0.60.6 => 0.61.2

Screen Shot 2019-10-04 at 13 56 47

Steps to reproduce

  1. Open https://react-native-community.github.io/upgrade-helper/?from=0.60.6&to=0.61.2
  2. Scroll down to the diff of .gitignore
  3. See that "Android/IntelliJ" appears as the header for the Buck ignore changes.

Describe what you expected to happen:
There should be a visual divider or other visual clue when line numbers increment more than 1.

Line numbers are copied

Bug

When I copy code from the upgrade helper and paste it into my editor, the line numbers are also copied.

linenumbers

Info

Safari: 12.1.1 (14607.2.6.1.1)
VS Code: 1.36.1 (1.36.1)

Roadmap

With this issue I want to line up all the things that we are planning to do in a bullet point manners, so that we can sort of prioritise them and discuss/add/remove new ones.

Version 1

This version should be literally the barebone version, so that we can put it in front of the developers and have them start using it & provide feedback.

  • Improve README with useful information
  • Add a way to conclude diffs as when they are done (PR at #21) - @lucasbento
  • Add useful links section (pointing to a blog post or something like that) (PR at #24)
  • Handle binaries (add a way for the user to download them) #22 (PR at #24)

Version 2

This one should be the "super powered" version of 1, with more advanced features & cool extras.

  • Add comments on the diff (will be manually created by us, PR at #18) - @lucasbento
  • review the ant design / maybe change it?
  • add the versions in the url (shareability <3) #9

React Native 0.60.0 `xcodeproj` upgrade

Moved here: react-native-community/upgrade-support#14

--

For an easy upgrade experience of this file, do the following.

After all the other files have been upgraded, run yarn install and

cd ios
pod install
cd ..

This will cause all the Pods to be connected. After that, open the workspace file in the ios directory, called something like MyApp.xcworkspace

Screenshot 2019-07-03 at 16 07 01

This workspace contains your original project, as well as the Pods project. Expand your project and find the Libraries directory.

Screenshot 2019-07-03 at 16 07 16

Inside that, there are a few libraries related to React Native, and possibly other native modules from other libraries you might have connected.

Screenshot 2019-07-03 at 16 07 27

You can go ahead and remove the React Native related libraries from there, by selecting them and hitting the delete button. In the popup you get, you can select Remove references. If you select to Move it to Trash, you might need to run yarn install again.

Screenshot 2019-07-03 at 16 07 40

These libraries are not needed there anymore, since now they are connected using CocoaPods. You can do the same for other libraries that might exist in that directory, if they support CocoaPods. If they don't, keep them there for now.

After all this, your diff of that file should look roughly the same as the one right here. Don't worry too much if it doesn't match exactly, as your project might have more or fewer targets.

Try to see if the rough outline is the same, and of course make sure your project can build and run.

Test automatically on different browsers

Feature Request

We should test the website automatically on multiple browsers.

Why it is needed

With #51 being opened (thank you for this @KevinHu2014), it came to my attention that we should properly test the website on multiple browsers, the best way to do it would be to run a few tests automatically on CircleCI.

Possible implementation

We can use Cypress.io with CircleCI, we can also think about a few image snapshots to do image comparison, which is an easier way to get things going for now.

Apparently Cypress supports only Chrome, we may consider using Sauce Labs (where we can run on multiple browsers) and WebdriverIO together with wdio-image-comparison-service.

I recall seeing a tweet that now also had a plugin/extension for doing image comparison on PRs, let's see if I find more info about that.

make AppName warning better

Description

After #112, @lucasbento suggested some good changes:

  • Have it appear only after the diff has been rendered
  • Move it to be shown below the "Useful content" section
  • Have the same width as the useful content section to maintain consistency
  • Use "info" alert instead of "warning"
  • Add a comment on it that the app name can be changed in the settings (this would happen in #111 probably)

@Naturalclar, since you have worked on both of these, we would be very happy if you wanted to pick these ones up too 🙌

add the versions in the url (shareability <3)

Feature Request

We should have links like gh.com/purge?from=0.30&to=0.39 to allow for linking and history keeping.

Why it is needed

For sharability.

Possible implementation

Code sample

View full file contents

Feature request

Instead of viewing just the diff between different file version, why not just allow the user to view the full contents of the file? I.e. "view raw"

Why it is needed

Some diffs are just not that useful 🤷‍♀

For instance, the .flowconfig-file is (in my case) never manually edited. The diff is not very helpful in this case, because all I want is just the "new version of the file".

Possible implementation

Add a "view raw" or "view file" to the "header" of the diff.

image

remove snapshot tests

We should remove the snapshot tests, at least for the general places. we should keep snapshots for specific UI things in the diff, but it makes little sense to test the main part, since it changes relatively often with new notes etc.

Add analytics tracking

Feature Request

Previous version as purge-web had analytics tracking with react-ga, we should add this again in order to know how much traffic the app is getting.

Add download link to all files

Feature Request

Add download link to all files

Why it is needed

Sometime files can be replace directly (.flowconfig) or in case of new file (.eslintrc.js). Download and replace it would be faster.

Possible implementation

Add download link just like binary file

Add counter to show how many files have been completed

Feature Request

Idea initiated in #21, basically add a counter like 2/10 in the bottom right of the page to show how many files have been completed and how many are still left, the counter should show only after you complete at least one file.

Automate deployment

Feature Request

We should have automatic deployment of master, plus maybe PR deployments?

Comments not selected?

I don't know if this can be done, but we should have a way to have the comments not mess with selection and copy-pasting.

Some people write the code manually, and some copy-paste from the diff. If there is a comment or more in there, then they also get selected and copied. Is there a way to make the text of the comment not selectable so copy-paste works easily?

If not, should we maybe add a way to quickly toggle them on and off?

Diff for upgrading package.json to 0.61.3 suggests old versions

Bug

React Native 0.61.3 has a dependency on React 16.9.0 but the upgrade suggestions for 0.61.3 indicate we should use React 16.8.1 (and some other older dependencies)...

image

React Native versions

0.61.3

Steps to reproduce

Review the suggested diffs for 0.61.3 here

Describe what you expected to happen:

  1. expect the dependencies to be at least the same as 0.61.3 and same as react-native init produces

PS. sorry if I'm missing something obvious - this is my first attempt at using this tool. All assistance is greatly appreciated.

Renaming the project

Now that we are getting closer to having a v1 ready, I am starting to wonder if we shouldn't change the name of the repo to something that more clearly tells what it is about.

I was thinking to changing the name to upgrade-helper, what do you think?

(also, we need to improve a bit the README, I can take care of it)

Add unified diff option

Feature Request

Some people may prefer to see the diff unified like GitHub provides, we should offer an option to do so.

Move the file after it's completed

Feature Request

This is related and started at #10, basically the website needs to show the "completed" files below the uncompleted ones.

Why it is needed

It's easier this way to know which files are still left to be changed.

Possible implementation

Have two sections of file groups, one for completed and another for uncompleted.

The project already stores the IDs of the completed ones here.

Improve the checking of which release files to gather info

Feature Request

This issue was raised from #40, basically the current implementation to gather which release files should be shown is not good enough, it uses semver.gt & semver.lt as you can see here.

The most optimal way would be to treat each file name as a version range, so for instance, if you want to write comments for 0.60.x you create a 0.60.js file, if you need it specifically for 0.59.9 then you should create a 0.59.9.js and not 0.59.0.js as it is currently.

Why it is needed

Currently you can not have comments/useful links for specific patch releases or release candidates.

Possible implementation

Use semver.coerce and its comparison functions: https://github.com/npm/node-semver#comparison.

improving 0.60 upgrade notes

Based on this conversation on twitter, Nick & Ram (& others) want to help people upgrading to 0.60 avoiding the pitfalls they've fallen into.

The most helpful approach will likely be by adding inline comments - feature we added via #18 (but still needs to be properly documented, see #28) - so let's use this issue to coordinate about what to write where :)

(protip: we have also been using dedicated issues like #47 to give in-depth descriptions and linked that inline)

Show `rc` versions in the `from` dropdown

We show rc versions on the to dropdown until the final release is out.
After the final is out, if a user is on an rc version, they should be able to upgrade from that to the final.

Therefore we should show the rc versions on the from dropdown.

(If we want to minimize noise, we should only show the rcs of the latest version.)

Add Netlify to deploy on each PR

Feature Request

We should add and configure Netlify to deploy on each PR so we have an URL to preview the PR without having to do it manually and locally.

Possible implementation

We can base the config on react-native-website's and will only use it for PRs, we will remain using GitHub pages for master as we want to keep the URL under react-native-community.

Add a logo

Would be really nice to have a logo for the project :)

Consider renaming the app_name to match the RN template and simplify the diff

Feature Request

Currently the diff is made between an RN app named RnDiffApp and the RN template which has a different app_name/DisplayName of Hello App Display Name. When upgrading this shows as 2 additional diffs that are IMO not necessary, see the SS:

rn_upgrade_helper_app_name_diff

I propose we handle this name discrepancy so that it doesn’t show up in the diff.

Why it is needed

Every upgrade shows at least 2 diffs that will (always?) be ignored. This unnecessarily increases the cognitive load for each upgrade.

Possible implementation

I thought the change would be as simple as running react-native init „Hello App Display Name” but the projectName does not allow spaces. One solution that comes to mind is replacing RnDiffApp (which is a fairly specific string) with Hello App Display Name. However I’m not sure if we want to add this to the workflow.

Another option would be to submit a patch directly to https://github.com/facebook/react-native/tree/master/template and change the name to something like HelloWorld. This doesn’t feel right, though :)

Let me know if this makes sense and if you have better options on how to handle this.

Cleanup/Refactor Goal

Description

  • We need to refactor the code here, it has become too complex for such a simple project 😬, but I haven't had the time to do it myself yet. Basically I want to have a simple utility thing that fetches the releases, and then generates a list of the versions to be displayed. Then we will have the ui thing that will actually display all that. Then we can actually test the utility part, and the ui I don't care if we test.

  • Also, we need to make the notes/comments/links better. Currently, we can only comment inline on minor versions (as it 0.59.x), but if a file has been touched on 0.59.1 and reverted on 0.59.2, this comment is now broken. We need to make a better plan for this.

  • We got a great idea on twitter https://twitter.com/safaiyeh/status/1205969341969133568?s=20 about adding a text input field that the user can put their app name, and all instances of RnDiffApp will be replaced with that name. Sounds cool, helpful and easy, so let's do it.

  • Write a document about xcodeproj. I explained it in my talk, but I should also write a text and have it here so its easy to find. For now, general explanations are needed. No specific questions to make an FAQ or something.

  • Move to typescript 🙌

Add a "how to use" section

Feature Request

Working on facebook/react-native-website#1063 I noticed that we lack a "getting started"/"how to use" guide for the user to know what to do once they land on the page.

Why it is needed

So it's more clear to the user what they need to do with that beautiful diff that's showing in their browser.

Possible implementation

A button with a ? icon that opens a modal with some nice content about how to upgrade using Upgrade Helper, content can be based on facebook/react-native-website#1063.

Dark mode

We should add a dark mode, so we don't get blind.

Add eslint & prettier pre git hooks

Feature Request

I think it would be helpful to have a precommit / post hooks to run eslint and/or prettier

Why it is needed

This way, code that doesn't conform to repo style standards won't push. Also helps with automating linting & prettifying tasks.

Possible implementation

Use husky package to create pre hooks

Add link to file in diff for binary change

Feature Request

Add Link to File in Diff panel so file can be download which will be useful for binary file update

Why it is needed

For example when upgrade from 0.59.8 to 0.59.9. File android/gradle/wrapper/gradle-wrapper.jar was upgrade but no diff due to it's a binary file.
image

Possible implementation

Add link to file for example https://github.com/react-native-community/rn-diff-purge/raw/release/0.59.9/RnDiffApp/android/gradle/wrapper/gradle-wrapper.jar

Code sample

Add Podfile change for iOS

Every time, When I m try to upgrade to the new react native version, I would speed too many times to fix compilation environment, If we can provide the correct Podfile configuration for react-native dependency. This toolkit will be more usefully.

Configure ESLint and Prettier

Feature Request

Configure proper ESLint and Prettier, they both have their configs but should also be run on CircleCI together with the unit tests.

We already have the lint script but for some reason it's not picking up warnings/errors from Prettier.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.