diff --git a/RNTester/js/ImageExample.js b/RNTester/js/ImageExample.js index 830978f46fc8be..f6c62b540e8bee 100644 --- a/RNTester/js/ImageExample.js +++ b/RNTester/js/ImageExample.js @@ -10,47 +10,62 @@ 'use strict'; -var React = require('react'); -var createReactClass = require('create-react-class'); -var ReactNative = require('react-native'); -var { +const React = require('react'); +const ReactNative = require('react-native'); +const { ActivityIndicator, Image, - Platform, StyleSheet, Text, View, ImageBackground, } = ReactNative; -var base64Icon = +const base64Icon = ''; -var ImageCapInsetsExample = require('./ImageCapInsetsExample'); +const ImageCapInsetsExample = require('./ImageCapInsetsExample'); const IMAGE_PREFETCH_URL = 'http://origami.design/public/images/bird-logo.png?r=1&t=' + Date.now(); -var prefetchTask = Image.prefetch(IMAGE_PREFETCH_URL); +const prefetchTask = Image.prefetch(IMAGE_PREFETCH_URL); -/* $FlowFixMe(>=0.63.0 site=react_native_fb) This comment suppresses an error - * found when Flow v0.63 was deployed. To see the error delete this comment and - * run Flow. */ -var NetworkImageCallbackExample = createReactClass({ - displayName: 'NetworkImageCallbackExample', - getInitialState: function() { - return { - events: [], - startLoadPrefetched: false, - mountTime: new Date(), - }; - }, +type ImageSource = $ReadOnly<{| + uri: string, +|}>; + +type NetworkImageCallbackExampleState = {| + events: Array, + startLoadPrefetched: boolean, + mountTime: Date, +|}; + +type NetworkImageCallbackExampleProps = $ReadOnly<{| + source: ImageSource, + prefetchedSource: ImageSource, +|}>; + +class NetworkImageCallbackExample extends React.Component< + NetworkImageCallbackExampleProps, + NetworkImageCallbackExampleState, +> { + state = { + events: [], + startLoadPrefetched: false, + mountTime: new Date(), + }; UNSAFE_componentWillMount() { this.setState({mountTime: new Date()}); - }, + } - render: function() { - var {mountTime} = this.state; + _loadEventFired = (event: string) => { + this.setState(state => ({ + events: [...state.events, event], + })); + }; + render() { + const {mountTime} = this.state; return ( {this.state.events.join('\n')} ); - }, + } +} - _loadEventFired(event) { - this.setState(state => { - return (state.events = [...state.events, event]); - }); - }, -}); +type NetworkImageExampleState = {| + error: boolean, + loading: boolean, + progress: number, +|}; -var NetworkImageExample = createReactClass({ - getInitialState: function() { - return { - error: false, - loading: false, - progress: 0, - }; - }, - render: function() { +type NetworkImageExampleProps = $ReadOnly<{| + source: ImageSource, +|}>; + +class NetworkImageExample extends React.Component< + NetworkImageExampleProps, + NetworkImageExampleState, +> { + state = { + error: false, + loading: false, + progress: 0, + }; + + render() { var loader = this.state.loading ? ( {this.state.progress}% @@ -178,22 +199,34 @@ var NetworkImageExample = createReactClass({ {loader} ); - }, -}); + } +} -var ImageSizeExample = createReactClass({ - getInitialState: function() { - return { - width: 0, - height: 0, - }; - }, - componentDidMount: function() { +type ImageSizeExampleState = {| + width: number, + height: number, +|}; + +type ImageSizeExampleProps = $ReadOnly<{| + source: ImageSource, +|}>; + +class ImageSizeExample extends React.Component< + ImageSizeExampleProps, + ImageSizeExampleState, +> { + state = { + width: 0, + height: 0, + }; + + componentDidMount() { Image.getSize(this.props.source.uri, (width, height) => { this.setState({width, height}); }); - }, - render: function() { + } + + render() { return ( ); - }, -}); + } +} + +type MultipleSourcesExampleState = {| + width: number, + height: number, +|}; + +type MultipleSourcesExampleProps = $ReadOnly<{||}>; + +class MultipleSourcesExample extends React.Component< + MultipleSourcesExampleProps, + MultipleSourcesExampleState, +> { + state = { + width: 30, + height: 30, + }; + + increaseImageSize = () => { + if (this.state.width >= 100) { + return; + } + this.setState({ + width: this.state.width + 10, + height: this.state.height + 10, + }); + }; -var MultipleSourcesExample = createReactClass({ - getInitialState: function() { - return { - width: 30, - height: 30, - }; - }, - render: function() { + increaseImageSize = () => { + if (this.state.width >= 100) { + return; + } + this.setState({ + width: this.state.width + 10, + height: this.state.height + 10, + }); + }; + + decreaseImageSize = () => { + if (this.state.width <= 10) { + return; + } + this.setState({ + width: this.state.width - 10, + height: this.state.height - 10, + }); + }; + + render() { return ( @@ -260,26 +332,8 @@ var MultipleSourcesExample = createReactClass({ ); - }, - increaseImageSize: function() { - if (this.state.width >= 100) { - return; - } - this.setState({ - width: this.state.width + 10, - height: this.state.height + 10, - }); - }, - decreaseImageSize: function() { - if (this.state.width <= 10) { - return; - } - this.setState({ - width: this.state.width - 10, - height: this.state.height - 10, - }); - }, -}); + } +} exports.displayName = (undefined: ?string); exports.framework = 'React';