@nocobase/plugin-localization 2.1.0-alpha.4 → 2.1.0-alpha.45

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 (37) hide show
  1. package/LICENSE +201 -661
  2. package/README.md +79 -10
  3. package/client-v2.d.ts +2 -0
  4. package/client-v2.js +1 -0
  5. package/dist/ai/ai-employees/lina.d.ts +10 -0
  6. package/dist/ai/ai-employees/lina.js +60 -0
  7. package/dist/client/300.1f79b801d226f40d.js +10 -0
  8. package/dist/client/i18n-missing-handler.d.ts +1 -17
  9. package/dist/client/index.js +1 -1
  10. package/dist/client-v2/796.0ec484505de4b04a.js +10 -0
  11. package/dist/client-v2/common/constants.d.ts +13 -0
  12. package/dist/client-v2/common/i18n-missing-handler.d.ts +23 -0
  13. package/dist/{client/Localization.d.ts → client-v2/i18n-missing-handler.d.ts} +1 -2
  14. package/dist/client-v2/index.d.ts +9 -0
  15. package/dist/client-v2/index.js +10 -0
  16. package/dist/client-v2/locale.d.ts +11 -0
  17. package/dist/client-v2/pages/LocalizationPage.d.ts +11 -0
  18. package/dist/client-v2/plugin.d.ts +13 -0
  19. package/dist/externalVersion.js +18 -13
  20. package/dist/locale/en-US.json +38 -1
  21. package/dist/locale/zh-CN.json +38 -1
  22. package/dist/server/actions/aiTranslate.d.ts +14 -0
  23. package/dist/server/actions/aiTranslate.js +151 -0
  24. package/dist/server/actions/localization.js +30 -15
  25. package/dist/server/actions/localizationTexts.js +8 -9
  26. package/dist/server/migrations/20260511230000-delete-official-plugin-package-resource-modules.d.ts +14 -0
  27. package/dist/server/migrations/20260511230000-delete-official-plugin-package-resource-modules.js +64 -0
  28. package/dist/server/plugin.d.ts +5 -2
  29. package/dist/server/plugin.js +76 -14
  30. package/dist/server/tasks/localization-ai-translate.d.ts +48 -0
  31. package/dist/server/tasks/localization-ai-translate.js +606 -0
  32. package/dist/server/translation-scope.d.ts +31 -0
  33. package/dist/server/translation-scope.js +107 -0
  34. package/package.json +8 -3
  35. package/dist/client/177bd849c95cf6cc.js +0 -10
  36. package/dist/server/source-manager.d.ts +0 -35
  37. package/dist/server/source-manager.js +0 -77
