@strapi/content-manager 0.0.0-experimental.0588b9a4effba287cf26bd50e23baa14cdaf1616

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 (547) hide show
  1. package/LICENSE +37 -0
  2. package/README.md +9 -0
  3. package/dist/_chunks/CardDragPreview-C0QyJgRA.js +69 -0
  4. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -0
  5. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs +70 -0
  6. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -0
  7. package/dist/_chunks/ComponentConfigurationPage-DhWA-JzT.mjs +236 -0
  8. package/dist/_chunks/ComponentConfigurationPage-DhWA-JzT.mjs.map +1 -0
  9. package/dist/_chunks/ComponentConfigurationPage-UduDBv3m.js +255 -0
  10. package/dist/_chunks/ComponentConfigurationPage-UduDBv3m.js.map +1 -0
  11. package/dist/_chunks/ComponentIcon-BXdiCGQp.js +176 -0
  12. package/dist/_chunks/ComponentIcon-BXdiCGQp.js.map +1 -0
  13. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs +157 -0
  14. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -0
  15. package/dist/_chunks/EditConfigurationPage-5tmx_7Hp.mjs +132 -0
  16. package/dist/_chunks/EditConfigurationPage-5tmx_7Hp.mjs.map +1 -0
  17. package/dist/_chunks/EditConfigurationPage-Cp9UzUfs.js +151 -0
  18. package/dist/_chunks/EditConfigurationPage-Cp9UzUfs.js.map +1 -0
  19. package/dist/_chunks/EditViewPage-BKoISUOu.mjs +254 -0
  20. package/dist/_chunks/EditViewPage-BKoISUOu.mjs.map +1 -0
  21. package/dist/_chunks/EditViewPage-C7l2Emuj.js +273 -0
  22. package/dist/_chunks/EditViewPage-C7l2Emuj.js.map +1 -0
  23. package/dist/_chunks/Field-BPSJpDfE.js +5614 -0
  24. package/dist/_chunks/Field-BPSJpDfE.js.map +1 -0
  25. package/dist/_chunks/Field-BZxzYf1x.mjs +5582 -0
  26. package/dist/_chunks/Field-BZxzYf1x.mjs.map +1 -0
  27. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs +50 -0
  28. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -0
  29. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js +49 -0
  30. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -0
  31. package/dist/_chunks/Form-8qyOU6YG.mjs +758 -0
  32. package/dist/_chunks/Form-8qyOU6YG.mjs.map +1 -0
  33. package/dist/_chunks/Form-DLkqDd2G.js +779 -0
  34. package/dist/_chunks/Form-DLkqDd2G.js.map +1 -0
  35. package/dist/_chunks/History-DYMicybF.js +996 -0
  36. package/dist/_chunks/History-DYMicybF.js.map +1 -0
  37. package/dist/_chunks/History-N_kRb1Yr.mjs +975 -0
  38. package/dist/_chunks/History-N_kRb1Yr.mjs.map +1 -0
  39. package/dist/_chunks/ListConfigurationPage-BM3qVxug.mjs +633 -0
  40. package/dist/_chunks/ListConfigurationPage-BM3qVxug.mjs.map +1 -0
  41. package/dist/_chunks/ListConfigurationPage-rUF9iGWq.js +653 -0
  42. package/dist/_chunks/ListConfigurationPage-rUF9iGWq.js.map +1 -0
  43. package/dist/_chunks/ListViewPage-BSLzd7cZ.js +875 -0
  44. package/dist/_chunks/ListViewPage-BSLzd7cZ.js.map +1 -0
  45. package/dist/_chunks/ListViewPage-CWilGbZb.mjs +851 -0
  46. package/dist/_chunks/ListViewPage-CWilGbZb.mjs.map +1 -0
  47. package/dist/_chunks/NoContentTypePage-CQccVhIX.js +51 -0
  48. package/dist/_chunks/NoContentTypePage-CQccVhIX.js.map +1 -0
  49. package/dist/_chunks/NoContentTypePage-VWYlePwI.mjs +51 -0
  50. package/dist/_chunks/NoContentTypePage-VWYlePwI.mjs.map +1 -0
  51. package/dist/_chunks/NoPermissionsPage-Af32Gg2m.js +23 -0
  52. package/dist/_chunks/NoPermissionsPage-Af32Gg2m.js.map +1 -0
  53. package/dist/_chunks/NoPermissionsPage-CS2tCmfr.mjs +23 -0
  54. package/dist/_chunks/NoPermissionsPage-CS2tCmfr.mjs.map +1 -0
  55. package/dist/_chunks/Preview-D4KzuJFL.js +291 -0
  56. package/dist/_chunks/Preview-D4KzuJFL.js.map +1 -0
  57. package/dist/_chunks/Preview-kPkuZbBJ.mjs +272 -0
  58. package/dist/_chunks/Preview-kPkuZbBJ.mjs.map +1 -0
  59. package/dist/_chunks/Relations-5k27Rh54.mjs +730 -0
  60. package/dist/_chunks/Relations-5k27Rh54.mjs.map +1 -0
  61. package/dist/_chunks/Relations-D_Ki5aVM.js +750 -0
  62. package/dist/_chunks/Relations-D_Ki5aVM.js.map +1 -0
  63. package/dist/_chunks/ar-BUUWXIYu.js +226 -0
  64. package/dist/_chunks/ar-BUUWXIYu.js.map +1 -0
  65. package/dist/_chunks/ar-CCEVvqGG.mjs +226 -0
  66. package/dist/_chunks/ar-CCEVvqGG.mjs.map +1 -0
  67. package/dist/_chunks/ca-5U32ON2v.mjs +201 -0
  68. package/dist/_chunks/ca-5U32ON2v.mjs.map +1 -0
  69. package/dist/_chunks/ca-Cmk45QO6.js +201 -0
  70. package/dist/_chunks/ca-Cmk45QO6.js.map +1 -0
  71. package/dist/_chunks/cs-CM2aBUar.mjs +125 -0
  72. package/dist/_chunks/cs-CM2aBUar.mjs.map +1 -0
  73. package/dist/_chunks/cs-CkJy6B2v.js +125 -0
  74. package/dist/_chunks/cs-CkJy6B2v.js.map +1 -0
  75. package/dist/_chunks/de-C72KDNOl.mjs +199 -0
  76. package/dist/_chunks/de-C72KDNOl.mjs.map +1 -0
  77. package/dist/_chunks/de-CCEmbAah.js +199 -0
  78. package/dist/_chunks/de-CCEmbAah.js.map +1 -0
  79. package/dist/_chunks/en-BK8Xyl5I.js +305 -0
  80. package/dist/_chunks/en-BK8Xyl5I.js.map +1 -0
  81. package/dist/_chunks/en-Dtk_ot79.mjs +305 -0
  82. package/dist/_chunks/en-Dtk_ot79.mjs.map +1 -0
  83. package/dist/_chunks/es-9K52xZIr.js +196 -0
  84. package/dist/_chunks/es-9K52xZIr.js.map +1 -0
  85. package/dist/_chunks/es-D34tqjMw.mjs +196 -0
  86. package/dist/_chunks/es-D34tqjMw.mjs.map +1 -0
  87. package/dist/_chunks/eu-CdALomew.mjs +202 -0
  88. package/dist/_chunks/eu-CdALomew.mjs.map +1 -0
  89. package/dist/_chunks/eu-VDH-3ovk.js +202 -0
  90. package/dist/_chunks/eu-VDH-3ovk.js.map +1 -0
  91. package/dist/_chunks/fr--pg5jUbt.mjs +216 -0
  92. package/dist/_chunks/fr--pg5jUbt.mjs.map +1 -0
  93. package/dist/_chunks/fr-B2Kyv8Z9.js +216 -0
  94. package/dist/_chunks/fr-B2Kyv8Z9.js.map +1 -0
  95. package/dist/_chunks/gu-BRmF601H.js +200 -0
  96. package/dist/_chunks/gu-BRmF601H.js.map +1 -0
  97. package/dist/_chunks/gu-CNpaMDpH.mjs +200 -0
  98. package/dist/_chunks/gu-CNpaMDpH.mjs.map +1 -0
  99. package/dist/_chunks/hi-CCJBptSq.js +200 -0
  100. package/dist/_chunks/hi-CCJBptSq.js.map +1 -0
  101. package/dist/_chunks/hi-Dwvd04m3.mjs +200 -0
  102. package/dist/_chunks/hi-Dwvd04m3.mjs.map +1 -0
  103. package/dist/_chunks/hooks-BAaaKPS_.js +7 -0
  104. package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -0
  105. package/dist/_chunks/hooks-E5u1mcgM.mjs +8 -0
  106. package/dist/_chunks/hooks-E5u1mcgM.mjs.map +1 -0
  107. package/dist/_chunks/hu-CeYvaaO0.mjs +202 -0
  108. package/dist/_chunks/hu-CeYvaaO0.mjs.map +1 -0
  109. package/dist/_chunks/hu-sNV_yLYy.js +202 -0
  110. package/dist/_chunks/hu-sNV_yLYy.js.map +1 -0
  111. package/dist/_chunks/id-B5Ser98A.js +160 -0
  112. package/dist/_chunks/id-B5Ser98A.js.map +1 -0
  113. package/dist/_chunks/id-BtwA9WJT.mjs +160 -0
  114. package/dist/_chunks/id-BtwA9WJT.mjs.map +1 -0
  115. package/dist/_chunks/index-BLPa8Dq-.mjs +4204 -0
  116. package/dist/_chunks/index-BLPa8Dq-.mjs.map +1 -0
  117. package/dist/_chunks/index-DwOsF7wF.js +4224 -0
  118. package/dist/_chunks/index-DwOsF7wF.js.map +1 -0
  119. package/dist/_chunks/it-BrVPqaf1.mjs +162 -0
  120. package/dist/_chunks/it-BrVPqaf1.mjs.map +1 -0
  121. package/dist/_chunks/it-DkBIs7vD.js +162 -0
  122. package/dist/_chunks/it-DkBIs7vD.js.map +1 -0
  123. package/dist/_chunks/ja-7sfIbjxE.js +196 -0
  124. package/dist/_chunks/ja-7sfIbjxE.js.map +1 -0
  125. package/dist/_chunks/ja-BHqhDq4V.mjs +196 -0
  126. package/dist/_chunks/ja-BHqhDq4V.mjs.map +1 -0
  127. package/dist/_chunks/ko-HVQRlfUI.mjs +195 -0
  128. package/dist/_chunks/ko-HVQRlfUI.mjs.map +1 -0
  129. package/dist/_chunks/ko-woFZPmLk.js +195 -0
  130. package/dist/_chunks/ko-woFZPmLk.js.map +1 -0
  131. package/dist/_chunks/layout-2Si0j0jO.mjs +471 -0
  132. package/dist/_chunks/layout-2Si0j0jO.mjs.map +1 -0
  133. package/dist/_chunks/layout-CN2bFL9V.js +489 -0
  134. package/dist/_chunks/layout-CN2bFL9V.js.map +1 -0
  135. package/dist/_chunks/ml-BihZwQit.mjs +200 -0
  136. package/dist/_chunks/ml-BihZwQit.mjs.map +1 -0
  137. package/dist/_chunks/ml-C2W8N8k1.js +200 -0
  138. package/dist/_chunks/ml-C2W8N8k1.js.map +1 -0
  139. package/dist/_chunks/ms-BuFotyP_.js +144 -0
  140. package/dist/_chunks/ms-BuFotyP_.js.map +1 -0
  141. package/dist/_chunks/ms-m_WjyWx7.mjs +144 -0
  142. package/dist/_chunks/ms-m_WjyWx7.mjs.map +1 -0
  143. package/dist/_chunks/nl-D4R9gHx5.mjs +202 -0
  144. package/dist/_chunks/nl-D4R9gHx5.mjs.map +1 -0
  145. package/dist/_chunks/nl-bbEOHChV.js +202 -0
  146. package/dist/_chunks/nl-bbEOHChV.js.map +1 -0
  147. package/dist/_chunks/objects-BcXOv6_9.js +47 -0
  148. package/dist/_chunks/objects-BcXOv6_9.js.map +1 -0
  149. package/dist/_chunks/objects-D6yBsdmx.mjs +45 -0
  150. package/dist/_chunks/objects-D6yBsdmx.mjs.map +1 -0
  151. package/dist/_chunks/pl-sbx9mSt_.mjs +199 -0
  152. package/dist/_chunks/pl-sbx9mSt_.mjs.map +1 -0
  153. package/dist/_chunks/pl-uzwG-hk7.js +199 -0
  154. package/dist/_chunks/pl-uzwG-hk7.js.map +1 -0
  155. package/dist/_chunks/pt-BR-BiOz37D9.js +201 -0
  156. package/dist/_chunks/pt-BR-BiOz37D9.js.map +1 -0
  157. package/dist/_chunks/pt-BR-C71iDxnh.mjs +201 -0
  158. package/dist/_chunks/pt-BR-C71iDxnh.mjs.map +1 -0
  159. package/dist/_chunks/pt-BsaFvS8-.mjs +95 -0
  160. package/dist/_chunks/pt-BsaFvS8-.mjs.map +1 -0
  161. package/dist/_chunks/pt-CeXQuq50.js +95 -0
  162. package/dist/_chunks/pt-CeXQuq50.js.map +1 -0
  163. package/dist/_chunks/relations-B0E0XUY7.js +133 -0
  164. package/dist/_chunks/relations-B0E0XUY7.js.map +1 -0
  165. package/dist/_chunks/relations-CAxDjUJF.mjs +134 -0
  166. package/dist/_chunks/relations-CAxDjUJF.mjs.map +1 -0
  167. package/dist/_chunks/ru-BE6A4Exp.mjs +231 -0
  168. package/dist/_chunks/ru-BE6A4Exp.mjs.map +1 -0
  169. package/dist/_chunks/ru-BT3ybNny.js +231 -0
  170. package/dist/_chunks/ru-BT3ybNny.js.map +1 -0
  171. package/dist/_chunks/sa-CcvkYInH.js +200 -0
  172. package/dist/_chunks/sa-CcvkYInH.js.map +1 -0
  173. package/dist/_chunks/sa-Dag0k-Z8.mjs +200 -0
  174. package/dist/_chunks/sa-Dag0k-Z8.mjs.map +1 -0
  175. package/dist/_chunks/sk-BFg-R8qJ.mjs +202 -0
  176. package/dist/_chunks/sk-BFg-R8qJ.mjs.map +1 -0
  177. package/dist/_chunks/sk-CvY09Xjv.js +202 -0
  178. package/dist/_chunks/sk-CvY09Xjv.js.map +1 -0
  179. package/dist/_chunks/sv-CUnfWGsh.mjs +202 -0
  180. package/dist/_chunks/sv-CUnfWGsh.mjs.map +1 -0
  181. package/dist/_chunks/sv-MYDuzgvT.js +202 -0
  182. package/dist/_chunks/sv-MYDuzgvT.js.map +1 -0
  183. package/dist/_chunks/th-BqbI8lIT.mjs +148 -0
  184. package/dist/_chunks/th-BqbI8lIT.mjs.map +1 -0
  185. package/dist/_chunks/th-D9_GfAjc.js +148 -0
  186. package/dist/_chunks/th-D9_GfAjc.js.map +1 -0
  187. package/dist/_chunks/tr-CgeK3wJM.mjs +199 -0
  188. package/dist/_chunks/tr-CgeK3wJM.mjs.map +1 -0
  189. package/dist/_chunks/tr-D9UH-O_R.js +199 -0
  190. package/dist/_chunks/tr-D9UH-O_R.js.map +1 -0
  191. package/dist/_chunks/uk-C8EiqJY7.js +144 -0
  192. package/dist/_chunks/uk-C8EiqJY7.js.map +1 -0
  193. package/dist/_chunks/uk-CR-zDhAY.mjs +144 -0
  194. package/dist/_chunks/uk-CR-zDhAY.mjs.map +1 -0
  195. package/dist/_chunks/useDebounce-CtcjDB3L.js +28 -0
  196. package/dist/_chunks/useDebounce-CtcjDB3L.js.map +1 -0
  197. package/dist/_chunks/useDebounce-DmuSJIF3.mjs +29 -0
  198. package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +1 -0
  199. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs +231 -0
  200. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs.map +1 -0
  201. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js +249 -0
  202. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js.map +1 -0
  203. package/dist/_chunks/vi-CJlYDheJ.js +111 -0
  204. package/dist/_chunks/vi-CJlYDheJ.js.map +1 -0
  205. package/dist/_chunks/vi-DUXIk_fw.mjs +111 -0
  206. package/dist/_chunks/vi-DUXIk_fw.mjs.map +1 -0
  207. package/dist/_chunks/zh-BWZspA60.mjs +209 -0
  208. package/dist/_chunks/zh-BWZspA60.mjs.map +1 -0
  209. package/dist/_chunks/zh-CQQfszqR.js +209 -0
  210. package/dist/_chunks/zh-CQQfszqR.js.map +1 -0
  211. package/dist/_chunks/zh-Hans-9kOncHGw.js +952 -0
  212. package/dist/_chunks/zh-Hans-9kOncHGw.js.map +1 -0
  213. package/dist/_chunks/zh-Hans-BPQcRIyH.mjs +952 -0
  214. package/dist/_chunks/zh-Hans-BPQcRIyH.mjs.map +1 -0
  215. package/dist/admin/index.js +13 -0
  216. package/dist/admin/index.js.map +1 -0
  217. package/dist/admin/index.mjs +13 -0
  218. package/dist/admin/index.mjs.map +1 -0
  219. package/dist/admin/src/components/ComponentIcon.d.ts +11 -0
  220. package/dist/admin/src/components/ConfigurationForm/EditFieldForm.d.ts +9 -0
  221. package/dist/admin/src/components/ConfigurationForm/Fields.d.ts +21 -0
  222. package/dist/admin/src/components/ConfigurationForm/Form.d.ts +32 -0
  223. package/dist/admin/src/components/DragLayer.d.ts +13 -0
  224. package/dist/admin/src/components/DragPreviews/CardDragPreview.d.ts +7 -0
  225. package/dist/admin/src/components/DragPreviews/ComponentDragPreview.d.ts +6 -0
  226. package/dist/admin/src/components/DragPreviews/RelationDragPreview.d.ts +11 -0
  227. package/dist/admin/src/components/FieldTypeIcon.d.ts +9 -0
  228. package/dist/admin/src/components/InjectionZone.d.ts +45 -0
  229. package/dist/admin/src/components/LeftMenu.d.ts +2 -0
  230. package/dist/admin/src/components/RelativeTime.d.ts +28 -0
  231. package/dist/admin/src/constants/attributes.d.ts +14 -0
  232. package/dist/admin/src/constants/collections.d.ts +3 -0
  233. package/dist/admin/src/constants/dragAndDrop.d.ts +8 -0
  234. package/dist/admin/src/constants/hooks.d.ts +26 -0
  235. package/dist/admin/src/constants/plugin.d.ts +3 -0
  236. package/dist/admin/src/content-manager.d.ts +133 -0
  237. package/dist/admin/src/exports.d.ts +12 -0
  238. package/dist/admin/src/features/DocumentRBAC.d.ts +36 -0
  239. package/dist/admin/src/history/components/HistoryAction.d.ts +3 -0
  240. package/dist/admin/src/history/components/VersionContent.d.ts +17 -0
  241. package/dist/admin/src/history/components/VersionHeader.d.ts +5 -0
  242. package/dist/admin/src/history/components/VersionInputRenderer.d.ts +19 -0
  243. package/dist/admin/src/history/components/VersionsList.d.ts +2 -0
  244. package/dist/admin/src/history/index.d.ts +3 -0
  245. package/dist/admin/src/history/pages/History.d.ts +27 -0
  246. package/dist/admin/src/history/routes.d.ts +6 -0
  247. package/dist/admin/src/history/services/historyVersion.d.ts +12 -0
  248. package/dist/admin/src/hooks/useContentManagerInitData.d.ts +15 -0
  249. package/dist/admin/src/hooks/useContentTypeSchema.d.ts +25 -0
  250. package/dist/admin/src/hooks/useDebounce.d.ts +1 -0
  251. package/dist/admin/src/hooks/useDocument.d.ts +118 -0
  252. package/dist/admin/src/hooks/useDocumentActions.d.ts +123 -0
  253. package/dist/admin/src/hooks/useDocumentLayout.d.ts +137 -0
  254. package/dist/admin/src/hooks/useDragAndDrop.d.ts +51 -0
  255. package/dist/admin/src/hooks/useKeyboardDragAndDrop.d.ts +14 -0
  256. package/dist/admin/src/hooks/useLazyComponents.d.ts +13 -0
  257. package/dist/admin/src/hooks/useOnce.d.ts +2 -0
  258. package/dist/admin/src/hooks/usePrev.d.ts +1 -0
  259. package/dist/admin/src/index.d.ts +17 -0
  260. package/dist/admin/src/layout.d.ts +2 -0
  261. package/dist/admin/src/modules/app.d.ts +20 -0
  262. package/dist/admin/src/modules/hooks.d.ts +10 -0
  263. package/dist/admin/src/modules/reducers.d.ts +6 -0
  264. package/dist/admin/src/pages/ComponentConfigurationPage.d.ts +3 -0
  265. package/dist/admin/src/pages/EditConfigurationPage.d.ts +3 -0
  266. package/dist/admin/src/pages/EditView/EditViewPage.d.ts +11 -0
  267. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +76 -0
  268. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +16 -0
  269. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +3 -0
  270. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Heading.d.ts +3 -0
  271. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Image.d.ts +3 -0
  272. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Link.d.ts +3 -0
  273. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/List.d.ts +3 -0
  274. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Paragraph.d.ts +3 -0
  275. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Quote.d.ts +3 -0
  276. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.d.ts +6 -0
  277. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.d.ts +61 -0
  278. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksInput.d.ts +11 -0
  279. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.d.ts +10 -0
  280. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/EditorLayout.d.ts +10 -0
  281. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Modifiers.d.ts +16 -0
  282. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/plugins/withImages.d.ts +11 -0
  283. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/plugins/withLinks.d.ts +9 -0
  284. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/plugins/withStrapiSchema.d.ts +8 -0
  285. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +4 -0
  286. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/conversions.d.ts +13 -0
  287. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/enterKey.d.ts +6 -0
  288. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/links.d.ts +10 -0
  289. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/types.d.ts +10 -0
  290. package/dist/admin/src/pages/EditView/components/FormInputs/Component/Initializer.d.ts +9 -0
  291. package/dist/admin/src/pages/EditView/components/FormInputs/Component/Input.d.ts +18 -0
  292. package/dist/admin/src/pages/EditView/components/FormInputs/Component/NonRepeatable.d.ts +5 -0
  293. package/dist/admin/src/pages/EditView/components/FormInputs/Component/Repeatable.d.ts +5 -0
  294. package/dist/admin/src/pages/EditView/components/FormInputs/ComponentContext.d.ts +42 -0
  295. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/AddComponentButton.d.ts +11 -0
  296. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/ComponentCard.d.ts +9 -0
  297. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/ComponentCategory.d.ts +15 -0
  298. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/ComponentPicker.d.ts +9 -0
  299. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.d.ts +14 -0
  300. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicZoneLabel.d.ts +12 -0
  301. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +14 -0
  302. package/dist/admin/src/pages/EditView/components/FormInputs/NotAllowed.d.ts +7 -0
  303. package/dist/admin/src/pages/EditView/components/FormInputs/Relations.d.ts +38 -0
  304. package/dist/admin/src/pages/EditView/components/FormInputs/UID.d.ts +9 -0
  305. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/Editor.d.ts +17 -0
  306. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.d.ts +14 -0
  307. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/Field.d.ts +11 -0
  308. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/PreviewWysiwyg.d.ts +5 -0
  309. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygFooter.d.ts +7 -0
  310. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.d.ts +17 -0
  311. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.d.ts +18 -0
  312. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/utils/continueList.d.ts +5 -0
  313. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/utils/mdRenderer.d.ts +4 -0
  314. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/utils/utils.d.ts +16 -0
  315. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +5 -0
  316. package/dist/admin/src/pages/EditView/components/Header.d.ts +35 -0
  317. package/dist/admin/src/pages/EditView/components/InputRenderer.d.ts +9 -0
  318. package/dist/admin/src/pages/EditView/components/Panels.d.ts +10 -0
  319. package/dist/admin/src/pages/EditView/utils/data.d.ts +33 -0
  320. package/dist/admin/src/pages/EditView/utils/forms.d.ts +9 -0
  321. package/dist/admin/src/pages/ListConfiguration/ListConfigurationPage.d.ts +10 -0
  322. package/dist/admin/src/pages/ListConfiguration/components/DraggableCard.d.ts +12 -0
  323. package/dist/admin/src/pages/ListConfiguration/components/EditFieldForm.d.ts +8 -0
  324. package/dist/admin/src/pages/ListConfiguration/components/Header.d.ts +8 -0
  325. package/dist/admin/src/pages/ListConfiguration/components/Settings.d.ts +19 -0
  326. package/dist/admin/src/pages/ListConfiguration/components/SortDisplayedFields.d.ts +6 -0
  327. package/dist/admin/src/pages/ListView/ListViewPage.d.ts +3 -0
  328. package/dist/admin/src/pages/ListView/components/AutoCloneFailureModal.d.ts +7 -0
  329. package/dist/admin/src/pages/ListView/components/BulkActions/Actions.d.ts +24 -0
  330. package/dist/admin/src/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.d.ts +15 -0
  331. package/dist/admin/src/pages/ListView/components/BulkActions/PublishAction.d.ts +14 -0
  332. package/dist/admin/src/pages/ListView/components/Filters.d.ts +8 -0
  333. package/dist/admin/src/pages/ListView/components/TableActions.d.ts +8 -0
  334. package/dist/admin/src/pages/ListView/components/TableCells/CellContent.d.ts +9 -0
  335. package/dist/admin/src/pages/ListView/components/TableCells/CellValue.d.ts +8 -0
  336. package/dist/admin/src/pages/ListView/components/TableCells/Components.d.ts +12 -0
  337. package/dist/admin/src/pages/ListView/components/TableCells/Media.d.ts +23 -0
  338. package/dist/admin/src/pages/ListView/components/TableCells/Relations.d.ts +12 -0
  339. package/dist/admin/src/pages/ListView/components/ViewSettingsMenu.d.ts +10 -0
  340. package/dist/admin/src/pages/NoContentTypePage.d.ts +2 -0
  341. package/dist/admin/src/pages/NoPermissionsPage.d.ts +2 -0
  342. package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -0
  343. package/dist/admin/src/preview/components/PreviewHeader.d.ts +2 -0
  344. package/dist/admin/src/preview/components/PreviewSidePanel.d.ts +3 -0
  345. package/dist/admin/src/preview/constants.d.ts +1 -0
  346. package/dist/admin/src/preview/index.d.ts +4 -0
  347. package/dist/admin/src/preview/pages/Preview.d.ts +11 -0
  348. package/dist/admin/src/preview/routes.d.ts +3 -0
  349. package/dist/admin/src/preview/services/preview.d.ts +3 -0
  350. package/dist/admin/src/router.d.ts +5 -0
  351. package/dist/admin/src/services/api.d.ts +2 -0
  352. package/dist/admin/src/services/components.d.ts +5 -0
  353. package/dist/admin/src/services/contentTypes.d.ts +17 -0
  354. package/dist/admin/src/services/documents.d.ts +100 -0
  355. package/dist/admin/src/services/init.d.ts +9 -0
  356. package/dist/admin/src/services/relations.d.ts +49 -0
  357. package/dist/admin/src/services/uid.d.ts +32 -0
  358. package/dist/admin/src/utils/api.d.ts +24 -0
  359. package/dist/admin/src/utils/attributes.d.ts +19 -0
  360. package/dist/admin/src/utils/objects.d.ts +33 -0
  361. package/dist/admin/src/utils/relations.d.ts +12 -0
  362. package/dist/admin/src/utils/strings.d.ts +2 -0
  363. package/dist/admin/src/utils/translations.d.ts +4 -0
  364. package/dist/admin/src/utils/urls.d.ts +2 -0
  365. package/dist/admin/src/utils/users.d.ts +6 -0
  366. package/dist/admin/src/utils/validation.d.ts +10 -0
  367. package/dist/server/index.js +4699 -0
  368. package/dist/server/index.js.map +1 -0
  369. package/dist/server/index.mjs +4675 -0
  370. package/dist/server/index.mjs.map +1 -0
  371. package/dist/server/src/bootstrap.d.ts +3 -0
  372. package/dist/server/src/bootstrap.d.ts.map +1 -0
  373. package/dist/server/src/config.d.ts +6 -0
  374. package/dist/server/src/config.d.ts.map +1 -0
  375. package/dist/server/src/constants/index.d.ts +6 -0
  376. package/dist/server/src/constants/index.d.ts.map +1 -0
  377. package/dist/server/src/controllers/collection-types.d.ts +23 -0
  378. package/dist/server/src/controllers/collection-types.d.ts.map +1 -0
  379. package/dist/server/src/controllers/components.d.ts +7 -0
  380. package/dist/server/src/controllers/components.d.ts.map +1 -0
  381. package/dist/server/src/controllers/content-types.d.ts +8 -0
  382. package/dist/server/src/controllers/content-types.d.ts.map +1 -0
  383. package/dist/server/src/controllers/index.d.ts +53 -0
  384. package/dist/server/src/controllers/index.d.ts.map +1 -0
  385. package/dist/server/src/controllers/init.d.ts +5 -0
  386. package/dist/server/src/controllers/init.d.ts.map +1 -0
  387. package/dist/server/src/controllers/relations.d.ts +13 -0
  388. package/dist/server/src/controllers/relations.d.ts.map +1 -0
  389. package/dist/server/src/controllers/single-types.d.ts +11 -0
  390. package/dist/server/src/controllers/single-types.d.ts.map +1 -0
  391. package/dist/server/src/controllers/uid.d.ts +6 -0
  392. package/dist/server/src/controllers/uid.d.ts.map +1 -0
  393. package/dist/server/src/controllers/utils/clone.d.ts +12 -0
  394. package/dist/server/src/controllers/utils/clone.d.ts.map +1 -0
  395. package/dist/server/src/controllers/utils/metadata.d.ts +22 -0
  396. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -0
  397. package/dist/server/src/controllers/validation/dimensions.d.ts +11 -0
  398. package/dist/server/src/controllers/validation/dimensions.d.ts.map +1 -0
  399. package/dist/server/src/controllers/validation/index.d.ts +20 -0
  400. package/dist/server/src/controllers/validation/index.d.ts.map +1 -0
  401. package/dist/server/src/controllers/validation/model-configuration.d.ts +22 -0
  402. package/dist/server/src/controllers/validation/model-configuration.d.ts.map +1 -0
  403. package/dist/server/src/controllers/validation/relations.d.ts +4 -0
  404. package/dist/server/src/controllers/validation/relations.d.ts.map +1 -0
  405. package/dist/server/src/destroy.d.ts +4 -0
  406. package/dist/server/src/destroy.d.ts.map +1 -0
  407. package/dist/server/src/history/constants.d.ts +3 -0
  408. package/dist/server/src/history/constants.d.ts.map +1 -0
  409. package/dist/server/src/history/controllers/history-version.d.ts +19 -0
  410. package/dist/server/src/history/controllers/history-version.d.ts.map +1 -0
  411. package/dist/server/src/history/controllers/index.d.ts +2 -0
  412. package/dist/server/src/history/controllers/index.d.ts.map +1 -0
  413. package/dist/server/src/history/controllers/validation/history-version.d.ts +2 -0
  414. package/dist/server/src/history/controllers/validation/history-version.d.ts.map +1 -0
  415. package/dist/server/src/history/index.d.ts +4 -0
  416. package/dist/server/src/history/index.d.ts.map +1 -0
  417. package/dist/server/src/history/models/history-version.d.ts +4 -0
  418. package/dist/server/src/history/models/history-version.d.ts.map +1 -0
  419. package/dist/server/src/history/routes/history-version.d.ts +4 -0
  420. package/dist/server/src/history/routes/history-version.d.ts.map +1 -0
  421. package/dist/server/src/history/routes/index.d.ts +8 -0
  422. package/dist/server/src/history/routes/index.d.ts.map +1 -0
  423. package/dist/server/src/history/services/history.d.ts +16 -0
  424. package/dist/server/src/history/services/history.d.ts.map +1 -0
  425. package/dist/server/src/history/services/index.d.ts +19 -0
  426. package/dist/server/src/history/services/index.d.ts.map +1 -0
  427. package/dist/server/src/history/services/lifecycles.d.ts +9 -0
  428. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -0
  429. package/dist/server/src/history/services/utils.d.ts +44 -0
  430. package/dist/server/src/history/services/utils.d.ts.map +1 -0
  431. package/dist/server/src/history/utils.d.ts +22 -0
  432. package/dist/server/src/history/utils.d.ts.map +1 -0
  433. package/dist/server/src/index.d.ts +353 -0
  434. package/dist/server/src/index.d.ts.map +1 -0
  435. package/dist/server/src/middlewares/index.d.ts +3 -0
  436. package/dist/server/src/middlewares/index.d.ts.map +1 -0
  437. package/dist/server/src/middlewares/routing.d.ts +4 -0
  438. package/dist/server/src/middlewares/routing.d.ts.map +1 -0
  439. package/dist/server/src/policies/hasPermissions.d.ts +7 -0
  440. package/dist/server/src/policies/hasPermissions.d.ts.map +1 -0
  441. package/dist/server/src/policies/index.d.ts +9 -0
  442. package/dist/server/src/policies/index.d.ts.map +1 -0
  443. package/dist/server/src/preview/constants.d.ts +2 -0
  444. package/dist/server/src/preview/constants.d.ts.map +1 -0
  445. package/dist/server/src/preview/controllers/index.d.ts +2 -0
  446. package/dist/server/src/preview/controllers/index.d.ts.map +1 -0
  447. package/dist/server/src/preview/controllers/preview.d.ts +13 -0
  448. package/dist/server/src/preview/controllers/preview.d.ts.map +1 -0
  449. package/dist/server/src/preview/controllers/validation/preview.d.ts +6 -0
  450. package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -0
  451. package/dist/server/src/preview/index.d.ts +4 -0
  452. package/dist/server/src/preview/index.d.ts.map +1 -0
  453. package/dist/server/src/preview/routes/index.d.ts +8 -0
  454. package/dist/server/src/preview/routes/index.d.ts.map +1 -0
  455. package/dist/server/src/preview/routes/preview.d.ts +4 -0
  456. package/dist/server/src/preview/routes/preview.d.ts.map +1 -0
  457. package/dist/server/src/preview/services/index.d.ts +16 -0
  458. package/dist/server/src/preview/services/index.d.ts.map +1 -0
  459. package/dist/server/src/preview/services/preview-config.d.ts +32 -0
  460. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -0
  461. package/dist/server/src/preview/services/preview.d.ts +12 -0
  462. package/dist/server/src/preview/services/preview.d.ts.map +1 -0
  463. package/dist/server/src/preview/utils.d.ts +19 -0
  464. package/dist/server/src/preview/utils.d.ts.map +1 -0
  465. package/dist/server/src/register.d.ts +4 -0
  466. package/dist/server/src/register.d.ts.map +1 -0
  467. package/dist/server/src/routes/admin.d.ts +41 -0
  468. package/dist/server/src/routes/admin.d.ts.map +1 -0
  469. package/dist/server/src/routes/index.d.ts +43 -0
  470. package/dist/server/src/routes/index.d.ts.map +1 -0
  471. package/dist/server/src/services/components.d.ts +32 -0
  472. package/dist/server/src/services/components.d.ts.map +1 -0
  473. package/dist/server/src/services/configuration.d.ts +20 -0
  474. package/dist/server/src/services/configuration.d.ts.map +1 -0
  475. package/dist/server/src/services/content-types.d.ts +18 -0
  476. package/dist/server/src/services/content-types.d.ts.map +1 -0
  477. package/dist/server/src/services/data-mapper.d.ts +20 -0
  478. package/dist/server/src/services/data-mapper.d.ts.map +1 -0
  479. package/dist/server/src/services/document-manager.d.ts +48 -0
  480. package/dist/server/src/services/document-manager.d.ts.map +1 -0
  481. package/dist/server/src/services/document-metadata.d.ts +67 -0
  482. package/dist/server/src/services/document-metadata.d.ts.map +1 -0
  483. package/dist/server/src/services/field-sizes.d.ts +19 -0
  484. package/dist/server/src/services/field-sizes.d.ts.map +1 -0
  485. package/dist/server/src/services/index.d.ts +245 -0
  486. package/dist/server/src/services/index.d.ts.map +1 -0
  487. package/dist/server/src/services/metrics.d.ts +9 -0
  488. package/dist/server/src/services/metrics.d.ts.map +1 -0
  489. package/dist/server/src/services/permission-checker.d.ts +54 -0
  490. package/dist/server/src/services/permission-checker.d.ts.map +1 -0
  491. package/dist/server/src/services/permission.d.ts +12 -0
  492. package/dist/server/src/services/permission.d.ts.map +1 -0
  493. package/dist/server/src/services/populate-builder.d.ts +30 -0
  494. package/dist/server/src/services/populate-builder.d.ts.map +1 -0
  495. package/dist/server/src/services/uid.d.ts +25 -0
  496. package/dist/server/src/services/uid.d.ts.map +1 -0
  497. package/dist/server/src/services/utils/configuration/attributes.d.ts +17 -0
  498. package/dist/server/src/services/utils/configuration/attributes.d.ts.map +1 -0
  499. package/dist/server/src/services/utils/configuration/index.d.ts +21 -0
  500. package/dist/server/src/services/utils/configuration/index.d.ts.map +1 -0
  501. package/dist/server/src/services/utils/configuration/layouts.d.ts +14 -0
  502. package/dist/server/src/services/utils/configuration/layouts.d.ts.map +1 -0
  503. package/dist/server/src/services/utils/configuration/metadatas.d.ts +5 -0
  504. package/dist/server/src/services/utils/configuration/metadatas.d.ts.map +1 -0
  505. package/dist/server/src/services/utils/configuration/settings.d.ts +5 -0
  506. package/dist/server/src/services/utils/configuration/settings.d.ts.map +1 -0
  507. package/dist/server/src/services/utils/count.d.ts +5 -0
  508. package/dist/server/src/services/utils/count.d.ts.map +1 -0
  509. package/dist/server/src/services/utils/draft.d.ts +11 -0
  510. package/dist/server/src/services/utils/draft.d.ts.map +1 -0
  511. package/dist/server/src/services/utils/populate.d.ts +42 -0
  512. package/dist/server/src/services/utils/populate.d.ts.map +1 -0
  513. package/dist/server/src/services/utils/store.d.ts +16 -0
  514. package/dist/server/src/services/utils/store.d.ts.map +1 -0
  515. package/dist/server/src/utils/index.d.ts +11 -0
  516. package/dist/server/src/utils/index.d.ts.map +1 -0
  517. package/dist/server/src/validation/policies/hasPermissions.d.ts +2 -0
  518. package/dist/server/src/validation/policies/hasPermissions.d.ts.map +1 -0
  519. package/dist/shared/contracts/collection-types.d.ts +338 -0
  520. package/dist/shared/contracts/collection-types.d.ts.map +1 -0
  521. package/dist/shared/contracts/components.d.ts +65 -0
  522. package/dist/shared/contracts/components.d.ts.map +1 -0
  523. package/dist/shared/contracts/content-types.d.ts +113 -0
  524. package/dist/shared/contracts/content-types.d.ts.map +1 -0
  525. package/dist/shared/contracts/history-versions.d.ts +92 -0
  526. package/dist/shared/contracts/history-versions.d.ts.map +1 -0
  527. package/dist/shared/contracts/index.d.ts +11 -0
  528. package/dist/shared/contracts/index.d.ts.map +1 -0
  529. package/dist/shared/contracts/init.d.ts +24 -0
  530. package/dist/shared/contracts/init.d.ts.map +1 -0
  531. package/dist/shared/contracts/preview.d.ts +27 -0
  532. package/dist/shared/contracts/preview.d.ts.map +1 -0
  533. package/dist/shared/contracts/relations.d.ts +70 -0
  534. package/dist/shared/contracts/relations.d.ts.map +1 -0
  535. package/dist/shared/contracts/review-workflows.d.ts +78 -0
  536. package/dist/shared/contracts/review-workflows.d.ts.map +1 -0
  537. package/dist/shared/contracts/single-types.d.ts +113 -0
  538. package/dist/shared/contracts/single-types.d.ts.map +1 -0
  539. package/dist/shared/contracts/uid.d.ts +48 -0
  540. package/dist/shared/contracts/uid.d.ts.map +1 -0
  541. package/dist/shared/index.d.ts +2 -0
  542. package/dist/shared/index.d.ts.map +1 -0
  543. package/dist/shared/index.js +47 -0
  544. package/dist/shared/index.js.map +1 -0
  545. package/dist/shared/index.mjs +47 -0
  546. package/dist/shared/index.mjs.map +1 -0
  547. package/package.json +133 -0
