@strapi/i18n 0.0.0 → 5.0.0-beta.7

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 (163) hide show
  1. package/README.md +17 -1
  2. package/dist/_chunks/SettingsPage-BvzzUueI.js +584 -0
  3. package/dist/_chunks/SettingsPage-BvzzUueI.js.map +1 -0
  4. package/dist/_chunks/SettingsPage-CB5yd4O3.mjs +564 -0
  5. package/dist/_chunks/SettingsPage-CB5yd4O3.mjs.map +1 -0
  6. package/dist/_chunks/de-9eCAqqrB.mjs +66 -0
  7. package/dist/_chunks/de-9eCAqqrB.mjs.map +1 -0
  8. package/dist/_chunks/de-DtWiGdHl.js +66 -0
  9. package/dist/_chunks/de-DtWiGdHl.js.map +1 -0
  10. package/dist/_chunks/dk-2qBjxt-P.mjs +66 -0
  11. package/dist/_chunks/dk-2qBjxt-P.mjs.map +1 -0
  12. package/dist/_chunks/dk-D8C-casx.js +66 -0
  13. package/dist/_chunks/dk-D8C-casx.js.map +1 -0
  14. package/dist/_chunks/en-BuBc6LKZ.js +69 -0
  15. package/dist/_chunks/en-BuBc6LKZ.js.map +1 -0
  16. package/dist/_chunks/en-CnrTsjWS.mjs +69 -0
  17. package/dist/_chunks/en-CnrTsjWS.mjs.map +1 -0
  18. package/dist/_chunks/es-DS-XFGSw.js +66 -0
  19. package/dist/_chunks/es-DS-XFGSw.js.map +1 -0
  20. package/dist/_chunks/es-DlmMVaBG.mjs +66 -0
  21. package/dist/_chunks/es-DlmMVaBG.mjs.map +1 -0
  22. package/dist/_chunks/fr-3S6ke71d.mjs +66 -0
  23. package/dist/_chunks/fr-3S6ke71d.mjs.map +1 -0
  24. package/dist/_chunks/fr-BTjekDpq.js +66 -0
  25. package/dist/_chunks/fr-BTjekDpq.js.map +1 -0
  26. package/dist/_chunks/index-DRjoX_5r.js +1084 -0
  27. package/dist/_chunks/index-DRjoX_5r.js.map +1 -0
  28. package/dist/_chunks/index-aiqKWFfV.mjs +1061 -0
  29. package/dist/_chunks/index-aiqKWFfV.mjs.map +1 -0
  30. package/dist/_chunks/ko-DmcGUBQ3.js +65 -0
  31. package/dist/_chunks/ko-DmcGUBQ3.js.map +1 -0
  32. package/dist/_chunks/ko-qTjQ8IMw.mjs +65 -0
  33. package/dist/_chunks/ko-qTjQ8IMw.mjs.map +1 -0
  34. package/dist/_chunks/pl-B67TSHqT.mjs +66 -0
  35. package/dist/_chunks/pl-B67TSHqT.mjs.map +1 -0
  36. package/dist/_chunks/pl-Cn5RYonZ.js +66 -0
  37. package/dist/_chunks/pl-Cn5RYonZ.js.map +1 -0
  38. package/dist/_chunks/ru-BMBgVL3s.js +68 -0
  39. package/dist/_chunks/ru-BMBgVL3s.js.map +1 -0
  40. package/dist/_chunks/ru-hagMa57T.mjs +68 -0
  41. package/dist/_chunks/ru-hagMa57T.mjs.map +1 -0
  42. package/dist/_chunks/tr-CarUU76c.js +66 -0
  43. package/dist/_chunks/tr-CarUU76c.js.map +1 -0
  44. package/dist/_chunks/tr-Dw_jmkG-.mjs +66 -0
  45. package/dist/_chunks/tr-Dw_jmkG-.mjs.map +1 -0
  46. package/dist/_chunks/zh-57YM4amO.mjs +66 -0
  47. package/dist/_chunks/zh-57YM4amO.mjs.map +1 -0
  48. package/dist/_chunks/zh-CukOviB0.js +66 -0
  49. package/dist/_chunks/zh-CukOviB0.js.map +1 -0
  50. package/dist/_chunks/zh-Hans-DSHIXAa3.js +57 -0
  51. package/dist/_chunks/zh-Hans-DSHIXAa3.js.map +1 -0
  52. package/dist/_chunks/zh-Hans-Dyc-aR-h.mjs +57 -0
  53. package/dist/_chunks/zh-Hans-Dyc-aR-h.mjs.map +1 -0
  54. package/dist/admin/index.js +6 -0
  55. package/dist/admin/index.js.map +1 -0
  56. package/dist/admin/index.mjs +7 -0
  57. package/dist/admin/index.mjs.map +1 -0
  58. package/dist/admin/src/components/CMHeaderActions.d.ts +4 -0
  59. package/dist/admin/src/components/CMListViewModalsAdditionalInformation.d.ts +4 -0
  60. package/dist/admin/src/components/CheckboxConfirmation.d.ts +20 -0
  61. package/dist/admin/src/components/CreateLocale.d.ts +29 -0
  62. package/dist/admin/src/components/DeleteLocale.d.ts +5 -0
  63. package/dist/admin/src/components/EditLocale.d.ts +13 -0
  64. package/dist/admin/src/components/Initializer.d.ts +5 -0
  65. package/dist/admin/src/components/LocaleListCell.d.ts +9 -0
  66. package/dist/admin/src/components/LocalePicker.d.ts +2 -0
  67. package/dist/admin/src/components/LocaleTable.d.ts +11 -0
  68. package/dist/admin/src/constants.d.ts +22 -0
  69. package/dist/admin/src/contentManagerHooks/editView.d.ts +6 -0
  70. package/dist/admin/src/contentManagerHooks/listView.d.ts +22 -0
  71. package/dist/admin/src/contentReleasesHooks/releaseDetailsView.d.ts +36 -0
  72. package/dist/admin/src/hooks/useI18n.d.ts +16 -0
  73. package/dist/admin/src/index.d.ts +16 -0
  74. package/dist/admin/src/middlewares/extendCTBAttributeInitialData.d.ts +4 -0
  75. package/dist/admin/src/middlewares/extendCTBInitialData.d.ts +4 -0
  76. package/dist/admin/src/middlewares/rbac-middleware.d.ts +3 -0
  77. package/dist/admin/src/pages/SettingsPage.d.ts +3 -0
  78. package/dist/admin/src/pluginId.d.ts +1 -0
  79. package/dist/admin/src/services/api.d.ts +3 -0
  80. package/dist/admin/src/services/locales.d.ts +4 -0
  81. package/dist/admin/src/types.d.ts +9 -0
  82. package/dist/admin/src/utils/baseQuery.d.ts +19 -0
  83. package/dist/admin/src/utils/fields.d.ts +7 -0
  84. package/dist/admin/src/utils/getTranslation.d.ts +2 -0
  85. package/dist/admin/src/utils/prefixPluginTranslations.d.ts +3 -0
  86. package/dist/admin/src/utils/schemas.d.ts +24 -0
  87. package/dist/admin/src/utils/strings.d.ts +2 -0
  88. package/dist/server/index.js +3522 -0
  89. package/dist/server/index.js.map +1 -0
  90. package/dist/server/index.mjs +3503 -0
  91. package/dist/server/index.mjs.map +1 -0
  92. package/dist/server/src/bootstrap.d.ts +6 -0
  93. package/dist/server/src/bootstrap.d.ts.map +1 -0
  94. package/dist/server/src/constants/index.d.ts +15 -0
  95. package/dist/server/src/constants/index.d.ts.map +1 -0
  96. package/dist/server/src/content-types/index.d.ts +37 -0
  97. package/dist/server/src/content-types/index.d.ts.map +1 -0
  98. package/dist/server/src/content-types/locale/index.d.ts +35 -0
  99. package/dist/server/src/content-types/locale/index.d.ts.map +1 -0
  100. package/dist/server/src/controllers/content-types.d.ts +6 -0
  101. package/dist/server/src/controllers/content-types.d.ts.map +1 -0
  102. package/dist/server/src/controllers/index.d.ts +10 -0
  103. package/dist/server/src/controllers/index.d.ts.map +1 -0
  104. package/dist/server/src/controllers/iso-locales.d.ts +4 -0
  105. package/dist/server/src/controllers/iso-locales.d.ts.map +1 -0
  106. package/dist/server/src/controllers/locales.d.ts +4 -0
  107. package/dist/server/src/controllers/locales.d.ts.map +1 -0
  108. package/dist/server/src/controllers/validate-locale-creation.d.ts +4 -0
  109. package/dist/server/src/controllers/validate-locale-creation.d.ts.map +1 -0
  110. package/dist/server/src/domain/locale.d.ts +11 -0
  111. package/dist/server/src/domain/locale.d.ts.map +1 -0
  112. package/dist/server/src/graphql.d.ts +8 -0
  113. package/dist/server/src/graphql.d.ts.map +1 -0
  114. package/dist/server/src/index.d.ts +148 -0
  115. package/dist/server/src/index.d.ts.map +1 -0
  116. package/dist/server/src/migrations/content-type/disable/index.d.ts +3 -0
  117. package/dist/server/src/migrations/content-type/disable/index.d.ts.map +1 -0
  118. package/dist/server/src/migrations/content-type/enable/index.d.ts +3 -0
  119. package/dist/server/src/migrations/content-type/enable/index.d.ts.map +1 -0
  120. package/dist/server/src/register.d.ts +6 -0
  121. package/dist/server/src/register.d.ts.map +1 -0
  122. package/dist/server/src/routes/admin.d.ts +18 -0
  123. package/dist/server/src/routes/admin.d.ts.map +1 -0
  124. package/dist/server/src/routes/content-api.d.ts +10 -0
  125. package/dist/server/src/routes/content-api.d.ts.map +1 -0
  126. package/dist/server/src/routes/index.d.ts +28 -0
  127. package/dist/server/src/routes/index.d.ts.map +1 -0
  128. package/dist/server/src/services/content-types.d.ts +13 -0
  129. package/dist/server/src/services/content-types.d.ts.map +1 -0
  130. package/dist/server/src/services/entity-service-decorator.d.ts +29 -0
  131. package/dist/server/src/services/entity-service-decorator.d.ts.map +1 -0
  132. package/dist/server/src/services/index.d.ts +71 -0
  133. package/dist/server/src/services/index.d.ts.map +1 -0
  134. package/dist/server/src/services/iso-locales.d.ts +10 -0
  135. package/dist/server/src/services/iso-locales.d.ts.map +1 -0
  136. package/dist/server/src/services/locales.d.ts +17 -0
  137. package/dist/server/src/services/locales.d.ts.map +1 -0
  138. package/dist/server/src/services/localizations.d.ts +8 -0
  139. package/dist/server/src/services/localizations.d.ts.map +1 -0
  140. package/dist/server/src/services/metrics.d.ts +8 -0
  141. package/dist/server/src/services/metrics.d.ts.map +1 -0
  142. package/dist/server/src/services/permissions/actions.d.ts +16 -0
  143. package/dist/server/src/services/permissions/actions.d.ts.map +1 -0
  144. package/dist/server/src/services/permissions/conditions.d.ts +15 -0
  145. package/dist/server/src/services/permissions/conditions.d.ts.map +1 -0
  146. package/dist/server/src/services/permissions/engine.d.ts +6 -0
  147. package/dist/server/src/services/permissions/engine.d.ts.map +1 -0
  148. package/dist/server/src/services/permissions/sections-builder.d.ts +6 -0
  149. package/dist/server/src/services/permissions/sections-builder.d.ts.map +1 -0
  150. package/dist/server/src/services/permissions.d.ts +28 -0
  151. package/dist/server/src/services/permissions.d.ts.map +1 -0
  152. package/dist/server/src/utils/index.d.ts +43 -0
  153. package/dist/server/src/utils/index.d.ts.map +1 -0
  154. package/dist/server/src/validation/content-types.d.ts +3 -0
  155. package/dist/server/src/validation/content-types.d.ts.map +1 -0
  156. package/dist/server/src/validation/locales.d.ts +12 -0
  157. package/dist/server/src/validation/locales.d.ts.map +1 -0
  158. package/dist/shared/contracts/content-manager.d.ts +27 -0
  159. package/dist/shared/contracts/iso-locales.d.ts +21 -0
  160. package/dist/shared/contracts/locales.d.ts +77 -0
  161. package/dist/shared/contracts/shared.d.ts +6 -0
  162. package/package.json +82 -4
  163. package/strapi-server.js +3 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SettingsPage-BvzzUueI.js","sources":["../../admin/src/components/CreateLocale.tsx","../../admin/src/components/DeleteLocale.tsx","../../admin/src/components/EditLocale.tsx","../../admin/src/components/LocaleTable.tsx","../../admin/src/pages/SettingsPage.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport {\n Form,\n type InputProps,\n InputRenderer,\n useField,\n type FormHelpers,\n useForm,\n useAPIErrorHandler,\n useNotification,\n useAuth,\n} from '@strapi/admin/strapi-admin';\nimport {\n Box,\n Button,\n ButtonProps,\n Divider,\n Field,\n Flex,\n Grid,\n GridItem,\n ModalBody,\n ModalFooter,\n ModalHeader,\n ModalLayout,\n SingleSelect,\n SingleSelectOption,\n Tab,\n TabGroup,\n TabPanel,\n TabPanels,\n Tabs,\n Typography,\n} from '@strapi/design-system';\nimport { Check, Plus } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport * as yup from 'yup';\n\nimport { CreateLocale } from '../../../shared/contracts/locales';\nimport { useCreateLocaleMutation, useGetDefaultLocalesQuery } from '../services/locales';\nimport { isBaseQueryError } from '../utils/baseQuery';\nimport { getTranslation } from '../utils/getTranslation';\n\n/* -------------------------------------------------------------------------------------------------\n * CreateLocale\n * -----------------------------------------------------------------------------------------------*/\n\ninterface CreateLocaleProps extends Pick<ButtonProps, 'disabled' | 'variant'> {}\n\nconst CreateLocale = ({ disabled, variant = 'default' }: CreateLocaleProps) => {\n const { formatMessage } = useIntl();\n const [visible, setVisible] = React.useState(false);\n\n return (\n <>\n <Button\n variant={variant}\n disabled={disabled}\n startIcon={<Plus />}\n onClick={() => setVisible(true)}\n size=\"S\"\n >\n {formatMessage({\n id: getTranslation('Settings.list.actions.add'),\n defaultMessage: 'Add new locale',\n })}\n </Button>\n {visible ? <CreateModal onClose={() => setVisible(false)} /> : null}\n </>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * CreateModal\n * -----------------------------------------------------------------------------------------------*/\n\nconst LOCALE_SCHEMA = yup.object().shape({\n code: yup.string().required({\n id: 'Settings.locales.modal.create.code.error',\n defaultMessage: 'Please select a locale',\n }),\n name: yup\n .string()\n .max(50, {\n id: 'Settings.locales.modal.create.name.error.min',\n defaultMessage: 'The locale display name can only be less than 50 characters.',\n })\n .required({\n id: 'Settings.locales.modal.create.name.error.required',\n defaultMessage: 'Please give the locale a display name',\n }),\n isDefault: yup.boolean(),\n});\n\ntype FormValues = CreateLocale.Request['body'];\n\nconst initialFormValues = {\n code: '',\n name: '',\n isDefault: false,\n} satisfies FormValues;\n\ntype ModalCreateProps = {\n onClose: () => void;\n};\n\nconst CreateModal = ({ onClose }: ModalCreateProps) => {\n const { toggleNotification } = useNotification();\n const {\n _unstableFormatAPIError: formatAPIError,\n _unstableFormatValidationErrors: formatValidationErrors,\n } = useAPIErrorHandler();\n const [createLocale] = useCreateLocaleMutation();\n const { formatMessage } = useIntl();\n const refetchPermissions = useAuth('CreateModal', (state) => state.refetchPermissions);\n\n const handleSubmit = async (values: FormValues, helpers: FormHelpers<FormValues>) => {\n try {\n const res = await createLocale(values);\n\n if ('error' in res) {\n if (isBaseQueryError(res.error) && res.error.name === 'ValidationError') {\n helpers.setErrors(formatValidationErrors(res.error));\n } else {\n toggleNotification({ type: 'danger', message: formatAPIError(res.error) });\n }\n\n return;\n }\n\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTranslation('Settings.locales.modal.create.success'),\n defaultMessage: 'Created locale',\n }),\n });\n\n refetchPermissions();\n onClose();\n } catch (err) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: 'notification.error',\n defaultMessage: 'An error occurred, please try again',\n }),\n });\n }\n };\n\n const titleId = React.useId();\n\n return (\n <ModalLayout onClose={onClose} labelledBy={titleId}>\n <Form\n method=\"POST\"\n initialValues={initialFormValues}\n validationSchema={LOCALE_SCHEMA}\n onSubmit={handleSubmit}\n >\n <ModalHeader>\n <Typography fontWeight=\"bold\" textColor=\"neutral800\" tag=\"h2\" id={titleId}>\n {formatMessage({\n id: getTranslation('Settings.list.actions.add'),\n defaultMessage: 'Add new locale',\n })}\n </Typography>\n </ModalHeader>\n <ModalBody>\n <TabGroup\n label={formatMessage({\n id: getTranslation('Settings.locales.modal.title'),\n defaultMessage: 'Configurations',\n })}\n variant=\"simple\"\n >\n <Flex justifyContent=\"space-between\">\n <Typography tag=\"h2\" variant=\"beta\">\n {formatMessage({\n id: getTranslation('Settings.locales.modal.title'),\n defaultMessage: 'Configuration',\n })}\n </Typography>\n <Tabs>\n <Tab>\n {formatMessage({\n id: getTranslation('Settings.locales.modal.base'),\n defaultMessage: 'Basic settings',\n })}\n </Tab>\n <Tab>\n {formatMessage({\n id: getTranslation('Settings.locales.modal.advanced'),\n defaultMessage: 'Advanced settings',\n })}\n </Tab>\n </Tabs>\n </Flex>\n\n <Divider />\n\n <Box paddingTop={7} paddingBottom={7}>\n <TabPanels>\n <TabPanel>\n <BaseForm />\n </TabPanel>\n <TabPanel>\n <AdvancedForm />\n </TabPanel>\n </TabPanels>\n </Box>\n </TabGroup>\n </ModalBody>\n <ModalFooter\n startActions={\n <Button variant=\"tertiary\" onClick={onClose}>\n {formatMessage({ id: 'app.components.Button.cancel', defaultMessage: 'Cancel' })}\n </Button>\n }\n endActions={<SubmitButton />}\n />\n </Form>\n </ModalLayout>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * SubmitButton\n * -----------------------------------------------------------------------------------------------*/\n\nconst SubmitButton = () => {\n const { formatMessage } = useIntl();\n const isSubmitting = useForm('SubmitButton', (state) => state.isSubmitting);\n const modified = useForm('SubmitButton', (state) => state.modified);\n\n return (\n <Button type=\"submit\" startIcon={<Check />} disabled={isSubmitting || !modified}>\n {formatMessage({ id: 'global.save', defaultMessage: 'Save' })}\n </Button>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * BaseForm\n * -----------------------------------------------------------------------------------------------*/\n\ninterface BaseFormProps {\n mode?: 'create' | 'edit';\n}\n\nconst BaseForm = ({ mode = 'create' }: BaseFormProps) => {\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();\n\n const { data: defaultLocales, error } = useGetDefaultLocalesQuery();\n\n React.useEffect(() => {\n if (error) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(error),\n });\n }\n }, [error, formatAPIError, toggleNotification]);\n\n if (!Array.isArray(defaultLocales)) {\n return null;\n }\n\n const options = defaultLocales.map((locale) => ({\n label: locale.name,\n value: locale.code,\n }));\n\n const translatedForm = [\n {\n disabled: mode !== 'create',\n label: {\n id: getTranslation('Settings.locales.modal.create.code.label'),\n defaultMessage: 'Locales',\n },\n name: 'code',\n options,\n placeholder: {\n id: 'components.placeholder.select',\n defaultMessage: 'Select',\n },\n required: true,\n size: 6,\n type: 'enumeration' as const,\n },\n {\n hint: {\n id: getTranslation('Settings.locales.modal.create.name.label.description'),\n defaultMessage: 'Locale will be displayed under that name in the administration panel',\n },\n label: {\n id: getTranslation('Settings.locales.modal.create.name.label'),\n defaultMessage: 'Locale display name',\n },\n name: 'name',\n required: true,\n size: 6,\n type: 'string' as const,\n },\n ].map((field) => ({\n ...field,\n hint: field.hint ? formatMessage(field.hint) : undefined,\n label: formatMessage(field.label),\n placeholder: field.placeholder ? formatMessage(field.placeholder) : undefined,\n }));\n\n return (\n <Grid gap={4}>\n {translatedForm.map(({ size, ...field }) => (\n <GridItem key={field.name} col={size}>\n <FormRenderer {...field} />\n </GridItem>\n ))}\n </Grid>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * AdvancedForm\n * -----------------------------------------------------------------------------------------------*/\n\ntype AdvancedFormProps = {\n isDefaultLocale?: boolean;\n};\n\nconst AdvancedForm = ({ isDefaultLocale }: AdvancedFormProps) => {\n const { formatMessage } = useIntl();\n\n const form = [\n {\n disabled: isDefaultLocale,\n hint: {\n id: getTranslation('Settings.locales.modal.advanced.setAsDefault.hint'),\n defaultMessage: 'One default locale is required, change it by selecting another one',\n },\n label: {\n id: getTranslation('Settings.locales.modal.advanced.setAsDefault'),\n defaultMessage: 'Set as default locale',\n },\n name: 'isDefault',\n size: 6,\n type: 'boolean' as const,\n },\n ].map((field) => ({\n ...field,\n hint: field.hint ? formatMessage(field.hint) : undefined,\n label: formatMessage(field.label),\n })) satisfies InputProps[];\n\n return (\n <Grid gap={4}>\n {form.map(({ size, ...field }) => (\n <GridItem key={field.name} col={size}>\n <FormRenderer {...field} />\n </GridItem>\n ))}\n </Grid>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * FormRenderer\n * -----------------------------------------------------------------------------------------------*/\n\nconst FormRenderer = (field: InputProps) => {\n switch (field.type) {\n /**\n * This will override the default input renderer\n * choice for `enumeration`.\n */\n case 'enumeration':\n return <EnumerationInput {...field} />;\n default:\n return <InputRenderer {...field} />;\n }\n};\n\nconst EnumerationInput = ({\n disabled,\n hint,\n label,\n name,\n options,\n placeholder,\n required,\n}: Extract<InputProps, { type: 'enumeration' }>) => {\n const { value, error, onChange } = useField(name);\n const { data: defaultLocales = [] } = useGetDefaultLocalesQuery();\n\n const handleChange = (value: string) => {\n if (Array.isArray(defaultLocales)) {\n // We know it exists because the options are created from the list of default locales\n const locale = defaultLocales.find((locale) => locale.code === value)!;\n\n onChange(name, value);\n // This lets us automatically fill the name field with the locale name\n onChange('name', locale.name);\n } else {\n onChange(name, value);\n }\n };\n\n return (\n <Field.Root error={error} hint={hint} name={name} required={required}>\n <Field.Label>{label}</Field.Label>\n <SingleSelect\n disabled={disabled}\n // @ts-expect-error – This will dissapear when the DS removes support for numbers to be returned by SingleSelect.\n onChange={handleChange}\n placeholder={placeholder}\n value={value}\n >\n {options.map((option) => (\n <SingleSelectOption value={option.value} key={option.value}>\n {option.label}\n </SingleSelectOption>\n ))}\n </SingleSelect>\n <Field.Error />\n <Field.Hint />\n </Field.Root>\n );\n};\n\nexport { CreateLocale, BaseForm, AdvancedForm, SubmitButton, LOCALE_SCHEMA };\n","import * as React from 'react';\n\nimport { ConfirmDialog, useAPIErrorHandler, useNotification } from '@strapi/admin/strapi-admin';\nimport { IconButton } from '@strapi/design-system';\nimport { Trash } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\n\nimport { useDeleteLocaleMutation } from '../services/locales';\nimport { getTranslation } from '../utils/getTranslation';\n\nimport type { Locale } from '../../../shared/contracts/locales';\n\n/* -------------------------------------------------------------------------------------------------\n * DeleteLocale\n * -----------------------------------------------------------------------------------------------*/\n\ninterface DeleteLocaleProps extends Locale {}\n\nconst DeleteLocale = ({ id, name }: DeleteLocaleProps) => {\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();\n\n const [visible, setVisible] = React.useState(false);\n\n const [deleteLocale] = useDeleteLocaleMutation();\n const handleConfirm = async () => {\n try {\n const res = await deleteLocale(id);\n\n if ('error' in res) {\n toggleNotification({ type: 'danger', message: formatAPIError(res.error) });\n\n return;\n }\n\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTranslation('Settings.locales.modal.delete.success'),\n defaultMessage: 'Deleted locale',\n }),\n });\n } catch (err) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: 'notification.error',\n defaultMessage: 'An error occurred, please try again',\n }),\n });\n }\n };\n\n return (\n <>\n <IconButton\n onClick={() => setVisible(true)}\n label={formatMessage(\n {\n id: getTranslation('Settings.list.actions.delete'),\n defaultMessage: 'Delete {name} locale',\n },\n {\n name,\n }\n )}\n icon={<Trash />}\n borderWidth={0}\n />\n <ConfirmDialog onConfirm={handleConfirm} onClose={() => setVisible(false)} isOpen={visible} />\n </>\n );\n};\n\nexport { DeleteLocale };\n","import * as React from 'react';\n\nimport {\n useNotification,\n useAPIErrorHandler,\n Form,\n FormHelpers,\n useAuth,\n} from '@strapi/admin/strapi-admin';\nimport {\n Box,\n Button,\n Divider,\n Flex,\n IconButton,\n ModalBody,\n ModalFooter,\n ModalHeader,\n ModalLayout,\n ModalLayoutProps,\n Tab,\n TabGroup,\n TabPanel,\n TabPanels,\n Tabs,\n Typography,\n} from '@strapi/design-system';\nimport { Pencil } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\n\nimport { Locale, UpdateLocale } from '../../../shared/contracts/locales';\nimport { useUpdateLocaleMutation } from '../services/locales';\nimport { isBaseQueryError } from '../utils/baseQuery';\nimport { getTranslation } from '../utils/getTranslation';\n\nimport { AdvancedForm, BaseForm, LOCALE_SCHEMA, SubmitButton } from './CreateLocale';\n\n/* -------------------------------------------------------------------------------------------------\n * EditLocale\n * -----------------------------------------------------------------------------------------------*/\n\ninterface EditLocaleProps extends Omit<EditModalProps, 'onClose'> {}\n\nconst EditLocale = (props: EditLocaleProps) => {\n const { formatMessage } = useIntl();\n const [visible, setVisible] = React.useState(false);\n\n return (\n <>\n <IconButton\n onClick={() => setVisible(true)}\n label={formatMessage(\n {\n id: getTranslation('Settings.list.actions.edit'),\n defaultMessage: 'Edit {name} locale',\n },\n {\n name: props.name,\n }\n )}\n icon={<Pencil />}\n borderWidth={0}\n />\n {visible ? <EditModal {...props} onClose={() => setVisible(false)} /> : null}\n </>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * EditModal\n * -----------------------------------------------------------------------------------------------*/\n\ninterface EditModalProps\n extends Pick<ModalLayoutProps, 'onClose'>,\n Pick<Locale, 'id' | 'isDefault' | 'name' | 'code'> {}\n\ntype FormValues = UpdateLocale.Request['body'] & { code: string };\n\n/**\n * @internal\n * @description Exported to be used when someone clicks on a table row.\n */\nconst EditModal = ({ id, code, isDefault, name, onClose }: EditModalProps) => {\n const { toggleNotification } = useNotification();\n const {\n _unstableFormatAPIError: formatAPIError,\n _unstableFormatValidationErrors: formatValidationErrors,\n } = useAPIErrorHandler();\n const refetchPermissions = useAuth('EditModal', (state) => state.refetchPermissions);\n const { formatMessage } = useIntl();\n const titleId = React.useId();\n\n const [updateLocale] = useUpdateLocaleMutation();\n const handleSubmit = async (\n { code: _code, ...data }: FormValues,\n helpers: FormHelpers<FormValues>\n ) => {\n try {\n /**\n * We don't need to send the code, because the\n * code can never be changed.\n */\n const res = await updateLocale({\n id,\n ...data,\n });\n\n if ('error' in res) {\n if (isBaseQueryError(res.error) && res.error.name === 'ValidationError') {\n helpers.setErrors(formatValidationErrors(res.error));\n } else {\n toggleNotification({ type: 'danger', message: formatAPIError(res.error) });\n }\n\n return;\n }\n\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTranslation('Settings.locales.modal.edit.success'),\n defaultMessage: 'Updated locale',\n }),\n });\n\n refetchPermissions();\n onClose();\n } catch (err) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: 'notification.error',\n defaultMessage: 'An error occurred, please try again',\n }),\n });\n }\n };\n\n return (\n <ModalLayout onClose={onClose} labelledBy={titleId}>\n <Form\n method=\"PUT\"\n onSubmit={handleSubmit}\n initialValues={{\n code,\n name,\n isDefault,\n }}\n validationSchema={LOCALE_SCHEMA}\n >\n <ModalHeader>\n <Typography fontWeight=\"bold\" textColor=\"neutral800\" tag=\"h2\" id={titleId}>\n {formatMessage({\n id: getTranslation('Settings.list.actions.edit'),\n defaultMessage: 'Edit a locale',\n })}\n </Typography>\n </ModalHeader>\n <ModalBody>\n <TabGroup\n label={formatMessage({\n id: getTranslation('Settings.locales.modal.title'),\n defaultMessage: 'Configurations',\n })}\n variant=\"simple\"\n >\n <Flex justifyContent=\"space-between\">\n <Typography tag=\"h2\" variant=\"beta\">\n {formatMessage({\n id: getTranslation('Settings.locales.modal.title'),\n defaultMessage: 'Configuration',\n })}\n </Typography>\n <Tabs>\n <Tab>\n {formatMessage({\n id: getTranslation('Settings.locales.modal.base'),\n defaultMessage: 'Basic settings',\n })}\n </Tab>\n <Tab>\n {formatMessage({\n id: getTranslation('Settings.locales.modal.advanced'),\n defaultMessage: 'Advanced settings',\n })}\n </Tab>\n </Tabs>\n </Flex>\n\n <Divider />\n\n <Box paddingTop={7} paddingBottom={7}>\n <TabPanels>\n <TabPanel>\n <BaseForm mode=\"edit\" />\n </TabPanel>\n <TabPanel>\n <AdvancedForm isDefaultLocale={isDefault} />\n </TabPanel>\n </TabPanels>\n </Box>\n </TabGroup>\n </ModalBody>\n <ModalFooter\n startActions={\n <Button variant=\"tertiary\" onClick={onClose}>\n {formatMessage({ id: 'app.components.Button.cancel', defaultMessage: 'Cancel' })}\n </Button>\n }\n endActions={<SubmitButton />}\n />\n </Form>\n </ModalLayout>\n );\n};\n\nexport { EditLocale, EditModal };\n","import * as React from 'react';\n\nimport {\n Flex,\n Table,\n Tbody,\n Td,\n Th,\n Thead,\n Tr,\n Typography,\n VisuallyHidden,\n} from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\n\nimport { getTranslation } from '../utils/getTranslation';\n\nimport { DeleteLocale } from './DeleteLocale';\nimport { EditLocale, EditModal } from './EditLocale';\n\nimport type { Locale } from '../../../shared/contracts/locales';\n\n/* -------------------------------------------------------------------------------------------------\n * LocaleTable\n * -----------------------------------------------------------------------------------------------*/\n\ntype LocaleTableProps = {\n locales?: Locale[];\n canDelete?: boolean;\n canUpdate?: boolean;\n onDeleteLocale?: (locale: Locale) => void;\n onEditLocale?: (locale: Locale) => void;\n};\n\nconst LocaleTable = ({ locales = [], canDelete, canUpdate }: LocaleTableProps) => {\n const [editLocaleId, setEditLocaleId] = React.useState<Locale['id']>();\n const { formatMessage } = useIntl();\n\n const handleClick = (localeId: Locale['id']) => () => {\n if (canUpdate) {\n setEditLocaleId(localeId);\n }\n };\n\n return (\n <Table colCount={4} rowCount={locales.length + 1}>\n <Thead>\n <Tr>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTranslation('Settings.locales.row.id'),\n defaultMessage: 'ID',\n })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTranslation('Settings.locales.row.displayName'),\n defaultMessage: 'Display name',\n })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTranslation('Settings.locales.row.default-locale'),\n defaultMessage: 'Default locale',\n })}\n </Typography>\n </Th>\n <Th>\n <VisuallyHidden>Actions</VisuallyHidden>\n </Th>\n </Tr>\n </Thead>\n <Tbody>\n {locales.map((locale) => (\n <React.Fragment key={locale.id}>\n <Tr\n onClick={handleClick(locale.id)}\n style={{ cursor: canUpdate ? 'pointer' : 'default' }}\n >\n <Td>\n <Typography textColor=\"neutral800\">{locale.id}</Typography>\n </Td>\n <Td>\n <Typography textColor=\"neutral800\">{locale.name}</Typography>\n </Td>\n <Td>\n <Typography textColor=\"neutral800\">\n {locale.isDefault\n ? formatMessage({\n id: getTranslation('Settings.locales.default'),\n defaultMessage: 'Default',\n })\n : null}\n </Typography>\n </Td>\n <Td>\n <Flex gap={1} justifyContent=\"flex-end\" onClick={(e) => e.stopPropagation()}>\n {canUpdate && <EditLocale {...locale} />}\n {canDelete && !locale.isDefault && <DeleteLocale {...locale} />}\n </Flex>\n </Td>\n </Tr>\n {editLocaleId === locale.id ? (\n <EditModal {...locale} onClose={() => setEditLocaleId(undefined)} />\n ) : null}\n </React.Fragment>\n ))}\n </Tbody>\n </Table>\n );\n};\n\nexport { LocaleTable };\nexport type { LocaleTableProps };\n","import * as React from 'react';\n\nimport {\n Page,\n useAPIErrorHandler,\n useNotification,\n useRBAC,\n Layouts,\n} from '@strapi/admin/strapi-admin';\nimport { EmptyStateLayout } from '@strapi/design-system';\nimport { EmptyDocuments } from '@strapi/icons/symbols';\nimport { useIntl } from 'react-intl';\n\nimport { CreateLocale } from '../components/CreateLocale';\nimport { LocaleTable } from '../components/LocaleTable';\nimport { PERMISSIONS } from '../constants';\nimport { useGetLocalesQuery } from '../services/locales';\nimport { getTranslation } from '../utils/getTranslation';\n\nconst SettingsPage = () => {\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();\n const { data: locales, isLoading: isLoadingLocales, error } = useGetLocalesQuery();\n const {\n isLoading: isLoadingRBAC,\n allowedActions: { canUpdate, canCreate, canDelete },\n } = useRBAC(PERMISSIONS);\n\n React.useEffect(() => {\n if (error) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(error),\n });\n }\n }, [error, formatAPIError, toggleNotification]);\n\n const isLoading = isLoadingLocales || isLoadingRBAC;\n\n if (isLoading) {\n return <Page.Loading />;\n }\n\n if (error || !Array.isArray(locales)) {\n return <Page.Error />;\n }\n\n return (\n <Page.Main tabIndex={-1}>\n <Layouts.Header\n primaryAction={<CreateLocale disabled={!canCreate} />}\n title={formatMessage({\n id: getTranslation('plugin.name'),\n defaultMessage: 'Internationalization',\n })}\n subtitle={formatMessage({\n id: getTranslation('Settings.list.description'),\n defaultMessage: 'Configure the settings',\n })}\n />\n <Layouts.Content>\n {locales.length > 0 ? (\n <LocaleTable locales={locales} canDelete={canDelete} canUpdate={canUpdate} />\n ) : (\n <EmptyStateLayout\n icon={<EmptyDocuments width={undefined} height={undefined} />}\n content={formatMessage({\n id: getTranslation('Settings.list.empty.title'),\n defaultMessage: 'There are no locales',\n })}\n action={<CreateLocale disabled={!canCreate} variant=\"secondary\" />}\n />\n )}\n </Layouts.Content>\n </Page.Main>\n );\n};\n\nconst ProtectedSettingsPage = () => {\n return (\n <Page.Protect permissions={PERMISSIONS.read}>\n <SettingsPage />\n </Page.Protect>\n );\n};\n\nexport { ProtectedSettingsPage, SettingsPage };\n"],"names":["useIntl","React","jsxs","Fragment","jsx","Button","Plus","getTranslation","yup","useNotification","useAPIErrorHandler","useCreateLocaleMutation","useAuth","isBaseQueryError","ModalLayout","Form","ModalHeader","Typography","ModalBody","TabGroup","Flex","Tabs","Tab","Divider","Box","TabPanels","TabPanel","ModalFooter","useForm","Check","useGetDefaultLocalesQuery","Grid","GridItem","InputRenderer","useField","value","locale","Field","SingleSelect","SingleSelectOption","useDeleteLocaleMutation","IconButton","Trash","ConfirmDialog","Pencil","useUpdateLocaleMutation","Table","Thead","Tr","Th","VisuallyHidden","Tbody","Td","useGetLocalesQuery","useRBAC","PERMISSIONS","Page","Layouts","EmptyStateLayout","EmptyDocuments"],"mappings":"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"}
