hazo_ui 2.3.1 → 2.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var React23 = require('react');
3
+ var React27 = require('react');
4
4
  var reactSlot = require('@radix-ui/react-slot');
5
5
  var classVarianceAuthority = require('class-variance-authority');
6
6
  var clsx = require('clsx');
@@ -53,6 +53,7 @@ var lu = require('react-icons/lu');
53
53
  var rx = require('react-icons/rx');
54
54
  var core = require('@tiptap/core');
55
55
  var TabsPrimitive = require('@radix-ui/react-tabs');
56
+ var Suggestion = require('@tiptap/suggestion');
56
57
 
57
58
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
58
59
 
@@ -74,7 +75,7 @@ function _interopNamespace(e) {
74
75
  return Object.freeze(n);
75
76
  }
76
77
 
77
- var React23__namespace = /*#__PURE__*/_interopNamespace(React23);
78
+ var React27__namespace = /*#__PURE__*/_interopNamespace(React27);
78
79
  var DialogPrimitive__namespace = /*#__PURE__*/_interopNamespace(DialogPrimitive);
79
80
  var PopoverPrimitive__namespace = /*#__PURE__*/_interopNamespace(PopoverPrimitive);
80
81
  var SelectPrimitive__namespace = /*#__PURE__*/_interopNamespace(SelectPrimitive);
@@ -110,6 +111,7 @@ var TableHeader__default = /*#__PURE__*/_interopDefault(TableHeader);
110
111
  var TaskList__default = /*#__PURE__*/_interopDefault(TaskList);
111
112
  var TaskItem__default = /*#__PURE__*/_interopDefault(TaskItem);
112
113
  var TabsPrimitive__namespace = /*#__PURE__*/_interopNamespace(TabsPrimitive);
114
+ var Suggestion__default = /*#__PURE__*/_interopDefault(Suggestion);
113
115
 
114
116
  var __create = Object.create;
115
117
  var __defProp = Object.defineProperty;
@@ -196,7 +198,7 @@ var buttonVariants = classVarianceAuthority.cva(
196
198
  }
197
199
  }
198
200
  );
