@ariakit/react-core
Version:
Ariakit React core
62 lines (47 loc) • 2.28 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 _TZV62ZWDcjs = require('./TZV62ZWD.cjs');
var _25BPIGZHcjs = require('./25BPIGZH.cjs');
var _OZM4QA2Vcjs = require('./OZM4QA2V.cjs');
var _7EQBAZ46cjs = require('./7EQBAZ46.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 = _TZV62ZWDcjs.useCollectionStoreProps.call(void 0, store, update, props);
_25BPIGZHcjs.useStoreProps.call(void 0, store, props, "values", "setValues");
_25BPIGZHcjs.useStoreProps.call(void 0, store, props, "errors", "setErrors");
_25BPIGZHcjs.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 = _OZM4QA2Vcjs.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 = _OZM4QA2Vcjs.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,
() => _7EQBAZ46cjs.__spreadProps.call(void 0, _7EQBAZ46cjs.__spreadValues.call(void 0, {}, store), {
useValue,
useValidate,
useSubmit
}),
[]
);
}
function useFormStore(props = {}) {
const [store, update] = _25BPIGZHcjs.useStore.call(void 0, Core.createFormStore, props);
return useFormStoreProps(store, update, props);
}
exports.useFormStoreProps = useFormStoreProps; exports.useFormStore = useFormStore;