@payloadcms/ui 3.80.0-internal.0311fce → 3.80.0-internal.37a8509

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 (530) hide show
  1. package/dist/elements/BulkUpload/EditForm/index.d.ts.map +1 -1
  2. package/dist/elements/BulkUpload/EditForm/index.js +12 -0
  3. package/dist/elements/BulkUpload/EditForm/index.js.map +1 -1
  4. package/dist/elements/Button/index.d.ts.map +1 -1
  5. package/dist/elements/Button/index.js +3 -5
  6. package/dist/elements/Button/index.js.map +1 -1
  7. package/dist/elements/Button/index.scss +5 -38
  8. package/dist/elements/Button/types.d.ts +1 -1
  9. package/dist/elements/Button/types.d.ts.map +1 -1
  10. package/dist/elements/Button/types.js.map +1 -1
  11. package/dist/elements/CheckboxPopup/index.d.ts.map +1 -1
  12. package/dist/elements/CheckboxPopup/index.js +1 -0
  13. package/dist/elements/CheckboxPopup/index.js.map +1 -1
  14. package/dist/elements/CheckboxPopup/index.scss +0 -1
  15. package/dist/elements/ClipboardAction/mergeFormStateFromClipboard.d.ts.map +1 -1
  16. package/dist/elements/ClipboardAction/mergeFormStateFromClipboard.js +4 -2
  17. package/dist/elements/ClipboardAction/mergeFormStateFromClipboard.js.map +1 -1
  18. package/dist/elements/ClipboardAction/mergeFormStateFromClipboard.spec.js +157 -0
  19. package/dist/elements/ClipboardAction/mergeFormStateFromClipboard.spec.js.map +1 -1
  20. package/dist/elements/DefaultListViewTabs/index.d.ts.map +1 -1
  21. package/dist/elements/DefaultListViewTabs/index.js +54 -28
  22. package/dist/elements/DefaultListViewTabs/index.js.map +1 -1
  23. package/dist/elements/DocumentControls/index.d.ts +0 -1
  24. package/dist/elements/DocumentControls/index.d.ts.map +1 -1
  25. package/dist/elements/DocumentControls/index.js +10 -6
  26. package/dist/elements/DocumentControls/index.js.map +1 -1
  27. package/dist/elements/DocumentControls/index.scss +1 -1
  28. package/dist/elements/DocumentDrawer/index.d.ts.map +1 -1
  29. package/dist/elements/DocumentDrawer/index.js +141 -54
  30. package/dist/elements/DocumentDrawer/index.js.map +1 -1
  31. package/dist/elements/DocumentDrawer/types.d.ts +1 -7
  32. package/dist/elements/DocumentDrawer/types.d.ts.map +1 -1
  33. package/dist/elements/DocumentDrawer/types.js.map +1 -1
  34. package/dist/elements/DrawerActionHeader/index.d.ts.map +1 -1
  35. package/dist/elements/DrawerActionHeader/index.js +0 -2
  36. package/dist/elements/DrawerActionHeader/index.js.map +1 -1
  37. package/dist/elements/DrawerActionHeader/index.scss +2 -2
  38. package/dist/elements/FolderView/Breadcrumbs/index.d.ts +19 -0
  39. package/dist/elements/FolderView/Breadcrumbs/index.d.ts.map +1 -0
  40. package/dist/elements/FolderView/Breadcrumbs/index.js +96 -0
  41. package/dist/elements/FolderView/Breadcrumbs/index.js.map +1 -0
  42. package/dist/elements/FolderView/Breadcrumbs/index.scss +56 -0
  43. package/dist/elements/FolderView/BrowseByFolderButton/index.d.ts +6 -0
  44. package/dist/elements/FolderView/BrowseByFolderButton/index.d.ts.map +1 -0
  45. package/dist/elements/FolderView/BrowseByFolderButton/index.js +40 -0
  46. package/dist/elements/FolderView/BrowseByFolderButton/index.js.map +1 -0
  47. package/dist/elements/FolderView/BrowseByFolderButton/index.scss +30 -0
  48. package/dist/elements/FolderView/Cell/index.client.d.ts +13 -0
  49. package/dist/elements/FolderView/Cell/index.client.d.ts.map +1 -0
  50. package/dist/elements/FolderView/Cell/index.client.js +95 -0
  51. package/dist/elements/FolderView/Cell/index.client.js.map +1 -0
  52. package/dist/elements/FolderView/Cell/index.server.d.ts +4 -0
  53. package/dist/elements/FolderView/Cell/index.server.d.ts.map +1 -0
  54. package/dist/elements/FolderView/Cell/index.server.js +18 -0
  55. package/dist/elements/FolderView/Cell/index.server.js.map +1 -0
  56. package/dist/elements/FolderView/ColoredFolderIcon/index.d.ts +3 -0
  57. package/dist/elements/FolderView/ColoredFolderIcon/index.d.ts.map +1 -0
  58. package/dist/elements/FolderView/ColoredFolderIcon/index.js +9 -0
  59. package/dist/elements/FolderView/ColoredFolderIcon/index.js.map +1 -0
  60. package/dist/elements/FolderView/ColoredFolderIcon/index.scss +5 -0
  61. package/dist/elements/FolderView/CurrentFolderActions/index.d.ts +7 -0
  62. package/dist/elements/FolderView/CurrentFolderActions/index.d.ts.map +1 -0
  63. package/dist/elements/FolderView/CurrentFolderActions/index.js +162 -0
  64. package/dist/elements/FolderView/CurrentFolderActions/index.js.map +1 -0
  65. package/dist/elements/FolderView/DragOverlaySelection/index.d.ts +11 -0
  66. package/dist/elements/FolderView/DragOverlaySelection/index.d.ts.map +1 -0
  67. package/dist/elements/FolderView/DragOverlaySelection/index.js +62 -0
  68. package/dist/elements/FolderView/DragOverlaySelection/index.js.map +1 -0
  69. package/dist/elements/FolderView/DragOverlaySelection/index.scss +35 -0
  70. package/dist/elements/FolderView/DraggableTableRow/index.d.ts +18 -0
  71. package/dist/elements/FolderView/DraggableTableRow/index.d.ts.map +1 -0
  72. package/dist/elements/FolderView/DraggableTableRow/index.js +63 -0
  73. package/dist/elements/FolderView/DraggableTableRow/index.js.map +1 -0
  74. package/dist/elements/FolderView/DraggableTableRow/index.scss +135 -0
  75. package/dist/elements/FolderView/DraggableWithClick/index.d.ts +15 -0
  76. package/dist/elements/FolderView/DraggableWithClick/index.d.ts.map +1 -0
  77. package/dist/elements/FolderView/DraggableWithClick/index.js +86 -0
  78. package/dist/elements/FolderView/DraggableWithClick/index.js.map +1 -0
  79. package/dist/elements/FolderView/DraggableWithClick/index.scss +5 -0
  80. package/dist/elements/FolderView/Drawers/EditFolderAction/index.d.ts +7 -0
  81. package/dist/elements/FolderView/Drawers/EditFolderAction/index.d.ts.map +1 -0
  82. package/dist/elements/FolderView/Drawers/EditFolderAction/index.js +39 -0
  83. package/dist/elements/FolderView/Drawers/EditFolderAction/index.js.map +1 -0
  84. package/dist/elements/FolderView/Drawers/MoveToFolder/index.d.ts +37 -0
  85. package/dist/elements/FolderView/Drawers/MoveToFolder/index.d.ts.map +1 -0
  86. package/dist/elements/FolderView/Drawers/MoveToFolder/index.js +609 -0
  87. package/dist/elements/FolderView/Drawers/MoveToFolder/index.js.map +1 -0
  88. package/dist/elements/FolderView/Drawers/MoveToFolder/index.scss +30 -0
  89. package/dist/elements/FolderView/FilterFolderTypePill/index.d.ts +4 -0
  90. package/dist/elements/FolderView/FilterFolderTypePill/index.d.ts.map +1 -0
  91. package/dist/elements/FolderView/FilterFolderTypePill/index.js +102 -0
  92. package/dist/elements/FolderView/FilterFolderTypePill/index.js.map +1 -0
  93. package/dist/elements/FolderView/FilterFolderTypePill/index.scss +16 -0
  94. package/dist/elements/FolderView/FolderField/index.scss +12 -0
  95. package/dist/elements/FolderView/FolderField/index.server.d.ts +4 -0
  96. package/dist/elements/FolderView/FolderField/index.server.d.ts.map +1 -0
  97. package/dist/elements/FolderView/FolderField/index.server.js +16 -0
  98. package/dist/elements/FolderView/FolderField/index.server.js.map +1 -0
  99. package/dist/elements/FolderView/FolderFileCard/index.d.ts +30 -0
  100. package/dist/elements/FolderView/FolderFileCard/index.d.ts.map +1 -0
  101. package/dist/elements/FolderView/FolderFileCard/index.js +209 -0
  102. package/dist/elements/FolderView/FolderFileCard/index.js.map +1 -0
  103. package/dist/elements/FolderView/FolderFileCard/index.scss +247 -0
  104. package/dist/elements/FolderView/FolderFileTable/index.d.ts +8 -0
  105. package/dist/elements/FolderView/FolderFileTable/index.d.ts.map +1 -0
  106. package/dist/elements/FolderView/FolderFileTable/index.js +284 -0
  107. package/dist/elements/FolderView/FolderFileTable/index.js.map +1 -0
  108. package/dist/elements/FolderView/FolderFileTable/index.scss +11 -0
  109. package/dist/elements/FolderView/FolderTypeField/index.d.ts +4 -0
  110. package/dist/elements/FolderView/FolderTypeField/index.d.ts.map +1 -0
  111. package/dist/elements/FolderView/FolderTypeField/index.js +123 -0
  112. package/dist/elements/FolderView/FolderTypeField/index.js.map +1 -0
  113. package/dist/elements/FolderView/ItemCardGrid/index.d.ts +16 -0
  114. package/dist/elements/FolderView/ItemCardGrid/index.d.ts.map +1 -0
  115. package/dist/elements/FolderView/ItemCardGrid/index.js +34 -0
  116. package/dist/elements/FolderView/ItemCardGrid/index.js.map +1 -0
  117. package/dist/elements/FolderView/ItemCardGrid/index.scss +16 -0
  118. package/dist/elements/FolderView/MoveDocToFolder/index.d.ts +37 -0
  119. package/dist/elements/FolderView/MoveDocToFolder/index.d.ts.map +1 -0
  120. package/dist/elements/FolderView/MoveDocToFolder/index.js +292 -0
  121. package/dist/elements/FolderView/MoveDocToFolder/index.js.map +1 -0
  122. package/dist/elements/{HierarchyButton → FolderView/MoveDocToFolder}/index.scss +1 -7
  123. package/dist/elements/FolderView/SimpleTable/index.d.ts +19 -0
  124. package/dist/elements/FolderView/SimpleTable/index.d.ts.map +1 -0
  125. package/dist/elements/FolderView/SimpleTable/index.js +95 -0
  126. package/dist/elements/FolderView/SimpleTable/index.js.map +1 -0
  127. package/dist/elements/FolderView/SimpleTable/index.scss +59 -0
  128. package/dist/elements/FolderView/SortByPill/index.d.ts +4 -0
  129. package/dist/elements/FolderView/SortByPill/index.d.ts.map +1 -0
  130. package/dist/elements/FolderView/SortByPill/index.js +112 -0
  131. package/dist/elements/FolderView/SortByPill/index.js.map +1 -0
  132. package/dist/elements/FolderView/SortByPill/index.scss +16 -0
  133. package/dist/elements/FolderView/ToggleViewButtons/index.d.ts +8 -0
  134. package/dist/elements/FolderView/ToggleViewButtons/index.d.ts.map +1 -0
  135. package/dist/elements/FolderView/ToggleViewButtons/index.js +31 -0
  136. package/dist/elements/FolderView/ToggleViewButtons/index.js.map +1 -0
  137. package/dist/elements/FolderView/ToggleViewButtons/index.scss +17 -0
  138. package/dist/elements/Link/index.d.ts +0 -4
  139. package/dist/elements/Link/index.d.ts.map +1 -1
  140. package/dist/elements/Link/index.js +0 -5
  141. package/dist/elements/Link/index.js.map +1 -1
  142. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.d.ts +15 -0
  143. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.d.ts.map +1 -0
  144. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js +182 -0
  145. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js.map +1 -0
  146. package/dist/elements/ListHeader/TitleActions/index.d.ts +1 -0
  147. package/dist/elements/ListHeader/TitleActions/index.d.ts.map +1 -1
  148. package/dist/elements/ListHeader/TitleActions/index.js +1 -0
  149. package/dist/elements/ListHeader/TitleActions/index.js.map +1 -1
  150. package/dist/elements/ListHeader/index.js +2 -2
  151. package/dist/elements/ListHeader/index.js.map +1 -1
  152. package/dist/elements/ListSelection/index.scss +1 -2
  153. package/dist/elements/Locked/index.scss +1 -1
  154. package/dist/elements/RelationshipTable/index.d.ts.map +1 -1
  155. package/dist/elements/RelationshipTable/index.js +17 -12
  156. package/dist/elements/RelationshipTable/index.js.map +1 -1
  157. package/dist/elements/StepNav/index.d.ts.map +1 -1
  158. package/dist/elements/StepNav/index.js +1 -10
  159. package/dist/elements/StepNav/index.js.map +1 -1
  160. package/dist/elements/StepNav/types.d.ts +0 -1
  161. package/dist/elements/StepNav/types.d.ts.map +1 -1
  162. package/dist/elements/StepNav/types.js.map +1 -1
  163. package/dist/elements/Table/DefaultCell/index.d.ts.map +1 -1
  164. package/dist/elements/Table/DefaultCell/index.js +0 -20
  165. package/dist/elements/Table/DefaultCell/index.js.map +1 -1
  166. package/dist/elements/Tooltip/index.js +1 -1
  167. package/dist/elements/Tooltip/index.js.map +1 -1
  168. package/dist/elements/Tooltip/index.scss +15 -1
  169. package/dist/elements/withMergedProps/index.d.ts +1 -1
  170. package/dist/elements/withMergedProps/index.js +1 -1
  171. package/dist/elements/withMergedProps/index.js.map +1 -1
  172. package/dist/exports/client/index.d.ts +9 -30
  173. package/dist/exports/client/index.d.ts.map +1 -1
  174. package/dist/exports/client/index.js +24 -26
  175. package/dist/exports/client/index.js.map +4 -4
  176. package/dist/exports/rsc/index.d.ts +3 -3
  177. package/dist/exports/rsc/index.d.ts.map +1 -1
  178. package/dist/exports/rsc/index.js +3 -3
  179. package/dist/exports/rsc/index.js.map +1 -1
  180. package/dist/exports/shared/index.js.map +1 -1
  181. package/dist/fields/Join/index.d.ts.map +1 -1
  182. package/dist/fields/Join/index.js +1 -1
  183. package/dist/fields/Join/index.js.map +1 -1
  184. package/dist/forms/Form/mergeServerFormState.d.ts.map +1 -1
  185. package/dist/forms/Form/mergeServerFormState.js +101 -24
  186. package/dist/forms/Form/mergeServerFormState.js.map +1 -1
  187. package/dist/icons/Chevron/index.d.ts.map +1 -1
  188. package/dist/icons/Chevron/index.js +1 -5
  189. package/dist/icons/Chevron/index.js.map +1 -1
  190. package/dist/icons/Document/index.d.ts +1 -3
  191. package/dist/icons/Document/index.d.ts.map +1 -1
  192. package/dist/icons/Document/index.js +2 -4
  193. package/dist/icons/Document/index.js.map +1 -1
  194. package/dist/icons/Document/index.scss +0 -4
  195. package/dist/icons/Folder/index.d.ts +2 -4
  196. package/dist/icons/Folder/index.d.ts.map +1 -1
  197. package/dist/icons/Folder/index.js +2 -4
  198. package/dist/icons/Folder/index.js.map +1 -1
  199. package/dist/icons/Folder/index.scss +0 -8
  200. package/dist/icons/Lock/index.scss +1 -1
  201. package/dist/icons/Plus/index.d.ts.map +1 -1
  202. package/dist/icons/Plus/index.js +1 -2
  203. package/dist/icons/Plus/index.js.map +1 -1
  204. package/dist/providers/Folders/groupItemIDsByRelation.d.ts +3 -0
  205. package/dist/providers/Folders/groupItemIDsByRelation.d.ts.map +1 -0
  206. package/dist/providers/Folders/groupItemIDsByRelation.js +10 -0
  207. package/dist/providers/Folders/groupItemIDsByRelation.js.map +1 -0
  208. package/dist/providers/Folders/index.d.ts +143 -0
  209. package/dist/providers/Folders/index.d.ts.map +1 -0
  210. package/dist/providers/Folders/index.js +641 -0
  211. package/dist/providers/Folders/index.js.map +1 -0
  212. package/dist/providers/Root/index.d.ts.map +1 -1
  213. package/dist/providers/Root/index.js +15 -18
  214. package/dist/providers/Root/index.js.map +1 -1
  215. package/dist/providers/ServerFunctions/index.d.ts +6 -1
  216. package/dist/providers/ServerFunctions/index.d.ts.map +1 -1
  217. package/dist/providers/ServerFunctions/index.js +18 -0
  218. package/dist/providers/ServerFunctions/index.js.map +1 -1
  219. package/dist/providers/TableColumns/buildColumnState/renderCell.d.ts +1 -2
  220. package/dist/providers/TableColumns/buildColumnState/renderCell.d.ts.map +1 -1
  221. package/dist/providers/TableColumns/buildColumnState/renderCell.js +1 -34
  222. package/dist/providers/TableColumns/buildColumnState/renderCell.js.map +1 -1
  223. package/dist/styles.css +1 -1
  224. package/dist/utilities/getFolderResultsComponentAndData.d.ts +25 -0
  225. package/dist/utilities/getFolderResultsComponentAndData.d.ts.map +1 -0
  226. package/dist/utilities/getFolderResultsComponentAndData.js +135 -0
  227. package/dist/utilities/getFolderResultsComponentAndData.js.map +1 -0
  228. package/dist/utilities/handleLivePreview.d.ts.map +1 -1
  229. package/dist/utilities/renderTable.d.ts +1 -3
  230. package/dist/utilities/renderTable.d.ts.map +1 -1
  231. package/dist/utilities/renderTable.js +3 -9
  232. package/dist/utilities/renderTable.js.map +1 -1
  233. package/dist/views/BrowseByFolder/index.d.ts +5 -0
  234. package/dist/views/BrowseByFolder/index.d.ts.map +1 -0
  235. package/dist/views/BrowseByFolder/index.js +342 -0
  236. package/dist/views/BrowseByFolder/index.js.map +1 -0
  237. package/dist/views/BrowseByFolder/index.scss +174 -0
  238. package/dist/views/CollectionFolder/ListSelection/index.d.ts +9 -0
  239. package/dist/views/CollectionFolder/ListSelection/index.d.ts.map +1 -0
  240. package/dist/views/CollectionFolder/ListSelection/index.js +180 -0
  241. package/dist/views/CollectionFolder/ListSelection/index.js.map +1 -0
  242. package/dist/views/CollectionFolder/index.d.ts +5 -0
  243. package/dist/views/CollectionFolder/index.d.ts.map +1 -0
  244. package/dist/views/CollectionFolder/index.js +325 -0
  245. package/dist/views/CollectionFolder/index.js.map +1 -0
  246. package/dist/views/CollectionFolder/index.scss +162 -0
  247. package/dist/views/Edit/index.d.ts +1 -1
  248. package/dist/views/Edit/index.d.ts.map +1 -1
  249. package/dist/views/Edit/index.js +12 -5
  250. package/dist/views/Edit/index.js.map +1 -1
  251. package/dist/views/List/index.d.ts.map +1 -1
  252. package/dist/views/List/index.js +7 -51
  253. package/dist/views/List/index.js.map +1 -1
  254. package/package.json +5 -5
  255. package/dist/elements/CreateDocumentButton/index.d.ts +0 -26
  256. package/dist/elements/CreateDocumentButton/index.d.ts.map +0 -1
  257. package/dist/elements/CreateDocumentButton/index.js +0 -182
  258. package/dist/elements/CreateDocumentButton/index.js.map +0 -1
  259. package/dist/elements/DelayedSpinner/index.d.ts +0 -23
  260. package/dist/elements/DelayedSpinner/index.d.ts.map +0 -1
  261. package/dist/elements/DelayedSpinner/index.js +0 -61
  262. package/dist/elements/DelayedSpinner/index.js.map +0 -1
  263. package/dist/elements/HierarchyButton/index.d.ts +0 -11
  264. package/dist/elements/HierarchyButton/index.d.ts.map +0 -1
  265. package/dist/elements/HierarchyButton/index.js +0 -126
  266. package/dist/elements/HierarchyButton/index.js.map +0 -1
  267. package/dist/elements/HierarchyButton/index.server.d.ts +0 -10
  268. package/dist/elements/HierarchyButton/index.server.d.ts.map +0 -1
  269. package/dist/elements/HierarchyButton/index.server.js +0 -34
  270. package/dist/elements/HierarchyButton/index.server.js.map +0 -1
  271. package/dist/elements/HierarchyColumnBrowser/Column/index.d.ts +0 -5
  272. package/dist/elements/HierarchyColumnBrowser/Column/index.d.ts.map +0 -1
  273. package/dist/elements/HierarchyColumnBrowser/Column/index.js +0 -166
  274. package/dist/elements/HierarchyColumnBrowser/Column/index.js.map +0 -1
  275. package/dist/elements/HierarchyColumnBrowser/Column/index.scss +0 -63
  276. package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.d.ts +0 -5
  277. package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.d.ts.map +0 -1
  278. package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.js +0 -161
  279. package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.js.map +0 -1
  280. package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.scss +0 -105
  281. package/dist/elements/HierarchyColumnBrowser/index.d.ts +0 -8
  282. package/dist/elements/HierarchyColumnBrowser/index.d.ts.map +0 -1
  283. package/dist/elements/HierarchyColumnBrowser/index.js +0 -470
  284. package/dist/elements/HierarchyColumnBrowser/index.js.map +0 -1
  285. package/dist/elements/HierarchyColumnBrowser/index.scss +0 -20
  286. package/dist/elements/HierarchyColumnBrowser/types.d.ts +0 -103
  287. package/dist/elements/HierarchyColumnBrowser/types.d.ts.map +0 -1
  288. package/dist/elements/HierarchyColumnBrowser/types.js +0 -2
  289. package/dist/elements/HierarchyColumnBrowser/types.js.map +0 -1
  290. package/dist/elements/HierarchyDrawer/Drawer/index.d.ts +0 -20
  291. package/dist/elements/HierarchyDrawer/Drawer/index.d.ts.map +0 -1
  292. package/dist/elements/HierarchyDrawer/Drawer/index.js +0 -289
  293. package/dist/elements/HierarchyDrawer/Drawer/index.js.map +0 -1
  294. package/dist/elements/HierarchyDrawer/Drawer/index.scss +0 -81
  295. package/dist/elements/HierarchyDrawer/fetchAncestorPath.d.ts +0 -15
  296. package/dist/elements/HierarchyDrawer/fetchAncestorPath.d.ts.map +0 -1
  297. package/dist/elements/HierarchyDrawer/fetchAncestorPath.js +0 -60
  298. package/dist/elements/HierarchyDrawer/fetchAncestorPath.js.map +0 -1
  299. package/dist/elements/HierarchyDrawer/index.d.ts +0 -30
  300. package/dist/elements/HierarchyDrawer/index.d.ts.map +0 -1
  301. package/dist/elements/HierarchyDrawer/index.js +0 -146
  302. package/dist/elements/HierarchyDrawer/index.js.map +0 -1
  303. package/dist/elements/HierarchyDrawer/types.d.ts +0 -65
  304. package/dist/elements/HierarchyDrawer/types.d.ts.map +0 -1
  305. package/dist/elements/HierarchyDrawer/types.js +0 -3
  306. package/dist/elements/HierarchyDrawer/types.js.map +0 -1
  307. package/dist/elements/HierarchyField/SelectedHierarchies.d.ts +0 -13
  308. package/dist/elements/HierarchyField/SelectedHierarchies.d.ts.map +0 -1
  309. package/dist/elements/HierarchyField/SelectedHierarchies.js +0 -194
  310. package/dist/elements/HierarchyField/SelectedHierarchies.js.map +0 -1
  311. package/dist/elements/HierarchyField/SelectedHierarchies.scss +0 -78
  312. package/dist/elements/HierarchyField/index.client.d.ts +0 -8
  313. package/dist/elements/HierarchyField/index.client.d.ts.map +0 -1
  314. package/dist/elements/HierarchyField/index.client.js +0 -198
  315. package/dist/elements/HierarchyField/index.client.js.map +0 -1
  316. package/dist/elements/HierarchyField/index.scss +0 -35
  317. package/dist/elements/HierarchyField/index.server.d.ts +0 -3
  318. package/dist/elements/HierarchyField/index.server.d.ts.map +0 -1
  319. package/dist/elements/HierarchyField/index.server.js +0 -30
  320. package/dist/elements/HierarchyField/index.server.js.map +0 -1
  321. package/dist/elements/HierarchySearch/HierarchySearchInput.d.ts +0 -18
  322. package/dist/elements/HierarchySearch/HierarchySearchInput.d.ts.map +0 -1
  323. package/dist/elements/HierarchySearch/HierarchySearchInput.js +0 -115
  324. package/dist/elements/HierarchySearch/HierarchySearchInput.js.map +0 -1
  325. package/dist/elements/HierarchySearch/HierarchySearchResultItem.d.ts +0 -13
  326. package/dist/elements/HierarchySearch/HierarchySearchResultItem.d.ts.map +0 -1
  327. package/dist/elements/HierarchySearch/HierarchySearchResultItem.js +0 -88
  328. package/dist/elements/HierarchySearch/HierarchySearchResultItem.js.map +0 -1
  329. package/dist/elements/HierarchySearch/HierarchySearchResults.d.ts +0 -17
  330. package/dist/elements/HierarchySearch/HierarchySearchResults.d.ts.map +0 -1
  331. package/dist/elements/HierarchySearch/HierarchySearchResults.js +0 -85
  332. package/dist/elements/HierarchySearch/HierarchySearchResults.js.map +0 -1
  333. package/dist/elements/HierarchySearch/index.d.ts +0 -10
  334. package/dist/elements/HierarchySearch/index.d.ts.map +0 -1
  335. package/dist/elements/HierarchySearch/index.js +0 -144
  336. package/dist/elements/HierarchySearch/index.js.map +0 -1
  337. package/dist/elements/HierarchySearch/index.scss +0 -212
  338. package/dist/elements/HierarchySearch/types.d.ts +0 -21
  339. package/dist/elements/HierarchySearch/types.d.ts.map +0 -1
  340. package/dist/elements/HierarchySearch/types.js +0 -2
  341. package/dist/elements/HierarchySearch/types.js.map +0 -1
  342. package/dist/elements/HierarchySearch/useHierarchySearch.d.ts +0 -20
  343. package/dist/elements/HierarchySearch/useHierarchySearch.d.ts.map +0 -1
  344. package/dist/elements/HierarchySearch/useHierarchySearch.js +0 -122
  345. package/dist/elements/HierarchySearch/useHierarchySearch.js.map +0 -1
  346. package/dist/elements/HierarchyTree/HierarchySidebarTab.d.ts +0 -20
  347. package/dist/elements/HierarchyTree/HierarchySidebarTab.d.ts.map +0 -1
  348. package/dist/elements/HierarchyTree/HierarchySidebarTab.js +0 -159
  349. package/dist/elements/HierarchyTree/HierarchySidebarTab.js.map +0 -1
  350. package/dist/elements/HierarchyTree/HierarchySidebarTab.server.d.ts +0 -7
  351. package/dist/elements/HierarchyTree/HierarchySidebarTab.server.d.ts.map +0 -1
  352. package/dist/elements/HierarchyTree/HierarchySidebarTab.server.js +0 -167
  353. package/dist/elements/HierarchyTree/HierarchySidebarTab.server.js.map +0 -1
  354. package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.d.ts +0 -8
  355. package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.d.ts.map +0 -1
  356. package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.js +0 -36
  357. package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.js.map +0 -1
  358. package/dist/elements/HierarchyTree/LoadMore/index.d.ts +0 -12
  359. package/dist/elements/HierarchyTree/LoadMore/index.d.ts.map +0 -1
  360. package/dist/elements/HierarchyTree/LoadMore/index.js +0 -29
  361. package/dist/elements/HierarchyTree/LoadMore/index.js.map +0 -1
  362. package/dist/elements/HierarchyTree/LoadMore/index.scss +0 -26
  363. package/dist/elements/HierarchyTree/TreeConnector.d.ts +0 -7
  364. package/dist/elements/HierarchyTree/TreeConnector.d.ts.map +0 -1
  365. package/dist/elements/HierarchyTree/TreeConnector.js +0 -23
  366. package/dist/elements/HierarchyTree/TreeConnector.js.map +0 -1
  367. package/dist/elements/HierarchyTree/TreeFocusContext.d.ts +0 -28
  368. package/dist/elements/HierarchyTree/TreeFocusContext.d.ts.map +0 -1
  369. package/dist/elements/HierarchyTree/TreeFocusContext.js +0 -140
  370. package/dist/elements/HierarchyTree/TreeFocusContext.js.map +0 -1
  371. package/dist/elements/HierarchyTree/TreeNode/index.d.ts +0 -5
  372. package/dist/elements/HierarchyTree/TreeNode/index.d.ts.map +0 -1
  373. package/dist/elements/HierarchyTree/TreeNode/index.js +0 -201
  374. package/dist/elements/HierarchyTree/TreeNode/index.js.map +0 -1
  375. package/dist/elements/HierarchyTree/TreeNode/index.scss +0 -99
  376. package/dist/elements/HierarchyTree/index.d.ts +0 -4
  377. package/dist/elements/HierarchyTree/index.d.ts.map +0 -1
  378. package/dist/elements/HierarchyTree/index.js +0 -68
  379. package/dist/elements/HierarchyTree/index.js.map +0 -1
  380. package/dist/elements/HierarchyTree/index.scss +0 -42
  381. package/dist/elements/HierarchyTree/types.d.ts +0 -57
  382. package/dist/elements/HierarchyTree/types.d.ts.map +0 -1
  383. package/dist/elements/HierarchyTree/types.js +0 -2
  384. package/dist/elements/HierarchyTree/types.js.map +0 -1
  385. package/dist/elements/HierarchyTree/useChildren.d.ts +0 -26
  386. package/dist/elements/HierarchyTree/useChildren.d.ts.map +0 -1
  387. package/dist/elements/HierarchyTree/useChildren.js +0 -150
  388. package/dist/elements/HierarchyTree/useChildren.js.map +0 -1
  389. package/dist/elements/HierarchyTree/useTreeState.d.ts +0 -9
  390. package/dist/elements/HierarchyTree/useTreeState.d.ts.map +0 -1
  391. package/dist/elements/HierarchyTree/useTreeState.js +0 -50
  392. package/dist/elements/HierarchyTree/useTreeState.js.map +0 -1
  393. package/dist/elements/HydrateHierarchyProvider/index.d.ts +0 -4
  394. package/dist/elements/HydrateHierarchyProvider/index.d.ts.map +0 -1
  395. package/dist/elements/HydrateHierarchyProvider/index.js +0 -70
  396. package/dist/elements/HydrateHierarchyProvider/index.js.map +0 -1
  397. package/dist/elements/LoadMoreRow/index.d.ts +0 -15
  398. package/dist/elements/LoadMoreRow/index.d.ts.map +0 -1
  399. package/dist/elements/LoadMoreRow/index.js +0 -75
  400. package/dist/elements/LoadMoreRow/index.js.map +0 -1
  401. package/dist/elements/LoadMoreRow/index.scss +0 -42
  402. package/dist/elements/MoveMany/index.d.ts +0 -22
  403. package/dist/elements/MoveMany/index.d.ts.map +0 -1
  404. package/dist/elements/MoveMany/index.js +0 -278
  405. package/dist/elements/MoveMany/index.js.map +0 -1
  406. package/dist/elements/MoveMany/index.scss +0 -7
  407. package/dist/elements/Spinner/index.d.ts +0 -16
  408. package/dist/elements/Spinner/index.d.ts.map +0 -1
  409. package/dist/elements/Spinner/index.js +0 -49
  410. package/dist/elements/Spinner/index.js.map +0 -1
  411. package/dist/elements/Spinner/index.scss +0 -39
  412. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.d.ts +0 -6
  413. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.d.ts.map +0 -1
  414. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.js +0 -187
  415. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.js.map +0 -1
  416. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.scss +0 -29
  417. package/dist/elements/Tree/LoadMore/LoadMoreButton.d.ts +0 -8
  418. package/dist/elements/Tree/LoadMore/LoadMoreButton.d.ts.map +0 -1
  419. package/dist/elements/Tree/LoadMore/LoadMoreButton.js +0 -36
  420. package/dist/elements/Tree/LoadMore/LoadMoreButton.js.map +0 -1
  421. package/dist/elements/Tree/LoadMore/index.d.ts +0 -12
  422. package/dist/elements/Tree/LoadMore/index.d.ts.map +0 -1
  423. package/dist/elements/Tree/LoadMore/index.js +0 -29
  424. package/dist/elements/Tree/LoadMore/index.js.map +0 -1
  425. package/dist/elements/Tree/LoadMore/index.scss +0 -26
  426. package/dist/elements/Tree/TreeConnector.d.ts +0 -7
  427. package/dist/elements/Tree/TreeConnector.d.ts.map +0 -1
  428. package/dist/elements/Tree/TreeConnector.js +0 -23
  429. package/dist/elements/Tree/TreeConnector.js.map +0 -1
  430. package/dist/elements/Tree/TreeFocusContext.d.ts +0 -28
  431. package/dist/elements/Tree/TreeFocusContext.d.ts.map +0 -1
  432. package/dist/elements/Tree/TreeFocusContext.js +0 -140
  433. package/dist/elements/Tree/TreeFocusContext.js.map +0 -1
  434. package/dist/elements/Tree/TreeNode/index.d.ts +0 -5
  435. package/dist/elements/Tree/TreeNode/index.d.ts.map +0 -1
  436. package/dist/elements/Tree/TreeNode/index.js +0 -218
  437. package/dist/elements/Tree/TreeNode/index.js.map +0 -1
  438. package/dist/elements/Tree/TreeNode/index.scss +0 -110
  439. package/dist/elements/Tree/index.d.ts +0 -5
  440. package/dist/elements/Tree/index.d.ts.map +0 -1
  441. package/dist/elements/Tree/index.js +0 -258
  442. package/dist/elements/Tree/index.js.map +0 -1
  443. package/dist/elements/Tree/index.scss +0 -63
  444. package/dist/elements/Tree/types.d.ts +0 -69
  445. package/dist/elements/Tree/types.d.ts.map +0 -1
  446. package/dist/elements/Tree/types.js +0 -2
  447. package/dist/elements/Tree/types.js.map +0 -1
  448. package/dist/elements/Tree/useChildren.d.ts +0 -25
  449. package/dist/elements/Tree/useChildren.d.ts.map +0 -1
  450. package/dist/elements/Tree/useChildren.js +0 -213
  451. package/dist/elements/Tree/useChildren.js.map +0 -1
  452. package/dist/fields/Null/index.d.ts +0 -11
  453. package/dist/fields/Null/index.d.ts.map +0 -1
  454. package/dist/fields/Null/index.js +0 -13
  455. package/dist/fields/Null/index.js.map +0 -1
  456. package/dist/icons/Filter/index.d.ts +0 -4
  457. package/dist/icons/Filter/index.d.ts.map +0 -1
  458. package/dist/icons/Filter/index.js +0 -15
  459. package/dist/icons/Filter/index.js.map +0 -1
  460. package/dist/icons/Filter/index.scss +0 -13
  461. package/dist/icons/Tag/index.d.ts +0 -8
  462. package/dist/icons/Tag/index.d.ts.map +0 -1
  463. package/dist/icons/Tag/index.js +0 -22
  464. package/dist/icons/Tag/index.js.map +0 -1
  465. package/dist/icons/Tag/index.scss +0 -14
  466. package/dist/providers/DocumentSelection/index.d.ts +0 -8
  467. package/dist/providers/DocumentSelection/index.d.ts.map +0 -1
  468. package/dist/providers/DocumentSelection/index.js +0 -239
  469. package/dist/providers/DocumentSelection/index.js.map +0 -1
  470. package/dist/providers/DocumentSelection/types.d.ts +0 -122
  471. package/dist/providers/DocumentSelection/types.d.ts.map +0 -1
  472. package/dist/providers/DocumentSelection/types.js +0 -5
  473. package/dist/providers/DocumentSelection/types.js.map +0 -1
  474. package/dist/providers/Hierarchy/index.d.ts +0 -5
  475. package/dist/providers/Hierarchy/index.d.ts.map +0 -1
  476. package/dist/providers/Hierarchy/index.js +0 -346
  477. package/dist/providers/Hierarchy/index.js.map +0 -1
  478. package/dist/providers/Hierarchy/types.d.ts +0 -105
  479. package/dist/providers/Hierarchy/types.d.ts.map +0 -1
  480. package/dist/providers/Hierarchy/types.js +0 -2
  481. package/dist/providers/Hierarchy/types.js.map +0 -1
  482. package/dist/utilities/isSuperset.d.ts +0 -6
  483. package/dist/utilities/isSuperset.d.ts.map +0 -1
  484. package/dist/utilities/isSuperset.js +0 -10
  485. package/dist/utilities/isSuperset.js.map +0 -1
  486. package/dist/views/HierarchyList/DocumentListSelection/index.d.ts +0 -10
  487. package/dist/views/HierarchyList/DocumentListSelection/index.d.ts.map +0 -1
  488. package/dist/views/HierarchyList/DocumentListSelection/index.js +0 -135
  489. package/dist/views/HierarchyList/DocumentListSelection/index.js.map +0 -1
  490. package/dist/views/HierarchyList/HierarchyListHeader/index.d.ts +0 -21
  491. package/dist/views/HierarchyList/HierarchyListHeader/index.d.ts.map +0 -1
  492. package/dist/views/HierarchyList/HierarchyListHeader/index.js +0 -67
  493. package/dist/views/HierarchyList/HierarchyListHeader/index.js.map +0 -1
  494. package/dist/views/HierarchyList/HierarchyListHeader/index.scss +0 -9
  495. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.d.ts +0 -4
  496. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.d.ts.map +0 -1
  497. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.js +0 -104
  498. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.js.map +0 -1
  499. package/dist/views/HierarchyList/HierarchyTable/DateCell.d.ts +0 -4
  500. package/dist/views/HierarchyList/HierarchyTable/DateCell.d.ts.map +0 -1
  501. package/dist/views/HierarchyList/HierarchyTable/DateCell.js +0 -53
  502. package/dist/views/HierarchyList/HierarchyTable/DateCell.js.map +0 -1
  503. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.d.ts +0 -4
  504. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.d.ts.map +0 -1
  505. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.js +0 -128
  506. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.js.map +0 -1
  507. package/dist/views/HierarchyList/HierarchyTable/SlotTable.d.ts +0 -99
  508. package/dist/views/HierarchyList/HierarchyTable/SlotTable.d.ts.map +0 -1
  509. package/dist/views/HierarchyList/HierarchyTable/SlotTable.js +0 -118
  510. package/dist/views/HierarchyList/HierarchyTable/SlotTable.js.map +0 -1
  511. package/dist/views/HierarchyList/HierarchyTable/SlotTable.scss +0 -214
  512. package/dist/views/HierarchyList/HierarchyTable/index.d.ts +0 -23
  513. package/dist/views/HierarchyList/HierarchyTable/index.d.ts.map +0 -1
  514. package/dist/views/HierarchyList/HierarchyTable/index.js +0 -387
  515. package/dist/views/HierarchyList/HierarchyTable/index.js.map +0 -1
  516. package/dist/views/HierarchyList/HierarchyTable/index.scss +0 -148
  517. package/dist/views/HierarchyList/HierarchyTable/types.d.ts +0 -20
  518. package/dist/views/HierarchyList/HierarchyTable/types.d.ts.map +0 -1
  519. package/dist/views/HierarchyList/HierarchyTable/types.js +0 -2
  520. package/dist/views/HierarchyList/HierarchyTable/types.js.map +0 -1
  521. package/dist/views/HierarchyList/TypeFilter/index.d.ts +0 -15
  522. package/dist/views/HierarchyList/TypeFilter/index.d.ts.map +0 -1
  523. package/dist/views/HierarchyList/TypeFilter/index.js +0 -37
  524. package/dist/views/HierarchyList/TypeFilter/index.js.map +0 -1
  525. package/dist/views/HierarchyList/TypeFilter/index.scss +0 -32
  526. package/dist/views/HierarchyList/index.d.ts +0 -5
  527. package/dist/views/HierarchyList/index.d.ts.map +0 -1
  528. package/dist/views/HierarchyList/index.js +0 -303
  529. package/dist/views/HierarchyList/index.js.map +0 -1
  530. package/dist/views/HierarchyList/index.scss +0 -72