199
- var Button = React23__namespace.forwardRef(
201
+ var Button = React27__namespace.forwardRef(
200
202
  ({ className, variant, size, asChild = false, ...props }, ref) => {
201
203
  const Comp = asChild ? reactSlot.Slot : "button";
202
204
  return /* @__PURE__ */ jsxRuntime.jsx(
@@ -213,7 +215,7 @@ Button.displayName = "Button";
213
215
  var Dialog = DialogPrimitive__namespace.Root;
214
216
  var DialogTrigger = DialogPrimitive__namespace.Trigger;
215
217
  var DialogPortal = DialogPrimitive__namespace.Portal;
216
- var DialogOverlay = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
218
+ var DialogOverlay = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
217
219
  DialogPrimitive__namespace.Overlay,
218
220
  {
219
221
  ref,
@@ -225,7 +227,7 @@ var DialogOverlay = React23__namespace.forwardRef(({ className, ...props }, ref)
225
227
  }
226
228
  ));
227
229
  DialogOverlay.displayName = DialogPrimitive__namespace.Overlay.displayName;
228
- var DialogContent = React23__namespace.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(DialogPortal, { children: [
230
+ var DialogContent = React27__namespace.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(DialogPortal, { children: [
229
231
  /* @__PURE__ */ jsxRuntime.jsx(DialogOverlay, {}),
230
232
  /* @__PURE__ */ jsxRuntime.jsxs(
231
233
  DialogPrimitive__namespace.Content,
@@ -275,7 +277,7 @@ var DialogFooter = ({
275
277
  }
276
278
  );
277
279
  DialogFooter.displayName = "DialogFooter";
278
- var DialogTitle = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
280
+ var DialogTitle = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
279
281
  DialogPrimitive__namespace.Title,
280
282
  {
281
283
  ref,
@@ -287,7 +289,7 @@ var DialogTitle = React23__namespace.forwardRef(({ className, ...props }, ref) =
287
289
  }
288
290
  ));
289
291
  DialogTitle.displayName = DialogPrimitive__namespace.Title.displayName;
290
- var DialogDescription = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
292
+ var DialogDescription = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
291
293
  DialogPrimitive__namespace.Description,
292
294
  {
293
295
  ref,
@@ -296,7 +298,7 @@ var DialogDescription = React23__namespace.forwardRef(({ className, ...props },
296
298
  }
297
299
  ));
298
300
  DialogDescription.displayName = DialogPrimitive__namespace.Description.displayName;
299
- var Command = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
301
+ var Command = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
300
302
  "div",
301
303
  {
302
304
  ref,
@@ -308,7 +310,7 @@ var Command = React23__namespace.forwardRef(({ className, ...props }, ref) => /*
308
310
  }
309
311
  ));
310
312
  Command.displayName = "Command";
311
- var CommandInput = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
313
+ var CommandInput = React27__namespace.forwardRef(({ className, onValueChange, onChange, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
312
314
  "input",
313
315
  {
314
316
  ref,
@@ -316,11 +318,15 @@ var CommandInput = React23__namespace.forwardRef(({ className, ...props }, ref)
316
318
  "flex h-11 w-full rounded-md border border-input bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50 px-3",
317
319
  className
318
320
  ),
321
+ onChange: (e) => {
322
+ onChange?.(e);
323
+ onValueChange?.(e.target.value);
324
+ },
319
325
  ...props
320
326
  }
321
327
  ));
322
328
  CommandInput.displayName = "CommandInput";
323
- var CommandList = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
329
+ var CommandList = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
324
330
  "div",
325
331
  {
326
332
  ref,
@@ -329,7 +335,7 @@ var CommandList = React23__namespace.forwardRef(({ className, ...props }, ref) =
329
335
  }
330
336
  ));
331
337
  CommandList.displayName = "CommandList";
332
- var CommandEmpty = React23__namespace.forwardRef((props, ref) => /* @__PURE__ */ jsxRuntime.jsx(
338
+ var CommandEmpty = React27__namespace.forwardRef((props, ref) => /* @__PURE__ */ jsxRuntime.jsx(
333
339
  "div",
334
340
  {
335
341
  ref,
@@ -338,19 +344,23 @@ var CommandEmpty = React23__namespace.forwardRef((props, ref) => /* @__PURE__ */
338
344
  }
339
345
  ));
340
346
  CommandEmpty.displayName = "CommandEmpty";
341
- var CommandGroup = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
347
+ var CommandGroup = React27__namespace.forwardRef(({ className, heading, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(
342
348
  "div",
343
349
  {
344
350
  ref,
345
351
  className: cn(
346
- "overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground",
352
+ "overflow-hidden p-1 text-foreground",
347
353
  className
348
354
  ),
349
- ...props
355
+ ...props,
356
+ children: [
357
+ heading && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "px-2 py-1.5 text-xs font-medium text-muted-foreground", children: heading }),
358
+ children
359
+ ]
350
360
  }
351
361
  ));
352
362
  CommandGroup.displayName = "CommandGroup";
353
- var CommandItem = React23__namespace.forwardRef(({ className, onSelect, value, ...props }, ref) => {
363
+ var CommandItem = React27__namespace.forwardRef(({ className, onSelect, value, ...props }, ref) => {
354
364
  const handleClick = () => {
355
365
  if (onSelect && value) {
356
366
  onSelect(value);
@@ -372,7 +382,7 @@ var CommandItem = React23__namespace.forwardRef(({ className, onSelect, value, .
372
382
  CommandItem.displayName = "CommandItem";
373
383
  var Popover = PopoverPrimitive__namespace.Root;
374
384
  var PopoverTrigger = PopoverPrimitive__namespace.Trigger;
375
- var PopoverContent = React23__namespace.forwardRef(({ className, align = "center", sideOffset = 4, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(PopoverPrimitive__namespace.Portal, { children: /* @__PURE__ */ jsxRuntime.jsx(
385
+ var PopoverContent = React27__namespace.forwardRef(({ className, align = "center", sideOffset = 4, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(PopoverPrimitive__namespace.Portal, { children: /* @__PURE__ */ jsxRuntime.jsx(
376
386
  PopoverPrimitive__namespace.Content,
377
387
  {
378
388
  ref,
@@ -386,7 +396,7 @@ var PopoverContent = React23__namespace.forwardRef(({ className, align = "center
386
396
  }
387
397
  ) }));
388
398
  PopoverContent.displayName = PopoverPrimitive__namespace.Content.displayName;
389
- var Input = React23__namespace.forwardRef(
399
+ var Input = React27__namespace.forwardRef(
390
400
  ({ className, type, ...props }, ref) => {
391
401
  return /* @__PURE__ */ jsxRuntime.jsx(
392
402
  "input",
@@ -405,7 +415,7 @@ var Input = React23__namespace.forwardRef(
405
415
  Input.displayName = "Input";
406
416
  var Select = SelectPrimitive__namespace.Root;
407
417
  var SelectValue = SelectPrimitive__namespace.Value;
408
- var SelectTrigger = React23__namespace.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(
418
+ var SelectTrigger = React27__namespace.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(
409
419
  SelectPrimitive__namespace.Trigger,
410
420
  {
411
421
  ref,
@@ -421,7 +431,7 @@ var SelectTrigger = React23__namespace.forwardRef(({ className, children, ...pro
421
431
  }
422
432
  ));
423
433
  SelectTrigger.displayName = SelectPrimitive__namespace.Trigger.displayName;
424
- var SelectScrollUpButton = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
434
+ var SelectScrollUpButton = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
425
435
  SelectPrimitive__namespace.ScrollUpButton,
426
436
  {
427
437
  ref,
@@ -434,7 +444,7 @@ var SelectScrollUpButton = React23__namespace.forwardRef(({ className, ...props
434
444
  }
435
445
  ));
436
446
  SelectScrollUpButton.displayName = SelectPrimitive__namespace.ScrollUpButton.displayName;
437
- var SelectScrollDownButton = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
447
+ var SelectScrollDownButton = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
438
448
  SelectPrimitive__namespace.ScrollDownButton,
439
449
  {
440
450
  ref,
@@ -447,7 +457,7 @@ var SelectScrollDownButton = React23__namespace.forwardRef(({ className, ...prop
447
457
  }
448
458
  ));
449
459
  SelectScrollDownButton.displayName = SelectPrimitive__namespace.ScrollDownButton.displayName;
450
- var SelectContent = React23__namespace.forwardRef(({ className, children, position = "popper", ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(SelectPrimitive__namespace.Portal, { children: /* @__PURE__ */ jsxRuntime.jsxs(
460
+ var SelectContent = React27__namespace.forwardRef(({ className, children, position = "popper", ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(SelectPrimitive__namespace.Portal, { children: /* @__PURE__ */ jsxRuntime.jsxs(
451
461
  SelectPrimitive__namespace.Content,
452
462
  {
453
463
  ref,
@@ -475,7 +485,7 @@ var SelectContent = React23__namespace.forwardRef(({ className, children, positi
475
485
  }
476
486
  ) }));
477
487
  SelectContent.displayName = SelectPrimitive__namespace.Content.displayName;
478
- var SelectLabel = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
488
+ var SelectLabel = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
479
489
  SelectPrimitive__namespace.Label,
480
490
  {
481
491
  ref,
@@ -484,7 +494,7 @@ var SelectLabel = React23__namespace.forwardRef(({ className, ...props }, ref) =
484
494
  }
485
495
  ));
486
496
  SelectLabel.displayName = SelectPrimitive__namespace.Label.displayName;
487
- var SelectItem = React23__namespace.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(
497
+ var SelectItem = React27__namespace.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(
488
498
  SelectPrimitive__namespace.Item,
489
499
  {
490
500
  ref,
@@ -500,7 +510,7 @@ var SelectItem = React23__namespace.forwardRef(({ className, children, ...props
500
510
  }
501
511
  ));
502
512
  SelectItem.displayName = SelectPrimitive__namespace.Item.displayName;
503
- var SelectSeparator = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
513
+ var SelectSeparator = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
504
514
  SelectPrimitive__namespace.Separator,
505
515
  {
506
516
  ref,
@@ -512,7 +522,7 @@ SelectSeparator.displayName = SelectPrimitive__namespace.Separator.displayName;
512
522
  var TooltipProvider = TooltipPrimitive__namespace.Provider;
513
523
  var Tooltip = TooltipPrimitive__namespace.Root;
514
524
  var TooltipTrigger = TooltipPrimitive__namespace.Trigger;
515
- var TooltipContent = React23__namespace.forwardRef(({ className, sideOffset = 4, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
525
+ var TooltipContent = React27__namespace.forwardRef(({ className, sideOffset = 4, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
516
526
  TooltipPrimitive__namespace.Content,
517
527
  {
518
528
  ref,
@@ -580,7 +590,7 @@ function FilterFieldItem({
580
590
  onOperatorChange,
581
591
  onDelete
582
592
  }) {
583
- const [isCalendarOpen, setIsCalendarOpen] = React23.useState(false);
593
+ const [isCalendarOpen, setIsCalendarOpen] = React27.useState(false);
584
594
  const renderInput = () => {
585
595
  switch (fieldConfig.type) {
586
596
  case "text":
@@ -767,10 +777,10 @@ function HazoUiMultiFilterDialog({
767
777
  title = "Filter",
768
778
  description = "Add multiple fields to filter by. Select a field and set its filter value."
769
779
  }) {
770
- const [isOpen, setIsOpen] = React23.useState(false);
771
- const [filterFields, setFilterFields] = React23.useState(initialFilters);
772
- const [isComboboxOpen, setIsComboboxOpen] = React23.useState(false);
773
- React23.useEffect(() => {
780
+ const [isOpen, setIsOpen] = React27.useState(false);
781
+ const [filterFields, setFilterFields] = React27.useState(initialFilters);
782
+ const [isComboboxOpen, setIsComboboxOpen] = React27.useState(false);
783
+ React27.useEffect(() => {
774
784
  if (isOpen) {
775
785
  setFilterFields(initialFilters);
776
786
  }
@@ -983,7 +993,7 @@ function HazoUiMultiFilterDialog({
983
993
  ] })
984
994
  ] });
985
995
  }
986
- var Switch = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
996
+ var Switch = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
987
997
  SwitchPrimitives__namespace.Root,
988
998
  {
989
999
  className: cn(
@@ -1003,7 +1013,7 @@ var Switch = React23__namespace.forwardRef(({ className, ...props }, ref) => /*
1003
1013
  }
1004
1014
  ));
1005
1015
  Switch.displayName = SwitchPrimitives__namespace.Root.displayName;
1006
- var Label2 = React23__namespace.forwardRef(
1016
+ var Label2 = React27__namespace.forwardRef(
1007
1017
  ({ className, ...props }, ref) => {
1008
1018
  return /* @__PURE__ */ jsxRuntime.jsx(
1009
1019
  "label",
@@ -1089,16 +1099,16 @@ function HazoUiMultiSortDialog({
1089
1099
  title = "Sort",
1090
1100
  description = "Add multiple fields to sort by and reorder them. Use the switch to toggle between ascending and descending."
1091
1101
  }) {
1092
- const [isOpen, setIsOpen] = React23.useState(false);
1093
- const [sortFields, setSortFields] = React23.useState(initialSortFields);
1094
- const [isComboboxOpen, setIsComboboxOpen] = React23.useState(false);
1102
+ const [isOpen, setIsOpen] = React27.useState(false);
1103
+ const [sortFields, setSortFields] = React27.useState(initialSortFields);
1104
+ const [isComboboxOpen, setIsComboboxOpen] = React27.useState(false);
1095
1105
  const sensors = core$1.useSensors(
1096
1106
  core$1.useSensor(core$1.PointerSensor),
1097
1107
  core$1.useSensor(core$1.KeyboardSensor, {
1098
1108
  coordinateGetter: sortable.sortableKeyboardCoordinates
1099
1109
  })
1100
1110
  );
1101
- React23.useEffect(() => {
1111
+ React27.useEffect(() => {
1102
1112
  if (isOpen) {
1103
1113
  setSortFields(initialSortFields);
1104
1114
  }
@@ -1297,7 +1307,7 @@ function HazoUiMultiSortDialog({
1297
1307
  ] })
1298
1308
  ] });
1299
1309
  }
1300
- var RadioGroup = React23__namespace.forwardRef(({ className, ...props }, ref) => {
1310
+ var RadioGroup = React27__namespace.forwardRef(({ className, ...props }, ref) => {
1301
1311
  return /* @__PURE__ */ jsxRuntime.jsx(
1302
1312
  RadioGroupPrimitive__namespace.Root,
1303
1313
  {
@@ -1308,7 +1318,7 @@ var RadioGroup = React23__namespace.forwardRef(({ className, ...props }, ref) =>
1308
1318
  );
1309
1319
  });
1310
1320
  RadioGroup.displayName = RadioGroupPrimitive__namespace.Root.displayName;
1311
- var RadioGroupItem = React23__namespace.forwardRef(({ className, ...props }, ref) => {
1321
+ var RadioGroupItem = React27__namespace.forwardRef(({ className, ...props }, ref) => {
1312
1322
  return /* @__PURE__ */ jsxRuntime.jsx(
1313
1323
  RadioGroupPrimitive__namespace.Item,
1314
1324
  {
@@ -1662,7 +1672,7 @@ function filterInputValue(value, input_type, num_decimals) {
1662
1672
  }
1663
1673
  }
1664
1674
  }
1665
- var HazoUiFlexInput = React23__namespace.forwardRef(
1675
+ var HazoUiFlexInput = React27__namespace.forwardRef(
1666
1676
  ({
1667
1677
  className,
1668
1678
  input_type = "mixed",
@@ -1679,13 +1689,13 @@ var HazoUiFlexInput = React23__namespace.forwardRef(
1679
1689
  onBlur,
1680
1690
  ...props
1681
1691
  }, ref) => {
1682
- const [internalValue, setInternalValue] = React23__namespace.useState(
1692
+ const [internalValue, setInternalValue] = React27__namespace.useState(
1683
1693
  typeof controlledValue === "string" ? controlledValue : typeof controlledValue === "number" ? String(controlledValue) : ""
1684
1694
  );
1685
- const [errorMessage, setErrorMessage] = React23__namespace.useState();
1695
+ const [errorMessage, setErrorMessage] = React27__namespace.useState();
1686
1696
  const isControlled = controlledValue !== void 0;
1687
1697
  const currentValue = isControlled ? typeof controlledValue === "string" ? controlledValue : String(controlledValue || "") : internalValue;
1688
- React23__namespace.useEffect(() => {
1698
+ React27__namespace.useEffect(() => {
1689
1699
  if (isControlled) {
1690
1700
  const newValue = typeof controlledValue === "string" ? controlledValue : String(controlledValue || "");
1691
1701
  if (newValue !== internalValue) {
@@ -1765,7 +1775,7 @@ var HazoUiFlexInput = React23__namespace.forwardRef(
1765
1775
  }
1766
1776
  );
1767
1777
  HazoUiFlexInput.displayName = "HazoUiFlexInput";
1768
- var ToolbarButton = React23__namespace.forwardRef(
1778
+ var ToolbarButton = React27__namespace.forwardRef(
1769
1779
  ({ onClick, is_active = false, disabled = false, tooltip, className, children }, ref) => {
1770
1780
  const button = /* @__PURE__ */ jsxRuntime.jsx(
1771
1781
  "button",
@@ -2052,11 +2062,11 @@ var validHex = (hex) => /^#?([A-Fa-f0-9]{3,4}){1,2}$/.test(hex);
2052
2062
  var import_extends2 = __toESM(require_extends());
2053
2063
  var import_objectWithoutPropertiesLoose = __toESM(require_objectWithoutPropertiesLoose());
2054
2064
  function useEventCallback(handler) {
2055
- var callbackRef = React23.useRef(handler);
2056
- React23.useEffect(() => {
2065
+ var callbackRef = React27.useRef(handler);
2066
+ React27.useEffect(() => {
2057
2067
  callbackRef.current = handler;
2058
2068
  });
2059
- return React23.useCallback((value, event) => callbackRef.current && callbackRef.current(value, event), []);
2069
+ return React27.useCallback((value, event) => callbackRef.current && callbackRef.current(value, event), []);
2060
2070
  }
2061
2071
  var isTouch = (event) => "touches" in event;
2062
2072
  var preventDefaultMove = (event) => {
@@ -2084,16 +2094,16 @@ var getRelativePosition = (node, event) => {
2084
2094
  };
2085
2095
  };
2086
2096
  var _excluded = ["prefixCls", "className", "onMove", "onDown"];
2087
- var Interactive = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2097
+ var Interactive = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2088
2098
  var {
2089
2099
  prefixCls = "w-color-interactive",
2090
2100
  className,
2091
2101
  onMove,
2092
2102
  onDown
2093
2103
  } = props, reset = (0, import_objectWithoutPropertiesLoose.default)(props, _excluded);
2094
- var container = React23.useRef(null);
2095
- var hasTouched = React23.useRef(false);
2096
- var [isDragging, setDragging] = React23.useState(false);
2104
+ var container = React27.useRef(null);
2105
+ var hasTouched = React27.useRef(false);
2106
+ var [isDragging, setDragging] = React27.useState(false);
2097
2107
  var onMoveCallback = useEventCallback(onMove);
2098
2108
  var onKeyCallback = useEventCallback(onDown);
2099
2109
  var isValid = (event) => {
@@ -2101,7 +2111,7 @@ var Interactive = /* @__PURE__ */ React23__namespace.default.forwardRef((props,
2101
2111
  hasTouched.current = isTouch(event);
2102
2112
  return true;
2103
2113
  };
2104
- var handleMove = React23.useCallback((event) => {
2114
+ var handleMove = React27.useCallback((event) => {
2105
2115
  preventDefaultMove(event);
2106
2116
  if (!container.current) return;
2107
2117
  var isDown = isTouch(event) ? event.touches.length > 0 : event.buttons > 0;
@@ -2111,8 +2121,8 @@ var Interactive = /* @__PURE__ */ React23__namespace.default.forwardRef((props,
2111
2121
  }
2112
2122
  onMoveCallback == null || onMoveCallback(getRelativePosition(container.current, event), event);
2113
2123
  }, [onMoveCallback]);
2114
- var handleMoveEnd = React23.useCallback(() => setDragging(false), []);
2115
- var toggleDocumentEvents = React23.useCallback((state) => {
2124
+ var handleMoveEnd = React27.useCallback(() => setDragging(false), []);
2125
+ var toggleDocumentEvents = React27.useCallback((state) => {
2116
2126
  if (state) {
2117
2127
  window.addEventListener(hasTouched.current ? "touchmove" : "mousemove", handleMove);
2118
2128
  window.addEventListener(hasTouched.current ? "touchend" : "mouseup", handleMoveEnd);
@@ -2123,13 +2133,13 @@ var Interactive = /* @__PURE__ */ React23__namespace.default.forwardRef((props,
2123
2133
  window.removeEventListener("touchend", handleMoveEnd);
2124
2134
  }
2125
2135
  }, [handleMove, handleMoveEnd]);
2126
- React23.useEffect(() => {
2136
+ React27.useEffect(() => {
2127
2137
  toggleDocumentEvents(isDragging);
2128
2138
  return () => {
2129
2139
  toggleDocumentEvents(false);
2130
2140
  };
2131
2141
  }, [isDragging, handleMove, handleMoveEnd, toggleDocumentEvents]);
2132
- var handleMoveStart = React23.useCallback((event) => {
2142
+ var handleMoveStart = React27.useCallback((event) => {
2133
2143
  var activeEl = document.activeElement;
2134
2144
  activeEl == null || activeEl.blur();
2135
2145
  preventDefaultMove(event.nativeEvent);
@@ -2173,7 +2183,7 @@ var Pointer = (_ref) => {
2173
2183
  borderRadius: "50%",
2174
2184
  backgroundColor: color2
2175
2185
  };
2176
- return React23.useMemo(() => /* @__PURE__ */ jsxRuntime.jsx("div", {
2186
+ return React27.useMemo(() => /* @__PURE__ */ jsxRuntime.jsx("div", {
2177
2187
  className: prefixCls + "-pointer " + (className || ""),
2178
2188
  style,
2179
2189
  children: /* @__PURE__ */ jsxRuntime.jsx("div", {
@@ -2183,7 +2193,7 @@ var Pointer = (_ref) => {
2183
2193
  }), [top, left, color2, className, prefixCls]);
2184
2194
  };
2185
2195
  var _excluded2 = ["prefixCls", "radius", "pointer", "className", "hue", "style", "hsva", "onChange"];
2186
- var Saturation = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2196
+ var Saturation = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2187
2197
  var _hsva$h;
2188
2198
  var {
2189
2199
  prefixCls = "w-color-saturation",
@@ -2211,7 +2221,7 @@ var Saturation = /* @__PURE__ */ React23__namespace.default.forwardRef((props, r
2211
2221
  // source: 'hsv',
2212
2222
  });
2213
2223
  };
2214
- var handleKeyDown = React23.useCallback((event) => {
2224
+ var handleKeyDown = React27.useCallback((event) => {
2215
2225
  if (!hsva || !onChange) return;
2216
2226
  var step = 1;
2217
2227
  var newS = hsva.s;
@@ -2250,7 +2260,7 @@ var Saturation = /* @__PURE__ */ React23__namespace.default.forwardRef((props, r
2250
2260
  });
2251
2261
  }
2252
2262
  }, [hsva, onChange]);
2253
- var pointerElement = React23.useMemo(() => {
2263
+ var pointerElement = React27.useMemo(() => {
2254
2264
  if (!hsva) return null;
2255
2265
  var comProps = {
2256
2266
  top: 100 - hsva.v + "%",
@@ -2266,7 +2276,7 @@ var Saturation = /* @__PURE__ */ React23__namespace.default.forwardRef((props, r
2266
2276
  prefixCls
2267
2277
  }, comProps));
2268
2278
  }, [hsva, pointer, prefixCls]);
2269
- var handleClick = React23.useCallback((event) => {
2279
+ var handleClick = React27.useCallback((event) => {
2270
2280
  event.target.focus();
2271
2281
  }, []);
2272
2282
  return /* @__PURE__ */ jsxRuntime.jsx(esm_default, (0, import_extends3.default)({
@@ -2335,7 +2345,7 @@ var Pointer2 = (_ref) => {
2335
2345
  };
2336
2346
  var _excluded4 = ["prefixCls", "className", "hsva", "background", "bgProps", "innerProps", "pointerProps", "radius", "width", "height", "direction", "style", "onChange", "pointer"];
2337
2347
  var BACKGROUND_IMG = "";
2338
- var Alpha = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2348
+ var Alpha = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2339
2349
  var {
2340
2350
  prefixCls = "w-color-alpha",
2341
2351
  className,
@@ -2380,7 +2390,7 @@ var Alpha = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) =
2380
2390
  }, style, {
2381
2391
  position: "relative"
2382
2392
  });
2383
- var handleKeyDown = React23.useCallback((event) => {
2393
+ var handleKeyDown = React27.useCallback((event) => {
2384
2394
  var step = 0.01;
2385
2395
  var currentAlpha = hsva.a;
2386
2396
  var newAlpha = currentAlpha;
@@ -2426,7 +2436,7 @@ var Alpha = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) =
2426
2436
  }), syntheticOffset);
2427
2437
  }
2428
2438
  }, [hsva, direction, onChange]);
2429
- var handleClick = React23.useCallback((event) => {
2439
+ var handleClick = React27.useCallback((event) => {
2430
2440
  event.target.focus();
2431
2441
  }, []);
2432
2442
  var pointerElement = pointer && typeof pointer === "function" ? pointer((0, import_extends5.default)({
@@ -2469,7 +2479,7 @@ var import_objectWithoutPropertiesLoose5 = __toESM(require_objectWithoutProperti
2469
2479
  var _excluded5 = ["prefixCls", "placement", "label", "value", "className", "style", "labelStyle", "inputStyle", "onChange", "onBlur", "renderInput"];
2470
2480
  var validHex2 = (hex) => /^#?([A-Fa-f0-9]{3,4}){1,2}$/.test(hex);
2471
2481
  var getNumberValue = (value) => Number(String(value).replace(/%/g, ""));
2472
- var EditableInput = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2482
+ var EditableInput = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2473
2483
  var {
2474
2484
  prefixCls = "w-color-editable-input",
2475
2485
  placement = "bottom",
@@ -2483,9 +2493,9 @@ var EditableInput = /* @__PURE__ */ React23__namespace.default.forwardRef((props
2483
2493
  onBlur,
2484
2494
  renderInput
2485
2495
  } = props, other = (0, import_objectWithoutPropertiesLoose5.default)(props, _excluded5);
2486
- var [value, setValue] = React23.useState(initValue);
2487
- var isFocus = React23.useRef(false);
2488
- React23.useEffect(() => {
2496
+ var [value, setValue] = React27.useState(initValue);
2497
+ var isFocus = React27.useRef(false);
2498
+ React27.useEffect(() => {
2489
2499
  if (props.value !== value) {
2490
2500
  if (!isFocus.current) {
2491
2501
  setValue(props.value);
@@ -2574,7 +2584,7 @@ var esm_default4 = EditableInput;
2574
2584
  var import_extends7 = __toESM(require_extends());
2575
2585
  var import_objectWithoutPropertiesLoose6 = __toESM(require_objectWithoutPropertiesLoose());
2576
2586
  var _excluded6 = ["prefixCls", "hsva", "placement", "rProps", "gProps", "bProps", "aProps", "className", "style", "onChange"];
2577
- var EditableInputRGBA = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2587
+ var EditableInputRGBA = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2578
2588
  var {
2579
2589
  prefixCls = "w-color-editable-input-rgba",
2580
2590
  hsva,
@@ -2697,7 +2707,7 @@ var esm_default5 = EditableInputRGBA;
2697
2707
  var import_extends8 = __toESM(require_extends());
2698
2708
  var import_objectWithoutPropertiesLoose7 = __toESM(require_objectWithoutPropertiesLoose());
2699
2709
  var _excluded7 = ["prefixCls", "className", "hue", "onChange", "direction"];
2700
- var Hue = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2710
+ var Hue = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2701
2711
  var {
2702
2712
  prefixCls = "w-color-hue",
2703
2713
  className,
@@ -2731,7 +2741,7 @@ var esm_default6 = Hue;
2731
2741
  var import_extends9 = __toESM(require_extends());
2732
2742
  var import_objectWithoutPropertiesLoose8 = __toESM(require_objectWithoutPropertiesLoose());
2733
2743
  var _excluded8 = ["prefixCls", "className", "color", "colors", "style", "rectProps", "onChange", "addonAfter", "addonBefore", "rectRender"];
2734
- var Swatch = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2744
+ var Swatch = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2735
2745
  var {
2736
2746
  prefixCls = "w-color-swatch",
2737
2747
  className,
@@ -2768,7 +2778,7 @@ var Swatch = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref)
2768
2778
  flexWrap: "wrap",
2769
2779
  position: "relative"
2770
2780
  }, style),
2771
- children: [addonBefore && /* @__PURE__ */ React23__namespace.default.isValidElement(addonBefore) && addonBefore, colors && Array.isArray(colors) && colors.map((item, idx) => {
2781
+ children: [addonBefore && /* @__PURE__ */ React27__namespace.default.isValidElement(addonBefore) && addonBefore, colors && Array.isArray(colors) && colors.map((item, idx) => {
2772
2782
  var title = "";
2773
2783
  var background = "";
2774
2784
  if (typeof item === "string") {
@@ -2790,11 +2800,11 @@ var Swatch = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref)
2790
2800
  onClick: (evn) => handleClick(background, evn)
2791
2801
  });
2792
2802
  if (render) {
2793
- return /* @__PURE__ */ jsxRuntime.jsx(React23.Fragment, {
2803
+ return /* @__PURE__ */ jsxRuntime.jsx(React27.Fragment, {
2794
2804
  children: render
2795
2805
  }, idx);
2796
2806
  }
2797
- var child = rectProps.children && /* @__PURE__ */ React23__namespace.default.isValidElement(rectProps.children) ? /* @__PURE__ */ React23__namespace.default.cloneElement(rectProps.children, {
2807
+ var child = rectProps.children && /* @__PURE__ */ React27__namespace.default.isValidElement(rectProps.children) ? /* @__PURE__ */ React27__namespace.default.cloneElement(rectProps.children, {
2798
2808
  color: background,
2799
2809
  checked
2800
2810
  }) : null;
@@ -2808,7 +2818,7 @@ var Swatch = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref)
2808
2818
  background
2809
2819
  })
2810
2820
  }), idx);
2811
- }), addonAfter && /* @__PURE__ */ React23__namespace.default.isValidElement(addonAfter) && addonAfter]
2821
+ }), addonAfter && /* @__PURE__ */ React27__namespace.default.isValidElement(addonAfter) && addonAfter]
2812
2822
  }));
2813
2823
  });
2814
2824
  Swatch.displayName = "Swatch";
@@ -2827,7 +2837,7 @@ var Bar = (props) => /* @__PURE__ */ jsxRuntime.jsx("div", {
2827
2837
  backgroundColor: "#fff"
2828
2838
  }
2829
2839
  });
2830
- var Sketch = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref) => {
2840
+ var Sketch = /* @__PURE__ */ React27__namespace.default.forwardRef((props, ref) => {
2831
2841
  var {
2832
2842
  prefixCls = "w-color-sketch",
2833
2843
  className,
@@ -2839,13 +2849,13 @@ var Sketch = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref)
2839
2849
  disableAlpha = false,
2840
2850
  style
2841
2851
  } = props, other = (0, import_objectWithoutPropertiesLoose9.default)(props, _excluded9);
2842
- var [hsva, setHsva] = React23.useState({
2852
+ var [hsva, setHsva] = React27.useState({
2843
2853
  h: 209,
2844
2854
  s: 36,
2845
2855
  v: 90,
2846
2856
  a: 1
2847
2857
  });
2848
- React23.useEffect(() => {
2858
+ React27.useEffect(() => {
2849
2859
  if (typeof color2 === "string" && validHex(color2)) {
2850
2860
  setHsva(hexToHsva(color2));
2851
2861
  }
@@ -2963,7 +2973,7 @@ var Sketch = /* @__PURE__ */ React23__namespace.default.forwardRef((props, ref)
2963
2973
  innerProps: {
2964
2974
  style: styleAlpha
2965
2975
  },
2966
- pointer: () => /* @__PURE__ */ jsxRuntime.jsx(React23.Fragment, {})
2976
+ pointer: () => /* @__PURE__ */ jsxRuntime.jsx(React27.Fragment, {})
2967
2977
  })]
2968
2978
  })]
2969
2979
  }), editableDisable && /* @__PURE__ */ jsxRuntime.jsxs("div", {
@@ -3078,19 +3088,19 @@ var Toolbar = ({
3078
3088
  on_attachments_change,
3079
3089
  disabled = false
3080
3090
  }) => {
3081
- const [link_url, set_link_url] = React23__namespace.useState("https://");
3082
- const [link_popover_open, set_link_popover_open] = React23__namespace.useState(false);
3083
- const [text_color_open, set_text_color_open] = React23__namespace.useState(false);
3084
- const [highlight_color_open, set_highlight_color_open] = React23__namespace.useState(false);
3085
- const [variables_menu_open, set_variables_menu_open] = React23__namespace.useState(false);
3086
- const [table_menu_open, set_table_menu_open] = React23__namespace.useState(false);
3087
- const [text_color, set_text_color] = React23__namespace.useState("#000000");
3088
- const [highlight_color, set_highlight_color] = React23__namespace.useState("#ffff00");
3089
- const [table_rows, set_table_rows] = React23__namespace.useState(3);
3090
- const [table_cols, set_table_cols] = React23__namespace.useState(3);
3091
- const [hovered_cell, set_hovered_cell] = React23__namespace.useState(null);
3092
- const file_input_ref = React23__namespace.useRef(null);
3093
- const image_input_ref = React23__namespace.useRef(null);
3091
+ const [link_url, set_link_url] = React27__namespace.useState("https://");
3092
+ const [link_popover_open, set_link_popover_open] = React27__namespace.useState(false);
3093
+ const [text_color_open, set_text_color_open] = React27__namespace.useState(false);
3094
+ const [highlight_color_open, set_highlight_color_open] = React27__namespace.useState(false);
3095
+ const [variables_menu_open, set_variables_menu_open] = React27__namespace.useState(false);
3096
+ const [table_menu_open, set_table_menu_open] = React27__namespace.useState(false);
3097
+ const [text_color, set_text_color] = React27__namespace.useState("#000000");
3098
+ const [highlight_color, set_highlight_color] = React27__namespace.useState("#ffff00");
3099
+ const [table_rows, set_table_rows] = React27__namespace.useState(3);
3100
+ const [table_cols, set_table_cols] = React27__namespace.useState(3);
3101
+ const [hovered_cell, set_hovered_cell] = React27__namespace.useState(null);
3102
+ const file_input_ref = React27__namespace.useRef(null);
3103
+ const image_input_ref = React27__namespace.useRef(null);
3094
3104
  if (!editor) {
3095
3105
  return null;
3096
3106
  }
@@ -4023,7 +4033,7 @@ var VariableExtension = core.Node.create({
4023
4033
  }
4024
4034
  });
4025
4035
  var Tabs = TabsPrimitive__namespace.Root;
4026
- var TabsList = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
4036
+ var TabsList = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
4027
4037
  TabsPrimitive__namespace.List,
4028
4038
  {
4029
4039
  ref,
@@ -4035,7 +4045,7 @@ var TabsList = React23__namespace.forwardRef(({ className, ...props }, ref) => /
4035
4045
  }
4036
4046
  ));
4037
4047
  TabsList.displayName = TabsPrimitive__namespace.List.displayName;
4038
- var TabsTrigger = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
4048
+ var TabsTrigger = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
4039
4049
  TabsPrimitive__namespace.Trigger,
4040
4050
  {
4041
4051
  ref,
@@ -4047,7 +4057,7 @@ var TabsTrigger = React23__namespace.forwardRef(({ className, ...props }, ref) =
4047
4057
  }
4048
4058
  ));
4049
4059
  TabsTrigger.displayName = TabsPrimitive__namespace.Trigger.displayName;
4050
- var TabsContent = React23__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
4060
+ var TabsContent = React27__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
4051
4061
  TabsPrimitive__namespace.Content,
4052
4062
  {
4053
4063
  ref,
@@ -4082,14 +4092,14 @@ var HazoUiRte = ({
4082
4092
  className,
4083
4093
  show_output_viewer = false
4084
4094
  }) => {
4085
- const [attachments, set_attachments] = React23__namespace.useState(
4095
+ const [attachments, set_attachments] = React27__namespace.useState(
4086
4096
  initial_attachments
4087
4097
  );
4088
- const [active_tab, set_active_tab] = React23__namespace.useState("html");
4098
+ const [active_tab, set_active_tab] = React27__namespace.useState("html");
4089
4099
  const is_view_only = active_tab !== "html";
4090
- const attachments_ref = React23__namespace.useRef(attachments);
4100
+ const attachments_ref = React27__namespace.useRef(attachments);
4091
4101
  attachments_ref.current = attachments;
4092
- const debounced_on_change = React23__namespace.useMemo(
4102
+ const debounced_on_change = React27__namespace.useMemo(
4093
4103
  () => debounce_fn((output) => {
4094
4104
  if (on_change) {
4095
4105
  on_change(output);
@@ -4188,7 +4198,7 @@ var HazoUiRte = ({
4188
4198
  debounced_on_change(output);
4189
4199
  }
4190
4200
  });
4191
- React23__namespace.useEffect(() => {
4201
+ React27__namespace.useEffect(() => {
4192
4202
  if (editor && html !== void 0) {
4193
4203
  const current_html = editor.getHTML();
4194
4204
  if (html !== current_html && !editor.isFocused) {
@@ -4196,21 +4206,21 @@ var HazoUiRte = ({
4196
4206
  }
4197
4207
  }
4198
4208
  }, [html, editor]);
4199
- React23__namespace.useEffect(() => {
4209
+ React27__namespace.useEffect(() => {
4200
4210
  if (editor) {
4201
4211
  editor.setEditable(!disabled);
4202
4212
  }
4203
4213
  }, [disabled, editor]);
4204
- const attachments_from_props_ref = React23__namespace.useRef(false);
4205
- const prev_initial_attachments_ref = React23__namespace.useRef(initial_attachments);
4206
- React23__namespace.useEffect(() => {
4214
+ const attachments_from_props_ref = React27__namespace.useRef(false);
4215
+ const prev_initial_attachments_ref = React27__namespace.useRef(initial_attachments);
4216
+ React27__namespace.useEffect(() => {
4207
4217
  if (JSON.stringify(initial_attachments) !== JSON.stringify(prev_initial_attachments_ref.current)) {
4208
4218
  prev_initial_attachments_ref.current = initial_attachments;
4209
4219
  attachments_from_props_ref.current = true;
4210
4220
  set_attachments(initial_attachments);
4211
4221
  }
4212
4222
  }, [initial_attachments]);
4213
- React23__namespace.useEffect(() => {
4223
+ React27__namespace.useEffect(() => {
4214
4224
  if (attachments_from_props_ref.current) {
4215
4225
  attachments_from_props_ref.current = false;
4216
4226
  return;
@@ -4304,11 +4314,1595 @@ var HazoUiRte = ({
4304
4314
  );
4305
4315
  };
4306
4316
  HazoUiRte.displayName = "HazoUiRte";
4317
+ var generate_command_id = () => {
4318
+ return `cmd_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
4319
+ };
4320
+ var get_variant_classes = (variant = "default") => {
4321
+ switch (variant) {
4322
+ case "outline":
4323
+ return "bg-transparent border-primary/40 text-primary";
4324
+ case "subtle":
4325
+ return "bg-muted border-transparent text-muted-foreground";
4326
+ case "default":
4327
+ default:
4328
+ return "bg-primary/10 text-primary border-primary/20";
4329
+ }
4330
+ };
4331
+ var CommandPillView = ({ node, selected, editor }) => {
4332
+ const { prefix, action, action_label, id, variant } = node.attrs;
4333
+ const handle_click = () => {
4334
+ const event = new CustomEvent("command-pill-click", {
4335
+ detail: {
4336
+ id,
4337
+ prefix,
4338
+ action,
4339
+ action_label,
4340
+ node_pos: editor.state.selection.from - 1
4341
+ },
4342
+ bubbles: true
4343
+ });
4344
+ document.dispatchEvent(event);
4345
+ };
4346
+ return /* @__PURE__ */ jsxRuntime.jsx(react.NodeViewWrapper, { as: "span", className: "inline", children: /* @__PURE__ */ jsxRuntime.jsxs(
4347
+ "span",
4348
+ {
4349
+ className: cn(
4350
+ "cls_command_pill",
4351
+ "inline-flex items-center",
4352
+ "px-1.5 py-0.5 mx-0.5",
4353
+ "rounded-md",
4354
+ "text-sm font-medium",
4355
+ "border",
4356
+ "cursor-pointer select-none",
4357
+ "transition-all duration-150",
4358
+ get_variant_classes(variant),
4359
+ selected && "ring-2 ring-ring ring-offset-1",
4360
+ "hover:opacity-80"
4361
+ ),
4362
+ contentEditable: false,
4363
+ "data-command-id": id,
4364
+ "data-command-prefix": prefix,
4365
+ "data-command-action": action,
4366
+ onClick: handle_click,
4367
+ children: [
4368
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-muted-foreground opacity-70", children: prefix }),
4369
+ /* @__PURE__ */ jsxRuntime.jsx("span", { children: action_label })
4370
+ ]
4371
+ }
4372
+ ) });
4373
+ };
4374
+ var CommandNodeExtension = core.Node.create({
4375
+ name: "commandNode",
4376
+ group: "inline",
4377
+ inline: true,
4378
+ // Atomic means the node cannot be split or merged
4379
+ atom: true,
4380
+ // Draggable in the editor
4381
+ draggable: true,
4382
+ // Selectable as a whole unit
4383
+ selectable: true,
4384
+ addAttributes() {
4385
+ return {
4386
+ id: {
4387
+ default: null,
4388
+ parseHTML: (element) => element.getAttribute("data-command-id"),
4389
+ renderHTML: (attributes) => ({
4390
+ "data-command-id": attributes.id
4391
+ })
4392
+ },
4393
+ prefix: {
4394
+ default: "",
4395
+ parseHTML: (element) => element.getAttribute("data-command-prefix"),
4396
+ renderHTML: (attributes) => ({
4397
+ "data-command-prefix": attributes.prefix
4398
+ })
4399
+ },
4400
+ action: {
4401
+ default: "",
4402
+ parseHTML: (element) => element.getAttribute("data-command-action"),
4403
+ renderHTML: (attributes) => ({
4404
+ "data-command-action": attributes.action
4405
+ })
4406
+ },
4407
+ action_label: {
4408
+ default: "",
4409
+ parseHTML: (element) => element.getAttribute("data-command-label"),
4410
+ renderHTML: (attributes) => ({
4411
+ "data-command-label": attributes.action_label
4412
+ })
4413
+ },
4414
+ variant: {
4415
+ default: "default",
4416
+ parseHTML: (element) => element.getAttribute("data-command-variant") || "default",
4417
+ renderHTML: (attributes) => ({
4418
+ "data-command-variant": attributes.variant
4419
+ })
4420
+ }
4421
+ };
4422
+ },
4423
+ parseHTML() {
4424
+ return [
4425
+ {
4426
+ tag: "span[data-command-id]"
4427
+ }
4428
+ ];
4429
+ },
4430
+ renderHTML({ HTMLAttributes }) {
4431
+ return [
4432
+ "span",
4433
+ core.mergeAttributes(HTMLAttributes, {
4434
+ class: "cls_command_pill",
4435
+ contenteditable: "false"
4436
+ }),
4437
+ `${HTMLAttributes["data-command-prefix"]}${HTMLAttributes["data-command-label"]}`
4438
+ ];
4439
+ },
4440
+ // Output format: prefix + action (e.g., "@user_123", "/due_date")
4441
+ renderText({ node }) {
4442
+ return `${node.attrs.prefix}${node.attrs.action}`;
4443
+ },
4444
+ addNodeView() {
4445
+ return react.ReactNodeViewRenderer(CommandPillView);
4446
+ },
4447
+ addCommands() {
4448
+ return {
4449
+ insertCommand: (attrs) => ({ commands }) => {
4450
+ return commands.insertContent({
4451
+ type: this.name,
4452
+ attrs: {
4453
+ ...attrs,
4454
+ id: generate_command_id()
4455
+ }
4456
+ });
4457
+ },
4458
+ updateCommand: (id, attrs) => ({ tr, state }) => {
4459
+ let updated = false;
4460
+ state.doc.descendants((node, pos) => {
4461
+ if (node.type.name === this.name && node.attrs.id === id) {
4462
+ tr.setNodeMarkup(pos, void 0, {
4463
+ ...node.attrs,
4464
+ ...attrs
4465
+ });
4466
+ updated = true;
4467
+ return false;
4468
+ }
4469
+ });
4470
+ return updated;
4471
+ }
4472
+ };
4473
+ },
4474
+ // Keyboard behavior - delete entire node on backspace
4475
+ addKeyboardShortcuts() {
4476
+ return {
4477
+ Backspace: () => this.editor.commands.command(({ tr, state }) => {
4478
+ let is_command = false;
4479
+ const { selection } = state;
4480
+ const { empty, anchor } = selection;
4481
+ if (!empty) {
4482
+ return false;
4483
+ }
4484
+ state.doc.nodesBetween(anchor - 1, anchor, (node, pos) => {
4485
+ if (node.type.name === this.name) {
4486
+ is_command = true;
4487
+ tr.insertText("", pos, pos + node.nodeSize);
4488
+ return false;
4489
+ }
4490
+ });
4491
+ return is_command;
4492
+ })
4493
+ };
4494
+ }
4495
+ });
4496
+ var create_suggestion_config = (prefix_config, on_suggestion_change, on_insert_command) => {
4497
+ return {
4498
+ char: prefix_config.char,
4499
+ allowSpaces: false,
4500
+ startOfLine: false,
4501
+ items: ({ query }) => {
4502
+ if (!query) return prefix_config.commands;
4503
+ const lower_query = query.toLowerCase();
4504
+ return prefix_config.commands.filter(
4505
+ (cmd) => cmd.action_label.toLowerCase().includes(lower_query) || cmd.action.toLowerCase().includes(lower_query) || cmd.action_description?.toLowerCase().includes(lower_query)
4506
+ );
4507
+ },
4508
+ render: () => {
4509
+ return {
4510
+ onStart: (props) => {
4511
+ on_suggestion_change({
4512
+ is_active: true,
4513
+ query: props.query,
4514
+ prefix: prefix_config.char,
4515
+ client_rect: props.clientRect,
4516
+ commands: prefix_config.commands,
4517
+ range: props.range
4518
+ });
4519
+ },
4520
+ onUpdate: (props) => {
4521
+ on_suggestion_change({
4522
+ is_active: true,
4523
+ query: props.query,
4524
+ prefix: prefix_config.char,
4525
+ client_rect: props.clientRect,
4526
+ commands: prefix_config.commands,
4527
+ range: props.range
4528
+ });
4529
+ },
4530
+ onKeyDown: (props) => {
4531
+ if (props.event.key === "Escape") {
4532
+ on_suggestion_change(null);
4533
+ return true;
4534
+ }
4535
+ if (props.event.key === "ArrowUp" || props.event.key === "ArrowDown" || props.event.key === "Enter") {
4536
+ return true;
4537
+ }
4538
+ return false;
4539
+ },
4540
+ onExit: () => {
4541
+ on_suggestion_change(null);
4542
+ }
4543
+ };
4544
+ },
4545
+ command: ({ range, props }) => {
4546
+ const command = props;
4547
+ on_insert_command(command, prefix_config.char, range);
4548
+ }
4549
+ };
4550
+ };
4551
+ var create_command_suggestion_extension = (config) => {
4552
+ const { prefixes, on_suggestion_change, on_insert_command } = config;
4553
+ return prefixes.map((prefix_config, index) => {
4554
+ return core.Extension.create({
4555
+ name: `commandSuggestion_${prefix_config.char}_${index}`,
4556
+ addProseMirrorPlugins() {
4557
+ return [
4558
+ Suggestion__default.default({
4559
+ editor: this.editor,
4560
+ ...create_suggestion_config(
4561
+ prefix_config,
4562
+ on_suggestion_change,
4563
+ on_insert_command
4564
+ )
4565
+ })
4566
+ ];
4567
+ }
4568
+ });
4569
+ });
4570
+ };
4571
+ var insert_command_at_position = (editor, command, prefix, range, variant = "default") => {
4572
+ editor.chain().focus().deleteRange(range).insertCommand({
4573
+ prefix,
4574
+ action: command.action,
4575
+ action_label: command.action_label,
4576
+ variant
4577
+ }).run();
4578
+ };
4579
+ var get_variant_classes2 = (variant = "default") => {
4580
+ switch (variant) {
4581
+ case "outline":
4582
+ return "bg-transparent border-primary/40 text-primary hover:bg-primary/5";
4583
+ case "subtle":
4584
+ return "bg-muted border-transparent text-muted-foreground hover:bg-muted/80";
4585
+ case "default":
4586
+ default:
4587
+ return "bg-primary/10 text-primary border-primary/20 hover:bg-primary/15";
4588
+ }
4589
+ };
4590
+ var CommandPill = ({
4591
+ prefix,
4592
+ action,
4593
+ action_label,
4594
+ id,
4595
+ selected = false,
4596
+ variant = "default",
4597
+ on_click
4598
+ }) => {
4599
+ return /* @__PURE__ */ jsxRuntime.jsxs(
4600
+ "span",
4601
+ {
4602
+ className: cn(
4603
+ "cls_command_pill_standalone",
4604
+ "inline-flex items-center",
4605
+ "px-1.5 py-0.5",
4606
+ "rounded-md",
4607
+ "text-sm font-medium",
4608
+ "border",
4609
+ "transition-all duration-150",
4610
+ get_variant_classes2(variant),
4611
+ selected && "ring-2 ring-ring ring-offset-1",
4612
+ on_click && "cursor-pointer"
4613
+ ),
4614
+ "data-command-id": id,
4615
+ "data-command-prefix": prefix,
4616
+ "data-command-action": action,
4617
+ onClick: on_click,
4618
+ role: on_click ? "button" : void 0,
4619
+ tabIndex: on_click ? 0 : void 0,
4620
+ onKeyDown: (e) => {
4621
+ if (on_click && (e.key === "Enter" || e.key === " ")) {
4622
+ e.preventDefault();
4623
+ on_click();
4624
+ }
4625
+ },
4626
+ children: [
4627
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-muted-foreground opacity-70", children: prefix }),
4628
+ /* @__PURE__ */ jsxRuntime.jsx("span", { children: action_label })
4629
+ ]
4630
+ }
4631
+ );
4632
+ };
4633
+ CommandPill.displayName = "CommandPill";
4634
+ var group_commands = (commands) => {
4635
+ const groups = /* @__PURE__ */ new Map();
4636
+ for (const cmd of commands) {
4637
+ const group_name = cmd.group || "";
4638
+ if (!groups.has(group_name)) {
4639
+ groups.set(group_name, []);
4640
+ }
4641
+ groups.get(group_name).push(cmd);
4642
+ }
4643
+ return groups;
4644
+ };
4645
+ var CommandPopover = ({
4646
+ is_open,
4647
+ commands,
4648
+ prefix,
4649
+ query,
4650
+ selected_index,
4651
+ position,
4652
+ on_select,
4653
+ on_close,
4654
+ on_selection_change: _on_selection_change
4655
+ }) => {
4656
+ const container_ref = React27__namespace.useRef(null);
4657
+ const grouped_commands = React27__namespace.useMemo(
4658
+ () => group_commands(commands),
4659
+ [commands]
4660
+ );
4661
+ React27__namespace.useEffect(() => {
4662
+ const handle_click_outside = (e) => {
4663
+ if (container_ref.current && !container_ref.current.contains(e.target)) {
4664
+ on_close();
4665
+ }
4666
+ };
4667
+ if (is_open) {
4668
+ document.addEventListener("mousedown", handle_click_outside);
4669
+ return () => {
4670
+ document.removeEventListener("mousedown", handle_click_outside);
4671
+ };
4672
+ }
4673
+ }, [is_open, on_close]);
4674
+ if (!is_open) return null;
4675
+ return /* @__PURE__ */ jsxRuntime.jsx(
4676
+ "div",
4677
+ {
4678
+ ref: container_ref,
4679
+ className: cn(
4680
+ "cls_command_popover",
4681
+ "absolute z-[9999]",
4682
+ "w-64 min-w-[200px] max-w-[300px]",
4683
+ "rounded-md border bg-popover text-popover-foreground shadow-lg",
4684
+ "animate-in fade-in-0 zoom-in-95"
4685
+ ),
4686
+ style: {
4687
+ top: position.top,
4688
+ left: position.left
4689
+ },
4690
+ children: /* @__PURE__ */ jsxRuntime.jsxs(Command, { className: "rounded-md", children: [
4691
+ query && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "px-3 py-2 text-xs text-muted-foreground border-b", children: [
4692
+ "Searching: ",
4693
+ /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "font-medium", children: [
4694
+ prefix,
4695
+ query
4696
+ ] })
4697
+ ] }),
4698
+ /* @__PURE__ */ jsxRuntime.jsxs(CommandList, { className: "max-h-[200px]", children: [
4699
+ commands.length === 0 && /* @__PURE__ */ jsxRuntime.jsx(CommandEmpty, { children: "No commands found." }),
4700
+ Array.from(grouped_commands.entries()).map(([group_name, group_commands2]) => /* @__PURE__ */ jsxRuntime.jsx(
4701
+ CommandGroup,
4702
+ {
4703
+ heading: group_name || void 0,
4704
+ children: group_commands2.map((cmd, idx) => {
4705
+ let flat_idx = 0;
4706
+ for (const [g, cmds] of grouped_commands.entries()) {
4707
+ if (g === group_name) {
4708
+ flat_idx += idx;
4709
+ break;
4710
+ }
4711
+ flat_idx += cmds.length;
4712
+ }
4713
+ return /* @__PURE__ */ jsxRuntime.jsx(
4714
+ CommandItem,
4715
+ {
4716
+ value: cmd.action,
4717
+ onSelect: () => on_select(cmd),
4718
+ className: cn(
4719
+ flat_idx === selected_index && "bg-accent"
4720
+ ),
4721
+ children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center gap-2 w-full", children: [
4722
+ cmd.icon && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "flex-shrink-0 text-muted-foreground", children: cmd.icon }),
4723
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex-1 min-w-0", children: [
4724
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "font-medium truncate", children: [
4725
+ prefix,
4726
+ cmd.action_label
4727
+ ] }),
4728
+ cmd.action_description && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-xs text-muted-foreground truncate", children: cmd.action_description })
4729
+ ] })
4730
+ ] })
4731
+ },
4732
+ cmd.action
4733
+ );
4734
+ })
4735
+ },
4736
+ group_name || "default"
4737
+ ))
4738
+ ] })
4739
+ ] })
4740
+ }
4741
+ );
4742
+ };
4743
+ CommandPopover.displayName = "CommandPopover";
4744
+
4745
+ // src/components/hazo_ui_command/index.tsx
4746
+ var parse_commands_from_text = (text, prefixes) => {
4747
+ const result = [];
4748
+ const action_to_label = /* @__PURE__ */ new Map();
4749
+ for (const prefix_config of prefixes) {
4750
+ for (const cmd of prefix_config.commands) {
4751
+ action_to_label.set(`${prefix_config.char}${cmd.action}`, {
4752
+ label: cmd.action_label,
4753
+ prefix: prefix_config.char
4754
+ });
4755
+ }
4756
+ }
4757
+ const prefix_chars = prefixes.map((p) => escape_regex(p.char)).join("|");
4758
+ const pattern = new RegExp(`(${prefix_chars})(\\w+)`, "g");
4759
+ let match;
4760
+ while ((match = pattern.exec(text)) !== null) {
4761
+ const full_match = match[0];
4762
+ const prefix = match[1];
4763
+ const action = match[2];
4764
+ const lookup_key = `${prefix}${action}`;
4765
+ const info = action_to_label.get(lookup_key);
4766
+ if (info) {
4767
+ result.push({
4768
+ action,
4769
+ action_label: info.label,
4770
+ prefix,
4771
+ position: match.index,
4772
+ length: full_match.length
4773
+ });
4774
+ }
4775
+ }
4776
+ return result;
4777
+ };
4778
+ var escape_regex = (str) => {
4779
+ return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
4780
+ };
4781
+ var text_to_tiptap_content = (text, prefixes, variant = "default") => {
4782
+ const commands = parse_commands_from_text(text, prefixes);
4783
+ if (commands.length === 0) {
4784
+ return {
4785
+ type: "doc",
4786
+ content: [
4787
+ {
4788
+ type: "paragraph",
4789
+ content: text ? [{ type: "text", text }] : []
4790
+ }
4791
+ ]
4792
+ };
4793
+ }
4794
+ commands.sort((a, b) => a.position - b.position);
4795
+ const content = [];
4796
+ let last_end = 0;
4797
+ for (const cmd of commands) {
4798
+ if (cmd.position > last_end) {
4799
+ content.push({
4800
+ type: "text",
4801
+ text: text.slice(last_end, cmd.position)
4802
+ });
4803
+ }
4804
+ content.push({
4805
+ type: "commandNode",
4806
+ attrs: {
4807
+ id: `cmd_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`,
4808
+ prefix: cmd.prefix,
4809
+ action: cmd.action,
4810
+ action_label: cmd.action_label,
4811
+ variant
4812
+ }
4813
+ });
4814
+ last_end = cmd.position + cmd.length;
4815
+ }
4816
+ if (last_end < text.length) {
4817
+ content.push({
4818
+ type: "text",
4819
+ text: text.slice(last_end)
4820
+ });
4821
+ }
4822
+ return {
4823
+ type: "doc",
4824
+ content: [
4825
+ {
4826
+ type: "paragraph",
4827
+ content
4828
+ }
4829
+ ]
4830
+ };
4831
+ };
4832
+ var Document = core.Node.create({
4833
+ name: "doc",
4834
+ topNode: true,
4835
+ content: "block+",
4836
+ renderMarkdown: (node, h) => {
4837
+ if (!node.content) {
4838
+ return "";
4839
+ }
4840
+ return h.renderChildren(node.content, "\n\n");
4841
+ }
4842
+ });
4843
+ var index_default = Document;
4844
+ var Paragraph = core.Node.create({
4845
+ name: "paragraph",
4846
+ priority: 1e3,
4847
+ addOptions() {
4848
+ return {
4849
+ HTMLAttributes: {}
4850
+ };
4851
+ },
4852
+ group: "block",
4853
+ content: "inline*",
4854
+ parseHTML() {
4855
+ return [{ tag: "p" }];
4856
+ },
4857
+ renderHTML({ HTMLAttributes }) {
4858
+ return ["p", core.mergeAttributes(this.options.HTMLAttributes, HTMLAttributes), 0];
4859
+ },
4860
+ parseMarkdown: (token, helpers) => {
4861
+ const tokens = token.tokens || [];
4862
+ if (tokens.length === 1 && tokens[0].type === "image") {
4863
+ return helpers.parseChildren([tokens[0]]);
4864
+ }
4865
+ return helpers.createNode(
4866
+ "paragraph",
4867
+ void 0,
4868
+ // no attributes for paragraph
4869
+ helpers.parseInline(tokens)
4870
+ );
4871
+ },
4872
+ renderMarkdown: (node, h) => {
4873
+ if (!node || !Array.isArray(node.content)) {
4874
+ return "";
4875
+ }
4876
+ return h.renderChildren(node.content);
4877
+ },
4878
+ addCommands() {
4879
+ return {
4880
+ setParagraph: () => ({ commands }) => {
4881
+ return commands.setNode(this.name);
4882
+ }
4883
+ };
4884
+ },
4885
+ addKeyboardShortcuts() {
4886
+ return {
4887
+ "Mod-Alt-0": () => this.editor.commands.setParagraph()
4888
+ };
4889
+ }
4890
+ });
4891
+ var index_default2 = Paragraph;
4892
+ var Text = core.Node.create({
4893
+ name: "text",
4894
+ group: "inline",
4895
+ parseMarkdown: (token) => {
4896
+ return {
4897
+ type: "text",
4898
+ text: token.text || ""
4899
+ };
4900
+ },
4901
+ renderMarkdown: (node) => node.text || ""
4902
+ });
4903
+ var index_default3 = Text;
4904
+ var SingleLineDocument = index_default.extend({
4905
+ content: "paragraph"
4906
+ });
4907
+ var get_editor_output = (editor) => {
4908
+ if (!editor) {
4909
+ return { plain_text: "", display_text: "", commands: [] };
4910
+ }
4911
+ const plain_text = editor.getText();
4912
+ const commands = [];
4913
+ let display_text = "";
4914
+ let position = 0;
4915
+ editor.state.doc.descendants((node, _pos) => {
4916
+ if (node.type.name === "text") {
4917
+ display_text += node.text || "";
4918
+ position += (node.text || "").length;
4919
+ } else if (node.type.name === "commandNode") {
4920
+ const { id, prefix, action, action_label } = node.attrs;
4921
+ const cmd_plain_text = `${prefix}${action}`;
4922
+ const cmd_display_text = `${prefix}${action_label}`;
4923
+ commands.push({
4924
+ id,
4925
+ prefix,
4926
+ action,
4927
+ action_label,
4928
+ position,
4929
+ length: cmd_plain_text.length
4930
+ });
4931
+ display_text += cmd_display_text;
4932
+ position += cmd_plain_text.length;
4933
+ }
4934
+ });
4935
+ return { plain_text, display_text, commands };
4936
+ };
4937
+ var HazoUiTextbox = ({
4938
+ value,
4939
+ default_value,
4940
+ prefixes,
4941
+ placeholder = "Type here...",
4942
+ disabled = false,
4943
+ className,
4944
+ pill_variant = "default",
4945
+ on_change,
4946
+ on_submit,
4947
+ on_command_insert,
4948
+ on_command_change,
4949
+ on_command_remove
4950
+ }) => {
4951
+ const [suggestion_state, set_suggestion_state] = React27__namespace.useState(null);
4952
+ const [selected_index, set_selected_index] = React27__namespace.useState(0);
4953
+ const [popover_position, set_popover_position] = React27__namespace.useState({ top: 0, left: 0 });
4954
+ const [edit_context, set_edit_context] = React27__namespace.useState(null);
4955
+ const [edit_selected_index, set_edit_selected_index] = React27__namespace.useState(0);
4956
+ const is_controlled = value !== void 0;
4957
+ const editor_container_ref = React27__namespace.useRef(null);
4958
+ const edit_popover_ref = React27__namespace.useRef(null);
4959
+ const suggestion_extensions = React27__namespace.useMemo(() => {
4960
+ return create_command_suggestion_extension({
4961
+ prefixes,
4962
+ on_suggestion_change: (state) => {
4963
+ set_suggestion_state(state);
4964
+ set_selected_index(0);
4965
+ },
4966
+ on_insert_command: (_command, _prefix, _range) => {
4967
+ }
4968
+ });
4969
+ }, [prefixes]);
4970
+ const editor = react.useEditor({
4971
+ extensions: [
4972
+ SingleLineDocument,
4973
+ index_default2,
4974
+ index_default3,
4975
+ Placeholder__default.default.configure({
4976
+ placeholder
4977
+ }),
4978
+ CommandNodeExtension.configure({}),
4979
+ ...suggestion_extensions
4980
+ ],
4981
+ content: is_controlled ? text_to_tiptap_content(value || "", prefixes, pill_variant) : text_to_tiptap_content(default_value || "", prefixes, pill_variant),
4982
+ editable: !disabled,
4983
+ immediatelyRender: false,
4984
+ editorProps: {
4985
+ attributes: {
4986
+ class: cn(
4987
+ "cls_textbox_editor",
4988
+ "w-full outline-none",
4989
+ "whitespace-nowrap overflow-x-auto"
4990
+ )
4991
+ },
4992
+ handleKeyDown: (_view, event) => {
4993
+ if (event.key === "Enter" && !suggestion_state?.is_active) {
4994
+ event.preventDefault();
4995
+ if (on_submit && editor) {
4996
+ on_submit(get_editor_output(editor));
4997
+ }
4998
+ return true;
4999
+ }
5000
+ return false;
5001
+ }
5002
+ },
5003
+ onUpdate: ({ editor: editor2 }) => {
5004
+ if (on_change) {
5005
+ on_change(get_editor_output(editor2));
5006
+ }
5007
+ }
5008
+ });
5009
+ React27__namespace.useEffect(() => {
5010
+ if (suggestion_state?.is_active && editor && editor_container_ref.current) {
5011
+ requestAnimationFrame(() => {
5012
+ const container = editor_container_ref.current;
5013
+ if (!container) return;
5014
+ const container_rect = container.getBoundingClientRect();
5015
+ const { from } = suggestion_state.range;
5016
+ try {
5017
+ const coords = editor.view.coordsAtPos(from);
5018
+ if (coords) {
5019
+ set_popover_position({
5020
+ top: coords.bottom - container_rect.top + 4,
5021
+ left: coords.left - container_rect.left
5022
+ });
5023
+ }
5024
+ } catch {
5025
+ const rect = suggestion_state.client_rect?.();
5026
+ if (rect) {
5027
+ set_popover_position({
5028
+ top: rect.bottom - container_rect.top + 4,
5029
+ left: rect.left - container_rect.left
5030
+ });
5031
+ }
5032
+ }
5033
+ });
5034
+ }
5035
+ }, [suggestion_state, editor]);
5036
+ React27__namespace.useEffect(() => {
5037
+ if (is_controlled && editor && !editor.isFocused) {
5038
+ const current_text = editor.getText();
5039
+ if (value !== current_text) {
5040
+ const content = text_to_tiptap_content(value || "", prefixes, pill_variant);
5041
+ editor.commands.setContent(content, { emitUpdate: false });
5042
+ }
5043
+ }
5044
+ }, [value, editor, is_controlled, prefixes, pill_variant]);
5045
+ React27__namespace.useEffect(() => {
5046
+ if (editor) {
5047
+ editor.setEditable(!disabled);
5048
+ }
5049
+ }, [disabled, editor]);
5050
+ const handle_command_select = React27__namespace.useCallback(
5051
+ (command) => {
5052
+ if (!editor || !suggestion_state) return;
5053
+ insert_command_at_position(
5054
+ editor,
5055
+ command,
5056
+ suggestion_state.prefix,
5057
+ suggestion_state.range,
5058
+ pill_variant
5059
+ );
5060
+ if (on_command_insert) {
5061
+ on_command_insert(command, suggestion_state.prefix);
5062
+ }
5063
+ set_suggestion_state(null);
5064
+ },
5065
+ [editor, suggestion_state, pill_variant, on_command_insert]
5066
+ );
5067
+ const handle_popover_close = React27__namespace.useCallback(() => {
5068
+ set_suggestion_state(null);
5069
+ editor?.commands.focus();
5070
+ }, [editor]);
5071
+ const handle_edit_close = React27__namespace.useCallback(() => {
5072
+ set_edit_context(null);
5073
+ editor?.commands.focus();
5074
+ }, [editor]);
5075
+ const handle_command_update = React27__namespace.useCallback(
5076
+ (new_command) => {
5077
+ if (!editor || !edit_context) return;
5078
+ const old_command = edit_context.command;
5079
+ editor.commands.updateCommand(old_command.id, {
5080
+ action: new_command.action,
5081
+ action_label: new_command.action_label
5082
+ });
5083
+ if (on_command_change) {
5084
+ on_command_change(old_command, new_command);
5085
+ }
5086
+ set_edit_context(null);
5087
+ editor.commands.focus();
5088
+ },
5089
+ [editor, edit_context, on_command_change]
5090
+ );
5091
+ const handle_command_remove = React27__namespace.useCallback(() => {
5092
+ if (!editor || !edit_context) return;
5093
+ const command = edit_context.command;
5094
+ editor.state.doc.descendants((node, pos) => {
5095
+ if (node.type.name === "commandNode" && node.attrs.id === command.id) {
5096
+ editor.chain().focus().deleteRange({ from: pos, to: pos + node.nodeSize }).run();
5097
+ return false;
5098
+ }
5099
+ });
5100
+ if (on_command_remove) {
5101
+ on_command_remove(command);
5102
+ }
5103
+ set_edit_context(null);
5104
+ }, [editor, edit_context, on_command_remove]);
5105
+ const filtered_commands = React27__namespace.useMemo(() => {
5106
+ if (!suggestion_state) return [];
5107
+ const query = suggestion_state.query.toLowerCase();
5108
+ if (!query) return suggestion_state.commands;
5109
+ return suggestion_state.commands.filter(
5110
+ (cmd) => cmd.action_label.toLowerCase().includes(query) || cmd.action.toLowerCase().includes(query) || cmd.action_description?.toLowerCase().includes(query)
5111
+ );
5112
+ }, [suggestion_state]);
5113
+ React27__namespace.useEffect(() => {
5114
+ if (!suggestion_state?.is_active) return;
5115
+ const handle_keydown = (e) => {
5116
+ switch (e.key) {
5117
+ case "ArrowDown":
5118
+ e.preventDefault();
5119
+ set_selected_index(
5120
+ (prev) => Math.min(prev + 1, filtered_commands.length - 1)
5121
+ );
5122
+ break;
5123
+ case "ArrowUp":
5124
+ e.preventDefault();
5125
+ set_selected_index((prev) => Math.max(prev - 1, 0));
5126
+ break;
5127
+ case "Enter":
5128
+ e.preventDefault();
5129
+ if (filtered_commands[selected_index]) {
5130
+ handle_command_select(filtered_commands[selected_index]);
5131
+ }
5132
+ break;
5133
+ case "Escape":
5134
+ e.preventDefault();
5135
+ handle_popover_close();
5136
+ break;
5137
+ }
5138
+ };
5139
+ window.addEventListener("keydown", handle_keydown);
5140
+ return () => window.removeEventListener("keydown", handle_keydown);
5141
+ }, [
5142
+ suggestion_state?.is_active,
5143
+ filtered_commands,
5144
+ selected_index,
5145
+ handle_command_select,
5146
+ handle_popover_close
5147
+ ]);
5148
+ React27__namespace.useEffect(() => {
5149
+ if (!edit_context) return;
5150
+ const handle_click_outside = (e) => {
5151
+ if (edit_popover_ref.current && !edit_popover_ref.current.contains(e.target)) {
5152
+ set_edit_context(null);
5153
+ }
5154
+ };
5155
+ const timeout = setTimeout(() => {
5156
+ document.addEventListener("mousedown", handle_click_outside);
5157
+ }, 100);
5158
+ return () => {
5159
+ clearTimeout(timeout);
5160
+ document.removeEventListener("mousedown", handle_click_outside);
5161
+ };
5162
+ }, [edit_context]);
5163
+ const edit_commands = React27__namespace.useMemo(() => {
5164
+ if (!edit_context) return [];
5165
+ const prefix_config = prefixes.find((p) => p.char === edit_context.command.prefix);
5166
+ return prefix_config?.commands || [];
5167
+ }, [edit_context, prefixes]);
5168
+ React27__namespace.useEffect(() => {
5169
+ if (!edit_context) return;
5170
+ const handle_keydown = (e) => {
5171
+ switch (e.key) {
5172
+ case "ArrowDown":
5173
+ e.preventDefault();
5174
+ set_edit_selected_index(
5175
+ (prev) => Math.min(prev + 1, edit_commands.length)
5176
+ );
5177
+ break;
5178
+ case "ArrowUp":
5179
+ e.preventDefault();
5180
+ set_edit_selected_index((prev) => Math.max(prev - 1, 0));
5181
+ break;
5182
+ case "Enter":
5183
+ e.preventDefault();
5184
+ if (edit_selected_index === edit_commands.length) {
5185
+ handle_command_remove();
5186
+ } else if (edit_commands[edit_selected_index]) {
5187
+ handle_command_update(edit_commands[edit_selected_index]);
5188
+ }
5189
+ break;
5190
+ case "Escape":
5191
+ e.preventDefault();
5192
+ handle_edit_close();
5193
+ break;
5194
+ }
5195
+ };
5196
+ window.addEventListener("keydown", handle_keydown);
5197
+ return () => window.removeEventListener("keydown", handle_keydown);
5198
+ }, [
5199
+ edit_context,
5200
+ edit_commands,
5201
+ edit_selected_index,
5202
+ handle_command_update,
5203
+ handle_command_remove,
5204
+ handle_edit_close
5205
+ ]);
5206
+ React27__namespace.useEffect(() => {
5207
+ const handle_pill_click = (e) => {
5208
+ const detail = e.detail;
5209
+ const { id, prefix, action, action_label, node_pos } = detail;
5210
+ if (editor && editor_container_ref.current) {
5211
+ const container_rect = editor_container_ref.current.getBoundingClientRect();
5212
+ try {
5213
+ const coords = editor.view.coordsAtPos(node_pos);
5214
+ if (coords) {
5215
+ const prefix_config = prefixes.find((p) => p.char === prefix);
5216
+ const current_index = prefix_config?.commands.findIndex(
5217
+ (cmd) => cmd.action === action
5218
+ ) ?? 0;
5219
+ set_edit_context({
5220
+ command: {
5221
+ id,
5222
+ prefix,
5223
+ action,
5224
+ action_label,
5225
+ position: node_pos,
5226
+ length: 0
5227
+ },
5228
+ node_pos,
5229
+ rect: new DOMRect(
5230
+ coords.left - container_rect.left,
5231
+ coords.bottom - container_rect.top + 4,
5232
+ 0,
5233
+ 0
5234
+ )
5235
+ });
5236
+ set_edit_selected_index(Math.max(0, current_index));
5237
+ }
5238
+ } catch {
5239
+ }
5240
+ }
5241
+ };
5242
+ document.addEventListener("command-pill-click", handle_pill_click);
5243
+ return () => document.removeEventListener("command-pill-click", handle_pill_click);
5244
+ }, [editor, prefixes]);
5245
+ return /* @__PURE__ */ jsxRuntime.jsxs(
5246
+ "div",
5247
+ {
5248
+ ref: editor_container_ref,
5249
+ className: cn(
5250
+ "cls_hazo_ui_textbox",
5251
+ "relative flex h-10 w-full rounded-md border border-input bg-background px-3 py-2",
5252
+ "text-sm ring-offset-background",
5253
+ "focus-within:outline-none focus-within:ring-2 focus-within:ring-ring focus-within:ring-offset-2",
5254
+ disabled && "cursor-not-allowed opacity-50",
5255
+ className
5256
+ ),
5257
+ children: [
5258
+ /* @__PURE__ */ jsxRuntime.jsx(
5259
+ react.EditorContent,
5260
+ {
5261
+ editor,
5262
+ className: cn(
5263
+ "cls_textbox_content",
5264
+ "flex-1 min-w-0",
5265
+ "[&_.ProseMirror]:outline-none",
5266
+ "[&_.ProseMirror_p]:m-0",
5267
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:content-[attr(data-placeholder)]",
5268
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:text-muted-foreground",
5269
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:pointer-events-none",
5270
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:float-left",
5271
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:h-0"
5272
+ )
5273
+ }
5274
+ ),
5275
+ suggestion_state?.is_active && /* @__PURE__ */ jsxRuntime.jsx(
5276
+ CommandPopover,
5277
+ {
5278
+ is_open: true,
5279
+ commands: filtered_commands,
5280
+ prefix: suggestion_state.prefix,
5281
+ query: suggestion_state.query,
5282
+ selected_index,
5283
+ position: popover_position,
5284
+ on_query_change: () => {
5285
+ },
5286
+ on_select: handle_command_select,
5287
+ on_close: handle_popover_close,
5288
+ on_selection_change: set_selected_index
5289
+ }
5290
+ ),
5291
+ edit_context && /* @__PURE__ */ jsxRuntime.jsx(
5292
+ "div",
5293
+ {
5294
+ ref: edit_popover_ref,
5295
+ className: cn(
5296
+ "cls_edit_popover",
5297
+ "absolute z-[9999]",
5298
+ "w-64 min-w-[200px] max-w-[300px]",
5299
+ "rounded-md border bg-popover text-popover-foreground shadow-lg",
5300
+ "animate-in fade-in-0 zoom-in-95"
5301
+ ),
5302
+ style: {
5303
+ top: edit_context.rect.y,
5304
+ left: edit_context.rect.x
5305
+ },
5306
+ children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "py-1", children: [
5307
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "px-3 py-2 text-xs text-muted-foreground border-b", children: "Change command" }),
5308
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "max-h-[200px] overflow-y-auto", children: [
5309
+ edit_commands.map((cmd, idx) => /* @__PURE__ */ jsxRuntime.jsxs(
5310
+ "div",
5311
+ {
5312
+ className: cn(
5313
+ "px-3 py-2 cursor-pointer flex items-center gap-2",
5314
+ "hover:bg-accent",
5315
+ idx === edit_selected_index && "bg-accent",
5316
+ cmd.action === edit_context.command.action && "font-medium"
5317
+ ),
5318
+ onClick: () => handle_command_update(cmd),
5319
+ children: [
5320
+ cmd.icon && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "flex-shrink-0 text-muted-foreground", children: cmd.icon }),
5321
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex-1 min-w-0", children: [
5322
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "truncate", children: [
5323
+ edit_context.command.prefix,
5324
+ cmd.action_label
5325
+ ] }),
5326
+ cmd.action_description && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-xs text-muted-foreground truncate", children: cmd.action_description })
5327
+ ] }),
5328
+ cmd.action === edit_context.command.action && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-xs text-muted-foreground", children: "current" })
5329
+ ]
5330
+ },
5331
+ cmd.action
5332
+ )),
5333
+ /* @__PURE__ */ jsxRuntime.jsx(
5334
+ "div",
5335
+ {
5336
+ className: cn(
5337
+ "px-3 py-2 cursor-pointer flex items-center gap-2 text-destructive border-t",
5338
+ "hover:bg-destructive/10",
5339
+ edit_selected_index === edit_commands.length && "bg-destructive/10"
5340
+ ),
5341
+ onClick: handle_command_remove,
5342
+ children: /* @__PURE__ */ jsxRuntime.jsx("span", { children: "Remove" })
5343
+ }
5344
+ )
5345
+ ] })
5346
+ ] })
5347
+ }
5348
+ )
5349
+ ]
5350
+ }
5351
+ );
5352
+ };
5353
+ HazoUiTextbox.displayName = "HazoUiTextbox";
5354
+ var HardBreak = core.Node.create({
5355
+ name: "hardBreak",
5356
+ markdownTokenName: "br",
5357
+ addOptions() {
5358
+ return {
5359
+ keepMarks: true,
5360
+ HTMLAttributes: {}
5361
+ };
5362
+ },
5363
+ inline: true,
5364
+ group: "inline",
5365
+ selectable: false,
5366
+ linebreakReplacement: true,
5367
+ parseHTML() {
5368
+ return [{ tag: "br" }];
5369
+ },
5370
+ renderHTML({ HTMLAttributes }) {
5371
+ return ["br", core.mergeAttributes(this.options.HTMLAttributes, HTMLAttributes)];
5372
+ },
5373
+ renderText() {
5374
+ return "\n";
5375
+ },
5376
+ renderMarkdown: () => `
5377
+ `,
5378
+ parseMarkdown: () => {
5379
+ return {
5380
+ type: "hardBreak"
5381
+ };
5382
+ },
5383
+ addCommands() {
5384
+ return {
5385
+ setHardBreak: () => ({ commands, chain, state, editor }) => {
5386
+ return commands.first([
5387
+ () => commands.exitCode(),
5388
+ () => commands.command(() => {
5389
+ const { selection, storedMarks } = state;
5390
+ if (selection.$from.parent.type.spec.isolating) {
5391
+ return false;
5392
+ }
5393
+ const { keepMarks } = this.options;
5394
+ const { splittableMarks } = editor.extensionManager;
5395
+ const marks = storedMarks || selection.$to.parentOffset && selection.$from.marks();
5396
+ return chain().insertContent({ type: this.name }).command(({ tr, dispatch }) => {
5397
+ if (dispatch && marks && keepMarks) {
5398
+ const filteredMarks = marks.filter((mark) => splittableMarks.includes(mark.type.name));
5399
+ tr.ensureMarks(filteredMarks);
5400
+ }
5401
+ return true;
5402
+ }).run();
5403
+ })
5404
+ ]);
5405
+ }
5406
+ };
5407
+ },
5408
+ addKeyboardShortcuts() {
5409
+ return {
5410
+ "Mod-Enter": () => this.editor.commands.setHardBreak(),
5411
+ "Shift-Enter": () => this.editor.commands.setHardBreak()
5412
+ };
5413
+ }
5414
+ });
5415
+ var index_default4 = HardBreak;
5416
+ var get_editor_output2 = (editor) => {
5417
+ if (!editor) {
5418
+ return { plain_text: "", display_text: "", commands: [] };
5419
+ }
5420
+ const plain_text = editor.getText();
5421
+ const commands = [];
5422
+ let display_text = "";
5423
+ let position = 0;
5424
+ editor.state.doc.descendants((node, _pos) => {
5425
+ if (node.type.name === "text") {
5426
+ display_text += node.text || "";
5427
+ position += (node.text || "").length;
5428
+ } else if (node.type.name === "commandNode") {
5429
+ const { id, prefix, action, action_label } = node.attrs;
5430
+ const cmd_plain_text = `${prefix}${action}`;
5431
+ const cmd_display_text = `${prefix}${action_label}`;
5432
+ commands.push({
5433
+ id,
5434
+ prefix,
5435
+ action,
5436
+ action_label,
5437
+ position,
5438
+ length: cmd_plain_text.length
5439
+ });
5440
+ display_text += cmd_display_text;
5441
+ position += cmd_plain_text.length;
5442
+ } else if (node.type.name === "hardBreak") {
5443
+ display_text += "\n";
5444
+ position += 1;
5445
+ }
5446
+ });
5447
+ return { plain_text, display_text, commands };
5448
+ };
5449
+ var multiline_text_to_tiptap_content = (text, prefixes, variant = "default") => {
5450
+ const lines = text.split("\n");
5451
+ const paragraphs = [];
5452
+ for (const line of lines) {
5453
+ const line_content = text_to_tiptap_content(line, prefixes, variant);
5454
+ const para = line_content.content?.[0];
5455
+ if (para) {
5456
+ paragraphs.push(para);
5457
+ } else {
5458
+ paragraphs.push({ type: "paragraph", content: [] });
5459
+ }
5460
+ }
5461
+ return {
5462
+ type: "doc",
5463
+ content: paragraphs.length > 0 ? paragraphs : [{ type: "paragraph", content: [] }]
5464
+ };
5465
+ };
5466
+ var HazoUiTextarea = ({
5467
+ value,
5468
+ default_value,
5469
+ prefixes,
5470
+ placeholder = "Type here...",
5471
+ disabled = false,
5472
+ className,
5473
+ pill_variant = "default",
5474
+ min_height = "80px",
5475
+ max_height = "200px",
5476
+ rows,
5477
+ on_change,
5478
+ on_submit,
5479
+ on_command_insert,
5480
+ on_command_change,
5481
+ on_command_remove
5482
+ }) => {
5483
+ const [suggestion_state, set_suggestion_state] = React27__namespace.useState(null);
5484
+ const [selected_index, set_selected_index] = React27__namespace.useState(0);
5485
+ const [popover_position, set_popover_position] = React27__namespace.useState({ top: 0, left: 0 });
5486
+ const [edit_context, set_edit_context] = React27__namespace.useState(null);
5487
+ const [edit_selected_index, set_edit_selected_index] = React27__namespace.useState(0);
5488
+ const is_controlled = value !== void 0;
5489
+ const editor_container_ref = React27__namespace.useRef(null);
5490
+ const edit_popover_ref = React27__namespace.useRef(null);
5491
+ const calculated_min_height = rows ? `${rows * 1.5}em` : min_height;
5492
+ const suggestion_extensions = React27__namespace.useMemo(() => {
5493
+ return create_command_suggestion_extension({
5494
+ prefixes,
5495
+ on_suggestion_change: (state) => {
5496
+ set_suggestion_state(state);
5497
+ set_selected_index(0);
5498
+ },
5499
+ on_insert_command: (_command, _prefix, _range) => {
5500
+ }
5501
+ });
5502
+ }, [prefixes]);
5503
+ const editor = react.useEditor({
5504
+ extensions: [
5505
+ index_default,
5506
+ index_default2,
5507
+ index_default3,
5508
+ index_default4,
5509
+ Placeholder__default.default.configure({
5510
+ placeholder
5511
+ }),
5512
+ CommandNodeExtension.configure({}),
5513
+ ...suggestion_extensions
5514
+ ],
5515
+ content: is_controlled ? multiline_text_to_tiptap_content(value || "", prefixes, pill_variant) : multiline_text_to_tiptap_content(default_value || "", prefixes, pill_variant),
5516
+ editable: !disabled,
5517
+ immediatelyRender: false,
5518
+ editorProps: {
5519
+ attributes: {
5520
+ class: cn("cls_textarea_editor", "w-full outline-none"),
5521
+ style: `min-height: ${calculated_min_height}; max-height: ${max_height}`
5522
+ },
5523
+ handleKeyDown: (_view, event) => {
5524
+ if (event.key === "Enter" && (event.metaKey || event.ctrlKey) && !suggestion_state?.is_active) {
5525
+ event.preventDefault();
5526
+ if (on_submit && editor) {
5527
+ on_submit(get_editor_output2(editor));
5528
+ }
5529
+ return true;
5530
+ }
5531
+ return false;
5532
+ }
5533
+ },
5534
+ onUpdate: ({ editor: editor2 }) => {
5535
+ if (on_change) {
5536
+ on_change(get_editor_output2(editor2));
5537
+ }
5538
+ }
5539
+ });
5540
+ React27__namespace.useEffect(() => {
5541
+ if (suggestion_state?.is_active && editor && editor_container_ref.current) {
5542
+ requestAnimationFrame(() => {
5543
+ const container = editor_container_ref.current;
5544
+ if (!container) return;
5545
+ const container_rect = container.getBoundingClientRect();
5546
+ const { from } = suggestion_state.range;
5547
+ try {
5548
+ const coords = editor.view.coordsAtPos(from);
5549
+ if (coords) {
5550
+ set_popover_position({
5551
+ top: coords.bottom - container_rect.top + 4,
5552
+ left: coords.left - container_rect.left
5553
+ });
5554
+ }
5555
+ } catch {
5556
+ const rect = suggestion_state.client_rect?.();
5557
+ if (rect) {
5558
+ set_popover_position({
5559
+ top: rect.bottom - container_rect.top + 4,
5560
+ left: rect.left - container_rect.left
5561
+ });
5562
+ }
5563
+ }
5564
+ });
5565
+ }
5566
+ }, [suggestion_state, editor]);
5567
+ React27__namespace.useEffect(() => {
5568
+ if (is_controlled && editor && !editor.isFocused) {
5569
+ const current_text = editor.getText();
5570
+ if (value !== current_text) {
5571
+ const content = multiline_text_to_tiptap_content(
5572
+ value || "",
5573
+ prefixes,
5574
+ pill_variant
5575
+ );
5576
+ editor.commands.setContent(content, { emitUpdate: false });
5577
+ }
5578
+ }
5579
+ }, [value, editor, is_controlled, prefixes, pill_variant]);
5580
+ React27__namespace.useEffect(() => {
5581
+ if (editor) {
5582
+ editor.setEditable(!disabled);
5583
+ }
5584
+ }, [disabled, editor]);
5585
+ const handle_command_select = React27__namespace.useCallback(
5586
+ (command) => {
5587
+ if (!editor || !suggestion_state) return;
5588
+ insert_command_at_position(
5589
+ editor,
5590
+ command,
5591
+ suggestion_state.prefix,
5592
+ suggestion_state.range,
5593
+ pill_variant
5594
+ );
5595
+ if (on_command_insert) {
5596
+ on_command_insert(command, suggestion_state.prefix);
5597
+ }
5598
+ set_suggestion_state(null);
5599
+ },
5600
+ [editor, suggestion_state, pill_variant, on_command_insert]
5601
+ );
5602
+ const handle_popover_close = React27__namespace.useCallback(() => {
5603
+ set_suggestion_state(null);
5604
+ editor?.commands.focus();
5605
+ }, [editor]);
5606
+ const handle_edit_close = React27__namespace.useCallback(() => {
5607
+ set_edit_context(null);
5608
+ editor?.commands.focus();
5609
+ }, [editor]);
5610
+ const handle_command_update = React27__namespace.useCallback(
5611
+ (new_command) => {
5612
+ if (!editor || !edit_context) return;
5613
+ const old_command = edit_context.command;
5614
+ editor.commands.updateCommand(old_command.id, {
5615
+ action: new_command.action,
5616
+ action_label: new_command.action_label
5617
+ });
5618
+ if (on_command_change) {
5619
+ on_command_change(old_command, new_command);
5620
+ }
5621
+ set_edit_context(null);
5622
+ editor.commands.focus();
5623
+ },
5624
+ [editor, edit_context, on_command_change]
5625
+ );
5626
+ const handle_command_remove = React27__namespace.useCallback(() => {
5627
+ if (!editor || !edit_context) return;
5628
+ const command = edit_context.command;
5629
+ editor.state.doc.descendants((node, pos) => {
5630
+ if (node.type.name === "commandNode" && node.attrs.id === command.id) {
5631
+ editor.chain().focus().deleteRange({ from: pos, to: pos + node.nodeSize }).run();
5632
+ return false;
5633
+ }
5634
+ });
5635
+ if (on_command_remove) {
5636
+ on_command_remove(command);
5637
+ }
5638
+ set_edit_context(null);
5639
+ }, [editor, edit_context, on_command_remove]);
5640
+ const filtered_commands = React27__namespace.useMemo(() => {
5641
+ if (!suggestion_state) return [];
5642
+ const query = suggestion_state.query.toLowerCase();
5643
+ if (!query) return suggestion_state.commands;
5644
+ return suggestion_state.commands.filter(
5645
+ (cmd) => cmd.action_label.toLowerCase().includes(query) || cmd.action.toLowerCase().includes(query) || cmd.action_description?.toLowerCase().includes(query)
5646
+ );
5647
+ }, [suggestion_state]);
5648
+ React27__namespace.useEffect(() => {
5649
+ if (!suggestion_state?.is_active) return;
5650
+ const handle_keydown = (e) => {
5651
+ switch (e.key) {
5652
+ case "ArrowDown":
5653
+ e.preventDefault();
5654
+ set_selected_index(
5655
+ (prev) => Math.min(prev + 1, filtered_commands.length - 1)
5656
+ );
5657
+ break;
5658
+ case "ArrowUp":
5659
+ e.preventDefault();
5660
+ set_selected_index((prev) => Math.max(prev - 1, 0));
5661
+ break;
5662
+ case "Enter":
5663
+ e.preventDefault();
5664
+ if (filtered_commands[selected_index]) {
5665
+ handle_command_select(filtered_commands[selected_index]);
5666
+ }
5667
+ break;
5668
+ case "Escape":
5669
+ e.preventDefault();
5670
+ handle_popover_close();
5671
+ break;
5672
+ }
5673
+ };
5674
+ window.addEventListener("keydown", handle_keydown);
5675
+ return () => window.removeEventListener("keydown", handle_keydown);
5676
+ }, [
5677
+ suggestion_state?.is_active,
5678
+ filtered_commands,
5679
+ selected_index,
5680
+ handle_command_select,
5681
+ handle_popover_close
5682
+ ]);
5683
+ React27__namespace.useEffect(() => {
5684
+ if (!edit_context) return;
5685
+ const handle_click_outside = (e) => {
5686
+ if (edit_popover_ref.current && !edit_popover_ref.current.contains(e.target)) {
5687
+ set_edit_context(null);
5688
+ }
5689
+ };
5690
+ const timeout = setTimeout(() => {
5691
+ document.addEventListener("mousedown", handle_click_outside);
5692
+ }, 100);
5693
+ return () => {
5694
+ clearTimeout(timeout);
5695
+ document.removeEventListener("mousedown", handle_click_outside);
5696
+ };
5697
+ }, [edit_context]);
5698
+ const edit_commands = React27__namespace.useMemo(() => {
5699
+ if (!edit_context) return [];
5700
+ const prefix_config = prefixes.find((p) => p.char === edit_context.command.prefix);
5701
+ return prefix_config?.commands || [];
5702
+ }, [edit_context, prefixes]);
5703
+ React27__namespace.useEffect(() => {
5704
+ if (!edit_context) return;
5705
+ const handle_keydown = (e) => {
5706
+ switch (e.key) {
5707
+ case "ArrowDown":
5708
+ e.preventDefault();
5709
+ set_edit_selected_index(
5710
+ (prev) => Math.min(prev + 1, edit_commands.length)
5711
+ );
5712
+ break;
5713
+ case "ArrowUp":
5714
+ e.preventDefault();
5715
+ set_edit_selected_index((prev) => Math.max(prev - 1, 0));
5716
+ break;
5717
+ case "Enter":
5718
+ e.preventDefault();
5719
+ if (edit_selected_index === edit_commands.length) {
5720
+ handle_command_remove();
5721
+ } else if (edit_commands[edit_selected_index]) {
5722
+ handle_command_update(edit_commands[edit_selected_index]);
5723
+ }
5724
+ break;
5725
+ case "Escape":
5726
+ e.preventDefault();
5727
+ handle_edit_close();
5728
+ break;
5729
+ }
5730
+ };
5731
+ window.addEventListener("keydown", handle_keydown);
5732
+ return () => window.removeEventListener("keydown", handle_keydown);
5733
+ }, [
5734
+ edit_context,
5735
+ edit_commands,
5736
+ edit_selected_index,
5737
+ handle_command_update,
5738
+ handle_command_remove,
5739
+ handle_edit_close
5740
+ ]);
5741
+ React27__namespace.useEffect(() => {
5742
+ const handle_pill_click = (e) => {
5743
+ const detail = e.detail;
5744
+ const { id, prefix, action, action_label, node_pos } = detail;
5745
+ if (editor && editor_container_ref.current) {
5746
+ const container_rect = editor_container_ref.current.getBoundingClientRect();
5747
+ try {
5748
+ const coords = editor.view.coordsAtPos(node_pos);
5749
+ if (coords) {
5750
+ const prefix_config = prefixes.find((p) => p.char === prefix);
5751
+ const current_index = prefix_config?.commands.findIndex(
5752
+ (cmd) => cmd.action === action
5753
+ ) ?? 0;
5754
+ set_edit_context({
5755
+ command: {
5756
+ id,
5757
+ prefix,
5758
+ action,
5759
+ action_label,
5760
+ position: node_pos,
5761
+ length: 0
5762
+ },
5763
+ node_pos,
5764
+ rect: new DOMRect(
5765
+ coords.left - container_rect.left,
5766
+ coords.bottom - container_rect.top + 4,
5767
+ 0,
5768
+ 0
5769
+ )
5770
+ });
5771
+ set_edit_selected_index(Math.max(0, current_index));
5772
+ }
5773
+ } catch {
5774
+ }
5775
+ }
5776
+ };
5777
+ document.addEventListener("command-pill-click", handle_pill_click);
5778
+ return () => document.removeEventListener("command-pill-click", handle_pill_click);
5779
+ }, [editor, prefixes]);
5780
+ return /* @__PURE__ */ jsxRuntime.jsxs(
5781
+ "div",
5782
+ {
5783
+ ref: editor_container_ref,
5784
+ className: cn(
5785
+ "cls_hazo_ui_textarea",
5786
+ "relative flex w-full rounded-md border border-input bg-background px-3 py-2",
5787
+ "text-sm ring-offset-background",
5788
+ "focus-within:outline-none focus-within:ring-2 focus-within:ring-ring focus-within:ring-offset-2",
5789
+ disabled && "cursor-not-allowed opacity-50",
5790
+ className
5791
+ ),
5792
+ style: {
5793
+ minHeight: calculated_min_height,
5794
+ maxHeight: max_height
5795
+ },
5796
+ children: [
5797
+ /* @__PURE__ */ jsxRuntime.jsx(
5798
+ react.EditorContent,
5799
+ {
5800
+ editor,
5801
+ className: cn(
5802
+ "cls_textarea_content",
5803
+ "flex-1 min-w-0 overflow-y-auto",
5804
+ "[&_.ProseMirror]:outline-none",
5805
+ "[&_.ProseMirror_p]:m-0 [&_.ProseMirror_p]:mb-1",
5806
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:content-[attr(data-placeholder)]",
5807
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:text-muted-foreground",
5808
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:pointer-events-none",
5809
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:float-left",
5810
+ "[&_.ProseMirror_.is-editor-empty:first-child::before]:h-0"
5811
+ )
5812
+ }
5813
+ ),
5814
+ suggestion_state?.is_active && /* @__PURE__ */ jsxRuntime.jsx(
5815
+ CommandPopover,
5816
+ {
5817
+ is_open: true,
5818
+ commands: filtered_commands,
5819
+ prefix: suggestion_state.prefix,
5820
+ query: suggestion_state.query,
5821
+ selected_index,
5822
+ position: popover_position,
5823
+ on_query_change: () => {
5824
+ },
5825
+ on_select: handle_command_select,
5826
+ on_close: handle_popover_close,
5827
+ on_selection_change: set_selected_index
5828
+ }
5829
+ ),
5830
+ edit_context && /* @__PURE__ */ jsxRuntime.jsx(
5831
+ "div",
5832
+ {
5833
+ ref: edit_popover_ref,
5834
+ className: cn(
5835
+ "cls_edit_popover",
5836
+ "absolute z-[9999]",
5837
+ "w-64 min-w-[200px] max-w-[300px]",
5838
+ "rounded-md border bg-popover text-popover-foreground shadow-lg",
5839
+ "animate-in fade-in-0 zoom-in-95"
5840
+ ),
5841
+ style: {
5842
+ top: edit_context.rect.y,
5843
+ left: edit_context.rect.x
5844
+ },
5845
+ children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "py-1", children: [
5846
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "px-3 py-2 text-xs text-muted-foreground border-b", children: "Change command" }),
5847
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "max-h-[200px] overflow-y-auto", children: [
5848
+ edit_commands.map((cmd, idx) => /* @__PURE__ */ jsxRuntime.jsxs(
5849
+ "div",
5850
+ {
5851
+ className: cn(
5852
+ "px-3 py-2 cursor-pointer flex items-center gap-2",
5853
+ "hover:bg-accent",
5854
+ idx === edit_selected_index && "bg-accent",
5855
+ cmd.action === edit_context.command.action && "font-medium"
5856
+ ),
5857
+ onClick: () => handle_command_update(cmd),
5858
+ children: [
5859
+ cmd.icon && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "flex-shrink-0 text-muted-foreground", children: cmd.icon }),
5860
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex-1 min-w-0", children: [
5861
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "truncate", children: [
5862
+ edit_context.command.prefix,
5863
+ cmd.action_label
5864
+ ] }),
5865
+ cmd.action_description && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-xs text-muted-foreground truncate", children: cmd.action_description })
5866
+ ] }),
5867
+ cmd.action === edit_context.command.action && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-xs text-muted-foreground", children: "current" })
5868
+ ]
5869
+ },
5870
+ cmd.action
5871
+ )),
5872
+ /* @__PURE__ */ jsxRuntime.jsx(
5873
+ "div",
5874
+ {
5875
+ className: cn(
5876
+ "px-3 py-2 cursor-pointer flex items-center gap-2 text-destructive border-t",
5877
+ "hover:bg-destructive/10",
5878
+ edit_selected_index === edit_commands.length && "bg-destructive/10"
5879
+ ),
5880
+ onClick: handle_command_remove,
5881
+ children: /* @__PURE__ */ jsxRuntime.jsx("span", { children: "Remove" })
5882
+ }
5883
+ )
5884
+ ] })
5885
+ ] })
5886
+ }
5887
+ )
5888
+ ]
5889
+ }
5890
+ );
5891
+ };
5892
+ HazoUiTextarea.displayName = "HazoUiTextarea";
4307
5893
 
5894
+ exports.CommandNodeExtension = CommandNodeExtension;
5895
+ exports.CommandPill = CommandPill;
5896
+ exports.CommandPopover = CommandPopover;
4308
5897
  exports.HazoUiFlexInput = HazoUiFlexInput;
4309
5898
  exports.HazoUiFlexRadio = HazoUiFlexRadio;
4310
5899
  exports.HazoUiMultiFilterDialog = HazoUiMultiFilterDialog;
4311
5900
  exports.HazoUiMultiSortDialog = HazoUiMultiSortDialog;
4312
5901
  exports.HazoUiRte = HazoUiRte;
5902
+ exports.HazoUiTextarea = HazoUiTextarea;
5903
+ exports.HazoUiTextbox = HazoUiTextbox;
5904
+ exports.create_command_suggestion_extension = create_command_suggestion_extension;
5905
+ exports.parse_commands_from_text = parse_commands_from_text;
5906
+ exports.text_to_tiptap_content = text_to_tiptap_content;
4313
5907
  //# sourceMappingURL=index.cjs.map
4314
5908
  //# sourceMappingURL=index.cjs.map