@ariakit/react-core
Version:
Ariakit React core
147 lines (125 loc) • 4.67 kB
JavaScript
;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;