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