mirror of
https://github.com/status-im/react-native.git
synced 2025-01-22 23:41:49 +00:00
18cb5d0711
- Bugfix/require module regexp | Amjad Masad - [ReactNative] RCTView's shadowOffset is of float type, not CGFloat | Kevin Gozali - Fix WebView automaticallyAdjustContentInsets error | Spencer Ahrens - [react-native] map view - add onTouch** props | Jiajie Zhu - [react-native] Fix documentation extraction for View | Ben Alpert - [ReactNative] Add few hints in the UI | Alex Kotliarskyi - Adding `scrollWithoutAnimationTo` method for ScrollViews | Felix Oghina - [ScrollView] Add "bounces" property to ScrollView propTypes | Spencer Ahrens - Fix a crash in RCTAsyncLocalStorage when the value is not a string. | Spencer Ahrens - [ReactNative] Remove global MutationObserver to fix Bluebird feature detection | Christopher Chedeau - [catalyst] fix typo | Jiajie Zhu - [react-packager] check-in bluebird | Amjad Masad - [react-native] v0.3.1 | Amjad Masad - [Pod] Preserve header directory structure | Alex Akers - [react-native] Bring React.render behavior in line with web | Ben Alpert - Expose html prop on WebView | Spencer Ahrens - missing '.' in ListView.DataSource example | Christopher Chedeau - [react-native] Support returning null from a component | Ben Alpert - [react-native] Fix race condition in removeSubviewsFromContainerWithID: | Ben Alpert
136 lines
3.9 KiB
JavaScript
136 lines
3.9 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 ReactIOS
|
|
* @flow
|
|
*/
|
|
"use strict";
|
|
|
|
var ReactChildren = require('ReactChildren');
|
|
var ReactClass = require('ReactClass');
|
|
var ReactComponent = require('ReactComponent');
|
|
var ReactContext = require('ReactContext');
|
|
var ReactCurrentOwner = require('ReactCurrentOwner');
|
|
var ReactElement = require('ReactElement');
|
|
var ReactElementValidator = require('ReactElementValidator');
|
|
var ReactInstanceHandles = require('ReactInstanceHandles');
|
|
var ReactIOSDefaultInjection = require('ReactIOSDefaultInjection');
|
|
var ReactIOSMount = require('ReactIOSMount');
|
|
var ReactPropTypes = require('ReactPropTypes');
|
|
|
|
var deprecated = require('deprecated');
|
|
var invariant = require('invariant');
|
|
var onlyChild = require('onlyChild');
|
|
|
|
ReactIOSDefaultInjection.inject();
|
|
|
|
var createElement = ReactElement.createElement;
|
|
var createFactory = ReactElement.createFactory;
|
|
var cloneElement = ReactElement.cloneElement;
|
|
|
|
if (__DEV__) {
|
|
createElement = ReactElementValidator.createElement;
|
|
createFactory = ReactElementValidator.createFactory;
|
|
cloneElement = ReactElementValidator.cloneElement;
|
|
}
|
|
|
|
var resolveDefaultProps = function(element) {
|
|
// Could be optimized, but not currently in heavy use.
|
|
var defaultProps = element.type.defaultProps;
|
|
var props = element.props;
|
|
for (var propName in defaultProps) {
|
|
if (props[propName] === undefined) {
|
|
props[propName] = defaultProps[propName];
|
|
}
|
|
}
|
|
};
|
|
|
|
// Experimental optimized element creation
|
|
var augmentElement = function(element: ReactElement) {
|
|
if (__DEV__) {
|
|
invariant(
|
|
false,
|
|
'This optimized path should never be used in DEV mode because ' +
|
|
'it does not provide validation. Check your JSX transform.'
|
|
);
|
|
}
|
|
element._owner = ReactCurrentOwner.current;
|
|
element._context = ReactContext.current;
|
|
if (element.type.defaultProps) {
|
|
resolveDefaultProps(element);
|
|
}
|
|
return element;
|
|
};
|
|
|
|
var render = function(
|
|
element: ReactElement,
|
|
mountInto: number,
|
|
callback?: ?(() => void)
|
|
): ?ReactComponent {
|
|
return ReactIOSMount.renderComponent(element, mountInto, callback);
|
|
};
|
|
|
|
var ReactIOS = {
|
|
hasReactIOSInitialized: false,
|
|
Children: {
|
|
map: ReactChildren.map,
|
|
forEach: ReactChildren.forEach,
|
|
count: ReactChildren.count,
|
|
only: onlyChild
|
|
},
|
|
Component: ReactComponent,
|
|
PropTypes: ReactPropTypes,
|
|
createClass: ReactClass.createClass,
|
|
createElement: createElement,
|
|
createFactory: createFactory,
|
|
cloneElement: cloneElement,
|
|
_augmentElement: augmentElement,
|
|
render: render,
|
|
unmountComponentAtNode: ReactIOSMount.unmountComponentAtNode,
|
|
|
|
// Hook for JSX spread, don't use this for anything else.
|
|
__spread: Object.assign,
|
|
|
|
unmountComponentAtNodeAndRemoveContainer: ReactIOSMount.unmountComponentAtNodeAndRemoveContainer,
|
|
isValidClass: ReactElement.isValidFactory,
|
|
isValidElement: ReactElement.isValidElement,
|
|
|
|
// Deprecations (remove for 0.13)
|
|
renderComponent: deprecated(
|
|
'React',
|
|
'renderComponent',
|
|
'render',
|
|
this,
|
|
render
|
|
),
|
|
isValidComponent: deprecated(
|
|
'React',
|
|
'isValidComponent',
|
|
'isValidElement',
|
|
this,
|
|
ReactElement.isValidElement
|
|
)
|
|
};
|
|
|
|
// Inject the runtime into a devtools global hook regardless of browser.
|
|
// Allows for debugging when the hook is injected on the page.
|
|
/* globals __REACT_DEVTOOLS_GLOBAL_HOOK__ */
|
|
if (
|
|
typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined' &&
|
|
typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.inject === 'function') {
|
|
__REACT_DEVTOOLS_GLOBAL_HOOK__.inject({
|
|
CurrentOwner: ReactCurrentOwner,
|
|
InstanceHandles: ReactInstanceHandles,
|
|
Mount: ReactIOSMount,
|
|
Reconciler: require('ReactReconciler'),
|
|
TextComponent: require('ReactIOSTextComponent'),
|
|
});
|
|
}
|
|
|
|
module.exports = ReactIOS;
|