@strapi/i18n 0.0.0-next.0521e81a13e903fbb769c5f0934bb4bfe573f7bf → 0.0.0-next.07574a2620494b9275cb638d597903ed2f92c360

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 (426) hide show
  1. package/dist/admin/components/BulkLocaleActionModal.js +262 -0
  2. package/dist/admin/components/BulkLocaleActionModal.js.map +1 -0
  3. package/dist/admin/components/BulkLocaleActionModal.mjs +260 -0
  4. package/dist/admin/components/BulkLocaleActionModal.mjs.map +1 -0
  5. package/dist/admin/components/CMHeaderActions.js +956 -0
  6. package/dist/admin/components/CMHeaderActions.js.map +1 -0
  7. package/dist/admin/components/CMHeaderActions.mjs +930 -0
  8. package/dist/admin/components/CMHeaderActions.mjs.map +1 -0
  9. package/dist/admin/components/CMListViewModalsAdditionalInformation.js +69 -0
  10. package/dist/admin/components/CMListViewModalsAdditionalInformation.js.map +1 -0
  11. package/dist/admin/components/CMListViewModalsAdditionalInformation.mjs +65 -0
  12. package/dist/admin/components/CMListViewModalsAdditionalInformation.mjs.map +1 -0
  13. package/dist/admin/components/CheckboxConfirmation.js +155 -0
  14. package/dist/admin/components/CheckboxConfirmation.js.map +1 -0
  15. package/dist/admin/components/CheckboxConfirmation.mjs +134 -0
  16. package/dist/admin/components/CheckboxConfirmation.mjs.map +1 -0
  17. package/dist/admin/components/CreateLocale.js +395 -0
  18. package/dist/admin/components/CreateLocale.js.map +1 -0
  19. package/dist/admin/components/CreateLocale.mjs +369 -0
  20. package/dist/admin/components/CreateLocale.mjs.map +1 -0
  21. package/dist/admin/components/DeleteLocale.js +90 -0
  22. package/dist/admin/components/DeleteLocale.js.map +1 -0
  23. package/dist/admin/components/DeleteLocale.mjs +69 -0
  24. package/dist/admin/components/DeleteLocale.mjs.map +1 -0
  25. package/dist/admin/components/EditLocale.js +212 -0
  26. package/dist/admin/components/EditLocale.js.map +1 -0
  27. package/dist/admin/components/EditLocale.mjs +190 -0
  28. package/dist/admin/components/EditLocale.mjs.map +1 -0
  29. package/dist/admin/components/LocaleListCell.js +102 -0
  30. package/dist/admin/components/LocaleListCell.js.map +1 -0
  31. package/dist/admin/components/LocaleListCell.mjs +100 -0
  32. package/dist/admin/components/LocaleListCell.mjs.map +1 -0
  33. package/dist/admin/components/LocalePicker.js +105 -0
  34. package/dist/admin/components/LocalePicker.js.map +1 -0
  35. package/dist/admin/components/LocalePicker.mjs +84 -0
  36. package/dist/admin/components/LocalePicker.mjs.map +1 -0
  37. package/dist/admin/components/LocaleTable.js +143 -0
  38. package/dist/admin/components/LocaleTable.js.map +1 -0
  39. package/dist/admin/components/LocaleTable.mjs +122 -0
  40. package/dist/admin/components/LocaleTable.mjs.map +1 -0
  41. package/dist/admin/constants.js +37 -0
  42. package/dist/admin/constants.js.map +1 -0
  43. package/dist/admin/constants.mjs +35 -0
  44. package/dist/admin/constants.mjs.map +1 -0
  45. package/dist/admin/contentManagerHooks/editView.js +109 -0
  46. package/dist/admin/contentManagerHooks/editView.js.map +1 -0
  47. package/dist/admin/contentManagerHooks/editView.mjs +88 -0
  48. package/dist/admin/contentManagerHooks/editView.mjs.map +1 -0
  49. package/dist/admin/contentManagerHooks/listView.js +44 -0
  50. package/dist/admin/contentManagerHooks/listView.js.map +1 -0
  51. package/dist/admin/contentManagerHooks/listView.mjs +42 -0
  52. package/dist/admin/contentManagerHooks/listView.mjs.map +1 -0
  53. package/dist/admin/contentReleasesHooks/releaseDetailsView.js +20 -0
  54. package/dist/admin/contentReleasesHooks/releaseDetailsView.js.map +1 -0
  55. package/dist/admin/contentReleasesHooks/releaseDetailsView.mjs +18 -0
  56. package/dist/admin/contentReleasesHooks/releaseDetailsView.mjs.map +1 -0
  57. package/dist/admin/hooks/useAILocalizationJobsPolling.js +110 -0
  58. package/dist/admin/hooks/useAILocalizationJobsPolling.js.map +1 -0
  59. package/dist/admin/hooks/useAILocalizationJobsPolling.mjs +89 -0
  60. package/dist/admin/hooks/useAILocalizationJobsPolling.mjs.map +1 -0
  61. package/dist/admin/hooks/useI18n.js +78 -0
  62. package/dist/admin/hooks/useI18n.js.map +1 -0
  63. package/dist/admin/hooks/useI18n.mjs +57 -0
  64. package/dist/admin/hooks/useI18n.mjs.map +1 -0
  65. package/dist/admin/index.js +221 -16
  66. package/dist/admin/index.js.map +1 -1
  67. package/dist/admin/index.mjs +203 -15
  68. package/dist/admin/index.mjs.map +1 -1
  69. package/dist/admin/middlewares/extendCTBAttributeInitialData.js +71 -0
  70. package/dist/admin/middlewares/extendCTBAttributeInitialData.js.map +1 -0
  71. package/dist/admin/middlewares/extendCTBAttributeInitialData.mjs +69 -0
  72. package/dist/admin/middlewares/extendCTBAttributeInitialData.mjs.map +1 -0
  73. package/dist/admin/middlewares/extendCTBInitialData.js +40 -0
  74. package/dist/admin/middlewares/extendCTBInitialData.js.map +1 -0
  75. package/dist/admin/middlewares/extendCTBInitialData.mjs +38 -0
  76. package/dist/admin/middlewares/extendCTBInitialData.mjs.map +1 -0
  77. package/dist/admin/middlewares/rbac-middleware.js +49 -0
  78. package/dist/admin/middlewares/rbac-middleware.js.map +1 -0
  79. package/dist/admin/middlewares/rbac-middleware.mjs +28 -0
  80. package/dist/admin/middlewares/rbac-middleware.mjs.map +1 -0
  81. package/dist/admin/pages/SettingsPage.js +182 -0
  82. package/dist/admin/pages/SettingsPage.js.map +1 -0
  83. package/dist/admin/pages/SettingsPage.mjs +179 -0
  84. package/dist/admin/pages/SettingsPage.mjs.map +1 -0
  85. package/dist/admin/pluginId.js +6 -0
  86. package/dist/admin/pluginId.js.map +1 -0
  87. package/dist/admin/pluginId.mjs +4 -0
  88. package/dist/admin/pluginId.mjs.map +1 -0
  89. package/dist/admin/services/aiLocalizationJobs.js +26 -0
  90. package/dist/admin/services/aiLocalizationJobs.js.map +1 -0
  91. package/dist/admin/services/aiLocalizationJobs.mjs +24 -0
  92. package/dist/admin/services/aiLocalizationJobs.mjs.map +1 -0
  93. package/dist/admin/services/api.js +15 -0
  94. package/dist/admin/services/api.js.map +1 -0
  95. package/dist/admin/services/api.mjs +13 -0
  96. package/dist/admin/services/api.mjs.map +1 -0
  97. package/dist/admin/services/locales.js +72 -0
  98. package/dist/admin/services/locales.js.map +1 -0
  99. package/dist/admin/services/locales.mjs +66 -0
  100. package/dist/admin/services/locales.mjs.map +1 -0
  101. package/dist/admin/services/relations.js +23 -0
  102. package/dist/admin/services/relations.js.map +1 -0
  103. package/dist/admin/services/relations.mjs +21 -0
  104. package/dist/admin/services/relations.mjs.map +1 -0
  105. package/dist/admin/services/settings.js +29 -0
  106. package/dist/admin/services/settings.js.map +1 -0
  107. package/dist/admin/services/settings.mjs +26 -0
  108. package/dist/admin/services/settings.mjs.map +1 -0
  109. package/dist/admin/src/components/CMHeaderActions.d.ts +17 -4
  110. package/dist/admin/src/components/LocaleListCell.d.ts +2 -1
  111. package/dist/admin/src/hooks/useAILocalizationJobsPolling.d.ts +9 -0
  112. package/dist/admin/src/services/aiLocalizationJobs.d.ts +6 -0
  113. package/dist/admin/src/services/api.d.ts +1 -1
  114. package/dist/admin/src/services/locales.d.ts +1 -1
  115. package/dist/admin/src/services/relations.d.ts +1 -1
  116. package/dist/admin/src/services/settings.d.ts +5 -0
  117. package/dist/admin/src/utils/schemas.d.ts +642 -16
  118. package/dist/admin/{chunks/de-nEMWvIiY.js → translations/de.json.js} +2 -2
  119. package/dist/admin/translations/de.json.js.map +1 -0
  120. package/dist/admin/{chunks/de-Cm8mYdaO.js → translations/de.json.mjs} +1 -1
  121. package/dist/admin/translations/de.json.mjs.map +1 -0
  122. package/dist/admin/{chunks/dk-CYATLPVe.js → translations/dk.json.js} +2 -2
  123. package/dist/admin/translations/dk.json.js.map +1 -0
  124. package/dist/admin/{chunks/dk-BeUFOegB.js → translations/dk.json.mjs} +1 -1
  125. package/dist/admin/translations/dk.json.mjs.map +1 -0
  126. package/dist/admin/{chunks/en-CG5cUCbD.js → translations/en.json.js} +12 -2
  127. package/dist/admin/translations/en.json.js.map +1 -0
  128. package/dist/admin/{chunks/en-eWSaCeOb.js → translations/en.json.mjs} +11 -1
  129. package/dist/admin/translations/en.json.mjs.map +1 -0
  130. package/dist/admin/{chunks/es-CWsogTGm.js → translations/es.json.js} +2 -2
  131. package/dist/admin/translations/es.json.js.map +1 -0
  132. package/dist/admin/{chunks/es-DqF_IdAc.js → translations/es.json.mjs} +1 -1
  133. package/dist/admin/translations/es.json.mjs.map +1 -0
  134. package/dist/admin/{chunks/fr-CC7UFcYd.js → translations/fr.json.js} +2 -2
  135. package/dist/admin/translations/fr.json.js.map +1 -0
  136. package/dist/admin/{chunks/fr-CyARbZ3c.js → translations/fr.json.mjs} +1 -1
  137. package/dist/admin/translations/fr.json.mjs.map +1 -0
  138. package/dist/admin/{chunks/ko-XwGmfhoq.js → translations/ko.json.js} +2 -2
  139. package/dist/admin/translations/ko.json.js.map +1 -0
  140. package/dist/admin/{chunks/ko-Ax4NSedM.js → translations/ko.json.mjs} +1 -1
  141. package/dist/admin/translations/ko.json.mjs.map +1 -0
  142. package/dist/admin/{chunks/pl-B_vzY_ZB.js → translations/pl.json.js} +2 -2
  143. package/dist/admin/translations/pl.json.js.map +1 -0
  144. package/dist/admin/{chunks/pl-B-aqvMqL.js → translations/pl.json.mjs} +1 -1
  145. package/dist/admin/translations/pl.json.mjs.map +1 -0
  146. package/dist/admin/{chunks/ru-WzHcJV1f.js → translations/ru.json.js} +2 -2
  147. package/dist/admin/translations/ru.json.js.map +1 -0
  148. package/dist/admin/{chunks/ru-VkPjQ-Sk.js → translations/ru.json.mjs} +1 -1
  149. package/dist/admin/translations/ru.json.mjs.map +1 -0
  150. package/dist/admin/{chunks/tr-CcWp6u3w.js → translations/tr.json.js} +2 -2
  151. package/dist/admin/translations/tr.json.js.map +1 -0
  152. package/dist/admin/{chunks/tr-DcTR88c9.js → translations/tr.json.mjs} +1 -1
  153. package/dist/admin/translations/tr.json.mjs.map +1 -0
  154. package/dist/admin/translations/uk.json.js +82 -0
  155. package/dist/admin/translations/uk.json.js.map +1 -0
  156. package/dist/admin/translations/uk.json.mjs +80 -0
  157. package/dist/admin/translations/uk.json.mjs.map +1 -0
  158. package/dist/admin/{chunks/zh-Hans-DnU2bhri.js → translations/zh-Hans.json.js} +2 -2
  159. package/dist/admin/translations/zh-Hans.json.js.map +1 -0
  160. package/dist/admin/{chunks/zh-Hans-L3wsRegj.js → translations/zh-Hans.json.mjs} +1 -1
  161. package/dist/admin/translations/zh-Hans.json.mjs.map +1 -0
  162. package/dist/admin/{chunks/zh-C9So4SGq.js → translations/zh.json.js} +2 -2
  163. package/dist/admin/translations/zh.json.js.map +1 -0
  164. package/dist/admin/{chunks/zh-RZyMiPIs.js → translations/zh.json.mjs} +1 -1
  165. package/dist/admin/translations/zh.json.mjs.map +1 -0
  166. package/dist/admin/utils/baseQuery.js +8 -0
  167. package/dist/admin/utils/baseQuery.js.map +1 -0
  168. package/dist/admin/utils/baseQuery.mjs +6 -0
  169. package/dist/admin/utils/baseQuery.mjs.map +1 -0
  170. package/dist/admin/utils/clean.js +70 -0
  171. package/dist/admin/utils/clean.js.map +1 -0
  172. package/dist/admin/utils/clean.mjs +68 -0
  173. package/dist/admin/utils/clean.mjs.map +1 -0
  174. package/dist/admin/utils/fields.js +34 -0
  175. package/dist/admin/utils/fields.js.map +1 -0
  176. package/dist/admin/utils/fields.mjs +31 -0
  177. package/dist/admin/utils/fields.mjs.map +1 -0
  178. package/dist/admin/utils/getTranslation.js +8 -0
  179. package/dist/admin/utils/getTranslation.js.map +1 -0
  180. package/dist/admin/utils/getTranslation.mjs +6 -0
  181. package/dist/admin/utils/getTranslation.mjs.map +1 -0
  182. package/dist/admin/utils/prefixPluginTranslations.js +11 -0
  183. package/dist/admin/utils/prefixPluginTranslations.js.map +1 -0
  184. package/dist/admin/utils/prefixPluginTranslations.mjs +9 -0
  185. package/dist/admin/utils/prefixPluginTranslations.mjs.map +1 -0
  186. package/dist/admin/utils/schemas.js +74 -0
  187. package/dist/admin/utils/schemas.js.map +1 -0
  188. package/dist/admin/utils/schemas.mjs +72 -0
  189. package/dist/admin/utils/schemas.mjs.map +1 -0
  190. package/dist/admin/utils/strings.js +6 -0
  191. package/dist/admin/utils/strings.js.map +1 -0
  192. package/dist/admin/utils/strings.mjs +4 -0
  193. package/dist/admin/utils/strings.mjs.map +1 -0
  194. package/dist/server/bootstrap.js +81 -0
  195. package/dist/server/bootstrap.js.map +1 -0
  196. package/dist/server/bootstrap.mjs +79 -0
  197. package/dist/server/bootstrap.mjs.map +1 -0
  198. package/dist/server/constants/index.js +29 -0
  199. package/dist/server/constants/index.js.map +1 -0
  200. package/dist/server/constants/index.mjs +25 -0
  201. package/dist/server/constants/index.mjs.map +1 -0
  202. package/dist/server/constants/iso-locales.json.js +2427 -0
  203. package/dist/server/constants/iso-locales.json.js.map +1 -0
  204. package/dist/server/constants/iso-locales.json.mjs +2425 -0
  205. package/dist/server/constants/iso-locales.json.mjs.map +1 -0
  206. package/dist/server/content-types/index.js +10 -0
  207. package/dist/server/content-types/index.js.map +1 -0
  208. package/dist/server/content-types/index.mjs +8 -0
  209. package/dist/server/content-types/index.mjs.map +1 -0
  210. package/dist/server/content-types/locale/index.js +10 -0
  211. package/dist/server/content-types/locale/index.js.map +1 -0
  212. package/dist/server/content-types/locale/index.mjs +8 -0
  213. package/dist/server/content-types/locale/index.mjs.map +1 -0
  214. package/dist/server/content-types/locale/schema.json.js +46 -0
  215. package/dist/server/content-types/locale/schema.json.js.map +1 -0
  216. package/dist/server/content-types/locale/schema.json.mjs +38 -0
  217. package/dist/server/content-types/locale/schema.json.mjs.map +1 -0
  218. package/dist/server/controllers/ai-localization-jobs.js +47 -0
  219. package/dist/server/controllers/ai-localization-jobs.js.map +1 -0
  220. package/dist/server/controllers/ai-localization-jobs.mjs +45 -0
  221. package/dist/server/controllers/ai-localization-jobs.mjs.map +1 -0
  222. package/dist/server/controllers/content-types.js +76 -0
  223. package/dist/server/controllers/content-types.js.map +1 -0
  224. package/dist/server/controllers/content-types.mjs +74 -0
  225. package/dist/server/controllers/content-types.mjs.map +1 -0
  226. package/dist/server/controllers/index.js +18 -0
  227. package/dist/server/controllers/index.js.map +1 -0
  228. package/dist/server/controllers/index.mjs +16 -0
  229. package/dist/server/controllers/index.mjs.map +1 -0
  230. package/dist/server/controllers/iso-locales.js +13 -0
  231. package/dist/server/controllers/iso-locales.js.map +1 -0
  232. package/dist/server/controllers/iso-locales.mjs +11 -0
  233. package/dist/server/controllers/iso-locales.mjs.map +1 -0
  234. package/dist/server/controllers/locales.js +108 -0
  235. package/dist/server/controllers/locales.js.map +1 -0
  236. package/dist/server/controllers/locales.mjs +87 -0
  237. package/dist/server/controllers/locales.mjs.map +1 -0
  238. package/dist/server/controllers/settings.js +24 -0
  239. package/dist/server/controllers/settings.js.map +1 -0
  240. package/dist/server/controllers/settings.mjs +22 -0
  241. package/dist/server/controllers/settings.mjs.map +1 -0
  242. package/dist/server/controllers/validate-locale-creation.js +47 -0
  243. package/dist/server/controllers/validate-locale-creation.js.map +1 -0
  244. package/dist/server/controllers/validate-locale-creation.mjs +45 -0
  245. package/dist/server/controllers/validate-locale-creation.mjs.map +1 -0
  246. package/dist/server/domain/locale.js +11 -0
  247. package/dist/server/domain/locale.js.map +1 -0
  248. package/dist/server/domain/locale.mjs +9 -0
  249. package/dist/server/domain/locale.mjs.map +1 -0
  250. package/dist/server/graphql.js +115 -0
  251. package/dist/server/graphql.js.map +1 -0
  252. package/dist/server/graphql.mjs +113 -0
  253. package/dist/server/graphql.mjs.map +1 -0
  254. package/dist/server/index.js +10 -3712
  255. package/dist/server/index.js.map +1 -1
  256. package/dist/server/index.mjs +7 -3691
  257. package/dist/server/index.mjs.map +1 -1
  258. package/dist/server/models/ai-localization-job.js +60 -0
  259. package/dist/server/models/ai-localization-job.js.map +1 -0
  260. package/dist/server/models/ai-localization-job.mjs +57 -0
  261. package/dist/server/models/ai-localization-job.mjs.map +1 -0
  262. package/dist/server/register.js +81 -0
  263. package/dist/server/register.js.map +1 -0
  264. package/dist/server/register.mjs +79 -0
  265. package/dist/server/register.mjs.map +1 -0
  266. package/dist/server/routes/admin.js +142 -0
  267. package/dist/server/routes/admin.js.map +1 -0
  268. package/dist/server/routes/admin.mjs +140 -0
  269. package/dist/server/routes/admin.mjs.map +1 -0
  270. package/dist/server/routes/content-api.js +19 -0
  271. package/dist/server/routes/content-api.js.map +1 -0
  272. package/dist/server/routes/content-api.mjs +17 -0
  273. package/dist/server/routes/content-api.mjs.map +1 -0
  274. package/dist/server/routes/index.js +12 -0
  275. package/dist/server/routes/index.js.map +1 -0
  276. package/dist/server/routes/index.mjs +10 -0
  277. package/dist/server/routes/index.mjs.map +1 -0
  278. package/dist/server/routes/validation/locale.js +57 -0
  279. package/dist/server/routes/validation/locale.js.map +1 -0
  280. package/dist/server/routes/validation/locale.mjs +36 -0
  281. package/dist/server/routes/validation/locale.mjs.map +1 -0
  282. package/dist/server/services/ai-localization-jobs.js +64 -0
  283. package/dist/server/services/ai-localization-jobs.js.map +1 -0
  284. package/dist/server/services/ai-localization-jobs.mjs +62 -0
  285. package/dist/server/services/ai-localization-jobs.mjs.map +1 -0
  286. package/dist/server/services/ai-localizations.js +276 -0
  287. package/dist/server/services/ai-localizations.js.map +1 -0
  288. package/dist/server/services/ai-localizations.mjs +274 -0
  289. package/dist/server/services/ai-localizations.mjs.map +1 -0
  290. package/dist/server/services/content-types.js +157 -0
  291. package/dist/server/services/content-types.js.map +1 -0
  292. package/dist/server/services/content-types.mjs +155 -0
  293. package/dist/server/services/content-types.mjs.map +1 -0
  294. package/dist/server/services/index.js +28 -0
  295. package/dist/server/services/index.js.map +1 -0
  296. package/dist/server/services/index.mjs +26 -0
  297. package/dist/server/services/index.mjs.map +1 -0
  298. package/dist/server/services/iso-locales.js +12 -0
  299. package/dist/server/services/iso-locales.js.map +1 -0
  300. package/dist/server/services/iso-locales.mjs +10 -0
  301. package/dist/server/services/iso-locales.mjs.map +1 -0
  302. package/dist/server/services/locales.js +114 -0
  303. package/dist/server/services/locales.js.map +1 -0
  304. package/dist/server/services/locales.mjs +112 -0
  305. package/dist/server/services/locales.mjs.map +1 -0
  306. package/dist/server/services/localizations.js +68 -0
  307. package/dist/server/services/localizations.js.map +1 -0
  308. package/dist/server/services/localizations.mjs +66 -0
  309. package/dist/server/services/localizations.mjs.map +1 -0
  310. package/dist/server/services/metrics.js +41 -0
  311. package/dist/server/services/metrics.js.map +1 -0
  312. package/dist/server/services/metrics.mjs +39 -0
  313. package/dist/server/services/metrics.mjs.map +1 -0
  314. package/dist/server/services/permissions/actions.js +136 -0
  315. package/dist/server/services/permissions/actions.js.map +1 -0
  316. package/dist/server/services/permissions/actions.mjs +134 -0
  317. package/dist/server/services/permissions/actions.mjs.map +1 -0
  318. package/dist/server/services/permissions/engine.js +52 -0
  319. package/dist/server/services/permissions/engine.js.map +1 -0
  320. package/dist/server/services/permissions/engine.mjs +50 -0
  321. package/dist/server/services/permissions/engine.mjs.map +1 -0
  322. package/dist/server/services/permissions/sections-builder.js +45 -0
  323. package/dist/server/services/permissions/sections-builder.js.map +1 -0
  324. package/dist/server/services/permissions/sections-builder.mjs +43 -0
  325. package/dist/server/services/permissions/sections-builder.mjs.map +1 -0
  326. package/dist/server/services/permissions.js +14 -0
  327. package/dist/server/services/permissions.js.map +1 -0
  328. package/dist/server/services/permissions.mjs +12 -0
  329. package/dist/server/services/permissions.mjs.map +1 -0
  330. package/dist/server/services/sanitize/index.js +34 -0
  331. package/dist/server/services/sanitize/index.js.map +1 -0
  332. package/dist/server/services/sanitize/index.mjs +32 -0
  333. package/dist/server/services/sanitize/index.mjs.map +1 -0
  334. package/dist/server/services/settings.js +25 -0
  335. package/dist/server/services/settings.js.map +1 -0
  336. package/dist/server/services/settings.mjs +23 -0
  337. package/dist/server/services/settings.mjs.map +1 -0
  338. package/dist/server/src/bootstrap.d.ts.map +1 -1
  339. package/dist/server/src/controllers/ai-localization-jobs.d.ts +17 -0
  340. package/dist/server/src/controllers/ai-localization-jobs.d.ts.map +1 -0
  341. package/dist/server/src/controllers/index.d.ts +10 -0
  342. package/dist/server/src/controllers/index.d.ts.map +1 -1
  343. package/dist/server/src/controllers/settings.d.ts +7 -0
  344. package/dist/server/src/controllers/settings.d.ts.map +1 -0
  345. package/dist/server/src/index.d.ts +48 -8
  346. package/dist/server/src/index.d.ts.map +1 -1
  347. package/dist/server/src/models/ai-localization-job.d.ts +5 -0
  348. package/dist/server/src/models/ai-localization-job.d.ts.map +1 -0
  349. package/dist/server/src/models/index.d.ts +5 -0
  350. package/dist/server/src/models/index.d.ts.map +1 -0
  351. package/dist/server/src/register.d.ts +1 -1
  352. package/dist/server/src/register.d.ts.map +1 -1
  353. package/dist/server/src/routes/admin.d.ts.map +1 -1
  354. package/dist/server/src/routes/content-api.d.ts +5 -8
  355. package/dist/server/src/routes/content-api.d.ts.map +1 -1
  356. package/dist/server/src/routes/index.d.ts +3 -7
  357. package/dist/server/src/routes/index.d.ts.map +1 -1
  358. package/dist/server/src/routes/validation/index.d.ts +2 -0
  359. package/dist/server/src/routes/validation/index.d.ts.map +1 -0
  360. package/dist/server/src/routes/validation/locale.d.ts +41 -0
  361. package/dist/server/src/routes/validation/locale.d.ts.map +1 -0
  362. package/dist/server/src/services/ai-localization-jobs.d.ts +26 -0
  363. package/dist/server/src/services/ai-localization-jobs.d.ts.map +1 -0
  364. package/dist/server/src/services/ai-localizations.d.ts +18 -0
  365. package/dist/server/src/services/ai-localizations.d.ts.map +1 -0
  366. package/dist/server/src/services/index.d.ts +34 -0
  367. package/dist/server/src/services/index.d.ts.map +1 -1
  368. package/dist/server/src/services/metrics.d.ts +1 -0
  369. package/dist/server/src/services/metrics.d.ts.map +1 -1
  370. package/dist/server/src/services/settings.d.ts +13 -0
  371. package/dist/server/src/services/settings.d.ts.map +1 -0
  372. package/dist/server/src/utils/index.d.ts +7 -1
  373. package/dist/server/src/utils/index.d.ts.map +1 -1
  374. package/dist/server/src/validation/settings.d.ts +12 -0
  375. package/dist/server/src/validation/settings.d.ts.map +1 -0
  376. package/dist/server/utils/index.js +16 -0
  377. package/dist/server/utils/index.js.map +1 -0
  378. package/dist/server/utils/index.mjs +13 -0
  379. package/dist/server/utils/index.mjs.map +1 -0
  380. package/dist/server/validation/content-types.js +18 -0
  381. package/dist/server/validation/content-types.js.map +1 -0
  382. package/dist/server/validation/content-types.mjs +16 -0
  383. package/dist/server/validation/content-types.mjs.map +1 -0
  384. package/dist/server/validation/locales.js +23 -0
  385. package/dist/server/validation/locales.js.map +1 -0
  386. package/dist/server/validation/locales.mjs +20 -0
  387. package/dist/server/validation/locales.mjs.map +1 -0
  388. package/dist/server/validation/settings.js +11 -0
  389. package/dist/server/validation/settings.js.map +1 -0
  390. package/dist/server/validation/settings.mjs +9 -0
  391. package/dist/server/validation/settings.mjs.map +1 -0
  392. package/dist/shared/contracts/ai-localization-jobs.d.ts +27 -0
  393. package/dist/shared/contracts/ai-localization-jobs.d.ts.map +1 -0
  394. package/dist/shared/contracts/settings.d.ts +40 -0
  395. package/dist/shared/contracts/shared.d.ts.map +1 -0
  396. package/package.json +12 -9
  397. package/dist/admin/chunks/SettingsPage-B6ikxVOg.js +0 -820
  398. package/dist/admin/chunks/SettingsPage-B6ikxVOg.js.map +0 -1
  399. package/dist/admin/chunks/SettingsPage-Kg4GAThm.js +0 -797
  400. package/dist/admin/chunks/SettingsPage-Kg4GAThm.js.map +0 -1
  401. package/dist/admin/chunks/de-Cm8mYdaO.js.map +0 -1
  402. package/dist/admin/chunks/de-nEMWvIiY.js.map +0 -1
  403. package/dist/admin/chunks/dk-BeUFOegB.js.map +0 -1
  404. package/dist/admin/chunks/dk-CYATLPVe.js.map +0 -1
  405. package/dist/admin/chunks/en-CG5cUCbD.js.map +0 -1
  406. package/dist/admin/chunks/en-eWSaCeOb.js.map +0 -1
  407. package/dist/admin/chunks/es-CWsogTGm.js.map +0 -1
  408. package/dist/admin/chunks/es-DqF_IdAc.js.map +0 -1
  409. package/dist/admin/chunks/fr-CC7UFcYd.js.map +0 -1
  410. package/dist/admin/chunks/fr-CyARbZ3c.js.map +0 -1
  411. package/dist/admin/chunks/index-Dch-2xao.js +0 -2035
  412. package/dist/admin/chunks/index-Dch-2xao.js.map +0 -1
  413. package/dist/admin/chunks/index-DyvbIjH9.js +0 -2006
  414. package/dist/admin/chunks/index-DyvbIjH9.js.map +0 -1
  415. package/dist/admin/chunks/ko-Ax4NSedM.js.map +0 -1
  416. package/dist/admin/chunks/ko-XwGmfhoq.js.map +0 -1
  417. package/dist/admin/chunks/pl-B-aqvMqL.js.map +0 -1
  418. package/dist/admin/chunks/pl-B_vzY_ZB.js.map +0 -1
  419. package/dist/admin/chunks/ru-VkPjQ-Sk.js.map +0 -1
  420. package/dist/admin/chunks/ru-WzHcJV1f.js.map +0 -1
  421. package/dist/admin/chunks/tr-CcWp6u3w.js.map +0 -1
  422. package/dist/admin/chunks/tr-DcTR88c9.js.map +0 -1
  423. package/dist/admin/chunks/zh-C9So4SGq.js.map +0 -1
  424. package/dist/admin/chunks/zh-Hans-DnU2bhri.js.map +0 -1
  425. package/dist/admin/chunks/zh-Hans-L3wsRegj.js.map +0 -1
  426. package/dist/admin/chunks/zh-RZyMiPIs.js.map +0 -1