@@ -1,24 +1,61 @@
1
1
  {
2
2
  "Add new": "Add new",
3
3
  "All": "All",
4
+ "Async task created": "Async task created",
4
5
  "Collections & Fields": "Collections & Fields",
6
+ "Confirm translation task": "Confirm translation task",
7
+ "Creating...": "Creating...",
5
8
  "Current language": "Current language",
9
+ "Built-in default reference language": "Built-in default reference language",
10
+ "Built-in entries": "Built-in entries",
11
+ "Built-in entries reference translation": "Built-in entries reference translation",
12
+ "Built-in entries are system and plugin entries. Custom entries include route names, collection and field names, and UI content.": "Built-in entries are system and plugin entries. Custom entries include route names, collection and field names, and UI content.",
13
+ "Built-in fallback reference language": "Built-in fallback reference language",
14
+ "Custom default reference language": "Custom default reference language",
15
+ "Custom entries": "Custom entries",
16
+ "Custom entries reference translation": "Custom entries reference translation",
17
+ "Custom fallback reference language": "Custom fallback reference language",
18
+ "Default language": "Default language",
6
19
  "Delete text": "Delete text",
7
20
  "Delete translation": "Delete translation",
8
21
  "Edit": "Edit",
22
+ "Entries to translate": "Entries to translate",
23
+ "Fallback language": "Fallback language",
9
24
  "Keyword": "Keyword",
10
25
  "Localization": "Localization",
11
26
  "Localization management": "Localization management",
27
+ "Localization engineer": "Localization engineer",
28
+ "Loading...": "Loading...",
12
29
  "Menu": "Menu",
30
+ "Model": "Model",
13
31
  "Module": "Module",
14
32
  "No data": "No data",
33
+ "No entries to translate": "No entries to translate",
15
34
  "No translation": "No translation",
35
+ "Please select the records you want to translate": "Please select the records you want to translate",
36
+ "Please wait for the translation preview to load": "Please wait for the translation preview to load",
16
37
  "Please select the resources you want to synchronize": "Please select the resources you want to synchronize",
38
+ "Provider": "Provider",
17
39
  "Publish": "Publish",
40
+ "Reference translation": "Reference translation",
41
+ "Refresh": "Refresh",
42
+ "Reset built-in translations": "Reset built-in translations",
43
+ "Translate all entries in the current language, including existing translations.": "Translate all entries in the current language, including existing translations.",
44
+ "Translate built-in entries only": "Translate built-in entries only",
45
+ "Translate custom entries only": "Translate custom entries only",
46
+ "Translate entries that do not yet have a translation in the current language.": "Translate entries that do not yet have a translation in the current language.",
47
+ "Translate only system and plugin entries from the System & Plugins synchronization source.": "Translate only system and plugin entries from the System & Plugins synchronization source.",
48
+ "Translate only the selected entries in the table.": "Translate only the selected entries in the table.",
49
+ "Translate only user-created entries that are not from the System & Plugins synchronization source.": "Translate only user-created entries that are not from the System & Plugins synchronization source.",
50
+ "Full translation": "Full translation",
51
+ "Incremental translation": "Incremental translation",
52
+ "Selected translation": "Selected translation",
18
53
  "Sync": "Sync",
19
54
  "System & Plugins": "System & Plugins",
20
55
  "Text": "Text",
56
+ "Translate localization resources with AI.": "Translate localization resources with AI.",
21
57
  "Translation": "Translation",
58
+ "Translation scope": "Translation scope",
22
59
  "Translations": "Translations",
23
60
  "User interfaces": "User interfaces"
24
- }
61
+ }
@@ -1,24 +1,61 @@
1
1
  {
2
2
  "Add new": "新增",
3
3
  "All": "全部",
4
+ "Async task created": "异步任务已创建",
4
5
  "Collections & Fields": "数据表和字段",
6
+ "Confirm translation task": "确认翻译任务",
7
+ "Creating...": "正在创建...",
5
8
  "Current language": "当前语言",
9
+ "Built-in default reference language": "内置词条默认参考语言",
10
+ "Built-in entries": "内置词条",
11
+ "Built-in entries reference translation": "内置词条参考翻译",
12
+ "Built-in entries are system and plugin entries. Custom entries include route names, collection and field names, and UI content.": "内置词条是指系统和插件的词条。自建词条包括路由名称、数据表和字段名称以及 UI 上的内容。",
13
+ "Built-in fallback reference language": "内置词条备选参考语言",
14
+ "Custom default reference language": "自建词条默认参考语言",
15
+ "Custom entries": "自建词条",
16
+ "Custom entries reference translation": "自建词条参考翻译",
17
+ "Custom fallback reference language": "自建词条备选参考语言",
18
+ "Default language": "默认语言",
6
19
  "Delete text": "删除原文",
7
20
  "Delete translation": "删除译文",
8
21
  "Edit": "编辑",
22
+ "Entries to translate": "即将翻译条数",
23
+ "Fallback language": "备选语言",
9
24
  "Keyword": "关键字",
10
25
  "Localization": "本地化",
11
26
  "Localization management": "本地化管理",
27
+ "Localization engineer": "本地化工程师",
28
+ "Loading...": "加载中...",
12
29
  "Menu": "菜单",
30
+ "Model": "模型",
13
31
  "Module": "模块",
14
32
  "No data": "暂无数据",
33
+ "No entries to translate": "没有需要翻译的词条",
15
34
  "No translation": "待翻译",
35
+ "Please select the records you want to translate": "请选择需要翻译的记录",
36
+ "Please wait for the translation preview to load": "请等待翻译预览加载完成",
16
37
  "Please select the resources you want to synchronize": "请选择需要同步的资源",
38
+ "Provider": "服务商",
17
39
  "Publish": "发布",
40
+ "Reference translation": "参考翻译",
41
+ "Refresh": "刷新",
42
+ "Reset built-in translations": "重置系统内置词条翻译内容",
43
+ "Translate all entries in the current language, including existing translations.": "翻译当前语言的全部词条,包括已有译文的词条。",
44
+ "Translate built-in entries only": "只翻译内置词条",
45
+ "Translate custom entries only": "只翻译用户自建词条",
46
+ "Translate entries that do not yet have a translation in the current language.": "翻译当前语言中尚未有译文的词条。",
47
+ "Translate only system and plugin entries from the System & Plugins synchronization source.": "仅翻译同步来源为“系统和插件”的内置词条。",
48
+ "Translate only the selected entries in the table.": "仅翻译表格中已选中的词条。",
49
+ "Translate only user-created entries that are not from the System & Plugins synchronization source.": "仅翻译非“系统和插件”同步来源的用户自建词条。",
50
+ "Full translation": "全量翻译",
51
+ "Incremental translation": "增量翻译",
52
+ "Selected translation": "翻译所选项",
18
53
  "Sync": "同步",
19
54
  "System & Plugins": "系统和插件",
20
55
  "Text": "原文",
56
+ "Translate localization resources with AI.": "使用 AI 翻译本地化资源。",
21
57
  "Translation": "译文",
58
+ "Translation scope": "翻译范围",
22
59
  "Translations": "翻译",
23
60
  "User interfaces": "用户界面配置"
24
- }
61
+ }
@@ -0,0 +1,14 @@
1
+ /**
2
+ * This file is part of the NocoBase (R) project.
3
+ * Copyright (c) 2020-2024 NocoBase Co., Ltd.
4
+ * Authors: NocoBase Team.
5
+ *
6
+ * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
+ * For more information, please refer to: https://www.nocobase.com/agreement.
8
+ */
9
+ import { Context, Next } from '@nocobase/actions';
10
+ declare const _default: {
11
+ aiTranslate: (ctx: Context, next: Next) => Promise<void>;
12
+ aiTranslatePreview: (ctx: Context, next: Next) => Promise<void>;
13
+ };
14
+ export default _default;
@@ -0,0 +1,151 @@
1
+ /**
2
+ * This file is part of the NocoBase (R) project.
3
+ * Copyright (c) 2020-2024 NocoBase Co., Ltd.
4
+ * Authors: NocoBase Team.
5
+ *
6
+ * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
+ * For more information, please refer to: https://www.nocobase.com/agreement.
8
+ */
9
+
10
+ var __defProp = Object.defineProperty;
11
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
12
+ var __getOwnPropNames = Object.getOwnPropertyNames;
13
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
14
+ var __export = (target, all) => {
15
+ for (var name in all)
16
+ __defProp(target, name, { get: all[name], enumerable: true });
17
+ };
18
+ var __copyProps = (to, from, except, desc) => {
19
+ if (from && typeof from === "object" || typeof from === "function") {
20
+ for (let key of __getOwnPropNames(from))
21
+ if (!__hasOwnProp.call(to, key) && key !== except)
22
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
23
+ }
24
+ return to;
25
+ };
26
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
27
+ var aiTranslate_exports = {};
28
+ __export(aiTranslate_exports, {
29
+ default: () => aiTranslate_default
30
+ });
31
+ module.exports = __toCommonJS(aiTranslate_exports);
32
+ var import_localization_ai_translate = require("../tasks/localization-ai-translate");
33
+ var import_translation_scope = require("../translation-scope");
34
+ const validateParams = (ctx) => {
35
+ const {
36
+ mode,
37
+ locale,
38
+ employeeUsername = "lina",
39
+ model,
40
+ textIds,
41
+ scope = "all",
42
+ referenceLocales
43
+ } = ctx.action.params.values || {};
44
+ if (!["full", "incremental", "selected"].includes(mode)) {
45
+ ctx.throw(400, "Invalid translation mode");
46
+ }
47
+ if (!["all", "builtIn", "custom"].includes(scope)) {
48
+ ctx.throw(400, "Invalid translation scope");
49
+ }
50
+ if (mode === "selected" && (!Array.isArray(textIds) || !textIds.length)) {
51
+ ctx.throw(400, "Please select the records you want to translate");
52
+ }
53
+ return {
54
+ mode,
55
+ locale: locale || ctx.get("X-Locale") || "en-US",
56
+ employeeUsername,
57
+ model,
58
+ textIds,
59
+ scope,
60
+ referenceLocales
61
+ };
62
+ };
63
+ const countTexts = async (ctx, mode, locale, scope, textIds) => {
64
+ const options = await (0, import_translation_scope.buildFindTextsOptions)({
65
+ app: ctx.app,
66
+ mode,
67
+ locale,
68
+ scope,
69
+ textIds
70
+ });
71
+ return await ctx.db.getRepository("localizationTexts").count(options);
72
+ };
73
+ const getScopeTitle = (scope) => {
74
+ return {
75
+ all: "All entries",
76
+ builtIn: "Built-in entries",
77
+ custom: "Custom entries"
78
+ }[scope];
79
+ };
80
+ const getTaskTitle = (mode, scope, locale) => {
81
+ if (mode === "selected") {
82
+ return `AI ${mode} localization translation - ${locale}`;
83
+ }
84
+ return `AI ${mode} localization translation - ${getScopeTitle(scope)} - ${locale}`;
85
+ };
86
+ const getAITranslatePreview = async (ctx) => {
87
+ const { mode, locale, employeeUsername, model, scope, referenceLocales, textIds } = validateParams(ctx);
88
+ const aiPlugin = ctx.app.pm.get("ai");
89
+ if (!(aiPlugin == null ? void 0 : aiPlugin.aiEmployeesManager)) {
90
+ ctx.throw(500, "AI plugin is not available");
91
+ }
92
+ const employee = await aiPlugin.aiEmployeesManager.getEmployee(employeeUsername);
93
+ if (!employee) {
94
+ ctx.throw(400, `AI employee "${employeeUsername}" not found`);
95
+ }
96
+ const resolvedModel = await aiPlugin.aiEmployeesManager.resolveModel(employee, model);
97
+ const { model: modelName, service } = await aiPlugin.aiManager.getLLMService(resolvedModel);
98
+ const providerMeta = aiPlugin.aiManager.llmProviders.get(service.provider);
99
+ const count = await countTexts(ctx, mode, locale, scope, textIds);
100
+ return {
101
+ mode,
102
+ locale,
103
+ scope,
104
+ referenceLocales,
105
+ count,
106
+ provider: service.provider,
107
+ providerTitle: providerMeta == null ? void 0 : providerMeta.title,
108
+ llmService: service.name,
109
+ llmServiceTitle: service.title,
110
+ model: modelName
111
+ };
112
+ };
113
+ const aiTranslatePreview = async (ctx, next) => {
114
+ ctx.body = await getAITranslatePreview(ctx);
115
+ await next();
116
+ };
117
+ const aiTranslate = async (ctx, next) => {
118
+ var _a, _b, _c, _d;
119
+ const { mode, locale, employeeUsername, model, textIds, scope, referenceLocales } = validateParams(ctx);
120
+ const currentUserId = ((_b = (_a = ctx.auth) == null ? void 0 : _a.user) == null ? void 0 : _b.id) || ((_d = (_c = ctx.state) == null ? void 0 : _c.currentUser) == null ? void 0 : _d.id);
121
+ const taskManager = ctx.app.container.get("AsyncTaskManager");
122
+ if (!taskManager) {
123
+ ctx.throw(500, "AsyncTaskManager is not available");
124
+ }
125
+ const task = await taskManager.createTask(
126
+ {
127
+ origin: "localization",
128
+ type: import_localization_ai_translate.LOCALIZATION_AI_TRANSLATE_TASK_TYPE,
129
+ title: getTaskTitle(mode, scope, locale),
130
+ params: {
131
+ mode,
132
+ locale,
133
+ employeeUsername,
134
+ model,
135
+ userId: currentUserId,
136
+ textIds,
137
+ scope,
138
+ referenceLocales
139
+ },
140
+ createdById: currentUserId,
141
+ cancelable: true
142
+ },
143
+ {
144
+ useQueue: true,
145
+ context: ctx
146
+ }
147
+ );
148
+ ctx.body = task.toJSON();
149
+ await next();
150
+ };
151
+ var aiTranslate_default = { aiTranslate, aiTranslatePreview };
@@ -35,15 +35,23 @@ const sync = async (ctx, next) => {
35
35
  const plugin = ctx.app.pm.get("localization");
36
36
  const resourcesInstance = plugin.resources;
37
37
  const locale = ctx.get("X-Locale") || "en-US";
38
- const { types = [] } = ctx.action.params.values || {};
38
+ const { types = [], resetTranslations = false } = ctx.action.params.values || {};
39
39
  if (!types.length) {
40
40
  ctx.throw(400, ctx.t("Please provide synchronization source."));
41
41
  }
42
- const resources = await plugin.sourceManager.sync(ctx, types);
43
- let textValues = [];
42
+ const resources = await ctx.app.localeManager.syncSources(ctx, types);
43
+ const normalizedResources = {};
44
44
  Object.entries(resources).forEach(([module2, resource]) => {
45
+ const normalizedModule = plugin.normalizeResourceModule(module2).replace("resources.", "");
46
+ normalizedResources[normalizedModule] = {
47
+ ...normalizedResources[normalizedModule] || {},
48
+ ...resource
49
+ };
50
+ });
51
+ let textValues = [];
52
+ Object.entries(normalizedResources).forEach(([module2, resource]) => {
45
53
  Object.keys(resource).forEach((text) => {
46
- textValues.push({ module: `resources.${module2}`, text });
54
+ textValues.push({ module: plugin.normalizeResourceModule(module2), text });
47
55
  });
48
56
  });
49
57
  textValues = await resourcesInstance.filterExists(textValues);
@@ -53,26 +61,34 @@ const sync = async (ctx, next) => {
53
61
  });
54
62
  const texts = await ctx.db.getModel("localizationTexts").findAll({
55
63
  include: [{ association: "translations", where: { locale }, required: false }],
56
- where: { "$translations.id$": null },
64
+ where: resetTranslations ? void 0 : { "$translations.id$": null },
57
65
  transaction: t
58
66
  });
59
67
  const translationValues = texts.filter((text) => {
60
68
  var _a;
61
- const module2 = text.module.replace("resources.", "");
62
- return (_a = resources[module2]) == null ? void 0 : _a[text.text];
69
+ const module2 = plugin.normalizeResourceModule(text.module).replace("resources.", "");
70
+ return (_a = normalizedResources[module2]) == null ? void 0 : _a[text.text];
63
71
  }).map((text) => {
64
72
  var _a;
65
- const module2 = text.module.replace("resources.", "");
73
+ const module2 = plugin.normalizeResourceModule(text.module).replace("resources.", "");
66
74
  return {
67
75
  locale,
68
76
  textId: text.id,
69
- translation: (_a = resources[module2]) == null ? void 0 : _a[text.text]
77
+ translation: (_a = normalizedResources[module2]) == null ? void 0 : _a[text.text]
70
78
  };
71
79
  });
72
- await ctx.db.getModel("localizationTranslations").bulkCreate(translationValues, {
73
- transaction: t
74
- });
80
+ if (resetTranslations) {
81
+ await ctx.db.getModel("localizationTranslations").bulkCreate(translationValues, {
82
+ updateOnDuplicate: ["translation"],
83
+ transaction: t
84
+ });
85
+ } else {
86
+ await ctx.db.getModel("localizationTranslations").bulkCreate(translationValues, {
87
+ transaction: t
88
+ });
89
+ }
75
90
  await resourcesInstance.updateCacheTexts(newTexts);
91
+ await resourcesInstance.reset();
76
92
  });
77
93
  ctx.logger.info(`Sync localization resources done, ${Date.now() - startTime}ms`);
78
94
  await next();
@@ -82,9 +98,8 @@ const publish = async (ctx, next) => {
82
98
  await next();
83
99
  };
84
100
  const getSources = async (ctx, next) => {
85
- const plugin = ctx.app.pm.get("localization");
86
- const sources = Array.from(plugin.sourceManager.sources.getEntities());
87
- ctx.body = sources.map(([name, source]) => ({
101
+ const sources = Array.from(ctx.app.localeManager.sources.getEntities());
102
+ ctx.body = sources.filter(([, source]) => source.sync).map(([name, source]) => ({
88
103
  name,
89
104
  title: source.title
90
105
  }));
@@ -104,18 +104,17 @@ const list = async (ctx, next) => {
104
104
  const [rows, count] = await listText(ctx.db, { module: module2, keyword, hasTranslation, locale, options });
105
105
  const cache = ctx.app.cache;
106
106
  const pm = ctx.app.pm;
107
- const plugin = pm.get("localization");
108
107
  const plugins = await cache.wrap(`lm-plugins:${locale}`, () => pm.list({ locale }));
109
- const sources = Array.from(plugin.sourceManager.sources.getValues());
108
+ const sources = Array.from(ctx.app.localeManager.sources.getValues());
110
109
  const extendModules = sources.filter((source) => source.namespace).map((source) => ({
111
110
  value: source.namespace,
112
111
  label: source.title
113
112
  }));
114
113
  const modules = [
115
114
  ...extendModules,
116
- ...plugins.map((plugin2) => ({
117
- value: plugin2.alias || plugin2.name,
118
- label: plugin2.displayName
115
+ ...plugins.map((plugin) => ({
116
+ value: plugin.alias || plugin.name,
117
+ label: plugin.displayName
119
118
  }))
120
119
  ];
121
120
  for (const row of rows) {
@@ -133,9 +132,9 @@ const list = async (ctx, next) => {
133
132
  totalPage: Math.ceil(count / pageSize),
134
133
  modules: [
135
134
  ...extendModules,
136
- ...plugins.map((plugin2) => ({
137
- value: plugin2.alias || plugin2.name,
138
- label: plugin2.displayName
135
+ ...plugins.map((plugin) => ({
136
+ value: plugin.alias || plugin.name,
137
+ label: plugin.displayName
139
138
  }))
140
139
  ]
141
140
  };
@@ -163,7 +162,7 @@ const missing = async (ctx, next) => {
163
162
  const plugin = (_a = ctx.app.pm) == null ? void 0 : _a.get("localization");
164
163
  const currentLocale = locale || ctx.get("X-Locale") || "en-US";
165
164
  await (plugin == null ? void 0 : plugin.addNewTexts(
166
- keys.map((key) => ({ text: key.text, module: `resources.${key.ns}` })),
165
+ keys.map((key) => ({ text: key.text, module: plugin.normalizeResourceModule(key.ns) })),
167
166
  {
168
167
  locale: currentLocale
169
168
  }
@@ -0,0 +1,14 @@
1
+ /**
2
+ * This file is part of the NocoBase (R) project.
3
+ * Copyright (c) 2020-2024 NocoBase Co., Ltd.
4
+ * Authors: NocoBase Team.
5
+ *
6
+ * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
+ * For more information, please refer to: https://www.nocobase.com/agreement.
8
+ */
9
+ import { Migration } from '@nocobase/server';
10
+ export default class extends Migration {
11
+ on: string;
12
+ appVersion: string;
13
+ up(): Promise<void>;
14
+ }
@@ -0,0 +1,64 @@
1
+ /**
2
+ * This file is part of the NocoBase (R) project.
3
+ * Copyright (c) 2020-2024 NocoBase Co., Ltd.
4
+ * Authors: NocoBase Team.
5
+ *
6
+ * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
+ * For more information, please refer to: https://www.nocobase.com/agreement.
8
+ */
9
+
10
+ var __defProp = Object.defineProperty;
11
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
12
+ var __getOwnPropNames = Object.getOwnPropertyNames;
13
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
14
+ var __export = (target, all) => {
15
+ for (var name in all)
16
+ __defProp(target, name, { get: all[name], enumerable: true });
17
+ };
18
+ var __copyProps = (to, from, except, desc) => {
19
+ if (from && typeof from === "object" || typeof from === "function") {
20
+ for (let key of __getOwnPropNames(from))
21
+ if (!__hasOwnProp.call(to, key) && key !== except)
22
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
23
+ }
24
+ return to;
25
+ };
26
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
27
+ var delete_official_plugin_package_resource_modules_exports = {};
28
+ __export(delete_official_plugin_package_resource_modules_exports, {
29
+ default: () => delete_official_plugin_package_resource_modules_default
30
+ });
31
+ module.exports = __toCommonJS(delete_official_plugin_package_resource_modules_exports);
32
+ var import_database = require("@nocobase/database");
33
+ var import_server = require("@nocobase/server");
34
+ class delete_official_plugin_package_resource_modules_default extends import_server.Migration {
35
+ on = "afterLoad";
36
+ // 'beforeLoad' or 'afterLoad'
37
+ appVersion = "<2.2.0";
38
+ async up() {
39
+ const textRepo = this.db.getRepository("localizationTexts");
40
+ const translationRepo = this.db.getRepository("localizationTranslations");
41
+ const texts = await textRepo.find({
42
+ filter: {
43
+ module: {
44
+ [import_database.Op.like]: `resources.${import_server.OFFICIAL_PLUGIN_PREFIX}%`
45
+ }
46
+ },
47
+ fields: ["id"]
48
+ });
49
+ const textIds = texts.map((text) => text.get("id"));
50
+ if (!textIds.length) {
51
+ return;
52
+ }
53
+ await translationRepo.destroy({
54
+ filter: {
55
+ textId: {
56
+ $in: textIds
57
+ }
58
+ }
59
+ });
60
+ await textRepo.destroy({
61
+ filterByTk: textIds
62
+ });
63
+ }
64
+ }
@@ -9,10 +9,11 @@
9
9
  /// <reference types="node" />
10
10
  import { InstallOptions, Plugin } from '@nocobase/server';
11
11
  import Resources from './resources';
12
- import { SourceManager } from './source-manager';
13
12
  export declare class PluginLocalizationServer extends Plugin {
14
13
  resources: Resources;
15
- sourceManager: SourceManager;
14
+ private aiTranslateTaskRegistered;
15
+ private localeSourceTextHookKeys;
16
+ normalizeResourceModule(module: string): string;
16
17
  addNewTexts: (texts: {
17
18
  text: string;
18
19
  module: string;
@@ -22,7 +23,9 @@ export declare class PluginLocalizationServer extends Plugin {
22
23
  }) => Promise<void>;
23
24
  afterAdd(): void;
24
25
  beforeLoad(): void;
26
+ private registerAITranslateTaskType;
25
27
  load(): Promise<void>;
28
+ private handleLocaleSourceTextsSaved;
26
29
  handleSyncMessage(message: any): Promise<void>;
27
30
  install(options?: InstallOptions): Promise<void>;
28
31
  afterEnable(): Promise<void>;