UNPKG

1.5 kBJavaScriptView Raw
1"use strict";
2
3exports.__esModule = true;
4exports.default = useMergeState;
5
6var _react = require("react");
7
8function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
9
10/**
11 * Mimics a React class component's state model, of having a single unified
12 * `state` object and an updater that merges updates into the existing state, as
13 * opposed to replacing it.
14 *
15 * ```js
16 * const [state, setState] = useMergeState({ name: 'Betsy', age: 24 })
17 *
18 * setState({ name: 'Johan' }) // { name: 'Johan', age: 24 }
19 *
20 * setState(state => ({ age: state.age + 10 })) // { name: 'Johan', age: 34 }
21 * ```
22 *
23 * @param initialState The initial state object
24 */
25function useMergeState(initialState) {
26 var _useState = (0, _react.useState)(initialState),
27 state = _useState[0],
28 setState = _useState[1];
29
30 var updater = (0, _react.useCallback)(function (update) {
31 if (update === null) return;
32
33 if (typeof update === 'function') {
34 setState(function (state) {
35 var nextState = update(state);
36 return nextState == null ? state : _extends({}, state, nextState);
37 });
38 } else {
39 setState(function (state) {
40 return _extends({}, state, update);
41 });
42 }
43 }, [setState]);
44 return [state, updater];
45}
\No newline at end of file