@@ -1,218 +0,0 @@
1
- 'use client';
2
-
3
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
4
- import React, { useCallback, useRef } from 'react';
5
- import { Spinner } from '../../../elements/Spinner/index.js';
6
- import { ChevronIcon } from '../../../icons/Chevron/index.js';
7
- import { useTranslation } from '../../../providers/Translation/index.js';
8
- import { LoadMore } from '../LoadMore/index.js';
9
- import { useFocusableItem, useTreeFocus } from '../TreeFocusContext.js';
10
- import { useChildren } from '../useChildren.js';
11
- import './index.scss';
12
- const DEFAULT_TREE_LIMIT = 10;
13
- const baseClass = 'tree-node';
14
- const getDocumentTitle = (doc, useAsTitle) => {
15
- const docId = doc.id;
16
- const idStr = typeof docId === 'number' ? String(docId) : docId;
17
- if (!useAsTitle) {
18
- return idStr;
19
- }
20
- const value = doc[useAsTitle];
21
- if (value && (typeof value === 'string' || typeof value === 'number')) {
22
- return String(value);
23
- }
24
- return idStr;
25
- };
26
- export const TreeNode = ({
27
- allPossibleTypeValues,
28
- cache,
29
- collectionSlug,
30
- depth = 0,
31
- expandedNodes,
32
- filterByCollections,
33
- limit = DEFAULT_TREE_LIMIT,
34
- node,
35
- onSelect,
36
- onToggle,
37
- parentFieldName,
38
- selected,
39
- selectedNodeId,
40
- typeFieldName,
41
- useAsTitle
42
- }) => {
43
- const {
44
- t
45
- } = useTranslation();
46
- const expanded = expandedNodes.has(node.id);
47
- const nodeRef = useRef(null);
48
- const {
49
- setFocusedId
50
- } = useTreeFocus();
51
- const {
52
- children,
53
- hasMore,
54
- isLoading,
55
- loadMore: loadMoreFromHook,
56
- totalDocs
57
- } = useChildren({
58
- allPossibleTypeValues,
59
- cache,
60
- collectionSlug,
61
- enabled: expanded,
62
- filterByCollections,
63
- limit,
64
- parentFieldName,
65
- parentId: node.id,
66
- typeFieldName,
67
- useAsTitle
68
- });
69
- const handleLoadMore = React.useCallback(async () => {
70
- const newDocs = await loadMoreFromHook();
71
- if (newDocs && newDocs.length > 0) {
72
- const firstNewDoc = newDocs[0];
73
- const docId = firstNewDoc.id;
74
- setFocusedId(`node-${docId}`);
75
- }
76
- }, [loadMoreFromHook, setFocusedId]);
77
- const {
78
- handleFocus,
79
- isFocused,
80
- tabIndex
81
- } = useFocusableItem({
82
- id: `node-${node.id}`,
83
- type: 'node',
84
- ref: nodeRef
85
- });
86
- // When focusedId points to this node, actually call .focus()
87
- React.useEffect(() => {
88
- if (isFocused && nodeRef.current && document.activeElement !== nodeRef.current) {
89
- nodeRef.current.focus();
90
- }
91
- }, [isFocused]);
92
- // Determine if node has children:
93
- // - If explicitly set in data, use that
94
- // - If expanded and loaded, check the actual children
95
- // - Otherwise, assume it might have children (show chevron until proven otherwise)
96
- const hasChildren = node.hasChildren === true || (expanded && children !== null ? children.length > 0 : true);
97
- const handleToggleClick = useCallback(e => {
98
- e.stopPropagation();
99
- onToggle({
100
- id: node.id
101
- });
102
- }, [node.id, onToggle]);
103
- const handleSelectClick = useCallback(() => {
104
- onSelect?.({
105
- id: node.id
106
- });
107
- }, [node.id, onSelect]);
108
- const handleKeyDown = useCallback(e_0 => {
109
- switch (e_0.key) {
110
- case ' ':
111
- case 'Enter':
112
- e_0.preventDefault();
113
- e_0.stopPropagation();
114
- handleSelectClick();
115
- break;
116
- case 'ArrowLeft':
117
- e_0.preventDefault();
118
- e_0.stopPropagation();
119
- if (hasChildren && expanded) {
120
- onToggle({
121
- id: node.id
122
- });
123
- }
124
- break;
125
- case 'ArrowRight':
126
- e_0.preventDefault();
127
- e_0.stopPropagation();
128
- if (hasChildren && !expanded) {
129
- onToggle({
130
- id: node.id
131
- });
132
- }
133
- break;
134
- }
135
- }, [hasChildren, expanded, handleSelectClick, onToggle, node.id]);
136
- return /*#__PURE__*/_jsxs("div", {
137
- "aria-expanded": hasChildren ? expanded : undefined,
138
- "aria-level": depth + 1,
139
- "aria-selected": selected,
140
- className: baseClass,
141
- onFocus: handleFocus,
142
- onKeyDown: handleKeyDown,
143
- ref: nodeRef,
144
- role: "treeitem",
145
- style: {
146
- '--tree-depth': depth
147
- },
148
- tabIndex: tabIndex,
149
- children: [/*#__PURE__*/_jsxs("div", {
150
- className: [`${baseClass}__content`, selected && `${baseClass}__content--selected`].filter(Boolean).join(' '),
151
- children: [/*#__PURE__*/_jsx("div", {
152
- className: `${baseClass}__indicator`
153
- }), hasChildren ? /*#__PURE__*/_jsx("button", {
154
- "aria-label": expanded ? t('general:collapse') : t('general:open'),
155
- className: `${baseClass}__toggle`,
156
- onClick: handleToggleClick,
157
- onMouseDown: e_1 => e_1.preventDefault(),
158
- tabIndex: -1,
159
- type: "button",
160
- children: /*#__PURE__*/_jsx(ChevronIcon, {
161
- direction: expanded ? 'down' : 'right'
162
- })
163
- }) : /*#__PURE__*/_jsx("div", {
164
- className: `${baseClass}__toggle-spacer`
165
- }), /*#__PURE__*/_jsx("span", {
166
- className: `${baseClass}__title`,
167
- onClick: handleSelectClick,
168
- onMouseDown: e_2 => e_2.preventDefault(),
169
- title: node.title,
170
- children: node.title
171
- }), isLoading && expanded && /*#__PURE__*/_jsx("span", {
172
- className: `${baseClass}__loading`,
173
- children: /*#__PURE__*/_jsx(Spinner, {
174
- loadingText: null,
175
- size: "small"
176
- })
177
- })]
178
- }), expanded && children && children.length > 0 && /*#__PURE__*/_jsxs(_Fragment, {
179
- children: [/*#__PURE__*/_jsx("div", {
180
- className: `${baseClass}__children`,
181
- role: "group",
182
- children: children.map(child => {
183
- const childData = child;
184
- const childId = childData.id;
185
- const childTitle = getDocumentTitle(child, useAsTitle);
186
- return /*#__PURE__*/_jsx(TreeNode, {
187
- allPossibleTypeValues: allPossibleTypeValues,
188
- cache: cache,
189
- collectionSlug: collectionSlug,
190
- depth: depth + 1,
191
- expandedNodes: expandedNodes,
192
- filterByCollections: filterByCollections,
193
- limit: limit,
194
- node: {
195
- id: childId,
196
- hasChildren: true,
197
- title: childTitle
198
- },
199
- onSelect: onSelect,
200
- onToggle: onToggle,
201
- parentFieldName: parentFieldName,
202
- selected: String(childId) === String(selectedNodeId),
203
- selectedNodeId: selectedNodeId,
204
- typeFieldName: typeFieldName,
205
- useAsTitle: useAsTitle
206
- }, String(childId));
207
- })
208
- }), hasMore && /*#__PURE__*/_jsx(LoadMore, {
209
- currentCount: children.length,
210
- depth: depth + 1,
211
- id: `load-more-${node.id}`,
212
- onLoadMore: handleLoadMore,
213
- totalDocs: totalDocs
214
- })]
215
- })]
216
- });
217
- };
218
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","names":["React","useCallback","useRef","Spinner","ChevronIcon","useTranslation","LoadMore","useFocusableItem","useTreeFocus","useChildren","DEFAULT_TREE_LIMIT","baseClass","getDocumentTitle","doc","useAsTitle","docId","id","idStr","String","value","TreeNode","allPossibleTypeValues","cache","collectionSlug","depth","expandedNodes","filterByCollections","limit","node","onSelect","onToggle","parentFieldName","selected","selectedNodeId","typeFieldName","t","expanded","has","nodeRef","setFocusedId","children","hasMore","isLoading","loadMore","loadMoreFromHook","totalDocs","enabled","parentId","handleLoadMore","newDocs","length","firstNewDoc","handleFocus","isFocused","tabIndex","type","ref","useEffect","current","document","activeElement","focus","hasChildren","handleToggleClick","e","stopPropagation","handleSelectClick","handleKeyDown","key","preventDefault","_jsxs","undefined","className","onFocus","onKeyDown","role","style","filter","Boolean","join","_jsx","onClick","onMouseDown","direction","title","loadingText","size","_Fragment","map","child","childData","childId","childTitle","currentCount","onLoadMore"],"sources":["../../../../src/elements/Tree/TreeNode/index.tsx"],"sourcesContent":["'use client'\n\nimport React, { useCallback, useRef } from 'react'\n\nimport type { TreeNodeProps } from '../types.js'\n\nimport { Spinner } from '../../../elements/Spinner/index.js'\nimport { ChevronIcon } from '../../../icons/Chevron/index.js'\nimport { useTranslation } from '../../../providers/Translation/index.js'\nimport { LoadMore } from '../LoadMore/index.js'\nimport { useFocusableItem, useTreeFocus } from '../TreeFocusContext.js'\nimport { useChildren } from '../useChildren.js'\nimport './index.scss'\n\nconst DEFAULT_TREE_LIMIT = 10\n\nconst baseClass = 'tree-node'\n\nconst getDocumentTitle = (doc: Record<string, unknown>, useAsTitle: string | undefined): string => {\n const docId: number | string = doc.id as number | string\n const idStr = typeof docId === 'number' ? String(docId) : docId\n\n if (!useAsTitle) {\n return idStr\n }\n\n const value = doc[useAsTitle]\n if (value && (typeof value === 'string' || typeof value === 'number')) {\n return String(value)\n }\n return idStr\n}\n\nexport const TreeNode = ({\n allPossibleTypeValues,\n cache,\n collectionSlug,\n depth = 0,\n expandedNodes,\n filterByCollections,\n limit = DEFAULT_TREE_LIMIT,\n node,\n onSelect,\n onToggle,\n parentFieldName,\n selected,\n selectedNodeId,\n typeFieldName,\n useAsTitle,\n}: TreeNodeProps) => {\n const { t } = useTranslation()\n const expanded = expandedNodes.has(node.id)\n const nodeRef = useRef<HTMLDivElement>(null)\n const { setFocusedId } = useTreeFocus()\n\n const {\n children,\n hasMore,\n isLoading,\n loadMore: loadMoreFromHook,\n totalDocs,\n } = useChildren({\n allPossibleTypeValues,\n cache,\n collectionSlug,\n enabled: expanded,\n filterByCollections,\n limit,\n parentFieldName,\n parentId: node.id,\n typeFieldName,\n useAsTitle,\n })\n\n const handleLoadMore = React.useCallback(async () => {\n const newDocs = await loadMoreFromHook()\n\n if (newDocs && newDocs.length > 0) {\n const firstNewDoc = newDocs[0]\n const docId: number | string = (firstNewDoc as { id: number | string }).id\n setFocusedId(`node-${docId}`)\n }\n }, [loadMoreFromHook, setFocusedId])\n\n const { handleFocus, isFocused, tabIndex } = useFocusableItem({\n id: `node-${node.id}`,\n type: 'node',\n ref: nodeRef,\n })\n\n // When focusedId points to this node, actually call .focus()\n React.useEffect(() => {\n if (isFocused && nodeRef.current && document.activeElement !== nodeRef.current) {\n nodeRef.current.focus()\n }\n }, [isFocused])\n\n // Determine if node has children:\n // - If explicitly set in data, use that\n // - If expanded and loaded, check the actual children\n // - Otherwise, assume it might have children (show chevron until proven otherwise)\n const hasChildren =\n node.hasChildren === true || (expanded && children !== null ? children.length > 0 : true)\n\n const handleToggleClick = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation()\n onToggle({ id: node.id })\n },\n [node.id, onToggle],\n )\n\n const handleSelectClick = useCallback(() => {\n onSelect?.({ id: node.id })\n }, [node.id, onSelect])\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n switch (e.key) {\n case ' ':\n case 'Enter':\n e.preventDefault()\n e.stopPropagation()\n handleSelectClick()\n break\n case 'ArrowLeft':\n e.preventDefault()\n e.stopPropagation()\n if (hasChildren && expanded) {\n onToggle({ id: node.id })\n }\n break\n case 'ArrowRight':\n e.preventDefault()\n e.stopPropagation()\n if (hasChildren && !expanded) {\n onToggle({ id: node.id })\n }\n break\n }\n },\n [hasChildren, expanded, handleSelectClick, onToggle, node.id],\n )\n\n return (\n <div\n aria-expanded={hasChildren ? expanded : undefined}\n aria-level={depth + 1}\n aria-selected={selected}\n className={baseClass}\n onFocus={handleFocus}\n onKeyDown={handleKeyDown}\n ref={nodeRef}\n role=\"treeitem\"\n style={{ '--tree-depth': depth } as React.CSSProperties}\n tabIndex={tabIndex}\n >\n <div\n className={[`${baseClass}__content`, selected && `${baseClass}__content--selected`]\n .filter(Boolean)\n .join(' ')}\n >\n <div className={`${baseClass}__indicator`} />\n {hasChildren ? (\n <button\n aria-label={expanded ? t('general:collapse') : t('general:open')}\n className={`${baseClass}__toggle`}\n onClick={handleToggleClick}\n onMouseDown={(e) => e.preventDefault()}\n tabIndex={-1}\n type=\"button\"\n >\n <ChevronIcon direction={expanded ? 'down' : 'right'} />\n </button>\n ) : (\n <div className={`${baseClass}__toggle-spacer`} />\n )}\n {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions -- keyboard handled by parent */}\n <span\n className={`${baseClass}__title`}\n onClick={handleSelectClick}\n onMouseDown={(e) => e.preventDefault()}\n title={node.title}\n >\n {node.title}\n </span>\n {isLoading && expanded && (\n <span className={`${baseClass}__loading`}>\n <Spinner loadingText={null} size=\"small\" />\n </span>\n )}\n </div>\n\n {expanded && children && children.length > 0 && (\n <>\n <div className={`${baseClass}__children`} role=\"group\">\n {children.map((child) => {\n const childData = child as { id: number | string }\n const childId = childData.id\n const childTitle = getDocumentTitle(child, useAsTitle)\n return (\n <TreeNode\n allPossibleTypeValues={allPossibleTypeValues}\n cache={cache}\n collectionSlug={collectionSlug}\n depth={depth + 1}\n expandedNodes={expandedNodes}\n filterByCollections={filterByCollections}\n key={String(childId)}\n limit={limit}\n node={{\n id: childId,\n hasChildren: true,\n title: childTitle,\n }}\n onSelect={onSelect}\n onToggle={onToggle}\n parentFieldName={parentFieldName}\n selected={String(childId) === String(selectedNodeId)}\n selectedNodeId={selectedNodeId}\n typeFieldName={typeFieldName}\n useAsTitle={useAsTitle}\n />\n )\n })}\n </div>\n {hasMore && (\n <LoadMore\n currentCount={children.length}\n depth={depth + 1}\n id={`load-more-${node.id}`}\n onLoadMore={handleLoadMore}\n totalDocs={totalDocs}\n />\n )}\n </>\n )}\n </div>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,110 +0,0 @@
1
- @import '../../../scss/styles.scss';
2
-
3
- .tree-node {
4
- // Remove default focus outline from treeitem - we style the content instead
5
- outline: none;
6
-
7
- // When treeitem is keyboard-focused, highlight only the content row
8
- &:focus-visible > .tree-node__content {
9
- outline: var(--accessibility-outline);
10
- }
11
-
12
- .tree-node {
13
- margin-left: 0;
14
- margin-right: 0;
15
- }
16
- // Variables are inherited from parent .tree
17
-
18
- &__indicator {
19
- position: absolute;
20
- left: 0;
21
- top: 0;
22
- width: 2px;
23
- height: 16px;
24
- background-color: transparent;
25
- border-start-end-radius: 2px;
26
- border-end-end-radius: 2px;
27
- left: calc(var(--nav-padding-inline-start) * -1);
28
- top: 50%;
29
- bottom: 50%;
30
- transform: translateY(-50%);
31
- }
32
-
33
- &__content--selected {
34
- font-weight: 600;
35
-
36
- & > .tree-node__indicator {
37
- background-color: var(--theme-text);
38
- }
39
-
40
- & > .tree-node__title {
41
- color: var(--theme-text);
42
- }
43
- }
44
-
45
- &__content {
46
- display: flex;
47
- align-items: center;
48
- padding: var(--tree-node-padding-y) 0px;
49
- padding-left: calc(var(--tree-depth, 0) * var(--tree-indent));
50
- user-select: none;
51
- transition: background-color 100ms ease;
52
- font-size: var(--tree-font-size);
53
- line-height: var(--tree-node-content-height);
54
- height: var(--tree-node-content-height);
55
- position: relative;
56
- margin-bottom: var(--tree-row-gap);
57
- border-radius: var(--style-radius-s);
58
- }
59
-
60
- &__toggle {
61
- background: none;
62
- border: none;
63
- padding: 0;
64
- margin: 0;
65
- margin-right: var(--tree-chevron-spacing);
66
- display: flex;
67
- align-items: center;
68
- justify-content: center;
69
- cursor: default;
70
- color: var(--theme-elevation-400);
71
- width: var(--tree-chevron-width);
72
- height: var(--tree-chevron-width);
73
- flex-shrink: 0;
74
- border-radius: var(--style-radius-m);
75
-
76
- &:hover {
77
- border: 1px solid var(--theme-elevation-400);
78
- }
79
- }
80
-
81
- &__toggle-spacer {
82
- width: calc(var(--tree-chevron-width) + var(--tree-chevron-spacing));
83
- flex-shrink: 0;
84
- }
85
-
86
- &__title {
87
- min-width: 0;
88
- overflow: hidden;
89
- text-overflow: ellipsis;
90
- white-space: nowrap;
91
- font-size: var(--tree-font-size);
92
- color: var(--theme-elevation-650);
93
- color: var(--theme-text);
94
- cursor: pointer;
95
- &:hover {
96
- text-decoration: underline;
97
- color: var(--theme-text);
98
- }
99
- }
100
-
101
- &__loading {
102
- margin-left: 8px;
103
- display: inline-flex;
104
- align-items: center;
105
- }
106
-
107
- &__children {
108
- /* Children are rendered with depth variable set */
109
- }
110
- }
@@ -1,5 +0,0 @@
1
- import React from 'react';
2
- import type { TreeProps } from './types.js';
3
- import './index.scss';
4
- export declare const Tree: React.FC<TreeProps>;
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/elements/Tree/index.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAiC,MAAM,OAAO,CAAA;AAErD,OAAO,KAAK,EAAgB,SAAS,EAAE,MAAM,YAAY,CAAA;AASzD,OAAO,cAAc,CAAA;AAkQrB,eAAO,MAAM,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAMpC,CAAA"}
@@ -1,258 +0,0 @@
1
- 'use client';
2
-
3
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
4
- import { getTranslation } from '@payloadcms/translations';
5
- import { useRouter } from 'next/navigation.js';
6
- import React, { useId, useMemo, useRef } from 'react';
7
- import { CreateDocumentButton } from '../../elements/CreateDocumentButton/index.js';
8
- import { DelayedSpinner } from '../../elements/DelayedSpinner/index.js';
9
- import { TagIcon } from '../../icons/Tag/index.js';
10
- import { useConfig } from '../../providers/Config/index.js';
11
- import { useTranslation } from '../../providers/Translation/index.js';
12
- import { LoadMore } from './LoadMore/index.js';
13
- import { TreeFocusProvider, useTreeFocus } from './TreeFocusContext.js';
14
- import './index.scss';
15
- import { TreeNode } from './TreeNode/index.js';
16
- import { useChildren } from './useChildren.js';
17
- const baseClass = 'tree';
18
- const DEFAULT_TREE_LIMIT = 10;
19
- const getDocumentTitle = (doc, useAsTitle) => {
20
- const docId = doc.id;
21
- const idStr = typeof docId === 'number' ? String(docId) : docId;
22
- if (!useAsTitle) {
23
- return idStr;
24
- }
25
- const value = doc[useAsTitle];
26
- if (value && (typeof value === 'string' || typeof value === 'number')) {
27
- return String(value);
28
- }
29
- return idStr;
30
- };
31
- const TreeInner = ({
32
- allPossibleTypeValues,
33
- collectionSlug,
34
- expandedNodes,
35
- filterByCollections,
36
- icon,
37
- initialData,
38
- onNodeClick,
39
- parentFieldName,
40
- selectedNodeId,
41
- showAllOption = true,
42
- toggleNode,
43
- treeLimit = DEFAULT_TREE_LIMIT,
44
- typeFieldName,
45
- useAsTitle
46
- }) => {
47
- const {
48
- moveFocus
49
- } = useTreeFocus();
50
- const router = useRouter();
51
- const {
52
- i18n,
53
- t
54
- } = useTranslation();
55
- const {
56
- getEntityConfig
57
- } = useConfig();
58
- const createDrawerSlug = `tree-create-${useId()}`;
59
- // Pre-populate cache with initialData SYNCHRONOUSLY (before first render)
60
- // This ensures expanded children find their data immediately without client-side fetch
61
- const childrenCache = useRef(useMemo(() => {
62
- const cache = new Map();
63
- if (initialData && initialData.docs.length > 0) {
64
- // Group docs by parent to populate cache
65
- const docsByParent = new Map();
66
- for (const doc of initialData.docs) {
67
- const parentId = doc[parentFieldName] || 'null';
68
- const parentKey = String(parentId);
69
- if (!docsByParent.has(parentKey)) {
70
- docsByParent.set(parentKey, []);
71
- }
72
- const parentDocs = docsByParent.get(parentKey);
73
- if (parentDocs) {
74
- parentDocs.push(doc);
75
- }
76
- }
77
- // Populate cache with grouped docs and metadata from server
78
- const filterKey = filterByCollections?.length ? filterByCollections.slice().sort().join(',') : '';
79
- for (const [parentKey_0, docs] of docsByParent) {
80
- const cacheKey = `${collectionSlug}-${parentKey_0}-${filterKey}`;
81
- const parentMeta = initialData.loadedParents[parentKey_0];
82
- if (parentMeta) {
83
- // Calculate page number based on loaded count
84
- // If server loaded multiple pages to find a selected node, loadedCount > treeLimit
85
- const loadedCount = parentMeta.loadedCount ?? docs.length;
86
- const currentPage = Math.ceil(loadedCount / treeLimit) || 1;
87
- cache.set(cacheKey, {
88
- children: docs,
89
- hasMore: parentMeta.hasMore,
90
- page: currentPage,
91
- totalDocs: parentMeta.totalDocs
92
- });
93
- } else {
94
- // Shouldn't happen, but fallback to conservative estimate
95
- cache.set(cacheKey, {
96
- children: docs,
97
- hasMore: false,
98
- page: 1,
99
- totalDocs: docs.length
100
- });
101
- }
102
- }
103
- }
104
- return cache;
105
- }, [initialData, filterByCollections, parentFieldName, collectionSlug, treeLimit]));
106
- const treeRef = useRef(null);
107
- // Fetch root nodes (items with no parent)
108
- const {
109
- children: rootNodes,
110
- hasMore,
111
- isLoading,
112
- loadMore: loadMoreFromHook,
113
- refresh,
114
- totalDocs
115
- } = useChildren({
116
- allPossibleTypeValues,
117
- cache: childrenCache,
118
- collectionSlug,
119
- enabled: true,
120
- filterByCollections,
121
- initialData,
122
- limit: treeLimit,
123
- parentFieldName,
124
- parentId: 'null',
125
- typeFieldName,
126
- useAsTitle
127
- });
128
- // Wrap loadMore - focusedId stays the same, tabindex handles the rest
129
- const handleLoadMore = React.useCallback(async () => {
130
- await loadMoreFromHook();
131
- }, [loadMoreFromHook]);
132
- const handleNodeClick = ({
133
- id
134
- }) => {
135
- if (onNodeClick) {
136
- onNodeClick({
137
- id
138
- });
139
- }
140
- };
141
- // Show loading state with delay to prevent flash
142
- if (isLoading && !rootNodes) {
143
- return /*#__PURE__*/_jsx("div", {
144
- className: baseClass,
145
- children: /*#__PURE__*/_jsx(DelayedSpinner, {
146
- baseClass: baseClass,
147
- isLoading: true
148
- })
149
- });
150
- }
151
- // Show empty state after loading completes
152
- if (!rootNodes || rootNodes.length === 0) {
153
- const collectionLabel = getEntityConfig({
154
- collectionSlug
155
- });
156
- return /*#__PURE__*/_jsx("div", {
157
- className: baseClass,
158
- children: /*#__PURE__*/_jsx(CreateDocumentButton, {
159
- buttonStyle: "primary",
160
- collections: [{
161
- collectionSlug
162
- }],
163
- drawerSlug: createDrawerSlug,
164
- label: t('general:createNewLabel', {
165
- label: getTranslation(collectionLabel.labels.singular, i18n)
166
- }),
167
- onSave: async () => {
168
- await refresh();
169
- router.refresh();
170
- }
171
- })
172
- });
173
- }
174
- const handleTreeKeyDown = e => {
175
- if (e.key === 'ArrowDown') {
176
- e.preventDefault();
177
- moveFocus('down');
178
- } else if (e.key === 'ArrowUp') {
179
- e.preventDefault();
180
- moveFocus('up');
181
- }
182
- };
183
- const isAllSelected = selectedNodeId === null;
184
- const handleAllClick = () => {
185
- if (onNodeClick) {
186
- onNodeClick({
187
- id: null
188
- });
189
- }
190
- };
191
- return /*#__PURE__*/_jsxs("div", {
192
- className: baseClass,
193
- onKeyDown: handleTreeKeyDown,
194
- ref: treeRef,
195
- role: "tree",
196
- tabIndex: -1,
197
- children: [showAllOption && /*#__PURE__*/_jsxs("div", {
198
- "aria-selected": isAllSelected,
199
- className: `${baseClass}__all-option${isAllSelected ? ` ${baseClass}__all-option--selected` : ''}`,
200
- onClick: handleAllClick,
201
- onKeyDown: e_0 => {
202
- if (e_0.key === 'Enter' || e_0.key === ' ') {
203
- e_0.preventDefault();
204
- handleAllClick();
205
- }
206
- },
207
- role: "treeitem",
208
- tabIndex: 0,
209
- children: [icon || /*#__PURE__*/_jsx(TagIcon, {
210
- color: "muted"
211
- }), /*#__PURE__*/_jsxs("span", {
212
- children: [t('general:all'), ' ', getTranslation(getEntityConfig({
213
- collectionSlug
214
- })?.labels?.plural, i18n)]
215
- })]
216
- }), rootNodes.map(node => {
217
- const nodeId = node.id;
218
- const nodeIdStr = typeof nodeId === 'number' ? String(nodeId) : nodeId;
219
- const nodeTitle = getDocumentTitle(node, useAsTitle);
220
- const isSelected = nodeIdStr === String(selectedNodeId);
221
- return /*#__PURE__*/_jsx(TreeNode, {
222
- allPossibleTypeValues: allPossibleTypeValues,
223
- cache: childrenCache,
224
- collectionSlug: collectionSlug,
225
- depth: 0,
226
- expandedNodes: expandedNodes,
227
- filterByCollections: filterByCollections,
228
- limit: treeLimit,
229
- node: {
230
- id: nodeId,
231
- hasChildren: true,
232
- title: nodeTitle
233
- },
234
- onSelect: handleNodeClick,
235
- onToggle: toggleNode,
236
- parentFieldName: parentFieldName,
237
- selected: isSelected,
238
- selectedNodeId: selectedNodeId,
239
- typeFieldName: typeFieldName,
240
- useAsTitle: useAsTitle
241
- }, nodeIdStr);
242
- }), hasMore && /*#__PURE__*/_jsx(LoadMore, {
243
- currentCount: rootNodes.length,
244
- depth: 0,
245
- id: "load-more-root",
246
- onLoadMore: handleLoadMore,
247
- totalDocs: totalDocs
248
- })]
249
- });
250
- };
251
- export const Tree = props => {
252
- return /*#__PURE__*/_jsx(TreeFocusProvider, {
253
- children: /*#__PURE__*/_jsx(TreeInner, {
254
- ...props
255
- })
256
- });
257
- };
258
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","names":["getTranslation","useRouter","React","useId","useMemo","useRef","CreateDocumentButton","DelayedSpinner","TagIcon","useConfig","useTranslation","LoadMore","TreeFocusProvider","useTreeFocus","TreeNode","useChildren","baseClass","DEFAULT_TREE_LIMIT","getDocumentTitle","doc","useAsTitle","docId","id","idStr","String","value","TreeInner","allPossibleTypeValues","collectionSlug","expandedNodes","filterByCollections","icon","initialData","onNodeClick","parentFieldName","selectedNodeId","showAllOption","toggleNode","treeLimit","typeFieldName","moveFocus","router","i18n","t","getEntityConfig","createDrawerSlug","childrenCache","cache","Map","docs","length","docsByParent","parentId","parentKey","has","set","parentDocs","get","push","filterKey","slice","sort","join","cacheKey","parentMeta","loadedParents","loadedCount","currentPage","Math","ceil","children","hasMore","page","totalDocs","treeRef","rootNodes","isLoading","loadMore","loadMoreFromHook","refresh","enabled","limit","handleLoadMore","useCallback","handleNodeClick","_jsx","className","collectionLabel","buttonStyle","collections","drawerSlug","label","labels","singular","onSave","handleTreeKeyDown","e","key","preventDefault","isAllSelected","handleAllClick","_jsxs","onKeyDown","ref","role","tabIndex","onClick","color","plural","map","node","nodeId","nodeIdStr","nodeTitle","isSelected","depth","hasChildren","title","onSelect","onToggle","selected","currentCount","onLoadMore","Tree","props"],"sources":["../../../src/elements/Tree/index.tsx"],"sourcesContent":["'use client'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport { useRouter } from 'next/navigation.js'\nimport React, { useId, useMemo, useRef } from 'react'\n\nimport type { TreeDocument, TreeProps } from './types.js'\n\nimport { CreateDocumentButton } from '../../elements/CreateDocumentButton/index.js'\nimport { DelayedSpinner } from '../../elements/DelayedSpinner/index.js'\nimport { TagIcon } from '../../icons/Tag/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { LoadMore } from './LoadMore/index.js'\nimport { TreeFocusProvider, useTreeFocus } from './TreeFocusContext.js'\nimport './index.scss'\nimport { TreeNode } from './TreeNode/index.js'\nimport { useChildren } from './useChildren.js'\n\nconst baseClass = 'tree'\nconst DEFAULT_TREE_LIMIT = 10\n\nconst getDocumentTitle = (doc: TreeDocument, useAsTitle: string | undefined): string => {\n const docId: number | string = doc.id\n const idStr = typeof docId === 'number' ? String(docId) : docId\n\n if (!useAsTitle) {\n return idStr\n }\n\n const value = doc[useAsTitle]\n if (value && (typeof value === 'string' || typeof value === 'number')) {\n return String(value)\n }\n return idStr\n}\n\nconst TreeInner: React.FC<TreeProps> = ({\n allPossibleTypeValues,\n collectionSlug,\n expandedNodes,\n filterByCollections,\n icon,\n initialData,\n onNodeClick,\n parentFieldName,\n selectedNodeId,\n showAllOption = true,\n toggleNode,\n treeLimit = DEFAULT_TREE_LIMIT,\n typeFieldName,\n useAsTitle,\n}) => {\n const { moveFocus } = useTreeFocus()\n const router = useRouter()\n const { i18n, t } = useTranslation()\n const { getEntityConfig } = useConfig()\n const createDrawerSlug = `tree-create-${useId()}`\n\n // Pre-populate cache with initialData SYNCHRONOUSLY (before first render)\n // This ensures expanded children find their data immediately without client-side fetch\n const childrenCache = useRef(\n useMemo(() => {\n const cache = new Map()\n\n if (initialData && initialData.docs.length > 0) {\n // Group docs by parent to populate cache\n const docsByParent = new Map<string, TreeDocument[]>()\n\n for (const doc of initialData.docs) {\n const parentId = doc[parentFieldName] || 'null'\n const parentKey = String(parentId)\n\n if (!docsByParent.has(parentKey)) {\n docsByParent.set(parentKey, [])\n }\n const parentDocs = docsByParent.get(parentKey)\n if (parentDocs) {\n parentDocs.push(doc)\n }\n }\n\n // Populate cache with grouped docs and metadata from server\n const filterKey = filterByCollections?.length\n ? filterByCollections.slice().sort().join(',')\n : ''\n for (const [parentKey, docs] of docsByParent) {\n const cacheKey = `${collectionSlug}-${parentKey}-${filterKey}`\n const parentMeta = initialData.loadedParents[parentKey]\n\n if (parentMeta) {\n // Calculate page number based on loaded count\n // If server loaded multiple pages to find a selected node, loadedCount > treeLimit\n const loadedCount = parentMeta.loadedCount ?? docs.length\n const currentPage = Math.ceil(loadedCount / treeLimit) || 1\n\n cache.set(cacheKey, {\n children: docs,\n hasMore: parentMeta.hasMore,\n page: currentPage,\n totalDocs: parentMeta.totalDocs,\n })\n } else {\n // Shouldn't happen, but fallback to conservative estimate\n cache.set(cacheKey, {\n children: docs,\n hasMore: false,\n page: 1,\n totalDocs: docs.length,\n })\n }\n }\n }\n\n return cache\n }, [initialData, filterByCollections, parentFieldName, collectionSlug, treeLimit]),\n )\n const treeRef = useRef<HTMLDivElement>(null)\n\n // Fetch root nodes (items with no parent)\n const {\n children: rootNodes,\n hasMore,\n isLoading,\n loadMore: loadMoreFromHook,\n refresh,\n totalDocs,\n } = useChildren({\n allPossibleTypeValues,\n cache: childrenCache,\n collectionSlug,\n enabled: true,\n filterByCollections,\n initialData,\n limit: treeLimit,\n parentFieldName,\n parentId: 'null', // Special value to query for null parent\n typeFieldName,\n useAsTitle,\n })\n\n // Wrap loadMore - focusedId stays the same, tabindex handles the rest\n const handleLoadMore = React.useCallback(async () => {\n await loadMoreFromHook()\n }, [loadMoreFromHook])\n\n const handleNodeClick = ({ id }: { id: number | string }) => {\n if (onNodeClick) {\n onNodeClick({ id })\n }\n }\n\n // Show loading state with delay to prevent flash\n if (isLoading && !rootNodes) {\n return (\n <div className={baseClass}>\n <DelayedSpinner baseClass={baseClass} isLoading={true} />\n </div>\n )\n }\n\n // Show empty state after loading completes\n if (!rootNodes || rootNodes.length === 0) {\n const collectionLabel = getEntityConfig({ collectionSlug })\n return (\n <div className={baseClass}>\n <CreateDocumentButton\n buttonStyle=\"primary\"\n collections={[{ collectionSlug }]}\n drawerSlug={createDrawerSlug}\n label={t('general:createNewLabel', {\n label: getTranslation(collectionLabel.labels.singular, i18n),\n })}\n onSave={async () => {\n await refresh()\n router.refresh()\n }}\n />\n </div>\n )\n }\n\n const handleTreeKeyDown = (e: React.KeyboardEvent) => {\n if (e.key === 'ArrowDown') {\n e.preventDefault()\n moveFocus('down')\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n moveFocus('up')\n }\n }\n\n const isAllSelected = selectedNodeId === null\n\n const handleAllClick = () => {\n if (onNodeClick) {\n onNodeClick({ id: null })\n }\n }\n\n return (\n <div\n className={baseClass}\n onKeyDown={handleTreeKeyDown}\n ref={treeRef}\n role=\"tree\"\n tabIndex={-1}\n >\n {showAllOption && (\n <div\n aria-selected={isAllSelected}\n className={`${baseClass}__all-option${isAllSelected ? ` ${baseClass}__all-option--selected` : ''}`}\n onClick={handleAllClick}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n handleAllClick()\n }\n }}\n role=\"treeitem\"\n tabIndex={0}\n >\n {icon || <TagIcon color=\"muted\" />}\n <span>\n {t('general:all')}{' '}\n {getTranslation(getEntityConfig({ collectionSlug })?.labels?.plural, i18n)}\n </span>\n </div>\n )}\n {rootNodes.map((node) => {\n const nodeId: number | string = node.id\n const nodeIdStr = typeof nodeId === 'number' ? String(nodeId) : nodeId\n const nodeTitle = getDocumentTitle(node, useAsTitle)\n const isSelected = nodeIdStr === String(selectedNodeId)\n\n return (\n <TreeNode\n allPossibleTypeValues={allPossibleTypeValues}\n cache={childrenCache}\n collectionSlug={collectionSlug}\n depth={0}\n expandedNodes={expandedNodes}\n filterByCollections={filterByCollections}\n key={nodeIdStr}\n limit={treeLimit}\n node={{\n id: nodeId,\n hasChildren: true,\n title: nodeTitle,\n }}\n onSelect={handleNodeClick}\n onToggle={toggleNode}\n parentFieldName={parentFieldName}\n selected={isSelected}\n selectedNodeId={selectedNodeId}\n typeFieldName={typeFieldName}\n useAsTitle={useAsTitle}\n />\n )\n })}\n {hasMore && (\n <LoadMore\n currentCount={rootNodes.length}\n depth={0}\n id=\"load-more-root\"\n onLoadMore={handleLoadMore}\n totalDocs={totalDocs}\n />\n )}\n </div>\n )\n}\n\nexport const Tree: React.FC<TreeProps> = (props) => {\n return (\n <TreeFocusProvider>\n <TreeInner {...props} />\n </TreeFocusProvider>\n )\n}\n"],"mappings":"AAAA;;;AAEA,SAASA,cAAc,QAAQ;AAC/B,SAASC,SAAS,QAAQ;AAC1B,OAAOC,KAAA,IAASC,KAAK,EAAEC,OAAO,EAAEC,MAAM,QAAQ;AAI9C,SAASC,oBAAoB,QAAQ;AACrC,SAASC,cAAc,QAAQ;AAC/B,SAASC,OAAO,QAAQ;AACxB,SAASC,SAAS,QAAQ;AAC1B,SAASC,cAAc,QAAQ;AAC/B,SAASC,QAAQ,QAAQ;AACzB,SAASC,iBAAiB,EAAEC,YAAY,QAAQ;AAChD,OAAO;AACP,SAASC,QAAQ,QAAQ;AACzB,SAASC,WAAW,QAAQ;AAE5B,MAAMC,SAAA,GAAY;AAClB,MAAMC,kBAAA,GAAqB;AAE3B,MAAMC,gBAAA,GAAmBA,CAACC,GAAA,EAAmBC,UAAA;EAC3C,MAAMC,KAAA,GAAyBF,GAAA,CAAIG,EAAE;EACrC,MAAMC,KAAA,GAAQ,OAAOF,KAAA,KAAU,WAAWG,MAAA,CAAOH,KAAA,IAASA,KAAA;EAE1D,IAAI,CAACD,UAAA,EAAY;IACf,OAAOG,KAAA;EACT;EAEA,MAAME,KAAA,GAAQN,GAAG,CAACC,UAAA,CAAW;EAC7B,IAAIK,KAAA,KAAU,OAAOA,KAAA,KAAU,YAAY,OAAOA,KAAA,KAAU,QAAO,GAAI;IACrE,OAAOD,MAAA,CAAOC,KAAA;EAChB;EACA,OAAOF,KAAA;AACT;AAEA,MAAMG,SAAA,GAAiCA,CAAC;EACtCC,qBAAqB;EACrBC,cAAc;EACdC,aAAa;EACbC,mBAAmB;EACnBC,IAAI;EACJC,WAAW;EACXC,WAAW;EACXC,eAAe;EACfC,cAAc;EACdC,aAAA,GAAgB,IAAI;EACpBC,UAAU;EACVC,SAAA,GAAYrB,kBAAkB;EAC9BsB,aAAa;EACbnB;AAAU,CACX;EACC,MAAM;IAAEoB;EAAS,CAAE,GAAG3B,YAAA;EACtB,MAAM4B,MAAA,GAASxC,SAAA;EACf,MAAM;IAAEyC,IAAI;IAAEC;EAAC,CAAE,GAAGjC,cAAA;EACpB,MAAM;IAAEkC;EAAe,CAAE,GAAGnC,SAAA;EAC5B,MAAMoC,gBAAA,GAAmB,eAAe1C,KAAA,IAAS;EAEjD;EACA;EACA,MAAM2C,aAAA,GAAgBzC,MAAA,CACpBD,OAAA,CAAQ;IACN,MAAM2C,KAAA,GAAQ,IAAIC,GAAA;IAElB,IAAIhB,WAAA,IAAeA,WAAA,CAAYiB,IAAI,CAACC,MAAM,GAAG,GAAG;MAC9C;MACA,MAAMC,YAAA,GAAe,IAAIH,GAAA;MAEzB,KAAK,MAAM7B,GAAA,IAAOa,WAAA,CAAYiB,IAAI,EAAE;QAClC,MAAMG,QAAA,GAAWjC,GAAG,CAACe,eAAA,CAAgB,IAAI;QACzC,MAAMmB,SAAA,GAAY7B,MAAA,CAAO4B,QAAA;QAEzB,IAAI,CAACD,YAAA,CAAaG,GAAG,CAACD,SAAA,GAAY;UAChCF,YAAA,CAAaI,GAAG,CAACF,SAAA,EAAW,EAAE;QAChC;QACA,MAAMG,UAAA,GAAaL,YAAA,CAAaM,GAAG,CAACJ,SAAA;QACpC,IAAIG,UAAA,EAAY;UACdA,UAAA,CAAWE,IAAI,CAACvC,GAAA;QAClB;MACF;MAEA;MACA,MAAMwC,SAAA,GAAY7B,mBAAA,EAAqBoB,MAAA,GACnCpB,mBAAA,CAAoB8B,KAAK,GAAGC,IAAI,GAAGC,IAAI,CAAC,OACxC;MACJ,KAAK,MAAM,CAACT,WAAA,EAAWJ,IAAA,CAAK,IAAIE,YAAA,EAAc;QAC5C,MAAMY,QAAA,GAAW,GAAGnC,cAAA,IAAkByB,WAAA,IAAaM,SAAA,EAAW;QAC9D,MAAMK,UAAA,GAAahC,WAAA,CAAYiC,aAAa,CAACZ,WAAA,CAAU;QAEvD,IAAIW,UAAA,EAAY;UACd;UACA;UACA,MAAME,WAAA,GAAcF,UAAA,CAAWE,WAAW,IAAIjB,IAAA,CAAKC,MAAM;UACzD,MAAMiB,WAAA,GAAcC,IAAA,CAAKC,IAAI,CAACH,WAAA,GAAc5B,SAAA,KAAc;UAE1DS,KAAA,CAAMQ,GAAG,CAACQ,QAAA,EAAU;YAClBO,QAAA,EAAUrB,IAAA;YACVsB,OAAA,EAASP,UAAA,CAAWO,OAAO;YAC3BC,IAAA,EAAML,WAAA;YACNM,SAAA,EAAWT,UAAA,CAAWS;UACxB;QACF,OAAO;UACL;UACA1B,KAAA,CAAMQ,GAAG,CAACQ,QAAA,EAAU;YAClBO,QAAA,EAAUrB,IAAA;YACVsB,OAAA,EAAS;YACTC,IAAA,EAAM;YACNC,SAAA,EAAWxB,IAAA,CAAKC;UAClB;QACF;MACF;IACF;IAEA,OAAOH,KAAA;EACT,GAAG,CAACf,WAAA,EAAaF,mBAAA,EAAqBI,eAAA,EAAiBN,cAAA,EAAgBU,SAAA,CAAU;EAEnF,MAAMoC,OAAA,GAAUrE,MAAA,CAAuB;EAEvC;EACA,MAAM;IACJiE,QAAA,EAAUK,SAAS;IACnBJ,OAAO;IACPK,SAAS;IACTC,QAAA,EAAUC,gBAAgB;IAC1BC,OAAO;IACPN;EAAS,CACV,GAAG1D,WAAA,CAAY;IACdY,qBAAA;IACAoB,KAAA,EAAOD,aAAA;IACPlB,cAAA;IACAoD,OAAA,EAAS;IACTlD,mBAAA;IACAE,WAAA;IACAiD,KAAA,EAAO3C,SAAA;IACPJ,eAAA;IACAkB,QAAA,EAAU;IACVb,aAAA;IACAnB;EACF;EAEA;EACA,MAAM8D,cAAA,GAAiBhF,KAAA,CAAMiF,WAAW,CAAC;IACvC,MAAML,gBAAA;EACR,GAAG,CAACA,gBAAA,CAAiB;EAErB,MAAMM,eAAA,GAAkBA,CAAC;IAAE9D;EAAE,CAA2B;IACtD,IAAIW,WAAA,EAAa;MACfA,WAAA,CAAY;QAAEX;MAAG;IACnB;EACF;EAEA;EACA,IAAIsD,SAAA,IAAa,CAACD,SAAA,EAAW;IAC3B,oBACEU,IAAA,CAAC;MAAIC,SAAA,EAAWtE,SAAA;gBACd,aAAAqE,IAAA,CAAC9E,cAAA;QAAeS,SAAA,EAAWA,SAAA;QAAW4D,SAAA,EAAW;;;EAGvD;EAEA;EACA,IAAI,CAACD,SAAA,IAAaA,SAAA,CAAUzB,MAAM,KAAK,GAAG;IACxC,MAAMqC,eAAA,GAAkB3C,eAAA,CAAgB;MAAEhB;IAAe;IACzD,oBACEyD,IAAA,CAAC;MAAIC,SAAA,EAAWtE,SAAA;gBACd,aAAAqE,IAAA,CAAC/E,oBAAA;QACCkF,WAAA,EAAY;QACZC,WAAA,EAAa,CAAC;UAAE7D;QAAe,EAAE;QACjC8D,UAAA,EAAY7C,gBAAA;QACZ8C,KAAA,EAAOhD,CAAA,CAAE,0BAA0B;UACjCgD,KAAA,EAAO3F,cAAA,CAAeuF,eAAA,CAAgBK,MAAM,CAACC,QAAQ,EAAEnD,IAAA;QACzD;QACAoD,MAAA,EAAQ,MAAAA,CAAA;UACN,MAAMf,OAAA;UACNtC,MAAA,CAAOsC,OAAO;QAChB;;;EAIR;EAEA,MAAMgB,iBAAA,GAAqBC,CAAA;IACzB,IAAIA,CAAA,CAAEC,GAAG,KAAK,aAAa;MACzBD,CAAA,CAAEE,cAAc;MAChB1D,SAAA,CAAU;IACZ,OAAO,IAAIwD,CAAA,CAAEC,GAAG,KAAK,WAAW;MAC9BD,CAAA,CAAEE,cAAc;MAChB1D,SAAA,CAAU;IACZ;EACF;EAEA,MAAM2D,aAAA,GAAgBhE,cAAA,KAAmB;EAEzC,MAAMiE,cAAA,GAAiBA,CAAA;IACrB,IAAInE,WAAA,EAAa;MACfA,WAAA,CAAY;QAAEX,EAAA,EAAI;MAAK;IACzB;EACF;EAEA,oBACE+E,KAAA,CAAC;IACCf,SAAA,EAAWtE,SAAA;IACXsF,SAAA,EAAWP,iBAAA;IACXQ,GAAA,EAAK7B,OAAA;IACL8B,IAAA,EAAK;IACLC,QAAA,EAAU,CAAC;eAEVrE,aAAA,iBACCiE,KAAA,CAAC;MACC,iBAAeF,aAAA;MACfb,SAAA,EAAW,GAAGtE,SAAA,eAAwBmF,aAAA,GAAgB,IAAInF,SAAA,wBAAiC,GAAG,IAAI;MAClG0F,OAAA,EAASN,cAAA;MACTE,SAAA,EAAYN,GAAA;QACV,IAAIA,GAAA,CAAEC,GAAG,KAAK,WAAWD,GAAA,CAAEC,GAAG,KAAK,KAAK;UACtCD,GAAA,CAAEE,cAAc;UAChBE,cAAA;QACF;MACF;MACAI,IAAA,EAAK;MACLC,QAAA,EAAU;iBAET1E,IAAA,iBAAQsD,IAAA,CAAC7E,OAAA;QAAQmG,KAAA,EAAM;uBACxBN,KAAA,CAAC;mBACE1D,CAAA,CAAE,gBAAgB,KAClB3C,cAAA,CAAe4C,eAAA,CAAgB;UAAEhB;QAAe,IAAIgE,MAAA,EAAQgB,MAAA,EAAQlE,IAAA;;QAI1EiC,SAAA,CAAUkC,GAAG,CAAEC,IAAA;MACd,MAAMC,MAAA,GAA0BD,IAAA,CAAKxF,EAAE;MACvC,MAAM0F,SAAA,GAAY,OAAOD,MAAA,KAAW,WAAWvF,MAAA,CAAOuF,MAAA,IAAUA,MAAA;MAChE,MAAME,SAAA,GAAY/F,gBAAA,CAAiB4F,IAAA,EAAM1F,UAAA;MACzC,MAAM8F,UAAA,GAAaF,SAAA,KAAcxF,MAAA,CAAOW,cAAA;MAExC,oBACEkD,IAAA,CAACvE,QAAA;QACCa,qBAAA,EAAuBA,qBAAA;QACvBoB,KAAA,EAAOD,aAAA;QACPlB,cAAA,EAAgBA,cAAA;QAChBuF,KAAA,EAAO;QACPtF,aAAA,EAAeA,aAAA;QACfC,mBAAA,EAAqBA,mBAAA;QAErBmD,KAAA,EAAO3C,SAAA;QACPwE,IAAA,EAAM;UACJxF,EAAA,EAAIyF,MAAA;UACJK,WAAA,EAAa;UACbC,KAAA,EAAOJ;QACT;QACAK,QAAA,EAAUlC,eAAA;QACVmC,QAAA,EAAUlF,UAAA;QACVH,eAAA,EAAiBA,eAAA;QACjBsF,QAAA,EAAUN,UAAA;QACV/E,cAAA,EAAgBA,cAAA;QAChBI,aAAA,EAAeA,aAAA;QACfnB,UAAA,EAAYA;SAbP4F,SAAA;IAgBX,IACCzC,OAAA,iBACCc,IAAA,CAAC1E,QAAA;MACC8G,YAAA,EAAc9C,SAAA,CAAUzB,MAAM;MAC9BiE,KAAA,EAAO;MACP7F,EAAA,EAAG;MACHoG,UAAA,EAAYxC,cAAA;MACZT,SAAA,EAAWA;;;AAKrB;AAEA,OAAO,MAAMkD,IAAA,GAA6BC,KAAA;EACxC,oBACEvC,IAAA,CAACzE,iBAAA;cACC,aAAAyE,IAAA,CAAC3D,SAAA;MAAW,GAAGkG;;;AAGrB","ignoreList":[]}