10
10
11
11
'use strict' ;
12
12
13
- var React = require ( 'react' ) ;
14
- var createReactClass = require ( 'create-react-class' ) ;
15
- var ReactNative = require ( 'react-native' ) ;
16
- var {
13
+ const React = require ( 'react' ) ;
14
+ const ReactNative = require ( 'react-native' ) ;
15
+ const {
17
16
ActivityIndicator,
18
17
Image,
19
- Platform,
20
18
StyleSheet,
21
19
Text,
22
20
View,
23
21
ImageBackground,
24
22
} = ReactNative ;
25
23
26
- var base64Icon =
24
+ const base64Icon =
27
25
'' ;
28
26
29
- var ImageCapInsetsExample = require ( './ImageCapInsetsExample' ) ;
27
+ const ImageCapInsetsExample = require ( './ImageCapInsetsExample' ) ;
30
28
const IMAGE_PREFETCH_URL =
31
29
'http://origami.design/public/images/bird-logo.png?r=1&t=' + Date . now ( ) ;
32
- var prefetchTask = Image . prefetch ( IMAGE_PREFETCH_URL ) ;
30
+ const prefetchTask = Image . prefetch ( IMAGE_PREFETCH_URL ) ;
33
31
34
- /* $FlowFixMe(>=0.63.0 site=react_native_fb) This comment suppresses an error
35
- * found when Flow v0.63 was deployed. To see the error delete this comment and
36
- * run Flow. */
37
- var NetworkImageCallbackExample = createReactClass ( {
38
- displayName : 'NetworkImageCallbackExample' ,
39
- getInitialState : function ( ) {
40
- return {
41
- events : [ ] ,
42
- startLoadPrefetched : false ,
43
- mountTime : new Date ( ) ,
44
- } ;
45
- } ,
32
+ type ImageSource = $ReadOnly < { |
33
+ uri : string ,
34
+ | } > ;
35
+
36
+ type NetworkImageCallbackExampleState = { |
37
+ events : Array < string > ,
38
+ startLoadPrefetched : boolean ,
39
+ mountTime : Date ,
40
+ | } ;
41
+
42
+ type NetworkImageCallbackExampleProps = $ReadOnly < { |
43
+ source : ImageSource ,
44
+ prefetchedSource : ImageSource ,
45
+ | } > ;
46
+
47
+ class NetworkImageCallbackExample extends React . Component <
48
+ NetworkImageCallbackExampleProps ,
49
+ NetworkImageCallbackExampleState ,
50
+ > {
51
+ state = {
52
+ events : [ ] ,
53
+ startLoadPrefetched : false ,
54
+ mountTime : new Date ( ) ,
55
+ } ;
46
56
47
57
UNSAFE_componentWillMount ( ) {
48
58
this . setState ( { mountTime : new Date ( ) } ) ;
49
- } ,
59
+ }
50
60
51
- render : function ( ) {
52
- var { mountTime} = this . state ;
61
+ _loadEventFired = ( event : string ) => {
62
+ this . setState ( state => ( {
63
+ events : [ ...state . events , event ] ,
64
+ } ) ) ;
65
+ } ;
53
66
67
+ render ( ) {
68
+ const { mountTime} = this . state ;
54
69
return (
55
70
< View >
56
71
< Image
@@ -133,24 +148,30 @@ var NetworkImageCallbackExample = createReactClass({
133
148
< Text style = { { marginTop : 20 } } > { this . state . events . join ( '\n' ) } </ Text >
134
149
</ View >
135
150
) ;
136
- } ,
151
+ }
152
+ }
137
153
138
- _loadEventFired ( event ) {
139
- this . setState ( state => {
140
- return ( state . events = [ ...state . events , event ] ) ;
141
- } ) ;
142
- } ,
143
- } ) ;
154
+ type NetworkImageExampleState = { |
155
+ error : boolean ,
156
+ loading : boolean ,
157
+ progress : number ,
158
+ | } ;
144
159
145
- var NetworkImageExample = createReactClass ( {
146
- getInitialState : function ( ) {
147
- return {
148
- error : false ,
149
- loading : false ,
150
- progress : 0 ,
151
- } ;
152
- } ,
153
- render : function ( ) {
160
+ type NetworkImageExampleProps = $ReadOnly < { |
161
+ source : ImageSource ,
162
+ | } > ;
163
+
164
+ class NetworkImageExample extends React . Component <
165
+ NetworkImageExampleProps ,
166
+ NetworkImageExampleState ,
167
+ > {
168
+ state = {
169
+ error : false ,
170
+ loading : false ,
171
+ progress : 0 ,
172
+ } ;
173
+
174
+ render ( ) {
154
175
var loader = this . state . loading ? (
155
176
< View style = { styles . progress } >
156
177
< Text > { this . state . progress } %</ Text >
@@ -178,22 +199,34 @@ var NetworkImageExample = createReactClass({
178
199
{ loader }
179
200
</ ImageBackground >
180
201
) ;
181
- } ,
182
- } ) ;
202
+ }
203
+ }
183
204
184
- var ImageSizeExample = createReactClass ( {
185
- getInitialState : function ( ) {
186
- return {
187
- width : 0 ,
188
- height : 0 ,
189
- } ;
190
- } ,
191
- componentDidMount : function ( ) {
205
+ type ImageSizeExampleState = { |
206
+ width : number ,
207
+ height : number ,
208
+ | } ;
209
+
210
+ type ImageSizeExampleProps = $ReadOnly < { |
211
+ source : ImageSource ,
212
+ | } > ;
213
+
214
+ class ImageSizeExample extends React . Component <
215
+ ImageSizeExampleProps ,
216
+ ImageSizeExampleState ,
217
+ > {
218
+ state = {
219
+ width : 0 ,
220
+ height : 0 ,
221
+ } ;
222
+
223
+ componentDidMount ( ) {
192
224
Image . getSize ( this . props . source . uri , ( width , height ) => {
193
225
this . setState ( { width, height} ) ;
194
226
} ) ;
195
- } ,
196
- render : function ( ) {
227
+ }
228
+
229
+ render ( ) {
197
230
return (
198
231
< View style = { { flexDirection : 'row' } } >
199
232
< Image
@@ -211,17 +244,56 @@ var ImageSizeExample = createReactClass({
211
244
</ Text >
212
245
</ View >
213
246
) ;
214
- } ,
215
- } ) ;
247
+ }
248
+ }
249
+
250
+ type MultipleSourcesExampleState = { |
251
+ width : number ,
252
+ height : number ,
253
+ | } ;
254
+
255
+ type MultipleSourcesExampleProps = $ReadOnly < { || } > ;
256
+
257
+ class MultipleSourcesExample extends React . Component <
258
+ MultipleSourcesExampleProps ,
259
+ MultipleSourcesExampleState ,
260
+ > {
261
+ state = {
262
+ width : 30 ,
263
+ height : 30 ,
264
+ } ;
265
+
266
+ increaseImageSize = ( ) => {
267
+ if ( this . state . width >= 100 ) {
268
+ return ;
269
+ }
270
+ this . setState ( {
271
+ width : this . state . width + 10 ,
272
+ height : this . state . height + 10 ,
273
+ } ) ;
274
+ } ;
216
275
217
- var MultipleSourcesExample = createReactClass ( {
218
- getInitialState : function ( ) {
219
- return {
220
- width : 30 ,
221
- height : 30 ,
222
- } ;
223
- } ,
224
- render : function ( ) {
276
+ increaseImageSize = ( ) => {
277
+ if ( this . state . width >= 100 ) {
278
+ return ;
279
+ }
280
+ this . setState ( {
281
+ width : this . state . width + 10 ,
282
+ height : this . state . height + 10 ,
283
+ } ) ;
284
+ } ;
285
+
286
+ decreaseImageSize = ( ) => {
287
+ if ( this . state . width <= 10 ) {
288
+ return ;
289
+ }
290
+ this . setState ( {
291
+ width : this . state . width - 10 ,
292
+ height : this . state . height - 10 ,
293
+ } ) ;
294
+ } ;
295
+
296
+ render ( ) {
225
297
return (
226
298
< View >
227
299
< View style = { { flexDirection : 'row' , justifyContent : 'space-between' } } >
@@ -260,26 +332,8 @@ var MultipleSourcesExample = createReactClass({
260
332
</ View >
261
333
</ View >
262
334
) ;
263
- } ,
264
- increaseImageSize : function ( ) {
265
- if ( this . state . width >= 100 ) {
266
- return ;
267
- }
268
- this . setState ( {
269
- width : this . state . width + 10 ,
270
- height : this . state . height + 10 ,
271
- } ) ;
272
- } ,
273
- decreaseImageSize : function ( ) {
274
- if ( this . state . width <= 10 ) {
275
- return ;
276
- }
277
- this . setState ( {
278
- width : this . state . width - 10 ,
279
- height : this . state . height - 10 ,
280
- } ) ;
281
- } ,
282
- } ) ;
335
+ }
336
+ }
283
337
284
338
exports . displayName = ( undefined : ?string ) ;
285
339
exports . framework = 'React' ;
0 commit comments