mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
6a547c6c57
Summary: Creates `NativeComponentRegistry` which makes native component initialization more declarative and configurable through an optionally configurable provider. The next diff converts `ScrollView` to use this new abstraction as a demonstration. The plan would be to use this to replace all current manual call sites of `registerGeneratedViewConfig`, and then the ones generated via the Babel plugin. Migrating to this will not change any production behavior, but it will enable verification of `ViewConfig` in development. Changelog: [Internal] Reviewed By: JoshuaGross Differential Revision: D25084468 fbshipit-source-id: 9c758ddc279bf937a401a868a066907a94098f37
37 lines
800 B
JavaScript
37 lines
800 B
JavaScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const React = require('react');
|
|
|
|
module.exports = viewName => {
|
|
const Component = class extends React.Component {
|
|
render() {
|
|
return React.createElement(viewName, this.props, this.props.children);
|
|
}
|
|
|
|
// The methods that exist on host components
|
|
blur = jest.fn();
|
|
focus = jest.fn();
|
|
measure = jest.fn();
|
|
measureInWindow = jest.fn();
|
|
measureLayout = jest.fn();
|
|
setNativeProps = jest.fn();
|
|
};
|
|
|
|
if (viewName === 'RCTView') {
|
|
Component.displayName = 'View';
|
|
} else {
|
|
Component.displayName = viewName;
|
|
}
|
|
|
|
return Component;
|
|
};
|