@@ -0,0 +1,930 @@
1
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
2
+ import * as React from 'react';
3
+ import { skipToken } from '@reduxjs/toolkit/query';
4
+ import { useQueryParams, useForm, useNotification, useAPIErrorHandler, Table } from '@strapi/admin/strapi-admin';
5
+ import { useAIAvailability } from '@strapi/admin/strapi-admin/ee';
6
+ import { unstable_useDocument, unstable_useDocumentActions, buildValidParams } from '@strapi/content-manager/strapi-admin';
7
+ import { Status, SingleSelectOption, Box, Typography, Flex, Link, Dialog, Field, SingleSelect, Button, Modal } from '@strapi/design-system';
8
+ import { Trash, Sparkle, Earth, WarningCircle, Plus, ListPlus, Cross } from '@strapi/icons';
9
+ import { useIntl } from 'react-intl';
10
+ import { NavLink, useNavigate } from 'react-router-dom';
11
+ import { styled } from 'styled-components';
12
+ import { useAILocalizationJobsPolling } from '../hooks/useAILocalizationJobsPolling.mjs';
13
+ import { useI18n } from '../hooks/useI18n.mjs';
14
+ import { useGetAILocalizationJobsByDocumentQuery } from '../services/aiLocalizationJobs.mjs';
15
+ import { useGetLocalesQuery } from '../services/locales.mjs';
16
+ import { useGetManyDraftRelationCountQuery } from '../services/relations.mjs';
17
+ import { useGetSettingsQuery } from '../services/settings.mjs';
18
+ import { cleanData } from '../utils/clean.mjs';
19
+ import { getTranslation } from '../utils/getTranslation.mjs';
20
+ import { capitalize } from '../utils/strings.mjs';
21
+ import { BulkLocaleActionModal } from './BulkLocaleActionModal.mjs';
22
+
23
+ const statusVariants = {
24
+ draft: 'secondary',
25
+ published: 'success',
26
+ modified: 'alternative'
27
+ };
28
+ const LocaleOption = ({ isDraftAndPublishEnabled, locale, status, entryExists })=>{
29
+ const { formatMessage } = useIntl();
30
+ if (!entryExists) {
31
+ return formatMessage({
32
+ id: getTranslation('CMEditViewLocalePicker.locale.create'),
33
+ defaultMessage: 'Create <bold>{locale}</bold> locale'
34
+ }, {
35
+ bold: (locale)=>/*#__PURE__*/ jsx("b", {
36
+ children: locale
37
+ }),
38
+ locale: locale.name
39
+ });
40
+ }
41
+ return /*#__PURE__*/ jsxs(Flex, {
42
+ width: "100%",
43
+ gap: 1,
44
+ justifyContent: "space-between",
45
+ children: [
46
+ /*#__PURE__*/ jsx(Typography, {
47
+ children: locale.name
48
+ }),
49
+ isDraftAndPublishEnabled ? /*#__PURE__*/ jsx(Status, {
50
+ display: "flex",
51
+ paddingLeft: "6px",
52
+ paddingRight: "6px",
53
+ paddingTop: "2px",
54
+ paddingBottom: "2px",
55
+ size: "S",
56
+ variant: statusVariants[status],
57
+ children: /*#__PURE__*/ jsx(Typography, {
58
+ tag: "span",
59
+ variant: "pi",
60
+ fontWeight: "bold",
61
+ children: capitalize(status)
62
+ })
63
+ }) : null
64
+ ]
65
+ });
66
+ };
67
+ const LocaleOptionStartIcon = ({ entryWithLocaleExists, translationStatus, index })=>{
68
+ const isAiAvailable = useAIAvailability();
69
+ if (!entryWithLocaleExists) {
70
+ return /*#__PURE__*/ jsx(Plus, {});
71
+ }
72
+ if (isAiAvailable && index !== 0 && translationStatus === 'failed') {
73
+ return /*#__PURE__*/ jsx(WarningCircle, {
74
+ fill: "warning600"
75
+ });
76
+ }
77
+ return null;
78
+ };
79
+ const LocalePickerAction = ({ document, meta, model, collectionType, documentId })=>{
80
+ const { formatMessage } = useIntl();
81
+ const [{ query }, setQuery] = useQueryParams();
82
+ const { hasI18n, canCreate, canRead } = useI18n();
83
+ const { data: locales = [] } = useGetLocalesQuery();
84
+ const currentDesiredLocale = query.plugins?.i18n?.locale;
85
+ const { schema } = unstable_useDocument({
86
+ model,
87
+ collectionType,
88
+ documentId,
89
+ params: {
90
+ locale: currentDesiredLocale
91
+ }
92
+ });
93
+ const { data: jobData } = useGetAILocalizationJobsByDocumentQuery({
94
+ documentId: documentId,
95
+ model: model,
96
+ collectionType: collectionType
97
+ });
98
+ const { data: settings } = useGetSettingsQuery();
99
+ const isAiAvailable = useAIAvailability();
100
+ const setValues = useForm('LocalePickerAction', (state)=>state.setValues);
101
+ const handleSelect = React.useCallback((value)=>{
102
+ setQuery({
103
+ plugins: {
104
+ ...query.plugins,
105
+ i18n: {
106
+ locale: value
107
+ }
108
+ }
109
+ }, 'push', true);
110
+ }, [
111
+ query.plugins,
112
+ setQuery
113
+ ]);
114
+ const nonTranslatedFields = React.useMemo(()=>{
115
+ if (!schema?.attributes) return [];
116
+ return Object.keys(schema.attributes).filter((field)=>{
117
+ const attribute = schema.attributes[field];
118
+ return attribute?.pluginOptions?.i18n?.localized === false;
119
+ });
120
+ }, [
121
+ schema?.attributes
122
+ ]);
123
+ const sourceLocaleData = React.useMemo(()=>{
124
+ if (!Array.isArray(locales) || !meta?.availableLocales) return null;
125
+ const defaultLocale = locales.find((locale)=>locale.isDefault);
126
+ const existingLocales = meta.availableLocales.map((loc)=>loc.locale);
127
+ const sourceLocaleCode = defaultLocale && existingLocales.includes(defaultLocale.code) && defaultLocale.code !== currentDesiredLocale ? defaultLocale.code : existingLocales.find((locale)=>locale !== currentDesiredLocale);
128
+ if (!sourceLocaleCode) return null;
129
+ // Find the document data from availableLocales (now includes non-translatable fields)
130
+ const sourceLocaleDoc = meta.availableLocales.find((loc)=>loc.locale === sourceLocaleCode);
131
+ return sourceLocaleDoc ? {
132
+ locale: sourceLocaleCode,
133
+ data: sourceLocaleDoc
134
+ } : null;
135
+ }, [
136
+ locales,
137
+ meta?.availableLocales,
138
+ currentDesiredLocale
139
+ ]);
140
+ /**
141
+ * Prefilling form with non-translatable fields from already existing locale
142
+ */ React.useEffect(()=>{
143
+ // Only run when creating a new locale (no document ID yet) and when we have non-translatable fields
144
+ if (!document?.id && nonTranslatedFields.length > 0 && sourceLocaleData?.data) {
145
+ const dataToSet = nonTranslatedFields.reduce((acc, field)=>{
146
+ acc[field] = sourceLocaleData.data[field];
147
+ return acc;
148
+ }, {});
149
+ if (Object.keys(dataToSet).length > 0) {
150
+ setValues(dataToSet);
151
+ }
152
+ }
153
+ }, [
154
+ document?.id,
155
+ nonTranslatedFields,
156
+ sourceLocaleData?.data,
157
+ setValues
158
+ ]);
159
+ React.useEffect(()=>{
160
+ if (!Array.isArray(locales) || !hasI18n) {
161
+ return;
162
+ }
163
+ /**
164
+ * Handle the case where the current locale query param doesn't exist
165
+ * in the list of available locales, so we redirect to the default locale.
166
+ */ const doesLocaleExist = locales.find((loc)=>loc.code === currentDesiredLocale);
167
+ const defaultLocale = locales.find((locale)=>locale.isDefault);
168
+ if (!doesLocaleExist && defaultLocale?.code) {
169
+ handleSelect(defaultLocale.code);
170
+ }
171
+ }, [
172
+ handleSelect,
173
+ hasI18n,
174
+ locales,
175
+ currentDesiredLocale
176
+ ]);
177
+ const currentLocale = Array.isArray(locales) ? locales.find((locale)=>locale.code === currentDesiredLocale) : undefined;
178
+ // Use meta.availableLocales instead of document.localizations
179
+ // meta.availableLocales contains all locales for the document, even when creating new locales
180
+ const availableLocales = meta?.availableLocales ?? [];
181
+ const documentLocalizations = document?.localizations ?? [];
182
+ // Prefer meta.availableLocales as it's more reliable, fallback to document.localizations
183
+ const allLocalizations = availableLocales.length > 0 ? availableLocales : documentLocalizations;
184
+ const allCurrentLocales = [
185
+ {
186
+ status: getDocumentStatus(document, meta),
187
+ locale: currentLocale?.code
188
+ },
189
+ ...allLocalizations
190
+ ];
191
+ if (!hasI18n || !Array.isArray(locales) || locales.length === 0) {
192
+ return null;
193
+ }
194
+ const displayedLocales = locales.filter((locale)=>{
195
+ /**
196
+ * If you can read we allow you to see the locale exists
197
+ * otherwise the locale is hidden.
198
+ */ return canRead.includes(locale.code);
199
+ });
200
+ const localesSortingDefaultFirst = displayedLocales.sort((a, b)=>a.isDefault ? -1 : b.isDefault ? 1 : 0);
201
+ return {
202
+ label: formatMessage({
203
+ id: getTranslation('Settings.locales.modal.locales.label'),
204
+ defaultMessage: 'Locales'
205
+ }),
206
+ options: localesSortingDefaultFirst.map((locale, index)=>{
207
+ const entryWithLocaleExists = allCurrentLocales.some((doc)=>doc.locale === locale.code);
208
+ const currentLocaleDoc = allCurrentLocales.find((doc)=>'locale' in doc ? doc.locale === locale.code : false);
209
+ const permissionsToCheck = currentLocaleDoc ? canRead : canCreate;
210
+ if (isAiAvailable && settings?.data?.aiLocalizations) {
211
+ return {
212
+ _render: ()=>/*#__PURE__*/ jsxs(React.Fragment, {
213
+ children: [
214
+ /*#__PURE__*/ jsx(SingleSelectOption, {
215
+ disabled: !permissionsToCheck.includes(locale.code),
216
+ startIcon: /*#__PURE__*/ jsx(LocaleOptionStartIcon, {
217
+ entryWithLocaleExists: entryWithLocaleExists,
218
+ translationStatus: jobData?.data?.status,
219
+ index: index
220
+ }),
221
+ value: locale.code,
222
+ children: /*#__PURE__*/ jsx(LocaleOption, {
223
+ isDraftAndPublishEnabled: !!schema?.options?.draftAndPublish,
224
+ locale: locale,
225
+ status: currentLocaleDoc?.status,
226
+ entryExists: entryWithLocaleExists
227
+ })
228
+ }, locale.code),
229
+ localesSortingDefaultFirst.length > 1 && index === 0 && /*#__PURE__*/ jsx(Box, {
230
+ paddingRight: 4,
231
+ paddingLeft: 4,
232
+ paddingTop: 2,
233
+ paddingBottom: 2,
234
+ children: /*#__PURE__*/ jsx(Typography, {
235
+ variant: "sigma",
236
+ children: formatMessage({
237
+ id: getTranslation('CMEditViewLocalePicker.locale.ai-translations'),
238
+ defaultMessage: 'AI Translations'
239
+ })
240
+ })
241
+ })
242
+ ]
243
+ }, index)
244
+ };
245
+ }
246
+ return {
247
+ disabled: !permissionsToCheck.includes(locale.code),
248
+ value: locale.code,
249
+ label: /*#__PURE__*/ jsx(LocaleOption, {
250
+ isDraftAndPublishEnabled: !!schema?.options?.draftAndPublish,
251
+ locale: locale,
252
+ status: currentLocaleDoc?.status,
253
+ entryExists: entryWithLocaleExists,
254
+ translationStatus: jobData?.data?.status
255
+ }),
256
+ startIcon: /*#__PURE__*/ jsx(LocaleOptionStartIcon, {
257
+ entryWithLocaleExists: entryWithLocaleExists
258
+ })
259
+ };
260
+ }),
261
+ customizeContent: ()=>currentLocale?.name,
262
+ onSelect: handleSelect,
263
+ value: currentLocale
264
+ };
265
+ };
266
+ const getDocumentStatus = (document, meta)=>{
267
+ const docStatus = document?.status;
268
+ const statuses = meta?.availableStatus ?? [];
269
+ /**
270
+ * Creating an entry
271
+ */ if (!docStatus) {
272
+ return 'draft';
273
+ }
274
+ /**
275
+ * We're viewing a draft, but the document could have a published version
276
+ */ if (docStatus === 'draft' && statuses.find((doc)=>doc.publishedAt !== null)) {
277
+ return 'published';
278
+ }
279
+ return docStatus;
280
+ };
281
+ /* -------------------------------------------------------------------------------------------------
282
+ * AISettingsStatusAction
283
+ * -----------------------------------------------------------------------------------------------*/ const AITranslationStatusIcon = styled(Status)`
284
+ display: flex;
285
+ gap: ${({ theme })=>theme.spaces[1]};
286
+ justify-content: center;
287
+ align-items: center;
288
+ height: 100%;
289
+
290
+ // Disabled state
291
+ ${({ $isAISettingEnabled, theme })=>!$isAISettingEnabled && `
292
+ background-color: ${theme.colors.neutral150};
293
+ `}
294
+
295
+ svg {
296
+ ${({ $isAISettingEnabled, theme })=>!$isAISettingEnabled && `
297
+ fill: ${theme.colors.neutral300};
298
+ `}
299
+ }
300
+ `;
301
+ const AITranslationStatusAction = ({ documentId, model, collectionType })=>{
302
+ const { formatMessage } = useIntl();
303
+ const isAIAvailable = useAIAvailability();
304
+ const { data: settings } = useGetSettingsQuery();
305
+ const isAISettingEnabled = settings?.data?.aiLocalizations;
306
+ const { hasI18n } = useI18n();
307
+ // Poll for AI localizations jobs when AI is enabled and we have a documentId
308
+ const { status } = useAILocalizationJobsPolling({
309
+ documentId,
310
+ model,
311
+ collectionType
312
+ });
313
+ const statusVariant = (()=>{
314
+ if (status === 'failed') {
315
+ return 'warning';
316
+ }
317
+ if (isAISettingEnabled) {
318
+ return 'alternative';
319
+ }
320
+ return 'neutral';
321
+ })();
322
+ // Do not display this action when i18n is not available
323
+ if (!hasI18n) {
324
+ return null;
325
+ }
326
+ // Do not display this action when AI is not available
327
+ if (!isAIAvailable) {
328
+ return null;
329
+ }
330
+ return {
331
+ _status: {
332
+ message: /*#__PURE__*/ jsx(Box, {
333
+ height: "100%",
334
+ "aria-label": formatMessage({
335
+ id: getTranslation('CMEditViewAITranslation.status-aria-label'),
336
+ defaultMessage: 'AI Translation Status'
337
+ }),
338
+ children: /*#__PURE__*/ jsx(AITranslationStatusIcon, {
339
+ $isAISettingEnabled: Boolean(isAISettingEnabled),
340
+ variant: statusVariant,
341
+ size: "S",
342
+ children: /*#__PURE__*/ jsx(Sparkle, {})
343
+ })
344
+ }),
345
+ tooltip: /*#__PURE__*/ jsxs(Flex, {
346
+ direction: "column",
347
+ padding: 4,
348
+ alignItems: "flex-start",
349
+ width: "25rem",
350
+ children: [
351
+ /*#__PURE__*/ jsx(Typography, {
352
+ variant: "pi",
353
+ fontWeight: "600",
354
+ children: formatMessage({
355
+ id: getTranslation('CMEditViewAITranslation.status-title'),
356
+ defaultMessage: '{enabled, select, true {AI translation enabled} false {AI translation disabled} other {AI translation disabled}}'
357
+ }, {
358
+ enabled: isAISettingEnabled
359
+ })
360
+ }),
361
+ /*#__PURE__*/ jsx(Typography, {
362
+ variant: "pi",
363
+ paddingTop: 1,
364
+ paddingBottom: 3,
365
+ children: formatMessage({
366
+ id: getTranslation('CMEditViewAITranslation.status-description'),
367
+ defaultMessage: 'Our AI translates content in all locales each time you save a modification in the default locale.'
368
+ })
369
+ }),
370
+ /*#__PURE__*/ jsx(Link, {
371
+ fontSize: "inherit",
372
+ tag: NavLink,
373
+ to: "/settings/internationalization",
374
+ style: {
375
+ alignSelf: 'flex-end'
376
+ },
377
+ children: /*#__PURE__*/ jsx(Typography, {
378
+ variant: "pi",
379
+ textAlign: "right",
380
+ children: formatMessage({
381
+ id: getTranslation('CMEditViewAITranslation.settings-link'),
382
+ defaultMessage: '{enabled, select, true {Disable it in settings} false {Enable it in settings} other {Enable it in settings}}'
383
+ }, {
384
+ enabled: isAISettingEnabled
385
+ })
386
+ })
387
+ })
388
+ ]
389
+ })
390
+ }
391
+ };
392
+ };
393
+ /* -------------------------------------------------------------------------------------------------
394
+ * FillFromAnotherLocaleAction
395
+ * -----------------------------------------------------------------------------------------------*/ const FillFromAnotherLocaleAction = ({ documentId, meta, model, collectionType })=>{
396
+ const { formatMessage } = useIntl();
397
+ const [{ query }] = useQueryParams();
398
+ const { hasI18n } = useI18n();
399
+ const currentDesiredLocale = query.plugins?.i18n?.locale;
400
+ const [localeSelected, setLocaleSelected] = React.useState(null);
401
+ const setValues = useForm('FillFromAnotherLocale', (state)=>state.setValues);
402
+ const { getDocument } = unstable_useDocumentActions();
403
+ const { schema, components } = unstable_useDocument({
404
+ model,
405
+ documentId,
406
+ collectionType,
407
+ params: {
408
+ locale: currentDesiredLocale
409
+ }
410
+ });
411
+ const { data: locales = [] } = useGetLocalesQuery();
412
+ const isAIAvailable = useAIAvailability();
413
+ const { data: settings } = useGetSettingsQuery();
414
+ const isAISettingEnabled = settings?.data?.aiLocalizations;
415
+ const availableLocales = Array.isArray(locales) ? locales.filter((locale)=>meta?.availableLocales.some((l)=>l.locale === locale.code)) : [];
416
+ const fillFromLocale = (onClose)=>async ()=>{
417
+ const response = await getDocument({
418
+ collectionType,
419
+ model,
420
+ documentId,
421
+ params: {
422
+ locale: localeSelected
423
+ }
424
+ });
425
+ if (!response || !schema) {
426
+ return;
427
+ }
428
+ const { data } = response;
429
+ const cleanedData = cleanData(data, schema, components);
430
+ setValues(cleanedData);
431
+ onClose();
432
+ };
433
+ if (!hasI18n) {
434
+ return null;
435
+ }
436
+ // Do not display this action when AI is available and AI translations are enabled
437
+ if (isAIAvailable && isAISettingEnabled) {
438
+ return null;
439
+ }
440
+ return {
441
+ type: 'icon',
442
+ icon: /*#__PURE__*/ jsx(Earth, {}),
443
+ disabled: availableLocales.length === 0,
444
+ label: formatMessage({
445
+ id: getTranslation('CMEditViewCopyLocale.copy-text'),
446
+ defaultMessage: 'Fill in from another locale'
447
+ }),
448
+ dialog: {
449
+ type: 'dialog',
450
+ title: formatMessage({
451
+ id: getTranslation('CMEditViewCopyLocale.dialog.title'),
452
+ defaultMessage: 'Confirmation'
453
+ }),
454
+ content: ({ onClose })=>/*#__PURE__*/ jsxs(Fragment, {
455
+ children: [
456
+ /*#__PURE__*/ jsx(Dialog.Body, {
457
+ children: /*#__PURE__*/ jsxs(Flex, {
458
+ direction: "column",
459
+ gap: 3,
460
+ children: [
461
+ /*#__PURE__*/ jsx(WarningCircle, {
462
+ width: "24px",
463
+ height: "24px",
464
+ fill: "danger600"
465
+ }),
466
+ /*#__PURE__*/ jsx(Typography, {
467
+ textAlign: "center",
468
+ children: formatMessage({
469
+ id: getTranslation('CMEditViewCopyLocale.dialog.body'),
470
+ defaultMessage: 'Your current content will be erased and filled by the content of the selected locale:'
471
+ })
472
+ }),
473
+ /*#__PURE__*/ jsxs(Field.Root, {
474
+ width: "100%",
475
+ children: [
476
+ /*#__PURE__*/ jsx(Field.Label, {
477
+ children: formatMessage({
478
+ id: getTranslation('CMEditViewCopyLocale.dialog.field.label'),
479
+ defaultMessage: 'Locale'
480
+ })
481
+ }),
482
+ /*#__PURE__*/ jsx(SingleSelect, {
483
+ value: localeSelected,
484
+ placeholder: formatMessage({
485
+ id: getTranslation('CMEditViewCopyLocale.dialog.field.placeholder'),
486
+ defaultMessage: 'Select one locale...'
487
+ }),
488
+ // @ts-expect-error – the DS will handle numbers, but we're not allowing the API.
489
+ onChange: (value)=>setLocaleSelected(value),
490
+ children: availableLocales.map((locale)=>/*#__PURE__*/ jsx(SingleSelectOption, {
491
+ value: locale.code,
492
+ children: locale.name
493
+ }, locale.code))
494
+ })
495
+ ]
496
+ })
497
+ ]
498
+ })
499
+ }),
500
+ /*#__PURE__*/ jsx(Dialog.Footer, {
501
+ children: /*#__PURE__*/ jsxs(Flex, {
502
+ gap: 2,
503
+ width: "100%",
504
+ children: [
505
+ /*#__PURE__*/ jsx(Button, {
506
+ flex: "auto",
507
+ variant: "tertiary",
508
+ onClick: onClose,
509
+ children: formatMessage({
510
+ id: getTranslation('CMEditViewCopyLocale.cancel-text'),
511
+ defaultMessage: 'No, cancel'
512
+ })
513
+ }),
514
+ /*#__PURE__*/ jsx(Button, {
515
+ flex: "auto",
516
+ variant: "success",
517
+ onClick: fillFromLocale(onClose),
518
+ children: formatMessage({
519
+ id: getTranslation('CMEditViewCopyLocale.submit-text'),
520
+ defaultMessage: 'Yes, fill in'
521
+ })
522
+ })
523
+ ]
524
+ })
525
+ })
526
+ ]
527
+ })
528
+ }
529
+ };
530
+ };
531
+ /* -------------------------------------------------------------------------------------------------
532
+ * DeleteLocaleAction
533
+ * -----------------------------------------------------------------------------------------------*/ const DeleteLocaleAction = ({ document, documentId, model, collectionType })=>{
534
+ const { formatMessage } = useIntl();
535
+ const navigate = useNavigate();
536
+ const { toggleNotification } = useNotification();
537
+ const { delete: deleteAction, isLoading } = unstable_useDocumentActions();
538
+ const { hasI18n, canDelete } = useI18n();
539
+ // Get the current locale object, using the URL instead of document so it works while creating
540
+ const [{ query }] = useQueryParams();
541
+ const { data: locales = [] } = useGetLocalesQuery();
542
+ const currentDesiredLocale = query.plugins?.i18n?.locale;
543
+ const locale = !('error' in locales) && locales.find((loc)=>loc.code === currentDesiredLocale);
544
+ if (!hasI18n) {
545
+ return null;
546
+ }
547
+ return {
548
+ disabled: document?.locale && !canDelete.includes(document.locale) || !document || !document.id,
549
+ position: [
550
+ 'header',
551
+ 'table-row'
552
+ ],
553
+ label: formatMessage({
554
+ id: getTranslation('actions.delete.label'),
555
+ defaultMessage: 'Delete entry ({locale})'
556
+ }, {
557
+ locale: locale && locale.name
558
+ }),
559
+ icon: /*#__PURE__*/ jsx(StyledTrash, {}),
560
+ variant: 'danger',
561
+ dialog: {
562
+ type: 'dialog',
563
+ title: formatMessage({
564
+ id: getTranslation('actions.delete.dialog.title'),
565
+ defaultMessage: 'Confirmation'
566
+ }),
567
+ content: /*#__PURE__*/ jsxs(Flex, {
568
+ direction: "column",
569
+ gap: 2,
570
+ children: [
571
+ /*#__PURE__*/ jsx(WarningCircle, {
572
+ width: "24px",
573
+ height: "24px",
574
+ fill: "danger600"
575
+ }),
576
+ /*#__PURE__*/ jsx(Typography, {
577
+ tag: "p",
578
+ variant: "omega",
579
+ textAlign: "center",
580
+ children: formatMessage({
581
+ id: getTranslation('actions.delete.dialog.body'),
582
+ defaultMessage: 'Are you sure?'
583
+ })
584
+ })
585
+ ]
586
+ }),
587
+ loading: isLoading,
588
+ onConfirm: async ()=>{
589
+ const unableToDelete = // We are unable to delete a collection type without a document ID
590
+ // & unable to delete generally if there is no document locale
591
+ collectionType !== 'single-types' && !documentId || !document?.locale;
592
+ if (unableToDelete) {
593
+ console.error("You're trying to delete a document without an id or locale, this is likely a bug with Strapi. Please open an issue.");
594
+ toggleNotification({
595
+ message: formatMessage({
596
+ id: getTranslation('actions.delete.error'),
597
+ defaultMessage: 'An error occurred while trying to delete the document locale.'
598
+ }),
599
+ type: 'danger'
600
+ });
601
+ return;
602
+ }
603
+ const res = await deleteAction({
604
+ documentId,
605
+ model,
606
+ collectionType,
607
+ params: {
608
+ locale: document.locale
609
+ }
610
+ });
611
+ if (!('error' in res)) {
612
+ navigate({
613
+ pathname: `../${collectionType}/${model}`
614
+ }, {
615
+ replace: true
616
+ });
617
+ }
618
+ }
619
+ }
620
+ };
621
+ };
622
+ /* -------------------------------------------------------------------------------------------------
623
+ * BulkLocaleAction
624
+ *
625
+ * This component is used to handle bulk publish and unpublish actions on locales.
626
+ * -----------------------------------------------------------------------------------------------*/ const BulkLocaleAction = ({ document, documentId, model, collectionType, action })=>{
627
+ const locale = document?.locale ?? null;
628
+ const [{ query }] = useQueryParams();
629
+ const params = React.useMemo(()=>buildValidParams(query), [
630
+ query
631
+ ]);
632
+ const isOnPublishedTab = query.status === 'published';
633
+ const { formatMessage } = useIntl();
634
+ const { hasI18n, canPublish } = useI18n();
635
+ const { toggleNotification } = useNotification();
636
+ const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
637
+ const [selectedRows, setSelectedRows] = React.useState([]);
638
+ const [isDraftRelationConfirmationOpen, setIsDraftRelationConfirmationOpen] = React.useState(false);
639
+ const { publishMany: publishManyAction, unpublishMany: unpublishManyAction } = unstable_useDocumentActions();
640
+ const { schema, validate } = unstable_useDocument({
641
+ model,
642
+ collectionType,
643
+ documentId,
644
+ params: {
645
+ locale
646
+ }
647
+ }, {
648
+ // No need to fetch the document, the data is already available in the `document` prop
649
+ skip: true
650
+ });
651
+ const { data: localesMetadata = [] } = useGetLocalesQuery(hasI18n ? undefined : skipToken);
652
+ const headers = [
653
+ {
654
+ label: formatMessage({
655
+ id: 'global.name',
656
+ defaultMessage: 'Name'
657
+ }),
658
+ name: 'name'
659
+ },
660
+ {
661
+ label: formatMessage({
662
+ id: getTranslation('CMEditViewBulkLocale.status'),
663
+ defaultMessage: 'Status'
664
+ }),
665
+ name: 'status'
666
+ },
667
+ {
668
+ label: formatMessage({
669
+ id: getTranslation('CMEditViewBulkLocale.publication-status'),
670
+ defaultMessage: 'Publication Status'
671
+ }),
672
+ name: 'publication-status'
673
+ }
674
+ ];
675
+ // Extract the rows for the bulk locale publish modal and any validation
676
+ // errors per locale
677
+ const [rows, validationErrors] = React.useMemo(()=>{
678
+ if (!document) {
679
+ return [
680
+ [],
681
+ {}
682
+ ];
683
+ }
684
+ const localizations = document.localizations ?? [];
685
+ // Build the rows for the bulk locale publish modal by combining the current
686
+ // document with all the available locales from the document meta
687
+ const locales = localizations.map((doc)=>{
688
+ const { locale, status } = doc;
689
+ return {
690
+ locale,
691
+ status
692
+ };
693
+ });
694
+ // Add the current document locale
695
+ locales.unshift({
696
+ locale: document.locale,
697
+ status: document.status
698
+ });
699
+ // Build the validation errors for each locale.
700
+ const allDocuments = [
701
+ document,
702
+ ...localizations
703
+ ];
704
+ const errors = allDocuments.reduce((errs, document)=>{
705
+ if (!document) {
706
+ return errs;
707
+ }
708
+ // Validate each locale entry via the useDocument validate function and store any errors in a dictionary
709
+ const validation = validate(document);
710
+ if (validation !== null) {
711
+ errs[document.locale] = validation;
712
+ }
713
+ return errs;
714
+ }, {});
715
+ return [
716
+ locales,
717
+ errors
718
+ ];
719
+ }, [
720
+ document,
721
+ validate
722
+ ]);
723
+ const isBulkPublish = action === 'bulk-publish';
724
+ const localesForAction = selectedRows.reduce((acc, selectedRow)=>{
725
+ const isValidLocale = // Validation errors are irrelevant if we are trying to unpublish
726
+ !isBulkPublish || !Object.keys(validationErrors).includes(selectedRow.locale);
727
+ const shouldAddLocale = isBulkPublish ? selectedRow.status !== 'published' && isValidLocale : selectedRow.status !== 'draft' && isValidLocale;
728
+ if (shouldAddLocale) {
729
+ acc.push(selectedRow.locale);
730
+ }
731
+ return acc;
732
+ }, []);
733
+ // TODO skipping this for now as there is a bug with the draft relation count that will be worked on separately
734
+ // see https://www.notion.so/strapi/Count-draft-relations-56901b492efb45ab90d42fe975b32bd8?pvs=4
735
+ const enableDraftRelationsCount = false;
736
+ const { data: draftRelationsCount = 0, isLoading: isDraftRelationsLoading, error: isDraftRelationsError } = useGetManyDraftRelationCountQuery({
737
+ model,
738
+ documentIds: [
739
+ documentId
740
+ ],
741
+ locale: localesForAction
742
+ }, {
743
+ skip: !enableDraftRelationsCount
744
+ });
745
+ React.useEffect(()=>{
746
+ if (isDraftRelationsError) {
747
+ toggleNotification({
748
+ type: 'danger',
749
+ message: formatAPIError(isDraftRelationsError)
750
+ });
751
+ }
752
+ }, [
753
+ isDraftRelationsError,
754
+ toggleNotification,
755
+ formatAPIError
756
+ ]);
757
+ if (!schema?.options?.draftAndPublish) {
758
+ return null;
759
+ }
760
+ if (!hasI18n) {
761
+ return null;
762
+ }
763
+ if (!documentId) {
764
+ return null;
765
+ }
766
+ // This document action can be enabled given that draft and publish and i18n are
767
+ // enabled and we can publish the current locale.
768
+ const publish = async ()=>{
769
+ await publishManyAction({
770
+ model,
771
+ documentIds: [
772
+ documentId
773
+ ],
774
+ params: {
775
+ ...params,
776
+ locale: localesForAction
777
+ }
778
+ });
779
+ setSelectedRows([]);
780
+ };
781
+ const unpublish = async ()=>{
782
+ await unpublishManyAction({
783
+ model,
784
+ documentIds: [
785
+ documentId
786
+ ],
787
+ params: {
788
+ ...params,
789
+ locale: localesForAction
790
+ }
791
+ });
792
+ setSelectedRows([]);
793
+ };
794
+ const handleAction = async ()=>{
795
+ if (draftRelationsCount > 0) {
796
+ setIsDraftRelationConfirmationOpen(true);
797
+ } else if (isBulkPublish) {
798
+ await publish();
799
+ } else {
800
+ await unpublish();
801
+ }
802
+ };
803
+ if (isDraftRelationConfirmationOpen) {
804
+ return {
805
+ label: formatMessage({
806
+ id: 'app.components.ConfirmDialog.title',
807
+ defaultMessage: 'Confirmation'
808
+ }),
809
+ variant: 'danger',
810
+ dialog: {
811
+ onCancel: ()=>{
812
+ setIsDraftRelationConfirmationOpen(false);
813
+ },
814
+ onConfirm: async ()=>{
815
+ await publish();
816
+ setIsDraftRelationConfirmationOpen(false);
817
+ },
818
+ type: 'dialog',
819
+ title: formatMessage({
820
+ id: getTranslation('actions.publish.dialog.title'),
821
+ defaultMessage: 'Confirmation'
822
+ }),
823
+ content: /*#__PURE__*/ jsxs(Flex, {
824
+ direction: "column",
825
+ alignItems: "center",
826
+ gap: 2,
827
+ children: [
828
+ /*#__PURE__*/ jsx(WarningCircle, {
829
+ width: "2.4rem",
830
+ height: "2.4rem",
831
+ fill: "danger600"
832
+ }),
833
+ /*#__PURE__*/ jsx(Typography, {
834
+ textAlign: "center",
835
+ children: formatMessage({
836
+ id: getTranslation('CMEditViewBulkLocale.draft-relation-warning'),
837
+ defaultMessage: 'Some locales are related to draft entries. Publishing them could leave broken links in your app.'
838
+ })
839
+ }),
840
+ /*#__PURE__*/ jsx(Typography, {
841
+ textAlign: "center",
842
+ children: formatMessage({
843
+ id: getTranslation('CMEditViewBulkLocale.continue-confirmation'),
844
+ defaultMessage: 'Are you sure you want to continue?'
845
+ })
846
+ })
847
+ ]
848
+ })
849
+ }
850
+ };
851
+ }
852
+ const hasPermission = selectedRows.map(({ locale })=>locale).every((locale)=>canPublish.includes(locale));
853
+ return {
854
+ label: formatMessage({
855
+ id: getTranslation(`CMEditViewBulkLocale.${isBulkPublish ? 'publish' : 'unpublish'}-title`),
856
+ defaultMessage: `${isBulkPublish ? 'Publish' : 'Unpublish'} Multiple Locales`
857
+ }),
858
+ variant: isBulkPublish ? 'secondary' : 'danger',
859
+ icon: isBulkPublish ? /*#__PURE__*/ jsx(ListPlus, {}) : /*#__PURE__*/ jsx(Cross, {}),
860
+ disabled: isOnPublishedTab || canPublish.length === 0,
861
+ position: [
862
+ 'panel'
863
+ ],
864
+ dialog: {
865
+ type: 'modal',
866
+ title: formatMessage({
867
+ id: getTranslation(`CMEditViewBulkLocale.${isBulkPublish ? 'publish' : 'unpublish'}-title`),
868
+ defaultMessage: `${isBulkPublish ? 'Publish' : 'Unpublish'} Multiple Locales`
869
+ }),
870
+ content: ()=>{
871
+ return /*#__PURE__*/ jsx(Table.Root, {
872
+ headers: headers,
873
+ rows: rows.map((row)=>({
874
+ ...row,
875
+ id: row.locale
876
+ })),
877
+ selectedRows: selectedRows,
878
+ onSelectedRowsChange: (tableSelectedRows)=>setSelectedRows(tableSelectedRows),
879
+ children: /*#__PURE__*/ jsx(BulkLocaleActionModal, {
880
+ validationErrors: validationErrors,
881
+ headers: headers,
882
+ rows: rows,
883
+ localesMetadata: localesMetadata,
884
+ action: action ?? 'bulk-publish'
885
+ })
886
+ });
887
+ },
888
+ footer: ()=>/*#__PURE__*/ jsx(Modal.Footer, {
889
+ justifyContent: "flex-end",
890
+ children: /*#__PURE__*/ jsx(Button, {
891
+ loading: isDraftRelationsLoading,
892
+ disabled: !hasPermission || localesForAction.length === 0,
893
+ variant: "default",
894
+ onClick: handleAction,
895
+ children: formatMessage({
896
+ id: isBulkPublish ? 'app.utils.publish' : 'app.utils.unpublish',
897
+ defaultMessage: isBulkPublish ? 'Publish' : 'Unpublish'
898
+ })
899
+ })
900
+ })
901
+ }
902
+ };
903
+ };
904
+ /* -------------------------------------------------------------------------------------------------
905
+ * BulkLocalePublishAction
906
+ * -----------------------------------------------------------------------------------------------*/ const BulkLocalePublishAction = (props)=>{
907
+ return BulkLocaleAction({
908
+ action: 'bulk-publish',
909
+ ...props
910
+ });
911
+ };
912
+ /* -------------------------------------------------------------------------------------------------
913
+ * BulkLocaleUnpublishAction
914
+ * -----------------------------------------------------------------------------------------------*/ const BulkLocaleUnpublishAction = (props)=>{
915
+ return BulkLocaleAction({
916
+ action: 'bulk-unpublish',
917
+ ...props
918
+ });
919
+ };
920
+ /**
921
+ * Because the icon system is completely broken, we have to do
922
+ * this to remove the fill from the cog.
923
+ */ const StyledTrash = styled(Trash)`
924
+ path {
925
+ fill: currentColor;
926
+ }
927
+ `;
928
+
929
+ export { AITranslationStatusAction, BulkLocalePublishAction, BulkLocaleUnpublishAction, DeleteLocaleAction, FillFromAnotherLocaleAction, LocalePickerAction };
930
+ //# sourceMappingURL=CMHeaderActions.mjs.map