UNPKG

tldraw

Version:

A tiny little drawing editor.

54 lines (53 loc) 1.66 kB
import { jsx, jsxs } from "react/jsx-runtime"; import { Range, Root, Thumb, Track } from "@radix-ui/react-slider"; import { memo, useCallback } from "react"; import { useTranslation } from "../../hooks/useTranslation/useTranslation.mjs"; const TldrawUiSlider = memo(function Slider({ onHistoryMark, title, steps, value, label, onValueChange, ["data-testid"]: testId }) { const msg = useTranslation(); const handleValueChange = useCallback( (value2) => { onValueChange(value2[0]); }, [onValueChange] ); const handlePointerDown = useCallback(() => { onHistoryMark("click slider"); }, [onHistoryMark]); const handlePointerUp = useCallback(() => { if (!value) return; onValueChange(value); }, [value, onValueChange]); return /* @__PURE__ */ jsx("div", { className: "tlui-slider__container", children: /* @__PURE__ */ jsxs( Root, { "data-testid": testId, className: "tlui-slider", "area-label": "Opacity", dir: "ltr", min: 0, max: steps, step: 1, value: value ? [value] : void 0, onPointerDown: handlePointerDown, onValueChange: handleValueChange, onPointerUp: handlePointerUp, title: title + " \u2014 " + msg(label), children: [ /* @__PURE__ */ jsx(Track, { className: "tlui-slider__track", dir: "ltr", children: value !== null && /* @__PURE__ */ jsx(Range, { className: "tlui-slider__range", dir: "ltr" }) }), value !== null && /* @__PURE__ */ jsx(Thumb, { className: "tlui-slider__thumb", dir: "ltr" }) ] } ) }); }); export { TldrawUiSlider }; //# sourceMappingURL=TldrawUiSlider.mjs.map