@@ -0,0 +1,730 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import { createContext, useQueryParams, useForm, useField, useNotification, useFocusInputField } from "@strapi/admin/strapi-admin";
4
+ import { Flex, TextButton, Field, Combobox, ComboboxOption, Typography, VisuallyHidden, Box, useComposedRefs, IconButton, Tooltip, Link } from "@strapi/design-system";
5
+ import { ArrowClockwise, Drag, Cross } from "@strapi/icons";
6
+ import { generateNKeysBetween } from "fractional-indexing";
7
+ import pipe from "lodash/fp/pipe";
8
+ import { getEmptyImage } from "react-dnd-html5-backend";
9
+ import { useIntl } from "react-intl";
10
+ import { NavLink } from "react-router-dom";
11
+ import { FixedSizeList } from "react-window";
12
+ import { styled } from "styled-components";
13
+ import { c as useDoc, d as buildValidParams, C as COLLECTION_TYPES, g as getTranslation, D as DocumentStatus } from "./index-BLPa8Dq-.mjs";
14
+ import { u as useDragAndDrop, I as ItemTypes, D as DROP_SENSITIVITY } from "./useDragAndDrop-DdHgKsqq.mjs";
15
+ import { u as useGetRelationsQuery, g as getRelationLabel, a as useLazySearchRelationsQuery } from "./relations-CAxDjUJF.mjs";
16
+ const [ComponentProvider, useComponent] = createContext("ComponentContext", {
17
+ id: void 0,
18
+ level: -1,
19
+ uid: void 0,
20
+ type: void 0
21
+ });
22
+ function useHandleDisconnect(fieldName, consumerName) {
23
+ const field = useField(fieldName);
24
+ const removeFieldRow = useForm(consumerName, (state) => state.removeFieldRow);
25
+ const addFieldRow = useForm(consumerName, (state) => state.addFieldRow);
26
+ const handleDisconnect = (relation) => {
27
+ if (field.value && field.value.connect) {
28
+ const indexOfRelationInConnectArray = field.value.connect.findIndex(
29
+ (rel) => rel.id === relation.id
30
+ );
31
+ if (indexOfRelationInConnectArray >= 0) {
32
+ removeFieldRow(`${fieldName}.connect`, indexOfRelationInConnectArray);
33
+ return;
34
+ }
35
+ }
36
+ addFieldRow(`${fieldName}.disconnect`, {
37
+ id: relation.id,
38
+ apiData: {
39
+ id: relation.id,
40
+ documentId: relation.documentId,
41
+ locale: relation.locale
42
+ }
43
+ });
44
+ };
45
+ return handleDisconnect;
46
+ }
47
+ const RELATIONS_TO_DISPLAY = 5;
48
+ const ONE_WAY_RELATIONS = ["oneWay", "oneToOne", "manyToOne", "oneToManyMorph", "oneToOneMorph"];
49
+ const RelationsField = React.forwardRef(
50
+ ({ disabled, label, ...props }, ref) => {
51
+ const [currentPage, setCurrentPage] = React.useState(1);
52
+ const { document, model: documentModel } = useDoc();
53
+ const documentId = document?.documentId;
54
+ const { formatMessage } = useIntl();
55
+ const [{ query }] = useQueryParams();
56
+ const params = buildValidParams(query);
57
+ const isMorph = props.attribute.relation.toLowerCase().includes("morph");
58
+ const isDisabled = isMorph || disabled;
59
+ const { componentId, componentUID } = useComponent("RelationsField", ({ uid, id: id2 }) => ({
60
+ componentId: id2,
61
+ componentUID: uid
62
+ }));
63
+ const isSubmitting = useForm("RelationsList", (state) => state.isSubmitting);
64
+ React.useEffect(() => {
65
+ setCurrentPage(1);
66
+ }, [isSubmitting]);
67
+ const id = componentId ? componentId.toString() : documentId;
68
+ const model = componentUID ?? documentModel;
69
+ const [targetField] = props.name.split(".").slice(-1);
70
+ const { data, isLoading, isFetching } = useGetRelationsQuery(
71
+ {
72
+ model,
73
+ targetField,
74
+ // below we don't run the query if there is no id.
75
+ id,
76
+ params: {
77
+ ...params,
78
+ pageSize: RELATIONS_TO_DISPLAY,
79
+ page: currentPage
80
+ }
81
+ },
82
+ {
83
+ refetchOnMountOrArgChange: true,
84
+ skip: !id,
85
+ selectFromResult: (result) => {
86
+ return {
87
+ ...result,
88
+ data: {
89
+ ...result.data,
90
+ results: result.data?.results ? result.data.results : []
91
+ }
92
+ };
93
+ }
94
+ }
95
+ );
96
+ const handleLoadMore = () => {
97
+ setCurrentPage((prev) => prev + 1);
98
+ };
99
+ const field = useField(props.name);
100
+ const isFetchingMoreRelations = isLoading || isFetching;
101
+ const realServerRelationsCount = "pagination" in data && data.pagination ? data.pagination.total : 0;
102
+ const relationsConnected = (field.value?.connect ?? []).filter(
103
+ (rel) => data.results.findIndex((relation) => relation.id === rel.id) === -1
104
+ ).length ?? 0;
105
+ const relationsDisconnected = field.value?.disconnect?.length ?? 0;
106
+ const relationsCount = realServerRelationsCount + relationsConnected - relationsDisconnected;
107
+ const relations = React.useMemo(() => {
108
+ const ctx = {
109
+ field: field.value,
110
+ // @ts-expect-error – targetModel does exist on the attribute. But it's not typed.
111
+ href: `../${COLLECTION_TYPES}/${props.attribute.targetModel}`,
112
+ mainField: props.mainField
113
+ };
114
+ const transformations = pipe(
115
+ removeConnected(ctx),
116
+ removeDisconnected(ctx),
117
+ addLabelAndHref(ctx)
118
+ );
119
+ const transformedRels = transformations([...data.results]);
120
+ return [...transformedRels, ...field.value?.connect ?? []].sort((a, b) => {
121
+ if (a.__temp_key__ < b.__temp_key__)
122
+ return -1;
123
+ if (a.__temp_key__ > b.__temp_key__)
124
+ return 1;
125
+ return 0;
126
+ });
127
+ }, [
128
+ data.results,
129
+ field.value,
130
+ // @ts-expect-error – targetModel does exist on the attribute. But it's not typed.
131
+ props.attribute.targetModel,
132
+ props.mainField
133
+ ]);
134
+ const handleDisconnect = useHandleDisconnect(props.name, "RelationsField");
135
+ const handleConnect = (relation) => {
136
+ const [lastItemInList] = relations.slice(-1);
137
+ const item = {
138
+ id: relation.id,
139
+ apiData: {
140
+ id: relation.id,
141
+ documentId: relation.documentId,
142
+ locale: relation.locale
143
+ },
144
+ status: relation.status,
145
+ /**
146
+ * If there's a last item, that's the first key we use to generate out next one.
147
+ */
148
+ __temp_key__: generateNKeysBetween(lastItemInList?.__temp_key__ ?? null, null, 1)[0],
149
+ // Fallback to `id` if there is no `mainField` value, which will overwrite the above `id` property with the exact same data.
150
+ [props.mainField?.name ?? "documentId"]: relation[props.mainField?.name ?? "documentId"],
151
+ label: getRelationLabel(relation, props.mainField),
152
+ // @ts-expect-error – targetModel does exist on the attribute, but it's not typed.
153
+ href: `../${COLLECTION_TYPES}/${props.attribute.targetModel}/${relation.documentId}?${relation.locale ? `plugins[i18n][locale]=${relation.locale}` : ""}`
154
+ };
155
+ if (ONE_WAY_RELATIONS.includes(props.attribute.relation)) {
156
+ field.value?.connect?.forEach(handleDisconnect);
157
+ relations.forEach(handleDisconnect);
158
+ field.onChange(`${props.name}.connect`, [item]);
159
+ } else {
160
+ field.onChange(`${props.name}.connect`, [...field.value?.connect ?? [], item]);
161
+ }
162
+ };
163
+ return /* @__PURE__ */ jsxs(
164
+ Flex,
165
+ {
166
+ ref,
167
+ direction: "column",
168
+ gap: 3,
169
+ justifyContent: "space-between",
170
+ alignItems: "stretch",
171
+ wrap: "wrap",
172
+ children: [
173
+ /* @__PURE__ */ jsxs(StyledFlex, { direction: "column", alignItems: "start", gap: 2, width: "100%", children: [
174
+ /* @__PURE__ */ jsx(
175
+ RelationsInput,
176
+ {
177
+ disabled: isDisabled,
178
+ id: componentUID ? componentId ? `${componentId}` : "" : documentId,
179
+ label: `${label} ${relationsCount > 0 ? `(${relationsCount})` : ""}`,
180
+ model,
181
+ onChange: handleConnect,
182
+ ...props
183
+ }
184
+ ),
185
+ "pagination" in data && data.pagination && data.pagination.pageCount > data.pagination.page ? /* @__PURE__ */ jsx(
186
+ TextButton,
187
+ {
188
+ disabled: isFetchingMoreRelations,
189
+ onClick: handleLoadMore,
190
+ loading: isFetchingMoreRelations,
191
+ startIcon: /* @__PURE__ */ jsx(ArrowClockwise, {}),
192
+ shrink: 0,
193
+ children: formatMessage({
194
+ id: getTranslation("relation.loadMore"),
195
+ defaultMessage: "Load More"
196
+ })
197
+ }
198
+ ) : null
199
+ ] }),
200
+ /* @__PURE__ */ jsx(
201
+ RelationsList,
202
+ {
203
+ data: relations,
204
+ serverData: data.results,
205
+ disabled: isDisabled,
206
+ name: props.name,
207
+ isLoading: isFetchingMoreRelations,
208
+ relationType: props.attribute.relation
209
+ }
210
+ )
211
+ ]
212
+ }
213
+ );
214
+ }
215
+ );
216
+ const StyledFlex = styled(Flex)`
217
+ & > div {
218
+ width: 100%;
219
+ }
220
+ `;
221
+ const removeConnected = ({ field }) => (relations) => {
222
+ return relations.filter((relation) => {
223
+ const connectedRelations = field?.connect ?? [];
224
+ return connectedRelations.findIndex((rel) => rel.id === relation.id) === -1;
225
+ });
226
+ };
227
+ const removeDisconnected = ({ field }) => (relations) => relations.filter((relation) => {
228
+ const disconnectedRelations = field?.disconnect ?? [];
229
+ return disconnectedRelations.findIndex((rel) => rel.id === relation.id) === -1;
230
+ });
231
+ const addLabelAndHref = ({ mainField, href }) => (relations) => relations.map((relation) => {
232
+ return {
233
+ ...relation,
234
+ // Fallback to `id` if there is no `mainField` value, which will overwrite the above `documentId` property with the exact same data.
235
+ [mainField?.name ?? "documentId"]: relation[mainField?.name ?? "documentId"],
236
+ label: getRelationLabel(relation, mainField),
237
+ href: `${href}/${relation.documentId}?${relation.locale ? `plugins[i18n][locale]=${relation.locale}` : ""}`
238
+ };
239
+ });
240
+ const RelationsInput = ({
241
+ hint,
242
+ id,
243
+ model,
244
+ label,
245
+ labelAction,
246
+ name,
247
+ mainField,
248
+ placeholder,
249
+ required,
250
+ unique: _unique,
251
+ "aria-label": _ariaLabel,
252
+ onChange,
253
+ ...props
254
+ }) => {
255
+ const [textValue, setTextValue] = React.useState("");
256
+ const [searchParams, setSearchParams] = React.useState({
257
+ _q: "",
258
+ page: 1
259
+ });
260
+ const { toggleNotification } = useNotification();
261
+ const [{ query }] = useQueryParams();
262
+ const { formatMessage } = useIntl();
263
+ const fieldRef = useFocusInputField(name);
264
+ const field = useField(name);
265
+ const [searchForTrigger, { data, isLoading }] = useLazySearchRelationsQuery();
266
+ React.useEffect(() => {
267
+ const [targetField] = name.split(".").slice(-1);
268
+ searchForTrigger({
269
+ model,
270
+ targetField,
271
+ params: {
272
+ ...buildValidParams(query),
273
+ id: id ?? "",
274
+ pageSize: 10,
275
+ idsToInclude: field.value?.disconnect?.map((rel) => rel.id.toString()) ?? [],
276
+ idsToOmit: field.value?.connect?.map((rel) => rel.id.toString()) ?? [],
277
+ ...searchParams
278
+ }
279
+ });
280
+ }, [
281
+ field.value?.connect,
282
+ field.value?.disconnect,
283
+ id,
284
+ model,
285
+ name,
286
+ query,
287
+ searchForTrigger,
288
+ searchParams
289
+ ]);
290
+ const handleSearch = async (search) => {
291
+ setSearchParams((s) => ({ ...s, _q: search, page: 1 }));
292
+ };
293
+ const hasNextPage = data?.pagination ? data.pagination.page < data.pagination.pageCount : false;
294
+ const options = data?.results ?? [];
295
+ const handleChange = (relationId) => {
296
+ if (!relationId) {
297
+ return;
298
+ }
299
+ const relation = options.find((opt) => opt.id.toString() === relationId);
300
+ if (!relation) {
301
+ console.error(
302
+ "You've tried to add a relation with an id that does not exist in the options you can see, this is likely a bug with Strapi. Please open an issue."
303
+ );
304
+ toggleNotification({
305
+ message: formatMessage({
306
+ id: getTranslation("relation.error-adding-relation"),
307
+ defaultMessage: "An error occurred while trying to add the relation."
308
+ }),
309
+ type: "danger"
310
+ });
311
+ return;
312
+ }
313
+ onChange(relation);
314
+ };
315
+ const handleLoadMore = () => {
316
+ if (!data || !data.pagination) {
317
+ return;
318
+ } else if (data.pagination.page < data.pagination.pageCount) {
319
+ setSearchParams((s) => ({ ...s, page: s.page + 1 }));
320
+ }
321
+ };
322
+ React.useLayoutEffect(() => {
323
+ setTextValue("");
324
+ }, [field.value]);
325
+ return /* @__PURE__ */ jsxs(Field.Root, { error: field.error, hint, name, required, children: [
326
+ /* @__PURE__ */ jsx(Field.Label, { action: labelAction, children: label }),
327
+ /* @__PURE__ */ jsx(
328
+ Combobox,
329
+ {
330
+ ref: fieldRef,
331
+ name,
332
+ autocomplete: "list",
333
+ placeholder: placeholder || formatMessage({
334
+ id: getTranslation("relation.add"),
335
+ defaultMessage: "Add relation"
336
+ }),
337
+ hasMoreItems: hasNextPage,
338
+ loading: isLoading,
339
+ onOpenChange: () => {
340
+ handleSearch(textValue ?? "");
341
+ },
342
+ noOptionsMessage: () => formatMessage({
343
+ id: getTranslation("relation.notAvailable"),
344
+ defaultMessage: "No relations available"
345
+ }),
346
+ loadingMessage: formatMessage({
347
+ id: getTranslation("relation.isLoading"),
348
+ defaultMessage: "Relations are loading"
349
+ }),
350
+ onLoadMore: handleLoadMore,
351
+ textValue,
352
+ onChange: handleChange,
353
+ onTextValueChange: (text) => {
354
+ setTextValue(text);
355
+ },
356
+ onInputChange: (event) => {
357
+ handleSearch(event.currentTarget.value);
358
+ },
359
+ ...props,
360
+ children: options.map((opt) => {
361
+ const textValue2 = getRelationLabel(opt, mainField);
362
+ return /* @__PURE__ */ jsx(ComboboxOption, { value: opt.id.toString(), textValue: textValue2, children: /* @__PURE__ */ jsxs(Flex, { gap: 2, justifyContent: "space-between", children: [
363
+ /* @__PURE__ */ jsx(Typography, { ellipsis: true, children: textValue2 }),
364
+ opt.status ? /* @__PURE__ */ jsx(DocumentStatus, { status: opt.status }) : null
365
+ ] }) }, opt.id);
366
+ })
367
+ }
368
+ ),
369
+ /* @__PURE__ */ jsx(Field.Error, {}),
370
+ /* @__PURE__ */ jsx(Field.Hint, {})
371
+ ] });
372
+ };
373
+ const RELATION_ITEM_HEIGHT = 50;
374
+ const RELATION_GUTTER = 4;
375
+ const RelationsList = ({
376
+ data,
377
+ serverData,
378
+ disabled,
379
+ name,
380
+ isLoading,
381
+ relationType
382
+ }) => {
383
+ const ariaDescriptionId = React.useId();
384
+ const { formatMessage } = useIntl();
385
+ const listRef = React.useRef(null);
386
+ const outerListRef = React.useRef(null);
387
+ const [overflow, setOverflow] = React.useState();
388
+ const [liveText, setLiveText] = React.useState("");
389
+ const field = useField(name);
390
+ React.useEffect(() => {
391
+ if (data.length <= RELATIONS_TO_DISPLAY) {
392
+ return setOverflow(void 0);
393
+ }
394
+ const handleNativeScroll = (e) => {
395
+ const el = e.target;
396
+ const parentScrollContainerHeight = el.parentNode.scrollHeight;
397
+ const maxScrollBottom = el.scrollHeight - el.scrollTop;
398
+ if (el.scrollTop === 0) {
399
+ return setOverflow("bottom");
400
+ }
401
+ if (maxScrollBottom === parentScrollContainerHeight) {
402
+ return setOverflow("top");
403
+ }
404
+ return setOverflow("top-bottom");
405
+ };
406
+ const outerListRefCurrent = outerListRef?.current;
407
+ if (!isLoading && data.length > 0 && outerListRefCurrent) {
408
+ outerListRef.current.addEventListener("scroll", handleNativeScroll);
409
+ }
410
+ return () => {
411
+ if (outerListRefCurrent) {
412
+ outerListRefCurrent.removeEventListener("scroll", handleNativeScroll);
413
+ }
414
+ };
415
+ }, [isLoading, data.length]);
416
+ const getItemPos = (index) => `${index + 1} of ${data.length}`;
417
+ const handleMoveItem = (newIndex, oldIndex) => {
418
+ const item = data[oldIndex];
419
+ setLiveText(
420
+ formatMessage(
421
+ {
422
+ id: getTranslation("dnd.reorder"),
423
+ defaultMessage: "{item}, moved. New position in list: {position}."
424
+ },
425
+ {
426
+ item: item.label ?? item.documentId,
427
+ position: getItemPos(newIndex)
428
+ }
429
+ )
430
+ );
431
+ const newData = [...data];
432
+ const currentRow = data[oldIndex];
433
+ const startKey = oldIndex > newIndex ? newData[newIndex - 1]?.__temp_key__ : newData[newIndex]?.__temp_key__;
434
+ const endKey = oldIndex > newIndex ? newData[newIndex]?.__temp_key__ : newData[newIndex + 1]?.__temp_key__;
435
+ const [newKey] = generateNKeysBetween(startKey, endKey, 1);
436
+ newData.splice(oldIndex, 1);
437
+ newData.splice(newIndex, 0, { ...currentRow, __temp_key__: newKey });
438
+ const connectedRelations = newData.reduce((acc, relation, currentIndex, array) => {
439
+ const relationOnServer = serverData.find((oldRelation) => oldRelation.id === relation.id);
440
+ const relationInFront = array[currentIndex + 1];
441
+ if (!relationOnServer || relationOnServer.__temp_key__ !== relation.__temp_key__) {
442
+ const position = relationInFront ? {
443
+ before: relationInFront.documentId,
444
+ locale: relationInFront.locale,
445
+ status: "publishedAt" in relationInFront && relationInFront.publishedAt ? "published" : "draft"
446
+ } : { end: true };
447
+ const relationWithPosition = {
448
+ ...relation,
449
+ ...{
450
+ apiData: {
451
+ id: relation.id,
452
+ documentId: relation.documentId,
453
+ locale: relation.locale,
454
+ position
455
+ }
456
+ }
457
+ };
458
+ return [...acc, relationWithPosition];
459
+ }
460
+ return acc;
461
+ }, []).toReversed();
462
+ field.onChange(`${name}.connect`, connectedRelations);
463
+ };
464
+ const handleGrabItem = (index) => {
465
+ const item = data[index];
466
+ setLiveText(
467
+ formatMessage(
468
+ {
469
+ id: getTranslation("dnd.grab-item"),
470
+ defaultMessage: `{item}, grabbed. Current position in list: {position}. Press up and down arrow to change position, Spacebar to drop, Escape to cancel.`
471
+ },
472
+ {
473
+ item: item.label ?? item.documentId,
474
+ position: getItemPos(index)
475
+ }
476
+ )
477
+ );
478
+ };
479
+ const handleDropItem = (index) => {
480
+ const { href: _href, label, ...item } = data[index];
481
+ setLiveText(
482
+ formatMessage(
483
+ {
484
+ id: getTranslation("dnd.drop-item"),
485
+ defaultMessage: `{item}, dropped. Final position in list: {position}.`
486
+ },
487
+ {
488
+ item: label ?? item.documentId,
489
+ position: getItemPos(index)
490
+ }
491
+ )
492
+ );
493
+ };
494
+ const handleCancel = (index) => {
495
+ const item = data[index];
496
+ setLiveText(
497
+ formatMessage(
498
+ {
499
+ id: getTranslation("dnd.cancel-item"),
500
+ defaultMessage: "{item}, dropped. Re-order cancelled."
501
+ },
502
+ {
503
+ item: item.label ?? item.documentId
504
+ }
505
+ )
506
+ );
507
+ };
508
+ const handleDisconnect = useHandleDisconnect(name, "RelationsList");
509
+ const canReorder = !ONE_WAY_RELATIONS.includes(relationType);
510
+ const dynamicListHeight = data.length > RELATIONS_TO_DISPLAY ? Math.min(data.length, RELATIONS_TO_DISPLAY) * (RELATION_ITEM_HEIGHT + RELATION_GUTTER) + RELATION_ITEM_HEIGHT / 2 : Math.min(data.length, RELATIONS_TO_DISPLAY) * (RELATION_ITEM_HEIGHT + RELATION_GUTTER);
511
+ return /* @__PURE__ */ jsxs(ShadowBox, { $overflowDirection: overflow, children: [
512
+ /* @__PURE__ */ jsx(VisuallyHidden, { id: ariaDescriptionId, children: formatMessage({
513
+ id: getTranslation("dnd.instructions"),
514
+ defaultMessage: `Press spacebar to grab and re-order`
515
+ }) }),
516
+ /* @__PURE__ */ jsx(VisuallyHidden, { "aria-live": "assertive", children: liveText }),
517
+ /* @__PURE__ */ jsx(
518
+ FixedSizeList,
519
+ {
520
+ height: dynamicListHeight,
521
+ ref: listRef,
522
+ outerRef: outerListRef,
523
+ itemCount: data.length,
524
+ itemSize: RELATION_ITEM_HEIGHT + RELATION_GUTTER,
525
+ itemData: {
526
+ ariaDescribedBy: ariaDescriptionId,
527
+ canDrag: canReorder,
528
+ disabled,
529
+ handleCancel,
530
+ handleDropItem,
531
+ handleGrabItem,
532
+ handleMoveItem,
533
+ name,
534
+ handleDisconnect,
535
+ relations: data
536
+ },
537
+ itemKey: (index) => data[index].id,
538
+ innerElementType: "ol",
539
+ children: ListItem
540
+ }
541
+ )
542
+ ] });
543
+ };
544
+ const ShadowBox = styled(Box)`
545
+ position: relative;
546
+ overflow: hidden;
547
+ flex: 1;
548
+
549
+ &:before,
550
+ &:after {
551
+ position: absolute;
552
+ width: 100%;
553
+ height: 4px;
554
+ z-index: 1;
555
+ }
556
+
557
+ &:before {
558
+ /* TODO: as for DS Table component we would need this to be handled by the DS theme */
559
+ content: '';
560
+ background: linear-gradient(rgba(3, 3, 5, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
561
+ top: 0;
562
+ opacity: ${({ $overflowDirection }) => $overflowDirection === "top-bottom" || $overflowDirection === "top" ? 1 : 0};
563
+ transition: opacity 0.2s ease-in-out;
564
+ }
565
+
566
+ &:after {
567
+ /* TODO: as for DS Table component we would need this to be handled by the DS theme */
568
+ content: '';
569
+ background: linear-gradient(0deg, rgba(3, 3, 5, 0.2) 0%, rgba(0, 0, 0, 0) 100%);
570
+ bottom: 0;
571
+ opacity: ${({ $overflowDirection }) => $overflowDirection === "top-bottom" || $overflowDirection === "bottom" ? 1 : 0};
572
+ transition: opacity 0.2s ease-in-out;
573
+ }
574
+ `;
575
+ const ListItem = ({ data, index, style }) => {
576
+ const {
577
+ ariaDescribedBy,
578
+ canDrag = false,
579
+ disabled = false,
580
+ handleCancel,
581
+ handleDisconnect,
582
+ handleDropItem,
583
+ handleGrabItem,
584
+ handleMoveItem,
585
+ name,
586
+ relations
587
+ } = data;
588
+ const { formatMessage } = useIntl();
589
+ const { href, id, label, status } = relations[index];
590
+ const [{ handlerId, isDragging, handleKeyDown }, relationRef, dropRef, dragRef, dragPreviewRef] = useDragAndDrop(
591
+ canDrag && !disabled,
592
+ {
593
+ type: `${ItemTypes.RELATION}_${name}`,
594
+ index,
595
+ item: {
596
+ displayedValue: label,
597
+ status,
598
+ id,
599
+ index
600
+ },
601
+ onMoveItem: handleMoveItem,
602
+ onDropItem: handleDropItem,
603
+ onGrabItem: handleGrabItem,
604
+ onCancel: handleCancel,
605
+ dropSensitivity: DROP_SENSITIVITY.REGULAR
606
+ }
607
+ );
608
+ const composedRefs = useComposedRefs(relationRef, dragRef);
609
+ React.useEffect(() => {
610
+ dragPreviewRef(getEmptyImage());
611
+ }, [dragPreviewRef]);
612
+ return /* @__PURE__ */ jsx(
613
+ Box,
614
+ {
615
+ style,
616
+ tag: "li",
617
+ ref: dropRef,
618
+ "aria-describedby": ariaDescribedBy,
619
+ cursor: canDrag ? "all-scroll" : "default",
620
+ children: isDragging ? /* @__PURE__ */ jsx(RelationItemPlaceholder, {}) : /* @__PURE__ */ jsxs(
621
+ Flex,
622
+ {
623
+ paddingTop: 2,
624
+ paddingBottom: 2,
625
+ paddingLeft: canDrag ? 2 : 4,
626
+ paddingRight: 4,
627
+ hasRadius: true,
628
+ borderColor: "neutral200",
629
+ background: disabled ? "neutral150" : "neutral0",
630
+ justifyContent: "space-between",
631
+ ref: composedRefs,
632
+ "data-handler-id": handlerId,
633
+ children: [
634
+ /* @__PURE__ */ jsxs(FlexWrapper, { gap: 1, children: [
635
+ canDrag ? /* @__PURE__ */ jsx(
636
+ IconButton,
637
+ {
638
+ tag: "div",
639
+ role: "button",
640
+ tabIndex: 0,
641
+ withTooltip: false,
642
+ label: formatMessage({
643
+ id: getTranslation("components.RelationInput.icon-button-aria-label"),
644
+ defaultMessage: "Drag"
645
+ }),
646
+ variant: "ghost",
647
+ onKeyDown: handleKeyDown,
648
+ disabled,
649
+ children: /* @__PURE__ */ jsx(Drag, {})
650
+ }
651
+ ) : null,
652
+ /* @__PURE__ */ jsxs(Flex, { width: "100%", minWidth: 0, justifyContent: "space-between", children: [
653
+ /* @__PURE__ */ jsx(Box, { minWidth: 0, paddingTop: 1, paddingBottom: 1, paddingRight: 4, children: /* @__PURE__ */ jsx(Tooltip, { description: label, children: href ? /* @__PURE__ */ jsx(LinkEllipsis, { tag: NavLink, to: href, isExternal: false, children: label }) : /* @__PURE__ */ jsx(Typography, { textColor: disabled ? "neutral600" : "primary600", ellipsis: true, children: label }) }) }),
654
+ status ? /* @__PURE__ */ jsx(DocumentStatus, { status }) : null
655
+ ] })
656
+ ] }),
657
+ /* @__PURE__ */ jsx(Box, { paddingLeft: 4, children: /* @__PURE__ */ jsx(
658
+ IconButton,
659
+ {
660
+ onClick: () => handleDisconnect(relations[index]),
661
+ disabled,
662
+ label: formatMessage({
663
+ id: getTranslation("relation.disconnect"),
664
+ defaultMessage: "Remove"
665
+ }),
666
+ variant: "ghost",
667
+ size: "S",
668
+ children: /* @__PURE__ */ jsx(Cross, {})
669
+ }
670
+ ) })
671
+ ]
672
+ }
673
+ )
674
+ }
675
+ );
676
+ };
677
+ const FlexWrapper = styled(Flex)`
678
+ width: 100%;
679
+ /* Used to prevent endAction to be pushed out of container */
680
+ min-width: 0;
681
+
682
+ & > div[role='button'] {
683
+ cursor: all-scroll;
684
+ }
685
+ `;
686
+ const DisconnectButton = styled.button`
687
+ svg path {
688
+ fill: ${({ theme, disabled }) => disabled ? theme.colors.neutral600 : theme.colors.neutral500};
689
+ }
690
+
691
+ &:hover svg path,
692
+ &:focus svg path {
693
+ fill: ${({ theme, disabled }) => !disabled && theme.colors.neutral600};
694
+ }
695
+ `;
696
+ const LinkEllipsis = styled(Link)`
697
+ display: block;
698
+
699
+ & > span {
700
+ white-space: nowrap;
701
+ overflow: hidden;
702
+ text-overflow: ellipsis;
703
+ display: block;
704
+ }
705
+ `;
706
+ const RelationItemPlaceholder = () => /* @__PURE__ */ jsx(
707
+ Box,
708
+ {
709
+ paddingTop: 2,
710
+ paddingBottom: 2,
711
+ paddingLeft: 4,
712
+ paddingRight: 4,
713
+ hasRadius: true,
714
+ borderStyle: "dashed",
715
+ borderColor: "primary600",
716
+ borderWidth: "1px",
717
+ background: "primary100",
718
+ height: `calc(100% - ${RELATION_GUTTER}px)`
719
+ }
720
+ );
721
+ const MemoizedRelationsField = React.memo(RelationsField);
722
+ export {
723
+ ComponentProvider as C,
724
+ DisconnectButton as D,
725
+ FlexWrapper as F,
726
+ LinkEllipsis as L,
727
+ MemoizedRelationsField as M,
728
+ useComponent as u
729
+ };
730
+ //# sourceMappingURL=Relations-5k27Rh54.mjs.map