strapi-plugin-navigation 3.0.0-beta.0 → 3.0.0-beta.2

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 (339) hide show
  1. package/README.md +23 -28
  2. package/dist/_chunks/ca-Bjfh0w36.js +480 -0
  3. package/dist/_chunks/ca-DIZHA0OL.mjs +480 -0
  4. package/dist/_chunks/en-BPYZYsnc.mjs +490 -0
  5. package/dist/_chunks/en-CT7eKHZS.js +490 -0
  6. package/dist/_chunks/fr-BTVWPkax.mjs +490 -0
  7. package/dist/_chunks/fr-ybbSdjZO.js +490 -0
  8. package/dist/admin/index.js +55426 -0
  9. package/dist/admin/index.mjs +55408 -0
  10. package/dist/admin/src/api/client.d.ts +192 -0
  11. package/dist/admin/src/api/validators.d.ts +1828 -0
  12. package/dist/admin/src/components/ConfirmationDialog/index.d.ts +20 -0
  13. package/dist/admin/src/components/Initializer.d.ts +5 -0
  14. package/dist/admin/src/components/RestartAlert/index.d.ts +2 -0
  15. package/dist/admin/src/components/TextArrayInput/index.d.ts +12 -0
  16. package/dist/admin/src/components/icons/navigation.d.ts +4 -0
  17. package/dist/admin/src/components/icons/pluginIcon.d.ts +7 -0
  18. package/dist/admin/src/index.d.ts +10 -0
  19. package/dist/admin/src/pages/App.d.ts +2 -0
  20. package/dist/admin/src/pages/HomePage/components/AdditionalFieldInput/index.d.ts +12 -0
  21. package/dist/admin/src/pages/HomePage/components/CollapseButton/index.d.ts +8 -0
  22. package/dist/admin/src/pages/HomePage/components/DragButton/index.d.ts +5 -0
  23. package/dist/admin/src/pages/HomePage/components/I18nCopyNavigationItems/index.d.ts +13 -0
  24. package/dist/admin/src/pages/HomePage/components/NavigationContentHeader/index.d.ts +7 -0
  25. package/dist/admin/src/pages/HomePage/components/NavigationHeader/hooks.d.ts +5 -0
  26. package/dist/admin/src/pages/HomePage/components/NavigationHeader/index.d.ts +23 -0
  27. package/dist/admin/src/pages/HomePage/components/NavigationHeader/styles.d.ts +2 -0
  28. package/dist/admin/src/pages/HomePage/components/NavigationItemForm/index.d.ts +22 -0
  29. package/dist/admin/src/pages/HomePage/components/NavigationItemForm/types.d.ts +45 -0
  30. package/dist/admin/src/pages/HomePage/components/NavigationItemForm/utils/form.d.ts +184 -0
  31. package/dist/admin/src/pages/HomePage/components/NavigationItemForm/utils/hooks.d.ts +1 -0
  32. package/dist/admin/src/pages/HomePage/components/NavigationItemForm/utils/properties.d.ts +33 -0
  33. package/dist/admin/src/pages/HomePage/components/NavigationItemList/Wrapper.d.ts +5 -0
  34. package/dist/admin/src/pages/HomePage/components/NavigationItemList/index.d.ts +25 -0
  35. package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardBadge/index.d.ts +2 -0
  36. package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/Wrapper.d.ts +2 -0
  37. package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/icons.d.ts +5 -0
  38. package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/index.d.ts +16 -0
  39. package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardRemovedOverlay/index.d.ts +2 -0
  40. package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/Wrapper.d.ts +6 -0
  41. package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/index.d.ts +44 -0
  42. package/dist/admin/src/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupFooter.d.ts +10 -0
  43. package/dist/admin/src/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupHeader.d.ts +4 -0
  44. package/dist/admin/src/pages/HomePage/components/NavigationItemPopup/index.d.ts +19 -0
  45. package/dist/admin/src/pages/HomePage/components/NavigationManager/AllNavigations/icons.d.ts +3 -0
  46. package/dist/admin/src/pages/HomePage/components/NavigationManager/AllNavigations/index.d.ts +7 -0
  47. package/dist/admin/src/pages/HomePage/components/NavigationManager/DeletionConfirm/index.d.ts +7 -0
  48. package/dist/admin/src/pages/HomePage/components/NavigationManager/ErrorDetails/index.d.ts +7 -0
  49. package/dist/admin/src/pages/HomePage/components/NavigationManager/Footer/index.d.ts +26 -0
  50. package/dist/admin/src/pages/HomePage/components/NavigationManager/Form/hooks.d.ts +13 -0
  51. package/dist/admin/src/pages/HomePage/components/NavigationManager/Form/index.d.ts +10 -0
  52. package/dist/admin/src/pages/HomePage/components/NavigationManager/NavigationUpdate/index.d.ts +7 -0
  53. package/dist/admin/src/pages/HomePage/components/NavigationManager/NewNavigation/index.d.ts +8 -0
  54. package/dist/admin/src/pages/HomePage/components/NavigationManager/PurgeCacheConfirm/index.d.ts +7 -0
  55. package/dist/admin/src/pages/HomePage/components/NavigationManager/index.d.ts +9 -0
  56. package/dist/admin/src/pages/HomePage/components/NavigationManager/types.d.ts +46 -0
  57. package/dist/admin/src/pages/HomePage/components/Search/index.d.ts +11 -0
  58. package/dist/admin/src/pages/HomePage/hooks/index.d.ts +144 -0
  59. package/dist/admin/src/pages/HomePage/index.d.ts +2 -0
  60. package/dist/admin/src/pages/HomePage/utils/index.d.ts +5 -0
  61. package/dist/admin/src/pages/HomePage/utils/parsers.d.ts +46 -0
  62. package/dist/admin/src/pages/SettingsPage/common/const.d.ts +1 -0
  63. package/dist/admin/src/pages/SettingsPage/components/CustomFieldForm/index.d.ts +11 -0
  64. package/dist/admin/src/pages/SettingsPage/components/CustomFieldModal/index.d.ts +11 -0
  65. package/dist/admin/src/pages/SettingsPage/components/CustomFieldTable/index.d.ts +11 -0
  66. package/dist/admin/src/pages/SettingsPage/hooks/index.d.ts +369 -0
  67. package/dist/admin/src/pages/SettingsPage/index.d.ts +1 -0
  68. package/dist/admin/src/pages/SettingsPage/types.d.ts +7 -0
  69. package/dist/admin/src/pages/SettingsPage/utils/index.d.ts +9 -0
  70. package/dist/admin/src/pluginId.d.ts +1 -0
  71. package/dist/admin/src/schemas/config.d.ts +453 -0
  72. package/dist/admin/src/schemas/content-type.d.ts +49 -0
  73. package/dist/admin/src/translations/ca.d.ts +478 -0
  74. package/dist/admin/src/translations/en.d.ts +489 -0
  75. package/dist/admin/src/translations/fr.d.ts +488 -0
  76. package/dist/admin/src/translations/index.d.ts +14 -0
  77. package/dist/admin/src/types.d.ts +6 -0
  78. package/dist/admin/src/utils/constants.d.ts +1 -0
  79. package/dist/admin/src/utils/getTranslation.d.ts +3 -0
  80. package/dist/admin/src/utils/permissions.d.ts +15 -0
  81. package/dist/admin/src/utils/prefixPluginTranslations.d.ts +3 -0
  82. package/dist/assets/configuration.png +0 -0
  83. package/dist/assets/logo.png +0 -0
  84. package/dist/assets/manager-view.png +0 -0
  85. package/dist/assets/marketplace.png +0 -0
  86. package/dist/assets/preview.png +0 -0
  87. package/dist/server/index.js +16171 -0
  88. package/dist/server/index.mjs +16135 -0
  89. package/dist/server/src/app-errors.d.ts +11 -0
  90. package/dist/server/src/bootstrap.d.ts +5 -0
  91. package/dist/server/src/cache/index.d.ts +4 -0
  92. package/dist/server/src/config/index.d.ts +20 -0
  93. package/dist/server/src/config/setup.d.ts +41 -0
  94. package/dist/server/src/content-types/audience/index.d.ts +26 -0
  95. package/dist/server/src/content-types/audience/schema.d.ts +24 -0
  96. package/dist/server/src/content-types/index.d.ts +190 -0
  97. package/dist/server/src/content-types/navigation/index.d.ts +56 -0
  98. package/dist/server/src/content-types/navigation/lifecycles.d.ts +2 -0
  99. package/dist/server/src/content-types/navigation/schema.d.ts +53 -0
  100. package/dist/server/src/content-types/navigation-item/index.d.ts +108 -0
  101. package/dist/server/src/content-types/navigation-item/lifecycles.d.ts +2 -0
  102. package/dist/server/src/content-types/navigation-item/schema.d.ts +105 -0
  103. package/dist/server/src/controllers/admin.d.ts +241 -0
  104. package/dist/server/src/controllers/client.d.ts +192 -0
  105. package/dist/server/src/controllers/index.d.ts +7 -0
  106. package/dist/server/src/controllers/utils.d.ts +4 -0
  107. package/dist/server/src/controllers/validators.d.ts +62 -0
  108. package/dist/server/src/destroy.d.ts +5 -0
  109. package/dist/server/src/dtos/config.d.ts +28 -0
  110. package/dist/server/src/dtos/index.d.ts +3 -0
  111. package/dist/server/src/dtos/navigation-item.d.ts +52 -0
  112. package/dist/server/src/dtos/navigation.d.ts +5 -0
  113. package/dist/server/src/graphql/config.d.ts +5 -0
  114. package/dist/server/src/graphql/index.d.ts +1 -0
  115. package/dist/server/src/graphql/queries/index.d.ts +1 -0
  116. package/dist/server/src/graphql/queries/render-navigation-child.d.ts +31 -0
  117. package/dist/server/src/graphql/queries/render-navigation.d.ts +32 -0
  118. package/dist/server/src/graphql/resolvers-config.d.ts +8 -0
  119. package/dist/server/src/graphql/setup.d.ts +4 -0
  120. package/dist/server/src/graphql/types/content-types-name-fields.d.ts +2 -0
  121. package/dist/server/src/graphql/types/content-types.d.ts +2 -0
  122. package/dist/server/src/graphql/types/create-navigation-item.d.ts +2 -0
  123. package/dist/server/src/graphql/types/create-navigation-related.d.ts +2 -0
  124. package/dist/server/src/graphql/types/create-navigation.d.ts +2 -0
  125. package/dist/server/src/graphql/types/index.d.ts +1 -0
  126. package/dist/server/src/graphql/types/navigation-config.d.ts +2 -0
  127. package/dist/server/src/graphql/types/navigation-details.d.ts +2 -0
  128. package/dist/server/src/graphql/types/navigation-item-additional-field-media.d.ts +2 -0
  129. package/dist/server/src/graphql/types/navigation-item-additional-fields.d.ts +2 -0
  130. package/dist/server/src/graphql/types/navigation-item-related-data.d.ts +2 -0
  131. package/dist/server/src/graphql/types/navigation-item-related.d.ts +2 -0
  132. package/dist/server/src/graphql/types/navigation-item.d.ts +2 -0
  133. package/dist/server/src/graphql/types/navigation-render-type.d.ts +2 -0
  134. package/dist/server/src/graphql/types/navigation.d.ts +2 -0
  135. package/dist/server/src/i18n/index.d.ts +4 -0
  136. package/dist/server/src/index.d.ts +582 -0
  137. package/dist/server/src/middlewares/index.d.ts +2 -0
  138. package/dist/server/src/permissions/index.d.ts +3 -0
  139. package/dist/server/src/permissions/permissions.d.ts +9 -0
  140. package/dist/server/src/permissions/setup.d.ts +4 -0
  141. package/dist/server/src/permissions.d.ts +13 -0
  142. package/dist/server/src/policies/index.d.ts +2 -0
  143. package/dist/server/src/register.d.ts +5 -0
  144. package/dist/server/src/repositories/audience.d.ts +11 -0
  145. package/dist/server/src/repositories/generic.d.ts +23 -0
  146. package/dist/server/src/repositories/index.d.ts +4 -0
  147. package/dist/server/src/repositories/navigation-item.d.ts +24 -0
  148. package/dist/server/src/repositories/navigation.d.ts +47 -0
  149. package/dist/server/src/routes/admin.d.ts +24 -0
  150. package/dist/server/src/routes/client.d.ts +17 -0
  151. package/dist/server/src/routes/index.d.ts +37 -0
  152. package/dist/server/src/schemas/config.d.ts +424 -0
  153. package/dist/server/src/schemas/content-type.d.ts +918 -0
  154. package/dist/server/src/schemas/index.d.ts +3 -0
  155. package/dist/server/src/schemas/navigation.d.ts +237 -0
  156. package/dist/server/src/services/admin/admin.d.ts +32 -0
  157. package/dist/server/src/services/admin/index.d.ts +3 -0
  158. package/dist/server/src/services/admin/types.d.ts +47 -0
  159. package/dist/server/src/services/admin/utils.d.ts +32 -0
  160. package/dist/server/src/services/client/client.d.ts +93 -0
  161. package/dist/server/src/services/client/index.d.ts +3 -0
  162. package/dist/server/src/services/client/types.d.ts +66 -0
  163. package/dist/server/src/services/client/utils.d.ts +12 -0
  164. package/dist/server/src/services/common/common.d.ts +31 -0
  165. package/dist/server/src/services/common/index.d.ts +3 -0
  166. package/dist/server/src/services/common/types.d.ts +68 -0
  167. package/dist/server/src/services/common/utils.d.ts +12 -0
  168. package/dist/server/src/services/index.d.ts +320 -0
  169. package/dist/server/src/services/migration/index.d.ts +3 -0
  170. package/dist/server/src/services/migration/migration.d.ts +8 -0
  171. package/dist/server/src/types.d.ts +40 -0
  172. package/dist/server/src/utils/constants.d.ts +13 -0
  173. package/dist/server/src/utils/functions.d.ts +30 -0
  174. package/dist/server/src/utils/index.d.ts +2 -0
  175. package/package.json +116 -35
  176. package/admin/api/client.js +0 -107
  177. package/admin/api/validators.js +0 -248
  178. package/admin/components/ConfirmationDialog/index.js +0 -21
  179. package/admin/components/Initializer.js +0 -10
  180. package/admin/components/RestartAlert/index.js +0 -7
  181. package/admin/components/TextArrayInput/index.js +0 -18
  182. package/admin/components/icons/navigation.js +0 -9
  183. package/admin/components/icons/pluginIcon.js +0 -9
  184. package/admin/index.js +0 -48
  185. package/admin/pages/App.js +0 -10
  186. package/admin/pages/HomePage/components/AdditionalFieldInput/index.js +0 -58
  187. package/admin/pages/HomePage/components/CollapseButton/index.js +0 -15
  188. package/admin/pages/HomePage/components/DragButton/index.js +0 -55
  189. package/admin/pages/HomePage/components/I18nCopyNavigationItems/index.js +0 -9
  190. package/admin/pages/HomePage/components/NavigationContentHeader/index.js +0 -5
  191. package/admin/pages/HomePage/components/NavigationHeader/hooks.js +0 -14
  192. package/admin/pages/HomePage/components/NavigationHeader/index.js +0 -29
  193. package/admin/pages/HomePage/components/NavigationHeader/styles.js +0 -11
  194. package/admin/pages/HomePage/components/NavigationItemForm/index.js +0 -277
  195. package/admin/pages/HomePage/components/NavigationItemForm/types.js +0 -1
  196. package/admin/pages/HomePage/components/NavigationItemForm/utils/form.js +0 -105
  197. package/admin/pages/HomePage/components/NavigationItemForm/utils/hooks.js +0 -12
  198. package/admin/pages/HomePage/components/NavigationItemForm/utils/properties.js +0 -51
  199. package/admin/pages/HomePage/components/NavigationItemList/Wrapper.js +0 -21
  200. package/admin/pages/HomePage/components/NavigationItemList/index.js +0 -6
  201. package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardBadge/index.js +0 -20
  202. package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/Wrapper.js +0 -14
  203. package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/icons.js +0 -6
  204. package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/index.js +0 -19
  205. package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardRemovedOverlay/index.js +0 -11
  206. package/admin/pages/HomePage/components/NavigationItemListItem/Wrapper.js +0 -38
  207. package/admin/pages/HomePage/components/NavigationItemListItem/index.js +0 -165
  208. package/admin/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupFooter.js +0 -11
  209. package/admin/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupHeader.js +0 -12
  210. package/admin/pages/HomePage/components/NavigationItemPopup/index.js +0 -34
  211. package/admin/pages/HomePage/components/NavigationManager/AllNavigations/icons.js +0 -5
  212. package/admin/pages/HomePage/components/NavigationManager/AllNavigations/index.js +0 -79
  213. package/admin/pages/HomePage/components/NavigationManager/DeletionConfirm/index.js +0 -25
  214. package/admin/pages/HomePage/components/NavigationManager/ErrorDetails/index.js +0 -29
  215. package/admin/pages/HomePage/components/NavigationManager/Footer/index.js +0 -6
  216. package/admin/pages/HomePage/components/NavigationManager/Form/hooks.js +0 -19
  217. package/admin/pages/HomePage/components/NavigationManager/Form/index.js +0 -26
  218. package/admin/pages/HomePage/components/NavigationManager/NavigationUpdate/index.js +0 -32
  219. package/admin/pages/HomePage/components/NavigationManager/NewNavigation/index.js +0 -35
  220. package/admin/pages/HomePage/components/NavigationManager/PurgeCacheConfirm/index.js +0 -25
  221. package/admin/pages/HomePage/components/NavigationManager/index.js +0 -236
  222. package/admin/pages/HomePage/components/NavigationManager/types.js +0 -1
  223. package/admin/pages/HomePage/components/Search/index.js +0 -58
  224. package/admin/pages/HomePage/hooks/index.js +0 -165
  225. package/admin/pages/HomePage/index.js +0 -231
  226. package/admin/pages/HomePage/utils/index.js +0 -16
  227. package/admin/pages/HomePage/utils/parsers.js +0 -187
  228. package/admin/pages/SettingsPage/common/const.js +0 -1
  229. package/admin/pages/SettingsPage/components/CustomFieldForm/hooks/index.js +0 -10
  230. package/admin/pages/SettingsPage/components/CustomFieldForm/index.js +0 -36
  231. package/admin/pages/SettingsPage/components/CustomFieldModal/index.js +0 -16
  232. package/admin/pages/SettingsPage/components/CustomFieldTable/index.js +0 -45
  233. package/admin/pages/SettingsPage/hooks/index.js +0 -111
  234. package/admin/pages/SettingsPage/index.js +0 -189
  235. package/admin/pages/SettingsPage/types.js +0 -1
  236. package/admin/pages/SettingsPage/utils/index.js +0 -25
  237. package/admin/pluginId.js +0 -1
  238. package/admin/schemas/config.js +0 -53
  239. package/admin/schemas/content-type.js +0 -14
  240. package/admin/translations/ca.json +0 -199
  241. package/admin/translations/en.json +0 -218
  242. package/admin/translations/fr.json +0 -48
  243. package/admin/translations/index.js +0 -15
  244. package/admin/types.js +0 -1
  245. package/admin/utils/constants.js +0 -1
  246. package/admin/utils/getTranslation.js +0 -4
  247. package/admin/utils/permissions.js +0 -16
  248. package/admin/utils/prefixPluginTranslations.js +0 -3
  249. package/server/app-errors.js +0 -20
  250. package/server/bootstrap.js +0 -13
  251. package/server/cache/index.js +0 -37
  252. package/server/config/index.js +0 -39
  253. package/server/config/setup.js +0 -59
  254. package/server/content-types/audience/index.js +0 -9
  255. package/server/content-types/audience/schema.js +0 -25
  256. package/server/content-types/index.js +0 -13
  257. package/server/content-types/navigation/index.js +0 -11
  258. package/server/content-types/navigation/lifecycles.js +0 -6
  259. package/server/content-types/navigation/schema.js +0 -54
  260. package/server/content-types/navigation-item/index.js +0 -11
  261. package/server/content-types/navigation-item/lifecycles.js +0 -6
  262. package/server/content-types/navigation-item/schema.js +0 -106
  263. package/server/controllers/admin.js +0 -125
  264. package/server/controllers/client.js +0 -86
  265. package/server/controllers/index.js +0 -11
  266. package/server/controllers/utils.js +0 -22
  267. package/server/controllers/validators.js +0 -48
  268. package/server/destroy.js +0 -6
  269. package/server/dtos/config.js +0 -2
  270. package/server/dtos/index.js +0 -19
  271. package/server/dtos/navigation-item.js +0 -2
  272. package/server/dtos/navigation.js +0 -2
  273. package/server/graphql/config.js +0 -26
  274. package/server/graphql/index.js +0 -17
  275. package/server/graphql/queries/index.js +0 -21
  276. package/server/graphql/queries/render-navigation-child.js +0 -36
  277. package/server/graphql/queries/render-navigation.js +0 -48
  278. package/server/graphql/resolvers-config.js +0 -8
  279. package/server/graphql/setup.js +0 -14
  280. package/server/graphql/types/content-types-name-fields.js +0 -15
  281. package/server/graphql/types/content-types.js +0 -18
  282. package/server/graphql/types/create-navigation-item.js +0 -19
  283. package/server/graphql/types/create-navigation-related.js +0 -10
  284. package/server/graphql/types/create-navigation.js +0 -9
  285. package/server/graphql/types/index.js +0 -38
  286. package/server/graphql/types/navigation-config.js +0 -11
  287. package/server/graphql/types/navigation-details.js +0 -12
  288. package/server/graphql/types/navigation-item-additional-field-media.js +0 -13
  289. package/server/graphql/types/navigation-item-related-data.js +0 -9
  290. package/server/graphql/types/navigation-item-related.js +0 -25
  291. package/server/graphql/types/navigation-item.js +0 -58
  292. package/server/graphql/types/navigation-render-type.js +0 -6
  293. package/server/graphql/types/navigation.js +0 -11
  294. package/server/i18n/index.js +0 -32
  295. package/server/index.js +0 -33
  296. package/server/middlewares/index.js +0 -3
  297. package/server/permissions/index.js +0 -10
  298. package/server/permissions/permissions.js +0 -12
  299. package/server/permissions/setup.js +0 -32
  300. package/server/permissions.js +0 -39
  301. package/server/policies/index.js +0 -3
  302. package/server/register.js +0 -6
  303. package/server/repositories/audience.js +0 -12
  304. package/server/repositories/generic.js +0 -20
  305. package/server/repositories/index.js +0 -11
  306. package/server/repositories/navigation-item.js +0 -51
  307. package/server/repositories/navigation.js +0 -65
  308. package/server/routes/admin.js +0 -216
  309. package/server/routes/client.js +0 -32
  310. package/server/routes/index.js +0 -12
  311. package/server/schemas/config.js +0 -68
  312. package/server/schemas/content-type.js +0 -140
  313. package/server/schemas/index.js +0 -19
  314. package/server/schemas/navigation.js +0 -107
  315. package/server/services/admin/admin.js +0 -483
  316. package/server/services/admin/index.js +0 -7
  317. package/server/services/admin/types.js +0 -2
  318. package/server/services/admin/utils.js +0 -84
  319. package/server/services/client/client.js +0 -397
  320. package/server/services/client/index.js +0 -7
  321. package/server/services/client/types.js +0 -2
  322. package/server/services/client/utils.js +0 -88
  323. package/server/services/common/common.js +0 -307
  324. package/server/services/common/index.js +0 -7
  325. package/server/services/common/types.js +0 -2
  326. package/server/services/common/utils.js +0 -24
  327. package/server/services/index.js +0 -13
  328. package/server/types.js +0 -2
  329. package/server/utils/constants.js +0 -35
  330. package/server/utils/functions.js +0 -111
  331. package/server/utils/index.js +0 -18
  332. package/strapi-admin.js +0 -5
  333. package/strapi-server.js +0 -3
  334. package/tsconfig.tsbuildinfo +0 -1
  335. /package/{admin/api/index.js → dist/admin/src/api/index.d.ts} +0 -0
  336. /package/{admin/components/icons/index.js → dist/admin/src/components/icons/index.d.ts} +0 -0
  337. /package/{admin/pages/HomePage/components/index.js → dist/admin/src/pages/HomePage/components/index.d.ts} +0 -0
  338. /package/{admin/pages/SettingsPage/common/index.js → dist/admin/src/pages/SettingsPage/common/index.d.ts} +0 -0
  339. /package/{admin/schemas/index.js → dist/admin/src/schemas/index.d.ts} +0 -0
