@payloadcms/ui 3.80.0-internal.37a8509 → 3.80.0-internal.52ab774

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 (490) hide show
  1. package/dist/elements/BulkUpload/EditForm/index.d.ts.map +1 -1
  2. package/dist/elements/BulkUpload/EditForm/index.js +0 -12
  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 +5 -3
  6. package/dist/elements/Button/index.js.map +1 -1
  7. package/dist/elements/Button/index.scss +38 -5
  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 +0 -1
  13. package/dist/elements/CheckboxPopup/index.js.map +1 -1
  14. package/dist/elements/CheckboxPopup/index.scss +1 -0
  15. package/dist/elements/CreateDocumentButton/index.d.ts +26 -0
  16. package/dist/elements/CreateDocumentButton/index.d.ts.map +1 -0
  17. package/dist/elements/CreateDocumentButton/index.js +182 -0
  18. package/dist/elements/CreateDocumentButton/index.js.map +1 -0
  19. package/dist/elements/DefaultListViewTabs/index.d.ts.map +1 -1
  20. package/dist/elements/DefaultListViewTabs/index.js +28 -54
  21. package/dist/elements/DefaultListViewTabs/index.js.map +1 -1
  22. package/dist/elements/DelayedSpinner/index.d.ts +23 -0
  23. package/dist/elements/DelayedSpinner/index.d.ts.map +1 -0
  24. package/dist/elements/DelayedSpinner/index.js +61 -0
  25. package/dist/elements/DelayedSpinner/index.js.map +1 -0
  26. package/dist/elements/DocumentControls/index.d.ts +1 -0
  27. package/dist/elements/DocumentControls/index.d.ts.map +1 -1
  28. package/dist/elements/DocumentControls/index.js +6 -10
  29. package/dist/elements/DocumentControls/index.js.map +1 -1
  30. package/dist/elements/DocumentControls/index.scss +1 -1
  31. package/dist/elements/DocumentDrawer/index.d.ts.map +1 -1
  32. package/dist/elements/DocumentDrawer/index.js +54 -141
  33. package/dist/elements/DocumentDrawer/index.js.map +1 -1
  34. package/dist/elements/DocumentDrawer/types.d.ts +7 -1
  35. package/dist/elements/DocumentDrawer/types.d.ts.map +1 -1
  36. package/dist/elements/DocumentDrawer/types.js.map +1 -1
  37. package/dist/elements/DrawerActionHeader/index.d.ts.map +1 -1
  38. package/dist/elements/DrawerActionHeader/index.js +2 -0
  39. package/dist/elements/DrawerActionHeader/index.js.map +1 -1
  40. package/dist/elements/DrawerActionHeader/index.scss +2 -2
  41. package/dist/elements/Hierarchy/ColumnBrowser/Column/index.d.ts +5 -0
  42. package/dist/elements/Hierarchy/ColumnBrowser/Column/index.d.ts.map +1 -0
  43. package/dist/elements/Hierarchy/ColumnBrowser/Column/index.js +166 -0
  44. package/dist/elements/Hierarchy/ColumnBrowser/Column/index.js.map +1 -0
  45. package/dist/elements/Hierarchy/ColumnBrowser/Column/index.scss +63 -0
  46. package/dist/elements/Hierarchy/ColumnBrowser/ColumnItem/index.d.ts +5 -0
  47. package/dist/elements/Hierarchy/ColumnBrowser/ColumnItem/index.d.ts.map +1 -0
  48. package/dist/elements/Hierarchy/ColumnBrowser/ColumnItem/index.js +161 -0
  49. package/dist/elements/Hierarchy/ColumnBrowser/ColumnItem/index.js.map +1 -0
  50. package/dist/elements/Hierarchy/ColumnBrowser/ColumnItem/index.scss +105 -0
  51. package/dist/elements/Hierarchy/ColumnBrowser/index.d.ts +8 -0
  52. package/dist/elements/Hierarchy/ColumnBrowser/index.d.ts.map +1 -0
  53. package/dist/elements/Hierarchy/ColumnBrowser/index.js +473 -0
  54. package/dist/elements/Hierarchy/ColumnBrowser/index.js.map +1 -0
  55. package/dist/elements/Hierarchy/ColumnBrowser/index.scss +20 -0
  56. package/dist/elements/Hierarchy/ColumnBrowser/types.d.ts +106 -0
  57. package/dist/elements/Hierarchy/ColumnBrowser/types.d.ts.map +1 -0
  58. package/dist/elements/Hierarchy/ColumnBrowser/types.js +2 -0
  59. package/dist/elements/Hierarchy/ColumnBrowser/types.js.map +1 -0
  60. package/dist/elements/Hierarchy/DocHeaderButton/index.d.ts +11 -0
  61. package/dist/elements/Hierarchy/DocHeaderButton/index.d.ts.map +1 -0
  62. package/dist/elements/Hierarchy/DocHeaderButton/index.js +126 -0
  63. package/dist/elements/Hierarchy/DocHeaderButton/index.js.map +1 -0
  64. package/dist/elements/{FolderView/MoveDocToFolder → Hierarchy/DocHeaderButton}/index.scss +7 -1
  65. package/dist/elements/Hierarchy/DocHeaderButton/index.server.d.ts +10 -0
  66. package/dist/elements/Hierarchy/DocHeaderButton/index.server.d.ts.map +1 -0
  67. package/dist/elements/Hierarchy/DocHeaderButton/index.server.js +34 -0
  68. package/dist/elements/Hierarchy/DocHeaderButton/index.server.js.map +1 -0
  69. package/dist/elements/Hierarchy/Drawer/fetchAncestorPath.d.ts +15 -0
  70. package/dist/elements/Hierarchy/Drawer/fetchAncestorPath.d.ts.map +1 -0
  71. package/dist/elements/Hierarchy/Drawer/fetchAncestorPath.js +60 -0
  72. package/dist/elements/Hierarchy/Drawer/fetchAncestorPath.js.map +1 -0
  73. package/dist/elements/Hierarchy/Drawer/index.d.ts +20 -0
  74. package/dist/elements/Hierarchy/Drawer/index.d.ts.map +1 -0
  75. package/dist/elements/Hierarchy/Drawer/index.js +291 -0
  76. package/dist/elements/Hierarchy/Drawer/index.js.map +1 -0
  77. package/dist/elements/Hierarchy/Drawer/index.scss +81 -0
  78. package/dist/elements/Hierarchy/Drawer/types.d.ts +68 -0
  79. package/dist/elements/Hierarchy/Drawer/types.d.ts.map +1 -0
  80. package/dist/elements/Hierarchy/Drawer/types.js +3 -0
  81. package/dist/elements/Hierarchy/Drawer/types.js.map +1 -0
  82. package/dist/elements/Hierarchy/Drawer/useHierarchyDrawer.d.ts +30 -0
  83. package/dist/elements/Hierarchy/Drawer/useHierarchyDrawer.d.ts.map +1 -0
  84. package/dist/elements/Hierarchy/Drawer/useHierarchyDrawer.js +148 -0
  85. package/dist/elements/Hierarchy/Drawer/useHierarchyDrawer.js.map +1 -0
  86. package/dist/elements/Hierarchy/Field/SelectedHierarchies.d.ts +13 -0
  87. package/dist/elements/Hierarchy/Field/SelectedHierarchies.d.ts.map +1 -0
  88. package/dist/elements/Hierarchy/Field/SelectedHierarchies.js +185 -0
  89. package/dist/elements/Hierarchy/Field/SelectedHierarchies.js.map +1 -0
  90. package/dist/elements/Hierarchy/Field/SelectedHierarchies.scss +78 -0
  91. package/dist/elements/Hierarchy/Field/index.client.d.ts +8 -0
  92. package/dist/elements/Hierarchy/Field/index.client.d.ts.map +1 -0
  93. package/dist/elements/Hierarchy/Field/index.client.js +186 -0
  94. package/dist/elements/Hierarchy/Field/index.client.js.map +1 -0
  95. package/dist/elements/Hierarchy/Field/index.scss +35 -0
  96. package/dist/elements/Hierarchy/Field/index.server.d.ts +3 -0
  97. package/dist/elements/Hierarchy/Field/index.server.d.ts.map +1 -0
  98. package/dist/elements/Hierarchy/Field/index.server.js +30 -0
  99. package/dist/elements/Hierarchy/Field/index.server.js.map +1 -0
  100. package/dist/elements/Hierarchy/HydrateProvider/index.d.ts +4 -0
  101. package/dist/elements/Hierarchy/HydrateProvider/index.d.ts.map +1 -0
  102. package/dist/elements/Hierarchy/HydrateProvider/index.js +70 -0
  103. package/dist/elements/Hierarchy/HydrateProvider/index.js.map +1 -0
  104. package/dist/elements/Hierarchy/MoveMany/index.d.ts +22 -0
  105. package/dist/elements/Hierarchy/MoveMany/index.d.ts.map +1 -0
  106. package/dist/elements/Hierarchy/MoveMany/index.js +278 -0
  107. package/dist/elements/Hierarchy/MoveMany/index.js.map +1 -0
  108. package/dist/elements/Hierarchy/MoveMany/index.scss +7 -0
  109. package/dist/elements/Hierarchy/Search/HierarchySearchInput.d.ts +18 -0
  110. package/dist/elements/Hierarchy/Search/HierarchySearchInput.d.ts.map +1 -0
  111. package/dist/elements/Hierarchy/Search/HierarchySearchInput.js +115 -0
  112. package/dist/elements/Hierarchy/Search/HierarchySearchInput.js.map +1 -0
  113. package/dist/elements/Hierarchy/Search/HierarchySearchResultItem.d.ts +13 -0
  114. package/dist/elements/Hierarchy/Search/HierarchySearchResultItem.d.ts.map +1 -0
  115. package/dist/elements/Hierarchy/Search/HierarchySearchResultItem.js +88 -0
  116. package/dist/elements/Hierarchy/Search/HierarchySearchResultItem.js.map +1 -0
  117. package/dist/elements/Hierarchy/Search/HierarchySearchResults.d.ts +17 -0
  118. package/dist/elements/Hierarchy/Search/HierarchySearchResults.d.ts.map +1 -0
  119. package/dist/elements/Hierarchy/Search/HierarchySearchResults.js +85 -0
  120. package/dist/elements/Hierarchy/Search/HierarchySearchResults.js.map +1 -0
  121. package/dist/elements/Hierarchy/Search/index.d.ts +10 -0
  122. package/dist/elements/Hierarchy/Search/index.d.ts.map +1 -0
  123. package/dist/elements/Hierarchy/Search/index.js +144 -0
  124. package/dist/elements/Hierarchy/Search/index.js.map +1 -0
  125. package/dist/elements/Hierarchy/Search/index.scss +212 -0
  126. package/dist/elements/Hierarchy/Search/types.d.ts +21 -0
  127. package/dist/elements/Hierarchy/Search/types.d.ts.map +1 -0
  128. package/dist/elements/Hierarchy/Search/types.js +2 -0
  129. package/dist/elements/Hierarchy/Search/types.js.map +1 -0
  130. package/dist/elements/Hierarchy/Search/useHierarchySearch.d.ts +20 -0
  131. package/dist/elements/Hierarchy/Search/useHierarchySearch.d.ts.map +1 -0
  132. package/dist/elements/Hierarchy/Search/useHierarchySearch.js +122 -0
  133. package/dist/elements/Hierarchy/Search/useHierarchySearch.js.map +1 -0
  134. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.d.ts +21 -0
  135. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.d.ts.map +1 -0
  136. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.js +194 -0
  137. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.js.map +1 -0
  138. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.server.d.ts +7 -0
  139. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.server.d.ts.map +1 -0
  140. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.server.js +177 -0
  141. package/dist/elements/Hierarchy/Tree/HierarchySidebarTab.server.js.map +1 -0
  142. package/dist/elements/Hierarchy/Tree/LoadMore/LoadMoreButton.d.ts +8 -0
  143. package/dist/elements/Hierarchy/Tree/LoadMore/LoadMoreButton.d.ts.map +1 -0
  144. package/dist/elements/Hierarchy/Tree/LoadMore/LoadMoreButton.js +36 -0
  145. package/dist/elements/Hierarchy/Tree/LoadMore/LoadMoreButton.js.map +1 -0
  146. package/dist/elements/Hierarchy/Tree/LoadMore/index.d.ts +12 -0
  147. package/dist/elements/Hierarchy/Tree/LoadMore/index.d.ts.map +1 -0
  148. package/dist/elements/Hierarchy/Tree/LoadMore/index.js +29 -0
  149. package/dist/elements/Hierarchy/Tree/LoadMore/index.js.map +1 -0
  150. package/dist/elements/Hierarchy/Tree/LoadMore/index.scss +26 -0
  151. package/dist/elements/Hierarchy/Tree/TreeConnector.d.ts +7 -0
  152. package/dist/elements/Hierarchy/Tree/TreeConnector.d.ts.map +1 -0
  153. package/dist/elements/Hierarchy/Tree/TreeConnector.js +23 -0
  154. package/dist/elements/Hierarchy/Tree/TreeConnector.js.map +1 -0
  155. package/dist/elements/Hierarchy/Tree/TreeFocusContext.d.ts +28 -0
  156. package/dist/elements/Hierarchy/Tree/TreeFocusContext.d.ts.map +1 -0
  157. package/dist/elements/Hierarchy/Tree/TreeFocusContext.js +140 -0
  158. package/dist/elements/Hierarchy/Tree/TreeFocusContext.js.map +1 -0
  159. package/dist/elements/Hierarchy/Tree/TreeNode/index.d.ts +5 -0
  160. package/dist/elements/Hierarchy/Tree/TreeNode/index.d.ts.map +1 -0
  161. package/dist/elements/Hierarchy/Tree/TreeNode/index.js +225 -0
  162. package/dist/elements/Hierarchy/Tree/TreeNode/index.js.map +1 -0
  163. package/dist/elements/Hierarchy/Tree/TreeNode/index.scss +110 -0
  164. package/dist/elements/Hierarchy/Tree/index.d.ts +5 -0
  165. package/dist/elements/Hierarchy/Tree/index.d.ts.map +1 -0
  166. package/dist/elements/Hierarchy/Tree/index.js +305 -0
  167. package/dist/elements/Hierarchy/Tree/index.js.map +1 -0
  168. package/dist/elements/Hierarchy/Tree/index.scss +60 -0
  169. package/dist/elements/Hierarchy/Tree/types.d.ts +76 -0
  170. package/dist/elements/Hierarchy/Tree/types.d.ts.map +1 -0
  171. package/dist/elements/Hierarchy/Tree/types.js +2 -0
  172. package/dist/elements/Hierarchy/Tree/types.js.map +1 -0
  173. package/dist/elements/Hierarchy/Tree/useChildren.d.ts +32 -0
  174. package/dist/elements/Hierarchy/Tree/useChildren.d.ts.map +1 -0
  175. package/dist/elements/Hierarchy/Tree/useChildren.js +233 -0
  176. package/dist/elements/Hierarchy/Tree/useChildren.js.map +1 -0
  177. package/dist/elements/Link/index.d.ts +4 -0
  178. package/dist/elements/Link/index.d.ts.map +1 -1
  179. package/dist/elements/Link/index.js +5 -0
  180. package/dist/elements/Link/index.js.map +1 -1
  181. package/dist/elements/ListHeader/TitleActions/index.d.ts +0 -1
  182. package/dist/elements/ListHeader/TitleActions/index.d.ts.map +1 -1
  183. package/dist/elements/ListHeader/TitleActions/index.js +0 -1
  184. package/dist/elements/ListHeader/TitleActions/index.js.map +1 -1
  185. package/dist/elements/ListHeader/index.js +2 -2
  186. package/dist/elements/ListHeader/index.js.map +1 -1
  187. package/dist/elements/ListSelection/index.scss +2 -1
  188. package/dist/elements/LoadMoreRow/index.d.ts +15 -0
  189. package/dist/elements/LoadMoreRow/index.d.ts.map +1 -0
  190. package/dist/elements/LoadMoreRow/index.js +75 -0
  191. package/dist/elements/LoadMoreRow/index.js.map +1 -0
  192. package/dist/elements/LoadMoreRow/index.scss +42 -0
  193. package/dist/elements/Locked/index.scss +1 -1
  194. package/dist/elements/RelationshipTable/index.js +3 -3
  195. package/dist/elements/RelationshipTable/index.js.map +1 -1
  196. package/dist/elements/Spinner/index.d.ts +16 -0
  197. package/dist/elements/Spinner/index.d.ts.map +1 -0
  198. package/dist/elements/Spinner/index.js +49 -0
  199. package/dist/elements/Spinner/index.js.map +1 -0
  200. package/dist/elements/Spinner/index.scss +39 -0
  201. package/dist/elements/StepNav/index.d.ts.map +1 -1
  202. package/dist/elements/StepNav/index.js +10 -1
  203. package/dist/elements/StepNav/index.js.map +1 -1
  204. package/dist/elements/StepNav/types.d.ts +1 -0
  205. package/dist/elements/StepNav/types.d.ts.map +1 -1
  206. package/dist/elements/StepNav/types.js.map +1 -1
  207. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.d.ts +6 -0
  208. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.d.ts.map +1 -0
  209. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.js +187 -0
  210. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.js.map +1 -0
  211. package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.scss +29 -0
  212. package/dist/elements/Table/DefaultCell/index.d.ts.map +1 -1
  213. package/dist/elements/Table/DefaultCell/index.js +20 -0
  214. package/dist/elements/Table/DefaultCell/index.js.map +1 -1
  215. package/dist/elements/Tooltip/index.js +1 -1
  216. package/dist/elements/Tooltip/index.js.map +1 -1
  217. package/dist/elements/Tooltip/index.scss +1 -15
  218. package/dist/elements/withMergedProps/index.d.ts +1 -1
  219. package/dist/elements/withMergedProps/index.js +1 -1
  220. package/dist/elements/withMergedProps/index.js.map +1 -1
  221. package/dist/exports/client/index.d.ts +26 -9
  222. package/dist/exports/client/index.d.ts.map +1 -1
  223. package/dist/exports/client/index.js +14 -12
  224. package/dist/exports/client/index.js.map +4 -4
  225. package/dist/exports/rsc/index.d.ts +3 -3
  226. package/dist/exports/rsc/index.d.ts.map +1 -1
  227. package/dist/exports/rsc/index.js +3 -3
  228. package/dist/exports/rsc/index.js.map +1 -1
  229. package/dist/exports/shared/index.js.map +1 -1
  230. package/dist/fields/Join/index.d.ts.map +1 -1
  231. package/dist/fields/Join/index.js +1 -1
  232. package/dist/fields/Join/index.js.map +1 -1
  233. package/dist/fields/Null/index.d.ts +11 -0
  234. package/dist/fields/Null/index.d.ts.map +1 -0
  235. package/dist/fields/Null/index.js +13 -0
  236. package/dist/fields/Null/index.js.map +1 -0
  237. package/dist/icons/Chevron/index.d.ts.map +1 -1
  238. package/dist/icons/Chevron/index.js +5 -1
  239. package/dist/icons/Chevron/index.js.map +1 -1
  240. package/dist/icons/Document/index.d.ts +3 -1
  241. package/dist/icons/Document/index.d.ts.map +1 -1
  242. package/dist/icons/Document/index.js +4 -2
  243. package/dist/icons/Document/index.js.map +1 -1
  244. package/dist/icons/Document/index.scss +4 -0
  245. package/dist/icons/Filter/index.d.ts +4 -0
  246. package/dist/icons/Filter/index.d.ts.map +1 -0
  247. package/dist/icons/Filter/index.js +15 -0
  248. package/dist/icons/Filter/index.js.map +1 -0
  249. package/dist/icons/Filter/index.scss +13 -0
  250. package/dist/icons/Folder/index.d.ts +4 -2
  251. package/dist/icons/Folder/index.d.ts.map +1 -1
  252. package/dist/icons/Folder/index.js +4 -2
  253. package/dist/icons/Folder/index.js.map +1 -1
  254. package/dist/icons/Folder/index.scss +8 -0
  255. package/dist/icons/Lock/index.scss +1 -1
  256. package/dist/icons/Plus/index.d.ts.map +1 -1
  257. package/dist/icons/Plus/index.js +2 -1
  258. package/dist/icons/Plus/index.js.map +1 -1
  259. package/dist/icons/TableView/index.d.ts +3 -0
  260. package/dist/icons/TableView/index.d.ts.map +1 -0
  261. package/dist/icons/TableView/index.js +16 -0
  262. package/dist/icons/TableView/index.js.map +1 -0
  263. package/dist/icons/Tag/index.d.ts +8 -0
  264. package/dist/icons/Tag/index.d.ts.map +1 -0
  265. package/dist/icons/Tag/index.js +22 -0
  266. package/dist/icons/Tag/index.js.map +1 -0
  267. package/dist/icons/Tag/index.scss +14 -0
  268. package/dist/providers/DocumentSelection/index.d.ts +8 -0
  269. package/dist/providers/DocumentSelection/index.d.ts.map +1 -0
  270. package/dist/providers/DocumentSelection/index.js +239 -0
  271. package/dist/providers/DocumentSelection/index.js.map +1 -0
  272. package/dist/providers/DocumentSelection/types.d.ts +122 -0
  273. package/dist/providers/DocumentSelection/types.d.ts.map +1 -0
  274. package/dist/providers/DocumentSelection/types.js +5 -0
  275. package/dist/providers/DocumentSelection/types.js.map +1 -0
  276. package/dist/providers/Hierarchy/index.d.ts +5 -0
  277. package/dist/providers/Hierarchy/index.d.ts.map +1 -0
  278. package/dist/providers/Hierarchy/index.js +358 -0
  279. package/dist/providers/Hierarchy/index.js.map +1 -0
  280. package/dist/providers/Hierarchy/types.d.ts +106 -0
  281. package/dist/providers/Hierarchy/types.d.ts.map +1 -0
  282. package/dist/providers/Hierarchy/types.js +2 -0
  283. package/dist/providers/Hierarchy/types.js.map +1 -0
  284. package/dist/providers/Root/index.d.ts.map +1 -1
  285. package/dist/providers/Root/index.js +18 -15
  286. package/dist/providers/Root/index.js.map +1 -1
  287. package/dist/providers/ServerFunctions/index.d.ts +1 -6
  288. package/dist/providers/ServerFunctions/index.d.ts.map +1 -1
  289. package/dist/providers/ServerFunctions/index.js +0 -18
  290. package/dist/providers/ServerFunctions/index.js.map +1 -1
  291. package/dist/providers/SidebarTabs/index.d.ts +19 -0
  292. package/dist/providers/SidebarTabs/index.d.ts.map +1 -0
  293. package/dist/providers/SidebarTabs/index.js +24 -0
  294. package/dist/providers/SidebarTabs/index.js.map +1 -0
  295. package/dist/providers/TableColumns/buildColumnState/renderCell.d.ts +2 -1
  296. package/dist/providers/TableColumns/buildColumnState/renderCell.d.ts.map +1 -1
  297. package/dist/providers/TableColumns/buildColumnState/renderCell.js +34 -1
  298. package/dist/providers/TableColumns/buildColumnState/renderCell.js.map +1 -1
  299. package/dist/styles.css +1 -1
  300. package/dist/utilities/handleLivePreview.d.ts.map +1 -1
  301. package/dist/utilities/isSuperset.d.ts +6 -0
  302. package/dist/utilities/isSuperset.d.ts.map +1 -0
  303. package/dist/utilities/isSuperset.js +10 -0
  304. package/dist/utilities/isSuperset.js.map +1 -0
  305. package/dist/utilities/renderTable.d.ts +3 -1
  306. package/dist/utilities/renderTable.d.ts.map +1 -1
  307. package/dist/utilities/renderTable.js +9 -3
  308. package/dist/utilities/renderTable.js.map +1 -1
  309. package/dist/views/Edit/index.d.ts +1 -1
  310. package/dist/views/Edit/index.d.ts.map +1 -1
  311. package/dist/views/Edit/index.js +4 -2
  312. package/dist/views/Edit/index.js.map +1 -1
  313. package/dist/views/HierarchyList/DocumentListSelection/index.d.ts +10 -0
  314. package/dist/views/HierarchyList/DocumentListSelection/index.d.ts.map +1 -0
  315. package/dist/views/HierarchyList/DocumentListSelection/index.js +196 -0
  316. package/dist/views/HierarchyList/DocumentListSelection/index.js.map +1 -0
  317. package/dist/views/HierarchyList/HierarchyListHeader/index.d.ts +21 -0
  318. package/dist/views/HierarchyList/HierarchyListHeader/index.d.ts.map +1 -0
  319. package/dist/views/HierarchyList/HierarchyListHeader/index.js +68 -0
  320. package/dist/views/HierarchyList/HierarchyListHeader/index.js.map +1 -0
  321. package/dist/views/HierarchyList/HierarchyListHeader/index.scss +9 -0
  322. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.d.ts +4 -0
  323. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.d.ts.map +1 -0
  324. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.js +104 -0
  325. package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.js.map +1 -0
  326. package/dist/views/HierarchyList/HierarchyTable/DateCell.d.ts +4 -0
  327. package/dist/views/HierarchyList/HierarchyTable/DateCell.d.ts.map +1 -0
  328. package/dist/views/HierarchyList/HierarchyTable/DateCell.js +53 -0
  329. package/dist/views/HierarchyList/HierarchyTable/DateCell.js.map +1 -0
  330. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.d.ts +4 -0
  331. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.d.ts.map +1 -0
  332. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.js +128 -0
  333. package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.js.map +1 -0
  334. package/dist/views/HierarchyList/HierarchyTable/SlotTable.d.ts +99 -0
  335. package/dist/views/HierarchyList/HierarchyTable/SlotTable.d.ts.map +1 -0
  336. package/dist/views/HierarchyList/HierarchyTable/SlotTable.js +118 -0
  337. package/dist/views/HierarchyList/HierarchyTable/SlotTable.js.map +1 -0
  338. package/dist/views/HierarchyList/HierarchyTable/SlotTable.scss +214 -0
  339. package/dist/views/HierarchyList/HierarchyTable/index.d.ts +27 -0
  340. package/dist/views/HierarchyList/HierarchyTable/index.d.ts.map +1 -0
  341. package/dist/views/HierarchyList/HierarchyTable/index.js +388 -0
  342. package/dist/views/HierarchyList/HierarchyTable/index.js.map +1 -0
  343. package/dist/views/HierarchyList/HierarchyTable/index.scss +148 -0
  344. package/dist/views/HierarchyList/HierarchyTable/types.d.ts +20 -0
  345. package/dist/views/HierarchyList/HierarchyTable/types.d.ts.map +1 -0
  346. package/dist/views/HierarchyList/HierarchyTable/types.js +2 -0
  347. package/dist/views/HierarchyList/HierarchyTable/types.js.map +1 -0
  348. package/dist/views/HierarchyList/TypeFilter/index.d.ts +15 -0
  349. package/dist/views/HierarchyList/TypeFilter/index.d.ts.map +1 -0
  350. package/dist/views/HierarchyList/TypeFilter/index.js +37 -0
  351. package/dist/views/HierarchyList/TypeFilter/index.js.map +1 -0
  352. package/dist/views/HierarchyList/TypeFilter/index.scss +32 -0
  353. package/dist/views/HierarchyList/index.d.ts +5 -0
  354. package/dist/views/HierarchyList/index.d.ts.map +1 -0
  355. package/dist/views/HierarchyList/index.js +305 -0
  356. package/dist/views/HierarchyList/index.js.map +1 -0
  357. package/dist/views/HierarchyList/index.scss +72 -0
  358. package/dist/views/List/index.d.ts.map +1 -1
  359. package/dist/views/List/index.js +51 -7
  360. package/dist/views/List/index.js.map +1 -1
  361. package/package.json +4 -4
  362. package/dist/elements/FolderView/Breadcrumbs/index.d.ts +0 -19
  363. package/dist/elements/FolderView/Breadcrumbs/index.d.ts.map +0 -1
  364. package/dist/elements/FolderView/Breadcrumbs/index.js +0 -96
  365. package/dist/elements/FolderView/Breadcrumbs/index.js.map +0 -1
  366. package/dist/elements/FolderView/Breadcrumbs/index.scss +0 -56
  367. package/dist/elements/FolderView/BrowseByFolderButton/index.d.ts +0 -6
  368. package/dist/elements/FolderView/BrowseByFolderButton/index.d.ts.map +0 -1
  369. package/dist/elements/FolderView/BrowseByFolderButton/index.js +0 -40
  370. package/dist/elements/FolderView/BrowseByFolderButton/index.js.map +0 -1
  371. package/dist/elements/FolderView/BrowseByFolderButton/index.scss +0 -30
  372. package/dist/elements/FolderView/Cell/index.client.d.ts +0 -13
  373. package/dist/elements/FolderView/Cell/index.client.d.ts.map +0 -1
  374. package/dist/elements/FolderView/Cell/index.client.js +0 -95
  375. package/dist/elements/FolderView/Cell/index.client.js.map +0 -1
  376. package/dist/elements/FolderView/Cell/index.server.d.ts +0 -4
  377. package/dist/elements/FolderView/Cell/index.server.d.ts.map +0 -1
  378. package/dist/elements/FolderView/Cell/index.server.js +0 -18
  379. package/dist/elements/FolderView/Cell/index.server.js.map +0 -1
  380. package/dist/elements/FolderView/ColoredFolderIcon/index.d.ts +0 -3
  381. package/dist/elements/FolderView/ColoredFolderIcon/index.d.ts.map +0 -1
  382. package/dist/elements/FolderView/ColoredFolderIcon/index.js +0 -9
  383. package/dist/elements/FolderView/ColoredFolderIcon/index.js.map +0 -1
  384. package/dist/elements/FolderView/ColoredFolderIcon/index.scss +0 -5
  385. package/dist/elements/FolderView/CurrentFolderActions/index.d.ts +0 -7
  386. package/dist/elements/FolderView/CurrentFolderActions/index.d.ts.map +0 -1
  387. package/dist/elements/FolderView/CurrentFolderActions/index.js +0 -162
  388. package/dist/elements/FolderView/CurrentFolderActions/index.js.map +0 -1
  389. package/dist/elements/FolderView/DragOverlaySelection/index.d.ts +0 -11
  390. package/dist/elements/FolderView/DragOverlaySelection/index.d.ts.map +0 -1
  391. package/dist/elements/FolderView/DragOverlaySelection/index.js +0 -62
  392. package/dist/elements/FolderView/DragOverlaySelection/index.js.map +0 -1
  393. package/dist/elements/FolderView/DragOverlaySelection/index.scss +0 -35
  394. package/dist/elements/FolderView/DraggableTableRow/index.d.ts +0 -18
  395. package/dist/elements/FolderView/DraggableTableRow/index.d.ts.map +0 -1
  396. package/dist/elements/FolderView/DraggableTableRow/index.js +0 -63
  397. package/dist/elements/FolderView/DraggableTableRow/index.js.map +0 -1
  398. package/dist/elements/FolderView/DraggableTableRow/index.scss +0 -135
  399. package/dist/elements/FolderView/DraggableWithClick/index.d.ts +0 -15
  400. package/dist/elements/FolderView/DraggableWithClick/index.d.ts.map +0 -1
  401. package/dist/elements/FolderView/DraggableWithClick/index.js +0 -86
  402. package/dist/elements/FolderView/DraggableWithClick/index.js.map +0 -1
  403. package/dist/elements/FolderView/DraggableWithClick/index.scss +0 -5
  404. package/dist/elements/FolderView/Drawers/EditFolderAction/index.d.ts +0 -7
  405. package/dist/elements/FolderView/Drawers/EditFolderAction/index.d.ts.map +0 -1
  406. package/dist/elements/FolderView/Drawers/EditFolderAction/index.js +0 -39
  407. package/dist/elements/FolderView/Drawers/EditFolderAction/index.js.map +0 -1
  408. package/dist/elements/FolderView/Drawers/MoveToFolder/index.d.ts +0 -37
  409. package/dist/elements/FolderView/Drawers/MoveToFolder/index.d.ts.map +0 -1
  410. package/dist/elements/FolderView/Drawers/MoveToFolder/index.js +0 -609
  411. package/dist/elements/FolderView/Drawers/MoveToFolder/index.js.map +0 -1
  412. package/dist/elements/FolderView/Drawers/MoveToFolder/index.scss +0 -30
  413. package/dist/elements/FolderView/FilterFolderTypePill/index.d.ts +0 -4
  414. package/dist/elements/FolderView/FilterFolderTypePill/index.d.ts.map +0 -1
  415. package/dist/elements/FolderView/FilterFolderTypePill/index.js +0 -102
  416. package/dist/elements/FolderView/FilterFolderTypePill/index.js.map +0 -1
  417. package/dist/elements/FolderView/FilterFolderTypePill/index.scss +0 -16
  418. package/dist/elements/FolderView/FolderField/index.scss +0 -12
  419. package/dist/elements/FolderView/FolderField/index.server.d.ts +0 -4
  420. package/dist/elements/FolderView/FolderField/index.server.d.ts.map +0 -1
  421. package/dist/elements/FolderView/FolderField/index.server.js +0 -16
  422. package/dist/elements/FolderView/FolderField/index.server.js.map +0 -1
  423. package/dist/elements/FolderView/FolderFileCard/index.d.ts +0 -30
  424. package/dist/elements/FolderView/FolderFileCard/index.d.ts.map +0 -1
  425. package/dist/elements/FolderView/FolderFileCard/index.js +0 -209
  426. package/dist/elements/FolderView/FolderFileCard/index.js.map +0 -1
  427. package/dist/elements/FolderView/FolderFileCard/index.scss +0 -247
  428. package/dist/elements/FolderView/FolderFileTable/index.d.ts +0 -8
  429. package/dist/elements/FolderView/FolderFileTable/index.d.ts.map +0 -1
  430. package/dist/elements/FolderView/FolderFileTable/index.js +0 -284
  431. package/dist/elements/FolderView/FolderFileTable/index.js.map +0 -1
  432. package/dist/elements/FolderView/FolderFileTable/index.scss +0 -11
  433. package/dist/elements/FolderView/FolderTypeField/index.d.ts +0 -4
  434. package/dist/elements/FolderView/FolderTypeField/index.d.ts.map +0 -1
  435. package/dist/elements/FolderView/FolderTypeField/index.js +0 -123
  436. package/dist/elements/FolderView/FolderTypeField/index.js.map +0 -1
  437. package/dist/elements/FolderView/ItemCardGrid/index.d.ts +0 -16
  438. package/dist/elements/FolderView/ItemCardGrid/index.d.ts.map +0 -1
  439. package/dist/elements/FolderView/ItemCardGrid/index.js +0 -34
  440. package/dist/elements/FolderView/ItemCardGrid/index.js.map +0 -1
  441. package/dist/elements/FolderView/ItemCardGrid/index.scss +0 -16
  442. package/dist/elements/FolderView/MoveDocToFolder/index.d.ts +0 -37
  443. package/dist/elements/FolderView/MoveDocToFolder/index.d.ts.map +0 -1
  444. package/dist/elements/FolderView/MoveDocToFolder/index.js +0 -292
  445. package/dist/elements/FolderView/MoveDocToFolder/index.js.map +0 -1
  446. package/dist/elements/FolderView/SimpleTable/index.d.ts +0 -19
  447. package/dist/elements/FolderView/SimpleTable/index.d.ts.map +0 -1
  448. package/dist/elements/FolderView/SimpleTable/index.js +0 -95
  449. package/dist/elements/FolderView/SimpleTable/index.js.map +0 -1
  450. package/dist/elements/FolderView/SimpleTable/index.scss +0 -59
  451. package/dist/elements/FolderView/SortByPill/index.d.ts +0 -4
  452. package/dist/elements/FolderView/SortByPill/index.d.ts.map +0 -1
  453. package/dist/elements/FolderView/SortByPill/index.js +0 -112
  454. package/dist/elements/FolderView/SortByPill/index.js.map +0 -1
  455. package/dist/elements/FolderView/SortByPill/index.scss +0 -16
  456. package/dist/elements/FolderView/ToggleViewButtons/index.d.ts +0 -8
  457. package/dist/elements/FolderView/ToggleViewButtons/index.d.ts.map +0 -1
  458. package/dist/elements/FolderView/ToggleViewButtons/index.js +0 -31
  459. package/dist/elements/FolderView/ToggleViewButtons/index.js.map +0 -1
  460. package/dist/elements/FolderView/ToggleViewButtons/index.scss +0 -17
  461. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.d.ts +0 -15
  462. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.d.ts.map +0 -1
  463. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js +0 -182
  464. package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js.map +0 -1
  465. package/dist/providers/Folders/groupItemIDsByRelation.d.ts +0 -3
  466. package/dist/providers/Folders/groupItemIDsByRelation.d.ts.map +0 -1
  467. package/dist/providers/Folders/groupItemIDsByRelation.js +0 -10
  468. package/dist/providers/Folders/groupItemIDsByRelation.js.map +0 -1
  469. package/dist/providers/Folders/index.d.ts +0 -143
  470. package/dist/providers/Folders/index.d.ts.map +0 -1
  471. package/dist/providers/Folders/index.js +0 -641
  472. package/dist/providers/Folders/index.js.map +0 -1
  473. package/dist/utilities/getFolderResultsComponentAndData.d.ts +0 -25
  474. package/dist/utilities/getFolderResultsComponentAndData.d.ts.map +0 -1
  475. package/dist/utilities/getFolderResultsComponentAndData.js +0 -135
  476. package/dist/utilities/getFolderResultsComponentAndData.js.map +0 -1
  477. package/dist/views/BrowseByFolder/index.d.ts +0 -5
  478. package/dist/views/BrowseByFolder/index.d.ts.map +0 -1
  479. package/dist/views/BrowseByFolder/index.js +0 -342
  480. package/dist/views/BrowseByFolder/index.js.map +0 -1
  481. package/dist/views/BrowseByFolder/index.scss +0 -174
  482. package/dist/views/CollectionFolder/ListSelection/index.d.ts +0 -9
  483. package/dist/views/CollectionFolder/ListSelection/index.d.ts.map +0 -1
  484. package/dist/views/CollectionFolder/ListSelection/index.js +0 -180
  485. package/dist/views/CollectionFolder/ListSelection/index.js.map +0 -1
  486. package/dist/views/CollectionFolder/index.d.ts +0 -5
  487. package/dist/views/CollectionFolder/index.d.ts.map +0 -1
  488. package/dist/views/CollectionFolder/index.js +0 -325
  489. package/dist/views/CollectionFolder/index.js.map +0 -1
  490. package/dist/views/CollectionFolder/index.scss +0 -162
