@ariakit/react-core
Version:
Ariakit React core
59 lines (47 loc) • 2.16 kB
JavaScript
;Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } }
var _SZKZ5GQPcjs = require('./SZKZ5GQP.cjs');
var _EMYYI4CZcjs = require('./EMYYI4CZ.cjs');
var _MZ2HG624cjs = require('./MZ2HG624.cjs');
// src/form/form-store.ts
var _formstore = require('@ariakit/core/form/form-store'); var Core = _interopRequireWildcard(_formstore);
var _react = require('react');
function useFormStoreProps(store, update, props) {
store = _SZKZ5GQPcjs.useCollectionStoreProps.call(void 0, store, update, props);
_EMYYI4CZcjs.useStoreProps.call(void 0, store, props, "values", "setValues");
_EMYYI4CZcjs.useStoreProps.call(void 0, store, props, "errors", "setErrors");
_EMYYI4CZcjs.useStoreProps.call(void 0, store, props, "touched", "setTouched");
const useValue = _react.useCallback.call(void 0,
(name) => store.useState(() => store.getValue(name)),
[store]
);
const useValidate = _react.useCallback.call(void 0,
(callback) => {
callback = _MZ2HG624cjs.useEvent.call(void 0, callback);
const items = store.useState("items");
_react.useEffect.call(void 0, () => store.onValidate(callback), [items, callback]);
},
[store]
);
const useSubmit = _react.useCallback.call(void 0,
(callback) => {
callback = _MZ2HG624cjs.useEvent.call(void 0, callback);
const items = store.useState("items");
_react.useEffect.call(void 0, () => store.onSubmit(callback), [items, callback]);
},
[store]
);
return _react.useMemo.call(void 0,
() => ({
...store,
useValue,
useValidate,
useSubmit
}),
[]
);
}
function useFormStore(props = {}) {
const [store, update] = _EMYYI4CZcjs.useStore.call(void 0, Core.createFormStore, props);
return useFormStoreProps(store, update, props);
}
exports.useFormStoreProps = useFormStoreProps; exports.useFormStore = useFormStore;