(workInProgress)
| 7658 | } |
| 7659 | |
| 7660 | function checkClassInstance(workInProgress) { |
| 7661 | var instance = workInProgress.stateNode; |
| 7662 | var type = workInProgress.type; |
| 7663 | { |
| 7664 | var name = getComponentName(workInProgress) || 'Component'; |
| 7665 | var renderPresent = instance.render; |
| 7666 | |
| 7667 | if (!renderPresent) { |
| 7668 | if (type.prototype && typeof type.prototype.render === 'function') { |
| 7669 | warning(false, '%s(...): No `render` method found on the returned component ' + 'instance: did you accidentally return an object from the constructor?', name); |
| 7670 | } else { |
| 7671 | warning(false, '%s(...): No `render` method found on the returned component ' + 'instance: you may have forgotten to define `render`.', name); |
| 7672 | } |
| 7673 | } |
| 7674 | |
| 7675 | var noGetInitialStateOnES6 = !instance.getInitialState || instance.getInitialState.isReactClassApproved || instance.state; |
| 7676 | warning(noGetInitialStateOnES6, 'getInitialState was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Did you mean to define a state property instead?', name); |
| 7677 | var noGetDefaultPropsOnES6 = !instance.getDefaultProps || instance.getDefaultProps.isReactClassApproved; |
| 7678 | warning(noGetDefaultPropsOnES6, 'getDefaultProps was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Use a static property to define defaultProps instead.', name); |
| 7679 | var noInstancePropTypes = !instance.propTypes; |
| 7680 | warning(noInstancePropTypes, 'propTypes was defined as an instance property on %s. Use a static ' + 'property to define propTypes instead.', name); |
| 7681 | var noInstanceContextTypes = !instance.contextTypes; |
| 7682 | warning(noInstanceContextTypes, 'contextTypes was defined as an instance property on %s. Use a static ' + 'property to define contextTypes instead.', name); |
| 7683 | var noComponentShouldUpdate = typeof instance.componentShouldUpdate !== 'function'; |
| 7684 | warning(noComponentShouldUpdate, '%s has a method called ' + 'componentShouldUpdate(). Did you mean shouldComponentUpdate()? ' + 'The name is phrased as a question because the function is ' + 'expected to return a value.', name); |
| 7685 | if (type.prototype && type.prototype.isPureReactComponent && typeof instance.shouldComponentUpdate !== 'undefined') { |
| 7686 | warning(false, '%s has a method called shouldComponentUpdate(). ' + 'shouldComponentUpdate should not be used when extending React.PureComponent. ' + 'Please extend React.Component if shouldComponentUpdate is used.', getComponentName(workInProgress) || 'A pure component'); |
| 7687 | } |
| 7688 | var noComponentDidUnmount = typeof instance.componentDidUnmount !== 'function'; |
| 7689 | warning(noComponentDidUnmount, '%s has a method called ' + 'componentDidUnmount(). But there is no such lifecycle method. ' + 'Did you mean componentWillUnmount()?', name); |
| 7690 | var noComponentDidReceiveProps = typeof instance.componentDidReceiveProps !== 'function'; |
| 7691 | warning(noComponentDidReceiveProps, '%s has a method called ' + 'componentDidReceiveProps(). But there is no such lifecycle method. ' + 'If you meant to update the state in response to changing props, ' + 'use componentWillReceiveProps(). If you meant to fetch data or ' + 'run side-effects or mutations after React has updated the UI, use componentDidUpdate().', name); |
| 7692 | var noComponentWillRecieveProps = typeof instance.componentWillRecieveProps !== 'function'; |
| 7693 | warning(noComponentWillRecieveProps, '%s has a method called ' + 'componentWillRecieveProps(). Did you mean componentWillReceiveProps()?', name); |
| 7694 | var noUnsafeComponentWillRecieveProps = typeof instance.UNSAFE_componentWillRecieveProps !== 'function'; |
| 7695 | warning(noUnsafeComponentWillRecieveProps, '%s has a method called ' + 'UNSAFE_componentWillRecieveProps(). Did you mean UNSAFE_componentWillReceiveProps()?', name); |
| 7696 | var hasMutatedProps = instance.props !== workInProgress.pendingProps; |
| 7697 | warning(instance.props === undefined || !hasMutatedProps, '%s(...): When calling super() in `%s`, make sure to pass ' + "up the same props that your component's constructor was passed.", name, name); |
| 7698 | var noInstanceDefaultProps = !instance.defaultProps; |
| 7699 | warning(noInstanceDefaultProps, 'Setting defaultProps as an instance property on %s is not supported and will be ignored.' + ' Instead, define defaultProps as a static property on %s.', name, name); |
| 7700 | var noInstanceGetDerivedStateFromProps = typeof instance.getDerivedStateFromProps !== 'function'; |
| 7701 | warning(noInstanceGetDerivedStateFromProps, '%s: getDerivedStateFromProps() is defined as an instance method ' + 'and will be ignored. Instead, declare it as a static method.', name); |
| 7702 | var noInstanceGetDerivedStateFromCatch = typeof instance.getDerivedStateFromCatch !== 'function'; |
| 7703 | warning(noInstanceGetDerivedStateFromCatch, '%s: getDerivedStateFromCatch() is defined as an instance method ' + 'and will be ignored. Instead, declare it as a static method.', name); |
| 7704 | var _state = instance.state; |
| 7705 | if (_state && (typeof _state !== 'object' || isArray(_state))) { |
| 7706 | warning(false, '%s.state: must be set to an object or null', name); |
| 7707 | } |
| 7708 | if (typeof instance.getChildContext === 'function') { |
| 7709 | warning(typeof type.childContextTypes === 'object', '%s.getChildContext(): childContextTypes must be defined in order to ' + 'use getChildContext().', name); |
| 7710 | } |
| 7711 | } |
| 7712 | } |
| 7713 | |
| 7714 | function resetInputPointers(workInProgress, instance) { |
| 7715 | instance.props = workInProgress.memoizedProps; |
no test coverage detected