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

Documentation: add a more detailed guide for react native development #35529

Merged
merged 5 commits into from
Oct 28, 2021

Conversation

gwwar
Copy link
Contributor

@gwwar gwwar commented Oct 11, 2021

This PR adds some clearer first time setup instructions for react native development. I'd also be open to moving this to a separate how-to-guide, if we'd like to keep the current doc brief.

I also have images and video assets I can link to (really necessary for some of the android studio screens) but I'd be interested in knowing where the best place to add this would be. I do see an assets folder, but we probably don't want to add image/videos to the repository to avoid bloating repository size.

Testing Instructions

  • Verify that instructions are clear
  • If you don't have native development going locally, give the instructions a try!

@gwwar gwwar added [Type] Enhancement A suggestion for improvement. [Type] Developer Documentation Documentation for developers labels Oct 11, 2021
@gwwar gwwar requested review from mkaz and cameronvoell October 11, 2021 22:26
@gwwar gwwar self-assigned this Oct 11, 2021
@gwwar gwwar force-pushed the update/react-native-instructions branch from 8f4a03f to 555deb6 Compare October 11, 2021 22:34
@gziolo gziolo requested a review from hypest October 12, 2021 10:21
@gziolo gziolo added the Mobile App - i.e. Android or iOS Native mobile impl of the block editor. (Note: used in scripts, ping mobile folks to change) label Oct 12, 2021
@SiobhyB SiobhyB self-requested a review October 12, 2021 10:39
@hypest
Copy link
Contributor

hypest commented Oct 12, 2021

Thanks for the ping @gziolo and yeah, thanks for opening this ticket @gwwar !

Let me reel in @SiobhyB that has some recent interest in the topic. 👍

@gwwar
Copy link
Contributor Author

gwwar commented Oct 12, 2021

So chatting with @mkaz it sounds like it's not ideal to add image/video assets to the Gutenberg repository (since it'll bloat the repository). One way we can work around this is to add these assets to the media library of one of the WordPress.org blogs.

Let me know if folks prefer keeping this as one setup doc, or if it'd be more ideal to make a separate how to article. And of course if there are simpler steps or if I mis-noted anything! For Android setup in particular it took me quite a while to figure out the right path arguments.

@SiobhyB
Copy link
Contributor

SiobhyB commented Oct 12, 2021

Wow, this is all so detailed and awesome, thank you for the time putting it together @gwwar 🙇‍♀️

I like your thoughts on splitting this off into a separate doc. It feels a bit hard to parse at the length it is now and there's a chance not everyone getting set up is going to need these steps (for example, a new contributor already working with React Native will probably have gone through them). We'd also want to link to these detailed steps from the Gutenberg Mobile repository's README.

So, all in all, a separate doc with only these steps seems like the best move to me. If you agree with that reasoning, let me know if I can help with any part of separating this out and I'll be happy to review again when it's done :)

@gwwar
Copy link
Contributor Author

gwwar commented Oct 14, 2021

Reserving this comment for assets. Folks are welcome to contribute better quality ones. If folks agree, we'll want to add these to the media library of one of the wp.org blogs, then link to them in the how to guide.

cleanshot-2021-10-07-at-15 32 34402x

cleanshot-2021-10-07-at-15 20 02402x

CleanShot.2021-10-14.at.15.38.04.mp4

package-manager

show package details

screen-shot-2021-04-29-at-3 25 57-pm

screen-shot-2021-04-29-at-4 53 19-pm

screen-shot-2021-04-29-at-4 56 24-pm

avd

screen-shot-2021-04-30-at-8 16 03-am

screen-shot-2021-04-30-at-8 16 53-am

screen-shot-2021-04-30-at-8 17 09-am

screen-shot-2021-04-30-at-8 20 58-am

android_mp4_hd_1080p.mp4

screen-shot-2021-04-30-at-8 41 54-am

ios-e2e_mp4_hd_1080p.mp4

screen-shot-2021-04-30-at-8 50 11-am

android-e2e

@gwwar
Copy link
Contributor Author

gwwar commented Oct 14, 2021

@SiobhyB sounds good, I've moved instructions into a how-to guide in aea287c

Let me know if any of the instructions are incorrect or if we should clarify wording!

in our terminal, or `.bash_profile` if the terminal is still using bash.

```sh
export JAVA_HOME=/Applications/Android\ Studio.app/Contents/jre/jdk/Contents/Home
Copy link
Contributor Author

Choose a reason for hiding this comment

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

Reminder to note that this changed to a slightly different path in Arctic Fox

export JAVA_HOME="/Applications/Android Studio.app/Contents/jre/Contents/Home"

Copy link
Contributor

@SiobhyB SiobhyB left a comment

Choose a reason for hiding this comment

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

Thanks again for all the work on this @gwwar, I've added a few small comments/suggestions throughout, but it generally all looks excellent 🙇‍♀️


```sh
export JAVA_HOME=/Applications/Android\ Studio.app/Contents/jre/jdk/Contents/Home
export ANDROID_HOME=/Users/{your-username}/Library/Android/sdk
Copy link
Contributor

Choose a reason for hiding this comment

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

@gwwar, I'm curious whether the following paths also work for you? These are what I have in my ~/.zshrc file, which I got from the React Native docs::

