From e15309b82d8a21c44df3035532fc2bdd283150ed Mon Sep 17 00:00:00 2001 From: StaNov Date: Thu, 31 Oct 2024 16:39:51 +0100 Subject: [PATCH] DRAFT: Making namespaces as a hidden feature Closes #2594 --- TODO.txt | 2 ++ .../request/project/EditProjectRequest.kt | 1 + .../main/kotlin/io/tolgee/model/Project.kt | 3 +++ .../tolgee/service/project/ProjectService.kt | 1 + webapp/src/i18n/cs.json | 1 + webapp/src/i18n/da.json | 1 + webapp/src/i18n/de.json | 1 + webapp/src/i18n/en.json | 1 + webapp/src/i18n/ro.json | 1 + webapp/src/service/apiSchema.generated.ts | 2 ++ .../project/ProjectSettingsGeneral.tsx | 14 +++++++++++ .../components/UseNamespacesCheckbox.tsx | 24 +++++++++++++++++++ .../translations/KeyCreateForm/FormBody.tsx | 2 +- .../translations/KeyEdit/KeyGeneral.tsx | 4 +++- 14 files changed, 56 insertions(+), 2 deletions(-) create mode 100644 TODO.txt create mode 100644 webapp/src/views/projects/project/components/UseNamespacesCheckbox.tsx diff --git a/TODO.txt b/TODO.txt new file mode 100644 index 0000000000..41f58c7f5b --- /dev/null +++ b/TODO.txt @@ -0,0 +1,2 @@ +* Hide select boxes by the settings +* Add liquibase changeset for customers already using namespaces, disable them only when there are none \ No newline at end of file diff --git a/backend/data/src/main/kotlin/io/tolgee/dtos/request/project/EditProjectRequest.kt b/backend/data/src/main/kotlin/io/tolgee/dtos/request/project/EditProjectRequest.kt index 9546b7e00f..1cd3e8e549 100644 --- a/backend/data/src/main/kotlin/io/tolgee/dtos/request/project/EditProjectRequest.kt +++ b/backend/data/src/main/kotlin/io/tolgee/dtos/request/project/EditProjectRequest.kt @@ -13,6 +13,7 @@ data class EditProjectRequest( @field:Pattern(regexp = "^[a-z0-9-]*[a-z]+[a-z0-9-]*$", message = "invalid_pattern") var slug: String? = null, var baseLanguageId: Long? = null, + var useNamespaces: Boolean = false, var defaultNamespaceId: Long? = null, @field:Size(min = 3, max = 2000) var description: String? = null, diff --git a/backend/data/src/main/kotlin/io/tolgee/model/Project.kt b/backend/data/src/main/kotlin/io/tolgee/model/Project.kt index a01b6bda4a..63938bfc71 100644 --- a/backend/data/src/main/kotlin/io/tolgee/model/Project.kt +++ b/backend/data/src/main/kotlin/io/tolgee/model/Project.kt @@ -125,6 +125,9 @@ class Project( @ColumnDefault("true") override var icuPlaceholders: Boolean = true + @ColumnDefault("false") + var useNamespaces: Boolean = false + @ColumnDefault("0") var lastTaskNumber: Long = 0 diff --git a/backend/data/src/main/kotlin/io/tolgee/service/project/ProjectService.kt b/backend/data/src/main/kotlin/io/tolgee/service/project/ProjectService.kt index 0ffa1a5354..59ab225984 100644 --- a/backend/data/src/main/kotlin/io/tolgee/service/project/ProjectService.kt +++ b/backend/data/src/main/kotlin/io/tolgee/service/project/ProjectService.kt @@ -180,6 +180,7 @@ class ProjectService( project.name = dto.name project.description = dto.description project.icuPlaceholders = dto.icuPlaceholders + project.useNamespaces = dto.useNamespaces if (project.defaultNamespace != null) { namespaceService.deleteUnusedNamespaces(listOf(project.defaultNamespace!!)) diff --git a/webapp/src/i18n/cs.json b/webapp/src/i18n/cs.json index 05b7652177..f4c8246d9f 100644 --- a/webapp/src/i18n/cs.json +++ b/webapp/src/i18n/cs.json @@ -1146,6 +1146,7 @@ "projects_empty": "Žádné projekty", "projects_empty_action": "Přidat projekt", "project_settings_base_language": "Základní jazyk", + "project_settings_use_namespaces": "Používat namespaces", "project_settings_base_namespace": "Výchozí namespace", "project_settings_button": "Nastavení", "project_settings_danger_zone_title": "Nebezpečná zóna", diff --git a/webapp/src/i18n/da.json b/webapp/src/i18n/da.json index fa9a5f2678..cfebd015a2 100644 --- a/webapp/src/i18n/da.json +++ b/webapp/src/i18n/da.json @@ -1146,6 +1146,7 @@ "projects_empty": "Ingen projekter", "projects_empty_action": "Tilføj projekt", "project_settings_base_language": "Basis sprog", + "project_settings_use_namespaces": "Use namespaces TODO", "project_settings_base_namespace": "Standard navnerum", "project_settings_button": "Indstillinger", "project_settings_danger_zone_title": "Farezone", diff --git a/webapp/src/i18n/de.json b/webapp/src/i18n/de.json index 3c6b21d07c..bc33302bc0 100644 --- a/webapp/src/i18n/de.json +++ b/webapp/src/i18n/de.json @@ -1049,6 +1049,7 @@ "projects_empty": "Keine Projekte", "projects_empty_action": "Projekt hinzufügen", "project_settings_base_language": "Basissprache", + "project_settings_use_namespaces": "Use namespaces TODO", "project_settings_base_namespace": "Standard-Namespace", "project_settings_button": "Einstellungen", "project_settings_danger_zone_title": "Gefahrenzone", diff --git a/webapp/src/i18n/en.json b/webapp/src/i18n/en.json index 80af3d99ca..667249d297 100644 --- a/webapp/src/i18n/en.json +++ b/webapp/src/i18n/en.json @@ -1146,6 +1146,7 @@ "projects_empty": "No projects", "projects_empty_action": "Add project", "project_settings_base_language": "Base language", + "project_settings_use_namespaces": "Use namespaces", "project_settings_base_namespace": "Default namespace", "project_settings_button": "Settings", "project_settings_danger_zone_title": "Danger zone", diff --git a/webapp/src/i18n/ro.json b/webapp/src/i18n/ro.json index 9c8f52e4c8..23c9fc8ea6 100644 --- a/webapp/src/i18n/ro.json +++ b/webapp/src/i18n/ro.json @@ -1146,6 +1146,7 @@ "projects_empty": "Niciun proiect", "projects_empty_action": "Adaugă proiect", "project_settings_base_language": "Limba de bază", + "project_settings_use_namespaces": "Use namespaces TODO", "project_settings_base_namespace": "Spațiul de nume implicit", "project_settings_button": "Setări", "project_settings_danger_zone_title": "Zona de pericol", diff --git a/webapp/src/service/apiSchema.generated.ts b/webapp/src/service/apiSchema.generated.ts index cd63011a2f..46b942e5c1 100644 --- a/webapp/src/service/apiSchema.generated.ts +++ b/webapp/src/service/apiSchema.generated.ts @@ -1152,6 +1152,7 @@ export interface components { slug?: string; /** Format: int64 */ baseLanguageId?: number; + useNamespaces: boolean; /** Format: int64 */ defaultNamespaceId?: number; description?: string; @@ -1336,6 +1337,7 @@ export interface components { avatar?: components["schemas"]["Avatar"]; organizationOwner?: components["schemas"]["SimpleOrganizationModel"]; baseLanguage?: components["schemas"]["LanguageModel"]; + useNamespaces: boolean; defaultNamespace?: components["schemas"]["NamespaceModel"]; organizationRole?: "MEMBER" | "OWNER"; directPermission?: components["schemas"]["PermissionModel"]; diff --git a/webapp/src/views/projects/project/ProjectSettingsGeneral.tsx b/webapp/src/views/projects/project/ProjectSettingsGeneral.tsx index 408ec472b3..c4dd8d7349 100644 --- a/webapp/src/views/projects/project/ProjectSettingsGeneral.tsx +++ b/webapp/src/views/projects/project/ProjectSettingsGeneral.tsx @@ -15,11 +15,13 @@ import { Box, styled } from '@mui/material'; import { ProjectLanguagesProvider } from 'tg.hooks/ProjectLanguagesProvider'; import { useProjectNamespaces } from 'tg.hooks/useProjectNamespaces'; import { DefaultNamespaceSelect } from './components/DefaultNamespaceSelect'; +import { UseNamespacesCheckbox } from './components/UseNamespacesCheckbox'; type FormValues = { name: string; description: string | undefined; baseLanguageId: number | undefined; + useNamespaces: boolean | false; defaultNamespaceId: number | ''; }; @@ -49,6 +51,15 @@ const LanguageSelect = () => { ); }; +const NamespacesCheckbox = () => { + return ( + } + name="useNamespaces" + /> + ); +}; + const NamespaceSelect = () => { const { allNamespacesWithNone } = useProjectNamespaces(); return ( @@ -69,6 +80,7 @@ export const ProjectSettingsGeneral = () => { name: project.name, baseLanguageId: project.baseLanguage?.id, description: project.description ?? '', + useNamespaces: project.useNamespaces ?? false, defaultNamespaceId: defaultNamespace?.id ?? '', } satisfies FormValues; @@ -82,6 +94,7 @@ export const ProjectSettingsGeneral = () => { const data = { ...values, description: values.description || undefined, + useNamespaces: values.useNamespaces || false, defaultNamespaceId: values.defaultNamespaceId === 0 ? undefined : values.defaultNamespaceId, }; @@ -157,6 +170,7 @@ export const ProjectSettingsGeneral = () => { + diff --git a/webapp/src/views/projects/project/components/UseNamespacesCheckbox.tsx b/webapp/src/views/projects/project/components/UseNamespacesCheckbox.tsx new file mode 100644 index 0000000000..a10d9fa0ea --- /dev/null +++ b/webapp/src/views/projects/project/components/UseNamespacesCheckbox.tsx @@ -0,0 +1,24 @@ +import { FC, ReactNode } from 'react'; +import { Box, Checkbox, MenuItem } from '@mui/material'; + +import { Select } from 'tg.component/common/form/fields/Select'; +import { components } from 'tg.service/apiSchema.generated'; +import { FieldLabel } from 'tg.component/FormField'; +import { useTranslate } from '@tolgee/react'; + +export const UseNamespacesCheckbox: FC<{ + label?: ReactNode; + name: string; +}> = (props) => { + return ( + + {props.label} + + + ); +}; diff --git a/webapp/src/views/projects/translations/KeyCreateForm/FormBody.tsx b/webapp/src/views/projects/translations/KeyCreateForm/FormBody.tsx index 77a41bb8e9..111e20ef4d 100644 --- a/webapp/src/views/projects/translations/KeyCreateForm/FormBody.tsx +++ b/webapp/src/views/projects/translations/KeyCreateForm/FormBody.tsx @@ -126,7 +126,7 @@ export const FormBody: React.FC = ({ onCancel, autofocus }) => { {({ field, form }: FieldProps) => { return (
- + {/*TODO tady možná taky*/} diff --git a/webapp/src/views/projects/translations/KeyEdit/KeyGeneral.tsx b/webapp/src/views/projects/translations/KeyEdit/KeyGeneral.tsx index 9453d3e923..e00821cba2 100644 --- a/webapp/src/views/projects/translations/KeyEdit/KeyGeneral.tsx +++ b/webapp/src/views/projects/translations/KeyEdit/KeyGeneral.tsx @@ -67,10 +67,11 @@ export const KeyGeneral = () => { + {/**/} - {t('translations_key_edit_label_namespace')} + {t('translations_key_edit_label_namespace')} tady { /> + {/**/}