mirror of
https://github.com/status-im/react-native.git
synced 2025-01-30 19:25:11 +00:00
16ddb1962a
Summary: require('./image.jpg') returns a number and therefore the propType is wrong. Adding it to the propType to fix the warning and dealing with flow which is completely broken for this.
204 lines
6.1 KiB
JavaScript
204 lines
6.1 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* @providesModule Image
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
var EdgeInsetsPropType = require('EdgeInsetsPropType');
|
|
var ImageResizeMode = require('ImageResizeMode');
|
|
var ImageStylePropTypes = require('ImageStylePropTypes');
|
|
var NativeMethodsMixin = require('NativeMethodsMixin');
|
|
var NativeModules = require('NativeModules');
|
|
var PropTypes = require('ReactPropTypes');
|
|
var React = require('React');
|
|
var ReactNativeViewAttributes = require('ReactNativeViewAttributes');
|
|
var StyleSheet = require('StyleSheet');
|
|
var StyleSheetPropType = require('StyleSheetPropType');
|
|
|
|
var flattenStyle = require('flattenStyle');
|
|
var invariant = require('invariant');
|
|
var requireNativeComponent = require('requireNativeComponent');
|
|
var resolveAssetSource = require('resolveAssetSource');
|
|
var warning = require('warning');
|
|
|
|
/**
|
|
* A React component for displaying different types of images,
|
|
* including network images, static resources, temporary local images, and
|
|
* images from local disk, such as the camera roll.
|
|
*
|
|
* Example usage:
|
|
*
|
|
* ```
|
|
* renderImages: function() {
|
|
* return (
|
|
* <View>
|
|
* <Image
|
|
* style={styles.icon}
|
|
* source={require('image!myIcon')}
|
|
* />
|
|
* <Image
|
|
* style={styles.logo}
|
|
* source={{uri: 'http://facebook.github.io/react/img/logo_og.png'}}
|
|
* />
|
|
* </View>
|
|
* );
|
|
* },
|
|
* ```
|
|
*/
|
|
var Image = React.createClass({
|
|
propTypes: {
|
|
style: StyleSheetPropType(ImageStylePropTypes),
|
|
/**
|
|
* `uri` is a string representing the resource identifier for the image, which
|
|
* could be an http address, a local file path, or the name of a static image
|
|
* resource (which should be wrapped in the `require('image!name')` function).
|
|
*/
|
|
source: PropTypes.oneOfType([
|
|
PropTypes.shape({
|
|
uri: PropTypes.string,
|
|
}),
|
|
// Opaque type returned by require('./image.jpg')
|
|
PropTypes.number,
|
|
]),
|
|
/**
|
|
* A static image to display while downloading the final image off the
|
|
* network.
|
|
* @platform ios
|
|
*/
|
|
defaultSource: PropTypes.shape({
|
|
uri: PropTypes.string,
|
|
}),
|
|
/**
|
|
* When true, indicates the image is an accessibility element.
|
|
* @platform ios
|
|
*/
|
|
accessible: PropTypes.bool,
|
|
/**
|
|
* The text that's read by the screen reader when the user interacts with
|
|
* the image.
|
|
* @platform ios
|
|
*/
|
|
accessibilityLabel: PropTypes.string,
|
|
/**
|
|
* When the image is resized, the corners of the size specified
|
|
* by capInsets will stay a fixed size, but the center content and borders
|
|
* of the image will be stretched. This is useful for creating resizable
|
|
* rounded buttons, shadows, and other resizable assets. More info on
|
|
* [Apple documentation](https://developer.apple.com/library/ios/documentation/UIKit/Reference/UIImage_Class/index.html#//apple_ref/occ/instm/UIImage/resizableImageWithCapInsets)
|
|
* @platform ios
|
|
*/
|
|
capInsets: EdgeInsetsPropType,
|
|
/**
|
|
* Determines how to resize the image when the frame doesn't match the raw
|
|
* image dimensions.
|
|
*/
|
|
resizeMode: PropTypes.oneOf(['cover', 'contain', 'stretch']),
|
|
/**
|
|
* A unique identifier for this element to be used in UI Automation
|
|
* testing scripts.
|
|
*/
|
|
testID: PropTypes.string,
|
|
/**
|
|
* Invoked on mount and layout changes with
|
|
* `{nativeEvent: {layout: {x, y, width, height}}}`.
|
|
*/
|
|
onLayout: PropTypes.func,
|
|
/**
|
|
* Invoked on load start
|
|
* @platform ios
|
|
*/
|
|
onLoadStart: PropTypes.func,
|
|
/**
|
|
* Invoked on download progress with `{nativeEvent: {loaded, total}}`
|
|
* @platform ios
|
|
*/
|
|
onProgress: PropTypes.func,
|
|
/**
|
|
* Invoked on load error with `{nativeEvent: {error}}`
|
|
* @platform ios
|
|
*/
|
|
onError: PropTypes.func,
|
|
/**
|
|
* Invoked when load completes successfully
|
|
* @platform ios
|
|
*/
|
|
onLoad: PropTypes.func,
|
|
/**
|
|
* Invoked when load either succeeds or fails
|
|
* @platform ios
|
|
*/
|
|
onLoadEnd: PropTypes.func,
|
|
},
|
|
|
|
statics: {
|
|
resizeMode: ImageResizeMode,
|
|
},
|
|
|
|
mixins: [NativeMethodsMixin],
|
|
|
|
/**
|
|
* `NativeMethodsMixin` will look for this when invoking `setNativeProps`. We
|
|
* make `this` look like an actual native component class.
|
|
*/
|
|
viewConfig: {
|
|
uiViewClassName: 'UIView',
|
|
validAttributes: ReactNativeViewAttributes.UIView
|
|
},
|
|
|
|
render: function() {
|
|
for (var prop in cfg.nativeOnly) {
|
|
if (this.props[prop] !== undefined) {
|
|
console.warn('Prop `' + prop + ' = ' + this.props[prop] + '` should ' +
|
|
'not be set directly on Image.');
|
|
}
|
|
}
|
|
var source = resolveAssetSource(this.props.source) || {};
|
|
var defaultSource = (this.props.defaultSource && resolveAssetSource(this.props.defaultSource)) || {};
|
|
|
|
var {width, height} = source;
|
|
var style = flattenStyle([{width, height}, styles.base, this.props.style]) || {};
|
|
|
|
var isNetwork = source.uri && source.uri.match(/^https?:/);
|
|
var RawImage = isNetwork ? RCTNetworkImageView : RCTImageView;
|
|
var resizeMode = this.props.resizeMode || (style || {}).resizeMode || 'cover'; // Workaround for flow bug t7737108
|
|
var tintColor = (style || {}).tintColor; // Workaround for flow bug t7737108
|
|
|
|
return (
|
|
<RawImage
|
|
{...this.props}
|
|
style={style}
|
|
resizeMode={resizeMode}
|
|
tintColor={tintColor}
|
|
src={source.uri}
|
|
defaultImageSrc={defaultSource.uri}
|
|
/>
|
|
);
|
|
}
|
|
});
|
|
|
|
var styles = StyleSheet.create({
|
|
base: {
|
|
overflow: 'hidden',
|
|
},
|
|
});
|
|
|
|
var cfg = {
|
|
nativeOnly: {
|
|
src: true,
|
|
defaultImageSrc: true,
|
|
imageTag: true,
|
|
progressHandlerRegistered: true,
|
|
},
|
|
};
|
|
var RCTImageView = requireNativeComponent('RCTImageView', Image, cfg);
|
|
var RCTNetworkImageView = (NativeModules.NetworkImageViewManager) ? requireNativeComponent('RCTNetworkImageView', Image, cfg) : RCTImageView;
|
|
|
|
module.exports = Image;
|