UNPKG

@ariakit/react-core

Version:

Ariakit React core

120 lines (99 loc) 3.79 kB
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); var _2ORAXZT6cjs = require('../__chunks/2ORAXZT6.cjs'); var _U5MBFBNTcjs = require('../__chunks/U5MBFBNT.cjs'); require('../__chunks/UMS7MLRY.cjs'); require('../__chunks/YYY7KD73.cjs'); var _MSGRBKW7cjs = require('../__chunks/MSGRBKW7.cjs'); require('../__chunks/GPGAUVKK.cjs'); require('../__chunks/3VALIS7Q.cjs'); require('../__chunks/DX5OUXRC.cjs'); require('../__chunks/2XVCJUVB.cjs'); require('../__chunks/QM74NV6D.cjs'); require('../__chunks/7X7JMIHX.cjs'); require('../__chunks/WDV6EJ2U.cjs'); require('../__chunks/VFNUZFXS.cjs'); require('../__chunks/EOGOO37X.cjs'); require('../__chunks/HAR6UDZU.cjs'); require('../__chunks/BB34VMZX.cjs'); require('../__chunks/T3QB4FR3.cjs'); var _RDNUVX4Vcjs = require('../__chunks/RDNUVX4V.cjs'); require('../__chunks/ZYZTL3IQ.cjs'); var _SQLDFLTEcjs = require('../__chunks/SQLDFLTE.cjs'); var _4KGS3DOWcjs = require('../__chunks/4KGS3DOW.cjs'); require('../__chunks/TWX5YNTH.cjs'); // src/menu/menu-item-radio.tsx var _misc = require('@ariakit/core/utils/misc'); var _react = require('react'); var _jsxruntime = require('react/jsx-runtime'); var TagName = "div"; function getValue(prevValue, value, checked) { if (checked === void 0) return prevValue; if (checked) return value; return prevValue === value ? false : prevValue; } var useMenuItemRadio = _SQLDFLTEcjs.createHook.call(void 0, function useMenuItemRadio2({ store, name, value, checked, onChange: onChangeProp, hideOnClick = false, ...props }) { const context = _U5MBFBNTcjs.useMenuScopedContext.call(void 0, ); store = store || context; _misc.invariant.call(void 0, store, process.env.NODE_ENV !== "production" && "MenuItemRadio must be wrapped in a MenuList or Menu component" ); const defaultChecked = _4KGS3DOWcjs.useInitialValue.call(void 0, props.defaultChecked); _react.useEffect.call(void 0, () => { store == null ? void 0 : store.setValue(name, (prevValue = false) => { return getValue(prevValue, value, defaultChecked); }); }, [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 isChecked = _RDNUVX4Vcjs.useStoreState.call(void 0, store, (state) => state.values[name] === value ); props = _4KGS3DOWcjs.useWrapElement.call(void 0, props, (element) => /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _U5MBFBNTcjs.MenuItemCheckedContext.Provider, { value: isChecked, children: element }), [isChecked] ); props = { role: "menuitemradio", ...props }; props = _MSGRBKW7cjs.useRadio.call(void 0, { name, value, checked: isChecked, onChange(event) { onChangeProp == null ? void 0 : onChangeProp(event); if (event.defaultPrevented) return; const element = event.currentTarget; store == null ? void 0 : store.setValue(name, (prevValue) => { return getValue(prevValue, value, checked != null ? checked : element.checked); }); }, ...props }); props = _2ORAXZT6cjs.useMenuItem.call(void 0, { store, hideOnClick, ...props }); return props; } ); var MenuItemRadio = _SQLDFLTEcjs.memo.call(void 0, _SQLDFLTEcjs.forwardRef.call(void 0, function MenuItemRadio2(props) { const htmlProps = useMenuItemRadio(props); return _SQLDFLTEcjs.createElement.call(void 0, TagName, htmlProps); }) ); exports.MenuItemRadio = MenuItemRadio; exports.useMenuItemRadio = useMenuItemRadio;