mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-01-26 19:09:52 +00:00
## Summary Extracts shared formatting and network utilities into dedicated workspace package. ## Changes - **What**: Created `@comfyorg/shared-frontend-utils` package containing formatUtil and networkUtil - **Breaking**: None - utilities remain accessible via path aliases in `tsconfig` Split `createAnnotatedPath` and `electronMirrorCheck` out and left in frontend, due to their tightly-coupled nature. See [discussion on this PR](https://github.com/Comfy-Org/ComfyUI_frontend/pull/5843#issuecomment-3344724727).
179 lines
5.6 KiB
TypeScript
179 lines
5.6 KiB
TypeScript
import * as fs from 'fs'
|
|
|
|
import { comfyPageFixture as test } from '../browser_tests/fixtures/ComfyPage'
|
|
import {
|
|
formatCamelCase,
|
|
normalizeI18nKey
|
|
} from '../packages/shared-frontend-utils/src/formatUtil'
|
|
import { CORE_MENU_COMMANDS } from '../src/constants/coreMenuCommands'
|
|
import { DESKTOP_DIALOGS } from '../src/constants/desktopDialogs'
|
|
import { SERVER_CONFIG_ITEMS } from '../src/constants/serverConfig'
|
|
import type { FormItem, SettingParams } from '../src/platform/settings/types'
|
|
import type { ComfyCommandImpl } from '../src/stores/commandStore'
|
|
|
|
const localePath = './src/locales/en/main.json'
|
|
const commandsPath = './src/locales/en/commands.json'
|
|
const settingsPath = './src/locales/en/settings.json'
|
|
|
|
const extractMenuCommandLocaleStrings = (): Set<string> => {
|
|
const labels = new Set<string>()
|
|
for (const [category, _] of CORE_MENU_COMMANDS) {
|
|
category.forEach((category) => labels.add(category))
|
|
}
|
|
return labels
|
|
}
|
|
|
|
test('collect-i18n-general', async ({ comfyPage }) => {
|
|
const commands = (
|
|
await comfyPage.page.evaluate(() => {
|
|
const workspace = window['app'].extensionManager
|
|
const commands = workspace.command.commands as ComfyCommandImpl[]
|
|
return commands.map((command) => ({
|
|
id: command.id,
|
|
label: command.label,
|
|
menubarLabel: command.menubarLabel,
|
|
tooltip: command.tooltip
|
|
}))
|
|
})
|
|
).sort((a, b) => a.id.localeCompare(b.id))
|
|
|
|
const locale = JSON.parse(fs.readFileSync(localePath, 'utf-8'))
|
|
|
|
// Commands
|
|
const menuLabels = extractMenuCommandLocaleStrings()
|
|
const commandMenuLabels = new Set(
|
|
commands.map((command) => command.menubarLabel ?? command.label ?? '')
|
|
)
|
|
const allLabels = new Set([...menuLabels, ...commandMenuLabels])
|
|
allLabels.delete('')
|
|
|
|
const allLabelsLocale = Object.fromEntries(
|
|
Array.from(allLabels).map((label) => [normalizeI18nKey(label), label])
|
|
)
|
|
|
|
const allCommandsLocale = Object.fromEntries(
|
|
commands.map((command) => [
|
|
normalizeI18nKey(command.id),
|
|
{
|
|
label: command.label,
|
|
tooltip: command.tooltip
|
|
}
|
|
])
|
|
)
|
|
|
|
// Settings
|
|
const settings = await comfyPage.page.evaluate(() => {
|
|
const workspace = window['app'].extensionManager
|
|
const settings = workspace.setting.settings as Record<string, SettingParams>
|
|
return Object.values(settings)
|
|
.sort((a, b) => a.id.localeCompare(b.id))
|
|
.filter((setting) => setting.type !== 'hidden')
|
|
.map((setting) => ({
|
|
id: setting.id,
|
|
name: setting.name,
|
|
tooltip: setting.tooltip,
|
|
category: setting.category,
|
|
options:
|
|
typeof setting.options === 'function'
|
|
? // @ts-expect-error: Audit and deprecate usage of legacy options type:
|
|
// (value) => [string | {text: string, value: string}]
|
|
setting.options(setting.defaultValue ?? '')
|
|
: setting.options
|
|
}))
|
|
})
|
|
|
|
const allSettingsLocale = Object.fromEntries(
|
|
settings.map((setting) => [
|
|
normalizeI18nKey(setting.id),
|
|
{
|
|
name: setting.name,
|
|
tooltip: setting.tooltip,
|
|
// Don't translate the locale options as each option is in its own language.
|
|
// e.g. "English", "中文", "Русский", "日本語", "한국어"
|
|
options:
|
|
setting.options && setting.id !== 'Comfy.Locale'
|
|
? Object.fromEntries(
|
|
setting.options.map((option) => {
|
|
const optionLabel =
|
|
typeof option === 'string' ? option : option.text
|
|
return [normalizeI18nKey(optionLabel), optionLabel]
|
|
})
|
|
)
|
|
: undefined
|
|
}
|
|
])
|
|
)
|
|
|
|
const allSettingCategoriesLocale = Object.fromEntries(
|
|
settings
|
|
.flatMap((setting) => {
|
|
return (setting.category ?? setting.id.split('.')).slice(0, 2)
|
|
})
|
|
.map((category: string) => [
|
|
normalizeI18nKey(category),
|
|
formatCamelCase(category)
|
|
])
|
|
)
|
|
|
|
// Server Configs
|
|
const allServerConfigsLocale = Object.fromEntries(
|
|
SERVER_CONFIG_ITEMS.map((config) => [
|
|
normalizeI18nKey(config.id),
|
|
{
|
|
name: (config as unknown as FormItem).name,
|
|
tooltip: (config as unknown as FormItem).tooltip
|
|
}
|
|
])
|
|
)
|
|
|
|
const allServerConfigCategoriesLocale = Object.fromEntries(
|
|
SERVER_CONFIG_ITEMS.flatMap((config) => {
|
|
return config.category ?? ['General']
|
|
}).map((category) => [
|
|
normalizeI18nKey(category),
|
|
formatCamelCase(category)
|
|
])
|
|
)
|
|
|
|
// Desktop Dialogs
|
|
const allDesktopDialogsLocale = Object.fromEntries(
|
|
Object.values(DESKTOP_DIALOGS).map((dialog) => [
|
|
normalizeI18nKey(dialog.id),
|
|
{
|
|
title: dialog.title,
|
|
message: dialog.message,
|
|
buttons: Object.fromEntries(
|
|
dialog.buttons.map((button) => [
|
|
normalizeI18nKey(button.label),
|
|
button.label
|
|
])
|
|
)
|
|
}
|
|
])
|
|
)
|
|
|
|
fs.writeFileSync(
|
|
localePath,
|
|
JSON.stringify(
|
|
{
|
|
...locale,
|
|
menuLabels: allLabelsLocale,
|
|
// Do merge for settingsCategories as there are some manual translations
|
|
// for special panels like "About" and "Keybinding".
|
|
settingsCategories: {
|
|
...(locale.settingsCategories ?? {}),
|
|
...allSettingCategoriesLocale
|
|
},
|
|
serverConfigItems: allServerConfigsLocale,
|
|
serverConfigCategories: allServerConfigCategoriesLocale,
|
|
desktopDialogs: allDesktopDialogsLocale
|
|
},
|
|
null,
|
|
2
|
|
)
|
|
)
|
|
|
|
fs.writeFileSync(commandsPath, JSON.stringify(allCommandsLocale, null, 2))
|
|
fs.writeFileSync(settingsPath, JSON.stringify(allSettingsLocale, null, 2))
|
|
})
|