react-native/Examples/UIExplorer
Nick Lockwood 88ac40666c Replaced RegExp method parser with recursive descent
Summary:
public

This diff replaces the RegEx module method parser with a handwritten recursive descent parser that's faster and easier to maintain.

The new parser is ~8 times faster when tested on the UIManager.managerChildren() method, and uses ~1/10 as much RAM.

The new parser also supports lightweight generics, and is more tolerant of white space.

(This means that you now can – and should – use types like `NSArray<NSString *> *` for your exported properties and method arguments, instead of `NSStringArray`).

Reviewed By: jspahrsummers

Differential Revision: D2736636

fb-gh-sync-id: f6a11431935fa8acc8ac36f3471032ec9a1c8490
2015-12-10 10:12:29 -08:00
..
AnimatedGratuitousApp [RN] New AnimationExample 2015-09-03 12:52:56 -08:00
Navigator Fix 16 linter warnings in Examples/ 2015-10-16 04:03:23 -07:00
Thumbnails Fixed zero-size images 2015-11-18 15:23:30 -08:00
UIExplorer Refactored module access to allow for lazy loading 2015-11-25 04:49:45 -08:00
UIExplorer.xcodeproj added method to set thumb image 2015-11-24 16:10:04 -08:00
UIExplorerIntegrationTests added method to set thumb image 2015-11-24 16:10:04 -08:00
UIExplorerUnitTests Replaced RegExp method parser with recursive descent 2015-12-10 10:12:29 -08:00
android/app add permission for android geolocation example 2015-12-03 06:27:24 -08:00
AccessibilityAndroidExample.android.js Release React Native for Android 2015-09-14 18:13:39 +01:00
AccessibilityIOSExample.js Fix 16 linter warnings in Examples/ 2015-10-16 04:03:23 -07:00
ActionSheetIOSExample.js Add tintColor for buttons. 2015-12-09 05:19:25 -08:00
ActivityIndicatorIOSExample.js
AdSupportIOSExample.js
AlertIOSExample.js Add secure and login-password types to AlertIOS. 2015-11-30 19:51:41 -08:00
AnimatedExample.js [RN] New AnimationExample 2015-09-03 12:52:56 -08:00
AppStateIOSExample.js Fix 16 linter warnings in Examples/ 2015-10-16 04:03:23 -07:00
AssetScaledImageExample.js
AsyncStorageExample.js
BorderExample.js Added support for #rgba and #rrggbbaa colors 2015-11-09 08:02:46 -08:00
CameraRollExample.ios.js
CameraRollView.ios.js
ClipboardExample.js add Clipboard component for ios and android 2015-12-09 10:04:21 -08:00
DatePickerIOSExample.js
ExampleTypes.js React native fixups 2015-09-18 10:36:24 -07:00
GeolocationExample.js Fix errors uncovered by v0.19.0 2015-12-01 20:11:26 -08:00
ImageCapInsetsExample.js
ImageEditingExample.js Wrapped UIManager native module for better abstraction 2015-11-27 07:00:32 -08:00
ImageExample.js Fix errors uncovered by v0.19.0 2015-12-01 20:11:26 -08:00
IntentAndroidExample.android.js Open source IntentAndroid 2015-11-12 12:41:32 -08:00
LayoutEventsExample.js Fix errors uncovered by v0.19.0 2015-12-01 20:11:26 -08:00
LayoutExample.js
ListViewExample.js THUMB_URLS of Examples are fixed. Issue #4159 2015-11-17 08:50:33 -08:00
ListViewGridLayoutExample.js THUMB_URLS of Examples are fixed. Issue #4159 2015-11-17 08:50:33 -08:00
ListViewPagingExample.js LayoutAnimation support for Android RN 2015-12-01 19:06:32 -08:00
MapViewExample.js Fix errors uncovered by v0.19.0 2015-12-01 20:11:26 -08:00
ModalExample.js Make <Modal> visible by default 2015-10-30 17:09:27 -07:00
NavigatorIOSColorsExample.js Fix one warning 2015-09-30 21:02:25 -07:00
NavigatorIOSExample.js
NetInfoExample.js Don't use arrow functions with Flow types to fix website generation 2015-12-09 14:56:40 -08:00
PanResponderExample.js Fix errors uncovered by v0.19.0 2015-12-01 20:11:26 -08:00
PickerIOSExample.js Fix PickerIOSExample 2015-12-08 13:48:28 -08:00
PointerEventsExample.js Better text descriptions for examples 2015-09-15 14:55:27 -07:00
ProgressBarAndroidExample.android.js Support progress in ProgressBarAndroid 2015-11-06 12:08:29 -08:00
ProgressViewIOSExample.js
PullToRefreshViewAndroidExample.android.js Rename PullToRefreshLayoutAndroid -> PullToRefreshViewAndroid 2015-12-07 08:33:25 -08:00
PushNotificationIOSExample.js
RCTRootViewIOSExample.js RN: Revamp YellowBox for Warnings 2015-11-20 13:09:16 -08:00
README.md Add git clone step to READMEs 2015-11-16 22:55:45 -05:00
ScrollViewExample.js Fixes #3060 2015-10-02 14:32:23 -07:00
ScrollViewSimpleExample.js Get back 100% in sync with fb codebase 2015-09-16 10:30:53 -07:00
SegmentedControlIOSExample.js
SetPropertiesExampleApp.js 'Update app properties in runtime' UIExplorer demo 2015-11-12 11:43:34 -08:00
SliderIOSExample.js added method to set thumb image 2015-11-24 16:10:04 -08:00
StatusBarIOSExample.js
SwitchAndroidExample.android.js Fix 16 linter warnings in Examples/ 2015-10-16 04:03:23 -07:00
SwitchIOSExample.js Fix 16 linter warnings in Examples/ 2015-10-16 04:03:23 -07:00
TabBarIOSExample.js Managed assets support for RCTConvert 2015-09-29 09:21:39 -07:00
TextExample.android.js Initial checkin for Image within Text nodes 2015-11-13 11:16:27 -08:00
TextExample.ios.js Simplify opaque nested Text UIExplorer example 2015-11-04 08:55:42 -08:00
TextInputExample.android.js implement android maxlength prop 2015-11-06 13:25:34 -08:00
TextInputExample.ios.js Added blurOnSubmit support to multine TextInput (aka RCTTextView) 2015-12-02 08:16:27 -08:00
TimerExample.js Fix 16 linter warnings in Examples/ 2015-10-16 04:03:23 -07:00
ToastAndroidExample.android.js Fix typos in example descriptions. 2015-10-20 04:38:21 -07:00
ToolbarAndroidExample.android.js Allow for styling of ToolbarAndroid's overflow icon 2015-10-22 04:43:25 -07:00
TouchableExample.js Better text descriptions for examples 2015-09-15 14:55:27 -07:00
TransformExample.js
TransparentHitTestExample.js Hit testing now treats views with 0.0 opacity as interactable 2015-10-30 04:14:25 -07:00
UIExplorerApp.android.js Release React Native for Android 2015-09-14 18:13:39 +01:00
UIExplorerApp.ios.js 'RCTRootView's size flexibility' UIExplorer demo 2015-11-12 11:43:43 -08:00
UIExplorerBlock.js
UIExplorerButton.js Add Timer example 2015-09-11 02:00:31 -07:00
UIExplorerList.android.js add Clipboard component for ios and android 2015-12-09 10:04:21 -08:00
UIExplorerList.ios.js add Clipboard component for ios and android 2015-12-09 10:04:21 -08:00
UIExplorerListBase.js Fix errors uncovered by v0.19.0 2015-12-01 20:11:26 -08:00
UIExplorerPage.js
UIExplorerTitle.js
VibrationIOSExample.js
ViewExample.js Better text descriptions for examples 2015-09-15 14:55:27 -07:00
ViewPagerAndroidExample.android.js Add setPageWithoutAnimation 2015-11-13 08:05:27 -08:00
WebViewExample.js Exporting a synchronous UIWebView to JS 2015-11-04 08:44:29 -08:00
XHRExample.android.js Support cookies on Android 2015-11-23 03:21:31 -08:00
XHRExample.ios.js Add response headers to XHR response 2015-10-30 11:23:25 -07:00
XHRExampleCookies.js Support cookies on Android 2015-11-23 03:21:31 -08:00
XHRExampleHeaders.js Fix errors uncovered by v0.19.0 2015-12-01 20:11:26 -08:00
bunny.png add remote image support to toolbar 2015-09-30 09:21:27 -07:00
createExamplePage.js [ReactNative][SyncDiff] Add option to make examples platform specific 2015-09-01 04:56:05 -08:00
flux@3x.png Managed assets support for RCTConvert 2015-09-29 09:21:39 -07:00
hawk.png add remote image support to toolbar 2015-09-30 09:21:27 -07:00
uie_thumb_big.png added method to set thumb image 2015-11-24 16:10:04 -08:00

README.md

UIExplorer

The UIExplorer is a sample app that showcases React Native views and modules.

Running this app

Before running the app, make sure you ran:

git clone https://github.com/facebook/react-native.git
cd react-native
npm install

Running on iOS

Mac OS and Xcode are required.

  • Open Examples/UIExplorer/UIExplorer.xcodeproj in Xcode
  • Hit the Run button

See Running on device if you want to use a physical device.

Running on Android

You'll need to have all the prerequisites (SDK, NDK) for Building React Native installed.

Start an Android emulator (Genymotion is recommended).

cd react-native
./gradlew :Examples:UIExplorer:android:app:installDebug
./packager/packager.sh

Note: Building for the first time can take a while.

Open the UIExplorer app in your emulator.

See Running on Device in case you want to use a physical device.

Built from source

Building the app on both iOS and Android means building the React Native framework from source. This way you're running the latest native and JS code the way you see it in your clone of the github repo.

This is different from apps created using react-native init which have a dependency on a specific version of React Native JS and native code, declared in a package.json file (and build.gradle for Android apps).