@ariakit/react-core
Version:
Ariakit React core
76 lines (74 loc) • 1.82 kB
JavaScript
"use client";
import {
useToolbarStore
} from "../__chunks/XW7L7ASO.js";
import {
ToolbarScopedContextProvider,
useToolbarProviderContext
} from "../__chunks/UFQNG5D2.js";
import "../__chunks/VEHC2EHR.js";
import {
useComposite
} from "../__chunks/E7PWFDGB.js";
import "../__chunks/5VQZOHHZ.js";
import "../__chunks/QHXYX2YB.js";
import "../__chunks/72IB6YNO.js";
import "../__chunks/US3TW2XI.js";
import "../__chunks/SWN3JYXT.js";
import "../__chunks/Q3KUZPD7.js";
import "../__chunks/45YOMIF3.js";
import {
createElement,
createHook,
forwardRef
} from "../__chunks/ILRXHV7V.js";
import {
useWrapElement
} from "../__chunks/K2XTQB3X.js";
import "../__chunks/YXGXYGQX.js";
// src/toolbar/toolbar.tsx
import { jsx } from "react/jsx-runtime";
var TagName = "div";
var useToolbar = createHook(
function useToolbar2({
store: storeProp,
orientation: orientationProp,
virtualFocus,
focusLoop,
rtl,
...props
}) {
const context = useToolbarProviderContext();
storeProp = storeProp || context;
const store = useToolbarStore({
store: storeProp,
orientation: orientationProp,
virtualFocus,
focusLoop,
rtl
});
const orientation = store.useState(
(state) => state.orientation === "both" ? void 0 : state.orientation
);
props = useWrapElement(
props,
(element) => /* @__PURE__ */ jsx(ToolbarScopedContextProvider, { value: store, children: element }),
[store]
);
props = {
role: "toolbar",
"aria-orientation": orientation,
...props
};
props = useComposite({ store, ...props });
return props;
}
);
var Toolbar = forwardRef(function Toolbar2(props) {
const htmlProps = useToolbar(props);
return createElement(TagName, htmlProps);
});
export {
Toolbar,
useToolbar
};