@vocab/vite 0.3.9 → 1.0.0
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.
- package/dist/README.md +11 -0
- package/dist/index.cjs +2 -6
- package/dist/index.cjs.map +1 -1
- package/dist/index.mjs +2 -6
- package/dist/index.mjs.map +1 -1
- package/package.json +2 -2
package/dist/README.md
CHANGED
|
@@ -732,6 +732,17 @@ This flag accepts an array of glob patterns to ignore.
|
|
|
732
732
|
vocab push --branch my-branch --ignore "**/dist/**" "**/another_ignored_directory/**"
|
|
733
733
|
```
|
|
734
734
|
|
|
735
|
+
#### Auto-Translation
|
|
736
|
+
|
|
737
|
+
By default, Phrase may not apply the project's automatic translation behaviour for new keys uploaded via API.
|
|
738
|
+
|
|
739
|
+
The `--auto-translate` flag instructs Phrase to automatically translate any missing keys using machine translation.. See [Phrase auto-translate API Documentation] for more information.
|
|
740
|
+
|
|
741
|
+
```sh
|
|
742
|
+
vocab push --branch my-branch --auto-translate
|
|
743
|
+
```
|
|
744
|
+
|
|
745
|
+
[Phrase auto-translate API Documentation]: https://developers.phrase.com/en/api/strings/uploads/upload-a-new-file#body-autotranslate
|
|
735
746
|
[phrase]: https://developers.phrase.com/api/
|
|
736
747
|
|
|
737
748
|
#### [Tags]
|
package/dist/index.cjs
CHANGED
|
@@ -77,25 +77,21 @@ const virtualResourceLoader = (path) => Buffer.from(path.split(sourceQueryKey)[1
|
|
|
77
77
|
//#endregion
|
|
78
78
|
//#region src/index.ts
|
|
79
79
|
const vitePluginVocab = ({ vocabConfig }) => {
|
|
80
|
-
let isSSR = false;
|
|
81
80
|
require_logger.trace(`Creating Vocab plugin${vocabConfig ? ` with config file ${vocabConfig}` : ""}`);
|
|
82
81
|
return {
|
|
83
82
|
name: "vite-plugin-vocab",
|
|
84
83
|
apply: "build",
|
|
85
84
|
enforce: "pre",
|
|
86
|
-
|
|
87
|
-
|
|
85
|
+
applyToEnvironment(env) {
|
|
86
|
+
return env.name === "client";
|
|
88
87
|
},
|
|
89
88
|
resolveId(id) {
|
|
90
|
-
if (isSSR) return null;
|
|
91
89
|
if (id.includes(virtualModuleId)) return `\0${id}`;
|
|
92
90
|
},
|
|
93
91
|
load(id) {
|
|
94
|
-
if (isSSR) return null;
|
|
95
92
|
if (id.includes(`\0${virtualModuleId}`)) return virtualResourceLoader(id);
|
|
96
93
|
},
|
|
97
94
|
async transform(code, id) {
|
|
98
|
-
if (isSSR) return null;
|
|
99
95
|
if (compiledVocabFileFilter.test(id)) return {
|
|
100
96
|
code: await transformVocabFile(code, id, vocabConfig),
|
|
101
97
|
map: null
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","names":["_compiledVocabFileFilter","_trace","exports","esModuleLexer","cjsModuleLexer","langJson: TranslationMessagesByKey"],"sources":["../src/consts.ts","../src/transform-vocab-file.ts","../src/virtual-resource-loader.ts","../src/index.ts"],"sourcesContent":["import { compiledVocabFileFilter as _compiledVocabFileFilter } from '@vocab/core';\n\n/**\n * @deprecated Import from `@vocab/core` instead\n */\nexport const compiledVocabFileFilter = _compiledVocabFileFilter;\nexport const virtualModuleId = 'virtual:vocab';\nexport const sourceQueryKey = '?source=';\n","import {\n getDevLanguageFileFromTsFile,\n type LoadedTranslation,\n loadTranslation,\n type TranslationMessagesByKey,\n type UserConfig,\n} from '@vocab/core';\n\nimport * as esModuleLexer from 'es-module-lexer';\nimport * as cjsModuleLexer from 'cjs-module-lexer';\n\nimport { sourceQueryKey, virtualModuleId } from './consts';\n\nimport { trace as _trace } from './logger';\n\nconst trace = _trace.extend('transform');\n\nfunction findExportNames(source: string, mode: 'cjs'): string[];\nfunction findExportNames(\n source: string,\n mode: 'esm',\n): esModuleLexer.ExportSpecifier[];\nfunction findExportNames(source: string, mode: 'cjs' | 'esm') {\n if (mode === 'esm') {\n const [, exports] = esModuleLexer.parse(source);\n return exports;\n }\n const { exports } = cjsModuleLexer.parse(source);\n return exports;\n}\n\nexport const transformVocabFile = async (\n code: string,\n id: string,\n config: UserConfig,\n) => {\n trace('Transforming vocab file', id);\n\n let result = code;\n\n const devJsonFilePath = getDevLanguageFileFromTsFile(id);\n\n const loadedTranslation = loadTranslation(\n { filePath: devJsonFilePath, fallbacks: 'all' },\n config,\n );\n\n const renderLanguageLoader = renderLanguageLoaderAsync(loadedTranslation);\n\n const translations = /* ts */ `\n const translations = createTranslationFile({\n ${Object.keys(loadedTranslation.languages)\n .map((lang) => `${JSON.stringify(lang)}: ${renderLanguageLoader(lang)}`)\n .join(',\\n')}\n });\n `;\n\n await esModuleLexer.init;\n const esmExports = findExportNames(code, 'esm');\n if (esmExports.length > 0) {\n const exportName = esmExports[0];\n trace(`Found ESM export '${exportName.n}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n export { translations as ${exportName.n} };\n `;\n } else {\n // init needs to be called and waited upon\n await cjsModuleLexer.init();\n\n const exportName = findExportNames(code, 'cjs')[0];\n trace(`Found CJS export '${exportName}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n exports.${exportName} = translations;\n `;\n }\n trace('Created translation file', result);\n\n return result;\n};\n\nconst renderLanguageLoaderAsync =\n (loadedTranslation: LoadedTranslation) => (lang: string) => {\n const identifier = JSON.stringify(\n createIdentifier(lang, loadedTranslation),\n );\n\n return /* ts */ `createLanguage(() => import(${identifier}))`.trim();\n };\n\nconst createIdentifier = (\n lang: string,\n loadedTranslation: LoadedTranslation,\n) => {\n const languageTranslations = loadedTranslation.languages[lang] ?? {};\n\n const langJson: TranslationMessagesByKey = {};\n\n for (const key of loadedTranslation.keys) {\n langJson[key] = languageTranslations[key].message;\n }\n\n const base64 = Buffer.from(JSON.stringify(langJson), 'utf-8').toString(\n 'base64',\n );\n\n const encodedResource = `${sourceQueryKey}${base64}`;\n\n return `${virtualModuleId}-${lang}.json${encodedResource}`;\n};\n","import { sourceQueryKey } from './consts';\n\nexport const virtualResourceLoader = (path: string) =>\n Buffer.from(path.split(sourceQueryKey)[1] as string, 'base64').toString(\n 'utf-8',\n );\n","import type { Plugin as VitePlugin } from 'vite';\nimport type { UserConfig } from '@vocab/core';\n\nimport { transformVocabFile } from './transform-vocab-file';\nimport { virtualResourceLoader } from './virtual-resource-loader';\n\nimport { trace } from './logger';\n\nimport { compiledVocabFileFilter, virtualModuleId } from './consts';\n\nexport type VocabPluginOptions = {\n vocabConfig: UserConfig;\n};\n\nexport const vitePluginVocab = ({\n vocabConfig,\n}: VocabPluginOptions): VitePlugin => {\n
|
|
1
|
+
{"version":3,"file":"index.cjs","names":["_compiledVocabFileFilter","_trace","exports","esModuleLexer","cjsModuleLexer","langJson: TranslationMessagesByKey"],"sources":["../src/consts.ts","../src/transform-vocab-file.ts","../src/virtual-resource-loader.ts","../src/index.ts"],"sourcesContent":["import { compiledVocabFileFilter as _compiledVocabFileFilter } from '@vocab/core';\n\n/**\n * @deprecated Import from `@vocab/core` instead\n */\nexport const compiledVocabFileFilter = _compiledVocabFileFilter;\nexport const virtualModuleId = 'virtual:vocab';\nexport const sourceQueryKey = '?source=';\n","import {\n getDevLanguageFileFromTsFile,\n type LoadedTranslation,\n loadTranslation,\n type TranslationMessagesByKey,\n type UserConfig,\n} from '@vocab/core';\n\nimport * as esModuleLexer from 'es-module-lexer';\nimport * as cjsModuleLexer from 'cjs-module-lexer';\n\nimport { sourceQueryKey, virtualModuleId } from './consts';\n\nimport { trace as _trace } from './logger';\n\nconst trace = _trace.extend('transform');\n\nfunction findExportNames(source: string, mode: 'cjs'): string[];\nfunction findExportNames(\n source: string,\n mode: 'esm',\n): esModuleLexer.ExportSpecifier[];\nfunction findExportNames(source: string, mode: 'cjs' | 'esm') {\n if (mode === 'esm') {\n const [, exports] = esModuleLexer.parse(source);\n return exports;\n }\n const { exports } = cjsModuleLexer.parse(source);\n return exports;\n}\n\nexport const transformVocabFile = async (\n code: string,\n id: string,\n config: UserConfig,\n) => {\n trace('Transforming vocab file', id);\n\n let result = code;\n\n const devJsonFilePath = getDevLanguageFileFromTsFile(id);\n\n const loadedTranslation = loadTranslation(\n { filePath: devJsonFilePath, fallbacks: 'all' },\n config,\n );\n\n const renderLanguageLoader = renderLanguageLoaderAsync(loadedTranslation);\n\n const translations = /* ts */ `\n const translations = createTranslationFile({\n ${Object.keys(loadedTranslation.languages)\n .map((lang) => `${JSON.stringify(lang)}: ${renderLanguageLoader(lang)}`)\n .join(',\\n')}\n });\n `;\n\n await esModuleLexer.init;\n const esmExports = findExportNames(code, 'esm');\n if (esmExports.length > 0) {\n const exportName = esmExports[0];\n trace(`Found ESM export '${exportName.n}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n export { translations as ${exportName.n} };\n `;\n } else {\n // init needs to be called and waited upon\n await cjsModuleLexer.init();\n\n const exportName = findExportNames(code, 'cjs')[0];\n trace(`Found CJS export '${exportName}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n exports.${exportName} = translations;\n `;\n }\n trace('Created translation file', result);\n\n return result;\n};\n\nconst renderLanguageLoaderAsync =\n (loadedTranslation: LoadedTranslation) => (lang: string) => {\n const identifier = JSON.stringify(\n createIdentifier(lang, loadedTranslation),\n );\n\n return /* ts */ `createLanguage(() => import(${identifier}))`.trim();\n };\n\nconst createIdentifier = (\n lang: string,\n loadedTranslation: LoadedTranslation,\n) => {\n const languageTranslations = loadedTranslation.languages[lang] ?? {};\n\n const langJson: TranslationMessagesByKey = {};\n\n for (const key of loadedTranslation.keys) {\n langJson[key] = languageTranslations[key].message;\n }\n\n const base64 = Buffer.from(JSON.stringify(langJson), 'utf-8').toString(\n 'base64',\n );\n\n const encodedResource = `${sourceQueryKey}${base64}`;\n\n return `${virtualModuleId}-${lang}.json${encodedResource}`;\n};\n","import { sourceQueryKey } from './consts';\n\nexport const virtualResourceLoader = (path: string) =>\n Buffer.from(path.split(sourceQueryKey)[1] as string, 'base64').toString(\n 'utf-8',\n );\n","import type { Plugin as VitePlugin } from 'vite';\nimport type { UserConfig } from '@vocab/core';\n\nimport { transformVocabFile } from './transform-vocab-file';\nimport { virtualResourceLoader } from './virtual-resource-loader';\n\nimport { trace } from './logger';\n\nimport { compiledVocabFileFilter, virtualModuleId } from './consts';\n\nexport type VocabPluginOptions = {\n vocabConfig: UserConfig;\n};\n\nexport const vitePluginVocab = ({\n vocabConfig,\n}: VocabPluginOptions): VitePlugin => {\n trace(\n `Creating Vocab plugin${\n vocabConfig ? ` with config file ${vocabConfig}` : ''\n }`,\n );\n\n return {\n name: 'vite-plugin-vocab',\n apply: 'build',\n enforce: 'pre',\n applyToEnvironment(env) {\n return env.name === 'client';\n },\n resolveId(id) {\n if (id.includes(virtualModuleId)) {\n return `\\0${id}`;\n }\n },\n load(id) {\n if (id.includes(`\\0${virtualModuleId}`)) {\n return virtualResourceLoader(id);\n }\n },\n async transform(code, id) {\n if (compiledVocabFileFilter.test(id)) {\n const transformedCode = await transformVocabFile(code, id, vocabConfig);\n\n return {\n code: transformedCode,\n map: null, // provide source map if available\n };\n }\n },\n };\n};\n"],"mappings":";;;;;;;;;;;AAKA,MAAa,0BAA0BA;AACvC,MAAa,kBAAkB;AAC/B,MAAa,iBAAiB;;;;ACQ9B,MAAM,QAAQC,qBAAO,OAAO,YAAY;AAOxC,SAAS,gBAAgB,QAAgB,MAAqB;AAC5D,KAAI,SAAS,OAAO;EAClB,MAAM,GAAGC,aAAWC,gBAAc,MAAM,OAAO;AAC/C,SAAOD;;CAET,MAAM,EAAE,uBAAYE,iBAAe,MAAM,OAAO;AAChD,QAAOF;;AAGT,MAAa,qBAAqB,OAChC,MACA,IACA,WACG;AACH,OAAM,2BAA2B,GAAG;CAEpC,IAAI,SAAS;CAIb,MAAM,qDACJ;EAAE,wDAHiD,GAAG;EAGzB,WAAW;EAAO,EAC/C,OACD;CAED,MAAM,uBAAuB,0BAA0B,kBAAkB;CAEzE,MAAM,eAAwB;;QAExB,OAAO,KAAK,kBAAkB,UAAU,CACvC,KAAK,SAAS,GAAG,KAAK,UAAU,KAAK,CAAC,IAAI,qBAAqB,KAAK,GAAG,CACvE,KAAK,MAAM,CAAC;;;AAInB,OAAMC,gBAAc;CACpB,MAAM,aAAa,gBAAgB,MAAM,MAAM;AAC/C,KAAI,WAAW,SAAS,GAAG;EACzB,MAAM,aAAa,WAAW;AAC9B,QAAM,qBAAqB,WAAW,EAAE,OAAO,KAAK;AAEpD,WAAkB;;QAEd,aAAa;iCACY,WAAW,EAAE;;QAErC;AAEL,QAAMC,iBAAe,MAAM;EAE3B,MAAM,aAAa,gBAAgB,MAAM,MAAM,CAAC;AAChD,QAAM,qBAAqB,WAAW,OAAO,KAAK;AAElD,WAAkB;;QAEd,aAAa;gBACL,WAAW;;;AAGzB,OAAM,4BAA4B,OAAO;AAEzC,QAAO;;AAGT,MAAM,6BACH,uBAA0C,SAAiB;AAK1D,QAAgB,+BAJG,KAAK,UACtB,iBAAiB,MAAM,kBAAkB,CAC1C,CAEyD,IAAI,MAAM;;AAGxE,MAAM,oBACJ,MACA,sBACG;CACH,MAAM,uBAAuB,kBAAkB,UAAU,SAAS,EAAE;CAEpE,MAAMC,WAAqC,EAAE;AAE7C,MAAK,MAAM,OAAO,kBAAkB,KAClC,UAAS,OAAO,qBAAqB,KAAK;AAS5C,QAAO,GAAG,gBAAgB,GAAG,KAAK,OAFV,GAAG,iBAJZ,OAAO,KAAK,KAAK,UAAU,SAAS,EAAE,QAAQ,CAAC,SAC5D,SACD;;;;;AC3GH,MAAa,yBAAyB,SACpC,OAAO,KAAK,KAAK,MAAM,eAAe,CAAC,IAAc,SAAS,CAAC,SAC7D,QACD;;;;ACSH,MAAa,mBAAmB,EAC9B,kBACoC;AACpC,sBACE,wBACE,cAAc,qBAAqB,gBAAgB,KAEtD;AAED,QAAO;EACL,MAAM;EACN,OAAO;EACP,SAAS;EACT,mBAAmB,KAAK;AACtB,UAAO,IAAI,SAAS;;EAEtB,UAAU,IAAI;AACZ,OAAI,GAAG,SAAS,gBAAgB,CAC9B,QAAO,KAAK;;EAGhB,KAAK,IAAI;AACP,OAAI,GAAG,SAAS,KAAK,kBAAkB,CACrC,QAAO,sBAAsB,GAAG;;EAGpC,MAAM,UAAU,MAAM,IAAI;AACxB,OAAI,wBAAwB,KAAK,GAAG,CAGlC,QAAO;IACL,MAHsB,MAAM,mBAAmB,MAAM,IAAI,YAAY;IAIrE,KAAK;IACN;;EAGN"}
|
package/dist/index.mjs
CHANGED
|
@@ -75,25 +75,21 @@ const virtualResourceLoader = (path) => Buffer.from(path.split(sourceQueryKey)[1
|
|
|
75
75
|
//#endregion
|
|
76
76
|
//#region src/index.ts
|
|
77
77
|
const vitePluginVocab = ({ vocabConfig }) => {
|
|
78
|
-
let isSSR = false;
|
|
79
78
|
trace$1(`Creating Vocab plugin${vocabConfig ? ` with config file ${vocabConfig}` : ""}`);
|
|
80
79
|
return {
|
|
81
80
|
name: "vite-plugin-vocab",
|
|
82
81
|
apply: "build",
|
|
83
82
|
enforce: "pre",
|
|
84
|
-
|
|
85
|
-
|
|
83
|
+
applyToEnvironment(env) {
|
|
84
|
+
return env.name === "client";
|
|
86
85
|
},
|
|
87
86
|
resolveId(id) {
|
|
88
|
-
if (isSSR) return null;
|
|
89
87
|
if (id.includes(virtualModuleId)) return `\0${id}`;
|
|
90
88
|
},
|
|
91
89
|
load(id) {
|
|
92
|
-
if (isSSR) return null;
|
|
93
90
|
if (id.includes(`\0${virtualModuleId}`)) return virtualResourceLoader(id);
|
|
94
91
|
},
|
|
95
92
|
async transform(code, id) {
|
|
96
|
-
if (isSSR) return null;
|
|
97
93
|
if (compiledVocabFileFilter$1.test(id)) return {
|
|
98
94
|
code: await transformVocabFile(code, id, vocabConfig),
|
|
99
95
|
map: null
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","names":["compiledVocabFileFilter","_compiledVocabFileFilter","_trace","exports","langJson: TranslationMessagesByKey","compiledVocabFileFilter"],"sources":["../src/consts.ts","../src/transform-vocab-file.ts","../src/virtual-resource-loader.ts","../src/index.ts"],"sourcesContent":["import { compiledVocabFileFilter as _compiledVocabFileFilter } from '@vocab/core';\n\n/**\n * @deprecated Import from `@vocab/core` instead\n */\nexport const compiledVocabFileFilter = _compiledVocabFileFilter;\nexport const virtualModuleId = 'virtual:vocab';\nexport const sourceQueryKey = '?source=';\n","import {\n getDevLanguageFileFromTsFile,\n type LoadedTranslation,\n loadTranslation,\n type TranslationMessagesByKey,\n type UserConfig,\n} from '@vocab/core';\n\nimport * as esModuleLexer from 'es-module-lexer';\nimport * as cjsModuleLexer from 'cjs-module-lexer';\n\nimport { sourceQueryKey, virtualModuleId } from './consts';\n\nimport { trace as _trace } from './logger';\n\nconst trace = _trace.extend('transform');\n\nfunction findExportNames(source: string, mode: 'cjs'): string[];\nfunction findExportNames(\n source: string,\n mode: 'esm',\n): esModuleLexer.ExportSpecifier[];\nfunction findExportNames(source: string, mode: 'cjs' | 'esm') {\n if (mode === 'esm') {\n const [, exports] = esModuleLexer.parse(source);\n return exports;\n }\n const { exports } = cjsModuleLexer.parse(source);\n return exports;\n}\n\nexport const transformVocabFile = async (\n code: string,\n id: string,\n config: UserConfig,\n) => {\n trace('Transforming vocab file', id);\n\n let result = code;\n\n const devJsonFilePath = getDevLanguageFileFromTsFile(id);\n\n const loadedTranslation = loadTranslation(\n { filePath: devJsonFilePath, fallbacks: 'all' },\n config,\n );\n\n const renderLanguageLoader = renderLanguageLoaderAsync(loadedTranslation);\n\n const translations = /* ts */ `\n const translations = createTranslationFile({\n ${Object.keys(loadedTranslation.languages)\n .map((lang) => `${JSON.stringify(lang)}: ${renderLanguageLoader(lang)}`)\n .join(',\\n')}\n });\n `;\n\n await esModuleLexer.init;\n const esmExports = findExportNames(code, 'esm');\n if (esmExports.length > 0) {\n const exportName = esmExports[0];\n trace(`Found ESM export '${exportName.n}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n export { translations as ${exportName.n} };\n `;\n } else {\n // init needs to be called and waited upon\n await cjsModuleLexer.init();\n\n const exportName = findExportNames(code, 'cjs')[0];\n trace(`Found CJS export '${exportName}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n exports.${exportName} = translations;\n `;\n }\n trace('Created translation file', result);\n\n return result;\n};\n\nconst renderLanguageLoaderAsync =\n (loadedTranslation: LoadedTranslation) => (lang: string) => {\n const identifier = JSON.stringify(\n createIdentifier(lang, loadedTranslation),\n );\n\n return /* ts */ `createLanguage(() => import(${identifier}))`.trim();\n };\n\nconst createIdentifier = (\n lang: string,\n loadedTranslation: LoadedTranslation,\n) => {\n const languageTranslations = loadedTranslation.languages[lang] ?? {};\n\n const langJson: TranslationMessagesByKey = {};\n\n for (const key of loadedTranslation.keys) {\n langJson[key] = languageTranslations[key].message;\n }\n\n const base64 = Buffer.from(JSON.stringify(langJson), 'utf-8').toString(\n 'base64',\n );\n\n const encodedResource = `${sourceQueryKey}${base64}`;\n\n return `${virtualModuleId}-${lang}.json${encodedResource}`;\n};\n","import { sourceQueryKey } from './consts';\n\nexport const virtualResourceLoader = (path: string) =>\n Buffer.from(path.split(sourceQueryKey)[1] as string, 'base64').toString(\n 'utf-8',\n );\n","import type { Plugin as VitePlugin } from 'vite';\nimport type { UserConfig } from '@vocab/core';\n\nimport { transformVocabFile } from './transform-vocab-file';\nimport { virtualResourceLoader } from './virtual-resource-loader';\n\nimport { trace } from './logger';\n\nimport { compiledVocabFileFilter, virtualModuleId } from './consts';\n\nexport type VocabPluginOptions = {\n vocabConfig: UserConfig;\n};\n\nexport const vitePluginVocab = ({\n vocabConfig,\n}: VocabPluginOptions): VitePlugin => {\n
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["compiledVocabFileFilter","_compiledVocabFileFilter","_trace","exports","langJson: TranslationMessagesByKey","compiledVocabFileFilter"],"sources":["../src/consts.ts","../src/transform-vocab-file.ts","../src/virtual-resource-loader.ts","../src/index.ts"],"sourcesContent":["import { compiledVocabFileFilter as _compiledVocabFileFilter } from '@vocab/core';\n\n/**\n * @deprecated Import from `@vocab/core` instead\n */\nexport const compiledVocabFileFilter = _compiledVocabFileFilter;\nexport const virtualModuleId = 'virtual:vocab';\nexport const sourceQueryKey = '?source=';\n","import {\n getDevLanguageFileFromTsFile,\n type LoadedTranslation,\n loadTranslation,\n type TranslationMessagesByKey,\n type UserConfig,\n} from '@vocab/core';\n\nimport * as esModuleLexer from 'es-module-lexer';\nimport * as cjsModuleLexer from 'cjs-module-lexer';\n\nimport { sourceQueryKey, virtualModuleId } from './consts';\n\nimport { trace as _trace } from './logger';\n\nconst trace = _trace.extend('transform');\n\nfunction findExportNames(source: string, mode: 'cjs'): string[];\nfunction findExportNames(\n source: string,\n mode: 'esm',\n): esModuleLexer.ExportSpecifier[];\nfunction findExportNames(source: string, mode: 'cjs' | 'esm') {\n if (mode === 'esm') {\n const [, exports] = esModuleLexer.parse(source);\n return exports;\n }\n const { exports } = cjsModuleLexer.parse(source);\n return exports;\n}\n\nexport const transformVocabFile = async (\n code: string,\n id: string,\n config: UserConfig,\n) => {\n trace('Transforming vocab file', id);\n\n let result = code;\n\n const devJsonFilePath = getDevLanguageFileFromTsFile(id);\n\n const loadedTranslation = loadTranslation(\n { filePath: devJsonFilePath, fallbacks: 'all' },\n config,\n );\n\n const renderLanguageLoader = renderLanguageLoaderAsync(loadedTranslation);\n\n const translations = /* ts */ `\n const translations = createTranslationFile({\n ${Object.keys(loadedTranslation.languages)\n .map((lang) => `${JSON.stringify(lang)}: ${renderLanguageLoader(lang)}`)\n .join(',\\n')}\n });\n `;\n\n await esModuleLexer.init;\n const esmExports = findExportNames(code, 'esm');\n if (esmExports.length > 0) {\n const exportName = esmExports[0];\n trace(`Found ESM export '${exportName.n}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n export { translations as ${exportName.n} };\n `;\n } else {\n // init needs to be called and waited upon\n await cjsModuleLexer.init();\n\n const exportName = findExportNames(code, 'cjs')[0];\n trace(`Found CJS export '${exportName}' in ${id}`);\n\n result = /* ts */ `\n import { createLanguage, createTranslationFile } from '@vocab/vite/runtime';\n ${translations}\n exports.${exportName} = translations;\n `;\n }\n trace('Created translation file', result);\n\n return result;\n};\n\nconst renderLanguageLoaderAsync =\n (loadedTranslation: LoadedTranslation) => (lang: string) => {\n const identifier = JSON.stringify(\n createIdentifier(lang, loadedTranslation),\n );\n\n return /* ts */ `createLanguage(() => import(${identifier}))`.trim();\n };\n\nconst createIdentifier = (\n lang: string,\n loadedTranslation: LoadedTranslation,\n) => {\n const languageTranslations = loadedTranslation.languages[lang] ?? {};\n\n const langJson: TranslationMessagesByKey = {};\n\n for (const key of loadedTranslation.keys) {\n langJson[key] = languageTranslations[key].message;\n }\n\n const base64 = Buffer.from(JSON.stringify(langJson), 'utf-8').toString(\n 'base64',\n );\n\n const encodedResource = `${sourceQueryKey}${base64}`;\n\n return `${virtualModuleId}-${lang}.json${encodedResource}`;\n};\n","import { sourceQueryKey } from './consts';\n\nexport const virtualResourceLoader = (path: string) =>\n Buffer.from(path.split(sourceQueryKey)[1] as string, 'base64').toString(\n 'utf-8',\n );\n","import type { Plugin as VitePlugin } from 'vite';\nimport type { UserConfig } from '@vocab/core';\n\nimport { transformVocabFile } from './transform-vocab-file';\nimport { virtualResourceLoader } from './virtual-resource-loader';\n\nimport { trace } from './logger';\n\nimport { compiledVocabFileFilter, virtualModuleId } from './consts';\n\nexport type VocabPluginOptions = {\n vocabConfig: UserConfig;\n};\n\nexport const vitePluginVocab = ({\n vocabConfig,\n}: VocabPluginOptions): VitePlugin => {\n trace(\n `Creating Vocab plugin${\n vocabConfig ? ` with config file ${vocabConfig}` : ''\n }`,\n );\n\n return {\n name: 'vite-plugin-vocab',\n apply: 'build',\n enforce: 'pre',\n applyToEnvironment(env) {\n return env.name === 'client';\n },\n resolveId(id) {\n if (id.includes(virtualModuleId)) {\n return `\\0${id}`;\n }\n },\n load(id) {\n if (id.includes(`\\0${virtualModuleId}`)) {\n return virtualResourceLoader(id);\n }\n },\n async transform(code, id) {\n if (compiledVocabFileFilter.test(id)) {\n const transformedCode = await transformVocabFile(code, id, vocabConfig);\n\n return {\n code: transformedCode,\n map: null, // provide source map if available\n };\n }\n },\n };\n};\n"],"mappings":";;;;;;;;;AAKA,MAAaA,4BAA0BC;AACvC,MAAa,kBAAkB;AAC/B,MAAa,iBAAiB;;;;ACQ9B,MAAM,QAAQC,QAAO,OAAO,YAAY;AAOxC,SAAS,gBAAgB,QAAgB,MAAqB;AAC5D,KAAI,SAAS,OAAO;EAClB,MAAM,GAAGC,aAAW,cAAc,MAAM,OAAO;AAC/C,SAAOA;;CAET,MAAM,EAAE,YAAY,eAAe,MAAM,OAAO;AAChD,QAAO;;AAGT,MAAa,qBAAqB,OAChC,MACA,IACA,WACG;AACH,OAAM,2BAA2B,GAAG;CAEpC,IAAI,SAAS;CAIb,MAAM,oBAAoB,gBACxB;EAAE,UAHoB,6BAA6B,GAAG;EAGzB,WAAW;EAAO,EAC/C,OACD;CAED,MAAM,uBAAuB,0BAA0B,kBAAkB;CAEzE,MAAM,eAAwB;;QAExB,OAAO,KAAK,kBAAkB,UAAU,CACvC,KAAK,SAAS,GAAG,KAAK,UAAU,KAAK,CAAC,IAAI,qBAAqB,KAAK,GAAG,CACvE,KAAK,MAAM,CAAC;;;AAInB,OAAM,cAAc;CACpB,MAAM,aAAa,gBAAgB,MAAM,MAAM;AAC/C,KAAI,WAAW,SAAS,GAAG;EACzB,MAAM,aAAa,WAAW;AAC9B,QAAM,qBAAqB,WAAW,EAAE,OAAO,KAAK;AAEpD,WAAkB;;QAEd,aAAa;iCACY,WAAW,EAAE;;QAErC;AAEL,QAAM,eAAe,MAAM;EAE3B,MAAM,aAAa,gBAAgB,MAAM,MAAM,CAAC;AAChD,QAAM,qBAAqB,WAAW,OAAO,KAAK;AAElD,WAAkB;;QAEd,aAAa;gBACL,WAAW;;;AAGzB,OAAM,4BAA4B,OAAO;AAEzC,QAAO;;AAGT,MAAM,6BACH,uBAA0C,SAAiB;AAK1D,QAAgB,+BAJG,KAAK,UACtB,iBAAiB,MAAM,kBAAkB,CAC1C,CAEyD,IAAI,MAAM;;AAGxE,MAAM,oBACJ,MACA,sBACG;CACH,MAAM,uBAAuB,kBAAkB,UAAU,SAAS,EAAE;CAEpE,MAAMC,WAAqC,EAAE;AAE7C,MAAK,MAAM,OAAO,kBAAkB,KAClC,UAAS,OAAO,qBAAqB,KAAK;AAS5C,QAAO,GAAG,gBAAgB,GAAG,KAAK,OAFV,GAAG,iBAJZ,OAAO,KAAK,KAAK,UAAU,SAAS,EAAE,QAAQ,CAAC,SAC5D,SACD;;;;;AC3GH,MAAa,yBAAyB,SACpC,OAAO,KAAK,KAAK,MAAM,eAAe,CAAC,IAAc,SAAS,CAAC,SAC7D,QACD;;;;ACSH,MAAa,mBAAmB,EAC9B,kBACoC;AACpC,SACE,wBACE,cAAc,qBAAqB,gBAAgB,KAEtD;AAED,QAAO;EACL,MAAM;EACN,OAAO;EACP,SAAS;EACT,mBAAmB,KAAK;AACtB,UAAO,IAAI,SAAS;;EAEtB,UAAU,IAAI;AACZ,OAAI,GAAG,SAAS,gBAAgB,CAC9B,QAAO,KAAK;;EAGhB,KAAK,IAAI;AACP,OAAI,GAAG,SAAS,KAAK,kBAAkB,CACrC,QAAO,sBAAsB,GAAG;;EAGpC,MAAM,UAAU,MAAM,IAAI;AACxB,OAAIC,0BAAwB,KAAK,GAAG,CAGlC,QAAO;IACL,MAHsB,MAAM,mBAAmB,MAAM,IAAI,YAAY;IAIrE,KAAK;IACN;;EAGN"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vocab/vite",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "1.0.0",
|
|
4
4
|
"author": "SEEK",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -45,6 +45,6 @@
|
|
|
45
45
|
"vite": "^7.0.6"
|
|
46
46
|
},
|
|
47
47
|
"peerDependencies": {
|
|
48
|
-
"vite": "^
|
|
48
|
+
"vite": "^6.0.0 || ^7.0.0"
|
|
49
49
|
}
|
|
50
50
|
}
|