@@ -1,29 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import { Box, Button, Field, Flex, Grid, SingleSelect, SingleSelectOption, Tag, } from '@strapi/design-system';
3
- import { Check, Information } from '@strapi/icons';
4
- import { Layouts, Page } from '@strapi/strapi/admin';
5
- import { useIntl } from 'react-intl';
6
- import { getTrad } from '../../../../translations';
7
- import { useConfig } from '../../hooks';
8
- import { useNavigationManager } from './hooks';
9
- const submitIcon = _jsx(Check, {});
10
- export const NavigationHeader = ({ activeNavigation, availableNavigations, structureHasErrors, structureHasChanged, handleChangeSelection, handleLocalizationSelection, handleSave, handleCachePurge, permissions = {}, locale, currentLocale, }) => {
11
- const { formatMessage } = useIntl();
12
- const { openNavigationManagerModal, navigationManagerModal } = useNavigationManager();
13
- const hasLocalizations = !!locale.restLocale;
14
- const { canUpdate } = permissions;
15
- const configQuery = useConfig();
16
- return (_jsxs(_Fragment, { children: [_jsx(Page.Title, { children: formatMessage(getTrad('header.title', 'UI Navigation')) }), _jsx(Layouts.Header, { title: formatMessage(getTrad('header.title', 'UI Navigation')), subtitle: formatMessage(getTrad('header.description')), primaryAction: _jsxs(Flex, { direction: "row", size: 2, children: [_jsx(Box, { children: _jsxs(Grid.Root, { gap: 4, style: configQuery.data?.isCacheEnabled ? { display: 'flex' } : undefined, children: [!hasLocalizations ? _jsx(Grid.Item, { col: 2 }) : null, canUpdate && (_jsx(Grid.Item, { col: 3, children: _jsx(Button, { onClick: openNavigationManagerModal, startIcon: null, type: "button", variant: "secondary", fullWidth: true, size: "S", children: formatMessage(getTrad('header.action.manage')) }) })), _jsx(Grid.Item, { col: canUpdate ? 4 : 10, children: _jsx(Field.Root, { width: "100%", children: _jsx(SingleSelect, { type: "select", placeholder: "Change navigation", name: "navigationSelect", onChange: (nextId) => {
17
- const nextNavigation = availableNavigations.find(({ id }) => nextId === id);
18
- if (nextNavigation) {
19
- handleChangeSelection(nextNavigation);
20
- }
21
- }, value: activeNavigation?.id, size: "S", style: null, children: availableNavigations
22
- .filter(({ localeCode }) => localeCode === currentLocale)
23
- .map(({ id, name }) => (_jsx(SingleSelectOption, { value: id, children: name }, id))) }) }) }), hasLocalizations ? (_jsx(Grid.Item, { col: 2, children: _jsx(SingleSelect, { type: "select", placeholder: formatMessage(getTrad('pages.main.header.localization.select.placeholder')), name: "navigationLocalizationSelect", onChange: handleLocalizationSelection, value: currentLocale, size: "S", children: [locale.defaultLocale, ...locale.restLocale].map((code) => (_jsx(SingleSelectOption, { value: code, children: code }, code))) }) })) : null, canUpdate && (_jsx(Grid.Item, { col: 3, children: _jsx(Button, { onClick: handleSave, startIcon: submitIcon, disabled: structureHasErrors || !structureHasChanged, type: "submit", fullWidth: true, size: "S", children: formatMessage(getTrad('submit.cta.save')) }) })), configQuery.data?.isCacheEnabled && (_jsx(Grid.Item, { col: 3, children: _jsx(Button, { onClick: handleCachePurge, startIcon: submitIcon, variant: "danger", type: "submit", fullWidth: true, size: "S", children: formatMessage(getTrad('submit.cta.cache.purge')) }) }))] }) }), canUpdate && navigationManagerModal] }), secondaryAction: _jsx(Tag, { icon: _jsx(Information, { "aria-hidden": true }), children: activeNavigation
24
- ? formatMessage(getTrad('header.meta'), {
25
- id: activeNavigation?.id,
26
- key: activeNavigation?.slug,
27
- })
28
- : null }) })] }));
29
- };
@@ -1,11 +0,0 @@
1
- import styled from 'styled-components';
2
- import { IconButton } from '@strapi/design-system';
3
- export const MoreButton = styled(IconButton) `
4
- margin: ${({ theme }) => `0 ${theme.spaces[2]}`};
5
- padding: ${({ theme }) => theme.spaces[2]};
6
-
7
- svg {
8
- width: ${18 / 16}rem;
9
- height: ${18 / 16}rem;
10
- }
11
- `;
@@ -1,277 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import { Button, Field, Grid, Modal } from '@strapi/design-system';
3
- import { useNotification } from '@strapi/strapi/admin';
4
- import { isEmpty, isNil, sortBy } from 'lodash';
5
- import { useCallback, useEffect, useMemo, useState } from 'react';
6
- import { Controller } from 'react-hook-form';
7
- import { useIntl } from 'react-intl';
8
- import { Box, MultiSelect, MultiSelectOption, SingleSelect, SingleSelectOption, TextInput, Toggle, } from '@strapi/design-system';
9
- import { getTrad } from '../../../../translations';
10
- import { RELATED_ITEM_SEPARATOR } from '../../../../utils/constants';
11
- import { useConfig, useContentTypeItems, useCopyNavigationItemI18n, useNavigations, } from '../../hooks';
12
- import { extractRelatedItemLabel } from '../../utils';
13
- import { AdditionalFieldInput } from '../AdditionalFieldInput';
14
- import { NavigationItemPopupFooter } from '../NavigationItemPopup/NavigationItemPopupFooter';
15
- import { useNavigationItemForm } from './utils/form';
16
- import { useSlug } from './utils/hooks';
17
- import { generatePreviewPath, generateUiRouterKey } from './utils/properties';
18
- import { Divider } from '@strapi/design-system';
19
- export const NavigationItemForm = ({ availableLocale, isLoading: isPreloading, current, onSubmit, onCancel, appendLabelPublicationStatus = appendLabelPublicationStatusFallback, locale, permissions = {}, currentNavigation, }) => {
20
- const { formatMessage } = useIntl();
21
- const [isLoading, setIsLoading] = useState(isPreloading);
22
- const { canUpdate } = permissions;
23
- const [isSingleSelected, setIsSingleSelected] = useState(false);
24
- const [itemLocaleCopyValue, setItemLocaleCopyValue] = useState();
25
- const configQuery = useConfig();
26
- const availableAudiences = configQuery.data?.availableAudience ?? [];
27
- const contentTypes = configQuery.data?.contentTypes ?? [];
28
- const { control, watch, handleSubmit, setValue } = useNavigationItemForm({
29
- input: {
30
- isSingleSelected,
31
- additionalFields: configQuery.data?.additionalFields ?? [],
32
- },
33
- current: current,
34
- });
35
- const { toggleNotification } = useNotification();
36
- const copyItemFromLocaleMutation = useCopyNavigationItemI18n();
37
- const navigationsQuery = useNavigations();
38
- const submit = handleSubmit(async (payload) => {
39
- const title = !!payload.title.trim()
40
- ? payload.title
41
- : getDefaultTitle(payload.related, payload.relatedType, isSingleSelected);
42
- setIsLoading(true);
43
- const uiRouterKey = await generateUiRouterKey({
44
- slugify: slugifyMutation.mutateAsync,
45
- title,
46
- related: payload.related,
47
- relatedType: payload.relatedType,
48
- });
49
- slugifyMutation.reset();
50
- setIsLoading(false);
51
- if (!uiRouterKey) {
52
- toggleNotification({
53
- type: 'warning',
54
- message: formatMessage(getTrad('popup.item.form.uiRouter.unableToRender')),
55
- });
56
- return;
57
- }
58
- onSubmit(payload.type === 'INTERNAL'
59
- ? {
60
- ...payload,
61
- title,
62
- uiRouterKey,
63
- }
64
- : {
65
- ...payload,
66
- title,
67
- uiRouterKey,
68
- });
69
- });
70
- const initialRelatedTypeSelected = current.relatedType;
71
- const [currentRelatedType, currentRelated, currentPath, currentType, currentTitle, autoSyncEnabled,] = watch(['relatedType', 'related', 'path', 'type', 'title', 'autoSync']);
72
- const isExternal = currentType === 'EXTERNAL';
73
- const pathSourceName = isExternal ? 'externalPath' : 'path';
74
- const submitDisabled = (!isExternal && !isSingleSelected && isNil(currentRelated)) || isLoading;
75
- const contentTypeItemsQuery = useContentTypeItems({
76
- uid: currentRelatedType ?? '',
77
- locale,
78
- });
79
- const slugifyMutation = useSlug();
80
- const availableLocaleOptions = useMemo(() => availableLocale.map((locale, index) => ({
81
- key: `${locale}-${index}`,
82
- value: locale,
83
- label: locale,
84
- })), [availableLocale]);
85
- const audienceOptions = useMemo(() => availableAudiences.map((item) => ({
86
- value: item.id ?? 0,
87
- label: item.name ?? ' ',
88
- })), [availableAudiences]);
89
- const getDefaultTitle = useCallback((related, relatedType, isSingleSelected) => {
90
- let selectedEntity;
91
- if (isSingleSelected) {
92
- selectedEntity = contentTypeItemsQuery.data?.find((_) => _.uid === relatedType || _.__collectionUid === relatedType);
93
- if (!selectedEntity) {
94
- return contentTypes.find((_) => _.uid === relatedType)?.contentTypeName;
95
- }
96
- }
97
- else {
98
- const entity = contentTypeItemsQuery.data?.find(({ id }) => id === related);
99
- selectedEntity = {
100
- ...(entity || {
101
- id: -1,
102
- }),
103
- __collectionUid: relatedType,
104
- };
105
- }
106
- return extractRelatedItemLabel(selectedEntity, configQuery.data);
107
- }, [contentTypeItemsQuery.data, configQuery.data, contentTypes]);
108
- const navigationItemTypeOptions = ['INTERNAL', 'EXTERNAL'].map((key) => {
109
- return {
110
- key,
111
- value: key,
112
- label: formatMessage(getTrad(`popup.item.form.type.${key.toLowerCase()}.label`)),
113
- };
114
- });
115
- const relatedSelectOptions = sortBy(contentTypeItemsQuery.data?.map((item) => {
116
- const label = appendLabelPublicationStatus(extractRelatedItemLabel({
117
- ...item,
118
- __collectionUid: currentRelatedType,
119
- }, configQuery.data), item, false);
120
- return {
121
- key: item?.id.toString(),
122
- value: item.id.toString(),
123
- label: label,
124
- };
125
- }) ?? [], (item) => item.key);
126
- const relatedTypeSelectOptions = useMemo(() => sortBy(configQuery.data?.contentTypes
127
- ?.filter((contentType) => {
128
- if (contentType.isSingle) {
129
- return !!(currentRelatedType &&
130
- [currentRelatedType, initialRelatedTypeSelected].includes(contentType.uid));
131
- }
132
- return true;
133
- })
134
- .map((item) => {
135
- return {
136
- key: item.uid,
137
- value: item.uid,
138
- label: item.contentTypeName,
139
- };
140
- }), (item) => item.key), [configQuery.data, currentRelatedType]);
141
- const thereAreNoMoreContentTypes = isEmpty(relatedSelectOptions);
142
- const onCopyFromLocale = useCallback(async (event) => {
143
- event.preventDefault();
144
- event.stopPropagation();
145
- const source = navigationsQuery.data?.find(({ localeCode }) => localeCode === itemLocaleCopyValue);
146
- if (source) {
147
- setIsLoading(true);
148
- copyItemFromLocaleMutation.mutate({
149
- target: currentNavigation.id,
150
- structureId: current.structureId,
151
- source: source.id,
152
- }, {
153
- onSuccess(data) {
154
- copyItemFromLocaleMutation.reset();
155
- const { type, externalPath, path, related, title, uiRouterKey } = data;
156
- const [contentType, id] = related?.split(RELATED_ITEM_SEPARATOR) ?? [];
157
- setValue('type', type);
158
- setValue('externalPath', externalPath ?? undefined);
159
- setValue('path', path ?? undefined);
160
- setValue('title', title);
161
- setValue('uiRouterKey', uiRouterKey);
162
- if (contentType && id) {
163
- setValue('related', parseInt(id));
164
- setValue('relatedType', contentType);
165
- }
166
- },
167
- onSettled() {
168
- setIsLoading(false);
169
- },
170
- });
171
- }
172
- }, [setIsLoading, copyItemFromLocaleMutation, navigationsQuery]);
173
- useEffect(() => {
174
- if (currentRelatedType) {
175
- const relatedType = configQuery.data?.contentTypes.find((contentType) => contentType.uid === currentRelatedType);
176
- if (relatedType) {
177
- setIsSingleSelected(relatedType.isSingle);
178
- if (relatedType.isSingle && contentTypeItemsQuery.data?.length) {
179
- const nextRelated = contentTypeItemsQuery.data[0];
180
- if (nextRelated) {
181
- setValue('related', nextRelated.id);
182
- }
183
- }
184
- }
185
- }
186
- }, [currentRelatedType, configQuery.data, contentTypeItemsQuery.data, setValue]);
187
- useEffect(() => {
188
- if (autoSyncEnabled &&
189
- currentType === 'INTERNAL' &&
190
- currentRelated &&
191
- currentRelatedType &&
192
- configQuery.data) {
193
- const relatedItem = contentTypeItemsQuery.data?.find((item) => {
194
- return item.id === currentRelated;
195
- });
196
- if (relatedItem) {
197
- const { contentTypesNameFields, pathDefaultFields } = configQuery.data;
198
- const nextPath = pathDefaultFields[currentRelatedType]?.reduce((acc, field) => {
199
- return acc ? acc : relatedItem?.[field];
200
- }, undefined);
201
- const nextTitle = (contentTypesNameFields[currentRelatedType] ?? [])
202
- .concat(contentTypesNameFields.default ?? [])
203
- .reduce((acc, field) => {
204
- return acc ? acc : relatedItem?.[field];
205
- }, undefined);
206
- const batch = [];
207
- if (nextPath && nextPath !== currentPath) {
208
- batch.push({ name: 'path', value: nextPath });
209
- }
210
- if (nextTitle && nextTitle !== currentTitle) {
211
- batch.push({ name: 'title', value: nextTitle });
212
- }
213
- setTimeout(() => {
214
- batch.forEach((next) => {
215
- setValue(next.name, next.value);
216
- });
217
- }, 100);
218
- }
219
- }
220
- }, [
221
- currentTitle,
222
- currentPath,
223
- autoSyncEnabled,
224
- currentType,
225
- currentRelated,
226
- currentRelatedType,
227
- configQuery.data,
228
- contentTypeItemsQuery.data,
229
- ]);
230
- return (_jsxs(_Fragment, { children: [_jsxs(Modal.Body, { children: [_jsxs(Grid.Root, { gap: 5, children: [_jsx(Grid.Item, { alignItems: "flex-start", col: 12, children: _jsx(Controller, { control: control, name: "title", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { width: "100%", error: fieldState.error?.message, hint: formatMessage(getTrad('popup.item.form.title.placeholder', 'e.g. Blog')), children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.title.label', 'Title')) }), _jsx(TextInput, { type: "string", disabled: !canUpdate, name: name, onChange: onChange, value: value }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "title"), _jsx(Grid.Item, { alignItems: "flex-start", col: currentType === 'INTERNAL' ? 4 : 7, lg: 12, children: _jsx(Controller, { control: control, name: "type", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, hint: formatMessage(getTrad('popup.item.form.title.placeholder', 'e.g. Blog')), width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.type.label', 'Internal link')) }), _jsx(SingleSelect, { onChange: onChange, value: value, name: name, disabled: !configQuery.data?.contentTypes.length || !canUpdate, width: "100%", children: navigationItemTypeOptions.map(({ key, label, value }) => (_jsx(SingleSelectOption, { value: value, children: label }, key))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "type"), _jsx(Grid.Item, { alignItems: "flex-start", col: currentType === 'INTERNAL' ? 4 : 5, lg: 12, children: _jsx(Controller, { control: control, name: "menuAttached", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { width: "100%", error: fieldState.error?.message, hint: formatMessage(getTrad('popup.item.form.menuAttached.placeholder', 'is menu item attached to menu')), children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.menuAttached.label', 'MenuAttached')) }), _jsx(Toggle, { name: name, checked: value, onChange: ({ currentTarget: { checked }, }) => {
231
- onChange(checked);
232
- }, value: value, onLabel: "true", offLabel: "false", disabled: !canUpdate ||
233
- (configQuery.data?.cascadeMenuAttached
234
- ? !(current.isMenuAllowedLevel && current.parentAttachedToMenu)
235
- : false), width: "100%" }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "menuAttached"), currentType === 'INTERNAL' && (_jsx(Grid.Item, { alignItems: "flex-start", col: 4, lg: 12, children: _jsx(Controller, { control: control, name: "autoSync", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, width: "230px", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.autoSync.label', 'Read fields from related')) }), _jsx(Toggle, { name: name, checked: value, onChange: ({ currentTarget: { checked }, }) => {
236
- onChange(checked);
237
- }, onLabel: "Enabled", offLabel: "Disabled" }), _jsx(Field.Error, {})] })) }) }, "autoSync")), _jsx(Grid.Item, { alignItems: "flex-start", col: 12, children: _jsx(Controller, { control: control, name: pathSourceName, render: ({ field: { value, onChange, name }, fieldState }) => {
238
- const pathDefault = generatePreviewPath({
239
- currentPath,
240
- isExternal,
241
- current,
242
- currentType,
243
- config: configQuery.data,
244
- contentTypeItems: contentTypeItemsQuery.data,
245
- currentRelated,
246
- currentRelatedType,
247
- isSingleSelected,
248
- });
249
- return (_jsxs(Field.Root, { error: fieldState.error?.message, hint: [
250
- formatMessage(getTrad(`popup.item.form.${pathSourceName}.placeholder`, 'e.g. Blog')),
251
- pathDefault
252
- ? formatMessage(getTrad('popup.item.form.type.external.description'), {
253
- value: pathDefault,
254
- })
255
- : '',
256
- ].join(' '), width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad(`popup.item.form.${pathSourceName}.label`, 'Path')) }), _jsx(TextInput, { disabled: !canUpdate, name: name, onChange: onChange, value: value, width: "100%" }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] }));
257
- } }) }, "path"), currentType === 'INTERNAL' && (_jsxs(_Fragment, { children: [_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsx(Controller, { control: control, name: "relatedType", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { width: "100%", error: fieldState.error?.message, hint: !isLoading && isEmpty(relatedTypeSelectOptions)
258
- ? formatMessage(getTrad('popup.item.form.relatedType.empty', 'There are no more content types'))
259
- : undefined, children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.relatedType.label', 'Related Type')) }), _jsx(SingleSelect, { name: name, onChange: (nextType) => {
260
- onChange(nextType);
261
- setValue('related', undefined);
262
- }, value: value, disabled: !configQuery.data?.contentTypes.length || !canUpdate, width: "100%", children: configQuery.data?.contentTypes.map((contentType) => (_jsx(SingleSelectOption, { value: contentType.uid, children: contentType.contentTypeName }, contentType.uid))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }), currentRelatedType && !isSingleSelected && (_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsx(Controller, { control: control, name: "related", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, hint: !isLoading && thereAreNoMoreContentTypes
263
- ? formatMessage(getTrad('popup.item.form.related.empty', 'There are no more entities'), { contentTypeName: currentRelatedType })
264
- : undefined, width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.related.label', 'Related')) }), _jsx(SingleSelect, { name: name, onChange: (next) => {
265
- onChange(parseInt(next, 10));
266
- }, value: value, options: relatedSelectOptions, disabled: isLoading || thereAreNoMoreContentTypes || !canUpdate, width: "100%", children: relatedSelectOptions.map(({ key, label, value }) => (_jsx(SingleSelectOption, { value: value, children: label }, key))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }))] })), configQuery.data?.additionalFields.map((additionalField) => {
267
- if (additionalField === 'audience') {
268
- return (_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsx(Controller, { control: control, name: "audience", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, hint: !isLoading && isEmpty(audienceOptions)
269
- ? formatMessage(getTrad('popup.item.form.title.placeholder', 'e.g. Blog'))
270
- : undefined, width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.audience.label')) }), _jsx(MultiSelect, { name: name, value: value?.map((x) => x.toString()), onChange: (next) => onChange(next.map(Number)), width: "100%", children: audienceOptions.map(({ value, label }) => (_jsx(MultiSelectOption, { value: value.toString(), children: label }, value))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "audience"));
271
- }
272
- else {
273
- return (_jsxs(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: [additionalField.name, _jsx(Controller, { control: control, name: `additionalFields.${additionalField.name}`, render: ({ field: { value, onChange }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, children: [_jsx(AdditionalFieldInput, { field: additionalField, isLoading: isLoading, onChange: onChange, value: value, disabled: !canUpdate }), _jsx(Field.Error, {})] })) })] }, additionalField.name));
274
- }
275
- })] }), availableLocaleOptions && (availableLocaleOptions.length > 1) && (_jsxs(_Fragment, { children: [_jsx(Divider, { marginTop: 5, marginBottom: 5 }), _jsxs(Grid.Root, { gap: 5, children: [_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsxs(Field.Root, { width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.i18n.locale.label', 'Copy details from')) }), _jsx(SingleSelect, { name: "i18n.locale", onChange: setItemLocaleCopyValue, value: itemLocaleCopyValue, disabled: isLoading || !canUpdate, placeholder: formatMessage(getTrad('popup.item.form.i18n.locale.placeholder', 'locale')), children: availableLocaleOptions.map(({ key, label, value }) => (_jsx(SingleSelectOption, { value: value, children: label }, key))) })] }) }), canUpdate && (_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, paddingTop: 6, children: _jsx(Box, { children: _jsx(Button, { variant: "tertiary", onClick: onCopyFromLocale, disabled: isLoading || !itemLocaleCopyValue, children: formatMessage(getTrad('popup.item.form.i18n.locale.button')) }) }) }))] })] }))] }), _jsx(NavigationItemPopupFooter, { handleSubmit: submit, handleCancel: onCancel, submitDisabled: submitDisabled, canUpdate: canUpdate })] }));
276
- };
277
- const appendLabelPublicationStatusFallback = () => '';
@@ -1,105 +0,0 @@
1
- import { zodResolver } from '@hookform/resolvers/zod';
2
- import { useForm } from 'react-hook-form';
3
- import { z } from 'zod';
4
- const externalPathRegexps = [
5
- /^mailto:[\w-\.]+@([\w-]+\.)+[\w-]{2,}$/,
6
- /^tel:(\+\d{1,3})?[\s]?(\(?\d{2,3}\)?)?[\s.-]?(\d{3})?[\s.-]?\d{3,4}$/,
7
- /^#.*/,
8
- /(https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|www\.[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9]+\.[^\s]{2,}|www\.[a-zA-Z0-9]+\.[^\s]{2,})/,
9
- ];
10
- const navigationItemCommon = ({ additionalFields }) => z.object({
11
- title: z.string(),
12
- autoSync: z.boolean().optional(),
13
- removed: z.boolean().optional(),
14
- updated: z.boolean().optional(),
15
- uiRouterKey: z.string(),
16
- levelPath: z.string().optional(),
17
- isMenuAllowedLevel: z.boolean().optional(),
18
- parentAttachedToMenu: z.boolean().optional(),
19
- viewId: z.number().optional(),
20
- structureId: z.string().optional(),
21
- menuAttached: z.boolean().optional(),
22
- collapsed: z.boolean().optional(),
23
- isSearchActive: z.boolean().optional(),
24
- viewParentId: z.number().optional(),
25
- id: z.number().optional(),
26
- audience: z.number().array().optional(),
27
- order: z.number().optional(),
28
- items: z.any().array().optional(),
29
- additionalFields: z.object(additionalFields.reduce((acc, field) => {
30
- if (typeof field === 'string') {
31
- return acc;
32
- }
33
- switch (field.type) {
34
- case 'string':
35
- acc[field.name] = field.required ? z.string() : z.string().optional();
36
- break;
37
- case 'boolean':
38
- acc[field.name] = field.required ? z.boolean() : z.boolean().optional();
39
- case 'media':
40
- acc[field.name] = field.required ? z.any() : z.any().optional();
41
- case 'select': {
42
- if (field.multi) {
43
- acc[field.name] = field.required ? z.string().array() : z.string().array().optional();
44
- }
45
- else {
46
- acc[field.name] = field.required ? z.string() : z.string().optional();
47
- }
48
- break;
49
- }
50
- default:
51
- break;
52
- }
53
- return acc;
54
- }, {})),
55
- });
56
- const navigationInternalItemFormSchema = ({ additionalFields, isSingleSelected, }) => navigationItemCommon({
57
- additionalFields,
58
- isSingleSelected,
59
- }).extend({
60
- type: z.literal('INTERNAL'),
61
- path: z.string(),
62
- externalPath: z.string().optional(),
63
- relatedType: z.string(),
64
- related: isSingleSelected ? z.number().optional() : z.number(),
65
- });
66
- const navigationExternalItemFormSchema = ({ isSingleSelected, additionalFields, }) => navigationItemCommon({
67
- additionalFields,
68
- isSingleSelected,
69
- }).extend({
70
- type: z.literal('EXTERNAL'),
71
- path: z.string().or(z.null()).optional(),
72
- externalPath: z
73
- .string()
74
- .min(1)
75
- .refine((path) => externalPathRegexps.some((re) => re.test(path))),
76
- relatedType: z.string().optional(),
77
- related: z.number().optional(),
78
- });
79
- const navigationItemFormSchema = (input) => z.discriminatedUnion('type', [
80
- navigationExternalItemFormSchema(input),
81
- navigationInternalItemFormSchema(input),
82
- ]);
83
- export const useNavigationItemForm = ({ input, current = defaultValues, }) => {
84
- return useForm({
85
- resolver: zodResolver(navigationItemFormSchema(input)),
86
- values: {
87
- ...defaultValues,
88
- ...current,
89
- updated: !!current.id,
90
- },
91
- });
92
- };
93
- export const defaultValues = {
94
- autoSync: true,
95
- type: 'INTERNAL',
96
- relatedType: '',
97
- menuAttached: false,
98
- title: '',
99
- externalPath: '',
100
- path: '',
101
- additionalFields: {},
102
- audience: [],
103
- updated: false,
104
- uiRouterKey: '',
105
- };
@@ -1,12 +0,0 @@
1
- import { getFetchClient } from '@strapi/strapi/admin';
2
- import { useMutation } from '@tanstack/react-query';
3
- import { getApiClient } from '../../../../../api';
4
- export const useSlug = () => {
5
- const fetch = getFetchClient();
6
- const apiClient = getApiClient(fetch);
7
- return useMutation({
8
- mutationFn(query) {
9
- return apiClient.slugify(query);
10
- },
11
- });
12
- };
@@ -1,51 +0,0 @@
1
- import { first, isEmpty } from 'lodash';
2
- import { extractRelatedItemLabel } from '../../../../HomePage/utils';
3
- export const generateUiRouterKey = async ({ slugify, title, config, related, relatedType, contentTypeItems, }) => {
4
- if (title) {
5
- return title ? await slugify(title) : undefined;
6
- }
7
- else if (related) {
8
- const relationTitle = extractRelatedItemLabel({
9
- ...(contentTypeItems?.find((_) => _.id === related) ?? {
10
- id: -1,
11
- }),
12
- __collectionUid: relatedType,
13
- }, config);
14
- return relationTitle ? await slugify(relationTitle) : undefined;
15
- }
16
- return undefined;
17
- };
18
- export const getDefaultPath = ({ currentType, config, contentTypeItems, currentRelated, currentRelatedType, isSingleSelected, }) => {
19
- if (currentType !== 'INTERNAL')
20
- return '';
21
- if (!currentRelatedType) {
22
- return '';
23
- }
24
- const pathDefaultFields = config?.pathDefaultFields[currentRelatedType] ?? [];
25
- if (isEmpty(currentType) && !isEmpty(pathDefaultFields)) {
26
- const selectedEntity = isSingleSelected
27
- ? first(contentTypeItems ?? [])
28
- : contentTypeItems?.find(({ id }) => id === currentRelated);
29
- const pathDefaultValues = pathDefaultFields
30
- .map((field) => selectedEntity?.[field] ?? '')
31
- .filter((value) => !!value.toString().trim());
32
- return pathDefaultValues[0] ?? '';
33
- }
34
- return '';
35
- };
36
- export const generatePreviewPath = ({ currentPath, isExternal, current, currentType, config, contentTypeItems, currentRelated, currentRelatedType, isSingleSelected, }) => {
37
- if (!isExternal) {
38
- const itemPath = isEmpty(currentPath) || currentPath === '/'
39
- ? getDefaultPath({
40
- currentType,
41
- config,
42
- contentTypeItems,
43
- currentRelated,
44
- currentRelatedType,
45
- isSingleSelected,
46
- })
47
- : currentPath || '';
48
- return `${current.levelPath !== '/' ? `${current.levelPath}` : ''}/${itemPath}`;
49
- }
50
- return undefined;
51
- };
@@ -1,21 +0,0 @@
1
- import styled from 'styled-components';
2
- const Wrapper = styled.div `
3
- position: relative;
4
- ${({ level, theme }) => level &&
5
- `
6
- &::before {
7
- content: "";
8
- display: block;
9
- height: ${theme.spaces[3]};
10
- width: 19px;
11
-
12
- position: absolute;
13
- top: -${theme.spaces[2]};
14
- left: 30px;
15
-
16
- border: 0px solid transparent;
17
- border-left: 4px solid ${theme.colors.neutral300};
18
- }
19
- `};
20
- `;
21
- export default Wrapper;
@@ -1,6 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Item, } from '../NavigationItemListItem';
3
- import Wrapper from './Wrapper';
4
- export const List = ({ isParentAttachedToMenu = false, items, level = 0, levelPath = '', onItemEdit, onItemLevelAdd, onItemRemove, onItemRestore, onItemReOrder, onItemToggleCollapse, displayFlat, permissions, structurePrefix, viewParentId, }) => (_jsx(Wrapper, { "data-level": level, children: items?.map((item, index) => {
5
- return (_jsx(Item, { item: item, isLast: index === items.length - 1, level: level, levelPath: levelPath, isParentAttachedToMenu: isParentAttachedToMenu, onItemRestore: onItemRestore, onItemLevelAdd: onItemLevelAdd, onItemRemove: onItemRemove, onItemEdit: onItemEdit, onItemReOrder: onItemReOrder, onItemToggleCollapse: onItemToggleCollapse, displayChildren: displayFlat, permissions: permissions, structureId: structurePrefix ? `${structurePrefix}.${index}` : index.toString(), viewParentId: viewParentId }, `list-item-${item.viewId || index}`));
6
- }) }));
@@ -1,20 +0,0 @@
1
- import { Badge } from '@strapi/design-system';
2
- import styled from 'styled-components';
3
- export const ItemCardBadge = styled(Badge) `
4
- border: 1px solid ${({ theme, borderColor }) => theme.colors[borderColor]};
5
-
6
- ${({ small, theme }) => small &&
7
- `
8
- padding: ${theme.spaces[1]} ${theme.spaces[2]};
9
- margin: 0px ${theme.spaces[3]};
10
- vertical-align: middle;
11
-
12
- cursor: default;
13
-
14
- span {
15
- font-size: .65rem;
16
- line-height: 1;
17
- vertical-align: middle;
18
- }
19
- `}
20
- `;
@@ -1,14 +0,0 @@
1
- import { CardTitle } from '@strapi/design-system';
2
- import styled from 'styled-components';
3
- export const CardItemTitle = styled(CardTitle) `
4
- width: 100%;
5
-
6
- display: flex;
7
- flex-direction: row;
8
- justify-content: space-between;
9
- align-items: center;
10
-
11
- > div > * {
12
- margin: 0px ${({ theme }) => theme.spaces[1]};
13
- }
14
- `;
@@ -1,6 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Eye, Pencil, Trash, Typhoon } from '@strapi/icons';
3
- export const pencilIcon = _jsx(Pencil, {});
4
- export const refreshIcon = _jsx(Typhoon, {});
5
- export const trashIcon = _jsx(Trash, {});
6
- export const eyeIcon = _jsx(Eye, {});
@@ -1,19 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import { IconButton as BaseIconButton, Flex, Typography } from '@strapi/design-system';
3
- import { useIntl } from 'react-intl';
4
- import styled from 'styled-components';
5
- import { getTrad } from '../../../../../translations';
6
- import DragButton from '../../DragButton';
7
- import { ItemCardBadge } from '../ItemCardBadge';
8
- import { CardItemTitle } from './Wrapper';
9
- import { eyeIcon, pencilIcon, refreshIcon, trashIcon } from './icons';
10
- const wrapperStyle = { zIndex: 2 };
11
- const pathWrapperStyle = { maxWidth: '425px' };
12
- export const ItemCardHeader = ({ title, path, icon, removed, canUpdate, onItemRemove, onItemEdit, onItemRestore, dragRef, isSearchActive, }) => {
13
- const { formatMessage } = useIntl();
14
- return (_jsxs(CardItemTitle, { children: [_jsxs(Flex, { alignItems: "center", children: [canUpdate && _jsx(DragButton, { ref: dragRef, isActive: isSearchActive }), _jsx(Typography, { variant: "omega", fontWeight: "bold", children: title }), _jsx(Typography, { variant: "omega", fontWeight: "bold", textColor: "neutral500", ellipsis: true, style: pathWrapperStyle, children: path }), _jsx(Flex, { children: icon })] }), _jsxs(Flex, { alignItems: "center", style: wrapperStyle, children: [removed && (_jsx(ItemCardBadge, { borderColor: "danger200", backgroundColor: "danger100", textColor: "danger600", children: formatMessage(getTrad('components.navigationItem.badge.removed')) })), _jsx(IconButton, { isActive: isSearchActive, disabled: removed, onClick: onItemEdit, label: formatMessage(getTrad(`components.navigationItem.action.${canUpdate ? 'edit' : 'view'}`, canUpdate ? 'Edit' : 'View')), children: canUpdate ? pencilIcon : eyeIcon }), canUpdate && (_jsx(_Fragment, { children: removed ? (_jsx(IconButton, { isActive: isSearchActive, onClick: onItemRestore, label: formatMessage(getTrad('components.navigationItem.action.restore', 'Restore')), children: refreshIcon })) : (_jsx(IconButton, { isActive: isSearchActive, onClick: onItemRemove, label: formatMessage(getTrad('components.navigationItem.action.remove', 'Remove')), children: trashIcon })) }))] })] }));
15
- };
16
- const IconButton = styled(BaseIconButton) `
17
- transition: background-color 0.3s ease-in;
18
- ${({ isActive, theme }) => (isActive ? `background-color: ${theme.colors.neutral150} ;` : '')}
19
- `;
@@ -1,11 +0,0 @@
1
- import styled from 'styled-components';
2
- export const ItemCardRemovedOverlay = styled.div `
3
- width: 100%;
4
- height: 100%;
5
- position: absolute;
6
- left: 0;
7
- right: 0;
8
- z-index: 1;
9
-
10
- background: rgba(255, 255, 255, 0.75);
11
- `;