Skip to content

Commit

Permalink
remove createReactClass from RNTester/js/ImageExample.js (facebook#21602
Browse files Browse the repository at this point in the history
)

Summary:
Related to facebook#21581 .
Removed createReactClass from the RNTester/js/ImageExample.js

The diff of this PR is a little big. If there are any problems, please teach me �
 - [x] npm run prettier
 - [x] npm run flow-check-ios
 - [x] npm run flow-check-android

[GENERAL] [ENHANCEMENT] [RNTester/js/ImageExample.js] - remove createReactClass dependency
Pull Request resolved: facebook#21602

Reviewed By: TheSavior

Differential Revision: D10304857

Pulled By: RSNara

fbshipit-source-id: 339b1220828c6218cad0d09c7a5034a61e623bc6
  • Loading branch information
nissy-dev authored and facebook-github-bot committed Oct 10, 2018
1 parent e0517b4 commit d5ce7ca
Showing 1 changed file with 135 additions and 81 deletions.
216 changes: 135 additions & 81 deletions RNTester/js/ImageExample.js
Original file line number Diff line number Diff line change
Expand Up @@ -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<string>,
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 (
<View>
<Image
Expand Down Expand Up @@ -133,24 +148,30 @@ var NetworkImageCallbackExample = createReactClass({
<Text style={{marginTop: 20}}>{this.state.events.join('\n')}</Text>
</View>
);
},
}
}

_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 ? (
<View style={styles.progress}>
<Text>{this.state.progress}%</Text>
Expand Down Expand Up @@ -178,22 +199,34 @@ var NetworkImageExample = createReactClass({
{loader}
</ImageBackground>
);
},
});
}
}

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 (
<View style={{flexDirection: 'row'}}>
<Image
Expand All @@ -211,17 +244,56 @@ var ImageSizeExample = createReactClass({
</Text>
</View>
);
},
});
}
}

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 (
<View>
<View style={{flexDirection: 'row', justifyContent: 'space-between'}}>
Expand Down Expand Up @@ -260,26 +332,8 @@ var MultipleSourcesExample = createReactClass({
</View>
</View>
);
},
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';
Expand Down

0 comments on commit d5ce7ca

Please sign in to comment.