diff --git a/fixtures/dom/package.json b/fixtures/dom/package.json
index 07a70c4dc1..214de66fb7 100644
--- a/fixtures/dom/package.json
+++ b/fixtures/dom/package.json
@@ -8,6 +8,7 @@
"dependencies": {
"classnames": "^2.2.5",
"query-string": "^4.2.3",
+ "prop-types": "^15.5.6",
"react": "^15.4.1",
"react-dom": "^15.4.1",
"semver": "^5.3.0"
diff --git a/fixtures/dom/public/index.html b/fixtures/dom/public/index.html
index a131a92882..ed1922517a 100644
--- a/fixtures/dom/public/index.html
+++ b/fixtures/dom/public/index.html
@@ -14,6 +14,7 @@
Learn how to configure a non-root public URL by running `npm run build`.
-->
React App
+
diff --git a/fixtures/dom/src/components/Fixture.js b/fixtures/dom/src/components/Fixture.js
index 1f6ef9ba09..6074fa7d44 100644
--- a/fixtures/dom/src/components/Fixture.js
+++ b/fixtures/dom/src/components/Fixture.js
@@ -1,7 +1,8 @@
+const PropTypes = window.PropTypes;
const React = window.React;
const propTypes = {
- children: React.PropTypes.node.isRequired,
+ children: PropTypes.node.isRequired,
};
class Fixture extends React.Component {
diff --git a/fixtures/dom/src/components/FixtureSet.js b/fixtures/dom/src/components/FixtureSet.js
index 9c6e8581eb..ff98b2884c 100644
--- a/fixtures/dom/src/components/FixtureSet.js
+++ b/fixtures/dom/src/components/FixtureSet.js
@@ -1,8 +1,9 @@
import React from 'react';
+import PropTypes from 'prop-types';
const propTypes = {
- title: React.PropTypes.node.isRequired,
- description: React.PropTypes.node.isRequired,
+ title: PropTypes.node.isRequired,
+ description: PropTypes.node.isRequired,
};
class FixtureSet extends React.Component {
diff --git a/fixtures/dom/src/components/TestCase.js b/fixtures/dom/src/components/TestCase.js
index 79c46a975a..053eac9467 100644
--- a/fixtures/dom/src/components/TestCase.js
+++ b/fixtures/dom/src/components/TestCase.js
@@ -1,14 +1,15 @@
import cn from 'classnames';
import semver from 'semver';
import React from 'react';
+import PropTypes from 'prop-types';
import { parse } from 'query-string';
-import { semverString } from './propTypes'
+import { semverString } from './propTypes';
const propTypes = {
- children: React.PropTypes.node.isRequired,
- title: React.PropTypes.node.isRequired,
+ children: PropTypes.node.isRequired,
+ title: PropTypes.node.isRequired,
resolvedIn: semverString,
- resolvedBy: React.PropTypes.string
+ resolvedBy: PropTypes.string
};
class TestCase extends React.Component {
diff --git a/fixtures/dom/src/components/propTypes.js b/fixtures/dom/src/components/propTypes.js
index 42f4f4cf3a..abfdb5c7d3 100644
--- a/fixtures/dom/src/components/propTypes.js
+++ b/fixtures/dom/src/components/propTypes.js
@@ -1,3 +1,4 @@
+import PropTypes from 'prop-types';
import semver from 'semver';
const React = window.React;
@@ -5,7 +6,7 @@ const React = window.React;
export function semverString (props, propName, componentName) {
let version = props[propName];
- let error = React.PropTypes.string(...arguments);
+ let error = PropTypes.string(...arguments);
if (!error && version != null && !semver.valid(version))
error = new Error(
`\`${propName}\` should be a valid "semantic version" matching ` +
diff --git a/fixtures/dom/yarn.lock b/fixtures/dom/yarn.lock
index e45c4a7054..762b52cfc0 100644
--- a/fixtures/dom/yarn.lock
+++ b/fixtures/dom/yarn.lock
@@ -4239,6 +4239,12 @@ promise@7.1.1, promise@^7.1.1:
dependencies:
asap "~2.0.3"
+prop-types@^15.5.6:
+ version "15.5.6"
+ resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.5.6.tgz#797a915b1714b645ebb7c5d6cc690346205bd2aa"
+ dependencies:
+ fbjs "^0.8.9"
+
proxy-addr@~1.1.2:
version "1.1.2"
resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-1.1.2.tgz#b4cc5f22610d9535824c123aef9d3cf73c40ba37"
diff --git a/package.json b/package.json
index 35589b84c6..f8dc8b83fd 100644
--- a/package.json
+++ b/package.json
@@ -73,6 +73,7 @@
"object-assign": "^4.1.1",
"platform": "^1.1.0",
"prettier": "^0.22.0",
+ "prop-types": "^15.5.6",
"rimraf": "^2.6.1",
"rollup": "^0.41.6",
"rollup-plugin-alias": "^1.2.1",
diff --git a/scripts/jest/ts-preprocessor.js b/scripts/jest/ts-preprocessor.js
index b4fe74552c..29ad307a9a 100644
--- a/scripts/jest/ts-preprocessor.js
+++ b/scripts/jest/ts-preprocessor.js
@@ -23,7 +23,7 @@ function compile(content, contentFilename) {
getSourceFile(filename, languageVersion) {
var source;
var jestRegex = /jest\.d\.ts/;
- var reactRegex = /(?:React|ReactDOM)(?:\.d)?\.ts$/;
+ var reactRegex = /(?:React|ReactDOM|PropTypes)(?:\.d)?\.ts$/;
// `path.normalize` is used to turn forward slashes in
// the file path into backslashes on Windows.
diff --git a/scripts/rollup/bundles.js b/scripts/rollup/bundles.js
index 69b04f0b73..80f7361418 100644
--- a/scripts/rollup/bundles.js
+++ b/scripts/rollup/bundles.js
@@ -68,13 +68,14 @@ const bundles = [
config: {
destDir: 'build/',
globals: {
+ 'prop-types': 'PropTypes',
react: 'React',
},
moduleName: 'ReactDOM',
sourceMap: false,
},
entry: 'src/renderers/dom/ReactDOM.js',
- externals: [],
+ externals: ['prop-types'],
fbEntry: 'src/fb/ReactDOMFBEntry.js',
hasteName: 'ReactDOMStack',
isRenderer: true,
@@ -96,13 +97,14 @@ const bundles = [
config: {
destDir: 'build/',
globals: {
+ 'prop-types': 'PropTypes',
react: 'React',
},
moduleName: 'ReactDOM',
sourceMap: false,
},
entry: 'src/renderers/dom/fiber/ReactDOMFiber.js',
- externals: [],
+ externals: ['prop-types'],
fbEntry: 'src/fb/ReactDOMFiberFBEntry.js',
hasteName: 'ReactDOMFiber',
isRenderer: true,
@@ -127,13 +129,14 @@ const bundles = [
config: {
destDir: 'build/',
globals: {
+ 'prop-types': 'PropTypes',
react: 'React',
},
moduleName: 'ReactDOMServer',
sourceMap: false,
},
entry: 'src/renderers/dom/ReactDOMServer.js',
- externals: [],
+ externals: ['prop-types'],
fbEntry: 'src/renderers/dom/ReactDOMServer.js',
hasteName: 'ReactDOMServerStack',
isRenderer: true,
diff --git a/scripts/rollup/results.json b/scripts/rollup/results.json
index 88406fe9df..d3774916fd 100644
--- a/scripts/rollup/results.json
+++ b/scripts/rollup/results.json
@@ -1,29 +1,29 @@
{
- "branch": "bundle-fixes",
+ "branch": null,
"bundleSizes": {
"react.development.js (UMD_DEV)": {
- "size": 116098,
- "gzip": 29520
+ "size": 92740,
+ "gzip": 23440
},
"react.production.min.js (UMD_PROD)": {
- "size": 13707,
- "gzip": 5073
+ "size": 10409,
+ "gzip": 4091
},
"react-dom.development.js (UMD_DEV)": {
- "size": 563844,
- "gzip": 130190
+ "size": 563910,
+ "gzip": 130211
},
"react-dom.production.min.js (UMD_PROD)": {
- "size": 120191,
- "gzip": 37860
+ "size": 120247,
+ "gzip": 37891
},
"react-dom-server.development.js (UMD_DEV)": {
- "size": 476049,
- "gzip": 115267
+ "size": 476115,
+ "gzip": 115286
},
"react-dom-server.production.min.js (UMD_PROD)": {
- "size": 106489,
- "gzip": 33035
+ "size": 106540,
+ "gzip": 33071
},
"react-art.development.js (UMD_DEV)": {
"size": 339929,
@@ -34,68 +34,68 @@
"gzip": 28991
},
"react.development.js (NODE_DEV)": {
- "size": 109110,
- "gzip": 27479
+ "size": 85810,
+ "gzip": 21432
},
"react.production.min.js (NODE_PROD)": {
- "size": 12598,
- "gzip": 4649
+ "size": 9288,
+ "gzip": 3659
},
"React-dev.js (FB_DEV)": {
- "size": 110875,
- "gzip": 28140
+ "size": 87652,
+ "gzip": 22071
},
"React-prod.js (FB_PROD)": {
- "size": 56406,
- "gzip": 14416
+ "size": 37663,
+ "gzip": 9519
},
"ReactDOMStack-dev.js (FB_DEV)": {
- "size": 522626,
- "gzip": 124708
+ "size": 522667,
+ "gzip": 124718
},
"ReactDOMStack-prod.js (FB_PROD)": {
- "size": 352708,
- "gzip": 84660
+ "size": 352737,
+ "gzip": 84668
},
"react-dom.development.js (NODE_DEV)": {
- "size": 542218,
- "gzip": 125162
+ "size": 542259,
+ "gzip": 125174
},
"react-dom.production.min.js (NODE_PROD)": {
- "size": 116858,
- "gzip": 36717
+ "size": 116884,
+ "gzip": 36722
},
"ReactDOMFiber-dev.js (FB_DEV)": {
- "size": 797268,
- "gzip": 184134
+ "size": 797309,
+ "gzip": 184144
},
"ReactDOMFiber-prod.js (FB_PROD)": {
- "size": 407540,
- "gzip": 93567
+ "size": 407569,
+ "gzip": 93574
},
"react-dom-server.development.js (NODE_DEV)": {
- "size": 445452,
- "gzip": 107574
+ "size": 445493,
+ "gzip": 107585
},
"react-dom-server.production.min.js (NODE_PROD)": {
- "size": 101344,
- "gzip": 31273
+ "size": 101370,
+ "gzip": 31284
},
"ReactDOMServerStack-dev.js (FB_DEV)": {
- "size": 444144,
- "gzip": 107423
+ "size": 444185,
+ "gzip": 107436
},
"ReactDOMServerStack-prod.js (FB_PROD)": {
- "size": 333744,
- "gzip": 80424
+ "size": 333773,
+ "gzip": 80431
},
"ReactARTStack-dev.js (FB_DEV)": {
- "size": 141589,
- "gzip": 32280
+ "size": 142890,
+ "gzip": 32689
},
"ReactARTStack-prod.js (FB_PROD)": {
- "size": 99762,
- "gzip": 22576
+ "size": 101099,
+ "gzip": 22973
},
"react-art.development.js (NODE_DEV)": {
"size": 265123,
diff --git a/src/isomorphic/classic/__tests__/ReactContextValidator-test.js b/src/isomorphic/classic/__tests__/ReactContextValidator-test.js
index 84a220877f..0630f588cc 100644
--- a/src/isomorphic/classic/__tests__/ReactContextValidator-test.js
+++ b/src/isomorphic/classic/__tests__/ReactContextValidator-test.js
@@ -17,6 +17,7 @@
'use strict';
+var PropTypes;
var React;
var ReactDOM;
var ReactTestUtils;
@@ -29,6 +30,7 @@ describe('ReactContextValidator', () => {
beforeEach(() => {
jest.resetModules();
+ PropTypes = require('prop-types');
React = require('react');
ReactDOM = require('react-dom');
ReactTestUtils = require('ReactTestUtils');
@@ -44,7 +46,7 @@ describe('ReactContextValidator', () => {
}
}
Component.contextTypes = {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
};
class ComponentInFooBarContext extends React.Component {
@@ -60,8 +62,8 @@ describe('ReactContextValidator', () => {
}
}
ComponentInFooBarContext.childContextTypes = {
- foo: React.PropTypes.string,
- bar: React.PropTypes.number,
+ foo: PropTypes.string,
+ bar: PropTypes.number,
};
var instance = ReactTestUtils.renderIntoDocument(
@@ -88,8 +90,8 @@ describe('ReactContextValidator', () => {
}
}
Parent.childContextTypes = {
- foo: React.PropTypes.string.isRequired,
- bar: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
+ bar: PropTypes.string.isRequired,
};
class Component extends React.Component {
@@ -112,7 +114,7 @@ describe('ReactContextValidator', () => {
}
}
Component.contextTypes = {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
};
var container = document.createElement('div');
@@ -139,8 +141,8 @@ describe('ReactContextValidator', () => {
}
}
Parent.childContextTypes = {
- foo: React.PropTypes.string.isRequired,
- bar: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
+ bar: PropTypes.string.isRequired,
};
class Component extends React.Component {
@@ -153,7 +155,7 @@ describe('ReactContextValidator', () => {
}
}
Component.contextTypes = {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
};
var container = document.createElement('div');
@@ -171,7 +173,7 @@ describe('ReactContextValidator', () => {
}
}
Component.contextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
ReactTestUtils.renderIntoDocument();
@@ -196,7 +198,7 @@ describe('ReactContextValidator', () => {
}
}
ComponentInFooStringContext.childContextTypes = {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
};
ReactTestUtils.renderIntoDocument(
@@ -218,7 +220,7 @@ describe('ReactContextValidator', () => {
}
}
ComponentInFooNumberContext.childContextTypes = {
- foo: React.PropTypes.number,
+ foo: PropTypes.number,
};
ReactTestUtils.renderIntoDocument(
@@ -248,8 +250,8 @@ describe('ReactContextValidator', () => {
}
}
Component.childContextTypes = {
- foo: React.PropTypes.string.isRequired,
- bar: React.PropTypes.number,
+ foo: PropTypes.string.isRequired,
+ bar: PropTypes.number,
};
ReactTestUtils.renderIntoDocument();
@@ -288,7 +290,7 @@ describe('ReactContextValidator', () => {
class ComponentA extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
render() {
return ;
@@ -296,7 +298,7 @@ describe('ReactContextValidator', () => {
}
class ComponentB extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
render() {
return ;
@@ -330,7 +332,7 @@ describe('ReactContextValidator', () => {
class ParentContextProvider extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.number,
+ foo: PropTypes.number,
};
getChildContext() {
return {
@@ -344,7 +346,7 @@ describe('ReactContextValidator', () => {
class MiddleMissingContext extends React.Component {
static childContextTypes = {
- bar: React.PropTypes.string.isRequired,
+ bar: PropTypes.string.isRequired,
};
render() {
return ;
@@ -359,8 +361,8 @@ describe('ReactContextValidator', () => {
}
}
ChildContextConsumer.contextTypes = {
- bar: React.PropTypes.string.isRequired,
- foo: React.PropTypes.string.isRequired,
+ bar: PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
ReactTestUtils.renderIntoDocument();
diff --git a/src/isomorphic/classic/class/__tests__/create-react-class-integration-test.js b/src/isomorphic/classic/class/__tests__/create-react-class-integration-test.js
index 3eddc97305..55fb8c1ed8 100644
--- a/src/isomorphic/classic/class/__tests__/create-react-class-integration-test.js
+++ b/src/isomorphic/classic/class/__tests__/create-react-class-integration-test.js
@@ -11,6 +11,7 @@
'use strict';
+var PropTypes;
var React;
var ReactDOM;
var ReactTestUtils;
@@ -18,8 +19,9 @@ var createReactClass;
describe('create-react-class-integration', () => {
beforeEach(() => {
- React = require('React');
- ReactDOM = require('ReactDOM');
+ PropTypes = require('prop-types');
+ React = require('react');
+ ReactDOM = require('react-dom');
ReactTestUtils = require('ReactTestUtils');
var createReactClassFactory = require('create-react-class/factory');
createReactClass = createReactClassFactory(
@@ -188,13 +190,13 @@ describe('create-react-class-integration', () => {
createReactClass({
mixins: [{}],
propTypes: {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
},
contextTypes: {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
},
childContextTypes: {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
},
render: function() {
return ;
@@ -268,7 +270,7 @@ describe('create-react-class-integration', () => {
it('renders based on context getInitialState', () => {
var Foo = createReactClass({
contextTypes: {
- className: React.PropTypes.string,
+ className: PropTypes.string,
},
getInitialState() {
return {className: this.context.className};
@@ -280,7 +282,7 @@ describe('create-react-class-integration', () => {
var Outer = createReactClass({
childContextTypes: {
- className: React.PropTypes.string,
+ className: PropTypes.string,
},
getChildContext() {
return {className: 'foo'};
diff --git a/src/isomorphic/classic/element/__tests__/ReactElementClone-test.js b/src/isomorphic/classic/element/__tests__/ReactElementClone-test.js
index 827509b196..365b187d24 100644
--- a/src/isomorphic/classic/element/__tests__/ReactElementClone-test.js
+++ b/src/isomorphic/classic/element/__tests__/ReactElementClone-test.js
@@ -11,6 +11,7 @@
'use strict';
+var PropTypes;
var React;
var ReactDOM;
var ReactTestUtils;
@@ -19,6 +20,7 @@ describe('ReactElementClone', () => {
var ComponentClass;
beforeEach(() => {
+ PropTypes = require('prop-types');
React = require('react');
ReactDOM = require('react-dom');
ReactTestUtils = require('ReactTestUtils');
@@ -288,13 +290,13 @@ describe('ReactElementClone', () => {
it('should check declared prop types after clone', () => {
spyOn(console, 'error');
class Component extends React.Component {
+ static propTypes = {
+ color: PropTypes.string.isRequired,
+ };
render() {
return React.createElement('div', null, 'My color is ' + this.color);
}
}
- Component.propTypes = {
- color: React.PropTypes.string.isRequired,
- };
class Parent extends React.Component {
render() {
return React.cloneElement(this.props.child, {color: 123});
diff --git a/src/isomorphic/classic/element/__tests__/ReactElementValidator-test.js b/src/isomorphic/classic/element/__tests__/ReactElementValidator-test.js
index ada2bb20fa..69bb8fd512 100644
--- a/src/isomorphic/classic/element/__tests__/ReactElementValidator-test.js
+++ b/src/isomorphic/classic/element/__tests__/ReactElementValidator-test.js
@@ -14,6 +14,7 @@
// NOTE: We're explicitly not using JSX in this file. This is intended to test
// classic JS without JSX.
+var PropTypes;
var React;
var ReactDOM;
var ReactTestUtils;
@@ -28,6 +29,7 @@ describe('ReactElementValidator', () => {
beforeEach(() => {
jest.resetModules();
+ PropTypes = require('prop-types');
React = require('react');
ReactDOM = require('react-dom');
ReactTestUtils = require('ReactTestUtils');
@@ -247,7 +249,7 @@ describe('ReactElementValidator', () => {
return React.createElement('div', null, 'My color is ' + props.color);
}
MyComp.propTypes = {
- color: React.PropTypes.string,
+ color: PropTypes.string,
};
function ParentComp() {
return React.createElement(MyComp, {color: 123});
@@ -332,12 +334,12 @@ describe('ReactElementValidator', () => {
spyOn(console, 'error');
class Component extends React.Component {
+ static propTypes = {prop: PropTypes.string.isRequired};
+ static defaultProps = {prop: null};
render() {
return React.createElement('span', null, this.props.prop);
}
}
- Component.propTypes = {prop: React.PropTypes.string.isRequired};
- Component.defaultProps = {prop: null};
ReactTestUtils.renderIntoDocument(React.createElement(Component));
@@ -353,12 +355,12 @@ describe('ReactElementValidator', () => {
spyOn(console, 'error');
class Component extends React.Component {
+ static propTypes = {prop: PropTypes.string.isRequired};
+ static defaultProps = {prop: 'text'};
render() {
return React.createElement('span', null, this.props.prop);
}
}
- Component.propTypes = {prop: React.PropTypes.string.isRequired};
- Component.defaultProps = {prop: 'text'};
ReactTestUtils.renderIntoDocument(
React.createElement(Component, {prop: null}),
@@ -376,13 +378,13 @@ describe('ReactElementValidator', () => {
spyOn(console, 'error');
class Component extends React.Component {
+ static propTypes = {
+ prop: PropTypes.string.isRequired,
+ };
render() {
return React.createElement('span', null, this.props.prop);
}
}
- Component.propTypes = {
- prop: React.PropTypes.string.isRequired,
- };
ReactTestUtils.renderIntoDocument(React.createElement(Component));
ReactTestUtils.renderIntoDocument(
@@ -416,13 +418,13 @@ describe('ReactElementValidator', () => {
spyOn(console, 'error');
class Component extends React.Component {
+ static propTypes = {
+ myProp: PropTypes.shape,
+ };
render() {
return React.createElement('span', null, this.props.myProp.value);
}
}
- Component.propTypes = {
- myProp: React.PropTypes.shape,
- };
ReactTestUtils.renderIntoDocument(
React.createElement(Component, {myProp: {value: 'hi'}}),
diff --git a/src/isomorphic/modern/class/PropTypes.d.ts b/src/isomorphic/modern/class/PropTypes.d.ts
new file mode 100644
index 0000000000..a8802e66fe
--- /dev/null
+++ b/src/isomorphic/modern/class/PropTypes.d.ts
@@ -0,0 +1,19 @@
+/*!
+ * Copyright 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.
+ */
+
+/**
+ * TypeScript Definition File for React.
+ *
+ * Full type definitions are not yet officially supported. These are mostly
+ * just helpers for the unit test.
+ */
+
+declare module 'prop-types' {
+ export var string : any;
+}
diff --git a/src/isomorphic/modern/class/__tests__/ReactCoffeeScriptClass-test.coffee b/src/isomorphic/modern/class/__tests__/ReactCoffeeScriptClass-test.coffee
index 1880a3dc6e..15f5e46eab 100644
--- a/src/isomorphic/modern/class/__tests__/ReactCoffeeScriptClass-test.coffee
+++ b/src/isomorphic/modern/class/__tests__/ReactCoffeeScriptClass-test.coffee
@@ -9,6 +9,7 @@ of patent rights can be found in the PATENTS file in the same directory.
React = null
ReactDOM = null
+PropTypes = null
describe 'ReactCoffeeScriptClass', ->
div = null
@@ -21,6 +22,7 @@ describe 'ReactCoffeeScriptClass', ->
beforeEach ->
React = require 'react'
ReactDOM = require 'react-dom'
+ PropTypes = require 'prop-types'
container = document.createElement 'div'
attachedListener = null
renderedName = null
@@ -102,8 +104,8 @@ describe 'ReactCoffeeScriptClass', ->
it 'renders based on context in the constructor', ->
class Foo extends React.Component
@contextTypes:
- tag: React.PropTypes.string
- className: React.PropTypes.string
+ tag: PropTypes.string
+ className: PropTypes.string
constructor: (props, context) ->
super props, context
@@ -118,8 +120,8 @@ describe 'ReactCoffeeScriptClass', ->
class Outer extends React.Component
@childContextTypes:
- tag: React.PropTypes.string
- className: React.PropTypes.string
+ tag: PropTypes.string
+ className: PropTypes.string
getChildContext: ->
tag: 'span'
@@ -393,13 +395,13 @@ describe 'ReactCoffeeScriptClass', ->
it 'supports this.context passed via getChildContext', ->
class Bar extends React.Component
@contextTypes:
- bar: React.PropTypes.string
+ bar: PropTypes.string
render: ->
div className: @context.bar
class Foo extends React.Component
@childContextTypes:
- bar: React.PropTypes.string
+ bar: PropTypes.string
getChildContext: ->
bar: 'bar-through-context'
render: ->
diff --git a/src/isomorphic/modern/class/__tests__/ReactES6Class-test.js b/src/isomorphic/modern/class/__tests__/ReactES6Class-test.js
index a6ec313d5c..f634e1d1c5 100644
--- a/src/isomorphic/modern/class/__tests__/ReactES6Class-test.js
+++ b/src/isomorphic/modern/class/__tests__/ReactES6Class-test.js
@@ -11,6 +11,7 @@
'use strict';
+var PropTypes;
var React;
var ReactDOM;
@@ -25,6 +26,7 @@ describe('ReactES6Class', () => {
var renderedName = null;
beforeEach(() => {
+ PropTypes = require('prop-types');
React = require('react');
ReactDOM = require('react-dom');
container = document.createElement('div');
@@ -123,8 +125,8 @@ describe('ReactES6Class', () => {
}
}
Foo.contextTypes = {
- tag: React.PropTypes.string,
- className: React.PropTypes.string,
+ tag: PropTypes.string,
+ className: PropTypes.string,
};
class Outer extends React.Component {
@@ -136,8 +138,8 @@ describe('ReactES6Class', () => {
}
}
Outer.childContextTypes = {
- tag: React.PropTypes.string,
- className: React.PropTypes.string,
+ tag: PropTypes.string,
+ className: PropTypes.string,
};
test(, 'SPAN', 'foo');
});
@@ -419,7 +421,7 @@ describe('ReactES6Class', () => {
return ;
}
}
- Bar.contextTypes = {bar: React.PropTypes.string};
+ Bar.contextTypes = {bar: PropTypes.string};
class Foo extends React.Component {
getChildContext() {
return {bar: 'bar-through-context'};
@@ -428,7 +430,7 @@ describe('ReactES6Class', () => {
return ;
}
}
- Foo.childContextTypes = {bar: React.PropTypes.string};
+ Foo.childContextTypes = {bar: PropTypes.string};
test(, 'DIV', 'bar-through-context');
});
diff --git a/src/isomorphic/modern/class/__tests__/ReactTypeScriptClass-test.ts b/src/isomorphic/modern/class/__tests__/ReactTypeScriptClass-test.ts
index 921474d3af..33085c89d9 100644
--- a/src/isomorphic/modern/class/__tests__/ReactTypeScriptClass-test.ts
+++ b/src/isomorphic/modern/class/__tests__/ReactTypeScriptClass-test.ts
@@ -1,3 +1,4 @@
+///
///
///
@@ -12,6 +13,7 @@
import React = require('react');
import ReactDOM = require('react-dom');
+import PropTypes = require('prop-types');
// Before Each
@@ -85,8 +87,8 @@ class StateBasedOnProps extends React.Component {
// it renders based on context in the constructor
class StateBasedOnContext extends React.Component {
static contextTypes = {
- tag: React.PropTypes.string,
- className: React.PropTypes.string
+ tag: PropTypes.string,
+ className: PropTypes.string
};
state = {
tag: this.context.tag,
@@ -100,8 +102,8 @@ class StateBasedOnContext extends React.Component {
class ProvideChildContextTypes extends React.Component {
static childContextTypes = {
- tag: React.PropTypes.string,
- className: React.PropTypes.string
+ tag: PropTypes.string,
+ className: PropTypes.string
};
getChildContext() {
return { tag: 'span', className: 'foo' };
@@ -278,13 +280,13 @@ class MisspelledComponent2 extends React.Component {
// it supports this.context passed via getChildContext
class ReadContext extends React.Component {
- static contextTypes = { bar: React.PropTypes.string };
+ static contextTypes = { bar: PropTypes.string };
render() {
return React.createElement('div', { className: this.context.bar });
}
}
class ProvideContext extends React.Component {
- static childContextTypes = { bar: React.PropTypes.string };
+ static childContextTypes = { bar: PropTypes.string };
getChildContext() {
return { bar: 'bar-through-context' };
}
diff --git a/src/isomorphic/modern/element/__tests__/ReactJSXElementValidator-test.js b/src/isomorphic/modern/element/__tests__/ReactJSXElementValidator-test.js
index 5074097dfa..ff1ff2e7c8 100644
--- a/src/isomorphic/modern/element/__tests__/ReactJSXElementValidator-test.js
+++ b/src/isomorphic/modern/element/__tests__/ReactJSXElementValidator-test.js
@@ -17,6 +17,7 @@
var React;
var ReactDOM;
var ReactTestUtils;
+var PropTypes;
describe('ReactJSXElementValidator', () => {
function normalizeCodeLocInfo(str) {
@@ -29,6 +30,7 @@ describe('ReactJSXElementValidator', () => {
beforeEach(() => {
jest.resetModules();
+ PropTypes = require('prop-types');
React = require('react');
ReactDOM = require('react-dom');
ReactTestUtils = require('ReactTestUtils');
@@ -45,7 +47,7 @@ describe('ReactJSXElementValidator', () => {
}
};
RequiredPropComponent.displayName = 'RequiredPropComponent';
- RequiredPropComponent.propTypes = {prop: React.PropTypes.string.isRequired};
+ RequiredPropComponent.propTypes = {prop: PropTypes.string.isRequired};
});
it('warns for keys for arrays of elements in children position', () => {
@@ -188,7 +190,7 @@ describe('ReactJSXElementValidator', () => {
}
}
MyComp.propTypes = {
- color: React.PropTypes.string,
+ color: PropTypes.string,
};
class ParentComp extends React.Component {
render() {
@@ -211,7 +213,7 @@ describe('ReactJSXElementValidator', () => {
return null;
}
MyComp.propTypes = {
- color: React.PropTypes.string,
+ color: PropTypes.string,
};
function MiddleComp(props) {
return ;
diff --git a/src/renderers/__tests__/ReactComponentLifeCycle-test.js b/src/renderers/__tests__/ReactComponentLifeCycle-test.js
index b9231571bb..af575d1530 100644
--- a/src/renderers/__tests__/ReactComponentLifeCycle-test.js
+++ b/src/renderers/__tests__/ReactComponentLifeCycle-test.js
@@ -14,6 +14,7 @@
var React;
var ReactDOM;
var ReactTestUtils;
+var PropTypes;
var clone = function(o) {
return JSON.parse(JSON.stringify(o));
@@ -91,6 +92,7 @@ describe('ReactComponentLifeCycle', () => {
React = require('react');
ReactDOM = require('react-dom');
ReactTestUtils = require('ReactTestUtils');
+ PropTypes = require('prop-types');
});
it('should not reuse an instance when it has been unmounted', () => {
@@ -605,14 +607,14 @@ describe('ReactComponentLifeCycle', () => {
};
}
Parent.childContextTypes = {
- x: React.PropTypes.number,
+ x: PropTypes.number,
};
function Child(props, context) {
expect(context.x).toBe(2);
return ;
}
Child.contextTypes = {
- x: React.PropTypes.number,
+ x: PropTypes.number,
};
const div = document.createElement('div');
diff --git a/src/renderers/__tests__/ReactComponentTreeHook-test.native.js b/src/renderers/__tests__/ReactComponentTreeHook-test.native.js
index dd7be7d701..ff458d64a4 100644
--- a/src/renderers/__tests__/ReactComponentTreeHook-test.native.js
+++ b/src/renderers/__tests__/ReactComponentTreeHook-test.native.js
@@ -29,10 +29,12 @@ describeStack('ReactComponentTreeHook', () => {
var View;
var Image;
var Text;
+ var PropTypes;
beforeEach(() => {
jest.resetModules();
+ PropTypes = require('prop-types');
React = require('react');
ReactNative = require('ReactNative');
ReactInstanceMap = require('ReactInstanceMap');
@@ -50,7 +52,7 @@ describeStack('ReactComponentTreeHook', () => {
});
Text = class extends React.Component {
static childContextTypes = {
- isInAParentText: React.PropTypes.bool,
+ isInAParentText: PropTypes.bool,
};
getChildContext() {
diff --git a/src/renderers/__tests__/ReactErrorBoundaries-test.js b/src/renderers/__tests__/ReactErrorBoundaries-test.js
index d9a34dc5e6..49e9a1273d 100644
--- a/src/renderers/__tests__/ReactErrorBoundaries-test.js
+++ b/src/renderers/__tests__/ReactErrorBoundaries-test.js
@@ -13,6 +13,7 @@
var ReactDOMFeatureFlags = require('ReactDOMFeatureFlags');
+var PropTypes;
var React;
var ReactDOM;
@@ -37,6 +38,7 @@ describe('ReactErrorBoundaries', () => {
var Normal;
beforeEach(() => {
+ PropTypes = require('prop-types');
ReactDOM = require('react-dom');
React = require('react');
@@ -737,7 +739,7 @@ describe('ReactErrorBoundaries', () => {
it('renders an error state if context provider throws in componentWillMount', () => {
class BrokenComponentWillMountWithContext extends React.Component {
- static childContextTypes = {foo: React.PropTypes.number};
+ static childContextTypes = {foo: PropTypes.number};
getChildContext() {
return {foo: 42};
}
@@ -774,7 +776,7 @@ describe('ReactErrorBoundaries', () => {
};
}
BrokenComponentWillMountWithContext.childContextTypes = {
- foo: React.PropTypes.number,
+ foo: PropTypes.number,
};
var container = document.createElement('div');
diff --git a/src/renderers/__tests__/ReactStatelessComponent-test.js b/src/renderers/__tests__/ReactStatelessComponent-test.js
index 3f11bf438e..0792eded59 100644
--- a/src/renderers/__tests__/ReactStatelessComponent-test.js
+++ b/src/renderers/__tests__/ReactStatelessComponent-test.js
@@ -11,6 +11,7 @@
'use strict';
+var PropTypes;
var React;
var ReactDOM;
var ReactTestUtils;
@@ -28,6 +29,7 @@ describe('ReactStatelessComponent', () => {
beforeEach(() => {
jest.resetModuleRegistry();
+ PropTypes = require('prop-types');
React = require('react');
ReactDOM = require('react-dom');
ReactTestUtils = require('ReactTestUtils');
@@ -68,7 +70,7 @@ describe('ReactStatelessComponent', () => {
it('should pass context thru stateless component', () => {
class Child extends React.Component {
static contextTypes = {
- test: React.PropTypes.string.isRequired,
+ test: PropTypes.string.isRequired,
};
render() {
@@ -82,7 +84,7 @@ describe('ReactStatelessComponent', () => {
class GrandParent extends React.Component {
static childContextTypes = {
- test: React.PropTypes.string.isRequired,
+ test: PropTypes.string.isRequired,
};
getChildContext() {
@@ -111,7 +113,7 @@ describe('ReactStatelessComponent', () => {
}
StatelessComponentWithChildContext.childContextTypes = {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
};
var container = document.createElement('div');
@@ -355,7 +357,7 @@ describe('ReactStatelessComponent', () => {
return {props.test}
;
}
Child.defaultProps = {test: 2};
- Child.propTypes = {test: React.PropTypes.string};
+ Child.propTypes = {test: PropTypes.string};
spyOn(console, 'error');
ReactTestUtils.renderIntoDocument();
@@ -372,7 +374,7 @@ describe('ReactStatelessComponent', () => {
it('should receive context', () => {
class Parent extends React.Component {
static childContextTypes = {
- lang: React.PropTypes.string,
+ lang: PropTypes.string,
};
getChildContext() {
@@ -387,7 +389,7 @@ describe('ReactStatelessComponent', () => {
function Child(props, context) {
return {context.lang}
;
}
- Child.contextTypes = {lang: React.PropTypes.string};
+ Child.contextTypes = {lang: PropTypes.string};
var el = document.createElement('div');
ReactDOM.render(, el);
diff --git a/src/renderers/dom/fiber/__tests__/ReactDOMFiber-test.js b/src/renderers/dom/fiber/__tests__/ReactDOMFiber-test.js
index a2280be28f..026fa91035 100644
--- a/src/renderers/dom/fiber/__tests__/ReactDOMFiber-test.js
+++ b/src/renderers/dom/fiber/__tests__/ReactDOMFiber-test.js
@@ -15,6 +15,7 @@ var React = require('react');
var ReactDOM = require('react-dom');
var ReactDOMFeatureFlags = require('ReactDOMFeatureFlags');
var ReactTestUtils = require('ReactTestUtils');
+var PropTypes = require('prop-types');
describe('ReactDOMFiber', () => {
var container;
@@ -683,7 +684,7 @@ describe('ReactDOMFiber', () => {
class Component extends React.Component {
static contextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
render() {
@@ -693,7 +694,7 @@ describe('ReactDOMFiber', () => {
class Parent extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
getChildContext() {
@@ -717,8 +718,8 @@ describe('ReactDOMFiber', () => {
class Component extends React.Component {
static contextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
render() {
@@ -728,8 +729,8 @@ describe('ReactDOMFiber', () => {
class Parent extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
state = {
@@ -761,8 +762,8 @@ describe('ReactDOMFiber', () => {
class Component extends React.Component {
static contextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
render() {
@@ -772,8 +773,8 @@ describe('ReactDOMFiber', () => {
class Parent extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
getChildContext() {
diff --git a/src/renderers/dom/shared/__tests__/ReactDOMServerIntegration-test.js b/src/renderers/dom/shared/__tests__/ReactDOMServerIntegration-test.js
index af29b8d5ac..0381ec8fb8 100644
--- a/src/renderers/dom/shared/__tests__/ReactDOMServerIntegration-test.js
+++ b/src/renderers/dom/shared/__tests__/ReactDOMServerIntegration-test.js
@@ -12,6 +12,7 @@
'use strict';
let ExecutionEnvironment;
+let PropTypes;
let React;
let ReactDOM;
let ReactDOMServer;
@@ -206,6 +207,7 @@ function expectMarkupMismatch(serverElement, clientElement) {
// To get around this, we must reload React modules in between server and client render.
function resetModules() {
jest.resetModuleRegistry();
+ PropTypes = require('prop-types');
React = require('React');
ReactDOM = require('ReactDOM');
ReactDOMServer = require('ReactDOMServer');
@@ -1585,7 +1587,7 @@ describe('ReactDOMServerIntegration', () => {
return this.props.children;
}
}
- Parent.childContextTypes = {text: React.PropTypes.string};
+ Parent.childContextTypes = {text: PropTypes.string};
PurpleContext = props => {props.children};
RedContext = props => {props.children};
@@ -1597,7 +1599,7 @@ describe('ReactDOMServerIntegration', () => {
return {this.context.text}
;
}
}
- ClassChildWithContext.contextTypes = {text: React.PropTypes.string};
+ ClassChildWithContext.contextTypes = {text: PropTypes.string};
const e = await render(
,
@@ -1609,7 +1611,7 @@ describe('ReactDOMServerIntegration', () => {
function StatelessChildWithContext(props, context) {
return {context.text}
;
}
- StatelessChildWithContext.contextTypes = {text: React.PropTypes.string};
+ StatelessChildWithContext.contextTypes = {text: PropTypes.string};
const e = await render(
,
@@ -1650,7 +1652,7 @@ describe('ReactDOMServerIntegration', () => {
return {this.context.text}
;
}
}
- ClassChildWithWrongContext.contextTypes = {foo: React.PropTypes.string};
+ ClassChildWithWrongContext.contextTypes = {foo: PropTypes.string};
const e = await render(
,
@@ -1664,7 +1666,7 @@ describe('ReactDOMServerIntegration', () => {
return {context.text}
;
}
StatelessChildWithWrongContext.contextTypes = {
- foo: React.PropTypes.string,
+ foo: PropTypes.string,
};
const e = await render(
@@ -1677,7 +1679,7 @@ describe('ReactDOMServerIntegration', () => {
function Grandchild(props, context) {
return {context.text}
;
}
- Grandchild.contextTypes = {text: React.PropTypes.string};
+ Grandchild.contextTypes = {text: PropTypes.string};
const Child = props => ;
@@ -1689,7 +1691,7 @@ describe('ReactDOMServerIntegration', () => {
const Grandchild = (props, context) => {
return {context.text}
;
};
- Grandchild.contextTypes = {text: React.PropTypes.string};
+ Grandchild.contextTypes = {text: PropTypes.string};
const e = await render(
,
@@ -1706,7 +1708,7 @@ describe('ReactDOMServerIntegration', () => {
return ;
}
}
- Parent.childContextTypes = {text1: React.PropTypes.string};
+ Parent.childContextTypes = {text1: PropTypes.string};
class Child extends React.Component {
getChildContext() {
@@ -1716,7 +1718,7 @@ describe('ReactDOMServerIntegration', () => {
return ;
}
}
- Child.childContextTypes = {text2: React.PropTypes.string};
+ Child.childContextTypes = {text2: PropTypes.string};
const Grandchild = (props, context) => {
return (
@@ -1727,8 +1729,8 @@ describe('ReactDOMServerIntegration', () => {
);
};
Grandchild.contextTypes = {
- text1: React.PropTypes.string,
- text2: React.PropTypes.string,
+ text1: PropTypes.string,
+ text2: PropTypes.string,
};
const e = await render();
@@ -1750,12 +1752,12 @@ describe('ReactDOMServerIntegration', () => {
return ;
}
}
- WillMountContext.childContextTypes = {text: React.PropTypes.string};
+ WillMountContext.childContextTypes = {text: PropTypes.string};
const Child = (props, context) => {
return {context.text}
;
};
- Child.contextTypes = {text: React.PropTypes.string};
+ Child.contextTypes = {text: PropTypes.string};
const e = await render();
expect(e.textContent).toBe('foo');
@@ -1788,7 +1790,7 @@ describe('ReactDOMServerIntegration', () => {
return {value1: 'foo', value2: 'bar'};
}
}
- Component.childContextTypes = {value1: React.PropTypes.string};
+ Component.childContextTypes = {value1: PropTypes.string};
return render();
},
);
diff --git a/src/renderers/dom/shared/__tests__/renderSubtreeIntoContainer-test.js b/src/renderers/dom/shared/__tests__/renderSubtreeIntoContainer-test.js
index 30e617480b..a0a30dfe8d 100644
--- a/src/renderers/dom/shared/__tests__/renderSubtreeIntoContainer-test.js
+++ b/src/renderers/dom/shared/__tests__/renderSubtreeIntoContainer-test.js
@@ -12,6 +12,7 @@
'use strict';
var React = require('react');
+var PropTypes = require('prop-types');
var ReactDOM = require('react-dom');
var ReactTestUtils = require('ReactTestUtils');
var renderSubtreeIntoContainer = require('renderSubtreeIntoContainer');
@@ -22,7 +23,7 @@ describe('renderSubtreeIntoContainer', () => {
class Component extends React.Component {
static contextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
render() {
@@ -32,7 +33,7 @@ describe('renderSubtreeIntoContainer', () => {
class Parent extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
getChildContext() {
@@ -63,7 +64,7 @@ describe('renderSubtreeIntoContainer', () => {
class Component extends React.Component {
static contextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
render() {
@@ -76,7 +77,7 @@ describe('renderSubtreeIntoContainer', () => {
// eslint-disable-next-line no-unused-vars
class Parent extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
+ foo: PropTypes.string.isRequired,
};
getChildContext() {
@@ -104,8 +105,8 @@ describe('renderSubtreeIntoContainer', () => {
class Component extends React.Component {
static contextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
render() {
@@ -115,8 +116,8 @@ describe('renderSubtreeIntoContainer', () => {
class Parent extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
state = {
@@ -156,8 +157,8 @@ describe('renderSubtreeIntoContainer', () => {
class Component extends React.Component {
static contextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
render() {
@@ -167,8 +168,8 @@ describe('renderSubtreeIntoContainer', () => {
class Parent extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.string.isRequired,
- getFoo: React.PropTypes.func.isRequired,
+ foo: PropTypes.string.isRequired,
+ getFoo: PropTypes.func.isRequired,
};
getChildContext() {
@@ -229,7 +230,7 @@ describe('renderSubtreeIntoContainer', () => {
return {value: this.props.value};
}
static childContextTypes = {
- value: React.PropTypes.string.isRequired,
+ value: PropTypes.string.isRequired,
};
}
@@ -244,7 +245,7 @@ describe('renderSubtreeIntoContainer', () => {
class Child extends React.Component {
static contextTypes = {
- value: React.PropTypes.string.isRequired,
+ value: PropTypes.string.isRequired,
};
render() {
return {this.context.value}
;
@@ -272,7 +273,7 @@ describe('renderSubtreeIntoContainer', () => {
renderSubtreeIntoContainer(this, , portal1);
}
static childContextTypes = {
- value: React.PropTypes.string.isRequired,
+ value: PropTypes.string.isRequired,
};
}
@@ -287,7 +288,7 @@ describe('renderSubtreeIntoContainer', () => {
class Child extends React.Component {
static contextTypes = {
- value: React.PropTypes.string.isRequired,
+ value: PropTypes.string.isRequired,
};
render() {
return {this.context.value}
;
diff --git a/src/renderers/dom/shared/utils/ReactControlledValuePropTypes.js b/src/renderers/dom/shared/utils/ReactControlledValuePropTypes.js
index e0cdedf22f..0f8b44bc81 100644
--- a/src/renderers/dom/shared/utils/ReactControlledValuePropTypes.js
+++ b/src/renderers/dom/shared/utils/ReactControlledValuePropTypes.js
@@ -11,7 +11,7 @@
'use strict';
-var React = require('react');
+var PropTypes = require('prop-types');
var ReactPropTypesSecret = require('ReactPropTypesSecret');
var warning = require('fbjs/lib/warning');
@@ -57,7 +57,7 @@ var propTypes = {
'set either `onChange` or `readOnly`.',
);
},
- onChange: React.PropTypes.func,
+ onChange: PropTypes.func,
};
var loggedTypeFailures = {};
diff --git a/src/renderers/native/__tests__/ReactNativeEvents-test.js b/src/renderers/native/__tests__/ReactNativeEvents-test.js
index 56206149a7..9efa5f05e0 100644
--- a/src/renderers/native/__tests__/ReactNativeEvents-test.js
+++ b/src/renderers/native/__tests__/ReactNativeEvents-test.js
@@ -11,6 +11,7 @@
'use strict';
+var PropTypes;
var RCTEventEmitter;
var React;
var ReactNative;
@@ -21,6 +22,7 @@ var createReactNativeComponentClass;
beforeEach(() => {
jest.resetModules();
+ PropTypes = require('prop-types');
RCTEventEmitter = require('RCTEventEmitter');
React = require('react');
ReactNative = require('ReactNative');
@@ -97,7 +99,7 @@ it('handles events on text nodes', () => {
});
class ContextHack extends React.Component {
- static childContextTypes = {isInAParentText: React.PropTypes.bool};
+ static childContextTypes = {isInAParentText: PropTypes.bool};
getChildContext() {
return {isInAParentText: true};
}
diff --git a/src/renderers/shared/fiber/__tests__/ReactIncremental-test.js b/src/renderers/shared/fiber/__tests__/ReactIncremental-test.js
index f0da503be5..b66151f38e 100644
--- a/src/renderers/shared/fiber/__tests__/ReactIncremental-test.js
+++ b/src/renderers/shared/fiber/__tests__/ReactIncremental-test.js
@@ -14,12 +14,14 @@
var React;
var ReactNoop;
var ReactFeatureFlags;
+var PropTypes;
describe('ReactIncremental', () => {
beforeEach(() => {
jest.resetModules();
React = require('react');
ReactNoop = require('ReactNoop');
+ PropTypes = require('prop-types');
ReactFeatureFlags = require('ReactFeatureFlags');
ReactFeatureFlags.disableNewFiberFeatures = false;
@@ -1592,7 +1594,7 @@ describe('ReactIncremental', () => {
class Intl extends React.Component {
static childContextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
getChildContext() {
return {
@@ -1607,7 +1609,7 @@ describe('ReactIncremental', () => {
class Router extends React.Component {
static childContextTypes = {
- route: React.PropTypes.string,
+ route: PropTypes.string,
};
getChildContext() {
return {
@@ -1622,7 +1624,7 @@ describe('ReactIncremental', () => {
class ShowLocale extends React.Component {
static contextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
render() {
ops.push('ShowLocale ' + JSON.stringify(this.context));
@@ -1632,7 +1634,7 @@ describe('ReactIncremental', () => {
class ShowRoute extends React.Component {
static contextTypes = {
- route: React.PropTypes.string,
+ route: PropTypes.string,
};
render() {
ops.push('ShowRoute ' + JSON.stringify(this.context));
@@ -1645,8 +1647,8 @@ describe('ReactIncremental', () => {
return `${context.route} in ${context.locale}`;
}
ShowBoth.contextTypes = {
- locale: React.PropTypes.string,
- route: React.PropTypes.string,
+ locale: PropTypes.string,
+ route: PropTypes.string,
};
class ShowNeither extends React.Component {
@@ -1745,10 +1747,10 @@ describe('ReactIncremental', () => {
var ops = [];
class Recurse extends React.Component {
static contextTypes = {
- n: React.PropTypes.number,
+ n: PropTypes.number,
};
static childContextTypes = {
- n: React.PropTypes.number,
+ n: PropTypes.number,
};
getChildContext() {
return {n: (this.context.n || 3) - 1};
@@ -1777,7 +1779,7 @@ describe('ReactIncremental', () => {
class Intl extends React.Component {
static childContextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
getChildContext() {
return {
@@ -1792,7 +1794,7 @@ describe('ReactIncremental', () => {
class ShowLocale extends React.Component {
static contextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
render() {
ops.push('ShowLocale ' + JSON.stringify(this.context));
@@ -1835,7 +1837,7 @@ describe('ReactIncremental', () => {
class Intl extends React.Component {
static childContextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
getChildContext() {
const childContext = {
@@ -1852,7 +1854,7 @@ describe('ReactIncremental', () => {
class ShowLocaleClass extends React.Component {
static contextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
render() {
ops.push('ShowLocaleClass:read ' + JSON.stringify(this.context));
@@ -1865,7 +1867,7 @@ describe('ReactIncremental', () => {
return context.locale;
}
ShowLocaleFn.contextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
class Stateful extends React.Component {
@@ -1925,7 +1927,7 @@ describe('ReactIncremental', () => {
class Intl extends React.Component {
static childContextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
getChildContext() {
const childContext = {
@@ -1942,7 +1944,7 @@ describe('ReactIncremental', () => {
class ShowLocaleClass extends React.Component {
static contextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
render() {
ops.push('ShowLocaleClass:read ' + JSON.stringify(this.context));
@@ -1955,7 +1957,7 @@ describe('ReactIncremental', () => {
return context.locale;
}
ShowLocaleFn.contextTypes = {
- locale: React.PropTypes.string,
+ locale: PropTypes.string,
};
function IndirectionFn(props, context) {
diff --git a/src/renderers/shared/fiber/__tests__/ReactIncrementalErrorHandling-test.js b/src/renderers/shared/fiber/__tests__/ReactIncrementalErrorHandling-test.js
index 4b4b415cc7..b4c9098e8f 100644
--- a/src/renderers/shared/fiber/__tests__/ReactIncrementalErrorHandling-test.js
+++ b/src/renderers/shared/fiber/__tests__/ReactIncrementalErrorHandling-test.js
@@ -11,6 +11,7 @@
'use strict';
+var PropTypes;
var React;
var ReactNoop;
var ReactFeatureFlags;
@@ -18,6 +19,7 @@ var ReactFeatureFlags;
describe('ReactIncrementalErrorHandling', () => {
beforeEach(() => {
jest.resetModules();
+ PropTypes = require('prop-types');
React = require('react');
ReactNoop = require('ReactNoop');
ReactFeatureFlags = require('ReactFeatureFlags');
@@ -679,8 +681,8 @@ describe('ReactIncrementalErrorHandling', () => {
it('unwinds the context stack correctly on error', () => {
class Provider extends React.Component {
- static childContextTypes = {message: React.PropTypes.string};
- static contextTypes = {message: React.PropTypes.string};
+ static childContextTypes = {message: PropTypes.string};
+ static contextTypes = {message: PropTypes.string};
getChildContext() {
return {
message: (this.context.message || '') + this.props.message,
@@ -696,7 +698,7 @@ describe('ReactIncrementalErrorHandling', () => {
}
Connector.contextTypes = {
- message: React.PropTypes.string,
+ message: PropTypes.string,
};
function BadRender() {
diff --git a/src/renderers/shared/fiber/__tests__/ReactIncrementalPerf-test.js b/src/renderers/shared/fiber/__tests__/ReactIncrementalPerf-test.js
index b4a4748003..56fa122245 100644
--- a/src/renderers/shared/fiber/__tests__/ReactIncrementalPerf-test.js
+++ b/src/renderers/shared/fiber/__tests__/ReactIncrementalPerf-test.js
@@ -17,6 +17,7 @@ describe('ReactDebugFiberPerf', () => {
let ReactFeatureFlags;
let ReactNoop;
let ReactPortal;
+ let PropTypes;
let root;
let activeMeasure;
@@ -119,6 +120,7 @@ describe('ReactDebugFiberPerf', () => {
ReactNoop = require('ReactNoop');
ReactPortal = require('ReactPortal');
ReactFeatureFlags.disableNewFiberFeatures = false;
+ PropTypes = require('prop-types');
});
afterEach(() => {
@@ -245,7 +247,7 @@ describe('ReactDebugFiberPerf', () => {
it('captures all lifecycles', () => {
class AllLifecycles extends React.Component {
static childContextTypes = {
- foo: React.PropTypes.any,
+ foo: PropTypes.any,
};
shouldComponentUpdate() {
return true;
diff --git a/src/test/__tests__/ReactTestUtils-test.js b/src/test/__tests__/ReactTestUtils-test.js
index 68c489cfb8..cd1b2a5dc8 100644
--- a/src/test/__tests__/ReactTestUtils-test.js
+++ b/src/test/__tests__/ReactTestUtils-test.js
@@ -11,6 +11,7 @@
'use strict';
+var PropTypes;
var React;
var ReactDOM;
var ReactDOMServer;
@@ -18,6 +19,7 @@ var ReactTestUtils;
describe('ReactTestUtils', () => {
beforeEach(() => {
+ PropTypes = require('prop-types');
React = require('react');
ReactDOM = require('react-dom');
ReactDOMServer = require('react-dom/server');
@@ -195,7 +197,7 @@ describe('ReactTestUtils', () => {
it('can shallowly render components with contextTypes', () => {
class SimpleComponent extends React.Component {
static contextTypes = {
- name: React.PropTypes.string,
+ name: PropTypes.string,
};
render() {
@@ -258,7 +260,7 @@ describe('ReactTestUtils', () => {
it('can pass context when shallowly rendering', () => {
class SimpleComponent extends React.Component {
static contextTypes = {
- name: React.PropTypes.string,
+ name: PropTypes.string,
};
render() {
@@ -278,7 +280,7 @@ describe('ReactTestUtils', () => {
class SimpleComponent extends React.Component {
static contextTypes = {
- name: React.PropTypes.string.isRequired,
+ name: PropTypes.string.isRequired,
};
render() {
diff --git a/yarn.lock b/yarn.lock
index 681679cb60..b297a7165e 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -3929,6 +3929,12 @@ promise@^7.1.1:
dependencies:
asap "~2.0.3"
+prop-types@^15.5.6:
+ version "15.5.6"
+ resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.5.6.tgz#797a915b1714b645ebb7c5d6cc690346205bd2aa"
+ dependencies:
+ fbjs "^0.8.9"
+
prr@~0.0.0:
version "0.0.0"
resolved "https://registry.yarnpkg.com/prr/-/prr-0.0.0.tgz#1a84b85908325501411853d0081ee3fa86e2926a"