@verbb/plugin-kit-react 1.0.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.
Files changed (593) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/LICENSE.md +21 -0
  3. package/README.md +31 -0
  4. package/dist/_virtual/_rolldown/runtime.js +34 -0
  5. package/dist/components/Button.d.ts +26 -0
  6. package/dist/components/Button.d.ts.map +1 -0
  7. package/dist/components/Button.js +148 -0
  8. package/dist/components/Button.js.map +1 -0
  9. package/dist/components/ButtonGroup.d.ts +11 -0
  10. package/dist/components/ButtonGroup.d.ts.map +1 -0
  11. package/dist/components/ButtonGroup.js +59 -0
  12. package/dist/components/ButtonGroup.js.map +1 -0
  13. package/dist/components/Calendar.d.ts +11 -0
  14. package/dist/components/Calendar.d.ts.map +1 -0
  15. package/dist/components/Calendar.js +133 -0
  16. package/dist/components/Calendar.js.map +1 -0
  17. package/dist/components/Checkbox.d.ts +5 -0
  18. package/dist/components/Checkbox.d.ts.map +1 -0
  19. package/dist/components/Checkbox.js +41 -0
  20. package/dist/components/Checkbox.js.map +1 -0
  21. package/dist/components/CheckboxInput.d.ts +14 -0
  22. package/dist/components/CheckboxInput.d.ts.map +1 -0
  23. package/dist/components/CheckboxInput.js +31 -0
  24. package/dist/components/CheckboxInput.js.map +1 -0
  25. package/dist/components/CheckboxSelect.d.ts +19 -0
  26. package/dist/components/CheckboxSelect.d.ts.map +1 -0
  27. package/dist/components/CheckboxSelect.js +63 -0
  28. package/dist/components/CheckboxSelect.js.map +1 -0
  29. package/dist/components/ColorInput.d.ts +14 -0
  30. package/dist/components/ColorInput.d.ts.map +1 -0
  31. package/dist/components/ColorInput.js +148 -0
  32. package/dist/components/ColorInput.js.map +1 -0
  33. package/dist/components/Combobox.d.ts +40 -0
  34. package/dist/components/Combobox.d.ts.map +1 -0
  35. package/dist/components/Combobox.js +393 -0
  36. package/dist/components/Combobox.js.map +1 -0
  37. package/dist/components/ComboboxInput.d.ts +28 -0
  38. package/dist/components/ComboboxInput.d.ts.map +1 -0
  39. package/dist/components/ComboboxInput.js +165 -0
  40. package/dist/components/ComboboxInput.js.map +1 -0
  41. package/dist/components/Command.d.ts +26 -0
  42. package/dist/components/Command.d.ts.map +1 -0
  43. package/dist/components/Command.js +94 -0
  44. package/dist/components/Command.js.map +1 -0
  45. package/dist/components/CopyButton.d.ts +9 -0
  46. package/dist/components/CopyButton.d.ts.map +1 -0
  47. package/dist/components/CopyButton.js +40 -0
  48. package/dist/components/CopyButton.js.map +1 -0
  49. package/dist/components/DatePicker.d.ts +9 -0
  50. package/dist/components/DatePicker.d.ts.map +1 -0
  51. package/dist/components/DatePicker.js +46 -0
  52. package/dist/components/DatePicker.js.map +1 -0
  53. package/dist/components/Dialog.d.ts +21 -0
  54. package/dist/components/Dialog.d.ts.map +1 -0
  55. package/dist/components/Dialog.js +179 -0
  56. package/dist/components/Dialog.js.map +1 -0
  57. package/dist/components/DropdownMenu.d.ts +47 -0
  58. package/dist/components/DropdownMenu.d.ts.map +1 -0
  59. package/dist/components/DropdownMenu.js +240 -0
  60. package/dist/components/DropdownMenu.js.map +1 -0
  61. package/dist/components/EditableTable.d.ts +28 -0
  62. package/dist/components/EditableTable.d.ts.map +1 -0
  63. package/dist/components/EditableTable.js +145 -0
  64. package/dist/components/EditableTable.js.map +1 -0
  65. package/dist/components/FadeIn.d.ts +12 -0
  66. package/dist/components/FadeIn.d.ts.map +1 -0
  67. package/dist/components/FadeIn.js +24 -0
  68. package/dist/components/FadeIn.js.map +1 -0
  69. package/dist/components/Input.d.ts +9 -0
  70. package/dist/components/Input.d.ts.map +1 -0
  71. package/dist/components/Input.js +43 -0
  72. package/dist/components/Input.js.map +1 -0
  73. package/dist/components/InputGroup.d.ts +20 -0
  74. package/dist/components/InputGroup.d.ts.map +1 -0
  75. package/dist/components/InputGroup.js +111 -0
  76. package/dist/components/InputGroup.js.map +1 -0
  77. package/dist/components/Label.d.ts +4 -0
  78. package/dist/components/Label.d.ts.map +1 -0
  79. package/dist/components/Label.js +15 -0
  80. package/dist/components/Label.js.map +1 -0
  81. package/dist/components/Lightswitch.d.ts +9 -0
  82. package/dist/components/Lightswitch.d.ts.map +1 -0
  83. package/dist/components/Lightswitch.js +56 -0
  84. package/dist/components/Lightswitch.js.map +1 -0
  85. package/dist/components/Markdown.d.ts +11 -0
  86. package/dist/components/Markdown.d.ts.map +1 -0
  87. package/dist/components/Markdown.js +46 -0
  88. package/dist/components/Markdown.js.map +1 -0
  89. package/dist/components/MenuButton.d.ts +40 -0
  90. package/dist/components/MenuButton.d.ts.map +1 -0
  91. package/dist/components/MenuButton.js +122 -0
  92. package/dist/components/MenuButton.js.map +1 -0
  93. package/dist/components/ModalTabs.d.ts +8 -0
  94. package/dist/components/ModalTabs.d.ts.map +1 -0
  95. package/dist/components/ModalTabs.js +37 -0
  96. package/dist/components/ModalTabs.js.map +1 -0
  97. package/dist/components/PaneTabs.d.ts +8 -0
  98. package/dist/components/PaneTabs.d.ts.map +1 -0
  99. package/dist/components/PaneTabs.js +37 -0
  100. package/dist/components/PaneTabs.js.map +1 -0
  101. package/dist/components/Popover.d.ts +12 -0
  102. package/dist/components/Popover.d.ts.map +1 -0
  103. package/dist/components/Popover.js +70 -0
  104. package/dist/components/Popover.js.map +1 -0
  105. package/dist/components/RadioGroup.d.ts +6 -0
  106. package/dist/components/RadioGroup.d.ts.map +1 -0
  107. package/dist/components/RadioGroup.js +34 -0
  108. package/dist/components/RadioGroup.js.map +1 -0
  109. package/dist/components/ScrollArea.d.ts +16 -0
  110. package/dist/components/ScrollArea.d.ts.map +1 -0
  111. package/dist/components/ScrollArea.js +47 -0
  112. package/dist/components/ScrollArea.js.map +1 -0
  113. package/dist/components/Select.d.ts +23 -0
  114. package/dist/components/Select.d.ts.map +1 -0
  115. package/dist/components/Select.js +205 -0
  116. package/dist/components/Select.js.map +1 -0
  117. package/dist/components/SelectInput.d.ts +33 -0
  118. package/dist/components/SelectInput.d.ts.map +1 -0
  119. package/dist/components/SelectInput.js +85 -0
  120. package/dist/components/SelectInput.js.map +1 -0
  121. package/dist/components/Separator.d.ts +4 -0
  122. package/dist/components/Separator.d.ts.map +1 -0
  123. package/dist/components/Separator.js +17 -0
  124. package/dist/components/Separator.js.map +1 -0
  125. package/dist/components/SlideUp.d.ts +12 -0
  126. package/dist/components/SlideUp.d.ts.map +1 -0
  127. package/dist/components/SlideUp.js +36 -0
  128. package/dist/components/SlideUp.js.map +1 -0
  129. package/dist/components/Slot.d.ts +6 -0
  130. package/dist/components/Slot.d.ts.map +1 -0
  131. package/dist/components/Slot.js +52 -0
  132. package/dist/components/Slot.js.map +1 -0
  133. package/dist/components/Spinner.d.ts +9 -0
  134. package/dist/components/Spinner.d.ts.map +1 -0
  135. package/dist/components/Spinner.js +43 -0
  136. package/dist/components/Spinner.js.map +1 -0
  137. package/dist/components/Status.d.ts +8 -0
  138. package/dist/components/Status.d.ts.map +1 -0
  139. package/dist/components/Status.js +55 -0
  140. package/dist/components/Status.js.map +1 -0
  141. package/dist/components/Table.d.ts +10 -0
  142. package/dist/components/Table.d.ts.map +1 -0
  143. package/dist/components/Table.js +64 -0
  144. package/dist/components/Table.js.map +1 -0
  145. package/dist/components/Tabs.d.ts +8 -0
  146. package/dist/components/Tabs.d.ts.map +1 -0
  147. package/dist/components/Tabs.js +37 -0
  148. package/dist/components/Tabs.js.map +1 -0
  149. package/dist/components/Textarea.d.ts +8 -0
  150. package/dist/components/Textarea.d.ts.map +1 -0
  151. package/dist/components/Textarea.js +26 -0
  152. package/dist/components/Textarea.js.map +1 -0
  153. package/dist/components/TimePicker.d.ts +9 -0
  154. package/dist/components/TimePicker.d.ts.map +1 -0
  155. package/dist/components/TimePicker.js +40 -0
  156. package/dist/components/TimePicker.js.map +1 -0
  157. package/dist/components/TiptapContent.d.ts +9 -0
  158. package/dist/components/TiptapContent.d.ts.map +1 -0
  159. package/dist/components/TiptapContent.js +24 -0
  160. package/dist/components/TiptapContent.js.map +1 -0
  161. package/dist/components/TiptapEditor.d.ts +41 -0
  162. package/dist/components/TiptapEditor.d.ts.map +1 -0
  163. package/dist/components/TiptapEditor.js +555 -0
  164. package/dist/components/TiptapEditor.js.map +1 -0
  165. package/dist/components/TiptapInput.d.ts +15 -0
  166. package/dist/components/TiptapInput.d.ts.map +1 -0
  167. package/dist/components/TiptapInput.js +138 -0
  168. package/dist/components/TiptapInput.js.map +1 -0
  169. package/dist/components/Toggle.d.ts +9 -0
  170. package/dist/components/Toggle.d.ts.map +1 -0
  171. package/dist/components/Toggle.js +48 -0
  172. package/dist/components/Toggle.js.map +1 -0
  173. package/dist/components/ToggleGroup.d.ts +11 -0
  174. package/dist/components/ToggleGroup.d.ts.map +1 -0
  175. package/dist/components/ToggleGroup.js +70 -0
  176. package/dist/components/ToggleGroup.js.map +1 -0
  177. package/dist/components/Tooltip.d.ts +9 -0
  178. package/dist/components/Tooltip.d.ts.map +1 -0
  179. package/dist/components/Tooltip.js +51 -0
  180. package/dist/components/Tooltip.js.map +1 -0
  181. package/dist/components/VirtualizedScrollArea.d.ts +25 -0
  182. package/dist/components/VirtualizedScrollArea.d.ts.map +1 -0
  183. package/dist/components/VirtualizedScrollArea.js +80 -0
  184. package/dist/components/VirtualizedScrollArea.js.map +1 -0
  185. package/dist/components/editable-table/RowDataCells.d.ts +3 -0
  186. package/dist/components/editable-table/RowDataCells.d.ts.map +1 -0
  187. package/dist/components/editable-table/RowDataCells.js +33 -0
  188. package/dist/components/editable-table/RowDataCells.js.map +1 -0
  189. package/dist/components/editable-table/TableCell.d.ts +13 -0
  190. package/dist/components/editable-table/TableCell.d.ts.map +1 -0
  191. package/dist/components/editable-table/TableCell.js +415 -0
  192. package/dist/components/editable-table/TableCell.js.map +1 -0
  193. package/dist/components/editable-table/TableRow.d.ts +3 -0
  194. package/dist/components/editable-table/TableRow.d.ts.map +1 -0
  195. package/dist/components/editable-table/TableRow.js +163 -0
  196. package/dist/components/editable-table/TableRow.js.map +1 -0
  197. package/dist/components/editable-table/helpers.d.ts +12 -0
  198. package/dist/components/editable-table/helpers.d.ts.map +1 -0
  199. package/dist/components/editable-table/helpers.js +23 -0
  200. package/dist/components/editable-table/helpers.js.map +1 -0
  201. package/dist/components/editable-table/index.d.ts +4 -0
  202. package/dist/components/editable-table/index.d.ts.map +1 -0
  203. package/dist/components/editable-table/index.js +4 -0
  204. package/dist/components/editable-table/types.d.ts +43 -0
  205. package/dist/components/editable-table/types.d.ts.map +1 -0
  206. package/dist/components/editable-table/types.js +0 -0
  207. package/dist/components/editable-table/useEditableTableCellChange.d.ts +17 -0
  208. package/dist/components/editable-table/useEditableTableCellChange.d.ts.map +1 -0
  209. package/dist/components/editable-table/useEditableTableCellChange.js +152 -0
  210. package/dist/components/editable-table/useEditableTableCellChange.js.map +1 -0
  211. package/dist/components/editable-table/useEditableTableDnd.d.ts +18 -0
  212. package/dist/components/editable-table/useEditableTableDnd.d.ts.map +1 -0
  213. package/dist/components/editable-table/useEditableTableDnd.js +55 -0
  214. package/dist/components/editable-table/useEditableTableDnd.js.map +1 -0
  215. package/dist/components/editable-table/useEditableTableRows.d.ts +17 -0
  216. package/dist/components/editable-table/useEditableTableRows.d.ts.map +1 -0
  217. package/dist/components/editable-table/useEditableTableRows.js +108 -0
  218. package/dist/components/editable-table/useEditableTableRows.js.map +1 -0
  219. package/dist/components/index.d.ts +45 -0
  220. package/dist/components/index.d.ts.map +1 -0
  221. package/dist/components/index.js +45 -0
  222. package/dist/components/tiptap/InlineVariablePickerPopover.d.ts +24 -0
  223. package/dist/components/tiptap/InlineVariablePickerPopover.d.ts.map +1 -0
  224. package/dist/components/tiptap/InlineVariablePickerPopover.js +63 -0
  225. package/dist/components/tiptap/InlineVariablePickerPopover.js.map +1 -0
  226. package/dist/components/tiptap/InsertLinkDialog.d.ts +14 -0
  227. package/dist/components/tiptap/InsertLinkDialog.d.ts.map +1 -0
  228. package/dist/components/tiptap/InsertLinkDialog.js +145 -0
  229. package/dist/components/tiptap/InsertLinkDialog.js.map +1 -0
  230. package/dist/components/tiptap/LinkBubbleMenu.d.ts +10 -0
  231. package/dist/components/tiptap/LinkBubbleMenu.d.ts.map +1 -0
  232. package/dist/components/tiptap/LinkBubbleMenu.js +106 -0
  233. package/dist/components/tiptap/LinkBubbleMenu.js.map +1 -0
  234. package/dist/components/tiptap/LinkDropdown.d.ts +53 -0
  235. package/dist/components/tiptap/LinkDropdown.d.ts.map +1 -0
  236. package/dist/components/tiptap/LinkDropdown.js +155 -0
  237. package/dist/components/tiptap/LinkDropdown.js.map +1 -0
  238. package/dist/components/tiptap/VariableCommandList.d.ts +37 -0
  239. package/dist/components/tiptap/VariableCommandList.d.ts.map +1 -0
  240. package/dist/components/tiptap/VariableCommandList.js +166 -0
  241. package/dist/components/tiptap/VariableCommandList.js.map +1 -0
  242. package/dist/components/tiptap/VariableDropdown.d.ts +33 -0
  243. package/dist/components/tiptap/VariableDropdown.d.ts.map +1 -0
  244. package/dist/components/tiptap/VariableDropdown.js +121 -0
  245. package/dist/components/tiptap/VariableDropdown.js.map +1 -0
  246. package/dist/components/tiptap/VariablePickerContext.d.ts +38 -0
  247. package/dist/components/tiptap/VariablePickerContext.d.ts.map +1 -0
  248. package/dist/components/tiptap/VariablePickerContext.js +30 -0
  249. package/dist/components/tiptap/VariablePickerContext.js.map +1 -0
  250. package/dist/components/tiptap/VariableTag.d.ts +6 -0
  251. package/dist/components/tiptap/VariableTag.d.ts.map +1 -0
  252. package/dist/components/tiptap/VariableTag.js +153 -0
  253. package/dist/components/tiptap/VariableTag.js.map +1 -0
  254. package/dist/components/tiptap/VariableTagView.d.ts +3 -0
  255. package/dist/components/tiptap/VariableTagView.d.ts.map +1 -0
  256. package/dist/components/tiptap/VariableTagView.js +445 -0
  257. package/dist/components/tiptap/VariableTagView.js.map +1 -0
  258. package/dist/components/tiptap/VariableTransformControls.d.ts +37 -0
  259. package/dist/components/tiptap/VariableTransformControls.d.ts.map +1 -0
  260. package/dist/components/tiptap/VariableTransformControls.js +157 -0
  261. package/dist/components/tiptap/VariableTransformControls.js.map +1 -0
  262. package/dist/components/tiptap/editorConfig.d.ts +15 -0
  263. package/dist/components/tiptap/editorConfig.d.ts.map +1 -0
  264. package/dist/components/tiptap/editorConfig.js +191 -0
  265. package/dist/components/tiptap/editorConfig.js.map +1 -0
  266. package/dist/components/tiptap/useInlineVariablePicker.d.ts +34 -0
  267. package/dist/components/tiptap/useInlineVariablePicker.d.ts.map +1 -0
  268. package/dist/components/tiptap/useInlineVariablePicker.js +240 -0
  269. package/dist/components/tiptap/useInlineVariablePicker.js.map +1 -0
  270. package/dist/components/tiptap/useVariablePicker.d.ts +28 -0
  271. package/dist/components/tiptap/useVariablePicker.d.ts.map +1 -0
  272. package/dist/components/tiptap/useVariablePicker.js +122 -0
  273. package/dist/components/tiptap/useVariablePicker.js.map +1 -0
  274. package/dist/components/tiptap/variablePickerUtils.d.ts +11 -0
  275. package/dist/components/tiptap/variablePickerUtils.d.ts.map +1 -0
  276. package/dist/components/tiptap/variablePickerUtils.js +63 -0
  277. package/dist/components/tiptap/variablePickerUtils.js.map +1 -0
  278. package/dist/components/tiptap/variableSerialization.d.ts +49 -0
  279. package/dist/components/tiptap/variableSerialization.d.ts.map +1 -0
  280. package/dist/components/tiptap/variableSerialization.js +250 -0
  281. package/dist/components/tiptap/variableSerialization.js.map +1 -0
  282. package/dist/css/core.css +288 -0
  283. package/dist/css/style.css +295 -0
  284. package/dist/forms/Field.d.ts +37 -0
  285. package/dist/forms/Field.d.ts.map +1 -0
  286. package/dist/forms/Field.js +159 -0
  287. package/dist/forms/Field.js.map +1 -0
  288. package/dist/forms/SchemaFormEngine.d.ts +23 -0
  289. package/dist/forms/SchemaFormEngine.d.ts.map +1 -0
  290. package/dist/forms/SchemaFormEngine.js +444 -0
  291. package/dist/forms/SchemaFormEngine.js.map +1 -0
  292. package/dist/forms/components/FieldWrap.d.ts +11 -0
  293. package/dist/forms/components/FieldWrap.d.ts.map +1 -0
  294. package/dist/forms/components/FieldWrap.js +84 -0
  295. package/dist/forms/components/FieldWrap.js.map +1 -0
  296. package/dist/forms/components/ModalTabs.d.ts +21 -0
  297. package/dist/forms/components/ModalTabs.d.ts.map +1 -0
  298. package/dist/forms/components/ModalTabs.js +84 -0
  299. package/dist/forms/components/ModalTabs.js.map +1 -0
  300. package/dist/forms/components/index.d.ts +3 -0
  301. package/dist/forms/components/index.d.ts.map +1 -0
  302. package/dist/forms/components/index.js +3 -0
  303. package/dist/forms/contexts/VariableCategoriesContext.d.ts +17 -0
  304. package/dist/forms/contexts/VariableCategoriesContext.d.ts.map +1 -0
  305. package/dist/forms/contexts/VariableCategoriesContext.js +18 -0
  306. package/dist/forms/contexts/VariableCategoriesContext.js.map +1 -0
  307. package/dist/forms/engine/FormStateStore.d.ts +24 -0
  308. package/dist/forms/engine/FormStateStore.d.ts.map +1 -0
  309. package/dist/forms/engine/FormStateStore.js +97 -0
  310. package/dist/forms/engine/FormStateStore.js.map +1 -0
  311. package/dist/forms/engine/SchemaIndex.d.ts +33 -0
  312. package/dist/forms/engine/SchemaIndex.d.ts.map +1 -0
  313. package/dist/forms/engine/SchemaIndex.js +21 -0
  314. package/dist/forms/engine/SchemaIndex.js.map +1 -0
  315. package/dist/forms/engine/ValidationEngine.d.ts +13 -0
  316. package/dist/forms/engine/ValidationEngine.d.ts.map +1 -0
  317. package/dist/forms/engine/ValidationEngine.js +155 -0
  318. package/dist/forms/engine/ValidationEngine.js.map +1 -0
  319. package/dist/forms/engine/buildGroupedMessage.d.ts +2 -0
  320. package/dist/forms/engine/buildGroupedMessage.d.ts.map +1 -0
  321. package/dist/forms/engine/buildGroupedMessage.js +20 -0
  322. package/dist/forms/engine/buildGroupedMessage.js.map +1 -0
  323. package/dist/forms/engine/context.d.ts +60 -0
  324. package/dist/forms/engine/context.d.ts.map +1 -0
  325. package/dist/forms/engine/context.js +12 -0
  326. package/dist/forms/engine/context.js.map +1 -0
  327. package/dist/forms/engine/rules/email.d.ts +2 -0
  328. package/dist/forms/engine/rules/email.d.ts.map +1 -0
  329. package/dist/forms/engine/rules/email.js +11 -0
  330. package/dist/forms/engine/rules/email.js.map +1 -0
  331. package/dist/forms/engine/rules/emailOrVariable.d.ts +2 -0
  332. package/dist/forms/engine/rules/emailOrVariable.d.ts.map +1 -0
  333. package/dist/forms/engine/rules/emailOrVariable.js +13 -0
  334. package/dist/forms/engine/rules/emailOrVariable.js.map +1 -0
  335. package/dist/forms/engine/rules/handle.d.ts +2 -0
  336. package/dist/forms/engine/rules/handle.d.ts.map +1 -0
  337. package/dist/forms/engine/rules/handle.js +12 -0
  338. package/dist/forms/engine/rules/handle.js.map +1 -0
  339. package/dist/forms/engine/rules/index.d.ts +9 -0
  340. package/dist/forms/engine/rules/index.d.ts.map +1 -0
  341. package/dist/forms/engine/rules/index.js +35 -0
  342. package/dist/forms/engine/rules/index.js.map +1 -0
  343. package/dist/forms/engine/rules/max.d.ts +2 -0
  344. package/dist/forms/engine/rules/max.d.ts.map +1 -0
  345. package/dist/forms/engine/rules/max.js +16 -0
  346. package/dist/forms/engine/rules/max.js.map +1 -0
  347. package/dist/forms/engine/rules/min.d.ts +2 -0
  348. package/dist/forms/engine/rules/min.d.ts.map +1 -0
  349. package/dist/forms/engine/rules/min.js +16 -0
  350. package/dist/forms/engine/rules/min.js.map +1 -0
  351. package/dist/forms/engine/rules/required.d.ts +2 -0
  352. package/dist/forms/engine/rules/required.d.ts.map +1 -0
  353. package/dist/forms/engine/rules/required.js +11 -0
  354. package/dist/forms/engine/rules/required.js.map +1 -0
  355. package/dist/forms/engine/rules/uniqueHandle.d.ts +9 -0
  356. package/dist/forms/engine/rules/uniqueHandle.d.ts.map +1 -0
  357. package/dist/forms/engine/rules/uniqueHandle.js +95 -0
  358. package/dist/forms/engine/rules/uniqueHandle.js.map +1 -0
  359. package/dist/forms/engine/rules/utils.d.ts +3 -0
  360. package/dist/forms/engine/rules/utils.d.ts.map +1 -0
  361. package/dist/forms/engine/rules/utils.js +21 -0
  362. package/dist/forms/engine/rules/utils.js.map +1 -0
  363. package/dist/forms/fields/CalculationsField.d.ts +24 -0
  364. package/dist/forms/fields/CalculationsField.d.ts.map +1 -0
  365. package/dist/forms/fields/CalculationsField.js +215 -0
  366. package/dist/forms/fields/CalculationsField.js.map +1 -0
  367. package/dist/forms/fields/CalculationsToolbar.d.ts +17 -0
  368. package/dist/forms/fields/CalculationsToolbar.d.ts.map +1 -0
  369. package/dist/forms/fields/CalculationsToolbar.js +130 -0
  370. package/dist/forms/fields/CalculationsToolbar.js.map +1 -0
  371. package/dist/forms/fields/CheckboxSelectField.d.ts +19 -0
  372. package/dist/forms/fields/CheckboxSelectField.d.ts.map +1 -0
  373. package/dist/forms/fields/CheckboxSelectField.js +30 -0
  374. package/dist/forms/fields/CheckboxSelectField.js.map +1 -0
  375. package/dist/forms/fields/ColorField.d.ts +15 -0
  376. package/dist/forms/fields/ColorField.d.ts.map +1 -0
  377. package/dist/forms/fields/ColorField.js +30 -0
  378. package/dist/forms/fields/ColorField.js.map +1 -0
  379. package/dist/forms/fields/ComboboxField.d.ts +23 -0
  380. package/dist/forms/fields/ComboboxField.d.ts.map +1 -0
  381. package/dist/forms/fields/ComboboxField.js +38 -0
  382. package/dist/forms/fields/ComboboxField.js.map +1 -0
  383. package/dist/forms/fields/DateTimeField.d.ts +14 -0
  384. package/dist/forms/fields/DateTimeField.d.ts.map +1 -0
  385. package/dist/forms/fields/DateTimeField.js +53 -0
  386. package/dist/forms/fields/DateTimeField.js.map +1 -0
  387. package/dist/forms/fields/EditableTableField.d.ts +22 -0
  388. package/dist/forms/fields/EditableTableField.d.ts.map +1 -0
  389. package/dist/forms/fields/EditableTableField.js +37 -0
  390. package/dist/forms/fields/EditableTableField.js.map +1 -0
  391. package/dist/forms/fields/ElementSelectField.d.ts +20 -0
  392. package/dist/forms/fields/ElementSelectField.d.ts.map +1 -0
  393. package/dist/forms/fields/ElementSelectField.js +215 -0
  394. package/dist/forms/fields/ElementSelectField.js.map +1 -0
  395. package/dist/forms/fields/GroupField.d.ts +19 -0
  396. package/dist/forms/fields/GroupField.d.ts.map +1 -0
  397. package/dist/forms/fields/GroupField.js +50 -0
  398. package/dist/forms/fields/GroupField.js.map +1 -0
  399. package/dist/forms/fields/HandleField.d.ts +20 -0
  400. package/dist/forms/fields/HandleField.d.ts.map +1 -0
  401. package/dist/forms/fields/HandleField.js +70 -0
  402. package/dist/forms/fields/HandleField.js.map +1 -0
  403. package/dist/forms/fields/LightswitchField.d.ts +14 -0
  404. package/dist/forms/fields/LightswitchField.d.ts.map +1 -0
  405. package/dist/forms/fields/LightswitchField.js +29 -0
  406. package/dist/forms/fields/LightswitchField.js.map +1 -0
  407. package/dist/forms/fields/ListField.d.ts +17 -0
  408. package/dist/forms/fields/ListField.d.ts.map +1 -0
  409. package/dist/forms/fields/ListField.js +51 -0
  410. package/dist/forms/fields/ListField.js.map +1 -0
  411. package/dist/forms/fields/NumberField.d.ts +17 -0
  412. package/dist/forms/fields/NumberField.d.ts.map +1 -0
  413. package/dist/forms/fields/NumberField.js +33 -0
  414. package/dist/forms/fields/NumberField.js.map +1 -0
  415. package/dist/forms/fields/RadioGroupField.d.ts +25 -0
  416. package/dist/forms/fields/RadioGroupField.d.ts.map +1 -0
  417. package/dist/forms/fields/RadioGroupField.js +102 -0
  418. package/dist/forms/fields/RadioGroupField.js.map +1 -0
  419. package/dist/forms/fields/RichTextField.d.ts +23 -0
  420. package/dist/forms/fields/RichTextField.d.ts.map +1 -0
  421. package/dist/forms/fields/RichTextField.js +50 -0
  422. package/dist/forms/fields/RichTextField.js.map +1 -0
  423. package/dist/forms/fields/SelectField.d.ts +25 -0
  424. package/dist/forms/fields/SelectField.d.ts.map +1 -0
  425. package/dist/forms/fields/SelectField.js +73 -0
  426. package/dist/forms/fields/SelectField.js.map +1 -0
  427. package/dist/forms/fields/StaticTableField.d.ts +34 -0
  428. package/dist/forms/fields/StaticTableField.d.ts.map +1 -0
  429. package/dist/forms/fields/StaticTableField.js +128 -0
  430. package/dist/forms/fields/StaticTableField.js.map +1 -0
  431. package/dist/forms/fields/TextField.d.ts +16 -0
  432. package/dist/forms/fields/TextField.d.ts.map +1 -0
  433. package/dist/forms/fields/TextField.js +31 -0
  434. package/dist/forms/fields/TextField.js.map +1 -0
  435. package/dist/forms/fields/TextareaField.d.ts +17 -0
  436. package/dist/forms/fields/TextareaField.d.ts.map +1 -0
  437. package/dist/forms/fields/TextareaField.js +32 -0
  438. package/dist/forms/fields/TextareaField.js.map +1 -0
  439. package/dist/forms/fields/VariablePickerField.d.ts +21 -0
  440. package/dist/forms/fields/VariablePickerField.d.ts.map +1 -0
  441. package/dist/forms/fields/VariablePickerField.js +49 -0
  442. package/dist/forms/fields/VariablePickerField.js.map +1 -0
  443. package/dist/forms/index.d.ts +8 -0
  444. package/dist/forms/index.d.ts.map +1 -0
  445. package/dist/forms/index.js +10 -0
  446. package/dist/forms/registry.d.ts +8 -0
  447. package/dist/forms/registry.d.ts.map +1 -0
  448. package/dist/forms/registry.js +76 -0
  449. package/dist/forms/registry.js.map +1 -0
  450. package/dist/forms/store/element-store.d.ts +11 -0
  451. package/dist/forms/store/element-store.d.ts.map +1 -0
  452. package/dist/forms/store/element-store.js +41 -0
  453. package/dist/forms/store/element-store.js.map +1 -0
  454. package/dist/forms/useEditableTableFieldBinding.d.ts +13 -0
  455. package/dist/forms/useEditableTableFieldBinding.d.ts.map +1 -0
  456. package/dist/forms/useEditableTableFieldBinding.js +91 -0
  457. package/dist/forms/useEditableTableFieldBinding.js.map +1 -0
  458. package/dist/forms/useEngineField.d.ts +9 -0
  459. package/dist/forms/useEngineField.d.ts.map +1 -0
  460. package/dist/forms/useEngineField.js +32 -0
  461. package/dist/forms/useEngineField.js.map +1 -0
  462. package/dist/hooks/index.d.ts +3 -0
  463. package/dist/hooks/index.d.ts.map +1 -0
  464. package/dist/hooks/index.js +3 -0
  465. package/dist/hooks/useKeyboardShortcuts.d.ts +14 -0
  466. package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -0
  467. package/dist/hooks/useKeyboardShortcuts.js +67 -0
  468. package/dist/hooks/useKeyboardShortcuts.js.map +1 -0
  469. package/dist/hooks/useTranslation.d.ts +3 -0
  470. package/dist/hooks/useTranslation.d.ts.map +1 -0
  471. package/dist/hooks/useTranslation.js +12 -0
  472. package/dist/hooks/useTranslation.js.map +1 -0
  473. package/dist/index.d.ts +2 -0
  474. package/dist/index.d.ts.map +1 -0
  475. package/dist/index.js +2 -0
  476. package/dist/node_modules/@babel/runtime/helpers/arrayLikeToArray.js +15 -0
  477. package/dist/node_modules/@babel/runtime/helpers/arrayLikeToArray.js.map +1 -0
  478. package/dist/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js +15 -0
  479. package/dist/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js.map +1 -0
  480. package/dist/node_modules/@babel/runtime/helpers/classCallCheck.js +13 -0
  481. package/dist/node_modules/@babel/runtime/helpers/classCallCheck.js.map +1 -0
  482. package/dist/node_modules/@babel/runtime/helpers/createClass.js +21 -0
  483. package/dist/node_modules/@babel/runtime/helpers/createClass.js.map +1 -0
  484. package/dist/node_modules/@babel/runtime/helpers/defineProperty.js +20 -0
  485. package/dist/node_modules/@babel/runtime/helpers/defineProperty.js.map +1 -0
  486. package/dist/node_modules/@babel/runtime/helpers/interopRequireDefault.js +13 -0
  487. package/dist/node_modules/@babel/runtime/helpers/interopRequireDefault.js.map +1 -0
  488. package/dist/node_modules/@babel/runtime/helpers/iterableToArray.js +13 -0
  489. package/dist/node_modules/@babel/runtime/helpers/iterableToArray.js.map +1 -0
  490. package/dist/node_modules/@babel/runtime/helpers/nonIterableSpread.js +13 -0
  491. package/dist/node_modules/@babel/runtime/helpers/nonIterableSpread.js.map +1 -0
  492. package/dist/node_modules/@babel/runtime/helpers/toConsumableArray.js +21 -0
  493. package/dist/node_modules/@babel/runtime/helpers/toConsumableArray.js.map +1 -0
  494. package/dist/node_modules/@babel/runtime/helpers/toPrimitive.js +22 -0
  495. package/dist/node_modules/@babel/runtime/helpers/toPrimitive.js.map +1 -0
  496. package/dist/node_modules/@babel/runtime/helpers/toPropertyKey.js +18 -0
  497. package/dist/node_modules/@babel/runtime/helpers/toPropertyKey.js.map +1 -0
  498. package/dist/node_modules/@babel/runtime/helpers/typeof.js +18 -0
  499. package/dist/node_modules/@babel/runtime/helpers/typeof.js.map +1 -0
  500. package/dist/node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js +19 -0
  501. package/dist/node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js.map +1 -0
  502. package/dist/node_modules/jexl/dist/Expression.js +84 -0
  503. package/dist/node_modules/jexl/dist/Expression.js.map +1 -0
  504. package/dist/node_modules/jexl/dist/Jexl.js +165 -0
  505. package/dist/node_modules/jexl/dist/Jexl.js.map +1 -0
  506. package/dist/node_modules/jexl/dist/Lexer.js +152 -0
  507. package/dist/node_modules/jexl/dist/Lexer.js.map +1 -0
  508. package/dist/node_modules/jexl/dist/PromiseSync.js +87 -0
  509. package/dist/node_modules/jexl/dist/PromiseSync.js.map +1 -0
  510. package/dist/node_modules/jexl/dist/evaluator/Evaluator.js +98 -0
  511. package/dist/node_modules/jexl/dist/evaluator/Evaluator.js.map +1 -0
  512. package/dist/node_modules/jexl/dist/evaluator/handlers.js +162 -0
  513. package/dist/node_modules/jexl/dist/evaluator/handlers.js.map +1 -0
  514. package/dist/node_modules/jexl/dist/grammar.js +195 -0
  515. package/dist/node_modules/jexl/dist/grammar.js.map +1 -0
  516. package/dist/node_modules/jexl/dist/parser/Parser.js +135 -0
  517. package/dist/node_modules/jexl/dist/parser/Parser.js.map +1 -0
  518. package/dist/node_modules/jexl/dist/parser/handlers.js +205 -0
  519. package/dist/node_modules/jexl/dist/parser/handlers.js.map +1 -0
  520. package/dist/node_modules/jexl/dist/parser/states.js +158 -0
  521. package/dist/node_modules/jexl/dist/parser/states.js.map +1 -0
  522. package/dist/types/global.d.d.ts +1 -0
  523. package/dist/types/global.d.js +0 -0
  524. package/dist/utils/classes.d.ts +18 -0
  525. package/dist/utils/classes.d.ts.map +1 -0
  526. package/dist/utils/classes.js +25 -0
  527. package/dist/utils/classes.js.map +1 -0
  528. package/dist/utils/config.d.ts +14 -0
  529. package/dist/utils/config.d.ts.map +1 -0
  530. package/dist/utils/config.js +16 -0
  531. package/dist/utils/config.js.map +1 -0
  532. package/dist/utils/craftHostBridge.d.ts +16 -0
  533. package/dist/utils/craftHostBridge.d.ts.map +1 -0
  534. package/dist/utils/craftHostBridge.js +28 -0
  535. package/dist/utils/craftHostBridge.js.map +1 -0
  536. package/dist/utils/handle.d.ts +10 -0
  537. package/dist/utils/handle.d.ts.map +1 -0
  538. package/dist/utils/handle.js +51 -0
  539. package/dist/utils/handle.js.map +1 -0
  540. package/dist/utils/hostBridge.d.ts +40 -0
  541. package/dist/utils/hostBridge.d.ts.map +1 -0
  542. package/dist/utils/hostBridge.js +35 -0
  543. package/dist/utils/hostBridge.js.map +1 -0
  544. package/dist/utils/index.d.ts +18 -0
  545. package/dist/utils/index.d.ts.map +1 -0
  546. package/dist/utils/index.js +66 -0
  547. package/dist/utils/index.js.map +1 -0
  548. package/dist/utils/portal.d.ts +17 -0
  549. package/dist/utils/portal.d.ts.map +1 -0
  550. package/dist/utils/portal.js +51 -0
  551. package/dist/utils/portal.js.map +1 -0
  552. package/dist/utils/schema.d.ts +17 -0
  553. package/dist/utils/schema.d.ts.map +1 -0
  554. package/dist/utils/schema.js +56 -0
  555. package/dist/utils/schema.js.map +1 -0
  556. package/dist/utils/schemaFieldNames.d.ts +2 -0
  557. package/dist/utils/schemaFieldNames.d.ts.map +1 -0
  558. package/dist/utils/schemaFieldNames.js +16 -0
  559. package/dist/utils/schemaFieldNames.js.map +1 -0
  560. package/dist/utils/schemaIndex.d.ts +6 -0
  561. package/dist/utils/schemaIndex.d.ts.map +1 -0
  562. package/dist/utils/schemaIndex.js +31 -0
  563. package/dist/utils/schemaIndex.js.map +1 -0
  564. package/dist/utils/schemaIndexCache.d.ts +6 -0
  565. package/dist/utils/schemaIndexCache.d.ts.map +1 -0
  566. package/dist/utils/schemaIndexCache.js +32 -0
  567. package/dist/utils/schemaIndexCache.js.map +1 -0
  568. package/dist/utils/schemaNormalize.d.ts +13 -0
  569. package/dist/utils/schemaNormalize.d.ts.map +1 -0
  570. package/dist/utils/schemaNormalize.js +17 -0
  571. package/dist/utils/schemaNormalize.js.map +1 -0
  572. package/dist/utils/store.d.ts +7 -0
  573. package/dist/utils/store.d.ts.map +1 -0
  574. package/dist/utils/store.js +6 -0
  575. package/dist/utils/store.js.map +1 -0
  576. package/dist/utils/timeOptions.d.ts +6 -0
  577. package/dist/utils/timeOptions.d.ts.map +1 -0
  578. package/dist/utils/timeOptions.js +42 -0
  579. package/dist/utils/timeOptions.js.map +1 -0
  580. package/dist/utils/tiptap.d.ts +13 -0
  581. package/dist/utils/tiptap.d.ts.map +1 -0
  582. package/dist/utils/tiptap.js +39 -0
  583. package/dist/utils/tiptap.js.map +1 -0
  584. package/dist/utils/translation.d.ts +5 -0
  585. package/dist/utils/translation.d.ts.map +1 -0
  586. package/dist/utils/translation.js +21 -0
  587. package/dist/utils/translation.js.map +1 -0
  588. package/dist/utils/validation.d.ts +4 -0
  589. package/dist/utils/validation.d.ts.map +1 -0
  590. package/dist/utils/validation.js +253 -0
  591. package/dist/utils/validation.js.map +1 -0
  592. package/package.json +167 -0
  593. package/vite-dev.mjs +56 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableRow.js","names":[],"sources":["../../../src/components/editable-table/TableRow.jsx"],"sourcesContent":["import React from 'react';\nimport { useSortable } from '@dnd-kit/react/sortable';\nimport { RestrictToVerticalAxis } from '@dnd-kit/abstract/modifiers';\nimport { RestrictToElement } from '@dnd-kit/dom/modifiers';\nimport {\n Button,\n DropdownMenu,\n DropdownMenuTrigger,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuSeparator,\n TableRow as UITableRow,\n TableCell,\n} from '@verbb/plugin-kit-react/components';\nimport { cn } from '@verbb/plugin-kit-react/utils';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport {\n faXmark, faArrowUp, faArrowDown, faEllipsis,\n} from '@fortawesome/pro-solid-svg-icons';\nimport { RowDataCells } from './RowDataCells';\n\nconst SortableRow = ({\n row, rowIndex, allowReorder, className, children,\n}) => {\n const sortable = useSortable({\n id: row._id,\n index: rowIndex,\n disabled: !allowReorder,\n modifiers: [\n RestrictToVerticalAxis,\n RestrictToElement.configure({\n element: (operation) => {\n const sourceElement = operation?.source?.element;\n return sourceElement?.parentElement ?? null;\n },\n }),\n ],\n });\n\n return (\n <UITableRow\n ref={sortable.ref}\n className={cn(\n sortable.isDragging && 'shadow-lg',\n className,\n )}\n >\n {children({ handleRef: sortable.handleRef })}\n </UITableRow>\n );\n};\n\nconst PlainRow = ({ className, children }) => {\n return (\n <UITableRow className={className}>\n {typeof children === 'function' ? children({ handleRef: undefined }) : children}\n </UITableRow>\n );\n};\n\nexport const TableRow = React.memo(({\n row,\n rowIndex,\n rowCount,\n columns,\n columnsSignature,\n useDnd,\n allowReorder,\n showReorderControls,\n allowDelete,\n modifyColumn,\n getCellErrors,\n onUpdateCell,\n moveRow,\n removeRow,\n t,\n renderRowActions,\n renderRowMenuItemsBeforeCore,\n renderRowMenuItemsAfterCore,\n renderRowMenuItems,\n}) => {\n const RowComponent = useDnd ? SortableRow : PlainRow;\n\n return (\n <RowComponent\n row={row}\n rowIndex={rowIndex}\n allowReorder={allowReorder}\n className=\"bg-white\"\n >\n {({ handleRef }) => {\n const dragHandleRef = useDnd ? handleRef : undefined;\n const legacyBeforeRowMenuItems = renderRowMenuItems?.({\n row,\n rowIndex,\n rowCount,\n });\n const customRowMenuItemsBeforeCore = renderRowMenuItemsBeforeCore?.({\n row,\n rowIndex,\n rowCount,\n }) ?? legacyBeforeRowMenuItems;\n const customRowMenuItemsAfterCore = renderRowMenuItemsAfterCore?.({\n row,\n rowIndex,\n rowCount,\n });\n const hasCustomRowMenuItemsBeforeCore = Boolean(customRowMenuItemsBeforeCore);\n const hasCustomRowMenuItemsAfterCore = Boolean(customRowMenuItemsAfterCore);\n const hasMoveActions = showReorderControls && rowCount > 1;\n const hasMenuActions = hasMoveActions || hasCustomRowMenuItemsBeforeCore || hasCustomRowMenuItemsAfterCore;\n\n return (\n <>\n <RowDataCells\n row={row}\n rowIndex={rowIndex}\n columns={columns}\n columnsSignature={columnsSignature}\n modifyColumn={modifyColumn}\n getCellErrors={getCellErrors}\n onUpdateCell={onUpdateCell}\n />\n {(showReorderControls || allowDelete) && (\n <TableCell className={cn(\n 'bg-[#fbfcfe]',\n )}>\n <div className=\"flex items-center px-1\">\n {showReorderControls && (\n <span ref={dragHandleRef}>\n <Button\n type=\"button\"\n variant=\"none\"\n size=\"xs\"\n disabled={!useDnd}\n className={cn(\n 'cursor-move',\n 'p-0 w-[24px] h-[24px]',\n 'text-gray-500',\n 'hover:bg-transparent',\n 'active:bg-transparent',\n 'hover:text-blue-500',\n !useDnd && 'opacity-40 cursor-default',\n )}\n >\n <div className=\"size-3\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 448 512\" focusable=\"false\" aria-hidden=\"true\"><path fill=\"currentColor\" d=\"M71.3 295.6c-21.9-21.9-21.9-57.3 0-79.2s57.3-21.9 79.2 0 21.9 57.3 0 79.2s-57.4 21.9-79.2 0zM184.4 182.5c-21.9-21.9-21.9-57.3 0-79.2s57.3-21.9 79.2 0 21.9 57.3 0 79.2-57.3 21.8-79.2 0zm0 147c21.9-21.9 57.3-21.9 79.2 0s21.9 57.3 0 79.2s-57.3 21.9-79.2 0c-21.9-21.8-21.9-57.3 0-79.2zM297.5 216.4c21.9-21.9 57.3-21.9 79.2 0s21.9 57.3 0 79.2s-57.3 21.9-79.2 0c-21.8-21.9-21.8-57.3 0-79.2z\"></path></svg>\n </div>\n </Button>\n </span>\n )}\n {showReorderControls && (\n <DropdownMenu>\n <DropdownMenuTrigger\n render={(\n <Button\n type=\"button\"\n variant=\"none\"\n size=\"xs\"\n disabled={!hasMenuActions}\n className={cn(\n 'p-0 w-[24px] h-[24px]',\n 'text-gray-500',\n 'hover:bg-transparent',\n 'active:bg-transparent',\n 'hover:text-blue-500',\n !hasMenuActions && 'opacity-40 cursor-not-allowed',\n )}\n aria-label={t('Row actions')}\n />\n )}\n >\n <FontAwesomeIcon icon={faEllipsis} className=\"size-[12px]\" />\n </DropdownMenuTrigger>\n <DropdownMenuContent align=\"end\">\n {customRowMenuItemsBeforeCore}\n {hasCustomRowMenuItemsBeforeCore && hasMoveActions && <DropdownMenuSeparator />}\n {showReorderControls && rowIndex > 0 && (\n <DropdownMenuItem onClick={() => { return moveRow(row, -1); }}>\n <FontAwesomeIcon icon={faArrowUp} />\n {t('Move up')}\n </DropdownMenuItem>\n )}\n {showReorderControls && rowIndex < rowCount - 1 && (\n <DropdownMenuItem onClick={() => { return moveRow(row, 1); }}>\n <FontAwesomeIcon icon={faArrowDown} />\n {t('Move down')}\n </DropdownMenuItem>\n )}\n {hasMoveActions && hasCustomRowMenuItemsAfterCore && <DropdownMenuSeparator />}\n {customRowMenuItemsAfterCore}\n </DropdownMenuContent>\n </DropdownMenu>\n )}\n {renderRowActions?.({\n row,\n rowIndex,\n rowCount,\n })}\n {allowDelete && (\n <Button\n type=\"button\"\n variant=\"none\"\n size=\"xs\"\n onClick={() => { return removeRow(row); }}\n className={cn(\n 'p-0 w-[24px] h-[24px]',\n 'text-gray-500',\n 'hover:bg-transparent',\n 'active:bg-transparent',\n 'hover:text-red-500',\n )}\n >\n <FontAwesomeIcon icon={faXmark} className=\"size-[12px] mt-[2px]\" />\n </Button>\n )}\n </div>\n </TableCell>\n )}\n </>\n );\n }}\n </RowComponent>\n );\n}, (prevProps, nextProps) => {\n return (\n prevProps.row === nextProps.row\n && prevProps.rowIndex === nextProps.rowIndex\n && prevProps.rowCount === nextProps.rowCount\n && prevProps.columnsSignature === nextProps.columnsSignature\n && prevProps.getCellErrors === nextProps.getCellErrors\n && prevProps.useDnd === nextProps.useDnd\n && prevProps.allowReorder === nextProps.allowReorder\n && prevProps.showReorderControls === nextProps.showReorderControls\n && prevProps.allowDelete === nextProps.allowDelete\n && prevProps.renderRowActions === nextProps.renderRowActions\n && prevProps.renderRowMenuItemsBeforeCore === nextProps.renderRowMenuItemsBeforeCore\n && prevProps.renderRowMenuItemsAfterCore === nextProps.renderRowMenuItemsAfterCore\n && prevProps.renderRowMenuItems === nextProps.renderRowMenuItems\n );\n});\n"],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { EditableTableColumn } from './types';
2
+ export declare const GENERATED_CELL_MODE: {
3
+ readonly EMPTY: "empty";
4
+ readonly AUTO: "auto";
5
+ readonly MANUAL: "manual";
6
+ readonly SEEDED: "seeded";
7
+ };
8
+ export declare const isGeneratedColumn: (column: EditableTableColumn) => string | false | undefined;
9
+ export declare const isThinColumn: (column: EditableTableColumn) => boolean;
10
+ export declare const getGeneratedCellKey: (rowId: string, columnName: string) => string;
11
+ export declare const isEmptyCellValue: (value: unknown) => value is "" | null | undefined;
12
+ //# sourceMappingURL=helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/components/editable-table/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAEnD,eAAO,MAAM,mBAAmB;;;;;CAKtB,CAAC;AAEX,eAAO,MAAM,iBAAiB,GAAI,QAAQ,mBAAmB,+BAE5D,CAAC;AAEF,eAAO,MAAM,YAAY,GAAI,QAAQ,mBAAmB,YAEvD,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,OAAO,MAAM,EAAE,YAAY,MAAM,WAEpE,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,OAAO,OAAO,mCAE9C,CAAC"}
@@ -0,0 +1,23 @@
1
+ //#region src/components/editable-table/helpers.ts
2
+ var GENERATED_CELL_MODE = {
3
+ EMPTY: "empty",
4
+ AUTO: "auto",
5
+ MANUAL: "manual",
6
+ SEEDED: "seeded"
7
+ };
8
+ var isGeneratedColumn = (column) => {
9
+ return (column?.type === "handle" || column?.type === "value") && column?.name && column?.source;
10
+ };
11
+ var isThinColumn = (column) => {
12
+ return Boolean(column?.thin || column?.type === "checkbox" || column?.type === "lightswitch" || column?.type === "radio");
13
+ };
14
+ var getGeneratedCellKey = (rowId, columnName) => {
15
+ return `${rowId}:${columnName}`;
16
+ };
17
+ var isEmptyCellValue = (value) => {
18
+ return value === void 0 || value === null || value === "";
19
+ };
20
+ //#endregion
21
+ export { GENERATED_CELL_MODE, getGeneratedCellKey, isEmptyCellValue, isGeneratedColumn, isThinColumn };
22
+
23
+ //# sourceMappingURL=helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.js","names":[],"sources":["../../../src/components/editable-table/helpers.ts"],"sourcesContent":["import type { EditableTableColumn } from './types';\n\nexport const GENERATED_CELL_MODE = {\n EMPTY: 'empty',\n AUTO: 'auto',\n MANUAL: 'manual',\n SEEDED: 'seeded',\n} as const;\n\nexport const isGeneratedColumn = (column: EditableTableColumn) => {\n return (column?.type === 'handle' || column?.type === 'value') && column?.name && column?.source;\n};\n\nexport const isThinColumn = (column: EditableTableColumn) => {\n return Boolean(column?.thin || column?.type === 'checkbox' || column?.type === 'lightswitch' || column?.type === 'radio');\n};\n\nexport const getGeneratedCellKey = (rowId: string, columnName: string) => {\n return `${rowId}:${columnName}`;\n};\n\nexport const isEmptyCellValue = (value: unknown) => {\n return value === undefined || value === null || value === '';\n};\n"],"mappings":";AAEA,IAAa,sBAAsB;CAC/B,OAAO;CACP,MAAM;CACN,QAAQ;CACR,QAAQ;CACX;AAED,IAAa,qBAAqB,WAAgC;AAC9D,SAAQ,QAAQ,SAAS,YAAY,QAAQ,SAAS,YAAY,QAAQ,QAAQ,QAAQ;;AAG9F,IAAa,gBAAgB,WAAgC;AACzD,QAAO,QAAQ,QAAQ,QAAQ,QAAQ,SAAS,cAAc,QAAQ,SAAS,iBAAiB,QAAQ,SAAS,QAAQ;;AAG7H,IAAa,uBAAuB,OAAe,eAAuB;AACtE,QAAO,GAAG,MAAM,GAAG;;AAGvB,IAAa,oBAAoB,UAAmB;AAChD,QAAO,UAAU,KAAA,KAAa,UAAU,QAAQ,UAAU"}
@@ -0,0 +1,4 @@
1
+ export * from './RowDataCells';
2
+ export * from './TableCell';
3
+ export * from './TableRow';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/editable-table/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { TableCell } from "./TableCell.js";
2
+ import { RowDataCells } from "./RowDataCells.js";
3
+ import { TableRow } from "./TableRow.js";
4
+ export { RowDataCells, TableCell, TableRow };
@@ -0,0 +1,43 @@
1
+ import { default as React } from 'react';
2
+ import { VariableCategories } from '../tiptap/VariableDropdown';
3
+ export type EditableTableRow = Record<string, unknown> & {
4
+ _id: string;
5
+ };
6
+ export type EditableTableColumn = {
7
+ name: string;
8
+ type?: string;
9
+ label?: string;
10
+ required?: boolean;
11
+ placeholder?: string;
12
+ options?: unknown[];
13
+ className?: string;
14
+ contentClassName?: string;
15
+ thin?: boolean;
16
+ source?: string;
17
+ allowUnselect?: boolean;
18
+ noneOptionLabel?: string;
19
+ showActionsMenu?: boolean;
20
+ variableCategories?: VariableCategories;
21
+ variableCategoryLabels?: Record<string, string>;
22
+ variableCategoryOrder?: string[];
23
+ onChange?: (newValue: unknown, row: EditableTableRow, columnName: string) => void;
24
+ renderCell?: (args: EditableTableRenderCellArgs) => React.ReactNode;
25
+ [key: string]: unknown;
26
+ };
27
+ export type EditableTableModifyColumn = (row: EditableTableRow, columnName: string) => Partial<EditableTableColumn> | null | undefined;
28
+ export type EditableTableRowActionArgs = {
29
+ row: EditableTableRow;
30
+ rowIndex: number;
31
+ rowCount: number;
32
+ };
33
+ export type EditableTableOnCellChange = (rowIndex: number, columnName: string, value: unknown, row: EditableTableRow) => void;
34
+ export type EditableTableRenderCellArgs = {
35
+ column: EditableTableColumn;
36
+ value: unknown;
37
+ row: EditableTableRow;
38
+ rowIndex: number;
39
+ isInvalid: boolean;
40
+ updateValue: (newValue: unknown) => void;
41
+ cellErrors: unknown[];
42
+ };
43
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/editable-table/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4DAA4D,CAAC;AAErG,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG;IACrD,GAAG,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;IACxC,sBAAsB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,qBAAqB,CAAC,EAAE,MAAM,EAAE,CAAC;IACjC,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IAClF,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,2BAA2B,KAAK,KAAK,CAAC,SAAS,CAAC;IACpE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG,CACpC,GAAG,EAAE,gBAAgB,EACrB,UAAU,EAAE,MAAM,KACjB,OAAO,CAAC,mBAAmB,CAAC,GAAG,IAAI,GAAG,SAAS,CAAC;AAErD,MAAM,MAAM,0BAA0B,GAAG;IACrC,GAAG,EAAE,gBAAgB,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG,CACpC,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,OAAO,EACd,GAAG,EAAE,gBAAgB,KACpB,IAAI,CAAC;AAEV,MAAM,MAAM,2BAA2B,GAAG;IACtC,MAAM,EAAE,mBAAmB,CAAC;IAC5B,KAAK,EAAE,OAAO,CAAC;IACf,GAAG,EAAE,gBAAgB,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IACzC,UAAU,EAAE,OAAO,EAAE,CAAC;CACzB,CAAC"}
File without changes
@@ -0,0 +1,17 @@
1
+ import { MutableRefObject, Dispatch, SetStateAction } from 'react';
2
+ import { EditableTableColumn, EditableTableOnCellChange, EditableTableRow } from './types';
3
+ type UseEditableTableCellChangeArgs = {
4
+ internalData: EditableTableRow[];
5
+ internalDataRef: MutableRefObject<EditableTableRow[]>;
6
+ setInternalData: Dispatch<SetStateAction<EditableTableRow[]>>;
7
+ skipNextRowsSyncRef: MutableRefObject<number>;
8
+ generatedColumns: EditableTableColumn[];
9
+ onCellChange?: EditableTableOnCellChange | null;
10
+ updateRow: (row: EditableTableRow, updates: Record<string, unknown>) => void;
11
+ handleChange: (rows: EditableTableRow[]) => void;
12
+ };
13
+ export declare const useEditableTableCellChange: ({ internalData, internalDataRef, setInternalData, skipNextRowsSyncRef, generatedColumns, onCellChange, updateRow, handleChange, }: UseEditableTableCellChangeArgs) => {
14
+ handleCellValueChange: (rowIndex: number, row: EditableTableRow, column: EditableTableColumn, newValue: unknown) => void;
15
+ };
16
+ export {};
17
+ //# sourceMappingURL=useEditableTableCellChange.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEditableTableCellChange.d.ts","sourceRoot":"","sources":["../../../src/components/editable-table/useEditableTableCellChange.ts"],"names":[],"mappings":"AAAA,OAAO,EAIH,KAAK,gBAAgB,EACrB,KAAK,QAAQ,EACb,KAAK,cAAc,EACtB,MAAM,OAAO,CAAC;AAWf,OAAO,KAAK,EACR,mBAAmB,EACnB,yBAAyB,EACzB,gBAAgB,EACnB,MAAM,SAAS,CAAC;AAEjB,KAAK,8BAA8B,GAAG;IAClC,YAAY,EAAE,gBAAgB,EAAE,CAAA;IAChC,eAAe,EAAE,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,CAAA;IACrD,eAAe,EAAE,QAAQ,CAAC,cAAc,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAA;IAC7D,mBAAmB,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAA;IAC7C,gBAAgB,EAAE,mBAAmB,EAAE,CAAA;IACvC,YAAY,CAAC,EAAE,yBAAyB,GAAG,IAAI,CAAA;IAC/C,SAAS,EAAE,CAAC,GAAG,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAA;IAC5E,YAAY,EAAE,CAAC,IAAI,EAAE,gBAAgB,EAAE,KAAK,IAAI,CAAA;CACnD,CAAC;AASF,eAAO,MAAM,0BAA0B,GAAI,mIASxC,8BAA8B;sCA4DwB,MAAM,OAAO,gBAAgB,UAAU,mBAAmB,YAAY,OAAO;CA8IrI,CAAC"}
@@ -0,0 +1,152 @@
1
+ import { utils_exports } from "../../utils/index.js";
2
+ import { GENERATED_CELL_MODE, getGeneratedCellKey, isEmptyCellValue, isGeneratedColumn } from "./helpers.js";
3
+ import { useCallback, useEffect, useRef } from "react";
4
+ //#region src/components/editable-table/useEditableTableCellChange.ts
5
+ var useEditableTableCellChange = ({ internalData, internalDataRef, setInternalData, skipNextRowsSyncRef, generatedColumns, onCellChange, updateRow, handleChange }) => {
6
+ const pendingCellChangesRef = useRef(/* @__PURE__ */ new Map());
7
+ const cellChangesRafRef = useRef(null);
8
+ const generatedCellModesRef = useRef(/* @__PURE__ */ new Map());
9
+ useEffect(() => {
10
+ if (internalData.length === 0 || generatedColumns.length === 0) {
11
+ generatedCellModesRef.current.clear();
12
+ return;
13
+ }
14
+ const validKeys = /* @__PURE__ */ new Set();
15
+ internalData.forEach((row) => {
16
+ generatedColumns.forEach((column) => {
17
+ const key = getGeneratedCellKey(row._id, column.name);
18
+ validKeys.add(key);
19
+ if (generatedCellModesRef.current.has(key)) return;
20
+ const value = row[column.name];
21
+ generatedCellModesRef.current.set(key, isEmptyCellValue(value) ? GENERATED_CELL_MODE.EMPTY : GENERATED_CELL_MODE.SEEDED);
22
+ });
23
+ });
24
+ Array.from(generatedCellModesRef.current.keys()).forEach((key) => {
25
+ if (!validKeys.has(key)) generatedCellModesRef.current.delete(key);
26
+ });
27
+ }, [generatedColumns, internalData]);
28
+ const flushPendingCellChanges = useCallback(() => {
29
+ cellChangesRafRef.current = null;
30
+ if (!onCellChange || pendingCellChangesRef.current.size === 0) return;
31
+ const entries = Array.from(pendingCellChangesRef.current.values());
32
+ pendingCellChangesRef.current.clear();
33
+ entries.forEach(({ rowIndex, columnName, value, row }) => {
34
+ onCellChange(rowIndex, columnName, value, row);
35
+ });
36
+ }, [onCellChange]);
37
+ useEffect(() => {
38
+ return () => {
39
+ if (cellChangesRafRef.current !== null && typeof cancelAnimationFrame === "function") cancelAnimationFrame(cellChangesRafRef.current);
40
+ flushPendingCellChanges();
41
+ };
42
+ }, [flushPendingCellChanges]);
43
+ return { handleCellValueChange: useCallback((rowIndex, row, column, newValue) => {
44
+ if (column.type === "radio") {
45
+ const nextChecked = Boolean(newValue);
46
+ const updatesByRowId = /* @__PURE__ */ new Map();
47
+ const allowUnselect = Boolean(column.allowUnselect);
48
+ if (nextChecked) internalDataRef.current.forEach((item) => {
49
+ const currentValue = Boolean(item[column.name]);
50
+ const targetValue = item._id === row._id;
51
+ if (currentValue !== targetValue) updatesByRowId.set(item._id, { [column.name]: targetValue });
52
+ });
53
+ else if (allowUnselect && Boolean(row[column.name])) updatesByRowId.set(row._id, { [column.name]: false });
54
+ else return;
55
+ if (updatesByRowId.size === 0) return;
56
+ const nextData = internalDataRef.current.map((item) => {
57
+ const rowUpdates = updatesByRowId.get(item._id);
58
+ return rowUpdates ? {
59
+ ...item,
60
+ ...rowUpdates
61
+ } : item;
62
+ });
63
+ skipNextRowsSyncRef.current += 1;
64
+ setInternalData(nextData);
65
+ if (onCellChange) {
66
+ updatesByRowId.forEach((updates, rowId) => {
67
+ const targetRow = internalDataRef.current.find((item) => {
68
+ return item._id === rowId;
69
+ });
70
+ const targetRowIndex = internalDataRef.current.findIndex((item) => {
71
+ return item._id === rowId;
72
+ });
73
+ if (!targetRow || targetRowIndex === -1) return;
74
+ Object.entries(updates).forEach(([columnName, value]) => {
75
+ const key = `${rowId || targetRowIndex}:${columnName}`;
76
+ pendingCellChangesRef.current.set(key, {
77
+ rowIndex: targetRowIndex,
78
+ columnName,
79
+ value,
80
+ row: targetRow
81
+ });
82
+ });
83
+ });
84
+ if (cellChangesRafRef.current === null) if (typeof requestAnimationFrame === "function") cellChangesRafRef.current = requestAnimationFrame(flushPendingCellChanges);
85
+ else flushPendingCellChanges();
86
+ return;
87
+ }
88
+ handleChange(nextData);
89
+ return;
90
+ }
91
+ if (isGeneratedColumn(column)) {
92
+ const targetKey = getGeneratedCellKey(row._id, column.name);
93
+ generatedCellModesRef.current.set(targetKey, GENERATED_CELL_MODE.MANUAL);
94
+ }
95
+ const sourceUpdate = { [column.name]: newValue };
96
+ const derivedUpdates = {};
97
+ generatedColumns.forEach((targetColumn) => {
98
+ if (targetColumn.source !== column.name) return;
99
+ const targetKey = getGeneratedCellKey(row._id, targetColumn.name);
100
+ const currentTargetValue = row[targetColumn.name];
101
+ const existingMode = generatedCellModesRef.current.get(targetKey) ?? (isEmptyCellValue(currentTargetValue) ? GENERATED_CELL_MODE.EMPTY : GENERATED_CELL_MODE.SEEDED);
102
+ if (existingMode === GENERATED_CELL_MODE.MANUAL || existingMode === GENERATED_CELL_MODE.SEEDED) return;
103
+ if (targetColumn.type === "handle") {
104
+ derivedUpdates[targetColumn.name] = (0, utils_exports.generateHandle)(String(newValue ?? ""));
105
+ generatedCellModesRef.current.set(targetKey, GENERATED_CELL_MODE.AUTO);
106
+ } else if (targetColumn.type === "value") {
107
+ derivedUpdates[targetColumn.name] = newValue;
108
+ generatedCellModesRef.current.set(targetKey, GENERATED_CELL_MODE.AUTO);
109
+ }
110
+ });
111
+ const allUpdates = {
112
+ ...sourceUpdate,
113
+ ...derivedUpdates
114
+ };
115
+ if (!Object.entries(allUpdates).some(([key, value]) => {
116
+ return row[key] !== value;
117
+ })) return;
118
+ if (column.onChange) column.onChange(newValue, row, column.name);
119
+ if (onCellChange) {
120
+ skipNextRowsSyncRef.current += 1;
121
+ setInternalData((prevData) => {
122
+ return (0, utils_exports.updateItem)(prevData, row, allUpdates);
123
+ });
124
+ Object.entries(allUpdates).forEach(([columnName, value]) => {
125
+ const key = `${row._id || rowIndex}:${columnName}`;
126
+ pendingCellChangesRef.current.set(key, {
127
+ rowIndex,
128
+ columnName,
129
+ value,
130
+ row
131
+ });
132
+ });
133
+ if (cellChangesRafRef.current === null) if (typeof requestAnimationFrame === "function") cellChangesRafRef.current = requestAnimationFrame(flushPendingCellChanges);
134
+ else flushPendingCellChanges();
135
+ return;
136
+ }
137
+ updateRow(row, allUpdates);
138
+ }, [
139
+ flushPendingCellChanges,
140
+ generatedColumns,
141
+ handleChange,
142
+ internalDataRef,
143
+ onCellChange,
144
+ setInternalData,
145
+ skipNextRowsSyncRef,
146
+ updateRow
147
+ ]) };
148
+ };
149
+ //#endregion
150
+ export { useEditableTableCellChange };
151
+
152
+ //# sourceMappingURL=useEditableTableCellChange.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEditableTableCellChange.js","names":[],"sources":["../../../src/components/editable-table/useEditableTableCellChange.ts"],"sourcesContent":["import {\n useCallback,\n useEffect,\n useRef,\n type MutableRefObject,\n type Dispatch,\n type SetStateAction,\n} from 'react';\nimport {\n updateItem,\n generateHandle,\n} from '@verbb/plugin-kit-react/utils';\nimport {\n GENERATED_CELL_MODE,\n isGeneratedColumn,\n getGeneratedCellKey,\n isEmptyCellValue,\n} from './helpers';\nimport type {\n EditableTableColumn,\n EditableTableOnCellChange,\n EditableTableRow,\n} from './types';\n\ntype UseEditableTableCellChangeArgs = {\n internalData: EditableTableRow[]\n internalDataRef: MutableRefObject<EditableTableRow[]>\n setInternalData: Dispatch<SetStateAction<EditableTableRow[]>>\n skipNextRowsSyncRef: MutableRefObject<number>\n generatedColumns: EditableTableColumn[]\n onCellChange?: EditableTableOnCellChange | null\n updateRow: (row: EditableTableRow, updates: Record<string, unknown>) => void\n handleChange: (rows: EditableTableRow[]) => void\n};\n\ntype PendingCellChange = {\n rowIndex: number;\n columnName: string;\n value: unknown;\n row: EditableTableRow;\n};\n\nexport const useEditableTableCellChange = ({\n internalData,\n internalDataRef,\n setInternalData,\n skipNextRowsSyncRef,\n generatedColumns,\n onCellChange,\n updateRow,\n handleChange,\n}: UseEditableTableCellChangeArgs) => {\n const pendingCellChangesRef = useRef<Map<string, PendingCellChange>>(new Map());\n const cellChangesRafRef = useRef<number | null>(null);\n const generatedCellModesRef = useRef<Map<string, string>>(new Map());\n\n useEffect(() => {\n if (internalData.length === 0 || generatedColumns.length === 0) {\n generatedCellModesRef.current.clear();\n return;\n }\n\n const validKeys = new Set<string>();\n\n internalData.forEach((row) => {\n generatedColumns.forEach((column) => {\n const key = getGeneratedCellKey(row._id, column.name);\n validKeys.add(key);\n\n if (generatedCellModesRef.current.has(key)) {\n return;\n }\n\n const value = row[column.name];\n generatedCellModesRef.current.set(key, isEmptyCellValue(value) ? GENERATED_CELL_MODE.EMPTY : GENERATED_CELL_MODE.SEEDED);\n });\n });\n\n Array.from(generatedCellModesRef.current.keys()).forEach((key) => {\n if (!validKeys.has(key)) {\n generatedCellModesRef.current.delete(key);\n }\n });\n }, [generatedColumns, internalData]);\n\n const flushPendingCellChanges = useCallback(() => {\n cellChangesRafRef.current = null;\n\n if (!onCellChange || pendingCellChangesRef.current.size === 0) {\n return;\n }\n\n const entries = Array.from(pendingCellChangesRef.current.values());\n pendingCellChangesRef.current.clear();\n entries.forEach(({\n rowIndex, columnName, value, row,\n }) => {\n onCellChange(rowIndex, columnName, value, row);\n });\n }, [onCellChange]);\n\n useEffect(() => {\n return () => {\n if (cellChangesRafRef.current !== null && typeof cancelAnimationFrame === 'function') {\n cancelAnimationFrame(cellChangesRafRef.current);\n }\n\n flushPendingCellChanges();\n };\n }, [flushPendingCellChanges]);\n\n const handleCellValueChange = useCallback((rowIndex: number, row: EditableTableRow, column: EditableTableColumn, newValue: unknown) => {\n if (column.type === 'radio') {\n const nextChecked = Boolean(newValue);\n const updatesByRowId = new Map<string, Record<string, unknown>>();\n const allowUnselect = Boolean(column.allowUnselect);\n\n if (nextChecked) {\n internalDataRef.current.forEach((item) => {\n const currentValue = Boolean(item[column.name]);\n const targetValue = item._id === row._id;\n if (currentValue !== targetValue) {\n updatesByRowId.set(item._id, { [column.name]: targetValue });\n }\n });\n } else if (allowUnselect && Boolean(row[column.name])) {\n updatesByRowId.set(row._id, { [column.name]: false });\n } else {\n return;\n }\n\n if (updatesByRowId.size === 0) {\n return;\n }\n\n const nextData = internalDataRef.current.map((item) => {\n const rowUpdates = updatesByRowId.get(item._id);\n return rowUpdates ? { ...item, ...rowUpdates } : item;\n });\n\n skipNextRowsSyncRef.current += 1;\n setInternalData(nextData);\n\n if (onCellChange) {\n updatesByRowId.forEach((updates, rowId) => {\n const targetRow = internalDataRef.current.find((item) => { return item._id === rowId; });\n const targetRowIndex = internalDataRef.current.findIndex((item) => { return item._id === rowId; });\n if (!targetRow || targetRowIndex === -1) {\n return;\n }\n\n Object.entries(updates).forEach(([columnName, value]) => {\n const key = `${rowId || targetRowIndex}:${columnName}`;\n pendingCellChangesRef.current.set(key, {\n rowIndex: targetRowIndex,\n columnName,\n value,\n row: targetRow,\n });\n });\n });\n\n if (cellChangesRafRef.current === null) {\n if (typeof requestAnimationFrame === 'function') {\n cellChangesRafRef.current = requestAnimationFrame(flushPendingCellChanges);\n } else {\n flushPendingCellChanges();\n }\n }\n\n return;\n }\n\n handleChange(nextData);\n return;\n }\n\n if (isGeneratedColumn(column)) {\n const targetKey = getGeneratedCellKey(row._id, column.name);\n generatedCellModesRef.current.set(targetKey, GENERATED_CELL_MODE.MANUAL);\n }\n\n const sourceUpdate = { [column.name]: newValue };\n const derivedUpdates: Record<string, unknown> = {};\n\n generatedColumns.forEach((targetColumn) => {\n if (targetColumn.source !== column.name) {\n return;\n }\n\n const targetKey = getGeneratedCellKey(row._id, targetColumn.name);\n const currentTargetValue = row[targetColumn.name];\n const existingMode = generatedCellModesRef.current.get(targetKey)\n ?? (isEmptyCellValue(currentTargetValue) ? GENERATED_CELL_MODE.EMPTY : GENERATED_CELL_MODE.SEEDED);\n\n if (existingMode === GENERATED_CELL_MODE.MANUAL || existingMode === GENERATED_CELL_MODE.SEEDED) {\n return;\n }\n\n if (targetColumn.type === 'handle') {\n derivedUpdates[targetColumn.name] = generateHandle(String(newValue ?? ''));\n generatedCellModesRef.current.set(targetKey, GENERATED_CELL_MODE.AUTO);\n } else if (targetColumn.type === 'value') {\n derivedUpdates[targetColumn.name] = newValue;\n generatedCellModesRef.current.set(targetKey, GENERATED_CELL_MODE.AUTO);\n }\n });\n\n const allUpdates = { ...sourceUpdate, ...derivedUpdates };\n const hasRealChange = Object.entries(allUpdates).some(([key, value]) => {\n return row[key] !== value;\n });\n if (!hasRealChange) {\n return;\n }\n\n if (column.onChange) {\n column.onChange(newValue, row, column.name);\n }\n\n if (onCellChange) {\n skipNextRowsSyncRef.current += 1;\n setInternalData((prevData) => {\n return updateItem(prevData, row, allUpdates);\n });\n\n Object.entries(allUpdates).forEach(([columnName, value]) => {\n const key = `${row._id || rowIndex}:${columnName}`;\n pendingCellChangesRef.current.set(key, {\n rowIndex,\n columnName,\n value,\n row,\n });\n });\n\n if (cellChangesRafRef.current === null) {\n if (typeof requestAnimationFrame === 'function') {\n cellChangesRafRef.current = requestAnimationFrame(flushPendingCellChanges);\n } else {\n flushPendingCellChanges();\n }\n }\n\n return;\n }\n\n updateRow(row, allUpdates);\n }, [flushPendingCellChanges, generatedColumns, handleChange, internalDataRef, onCellChange, setInternalData, skipNextRowsSyncRef, updateRow]);\n\n return {\n handleCellValueChange,\n };\n};\n"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { EditableTableRow } from './types';
2
+ export declare const useEditableTableDnd: ({ allowReorder, internalData, handleChange, }: {
3
+ allowReorder: boolean;
4
+ internalData: EditableTableRow[];
5
+ handleChange: (rows: EditableTableRow[]) => void;
6
+ }) => {
7
+ isDragging: boolean;
8
+ isDndHydrated: boolean;
9
+ effectiveAllowReorder: boolean;
10
+ handleDragStart: () => void;
11
+ handleDragEnd: (event: {
12
+ canceled?: boolean;
13
+ operation?: {
14
+ source?: unknown;
15
+ };
16
+ }) => void;
17
+ };
18
+ //# sourceMappingURL=useEditableTableDnd.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEditableTableDnd.d.ts","sourceRoot":"","sources":["../../../src/components/editable-table/useEditableTableDnd.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEhD,eAAO,MAAM,mBAAmB,GAAI,+CAIjC;IACC,YAAY,EAAE,OAAO,CAAA;IACrB,YAAY,EAAE,gBAAgB,EAAE,CAAA;IAChC,YAAY,EAAE,CAAC,IAAI,EAAE,gBAAgB,EAAE,KAAK,IAAI,CAAA;CACnD;;;;;2BAmC6C;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAC;QAAC,SAAS,CAAC,EAAE;YAAE,MAAM,CAAC,EAAE,OAAO,CAAA;SAAE,CAAA;KAAE;CA6CrG,CAAC"}
@@ -0,0 +1,55 @@
1
+ import { useCallback, useEffect, useState } from "react";
2
+ import { isSortable } from "@dnd-kit/react/sortable";
3
+ //#region src/components/editable-table/useEditableTableDnd.ts
4
+ var useEditableTableDnd = ({ allowReorder, internalData, handleChange }) => {
5
+ const [isDragging, setIsDragging] = useState(false);
6
+ const [isDndHydrated, setIsDndHydrated] = useState(false);
7
+ useEffect(() => {
8
+ if (!allowReorder) {
9
+ setIsDndHydrated(false);
10
+ return;
11
+ }
12
+ let idleId = null;
13
+ let timeoutId = null;
14
+ const enableDnd = () => {
15
+ setIsDndHydrated(true);
16
+ };
17
+ if (typeof window !== "undefined" && typeof window.requestIdleCallback === "function") idleId = window.requestIdleCallback(enableDnd, { timeout: 1200 });
18
+ else timeoutId = setTimeout(enableDnd, 250);
19
+ return () => {
20
+ if (idleId !== null && typeof window !== "undefined" && typeof window.cancelIdleCallback === "function") window.cancelIdleCallback(idleId);
21
+ if (timeoutId !== null) clearTimeout(timeoutId);
22
+ };
23
+ }, [allowReorder]);
24
+ return {
25
+ isDragging,
26
+ isDndHydrated,
27
+ effectiveAllowReorder: allowReorder,
28
+ handleDragStart: useCallback(() => {
29
+ setIsDragging(true);
30
+ }, []),
31
+ handleDragEnd: useCallback((event) => {
32
+ setIsDragging(false);
33
+ if (!allowReorder) return;
34
+ if (event.canceled) return;
35
+ const { source } = event.operation ?? {};
36
+ if (!isSortable(source)) return;
37
+ if (!("initialIndex" in source) || typeof source.initialIndex !== "number") return;
38
+ const { initialIndex, index } = source;
39
+ if (initialIndex === index) return;
40
+ if (initialIndex < 0 || index < 0 || initialIndex >= internalData.length || index >= internalData.length) return;
41
+ const nextRows = [...internalData];
42
+ const [movedRow] = nextRows.splice(initialIndex, 1);
43
+ nextRows.splice(index, 0, movedRow);
44
+ handleChange(nextRows);
45
+ }, [
46
+ allowReorder,
47
+ handleChange,
48
+ internalData
49
+ ])
50
+ };
51
+ };
52
+ //#endregion
53
+ export { useEditableTableDnd };
54
+
55
+ //# sourceMappingURL=useEditableTableDnd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEditableTableDnd.js","names":[],"sources":["../../../src/components/editable-table/useEditableTableDnd.ts"],"sourcesContent":["import {\n useCallback, useEffect, useState,\n} from 'react';\nimport { isSortable } from '@dnd-kit/react/sortable';\nimport type { EditableTableRow } from './types';\n\nexport const useEditableTableDnd = ({\n allowReorder,\n internalData,\n handleChange,\n}: {\n allowReorder: boolean\n internalData: EditableTableRow[]\n handleChange: (rows: EditableTableRow[]) => void\n}) => {\n const [isDragging, setIsDragging] = useState(false);\n const [isDndHydrated, setIsDndHydrated] = useState(false);\n\n useEffect(() => {\n if (!allowReorder) {\n setIsDndHydrated(false);\n return;\n }\n\n let idleId: number | null = null;\n let timeoutId: ReturnType<typeof setTimeout> | null = null;\n const enableDnd = () => { setIsDndHydrated(true); };\n\n if (typeof window !== 'undefined' && typeof window.requestIdleCallback === 'function') {\n idleId = window.requestIdleCallback(enableDnd, { timeout: 1200 });\n } else {\n timeoutId = setTimeout(enableDnd, 250);\n }\n\n return () => {\n if (idleId !== null && typeof window !== 'undefined' && typeof window.cancelIdleCallback === 'function') {\n window.cancelIdleCallback(idleId);\n }\n\n if (timeoutId !== null) {\n clearTimeout(timeoutId);\n }\n };\n }, [allowReorder]);\n\n const handleDragStart = useCallback(() => {\n setIsDragging(true);\n }, []);\n\n const handleDragEnd = useCallback((event: { canceled?: boolean; operation?: { source?: unknown } }) => {\n setIsDragging(false);\n\n if (!allowReorder) {\n return;\n }\n\n if (event.canceled) {\n return;\n }\n\n const { source } = event.operation ?? {};\n if (!isSortable(source)) {\n return;\n }\n\n if (!('initialIndex' in source) || typeof source.initialIndex !== 'number') {\n return;\n }\n\n const { initialIndex, index } = source;\n if (initialIndex === index) {\n return;\n }\n\n if (initialIndex < 0 || index < 0 || initialIndex >= internalData.length || index >= internalData.length) {\n return;\n }\n\n const nextRows = [...internalData];\n const [movedRow] = nextRows.splice(initialIndex, 1);\n nextRows.splice(index, 0, movedRow);\n\n handleChange(nextRows);\n }, [allowReorder, handleChange, internalData]);\n\n const effectiveAllowReorder = allowReorder;\n\n return {\n isDragging,\n isDndHydrated,\n effectiveAllowReorder,\n handleDragStart,\n handleDragEnd,\n };\n};\n"],"mappings":";;;AAMA,IAAa,uBAAuB,EAChC,cACA,cACA,mBAKE;CACF,MAAM,CAAC,YAAY,iBAAiB,SAAS,MAAM;CACnD,MAAM,CAAC,eAAe,oBAAoB,SAAS,MAAM;AAEzD,iBAAgB;AACZ,MAAI,CAAC,cAAc;AACf,oBAAiB,MAAM;AACvB;;EAGJ,IAAI,SAAwB;EAC5B,IAAI,YAAkD;EACtD,MAAM,kBAAkB;AAAE,oBAAiB,KAAK;;AAEhD,MAAI,OAAO,WAAW,eAAe,OAAO,OAAO,wBAAwB,WACvE,UAAS,OAAO,oBAAoB,WAAW,EAAE,SAAS,MAAM,CAAC;MAEjE,aAAY,WAAW,WAAW,IAAI;AAG1C,eAAa;AACT,OAAI,WAAW,QAAQ,OAAO,WAAW,eAAe,OAAO,OAAO,uBAAuB,WACzF,QAAO,mBAAmB,OAAO;AAGrC,OAAI,cAAc,KACd,cAAa,UAAU;;IAGhC,CAAC,aAAa,CAAC;AA4ClB,QAAO;EACH;EACA;EACA,uBAAA;EACA,iBA9CoB,kBAAkB;AACtC,iBAAc,KAAK;KACpB,EAAE,CA4CD;EACA,eA3CkB,aAAa,UAAoE;AACnG,iBAAc,MAAM;AAEpB,OAAI,CAAC,aACD;AAGJ,OAAI,MAAM,SACN;GAGJ,MAAM,EAAE,WAAW,MAAM,aAAa,EAAE;AACxC,OAAI,CAAC,WAAW,OAAO,CACnB;AAGJ,OAAI,EAAE,kBAAkB,WAAW,OAAO,OAAO,iBAAiB,SAC9D;GAGJ,MAAM,EAAE,cAAc,UAAU;AAChC,OAAI,iBAAiB,MACjB;AAGJ,OAAI,eAAe,KAAK,QAAQ,KAAK,gBAAgB,aAAa,UAAU,SAAS,aAAa,OAC9F;GAGJ,MAAM,WAAW,CAAC,GAAG,aAAa;GAClC,MAAM,CAAC,YAAY,SAAS,OAAO,cAAc,EAAE;AACnD,YAAS,OAAO,OAAO,GAAG,SAAS;AAEnC,gBAAa,SAAS;KACvB;GAAC;GAAc;GAAc;GAAa,CASzC;EACH"}
@@ -0,0 +1,17 @@
1
+ import { EditableTableRow } from './types';
2
+ export declare const useEditableTableRows: ({ rows, onChange, newRowDefaults, }: {
3
+ rows: EditableTableRow[];
4
+ onChange: (rows: EditableTableRow[]) => void;
5
+ newRowDefaults?: Record<string, unknown>;
6
+ }) => {
7
+ internalData: EditableTableRow[];
8
+ setInternalData: import('react').Dispatch<import('react').SetStateAction<EditableTableRow[]>>;
9
+ internalDataRef: import('react').RefObject<EditableTableRow[]>;
10
+ skipNextRowsSyncRef: import('react').RefObject<number>;
11
+ handleChange: (nextRows: EditableTableRow[]) => void;
12
+ addRow: () => void;
13
+ removeRow: (row: EditableTableRow) => void;
14
+ updateRow: (row: EditableTableRow, updates: Record<string, unknown>) => void;
15
+ moveRow: (row: EditableTableRow, direction: number) => void;
16
+ };
17
+ //# sourceMappingURL=useEditableTableRows.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEditableTableRows.d.ts","sourceRoot":"","sources":["../../../src/components/editable-table/useEditableTableRows.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAchD,eAAO,MAAM,oBAAoB,GAAI,qCAIlC;IACC,IAAI,EAAE,gBAAgB,EAAE,CAAA;IACxB,QAAQ,EAAE,CAAC,IAAI,EAAE,gBAAgB,EAAE,KAAK,IAAI,CAAA;IAC5C,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAC3C;;;;;6BA0E+C,gBAAgB,EAAE;;qBAW1B,gBAAgB;qBAOhB,gBAAgB,WAAW,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;mBAepD,gBAAgB,aAAa,MAAM;CA0BxE,CAAC"}
@@ -0,0 +1,108 @@
1
+ import { utils_exports } from "../../utils/index.js";
2
+ import { useCallback, useEffect, useRef, useState } from "react";
3
+ //#region src/components/editable-table/useEditableTableRows.ts
4
+ var reorderByIndex = (items, from, to) => {
5
+ if (from === to || from < 0 || to < 0 || from >= items.length || to >= items.length) return items;
6
+ const nextItems = [...items];
7
+ const [moved] = nextItems.splice(from, 1);
8
+ nextItems.splice(to, 0, moved);
9
+ return nextItems;
10
+ };
11
+ var useEditableTableRows = ({ rows, onChange, newRowDefaults = {} }) => {
12
+ const [internalData, setInternalData] = useState([]);
13
+ const stableRowIdsRef = useRef([]);
14
+ const internalDataRef = useRef([]);
15
+ const skipNextRowsSyncRef = useRef(0);
16
+ const rowsMatch = (prevRows = [], nextRows = []) => {
17
+ if (prevRows.length !== nextRows.length) return false;
18
+ for (let i = 0; i < prevRows.length; i++) {
19
+ const prevRow = prevRows[i] || {};
20
+ const nextRow = nextRows[i] || {};
21
+ if (prevRow._id !== nextRow._id) return false;
22
+ const keys = new Set([...Object.keys(prevRow), ...Object.keys(nextRow)]);
23
+ for (const key of keys) {
24
+ if (key === "_id") continue;
25
+ if (prevRow[key] !== nextRow[key]) return false;
26
+ }
27
+ }
28
+ return true;
29
+ };
30
+ useEffect(() => {
31
+ if (!rows || rows.length === 0) {
32
+ stableRowIdsRef.current = [];
33
+ setInternalData([]);
34
+ return;
35
+ }
36
+ if (skipNextRowsSyncRef.current > 0) {
37
+ skipNextRowsSyncRef.current -= 1;
38
+ return;
39
+ }
40
+ setInternalData((prevData) => {
41
+ const nextData = (0, utils_exports.normalizeCollection)(rows).map((normalizedRow, index) => {
42
+ if (rows[index]?._id) {
43
+ stableRowIdsRef.current[index] = rows[index]._id;
44
+ return normalizedRow;
45
+ }
46
+ const stableId = prevData[index]?._id || stableRowIdsRef.current[index] || normalizedRow._id;
47
+ stableRowIdsRef.current[index] = stableId;
48
+ return {
49
+ ...normalizedRow,
50
+ _id: stableId
51
+ };
52
+ });
53
+ stableRowIdsRef.current = stableRowIdsRef.current.slice(0, nextData.length);
54
+ if (rowsMatch(prevData, nextData)) return prevData;
55
+ return nextData;
56
+ });
57
+ }, [rows]);
58
+ useEffect(() => {
59
+ internalDataRef.current = internalData;
60
+ }, [internalData]);
61
+ const handleChange = useCallback((nextRows) => {
62
+ onChange(nextRows);
63
+ }, [onChange]);
64
+ return {
65
+ internalData,
66
+ setInternalData,
67
+ internalDataRef,
68
+ skipNextRowsSyncRef,
69
+ handleChange,
70
+ addRow: useCallback(() => {
71
+ const nextData = [...internalDataRef.current, (0, utils_exports.createItem)(newRowDefaults)];
72
+ skipNextRowsSyncRef.current += 1;
73
+ setInternalData(nextData);
74
+ handleChange(nextData);
75
+ }, [handleChange, newRowDefaults]),
76
+ removeRow: useCallback((row) => {
77
+ const nextData = (0, utils_exports.deleteItem)(internalDataRef.current, row);
78
+ skipNextRowsSyncRef.current += 1;
79
+ setInternalData(nextData);
80
+ handleChange(nextData);
81
+ }, [handleChange]),
82
+ updateRow: useCallback((row, updates) => {
83
+ if (!Object.entries(updates).some(([key, val]) => {
84
+ return row[key] !== val;
85
+ })) return;
86
+ const nextData = (0, utils_exports.updateItem)(internalDataRef.current, row, updates);
87
+ skipNextRowsSyncRef.current += 1;
88
+ setInternalData(nextData);
89
+ handleChange(nextData);
90
+ }, [handleChange]),
91
+ moveRow: useCallback((row, direction) => {
92
+ const prevData = internalDataRef.current;
93
+ const index = prevData.findIndex((item) => {
94
+ return item._id === row._id;
95
+ });
96
+ const nextIndex = index + direction;
97
+ if (index === -1 || nextIndex < 0 || nextIndex >= prevData.length) return;
98
+ const nextData = reorderByIndex(prevData, index, nextIndex);
99
+ skipNextRowsSyncRef.current += 1;
100
+ setInternalData(nextData);
101
+ handleChange(nextData);
102
+ }, [handleChange])
103
+ };
104
+ };
105
+ //#endregion
106
+ export { useEditableTableRows };
107
+
108
+ //# sourceMappingURL=useEditableTableRows.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEditableTableRows.js","names":[],"sources":["../../../src/components/editable-table/useEditableTableRows.ts"],"sourcesContent":["import {\n useCallback, useEffect, useRef, useState,\n} from 'react';\nimport {\n normalizeCollection,\n createItem,\n deleteItem,\n updateItem,\n} from '@verbb/plugin-kit-react/utils';\nimport type { EditableTableRow } from './types';\n\nconst reorderByIndex = (items: EditableTableRow[], from: number, to: number) => {\n if (from === to || from < 0 || to < 0 || from >= items.length || to >= items.length) {\n return items;\n }\n\n const nextItems = [...items];\n const [moved] = nextItems.splice(from, 1);\n nextItems.splice(to, 0, moved);\n\n return nextItems;\n};\n\nexport const useEditableTableRows = ({\n rows,\n onChange,\n newRowDefaults = {},\n}: {\n rows: EditableTableRow[]\n onChange: (rows: EditableTableRow[]) => void\n newRowDefaults?: Record<string, unknown>\n}) => {\n const [internalData, setInternalData] = useState<EditableTableRow[]>([]);\n const stableRowIdsRef = useRef<string[]>([]);\n const internalDataRef = useRef<EditableTableRow[]>([]);\n const skipNextRowsSyncRef = useRef(0);\n\n const rowsMatch = (prevRows: EditableTableRow[] = [], nextRows: EditableTableRow[] = []) => {\n if (prevRows.length !== nextRows.length) {\n return false;\n }\n\n for (let i = 0; i < prevRows.length; i++) {\n const prevRow = prevRows[i] || {};\n const nextRow = nextRows[i] || {};\n\n if (prevRow._id !== nextRow._id) {\n return false;\n }\n\n const keys = new Set([...Object.keys(prevRow), ...Object.keys(nextRow)]);\n for (const key of keys) {\n if (key === '_id') {\n continue;\n }\n\n if (prevRow[key] !== nextRow[key]) {\n return false;\n }\n }\n }\n\n return true;\n };\n\n useEffect(() => {\n if (!rows || rows.length === 0) {\n stableRowIdsRef.current = [];\n setInternalData([]);\n return;\n }\n\n if (skipNextRowsSyncRef.current > 0) {\n skipNextRowsSyncRef.current -= 1;\n return;\n }\n\n setInternalData((prevData) => {\n const normalizedRows = normalizeCollection(rows) as EditableTableRow[];\n const nextData = normalizedRows.map((normalizedRow, index) => {\n if (rows[index]?._id) {\n stableRowIdsRef.current[index] = rows[index]._id;\n return normalizedRow;\n }\n\n const stableId = prevData[index]?._id || stableRowIdsRef.current[index] || normalizedRow._id;\n stableRowIdsRef.current[index] = stableId;\n\n return { ...normalizedRow, _id: stableId };\n });\n\n stableRowIdsRef.current = stableRowIdsRef.current.slice(0, nextData.length);\n\n if (rowsMatch(prevData, nextData)) {\n return prevData;\n }\n\n return nextData;\n });\n }, [rows]);\n\n useEffect(() => {\n internalDataRef.current = internalData;\n }, [internalData]);\n\n const handleChange = useCallback((nextRows: EditableTableRow[]) => {\n onChange(nextRows);\n }, [onChange]);\n\n const addRow = useCallback(() => {\n const nextData = [...internalDataRef.current, createItem(newRowDefaults) as EditableTableRow];\n skipNextRowsSyncRef.current += 1;\n setInternalData(nextData);\n handleChange(nextData);\n }, [handleChange, newRowDefaults]);\n\n const removeRow = useCallback((row: EditableTableRow) => {\n const nextData = deleteItem(internalDataRef.current, row) as EditableTableRow[];\n skipNextRowsSyncRef.current += 1;\n setInternalData(nextData);\n handleChange(nextData);\n }, [handleChange]);\n\n const updateRow = useCallback((row: EditableTableRow, updates: Record<string, unknown>) => {\n const hasRealChange = Object.entries(updates).some(([key, val]) => {\n return row[key] !== val;\n });\n\n if (!hasRealChange) {\n return;\n }\n\n const nextData = updateItem(internalDataRef.current, row, updates) as EditableTableRow[];\n skipNextRowsSyncRef.current += 1;\n setInternalData(nextData);\n handleChange(nextData);\n }, [handleChange]);\n\n const moveRow = useCallback((row: EditableTableRow, direction: number) => {\n const prevData = internalDataRef.current;\n const index = prevData.findIndex((item) => { return item._id === row._id; });\n const nextIndex = index + direction;\n\n if (index === -1 || nextIndex < 0 || nextIndex >= prevData.length) {\n return;\n }\n\n const nextData = reorderByIndex(prevData, index, nextIndex);\n skipNextRowsSyncRef.current += 1;\n setInternalData(nextData);\n handleChange(nextData);\n }, [handleChange]);\n\n return {\n internalData,\n setInternalData,\n internalDataRef,\n skipNextRowsSyncRef,\n handleChange,\n addRow,\n removeRow,\n updateRow,\n moveRow,\n };\n};\n"],"mappings":"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"}