UNPKG

@gechiui/compose

Version:
61 lines (50 loc) 1.78 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = withState; var _element = require("@gechiui/element"); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _deprecated = _interopRequireDefault(require("@gechiui/deprecated")); var _createHigherOrderComponent = _interopRequireDefault(require("../../utils/create-higher-order-component")); /** * GeChiUI dependencies */ /** * Internal dependencies */ /** * A Higher Order Component used to provide and manage internal component state * via props. * * @deprecated Use `useState` instead. * * @param {any} initialState Optional initial state of the component. * * @return {any} A higher order component wrapper accepting a component that takes the state props + its own props + `setState` and returning a component that only accepts the own props. */ function withState() { let initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; (0, _deprecated.default)('gc.compose.withState', { since: '5.8', alternative: 'gc.element.useState' }); return (0, _createHigherOrderComponent.default)(OriginalComponent => { return class WrappedComponent extends _element.Component { constructor( /** @type {any} */ props) { super(props); this.setState = this.setState.bind(this); this.state = initialState; } render() { return (0, _element.createElement)(OriginalComponent, (0, _extends2.default)({}, this.props, this.state, { setState: this.setState })); } }; }, 'withState'); } //# sourceMappingURL=index.js.map