/** * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @format * @flow */ 'use strict'; var React = require('react'); var ReactNative = require('react-native'); var {ActionSheetIOS, StyleSheet, takeSnapshot, Text, View} = ReactNative; var BUTTONS = ['Option 0', 'Option 1', 'Option 2', 'Delete', 'Cancel']; var DESTRUCTIVE_INDEX = 3; var CANCEL_INDEX = 4; class ActionSheetExample extends React.Component<{}, $FlowFixMeState> { state = { clicked: 'none', }; render() { return ( Click to show the ActionSheet Clicked button: {this.state.clicked} ); } showActionSheet = () => { ActionSheetIOS.showActionSheetWithOptions( { options: BUTTONS, cancelButtonIndex: CANCEL_INDEX, destructiveButtonIndex: DESTRUCTIVE_INDEX, }, buttonIndex => { this.setState({clicked: BUTTONS[buttonIndex]}); }, ); }; } class ActionSheetTintExample extends React.Component<{}, $FlowFixMeState> { state = { clicked: 'none', }; render() { return ( Click to show the ActionSheet Clicked button: {this.state.clicked} ); } showActionSheet = () => { ActionSheetIOS.showActionSheetWithOptions( { options: BUTTONS, cancelButtonIndex: CANCEL_INDEX, destructiveButtonIndex: DESTRUCTIVE_INDEX, tintColor: 'green', }, buttonIndex => { this.setState({clicked: BUTTONS[buttonIndex]}); }, ); }; } class ShareActionSheetExample extends React.Component< $FlowFixMeProps, $FlowFixMeState, > { state = { text: '', }; render() { return ( Click to show the Share ActionSheet {this.state.text} ); } showShareActionSheet = () => { ActionSheetIOS.showShareActionSheetWithOptions( { url: this.props.url, message: 'message to go with the shared url', subject: 'a subject to go in the email heading', excludedActivityTypes: ['com.apple.UIKit.activity.PostToTwitter'], }, error => alert(error), (completed, method) => { var text; if (completed) { text = `Shared via ${method}`; } else { text = "You didn't share"; } this.setState({text}); }, ); }; } class ShareScreenshotExample extends React.Component<{}, $FlowFixMeState> { state = { text: '', }; render() { return ( Click to show the Share ActionSheet {this.state.text} ); } showShareActionSheet = () => { // Take the snapshot (returns a temp file uri) takeSnapshot('window') .then(uri => { // Share image data ActionSheetIOS.showShareActionSheetWithOptions( { url: uri, excludedActivityTypes: ['com.apple.UIKit.activity.PostToTwitter'], }, error => alert(error), (completed, method) => { var text; if (completed) { text = `Shared via ${method}`; } else { text = "You didn't share"; } this.setState({text}); }, ); }) .catch(error => alert(error)); }; } var style = StyleSheet.create({ button: { marginBottom: 10, fontWeight: '500', }, }); exports.title = 'ActionSheetIOS'; exports.description = "Interface to show iOS' action sheets"; exports.examples = [ { title: 'Show Action Sheet', render(): React.Element { return ; }, }, { title: 'Show Action Sheet with tinted buttons', render(): React.Element { return ; }, }, { title: 'Show Share Action Sheet', render(): React.Element { return ; }, }, { title: 'Share Local Image', render(): React.Element { return ; }, }, { title: 'Share Screenshot', render(): React.Element { return ; }, }, ];