@strapi/i18n 0.0.0-experimental.d1602f22dc638a4c3c5084965fd6126fff5e9d4f → 0.0.0-experimental.d19a9dcb5829d725ba4d7c1e7b3ae9c816c26514

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