UNPKG

@ariakit/react-core

Version:

Ariakit React core

147 lines (125 loc) 4.67 kB
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); var _OKZ7VQEOcjs = require('../__chunks/OKZ7VQEO.cjs'); var _6M54DBBOcjs = require('../__chunks/6M54DBBO.cjs'); require('../__chunks/VNVMHTCY.cjs'); require('../__chunks/6F6SPO63.cjs'); require('../__chunks/N37IROBR.cjs'); require('../__chunks/YTEJF6TY.cjs'); require('../__chunks/MIBORXQW.cjs'); require('../__chunks/IH6KF7WR.cjs'); require('../__chunks/ZVJRPAXY.cjs'); require('../__chunks/YDPERDKF.cjs'); require('../__chunks/KVXNVDJK.cjs'); require('../__chunks/D6FV6EYS.cjs'); var _XBPPFZKGcjs = require('../__chunks/XBPPFZKG.cjs'); var _FRCWMMQNcjs = require('../__chunks/FRCWMMQN.cjs'); require('../__chunks/DHAXJ5PA.cjs'); require('../__chunks/YUGKYIYY.cjs'); require('../__chunks/T3QB4FR3.cjs'); require('../__chunks/IRJEBRAW.cjs'); require('../__chunks/OUGM36S4.cjs'); require('../__chunks/25BPIGZH.cjs'); require('../__chunks/6HKL3JR2.cjs'); var _WULEED4Qcjs = require('../__chunks/WULEED4Q.cjs'); var _OZM4QA2Vcjs = require('../__chunks/OZM4QA2V.cjs'); require('../__chunks/FDRJDQ5Y.cjs'); var _7EQBAZ46cjs = require('../__chunks/7EQBAZ46.cjs'); // src/menu/menu-item-checkbox.tsx var _misc = require('@ariakit/core/utils/misc'); var _react = require('react'); var TagName = "div"; function getPrimitiveValue(value) { if (Array.isArray(value)) { return value.toString(); } return value; } function getValue(storeValue, value, checked) { if (value === void 0) { if (Array.isArray(storeValue)) return storeValue; return !!checked; } const primitiveValue = getPrimitiveValue(value); if (!Array.isArray(storeValue)) { if (checked) { return primitiveValue; } return storeValue === primitiveValue ? false : storeValue; } if (checked) { if (storeValue.includes(primitiveValue)) { return storeValue; } return [...storeValue, primitiveValue]; } return storeValue.filter((v) => v !== primitiveValue); } var useMenuItemCheckbox = _WULEED4Qcjs.createHook.call(void 0, function useMenuItemCheckbox2(_a) { var _b = _a, { store, name, value, checked, defaultChecked: defaultCheckedProp, hideOnClick = false } = _b, props = _7EQBAZ46cjs.__objRest.call(void 0, _b, [ "store", "name", "value", "checked", "defaultChecked", "hideOnClick" ]); const context = _6M54DBBOcjs.useMenuScopedContext.call(void 0, ); store = store || context; _misc.invariant.call(void 0, store, process.env.NODE_ENV !== "production" && "MenuItemCheckbox must be wrapped in a MenuList or Menu component" ); const defaultChecked = _OZM4QA2Vcjs.useInitialValue.call(void 0, defaultCheckedProp); _react.useEffect.call(void 0, () => { store == null ? void 0 : store.setValue(name, (prevValue = []) => { if (!defaultChecked) return prevValue; return getValue(prevValue, value, true); }); }, [store, name, value, defaultChecked]); _react.useEffect.call(void 0, () => { if (checked === void 0) return; store == null ? void 0 : store.setValue(name, (prevValue) => { return getValue(prevValue, value, checked); }); }, [store, name, value, checked]); const checkboxStore = _XBPPFZKGcjs.useCheckboxStore.call(void 0, { value: store.useState((state) => state.values[name]), setValue(internalValue) { store == null ? void 0 : store.setValue(name, () => { if (checked === void 0) return internalValue; const nextValue = getValue(internalValue, value, checked); if (!Array.isArray(nextValue)) return nextValue; if (!Array.isArray(internalValue)) return nextValue; if (_misc.shallowEqual.call(void 0, internalValue, nextValue)) return internalValue; return nextValue; }); } }); props = _7EQBAZ46cjs.__spreadValues.call(void 0, { role: "menuitemcheckbox" }, props); props = _FRCWMMQNcjs.useCheckbox.call(void 0, _7EQBAZ46cjs.__spreadValues.call(void 0, { store: checkboxStore, name, value, checked }, props)); props = _OKZ7VQEOcjs.useMenuItem.call(void 0, _7EQBAZ46cjs.__spreadValues.call(void 0, { store, hideOnClick }, props)); return props; } ); var MenuItemCheckbox = _WULEED4Qcjs.memo.call(void 0, _WULEED4Qcjs.forwardRef.call(void 0, function MenuItemCheckbox2(props) { const htmlProps = useMenuItemCheckbox(props); return _WULEED4Qcjs.createElement.call(void 0, TagName, htmlProps); }) ); exports.MenuItemCheckbox = MenuItemCheckbox; exports.useMenuItemCheckbox = useMenuItemCheckbox;