export ANDROID_HOME=$HOME/Android/Sdk
export PATH=$PATH:$ANDROID_HOME/emulator
export PATH=$PATH:$ANDROID_HOME/tools
export PATH=$PATH:$ANDROID_HOME/tools/bin
export PATH=$PATH:$ANDROID_HOME/platform-tools

As those are directly from the official docs, I'd lean towards using them, but let me know if they don't work as expected for you.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

They don't, but let me see if there's a way to consistently install in that directory.

Also is there a smarter way to install needed packages? I had to lookup needed items in the build.gradle file.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

So I do like the updated paths relative to $HOME 👍 I left a note inline on where the SDK home location can be modified. By default a new install on OSX will recommend $HOME/Library/Android/sdk

I also had to set JAVA_HOME. I pointed this at what comes with Android studio which is convenient. If there's a better alternative, I'm open to changes.

One other note is that I have a working environment on my Intel Mac but not my new M1. Currently getting stuck here with this trace:
CleanShot 2021-10-25 at 15 41 53@2x

Copy link
Contributor

Choose a reason for hiding this comment

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

Also is there a smarter way to install needed packages? I had to lookup needed items in the build.gradle file.

I'm afraid the only way I'm aware of is manually looking up the needed packages (I did that through the docs in my case, but your approach is also valid). I had a quick search to see if there were perhaps any Android Studio plugins to automate the process, but wasn't able to find anything.

One other note is that I have a working environment on my Intel Mac but not my new M1. Currently getting stuck here with this trace

@twstokes also ran into some problems running the demo app on an M1 and found he needed to install Platform S packages. These were the specific steps here shared:

  • In Android Studio, go to Preferences -> Appearance & Behavior -> System Settings -> Android SDK.
  • Check “Show Package Details” at the bottom right.
  • If not already selected, under “Android S Preview” check:
    • Android SDK Platform S
    • Google APIs ARM 64
    • Google Play ARM 64
  • Click OK.

And a screenshot of his settings:

screen-shot-2021-07-03-at-12 58 02

Another issue that Tanner came across is a bug that prevents the Android emulator from loading. This was in May, so hopefully, there will have been a fix by now. If not, Tanner followed the workaround outlined in this Medium article.

I don't have an M1 but, if installing the Platform S packages doesn't get things working for you, we could see if Tanner or others on the project have further ideas here. Let me know how it goes! (and thank you again for all the work documenting this!)

Copy link
Contributor

Choose a reason for hiding this comment

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

Noting for posterity that, following #36007 and the comment here #36007 (review), it doesn't seem like separate instructions for M1 are now necessary. 🎉

Copy link
Contributor

@SiobhyB SiobhyB left a comment

Choose a reason for hiding this comment

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

This all looks good to me @gwwar, pending the updated references to the images you've suggested in your previous comment :)

@gwwar gwwar force-pushed the update/react-native-instructions branch from ada0609 to 04b03b2 Compare October 27, 2021 22:44
@gwwar
Copy link
Contributor Author

gwwar commented Oct 27, 2021

Thanks @SiobhyB! I've also added image assets in 04b03b2

cc @mkaz did you have any recommendations on formatting/readme location or does this look ok to land?

@mkaz
Copy link
Member

mkaz commented Oct 28, 2021

Looks great! Thanks so much for the updates, it'll make it easier to get more people started and involved 👍

Can we rename the file to: osx-setup-guide.md ?
Since it still applies even if it's not your first time, makes for a slightly cleaner URL.

Also, you will need to add an entry to docs/toc.json (see existing for syntax) and run npm run docs:build and commit the generated manifest.json file.

I suppose it doesn't quite matter where in the How to Guides section of the toc.json list. I'm trying to get it in alphabetical order (#35904). I'll rebase and fix that ticket if yours goes in first.

@gwwar
Copy link
Contributor Author

gwwar commented Oct 28, 2021

Ah I knew I must have been missing something! Thanks @mkaz! updated in fbb0285

@mkaz
Copy link
Member

mkaz commented Oct 28, 2021

I just realized, since it's a new directory you may also want a README.md, I'm not really sure what it will do without. I'm ok with trying it as it is and we can add a README if needed.

@gwwar
Copy link
Contributor Author

gwwar commented Oct 28, 2021

Sure we can try as is, and see if we need to add an additional README.md as a follow up.

@gwwar
Copy link
Contributor Author

gwwar commented Oct 28, 2021

Going to rebase to see if unit test issues resolve themselves

@gwwar gwwar force-pushed the update/react-native-instructions branch from fbb0285 to 91ca5f3 Compare October 28, 2021 20:09
@gwwar gwwar merged commit 4ea8ae9 into trunk Oct 28, 2021
@gwwar gwwar deleted the update/react-native-instructions branch October 28, 2021 23:29
@github-actions github-actions bot added this to the Gutenberg 11.9 milestone Oct 28, 2021
@gwwar
Copy link
Contributor Author

gwwar commented Oct 28, 2021

Thanks for the reviews @SiobhyB @mkaz !

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Mobile App - i.e. Android or iOS Native mobile impl of the block editor. (Note: used in scripts, ping mobile folks to change) [Type] Developer Documentation Documentation for developers [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants