Provides a look at example code for how to embed Tableau visualizations inside of a React Native app that runs on iOS and Android.
The 2019 Tableau Conference included a session on the Mobile App Bootstrap as did the 2018 Tableau Conference. The sessions outline some business use cases and provide some more technical background. The session video and slides are available from those TC pages.
Mac:
- Download the code for the app from the github repository
- Install Visual Studio Code
- VS Code is the main IDE we use for React Native development; it's where you'll do most of your editing.
- Install Xcode for creating iOS builds
- Install Android Studio for creating Android builds
- You might need these added to your
~/.bash_profile
:export ANDROID_HOME=$HOME/Library/Android/sdk
export PATH="$PATH:$ANDROID_HOME/platform-tools:$ANDROID_HOME/tools"
- Install homebrew
brew install node
- This uses homebrew to install node
brew install watchman
- watchman enables some fun auto-reload-on-file-change capabilities in React Native
npm install -g react-native-cli
- This installs the React Native Command Line Interface
Windows:
- Download the code for the app from the github repository
- Install Visual Studio Code
- VS Code is the main IDE we use for React Native development; it's where you'll do most of your editing.
- Follow Step 1 and Step 2 in these excellent Windows installation instructions
Note that we've run into problems running watchman on Windows, so the auto-reload functionality won't be available. Also note that iOS building/running is only possible on a Mac. We do almost all of our mobile development using Macs.
From the Mobile_App_Bootstrap
directory, run npm install
- This installs the various modules needed into a
node_modules
directory.
iOS
cd ios
,pod install
,cd ..
will install the native iOS cocoapods libraries needed by the libraries included innode_modules
.react-native run-ios
runs the iOS build in the default simulator.react-native run-ios --simulator="MySimulatorName"
will run the iOS build using the simulator you specify.- More details on specifying simulators
- List of available simulators:
xcrun simctl list
- Example to create your own named simulator for an iPad Air 2 running iOS 11.3:
xcrun simctl create MySimulatorName com.apple.CoreSimulator.SimDeviceType.iPad-Air-2 com.apple.CoreSimulator.SimRuntime.iOS-11-3
- ⌘-d in the iOS simulator brings up the React Native debug menu.
Android
- Run an AVD (Android Virtual Device) emulator. This could be started via Android Studio (Tools -> AVD Manager) or the command line
react-native run-android
runs the Android build- ⌘-m in the Android emulator brings up the React Native debug menu.
For running on a physical iOS/Android device, take a look at the docs for the subtleties involved.
React Native has some great debugging documentation, it's well worth reading through. A common setup for us is to have the standalone React Developer Tools running and the simulator with Live Reload and Hot Reloading turned on.
The main app files you'll want to edit are in src
. The app uses React Navigation to provide the bottom tab navigation.
The core of this project was created using create-react-native-app
, as outlined in the React Native Getting Started docs. After the app was made, it was "ejected" and modified.
Home.js
shows the Home tab. A tap on one of the cards opens a CardDetails object, displaying the provided URL in a webview.Viz1.js
,Viz2.js
,Viz3.js
show the three viz tabs. They open the hard-coded URLs provided. Note that WKWebView is used behind the scenes on iOS, while the default WebView is used on Android. You'll want to change these URLs to point to your own vizzes.router.js
configures the bottom tabs using React Navigation.
The sample URLs use several query parameters which are especially helpful for mobile embedded vizzes:
:embed=y
: Requests the embedded version of the viz, without the server navigation UI.:tooltip=n
: Removes tooltips. Used in this demo to keep the user on the viz.:toolbar=n
: Removes the viz toolbar.:showVizHome=no
: Used in this demo to not show Tableau Public home information. Unnecessary when connecting to servers not named Tableau Public.:mobile=y
: Explicitly requests a touch-friendly UI, rather than relying on Tableau Server's User-Agent sniffing.:showAppBanner=n
: Removes the "Open in Tableau Public" banner at the top of the viz.
This collection is supported by the community and not officially 'blessed' by Tableau Engineering or Support. What does that mean? We didn't have a QA team test it. It's a tool for learning how to embed vizzes inside a mobile application. You should not expect that there are 0 bugs.
If you have problems getting it to work, feel free to email us with questions, but we can't promise quick responses. The Tableau Developer Community is also a great resource if you need help.
A standard disclaimer: mobile-app-bootstrap-react-native is made available AS-IS with no support and no warranty whatsoever. Despite efforts to write good and useful code there may be bugs that cause unexpected and undesirable behavior. The software is strictly “use at your own risk.”
The good news: This is intended to be a self-service tool. You are free to modify it in any way to meet your needs.