UNPKG

tldraw

Version:

A tiny little drawing editor.

61 lines (60 loc) 2.57 kB
import { jsx, jsxs } from "react/jsx-runtime"; import { useEditor } from "@tldraw/editor"; import * as React from "react"; import { useTranslation } from "../../hooks/useTranslation/useTranslation.mjs"; import { TldrawUiButton } from "../primitives/Button/TldrawUiButton.mjs"; import { TldrawUiButtonIcon } from "../primitives/Button/TldrawUiButtonIcon.mjs"; import { TldrawUiButtonLabel } from "../primitives/Button/TldrawUiButtonLabel.mjs"; import { TldrawUiDropdownMenuContent, TldrawUiDropdownMenuItem, TldrawUiDropdownMenuRoot, TldrawUiDropdownMenuTrigger } from "../primitives/TldrawUiDropdownMenu.mjs"; function DropdownPickerInner({ id, label, uiType, stylePanelType, style, items, type, value, onValueChange }) { const msg = useTranslation(); const editor = useEditor(); const icon = React.useMemo( () => items.find((item) => value.type === "shared" && item.value === value.value)?.icon, [items, value] ); const stylePanelName = msg(`style-panel.${stylePanelType}`); const titleStr = value.type === "mixed" ? msg("style-panel.mixed") : stylePanelName + " \u2014 " + msg(`${uiType}-style.${value.value}`); const labelStr = label ? msg(label) : ""; return /* @__PURE__ */ jsxs(TldrawUiDropdownMenuRoot, { id: `style panel ${id}`, children: [ /* @__PURE__ */ jsx(TldrawUiDropdownMenuTrigger, { children: /* @__PURE__ */ jsxs(TldrawUiButton, { type, "data-testid": `style.${uiType}`, title: titleStr, children: [ labelStr && /* @__PURE__ */ jsx(TldrawUiButtonLabel, { children: labelStr }), /* @__PURE__ */ jsx(TldrawUiButtonIcon, { icon: icon ?? "mixed" }) ] }) }), /* @__PURE__ */ jsx(TldrawUiDropdownMenuContent, { side: "left", align: "center", alignOffset: 0, children: /* @__PURE__ */ jsx("div", { className: "tlui-buttons__grid", children: items.map((item) => { return /* @__PURE__ */ jsx(TldrawUiDropdownMenuItem, { children: /* @__PURE__ */ jsx( TldrawUiButton, { type: "icon", "data-testid": `style.${uiType}.${item.value}`, title: stylePanelName + " \u2014 " + msg(`${uiType}-style.${item.value}`), onClick: () => { editor.markHistoryStoppingPoint("select style dropdown item"); onValueChange(style, item.value); }, children: /* @__PURE__ */ jsx(TldrawUiButtonIcon, { icon: item.icon }) } ) }, item.value); }) }) }) ] }); } const DropdownPicker = React.memo(DropdownPickerInner); export { DropdownPicker }; //# sourceMappingURL=DropdownPicker.mjs.map