@@ -0,0 +1,564 @@
1
+ import { jsxs, Fragment, jsx } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import { useNotification, useAPIErrorHandler, useAuth, Form, useForm, InputRenderer, useField, ConfirmDialog, useRBAC, Page, Layouts } from "@strapi/admin/strapi-admin";
4
+ import { Button, ModalLayout, ModalHeader, Typography, ModalBody, TabGroup, Flex, Tabs, Tab, Divider, Box, TabPanels, TabPanel, ModalFooter, Grid, GridItem, Field, SingleSelect, SingleSelectOption, IconButton, Table, Thead, Tr, Th, VisuallyHidden, Tbody, Td, EmptyStateLayout } from "@strapi/design-system";
5
+ import { EmptyDocuments } from "@strapi/icons/symbols";
6
+ import { useIntl } from "react-intl";
7
+ import { Plus, Check, Trash, Pencil } from "@strapi/icons";
8
+ import * as yup from "yup";
9
+ import { g as getTranslation, u as useCreateLocaleMutation, a as useGetDefaultLocalesQuery, i as isBaseQueryError, b as useDeleteLocaleMutation, c as useUpdateLocaleMutation, d as useGetLocalesQuery, P as PERMISSIONS } from "./index-aiqKWFfV.mjs";
10
+ const CreateLocale = ({ disabled, variant = "default" }) => {
11
+ const { formatMessage } = useIntl();
12
+ const [visible, setVisible] = React.useState(false);
13
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
14
+ /* @__PURE__ */ jsx(
15
+ Button,
16
+ {
17
+ variant,
18
+ disabled,
19
+ startIcon: /* @__PURE__ */ jsx(Plus, {}),
20
+ onClick: () => setVisible(true),
21
+ size: "S",
22
+ children: formatMessage({
23
+ id: getTranslation("Settings.list.actions.add"),
24
+ defaultMessage: "Add new locale"
25
+ })
26
+ }
27
+ ),
28
+ visible ? /* @__PURE__ */ jsx(CreateModal, { onClose: () => setVisible(false) }) : null
29
+ ] });
30
+ };
31
+ const LOCALE_SCHEMA = yup.object().shape({
32
+ code: yup.string().required({
33
+ id: "Settings.locales.modal.create.code.error",
34
+ defaultMessage: "Please select a locale"
35
+ }),
36
+ name: yup.string().max(50, {
37
+ id: "Settings.locales.modal.create.name.error.min",
38
+ defaultMessage: "The locale display name can only be less than 50 characters."
39
+ }).required({
40
+ id: "Settings.locales.modal.create.name.error.required",
41
+ defaultMessage: "Please give the locale a display name"
42
+ }),
43
+ isDefault: yup.boolean()
44
+ });
45
+ const initialFormValues = {
46
+ code: "",
47
+ name: "",
48
+ isDefault: false
49
+ };
50
+ const CreateModal = ({ onClose }) => {
51
+ const { toggleNotification } = useNotification();
52
+ const {
53
+ _unstableFormatAPIError: formatAPIError,
54
+ _unstableFormatValidationErrors: formatValidationErrors
55
+ } = useAPIErrorHandler();
56
+ const [createLocale] = useCreateLocaleMutation();
57
+ const { formatMessage } = useIntl();
58
+ const refetchPermissions = useAuth("CreateModal", (state) => state.refetchPermissions);
59
+ const handleSubmit = async (values, helpers) => {
60
+ try {
61
+ const res = await createLocale(values);
62
+ if ("error" in res) {
63
+ if (isBaseQueryError(res.error) && res.error.name === "ValidationError") {
64
+ helpers.setErrors(formatValidationErrors(res.error));
65
+ } else {
66
+ toggleNotification({ type: "danger", message: formatAPIError(res.error) });
67
+ }
68
+ return;
69
+ }
70
+ toggleNotification({
71
+ type: "success",
72
+ message: formatMessage({
73
+ id: getTranslation("Settings.locales.modal.create.success"),
74
+ defaultMessage: "Created locale"
75
+ })
76
+ });
77
+ refetchPermissions();
78
+ onClose();
79
+ } catch (err) {
80
+ toggleNotification({
81
+ type: "danger",
82
+ message: formatMessage({
83
+ id: "notification.error",
84
+ defaultMessage: "An error occurred, please try again"
85
+ })
86
+ });
87
+ }
88
+ };
89
+ const titleId = React.useId();
90
+ return /* @__PURE__ */ jsx(ModalLayout, { onClose, labelledBy: titleId, children: /* @__PURE__ */ jsxs(
91
+ Form,
92
+ {
93
+ method: "POST",
94
+ initialValues: initialFormValues,
95
+ validationSchema: LOCALE_SCHEMA,
96
+ onSubmit: handleSubmit,
97
+ children: [
98
+ /* @__PURE__ */ jsx(ModalHeader, { children: /* @__PURE__ */ jsx(Typography, { fontWeight: "bold", textColor: "neutral800", tag: "h2", id: titleId, children: formatMessage({
99
+ id: getTranslation("Settings.list.actions.add"),
100
+ defaultMessage: "Add new locale"
101
+ }) }) }),
102
+ /* @__PURE__ */ jsx(ModalBody, { children: /* @__PURE__ */ jsxs(
103
+ TabGroup,
104
+ {
105
+ label: formatMessage({
106
+ id: getTranslation("Settings.locales.modal.title"),
107
+ defaultMessage: "Configurations"
108
+ }),
109
+ variant: "simple",
110
+ children: [
111
+ /* @__PURE__ */ jsxs(Flex, { justifyContent: "space-between", children: [
112
+ /* @__PURE__ */ jsx(Typography, { tag: "h2", variant: "beta", children: formatMessage({
113
+ id: getTranslation("Settings.locales.modal.title"),
114
+ defaultMessage: "Configuration"
115
+ }) }),
116
+ /* @__PURE__ */ jsxs(Tabs, { children: [
117
+ /* @__PURE__ */ jsx(Tab, { children: formatMessage({
118
+ id: getTranslation("Settings.locales.modal.base"),
119
+ defaultMessage: "Basic settings"
120
+ }) }),
121
+ /* @__PURE__ */ jsx(Tab, { children: formatMessage({
122
+ id: getTranslation("Settings.locales.modal.advanced"),
123
+ defaultMessage: "Advanced settings"
124
+ }) })
125
+ ] })
126
+ ] }),
127
+ /* @__PURE__ */ jsx(Divider, {}),
128
+ /* @__PURE__ */ jsx(Box, { paddingTop: 7, paddingBottom: 7, children: /* @__PURE__ */ jsxs(TabPanels, { children: [
129
+ /* @__PURE__ */ jsx(TabPanel, { children: /* @__PURE__ */ jsx(BaseForm, {}) }),
130
+ /* @__PURE__ */ jsx(TabPanel, { children: /* @__PURE__ */ jsx(AdvancedForm, {}) })
131
+ ] }) })
132
+ ]
133
+ }
134
+ ) }),
135
+ /* @__PURE__ */ jsx(
136
+ ModalFooter,
137
+ {
138
+ startActions: /* @__PURE__ */ jsx(Button, { variant: "tertiary", onClick: onClose, children: formatMessage({ id: "app.components.Button.cancel", defaultMessage: "Cancel" }) }),
139
+ endActions: /* @__PURE__ */ jsx(SubmitButton, {})
140
+ }
141
+ )
142
+ ]
143
+ }
144
+ ) });
145
+ };
146
+ const SubmitButton = () => {
147
+ const { formatMessage } = useIntl();
148
+ const isSubmitting = useForm("SubmitButton", (state) => state.isSubmitting);
149
+ const modified = useForm("SubmitButton", (state) => state.modified);
150
+ return /* @__PURE__ */ jsx(Button, { type: "submit", startIcon: /* @__PURE__ */ jsx(Check, {}), disabled: isSubmitting || !modified, children: formatMessage({ id: "global.save", defaultMessage: "Save" }) });
151
+ };
152
+ const BaseForm = ({ mode = "create" }) => {
153
+ const { formatMessage } = useIntl();
154
+ const { toggleNotification } = useNotification();
155
+ const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
156
+ const { data: defaultLocales, error } = useGetDefaultLocalesQuery();
157
+ React.useEffect(() => {
158
+ if (error) {
159
+ toggleNotification({
160
+ type: "danger",
161
+ message: formatAPIError(error)
162
+ });
163
+ }
164
+ }, [error, formatAPIError, toggleNotification]);
165
+ if (!Array.isArray(defaultLocales)) {
166
+ return null;
167
+ }
168
+ const options = defaultLocales.map((locale) => ({
169
+ label: locale.name,
170
+ value: locale.code
171
+ }));
172
+ const translatedForm = [
173
+ {
174
+ disabled: mode !== "create",
175
+ label: {
176
+ id: getTranslation("Settings.locales.modal.create.code.label"),
177
+ defaultMessage: "Locales"
178
+ },
179
+ name: "code",
180
+ options,
181
+ placeholder: {
182
+ id: "components.placeholder.select",
183
+ defaultMessage: "Select"
184
+ },
185
+ required: true,
186
+ size: 6,
187
+ type: "enumeration"
188
+ },
189
+ {
190
+ hint: {
191
+ id: getTranslation("Settings.locales.modal.create.name.label.description"),
192
+ defaultMessage: "Locale will be displayed under that name in the administration panel"
193
+ },
194
+ label: {
195
+ id: getTranslation("Settings.locales.modal.create.name.label"),
196
+ defaultMessage: "Locale display name"
197
+ },
198
+ name: "name",
199
+ required: true,
200
+ size: 6,
201
+ type: "string"
202
+ }
203
+ ].map((field) => ({
204
+ ...field,
205
+ hint: field.hint ? formatMessage(field.hint) : void 0,
206
+ label: formatMessage(field.label),
207
+ placeholder: field.placeholder ? formatMessage(field.placeholder) : void 0
208
+ }));
209
+ return /* @__PURE__ */ jsx(Grid, { gap: 4, children: translatedForm.map(({ size, ...field }) => /* @__PURE__ */ jsx(GridItem, { col: size, children: /* @__PURE__ */ jsx(FormRenderer, { ...field }) }, field.name)) });
210
+ };
211
+ const AdvancedForm = ({ isDefaultLocale }) => {
212
+ const { formatMessage } = useIntl();
213
+ const form = [
214
+ {
215
+ disabled: isDefaultLocale,
216
+ hint: {
217
+ id: getTranslation("Settings.locales.modal.advanced.setAsDefault.hint"),
218
+ defaultMessage: "One default locale is required, change it by selecting another one"
219
+ },
220
+ label: {
221
+ id: getTranslation("Settings.locales.modal.advanced.setAsDefault"),
222
+ defaultMessage: "Set as default locale"
223
+ },
224
+ name: "isDefault",
225
+ size: 6,
226
+ type: "boolean"
227
+ }
228
+ ].map((field) => ({
229
+ ...field,
230
+ hint: field.hint ? formatMessage(field.hint) : void 0,
231
+ label: formatMessage(field.label)
232
+ }));
233
+ return /* @__PURE__ */ jsx(Grid, { gap: 4, children: form.map(({ size, ...field }) => /* @__PURE__ */ jsx(GridItem, { col: size, children: /* @__PURE__ */ jsx(FormRenderer, { ...field }) }, field.name)) });
234
+ };
235
+ const FormRenderer = (field) => {
236
+ switch (field.type) {
237
+ case "enumeration":
238
+ return /* @__PURE__ */ jsx(EnumerationInput, { ...field });
239
+ default:
240
+ return /* @__PURE__ */ jsx(InputRenderer, { ...field });
241
+ }
242
+ };
243
+ const EnumerationInput = ({
244
+ disabled,
245
+ hint,
246
+ label,
247
+ name,
248
+ options,
249
+ placeholder,
250
+ required
251
+ }) => {
252
+ const { value, error, onChange } = useField(name);
253
+ const { data: defaultLocales = [] } = useGetDefaultLocalesQuery();
254
+ const handleChange = (value2) => {
255
+ if (Array.isArray(defaultLocales)) {
256
+ const locale = defaultLocales.find((locale2) => locale2.code === value2);
257
+ onChange(name, value2);
258
+ onChange("name", locale.name);
259
+ } else {
260
+ onChange(name, value2);
261
+ }
262
+ };
263
+ return /* @__PURE__ */ jsxs(Field.Root, { error, hint, name, required, children: [
264
+ /* @__PURE__ */ jsx(Field.Label, { children: label }),
265
+ /* @__PURE__ */ jsx(
266
+ SingleSelect,
267
+ {
268
+ disabled,
269
+ onChange: handleChange,
270
+ placeholder,
271
+ value,
272
+ children: options.map((option) => /* @__PURE__ */ jsx(SingleSelectOption, { value: option.value, children: option.label }, option.value))
273
+ }
274
+ ),
275
+ /* @__PURE__ */ jsx(Field.Error, {}),
276
+ /* @__PURE__ */ jsx(Field.Hint, {})
277
+ ] });
278
+ };
279
+ const DeleteLocale = ({ id, name }) => {
280
+ const { formatMessage } = useIntl();
281
+ const { toggleNotification } = useNotification();
282
+ const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
283
+ const [visible, setVisible] = React.useState(false);
284
+ const [deleteLocale] = useDeleteLocaleMutation();
285
+ const handleConfirm = async () => {
286
+ try {
287
+ const res = await deleteLocale(id);
288
+ if ("error" in res) {
289
+ toggleNotification({ type: "danger", message: formatAPIError(res.error) });
290
+ return;
291
+ }
292
+ toggleNotification({
293
+ type: "success",
294
+ message: formatMessage({
295
+ id: getTranslation("Settings.locales.modal.delete.success"),
296
+ defaultMessage: "Deleted locale"
297
+ })
298
+ });
299
+ } catch (err) {
300
+ toggleNotification({
301
+ type: "danger",
302
+ message: formatMessage({
303
+ id: "notification.error",
304
+ defaultMessage: "An error occurred, please try again"
305
+ })
306
+ });
307
+ }
308
+ };
309
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
310
+ /* @__PURE__ */ jsx(
311
+ IconButton,
312
+ {
313
+ onClick: () => setVisible(true),
314
+ label: formatMessage(
315
+ {
316
+ id: getTranslation("Settings.list.actions.delete"),
317
+ defaultMessage: "Delete {name} locale"
318
+ },
319
+ {
320
+ name
321
+ }
322
+ ),
323
+ icon: /* @__PURE__ */ jsx(Trash, {}),
324
+ borderWidth: 0
325
+ }
326
+ ),
327
+ /* @__PURE__ */ jsx(ConfirmDialog, { onConfirm: handleConfirm, onClose: () => setVisible(false), isOpen: visible })
328
+ ] });
329
+ };
330
+ const EditLocale = (props) => {
331
+ const { formatMessage } = useIntl();
332
+ const [visible, setVisible] = React.useState(false);
333
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
334
+ /* @__PURE__ */ jsx(
335
+ IconButton,
336
+ {
337
+ onClick: () => setVisible(true),
338
+ label: formatMessage(
339
+ {
340
+ id: getTranslation("Settings.list.actions.edit"),
341
+ defaultMessage: "Edit {name} locale"
342
+ },
343
+ {
344
+ name: props.name
345
+ }
346
+ ),
347
+ icon: /* @__PURE__ */ jsx(Pencil, {}),
348
+ borderWidth: 0
349
+ }
350
+ ),
351
+ visible ? /* @__PURE__ */ jsx(EditModal, { ...props, onClose: () => setVisible(false) }) : null
352
+ ] });
353
+ };
354
+ const EditModal = ({ id, code, isDefault, name, onClose }) => {
355
+ const { toggleNotification } = useNotification();
356
+ const {
357
+ _unstableFormatAPIError: formatAPIError,
358
+ _unstableFormatValidationErrors: formatValidationErrors
359
+ } = useAPIErrorHandler();
360
+ const refetchPermissions = useAuth("EditModal", (state) => state.refetchPermissions);
361
+ const { formatMessage } = useIntl();
362
+ const titleId = React.useId();
363
+ const [updateLocale] = useUpdateLocaleMutation();
364
+ const handleSubmit = async ({ code: _code, ...data }, helpers) => {
365
+ try {
366
+ const res = await updateLocale({
367
+ id,
368
+ ...data
369
+ });
370
+ if ("error" in res) {
371
+ if (isBaseQueryError(res.error) && res.error.name === "ValidationError") {
372
+ helpers.setErrors(formatValidationErrors(res.error));
373
+ } else {
374
+ toggleNotification({ type: "danger", message: formatAPIError(res.error) });
375
+ }
376
+ return;
377
+ }
378
+ toggleNotification({
379
+ type: "success",
380
+ message: formatMessage({
381
+ id: getTranslation("Settings.locales.modal.edit.success"),
382
+ defaultMessage: "Updated locale"
383
+ })
384
+ });
385
+ refetchPermissions();
386
+ onClose();
387
+ } catch (err) {
388
+ toggleNotification({
389
+ type: "danger",
390
+ message: formatMessage({
391
+ id: "notification.error",
392
+ defaultMessage: "An error occurred, please try again"
393
+ })
394
+ });
395
+ }
396
+ };
397
+ return /* @__PURE__ */ jsx(ModalLayout, { onClose, labelledBy: titleId, children: /* @__PURE__ */ jsxs(
398
+ Form,
399
+ {
400
+ method: "PUT",
401
+ onSubmit: handleSubmit,
402
+ initialValues: {
403
+ code,
404
+ name,
405
+ isDefault
406
+ },
407
+ validationSchema: LOCALE_SCHEMA,
408
+ children: [
409
+ /* @__PURE__ */ jsx(ModalHeader, { children: /* @__PURE__ */ jsx(Typography, { fontWeight: "bold", textColor: "neutral800", tag: "h2", id: titleId, children: formatMessage({
410
+ id: getTranslation("Settings.list.actions.edit"),
411
+ defaultMessage: "Edit a locale"
412
+ }) }) }),
413
+ /* @__PURE__ */ jsx(ModalBody, { children: /* @__PURE__ */ jsxs(
414
+ TabGroup,
415
+ {
416
+ label: formatMessage({
417
+ id: getTranslation("Settings.locales.modal.title"),
418
+ defaultMessage: "Configurations"
419
+ }),
420
+ variant: "simple",
421
+ children: [
422
+ /* @__PURE__ */ jsxs(Flex, { justifyContent: "space-between", children: [
423
+ /* @__PURE__ */ jsx(Typography, { tag: "h2", variant: "beta", children: formatMessage({
424
+ id: getTranslation("Settings.locales.modal.title"),
425
+ defaultMessage: "Configuration"
426
+ }) }),
427
+ /* @__PURE__ */ jsxs(Tabs, { children: [
428
+ /* @__PURE__ */ jsx(Tab, { children: formatMessage({
429
+ id: getTranslation("Settings.locales.modal.base"),
430
+ defaultMessage: "Basic settings"
431
+ }) }),
432
+ /* @__PURE__ */ jsx(Tab, { children: formatMessage({
433
+ id: getTranslation("Settings.locales.modal.advanced"),
434
+ defaultMessage: "Advanced settings"
435
+ }) })
436
+ ] })
437
+ ] }),
438
+ /* @__PURE__ */ jsx(Divider, {}),
439
+ /* @__PURE__ */ jsx(Box, { paddingTop: 7, paddingBottom: 7, children: /* @__PURE__ */ jsxs(TabPanels, { children: [
440
+ /* @__PURE__ */ jsx(TabPanel, { children: /* @__PURE__ */ jsx(BaseForm, { mode: "edit" }) }),
441
+ /* @__PURE__ */ jsx(TabPanel, { children: /* @__PURE__ */ jsx(AdvancedForm, { isDefaultLocale: isDefault }) })
442
+ ] }) })
443
+ ]
444
+ }
445
+ ) }),
446
+ /* @__PURE__ */ jsx(
447
+ ModalFooter,
448
+ {
449
+ startActions: /* @__PURE__ */ jsx(Button, { variant: "tertiary", onClick: onClose, children: formatMessage({ id: "app.components.Button.cancel", defaultMessage: "Cancel" }) }),
450
+ endActions: /* @__PURE__ */ jsx(SubmitButton, {})
451
+ }
452
+ )
453
+ ]
454
+ }
455
+ ) });
456
+ };
457
+ const LocaleTable = ({ locales = [], canDelete, canUpdate }) => {
458
+ const [editLocaleId, setEditLocaleId] = React.useState();
459
+ const { formatMessage } = useIntl();
460
+ const handleClick = (localeId) => () => {
461
+ if (canUpdate) {
462
+ setEditLocaleId(localeId);
463
+ }
464
+ };
465
+ return /* @__PURE__ */ jsxs(Table, { colCount: 4, rowCount: locales.length + 1, children: [
466
+ /* @__PURE__ */ jsx(Thead, { children: /* @__PURE__ */ jsxs(Tr, { children: [
467
+ /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({
468
+ id: getTranslation("Settings.locales.row.id"),
469
+ defaultMessage: "ID"
470
+ }) }) }),
471
+ /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({
472
+ id: getTranslation("Settings.locales.row.displayName"),
473
+ defaultMessage: "Display name"
474
+ }) }) }),
475
+ /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({
476
+ id: getTranslation("Settings.locales.row.default-locale"),
477
+ defaultMessage: "Default locale"
478
+ }) }) }),
479
+ /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(VisuallyHidden, { children: "Actions" }) })
480
+ ] }) }),
481
+ /* @__PURE__ */ jsx(Tbody, { children: locales.map((locale) => /* @__PURE__ */ jsxs(React.Fragment, { children: [
482
+ /* @__PURE__ */ jsxs(
483
+ Tr,
484
+ {
485
+ onClick: handleClick(locale.id),
486
+ style: { cursor: canUpdate ? "pointer" : "default" },
487
+ children: [
488
+ /* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", children: locale.id }) }),
489
+ /* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", children: locale.name }) }),
490
+ /* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", children: locale.isDefault ? formatMessage({
491
+ id: getTranslation("Settings.locales.default"),
492
+ defaultMessage: "Default"
493
+ }) : null }) }),
494
+ /* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsxs(Flex, { gap: 1, justifyContent: "flex-end", onClick: (e) => e.stopPropagation(), children: [
495
+ canUpdate && /* @__PURE__ */ jsx(EditLocale, { ...locale }),
496
+ canDelete && !locale.isDefault && /* @__PURE__ */ jsx(DeleteLocale, { ...locale })
497
+ ] }) })
498
+ ]
499
+ }
500
+ ),
501
+ editLocaleId === locale.id ? /* @__PURE__ */ jsx(EditModal, { ...locale, onClose: () => setEditLocaleId(void 0) }) : null
502
+ ] }, locale.id)) })
503
+ ] });
504
+ };
505
+ const SettingsPage = () => {
506
+ const { formatMessage } = useIntl();
507
+ const { toggleNotification } = useNotification();
508
+ const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
509
+ const { data: locales, isLoading: isLoadingLocales, error } = useGetLocalesQuery();
510
+ const {
511
+ isLoading: isLoadingRBAC,
512
+ allowedActions: { canUpdate, canCreate, canDelete }
513
+ } = useRBAC(PERMISSIONS);
514
+ React.useEffect(() => {
515
+ if (error) {
516
+ toggleNotification({
517
+ type: "danger",
518
+ message: formatAPIError(error)
519
+ });
520
+ }
521
+ }, [error, formatAPIError, toggleNotification]);
522
+ const isLoading = isLoadingLocales || isLoadingRBAC;
523
+ if (isLoading) {
524
+ return /* @__PURE__ */ jsx(Page.Loading, {});
525
+ }
526
+ if (error || !Array.isArray(locales)) {
527
+ return /* @__PURE__ */ jsx(Page.Error, {});
528
+ }
529
+ return /* @__PURE__ */ jsxs(Page.Main, { tabIndex: -1, children: [
530
+ /* @__PURE__ */ jsx(
531
+ Layouts.Header,
532
+ {
533
+ primaryAction: /* @__PURE__ */ jsx(CreateLocale, { disabled: !canCreate }),
534
+ title: formatMessage({
535
+ id: getTranslation("plugin.name"),
536
+ defaultMessage: "Internationalization"
537
+ }),
538
+ subtitle: formatMessage({
539
+ id: getTranslation("Settings.list.description"),
540
+ defaultMessage: "Configure the settings"
541
+ })
542
+ }
543
+ ),
544
+ /* @__PURE__ */ jsx(Layouts.Content, { children: locales.length > 0 ? /* @__PURE__ */ jsx(LocaleTable, { locales, canDelete, canUpdate }) : /* @__PURE__ */ jsx(
545
+ EmptyStateLayout,
546
+ {
547
+ icon: /* @__PURE__ */ jsx(EmptyDocuments, { width: void 0, height: void 0 }),
548
+ content: formatMessage({
549
+ id: getTranslation("Settings.list.empty.title"),
550
+ defaultMessage: "There are no locales"
551
+ }),
552
+ action: /* @__PURE__ */ jsx(CreateLocale, { disabled: !canCreate, variant: "secondary" })
553
+ }
554
+ ) })
555
+ ] });
556
+ };
557
+ const ProtectedSettingsPage = () => {
558
+ return /* @__PURE__ */ jsx(Page.Protect, { permissions: PERMISSIONS.read, children: /* @__PURE__ */ jsx(SettingsPage, {}) });
559
+ };
560
+ export {
561
+ ProtectedSettingsPage,
562
+ SettingsPage
563
+ };
564
+ //# sourceMappingURL=SettingsPage-CB5yd4O3.mjs.map