@@ -0,0 +1,148 @@
1
+ 'use client';
2
+
3
+ import { jsx as _jsx } from "react/jsx-runtime";
4
+ import { createElement as _createElement } from "react";
5
+ import { useModal } from '@faceless-ui/modal';
6
+ import React, { useCallback, useId, useMemo, useRef } from 'react';
7
+ export * from './types.js';
8
+ import { useConfig } from '../../../providers/Config/index.js';
9
+ import { useEditDepth } from '../../../providers/EditDepth/index.js';
10
+ import { useHierarchy } from '../../../providers/Hierarchy/index.js';
11
+ import { DrawerToggler } from '../../Drawer/index.js';
12
+ import { baseClass, HierarchyDrawer } from './index.js';
13
+ export const formatHierarchyDrawerSlug = ({
14
+ depth,
15
+ uuid
16
+ }) => `hierarchy-drawer_${depth}_${uuid}`;
17
+ export const HierarchyDrawerToggler = ({
18
+ children,
19
+ className,
20
+ disabled,
21
+ drawerSlug,
22
+ onClick,
23
+ ...rest
24
+ }) => {
25
+ return /*#__PURE__*/_jsx(DrawerToggler, {
26
+ className: [className, `${baseClass}__toggler`].filter(Boolean).join(' '),
27
+ disabled: disabled,
28
+ onClick: onClick,
29
+ slug: drawerSlug,
30
+ ...rest,
31
+ children: children
32
+ });
33
+ };
34
+ /**
35
+ * Hook for using a hierarchy drawer for selecting hierarchy items.
36
+ *
37
+ * @example
38
+ * ```tsx
39
+ * const [HierarchyDrawer, HierarchyDrawerToggler, { closeDrawer, openDrawer }] = useHierarchyDrawer({
40
+ * collectionSlug: 'categories',
41
+ * })
42
+ *
43
+ * return (
44
+ * <>
45
+ * <HierarchyDrawer
46
+ * onSave={(selections) => console.log(selections)}
47
+ * hasMany={true}
48
+ * />
49
+ * <HierarchyDrawerToggler>Select Categories</HierarchyDrawerToggler>
50
+ * </>
51
+ * )
52
+ * ```
53
+ */
54
+ export const useHierarchyDrawer = ({
55
+ disabledIds,
56
+ filterByCollection: filterByCollectionProp,
57
+ hierarchyCollectionSlug,
58
+ Icon
59
+ }) => {
60
+ const {
61
+ getEntityConfig
62
+ } = useConfig();
63
+ const {
64
+ allowedCollections,
65
+ baseFilter
66
+ } = useHierarchy();
67
+ const collectionConfig = getEntityConfig({
68
+ collectionSlug: hierarchyCollectionSlug
69
+ });
70
+ const useAsTitle = collectionConfig?.admin?.useAsTitle;
71
+ const hierarchyConfig = collectionConfig?.hierarchy && typeof collectionConfig.hierarchy === 'object' ? collectionConfig.hierarchy : undefined;
72
+ const parentFieldName = hierarchyConfig?.parentFieldName;
73
+ // Use explicit prop if provided, otherwise fall back to allowedCollections from context
74
+ // - allowedCollections is null/undefined: no filtering (undefined)
75
+ // - allowedCollections is []: folder accepts everything, show only unrestricted destinations ([])
76
+ // - allowedCollections has values: show folders accepting those types
77
+ // Memoize to prevent new array references on every render
78
+ const filterByCollection = useMemo(() => {
79
+ if (filterByCollectionProp !== undefined) {
80
+ return filterByCollectionProp;
81
+ }
82
+ return allowedCollections !== null ? allowedCollections.map(c => c.slug) : undefined;
83
+ }, [filterByCollectionProp, allowedCollections]);
84
+ const drawerDepth = useEditDepth();
85
+ const uuid = useId();
86
+ const {
87
+ closeModal,
88
+ openModal,
89
+ toggleModal
90
+ } = useModal();
91
+ const drawerSlug = formatHierarchyDrawerSlug({
92
+ depth: drawerDepth,
93
+ uuid
94
+ });
95
+ // Store modal functions in refs to ensure stable callbacks
96
+ // This prevents re-renders when other modals (like DocumentDrawer) change state
97
+ const closeModalRef = useRef(closeModal);
98
+ const openModalRef = useRef(openModal);
99
+ const toggleModalRef = useRef(toggleModal);
100
+ closeModalRef.current = closeModal;
101
+ openModalRef.current = openModal;
102
+ toggleModalRef.current = toggleModal;
103
+ // Stable callbacks using refs - these will NEVER change
104
+ const toggleDrawer = useCallback(() => {
105
+ toggleModalRef.current(drawerSlug);
106
+ }, [drawerSlug]);
107
+ const closeDrawer = useCallback(() => {
108
+ closeModalRef.current(drawerSlug);
109
+ }, [drawerSlug]);
110
+ const openDrawer = useCallback(() => {
111
+ openModalRef.current(drawerSlug);
112
+ }, [drawerSlug]);
113
+ const MemoizedDrawer = useMemo(() => {
114
+ const DrawerComponent = props => /*#__PURE__*/_createElement(HierarchyDrawer, {
115
+ ...props,
116
+ baseFilter: baseFilter,
117
+ closeDrawer: closeDrawer,
118
+ disabledIds: disabledIds,
119
+ drawerSlug: drawerSlug,
120
+ filterByCollection: filterByCollection,
121
+ hierarchyCollectionSlug: hierarchyCollectionSlug,
122
+ Icon: Icon,
123
+ key: drawerSlug,
124
+ parentFieldName: parentFieldName,
125
+ useAsTitle: useAsTitle
126
+ });
127
+ return DrawerComponent;
128
+ }, [baseFilter, drawerSlug, closeDrawer, disabledIds, filterByCollection, Icon, parentFieldName, hierarchyCollectionSlug, useAsTitle]);
129
+ const MemoizedDrawerToggler = useMemo(() => {
130
+ const TogglerComponent = props_0 => /*#__PURE__*/_jsx(HierarchyDrawerToggler, {
131
+ ...props_0,
132
+ drawerSlug: drawerSlug
133
+ });
134
+ return TogglerComponent;
135
+ }, [drawerSlug]);
136
+ const MemoizedDrawerState = useMemo(() => ({
137
+ closeDrawer,
138
+ drawerDepth,
139
+ drawerSlug,
140
+ // Note: Not tracking isDrawerOpen to prevent re-renders when other modals change state
141
+ // Consumers needing this can use useModal() directly
142
+ isDrawerOpen: false,
143
+ openDrawer,
144
+ toggleDrawer
145
+ }), [drawerDepth, drawerSlug, toggleDrawer, closeDrawer, openDrawer]);
146
+ return [MemoizedDrawer, MemoizedDrawerToggler, MemoizedDrawerState];
147
+ };
148
+ //# sourceMappingURL=useHierarchyDrawer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useHierarchyDrawer.js","names":["useModal","React","useCallback","useId","useMemo","useRef","useConfig","useEditDepth","useHierarchy","DrawerToggler","baseClass","HierarchyDrawer","formatHierarchyDrawerSlug","depth","uuid","HierarchyDrawerToggler","children","className","disabled","drawerSlug","onClick","rest","_jsx","filter","Boolean","join","slug","useHierarchyDrawer","disabledIds","filterByCollection","filterByCollectionProp","hierarchyCollectionSlug","Icon","getEntityConfig","allowedCollections","baseFilter","collectionConfig","collectionSlug","useAsTitle","admin","hierarchyConfig","hierarchy","undefined","parentFieldName","map","c","drawerDepth","closeModal","openModal","toggleModal","closeModalRef","openModalRef","toggleModalRef","current","toggleDrawer","closeDrawer","openDrawer","MemoizedDrawer","DrawerComponent","props","_createElement","key","MemoizedDrawerToggler","TogglerComponent","MemoizedDrawerState","isDrawerOpen"],"sources":["../../../../src/elements/Hierarchy/Drawer/useHierarchyDrawer.tsx"],"sourcesContent":["'use client'\nimport { useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useId, useMemo, useRef } from 'react'\n\nimport type {\n HierarchyDrawerProps,\n HierarchyDrawerTogglerProps,\n UseHierarchyDrawer,\n} from './types.js'\n\nexport * from './types.js'\n\nimport { useConfig } from '../../../providers/Config/index.js'\nimport { useEditDepth } from '../../../providers/EditDepth/index.js'\nimport { useHierarchy } from '../../../providers/Hierarchy/index.js'\nimport { DrawerToggler } from '../../Drawer/index.js'\nimport { baseClass, HierarchyDrawer } from './index.js'\n\nexport const formatHierarchyDrawerSlug = ({\n depth,\n uuid,\n}: {\n depth: number\n uuid: string\n}): string => `hierarchy-drawer_${depth}_${uuid}`\n\nexport const HierarchyDrawerToggler: React.FC<HierarchyDrawerTogglerProps> = ({\n children,\n className,\n disabled,\n drawerSlug,\n onClick,\n ...rest\n}) => {\n return (\n <DrawerToggler\n className={[className, `${baseClass}__toggler`].filter(Boolean).join(' ')}\n disabled={disabled}\n onClick={onClick}\n slug={drawerSlug}\n {...rest}\n >\n {children}\n </DrawerToggler>\n )\n}\n\n/**\n * Hook for using a hierarchy drawer for selecting hierarchy items.\n *\n * @example\n * ```tsx\n * const [HierarchyDrawer, HierarchyDrawerToggler, { closeDrawer, openDrawer }] = useHierarchyDrawer({\n * collectionSlug: 'categories',\n * })\n *\n * return (\n * <>\n * <HierarchyDrawer\n * onSave={(selections) => console.log(selections)}\n * hasMany={true}\n * />\n * <HierarchyDrawerToggler>Select Categories</HierarchyDrawerToggler>\n * </>\n * )\n * ```\n */\nexport const useHierarchyDrawer: UseHierarchyDrawer = ({\n disabledIds,\n filterByCollection: filterByCollectionProp,\n hierarchyCollectionSlug,\n Icon,\n}) => {\n const { getEntityConfig } = useConfig()\n const { allowedCollections, baseFilter } = useHierarchy()\n const collectionConfig = getEntityConfig({ collectionSlug: hierarchyCollectionSlug })\n\n const useAsTitle = collectionConfig?.admin?.useAsTitle\n const hierarchyConfig =\n collectionConfig?.hierarchy && typeof collectionConfig.hierarchy === 'object'\n ? collectionConfig.hierarchy\n : undefined\n const parentFieldName = hierarchyConfig?.parentFieldName\n\n // Use explicit prop if provided, otherwise fall back to allowedCollections from context\n // - allowedCollections is null/undefined: no filtering (undefined)\n // - allowedCollections is []: folder accepts everything, show only unrestricted destinations ([])\n // - allowedCollections has values: show folders accepting those types\n // Memoize to prevent new array references on every render\n const filterByCollection = useMemo(() => {\n if (filterByCollectionProp !== undefined) {\n return filterByCollectionProp\n }\n return allowedCollections !== null ? allowedCollections.map((c) => c.slug) : undefined\n }, [filterByCollectionProp, allowedCollections])\n\n const drawerDepth = useEditDepth()\n const uuid = useId()\n const { closeModal, openModal, toggleModal } = useModal()\n\n const drawerSlug = formatHierarchyDrawerSlug({\n depth: drawerDepth,\n uuid,\n })\n\n // Store modal functions in refs to ensure stable callbacks\n // This prevents re-renders when other modals (like DocumentDrawer) change state\n const closeModalRef = useRef(closeModal)\n const openModalRef = useRef(openModal)\n const toggleModalRef = useRef(toggleModal)\n closeModalRef.current = closeModal\n openModalRef.current = openModal\n toggleModalRef.current = toggleModal\n\n // Stable callbacks using refs - these will NEVER change\n const toggleDrawer = useCallback(() => {\n toggleModalRef.current(drawerSlug)\n }, [drawerSlug])\n\n const closeDrawer = useCallback(() => {\n closeModalRef.current(drawerSlug)\n }, [drawerSlug])\n\n const openDrawer = useCallback(() => {\n openModalRef.current(drawerSlug)\n }, [drawerSlug])\n\n const MemoizedDrawer = useMemo(() => {\n const DrawerComponent: React.FC<HierarchyDrawerProps> = (props) => (\n <HierarchyDrawer\n {...props}\n baseFilter={baseFilter}\n closeDrawer={closeDrawer}\n disabledIds={disabledIds}\n drawerSlug={drawerSlug}\n filterByCollection={filterByCollection}\n hierarchyCollectionSlug={hierarchyCollectionSlug}\n Icon={Icon}\n key={drawerSlug}\n parentFieldName={parentFieldName}\n useAsTitle={useAsTitle}\n />\n )\n\n return DrawerComponent\n }, [\n baseFilter,\n drawerSlug,\n closeDrawer,\n disabledIds,\n filterByCollection,\n Icon,\n parentFieldName,\n hierarchyCollectionSlug,\n useAsTitle,\n ])\n\n const MemoizedDrawerToggler = useMemo(() => {\n const TogglerComponent: React.FC<Omit<HierarchyDrawerTogglerProps, 'drawerSlug'>> = (props) => (\n <HierarchyDrawerToggler {...props} drawerSlug={drawerSlug} />\n )\n\n return TogglerComponent\n }, [drawerSlug])\n\n const MemoizedDrawerState = useMemo(\n () => ({\n closeDrawer,\n drawerDepth,\n drawerSlug,\n // Note: Not tracking isDrawerOpen to prevent re-renders when other modals change state\n // Consumers needing this can use useModal() directly\n isDrawerOpen: false,\n openDrawer,\n toggleDrawer,\n }),\n [drawerDepth, drawerSlug, toggleDrawer, closeDrawer, openDrawer],\n )\n\n return [MemoizedDrawer, MemoizedDrawerToggler, MemoizedDrawerState]\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import './SelectedHierarchies.scss';
3
+ export type SelectedHierarchiesProps = {
4
+ hierarchySlug: string;
5
+ Icon?: React.ReactNode;
6
+ onRemove: ({ id }: {
7
+ id: number | string;
8
+ }) => void;
9
+ readOnly?: boolean;
10
+ selectedIds: (number | string)[];
11
+ };
12
+ export declare const SelectedHierarchies: React.FC<SelectedHierarchiesProps>;
13
+ //# sourceMappingURL=SelectedHierarchies.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectedHierarchies.d.ts","sourceRoot":"","sources":["../../../../src/elements/Hierarchy/Field/SelectedHierarchies.tsx"],"names":[],"mappings":"AAGA,OAAO,KAA+C,MAAM,OAAO,CAAA;AAOnE,OAAO,4BAA4B,CAAA;AASnC,MAAM,MAAM,wBAAwB,GAAG;IACrC,aAAa,EAAE,MAAM,CAAA;IACrB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,QAAQ,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE;QAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,KAAK,IAAI,CAAA;IACnD,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,WAAW,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAA;CACjC,CAAA;AAED,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,wBAAwB,CA8HlE,CAAA"}
@@ -0,0 +1,185 @@
1
+ 'use client';
2
+
3
+ import { c as _c } from "react/compiler-runtime";
4
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
5
+ import { formatAdminURL } from 'payload/shared';
6
+ import * as qs from 'qs-esm';
7
+ import React, { useEffect, useMemo, useRef, useState } from 'react';
8
+ import { XIcon } from '../../../icons/X/index.js';
9
+ import { useConfig } from '../../../providers/Config/index.js';
10
+ import { useTranslation } from '../../../providers/Translation/index.js';
11
+ import { Pill } from '../../Pill/index.js';
12
+ import { Spinner } from '../../Spinner/index.js';
13
+ import './SelectedHierarchies.scss';
14
+ const baseClass = 'selected-hierarchies';
15
+ export const SelectedHierarchies = ({
16
+ hierarchySlug,
17
+ Icon,
18
+ onRemove,
19
+ readOnly = false,
20
+ selectedIds
21
+ }) => {
22
+ const {
23
+ config,
24
+ getEntityConfig
25
+ } = useConfig();
26
+ const {
27
+ i18n
28
+ } = useTranslation();
29
+ const [items, setItems] = useState([]);
30
+ const [isInitialLoad, setIsInitialLoad] = useState(true);
31
+ const prevSelectedIdsRef = useRef('');
32
+ const {
33
+ routes: {
34
+ api
35
+ },
36
+ serverURL
37
+ } = config;
38
+ const collectionConfig = getEntityConfig({
39
+ collectionSlug: hierarchySlug
40
+ });
41
+ const selectedIdsKey = useMemo(() => selectedIds.slice().sort().join(','), [selectedIds]);
42
+ useEffect(() => {
43
+ if (!selectedIds || selectedIds.length === 0) {
44
+ setItems([]);
45
+ setIsInitialLoad(false);
46
+ return;
47
+ }
48
+ if (prevSelectedIdsRef.current === selectedIdsKey) {
49
+ return;
50
+ }
51
+ prevSelectedIdsRef.current = selectedIdsKey;
52
+ const fetchItems = async () => {
53
+ const useAsTitle = collectionConfig?.admin?.useAsTitle || 'id';
54
+ const query = {
55
+ depth: 0,
56
+ limit: selectedIds.length,
57
+ select: {
58
+ [useAsTitle]: true
59
+ },
60
+ where: {
61
+ id: {
62
+ in: selectedIds
63
+ }
64
+ }
65
+ };
66
+ const queryString = qs.stringify(query);
67
+ try {
68
+ const url = formatAdminURL({
69
+ apiRoute: api,
70
+ path: `/${hierarchySlug}?${queryString}`,
71
+ serverURL
72
+ });
73
+ const response = await fetch(url, {
74
+ credentials: 'include',
75
+ headers: {
76
+ 'Accept-Language': i18n.language
77
+ }
78
+ });
79
+ if (response.ok) {
80
+ const data = await response.json();
81
+ const fetchedItems = data.docs.map(doc => {
82
+ const docId = doc.id;
83
+ const titleValue = doc[useAsTitle] ?? docId;
84
+ const title = typeof titleValue === 'string' || typeof titleValue === 'number' ? String(titleValue) : String(docId);
85
+ return {
86
+ id: docId,
87
+ title
88
+ };
89
+ });
90
+ // Order by selectedIds to preserve selection order
91
+ const orderedItems = selectedIds.map(id => fetchedItems.find(item => item.id === id)).filter(item_0 => item_0 !== undefined);
92
+ setItems(orderedItems);
93
+ }
94
+ } catch {
95
+ // Silently fail - items will remain empty
96
+ } finally {
97
+ setIsInitialLoad(false);
98
+ }
99
+ };
100
+ void fetchItems();
101
+ }, [selectedIds, selectedIdsKey, hierarchySlug, collectionConfig, serverURL, api, i18n.language]);
102
+ if (isInitialLoad) {
103
+ return /*#__PURE__*/_jsx("div", {
104
+ className: `${baseClass}__loading`,
105
+ children: /*#__PURE__*/_jsx(Spinner, {
106
+ size: "small"
107
+ })
108
+ });
109
+ }
110
+ if (items.length === 0) {
111
+ return null;
112
+ }
113
+ return /*#__PURE__*/_jsx("div", {
114
+ className: baseClass,
115
+ children: /*#__PURE__*/_jsx("div", {
116
+ className: `${baseClass}__pills`,
117
+ children: items.map(item_1 => /*#__PURE__*/_jsx(SelectedPill, {
118
+ Icon: Icon,
119
+ item: item_1,
120
+ onRemove: onRemove,
121
+ readOnly: readOnly
122
+ }, item_1.id))
123
+ })
124
+ });
125
+ };
126
+ const SelectedPill = t0 => {
127
+ const $ = _c(9);
128
+ const {
129
+ Icon,
130
+ item,
131
+ onRemove,
132
+ readOnly
133
+ } = t0;
134
+ const {
135
+ t
136
+ } = useTranslation();
137
+ let t1;
138
+ if ($[0] !== item.id || $[1] !== onRemove) {
139
+ t1 = e => {
140
+ e.preventDefault();
141
+ e.stopPropagation();
142
+ onRemove({
143
+ id: item.id
144
+ });
145
+ };
146
+ $[0] = item.id;
147
+ $[1] = onRemove;
148
+ $[2] = t1;
149
+ } else {
150
+ t1 = $[2];
151
+ }
152
+ const handleRemove = t1;
153
+ let t2;
154
+ if ($[3] !== Icon || $[4] !== handleRemove || $[5] !== item.title || $[6] !== readOnly || $[7] !== t) {
155
+ t2 = _jsxs(Pill, {
156
+ className: `${baseClass}__pill`,
157
+ pillStyle: "light",
158
+ size: "small",
159
+ children: [Boolean(Icon) && _jsx("span", {
160
+ className: `${baseClass}__pill-icon`,
161
+ children: Icon
162
+ }), _jsx("span", {
163
+ className: `${baseClass}__pill-label`,
164
+ children: item.title
165
+ }), _jsx("button", {
166
+ "aria-label": t("general:remove"),
167
+ className: `${baseClass}__pill-remove`,
168
+ disabled: readOnly,
169
+ onClick: readOnly ? undefined : handleRemove,
170
+ type: "button",
171
+ children: _jsx(XIcon, {})
172
+ })]
173
+ });
174
+ $[3] = Icon;
175
+ $[4] = handleRemove;
176
+ $[5] = item.title;
177
+ $[6] = readOnly;
178
+ $[7] = t;
179
+ $[8] = t2;
180
+ } else {
181
+ t2 = $[8];
182
+ }
183
+ return t2;
184
+ };
185
+ //# sourceMappingURL=SelectedHierarchies.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectedHierarchies.js","names":["c","_c","formatAdminURL","qs","React","useEffect","useMemo","useRef","useState","XIcon","useConfig","useTranslation","Pill","Spinner","baseClass","SelectedHierarchies","hierarchySlug","Icon","onRemove","readOnly","selectedIds","config","getEntityConfig","i18n","items","setItems","isInitialLoad","setIsInitialLoad","prevSelectedIdsRef","routes","api","serverURL","collectionConfig","collectionSlug","selectedIdsKey","slice","sort","join","length","current","fetchItems","useAsTitle","admin","query","depth","limit","select","where","id","in","queryString","stringify","url","apiRoute","path","response","fetch","credentials","headers","language","ok","data","json","fetchedItems","docs","map","doc","docId","titleValue","title","String","orderedItems","find","item","filter","undefined","_jsx","className","size","SelectedPill","t0","$","t","t1","e","preventDefault","stopPropagation","handleRemove","t2","_jsxs","pillStyle","children","Boolean","disabled","onClick","type"],"sources":["../../../../src/elements/Hierarchy/Field/SelectedHierarchies.tsx"],"sourcesContent":["'use client'\nimport { formatAdminURL } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React, { useEffect, useMemo, useRef, useState } from 'react'\n\nimport { XIcon } from '../../../icons/X/index.js'\nimport { useConfig } from '../../../providers/Config/index.js'\nimport { useTranslation } from '../../../providers/Translation/index.js'\nimport { Pill } from '../../Pill/index.js'\nimport { Spinner } from '../../Spinner/index.js'\nimport './SelectedHierarchies.scss'\n\nconst baseClass = 'selected-hierarchies'\n\ntype HierarchyItem = {\n id: number | string\n title: string\n}\n\nexport type SelectedHierarchiesProps = {\n hierarchySlug: string\n Icon?: React.ReactNode\n onRemove: ({ id }: { id: number | string }) => void\n readOnly?: boolean\n selectedIds: (number | string)[]\n}\n\nexport const SelectedHierarchies: React.FC<SelectedHierarchiesProps> = ({\n hierarchySlug,\n Icon,\n onRemove,\n readOnly = false,\n selectedIds,\n}) => {\n const { config, getEntityConfig } = useConfig()\n const { i18n } = useTranslation()\n const [items, setItems] = useState<HierarchyItem[]>([])\n const [isInitialLoad, setIsInitialLoad] = useState(true)\n\n const prevSelectedIdsRef = useRef<string>('')\n\n const {\n routes: { api },\n serverURL,\n } = config\n\n const collectionConfig = getEntityConfig({ collectionSlug: hierarchySlug })\n\n const selectedIdsKey = useMemo(() => selectedIds.slice().sort().join(','), [selectedIds])\n\n useEffect(() => {\n if (!selectedIds || selectedIds.length === 0) {\n setItems([])\n setIsInitialLoad(false)\n return\n }\n\n if (prevSelectedIdsRef.current === selectedIdsKey) {\n return\n }\n prevSelectedIdsRef.current = selectedIdsKey\n\n const fetchItems = async () => {\n const useAsTitle = collectionConfig?.admin?.useAsTitle || 'id'\n\n const query = {\n depth: 0,\n limit: selectedIds.length,\n select: {\n [useAsTitle]: true,\n },\n where: {\n id: {\n in: selectedIds,\n },\n },\n }\n\n const queryString = qs.stringify(query)\n\n try {\n const url = formatAdminURL({\n apiRoute: api,\n path: `/${hierarchySlug}?${queryString}`,\n serverURL,\n })\n\n const response = await fetch(url, {\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (response.ok) {\n const data = await response.json()\n const fetchedItems: HierarchyItem[] = data.docs.map((doc: Record<string, unknown>) => {\n const docId = doc.id as number | string\n const titleValue = doc[useAsTitle] ?? docId\n const title =\n typeof titleValue === 'string' || typeof titleValue === 'number'\n ? String(titleValue)\n : String(docId)\n return {\n id: docId,\n title,\n }\n })\n\n // Order by selectedIds to preserve selection order\n const orderedItems = selectedIds\n .map((id) => fetchedItems.find((item) => item.id === id))\n .filter((item): item is HierarchyItem => item !== undefined)\n\n setItems(orderedItems)\n }\n } catch {\n // Silently fail - items will remain empty\n } finally {\n setIsInitialLoad(false)\n }\n }\n\n void fetchItems()\n }, [selectedIds, selectedIdsKey, hierarchySlug, collectionConfig, serverURL, api, i18n.language])\n\n if (isInitialLoad) {\n return (\n <div className={`${baseClass}__loading`}>\n <Spinner size=\"small\" />\n </div>\n )\n }\n\n if (items.length === 0) {\n return null\n }\n\n return (\n <div className={baseClass}>\n <div className={`${baseClass}__pills`}>\n {items.map((item) => (\n <SelectedPill\n Icon={Icon}\n item={item}\n key={item.id}\n onRemove={onRemove}\n readOnly={readOnly}\n />\n ))}\n </div>\n </div>\n )\n}\n\ntype SelectedPillProps = {\n Icon?: React.ReactNode\n item: HierarchyItem\n onRemove: ({ id }: { id: number | string }) => void\n readOnly: boolean\n}\n\nconst SelectedPill: React.FC<SelectedPillProps> = ({ Icon, item, onRemove, readOnly }) => {\n const { t } = useTranslation()\n\n const handleRemove = (e: React.MouseEvent) => {\n e.preventDefault()\n e.stopPropagation()\n onRemove({ id: item.id })\n }\n\n return (\n <Pill className={`${baseClass}__pill`} pillStyle=\"light\" size=\"small\">\n {Boolean(Icon) && <span className={`${baseClass}__pill-icon`}>{Icon}</span>}\n <span className={`${baseClass}__pill-label`}>{item.title}</span>\n <button\n aria-label={t('general:remove')}\n className={`${baseClass}__pill-remove`}\n disabled={readOnly}\n onClick={readOnly ? undefined : handleRemove}\n type=\"button\"\n >\n <XIcon />\n </button>\n </Pill>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,78 @@
1
+ @import '../../../scss/styles.scss';
2
+
3
+ @layer payload-default {
4
+ .selected-hierarchies {
5
+ &__pills {
6
+ display: flex;
7
+ flex-wrap: wrap;
8
+ gap: calc(var(--base) * 0.5);
9
+ }
10
+
11
+ &__pill {
12
+ display: inline-flex;
13
+ align-items: center;
14
+ gap: calc(var(--base) * 0.25);
15
+ align-items: center;
16
+ background-color: var(--theme-elevation-50);
17
+ border: 1px solid var(--theme-elevation-150);
18
+ padding-inline-end: calc(var(--base) * 0.2);
19
+
20
+ .pill__label {
21
+ display: flex;
22
+ align-items: center;
23
+ gap: 4px;
24
+ }
25
+ }
26
+
27
+ &__pill-label {
28
+ white-space: nowrap;
29
+ overflow: hidden;
30
+ text-overflow: ellipsis;
31
+ max-width: 200px;
32
+ }
33
+
34
+ &__pill-remove {
35
+ display: inline-flex;
36
+ align-items: center;
37
+ justify-content: center;
38
+ padding: 0;
39
+ margin: 0;
40
+ border: none;
41
+ background: none;
42
+ border-radius: $style-radius-s;
43
+ color: inherit;
44
+ position: relative;
45
+
46
+ &:disabled {
47
+ cursor: not-allowed;
48
+ }
49
+
50
+ &:hover {
51
+ background: var(--theme-elevation-200);
52
+ }
53
+
54
+ .icon {
55
+ width: calc(var(--base) * 0.8);
56
+ height: calc(var(--base) * 0.8);
57
+ color: var(--theme-elevation-500);
58
+ }
59
+ }
60
+
61
+ &__pill-tooltip {
62
+ white-space: nowrap;
63
+ }
64
+
65
+ &__empty {
66
+ color: var(--theme-elevation-500);
67
+ font-style: italic;
68
+ padding: calc(var(--base) * 0.25) 0;
69
+ height: 26px;
70
+ }
71
+
72
+ &__loading {
73
+ color: var(--theme-elevation-500);
74
+ padding: calc(var(--base) * 0.25) 0;
75
+ height: 26px;
76
+ }
77
+ }
78
+ }
@@ -0,0 +1,8 @@
1
+ import type { RelationshipFieldClientProps } from 'payload';
2
+ import React from 'react';
3
+ import './index.scss';
4
+ export type HierarchyFieldClientProps = {
5
+ Icon?: React.ReactNode;
6
+ } & RelationshipFieldClientProps;
7
+ export declare const HierarchyFieldClient: React.FC<HierarchyFieldClientProps>;
8
+ //# sourceMappingURL=index.client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.client.d.ts","sourceRoot":"","sources":["../../../../src/elements/Hierarchy/Field/index.client.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,SAAS,CAAA;AAG3D,OAAO,KAA+B,MAAM,OAAO,CAAA;AAiBnD,OAAO,cAAc,CAAA;AAMrB,MAAM,MAAM,yBAAyB,GAAG;IACtC,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;CACvB,GAAG,4BAA4B,CAAA;AAEhC,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAAE,CAAC,yBAAyB,CA2LpE,CAAA"}
@@ -0,0 +1,186 @@
1
+ 'use client';
2
+
3
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
4
+ import { getTranslation } from '@payloadcms/translations';
5
+ import React, { useCallback, useMemo } from 'react';
6
+ import { FieldDescription } from '../../../fields/FieldDescription/index.js';
7
+ import { FieldError } from '../../../fields/FieldError/index.js';
8
+ import { FieldLabel } from '../../../fields/FieldLabel/index.js';
9
+ import { mergeFieldStyles } from '../../../fields/mergeFieldStyles.js';
10
+ import { fieldBaseClass } from '../../../fields/shared/index.js';
11
+ import { useField } from '../../../forms/useField/index.js';
12
+ import { useConfig } from '../../../providers/Config/index.js';
13
+ import { useDocumentInfo } from '../../../providers/DocumentInfo/index.js';
14
+ import { useTranslation } from '../../../providers/Translation/index.js';
15
+ import { Button } from '../../Button/index.js';
16
+ import { RenderCustomComponent } from '../../RenderCustomComponent/index.js';
17
+ import { useHierarchyDrawer } from '../Drawer/useHierarchyDrawer.js';
18
+ import { SelectedHierarchies } from './SelectedHierarchies.js';
19
+ import './index.scss';
20
+ const baseClass = 'hierarchy-field';
21
+ export const HierarchyFieldClient = props => {
22
+ const {
23
+ field,
24
+ field: {
25
+ admin: {
26
+ className,
27
+ description
28
+ } = {},
29
+ hasMany,
30
+ label,
31
+ localized,
32
+ relationTo: relationToProp,
33
+ required
34
+ },
35
+ Icon,
36
+ path: pathFromProps,
37
+ readOnly,
38
+ validate
39
+ } = props;
40
+ const hierarchySlug = Array.isArray(relationToProp) ? relationToProp[0] : relationToProp;
41
+ const {
42
+ getEntityConfig
43
+ } = useConfig();
44
+ const {
45
+ collectionSlug: documentCollectionSlug
46
+ } = useDocumentInfo();
47
+ const {
48
+ i18n,
49
+ t
50
+ } = useTranslation();
51
+ const collectionConfig = getEntityConfig({
52
+ collectionSlug: hierarchySlug
53
+ });
54
+ const memoizedValidate = useCallback((value, validationOptions) => {
55
+ if (typeof validate === 'function') {
56
+ return validate(value, {
57
+ ...validationOptions,
58
+ required
59
+ });
60
+ }
61
+ }, [validate, required]);
62
+ const {
63
+ customComponents: {
64
+ AfterInput,
65
+ BeforeInput,
66
+ Description,
67
+ Error,
68
+ Label
69
+ } = {},
70
+ disabled,
71
+ path,
72
+ setValue,
73
+ showError,
74
+ value: value_0
75
+ } = useField({
76
+ potentiallyStalePath: pathFromProps,
77
+ validate: memoizedValidate
78
+ });
79
+ const styles = useMemo(() => mergeFieldStyles(field), [field]);
80
+ // Normalize value to array of IDs for display
81
+ const selectedIds = useMemo(() => {
82
+ if (!value_0) {
83
+ return [];
84
+ }
85
+ if (Array.isArray(value_0)) {
86
+ return value_0;
87
+ }
88
+ return [value_0];
89
+ }, [value_0]);
90
+ // Initialize selections for the drawer - use current value so drawer expands to current selection
91
+ const initialSelections = useMemo(() => {
92
+ if (!value_0) {
93
+ return [];
94
+ }
95
+ if (Array.isArray(value_0)) {
96
+ return value_0;
97
+ }
98
+ return [value_0];
99
+ }, [value_0]);
100
+ // Memoize to prevent new array references on every render
101
+ const filterByCollection = useMemo(() => documentCollectionSlug ? [documentCollectionSlug] : undefined, [documentCollectionSlug]);
102
+ const [HierarchyDrawer,, {
103
+ openDrawer
104
+ }] = useHierarchyDrawer({
105
+ filterByCollection,
106
+ hierarchyCollectionSlug: hierarchySlug,
107
+ Icon
108
+ });
109
+ const handleDrawerSave = useCallback(({
110
+ closeDrawer,
111
+ selections
112
+ }) => {
113
+ const ids = Array.from(selections.keys());
114
+ const newValue = hasMany ? ids : ids[0] ?? null;
115
+ setValue(newValue);
116
+ closeDrawer();
117
+ }, [hasMany, setValue]);
118
+ const handleRemove = useCallback(({
119
+ id: idToRemove
120
+ }) => {
121
+ if (hasMany) {
122
+ const newIds = selectedIds.filter(id => id !== idToRemove);
123
+ setValue(newIds.length > 0 ? newIds : null);
124
+ } else {
125
+ setValue(null);
126
+ }
127
+ }, [hasMany, selectedIds, setValue]);
128
+ const handleOpenDrawer = useCallback(() => {
129
+ openDrawer();
130
+ }, [openDrawer]);
131
+ const hierarchyLabel = getTranslation(hasMany ? collectionConfig?.labels?.plural : collectionConfig?.labels?.singular, i18n) || hierarchySlug;
132
+ return /*#__PURE__*/_jsxs("div", {
133
+ className: [fieldBaseClass, baseClass, className, showError && 'error', readOnly && `${baseClass}--read-only`].filter(Boolean).join(' '),
134
+ id: `field-${path?.replace(/\./g, '__')}`,
135
+ style: styles,
136
+ children: [/*#__PURE__*/_jsx(RenderCustomComponent, {
137
+ CustomComponent: Label,
138
+ Fallback: /*#__PURE__*/_jsx(FieldLabel, {
139
+ label: label,
140
+ localized: localized,
141
+ path: path,
142
+ required: required
143
+ })
144
+ }), /*#__PURE__*/_jsxs("div", {
145
+ className: `${fieldBaseClass}__wrap`,
146
+ children: [/*#__PURE__*/_jsx(RenderCustomComponent, {
147
+ CustomComponent: Error,
148
+ Fallback: /*#__PURE__*/_jsx(FieldError, {
149
+ path: path,
150
+ showError: showError
151
+ })
152
+ }), BeforeInput, /*#__PURE__*/_jsxs("div", {
153
+ className: `${baseClass}__content`,
154
+ children: [selectedIds.length > 0 && /*#__PURE__*/_jsx(SelectedHierarchies, {
155
+ hierarchySlug: hierarchySlug,
156
+ onRemove: handleRemove,
157
+ readOnly: readOnly || disabled,
158
+ selectedIds: selectedIds
159
+ }), !readOnly && (hasMany || selectedIds.length === 0) && /*#__PURE__*/_jsx(Button, {
160
+ buttonStyle: "dashed",
161
+ className: `${baseClass}__manage-button`,
162
+ disabled: disabled,
163
+ icon: "plus",
164
+ iconPosition: "left",
165
+ margin: false,
166
+ onClick: handleOpenDrawer,
167
+ size: "small",
168
+ children: t('general:selectLabel', {
169
+ label: hierarchyLabel
170
+ })
171
+ })]
172
+ }), AfterInput, /*#__PURE__*/_jsx(RenderCustomComponent, {
173
+ CustomComponent: Description,
174
+ Fallback: /*#__PURE__*/_jsx(FieldDescription, {
175
+ description: description,
176
+ path: path
177
+ })
178
+ })]
179
+ }), /*#__PURE__*/_jsx(HierarchyDrawer, {
180
+ hasMany: hasMany,
181
+ initialSelections: initialSelections,
182
+ onSave: handleDrawerSave
183
+ })]
184
+ });
185
+ };
186
+ //# sourceMappingURL=index.client.js.map