@intlayer/config 8.3.0-canary.0 → 8.3.0-canary.2

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 (32) hide show
  1. package/dist/cjs/configFile/buildConfigurationFields.cjs +1 -1
  2. package/dist/cjs/configFile/buildConfigurationFields.cjs.map +1 -1
  3. package/dist/cjs/configFile/configurationSchema.cjs +1 -1
  4. package/dist/cjs/configFile/configurationSchema.cjs.map +1 -1
  5. package/dist/cjs/defaultValues/build.cjs +1 -1
  6. package/dist/cjs/defaultValues/build.cjs.map +1 -1
  7. package/dist/cjs/defaultValues/editor.cjs +1 -1
  8. package/dist/cjs/defaultValues/editor.cjs.map +1 -1
  9. package/dist/cjs/loadExternalFile/loadExternalFile.cjs +1 -1
  10. package/dist/cjs/loadExternalFile/loadExternalFile.cjs.map +1 -1
  11. package/dist/cjs/utils/parseFilePathPattern.cjs +1 -1
  12. package/dist/cjs/utils/parseFilePathPattern.cjs.map +1 -1
  13. package/dist/esm/configFile/buildConfigurationFields.mjs +1 -1
  14. package/dist/esm/configFile/buildConfigurationFields.mjs.map +1 -1
  15. package/dist/esm/configFile/configurationSchema.mjs +1 -1
  16. package/dist/esm/configFile/configurationSchema.mjs.map +1 -1
  17. package/dist/esm/defaultValues/build.mjs +1 -1
  18. package/dist/esm/defaultValues/build.mjs.map +1 -1
  19. package/dist/esm/defaultValues/editor.mjs +1 -1
  20. package/dist/esm/defaultValues/editor.mjs.map +1 -1
  21. package/dist/esm/loadExternalFile/loadExternalFile.mjs +1 -1
  22. package/dist/esm/loadExternalFile/loadExternalFile.mjs.map +1 -1
  23. package/dist/esm/utils/cacheDisk.mjs.map +1 -1
  24. package/dist/esm/utils/parseFilePathPattern.mjs +1 -1
  25. package/dist/esm/utils/parseFilePathPattern.mjs.map +1 -1
  26. package/dist/types/configFile/configurationSchema.d.ts +21 -21
  27. package/dist/types/configFile/configurationSchema.d.ts.map +1 -1
  28. package/dist/types/defaultValues/build.d.ts.map +1 -1
  29. package/dist/types/defaultValues/editor.d.ts +1 -1
  30. package/dist/types/loadExternalFile/loadExternalFile.d.ts +1 -0
  31. package/dist/types/loadExternalFile/loadExternalFile.d.ts.map +1 -1
  32. package/package.json +4 -4
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../defaultValues/build.cjs`);require(`../defaultValues/compiler.cjs`);const n=require(`../defaultValues/content.cjs`);require(`../defaultValues/dictionary.cjs`),require(`../defaultValues/editor.cjs`);const r=require(`../defaultValues/internationalization.cjs`),i=require(`../defaultValues/log.cjs`),a=require(`../defaultValues/routing.cjs`);require(`../defaultValues/system.cjs`);const o=require(`../utils/normalizePath.cjs`),s=require(`../utils/ESMxCJSHelpers.cjs`);let c=require(`node:fs`),l=require(`node:path`),u=require(`@intlayer/types/package.json`);u=e.__toESM(u);let d;const f=e=>({locales:e?.locales??r.LOCALES,requiredLocales:e?.requiredLocales??e?.locales??r.REQUIRED_LOCALES,strictMode:e?.strictMode??`inclusive`,defaultLocale:e?.defaultLocale??r.DEFAULT_LOCALE}),p=e=>({mode:e?.mode??`prefix-no-default`,storage:e?.storage??a.STORAGE,basePath:e?.basePath??``,rewrite:e?.rewrite}),m=(e,t)=>{let n=e??process.cwd(),r=e=>{let t;try{t=s.getProjectRequire(n).resolve(e,{paths:[n]})}catch{t=(0,l.isAbsolute)(e)?e:(0,l.join)(n,e)}try{if((0,c.statSync)(t).isFile())return(0,l.dirname)(t)}catch{if(/\.[a-z0-9]+$/i.test(t))return(0,l.dirname)(t)}return t},i=r(t?.dictionariesDir??`.intlayer/dictionary`);return{baseDir:n,moduleAugmentationDir:r(t?.moduleAugmentationDir??`.intlayer/types`),unmergedDictionariesDir:r(t?.unmergedDictionariesDir??`.intlayer/unmerged_dictionary`),remoteDictionariesDir:r(t?.remoteDictionariesDir??`.intlayer/remote_dictionary`),dictionariesDir:i,dynamicDictionariesDir:r(t?.dynamicDictionariesDir??`.intlayer/dynamic_dictionary`),fetchDictionariesDir:r(t?.fetchDictionariesDir??`.intlayer/fetch_dictionary`),typesDir:r(t?.typesDir??`.intlayer/types`),mainDir:r(t?.mainDir??`.intlayer/main`),configDir:r(t?.configDir??`.intlayer/config`),cacheDir:r(t?.cacheDir??`.intlayer/cache`),tempDir:r(t?.tempDir??`.intlayer/tmp`),outputFilesPatternWithPath:`${o.normalizePath(i)}/**/*.json`}},h=(e,t)=>{let r=t?.fileExtensions??n.FILE_EXTENSIONS,i=t=>{let n;try{n=s.getProjectRequire(e.baseDir).resolve(t,{paths:[e.baseDir]})}catch{try{n=require.resolve(t,{paths:[e.baseDir]})}catch{n=(0,l.isAbsolute)(t)?t:(0,l.join)(e.baseDir,t)}}try{if((0,c.statSync)(n).isFile())return(0,l.dirname)(n)}catch{if(/\.[a-z0-9]+$/i.test(n))return(0,l.dirname)(n)}return n},a=(t?.contentDir??n.CONTENT_DIR).map(i);return{fileExtensions:r,contentDir:a,codeDir:(t?.codeDir??n.CODE_DIR).map(i),excludedPath:t?.excludedPath??n.EXCLUDED_PATHS,watch:t?.watch??!0,formatCommand:t?.formatCommand,watchedFilesPattern:r.map(e=>`/**/*${e}`),watchedFilesPatternWithPath:r.flatMap(e=>a.map(t=>`${o.normalizePath(t)}/**/*${e}`))}},g=e=>({applicationURL:e?.applicationURL??void 0,editorURL:e?.editorURL??`http://localhost:8000`,cmsURL:e?.cmsURL??`https://app.intlayer.org`,backendURL:e?.backendURL??`https://back.intlayer.org`,port:e?.port??8e3,enabled:e?.enabled??!0,clientId:e?.clientId??void 0,clientSecret:e?.clientSecret??void 0,dictionaryPriorityStrategy:e?.dictionaryPriorityStrategy??`local_first`,liveSync:e?.liveSync??!0,liveSyncPort:e?.liveSyncPort??4e3,liveSyncURL:e?.liveSyncURL??`http://localhost:${e?.liveSyncPort??4e3}`}),_=(e,t)=>({mode:e?.mode??`default`,prefix:e?.prefix??i.PREFIX,error:t?.error,log:t?.log,info:t?.info,warn:t?.warn}),v=e=>({provider:e?.provider,apiKey:e?.apiKey,model:e?.model,temperature:e?.temperature,applicationContext:e?.applicationContext,baseURL:e?.baseURL,dataSerialization:e?.dataSerialization}),y=e=>({mode:e?.mode??`auto`,optimize:e?.optimize,importMode:e?.importMode,traversePattern:e?.traversePattern??t.TRAVERSE_PATTERN,outputFormat:e?.outputFormat??t.OUTPUT_FORMAT,cache:e?.cache??!0,require:e?.require,checkTypes:e?.checkTypes??!1}),b=e=>({enabled:e?.enabled??!0,dictionaryKeyPrefix:e?.dictionaryKeyPrefix??`comp-`,transformPattern:e?.transformPattern,excludePattern:e?.excludePattern,outputDir:e?.outputDir,output:e?.output,noMetadata:e?.noMetadata??!1,saveComponents:e?.saveComponents??!1}),x=e=>{let t=e?.contentAutoTransformation??!1;return{fill:e?.fill??!0,contentAutoTransformation:typeof t==`object`?{markdown:t.markdown??!1,html:t.html??!1,insertion:t.insertion??!1}:t,location:e?.location??`local`,locale:e?.locale,title:e?.title,description:e?.description,tags:e?.tags,priority:e?.priority,importMode:e?.importMode??`static`,version:e?.version}},S=(e,t,n)=>{let r=f(e?.internationalization),i=p(e?.routing),a=m(t,e?.system);return d={internationalization:r,routing:i,content:h(a,e?.content),system:a,editor:g(e?.editor),log:_(e?.log,n),ai:v(e?.ai),build:y(e?.build),compiler:b(e?.compiler),dictionary:x(e?.dictionary),plugins:e?.plugins,schemas:e?.schemas,metadata:{name:`Intlayer`,version:u.default.version,doc:`https://intlayer.org/docs`}},d};exports.buildConfigurationFields=S;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../defaultValues/build.cjs`);require(`../defaultValues/compiler.cjs`);const n=require(`../defaultValues/content.cjs`);require(`../defaultValues/dictionary.cjs`),require(`../defaultValues/editor.cjs`);const r=require(`../defaultValues/internationalization.cjs`),i=require(`../defaultValues/log.cjs`),a=require(`../defaultValues/routing.cjs`);require(`../defaultValues/system.cjs`);const o=require(`../utils/normalizePath.cjs`),s=require(`../utils/ESMxCJSHelpers.cjs`);let c=require(`node:fs`),l=require(`node:path`),u=require(`@intlayer/types/package.json`);u=e.__toESM(u);let d;const f=e=>({locales:e?.locales??r.LOCALES,requiredLocales:e?.requiredLocales??e?.locales??r.REQUIRED_LOCALES,strictMode:e?.strictMode??`inclusive`,defaultLocale:e?.defaultLocale??r.DEFAULT_LOCALE}),p=e=>({mode:e?.mode??`prefix-no-default`,storage:e?.storage??a.STORAGE,basePath:e?.basePath??``,rewrite:e?.rewrite}),m=(e,t)=>{let n=e??process.cwd(),r=e=>{let t;try{t=s.getProjectRequire(n).resolve(e,{paths:[n]})}catch{t=(0,l.isAbsolute)(e)?e:(0,l.join)(n,e)}try{if((0,c.statSync)(t).isFile())return(0,l.dirname)(t)}catch{if(/\.[a-z0-9]+$/i.test(t))return(0,l.dirname)(t)}return t},i=r(t?.dictionariesDir??`.intlayer/dictionary`);return{baseDir:n,moduleAugmentationDir:r(t?.moduleAugmentationDir??`.intlayer/types`),unmergedDictionariesDir:r(t?.unmergedDictionariesDir??`.intlayer/unmerged_dictionary`),remoteDictionariesDir:r(t?.remoteDictionariesDir??`.intlayer/remote_dictionary`),dictionariesDir:i,dynamicDictionariesDir:r(t?.dynamicDictionariesDir??`.intlayer/dynamic_dictionary`),fetchDictionariesDir:r(t?.fetchDictionariesDir??`.intlayer/fetch_dictionary`),typesDir:r(t?.typesDir??`.intlayer/types`),mainDir:r(t?.mainDir??`.intlayer/main`),configDir:r(t?.configDir??`.intlayer/config`),cacheDir:r(t?.cacheDir??`.intlayer/cache`),tempDir:r(t?.tempDir??`.intlayer/tmp`),outputFilesPatternWithPath:`${o.normalizePath(i)}/**/*.json`}},h=(e,t)=>{let r=t?.fileExtensions??n.FILE_EXTENSIONS,i=t=>{let n;try{n=s.getProjectRequire(e.baseDir).resolve(t,{paths:[e.baseDir]})}catch{try{n=require.resolve(t,{paths:[e.baseDir]})}catch{n=(0,l.isAbsolute)(t)?t:(0,l.join)(e.baseDir,t)}}try{if((0,c.statSync)(n).isFile())return(0,l.dirname)(n)}catch{if(/\.[a-z0-9]+$/i.test(n))return(0,l.dirname)(n)}return n},a=(t?.contentDir??n.CONTENT_DIR).map(i);return{fileExtensions:r,contentDir:a,codeDir:(t?.codeDir??n.CODE_DIR).map(i),excludedPath:t?.excludedPath??n.EXCLUDED_PATHS,watch:t?.watch??!0,formatCommand:t?.formatCommand,watchedFilesPattern:r.map(e=>`/**/*${e}`),watchedFilesPatternWithPath:r.flatMap(e=>a.map(t=>`${o.normalizePath(t)}/**/*${e}`))}},g=e=>({applicationURL:e?.applicationURL||void 0,editorURL:e?.editorURL||`http://localhost:8000`,cmsURL:e?.cmsURL||`https://app.intlayer.org`,backendURL:e?.backendURL||`https://back.intlayer.org`,port:e?.port??8e3,enabled:e?.enabled??!1,clientId:e?.clientId??void 0,clientSecret:e?.clientSecret??void 0,dictionaryPriorityStrategy:e?.dictionaryPriorityStrategy??`local_first`,liveSync:e?.liveSync??!0,liveSyncPort:e?.liveSyncPort??4e3,liveSyncURL:e?.liveSyncURL??`http://localhost:${e?.liveSyncPort??4e3}`}),_=(e,t)=>({mode:e?.mode??`default`,prefix:e?.prefix??i.PREFIX,error:t?.error,log:t?.log,info:t?.info,warn:t?.warn}),v=e=>({provider:e?.provider,apiKey:e?.apiKey,model:e?.model,temperature:e?.temperature,applicationContext:e?.applicationContext,baseURL:e?.baseURL,dataSerialization:e?.dataSerialization}),y=e=>({mode:e?.mode??`auto`,optimize:e?.optimize,importMode:e?.importMode,traversePattern:e?.traversePattern??t.TRAVERSE_PATTERN,outputFormat:e?.outputFormat??t.OUTPUT_FORMAT,cache:e?.cache??!0,require:e?.require,checkTypes:e?.checkTypes??!1}),b=e=>({enabled:e?.enabled??!0,dictionaryKeyPrefix:e?.dictionaryKeyPrefix??`comp-`,transformPattern:e?.transformPattern,excludePattern:e?.excludePattern,outputDir:e?.outputDir,output:e?.output,noMetadata:e?.noMetadata??!1,saveComponents:e?.saveComponents??!1}),x=e=>{let t=e?.contentAutoTransformation??!1;return{fill:e?.fill??!0,contentAutoTransformation:typeof t==`object`?{markdown:t.markdown??!1,html:t.html??!1,insertion:t.insertion??!1}:t,location:e?.location??`local`,locale:e?.locale,title:e?.title,description:e?.description,tags:e?.tags,priority:e?.priority,importMode:e?.importMode??`static`,version:e?.version}},S=(e,t,n)=>{let r=f(e?.internationalization),i=p(e?.routing),a=m(t,e?.system);return d={internationalization:r,routing:i,content:h(a,e?.content),system:a,editor:g(e?.editor),log:_(e?.log,n),ai:v(e?.ai),build:y(e?.build),compiler:b(e?.compiler),dictionary:x(e?.dictionary),plugins:e?.plugins,schemas:e?.schemas,metadata:{name:`Intlayer`,version:u.default.version,doc:`https://intlayer.org/docs`}},d};exports.buildConfigurationFields=S;
2
2
  //# sourceMappingURL=buildConfigurationFields.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"buildConfigurationFields.cjs","names":["LOCALES","REQUIRED_LOCALES","DEFAULT_LOCALE","STORAGE","getProjectRequire","normalizePath","FILE_EXTENSIONS","CONTENT_DIR","CODE_DIR","EXCLUDED_PATHS","PREFIX","TRAVERSE_PATTERN","OUTPUT_FORMAT","packageJson"],"sources":["../../../src/configFile/buildConfigurationFields.ts"],"sourcesContent":["import { statSync } from 'node:fs';\nimport { dirname, isAbsolute, join } from 'node:path';\nimport type {\n AiConfig,\n BuildConfig,\n CompilerConfig,\n ContentConfig,\n CustomIntlayerConfig,\n DictionaryConfig,\n EditorConfig,\n InternationalizationConfig,\n IntlayerConfig,\n LogConfig,\n LogFunctions,\n RoutingConfig,\n SystemConfig,\n} from '@intlayer/types/config';\nimport packageJson from '@intlayer/types/package.json' with { type: 'json' };\nimport {\n BUILD_MODE,\n CACHE,\n OUTPUT_FORMAT,\n TRAVERSE_PATTERN,\n TYPE_CHECKING,\n} from '../defaultValues/build';\nimport {\n COMPILER_DICTIONARY_KEY_PREFIX,\n COMPILER_ENABLED,\n COMPILER_NO_METADATA,\n COMPILER_OUTPUT,\n COMPILER_SAVE_COMPONENTS,\n} from '../defaultValues/compiler';\nimport {\n CODE_DIR,\n CONTENT_DIR,\n EXCLUDED_PATHS,\n FILE_EXTENSIONS,\n WATCH,\n} from '../defaultValues/content';\nimport {\n CONTENT_AUTO_TRANSFORMATION,\n FILL,\n IMPORT_MODE,\n LOCATION,\n} from '../defaultValues/dictionary';\nimport {\n APPLICATION_URL,\n BACKEND_URL,\n CMS_URL,\n DICTIONARY_PRIORITY_STRATEGY,\n EDITOR_URL,\n IS_ENABLED,\n LIVE_SYNC,\n LIVE_SYNC_PORT,\n PORT,\n} from '../defaultValues/editor';\nimport {\n DEFAULT_LOCALE,\n LOCALES,\n REQUIRED_LOCALES,\n STRICT_MODE,\n} from '../defaultValues/internationalization';\nimport { MODE, PREFIX } from '../defaultValues/log';\nimport { BASE_PATH, ROUTING_MODE, STORAGE } from '../defaultValues/routing';\nimport {\n CACHE_DIR,\n CONFIG_DIR,\n DICTIONARIES_DIR,\n DYNAMIC_DICTIONARIES_DIR,\n FETCH_DICTIONARIES_DIR,\n MAIN_DIR,\n MODULE_AUGMENTATION_DIR,\n REMOTE_DICTIONARIES_DIR,\n TEMP_DIR,\n TYPES_DIR,\n UNMERGED_DICTIONARIES_DIR,\n} from '../defaultValues/system';\nimport { getProjectRequire } from '../utils';\nimport { normalizePath } from '../utils/normalizePath';\n\nlet storedConfiguration: IntlayerConfig;\n\nconst buildInternationalizationFields = (\n customConfiguration?: Partial<InternationalizationConfig>\n): InternationalizationConfig => ({\n /**\n * Locales available in the application\n *\n * Default: ['en']\n *\n */\n locales: customConfiguration?.locales ?? LOCALES,\n\n /**\n * Locales required by TypeScript to ensure strong implementations of internationalized content using typescript.\n *\n * Default: []\n *\n * If empty, all locales are required in `strict` mode.\n *\n * Ensure required locales are also defined in the `locales` field.\n */\n requiredLocales:\n customConfiguration?.requiredLocales ??\n customConfiguration?.locales ??\n REQUIRED_LOCALES,\n\n /**\n * Ensure strong implementations of internationalized content using typescript.\n * - If set to \"strict\", the translation `t` function will require each declared locales to be defined. If one locale is missing, or if a locale is not declared in your config, it will throw an error.\n * - If set to \"inclusive\", the translation `t` function will require each declared locales to be defined. If one locale is missing, it will throw a warning. But will accept if a locale is not declared in your config, but exist.\n * - If set to \"loose\", the translation `t` function will accept any existing locale.\n *\n * Default: \"inclusive\"\n */\n strictMode: customConfiguration?.strictMode ?? STRICT_MODE,\n\n /**\n * Default locale of the application for fallback\n *\n * Default: 'en'\n */\n defaultLocale: customConfiguration?.defaultLocale ?? DEFAULT_LOCALE,\n});\n\nconst buildRoutingFields = (\n customConfiguration?: Partial<RoutingConfig>\n): RoutingConfig => ({\n /**\n * URL routing mode for locale handling\n *\n * Controls how locales are represented in application URLs:\n * - 'prefix-no-default': Prefix all locales except the default locale (default)\n * - en → /dashboard\n * - fr → /fr/dashboard\n *\n * - 'prefix-all': Prefix all locales including the default locale\n * - en → /en/dashboard\n * - fr → /fr/dashboard\n *\n * - 'search-params': Use search parameters for locale handling\n * - en → /dashboard?locale=en\n * - fr → /fr/dashboard?locale=fr\n *\n * - 'no-prefix': No locale prefixing in URLs\n * - en → /dashboard\n * - fr → /dashboard\n *\n * Default: 'prefix-no-default'\n */\n mode: customConfiguration?.mode ?? ROUTING_MODE,\n\n /**\n * Configuration for storing the locale in the client (localStorage or sessionStorage)\n *\n * If false, the locale will not be stored by the middleware.\n * If true, the locale storage will consider all default values. (cookie and header)\n *\n * Default: ['cookie', 'header']\n *\n */\n storage: customConfiguration?.storage ?? STORAGE,\n\n /**\n * Base path of the application URL\n *\n * Default: ''\n *\n * Example:\n * - If the application is hosted at https://example.com/my-app\n * - The base path is '/my-app'\n * - The URL will be https://example.com/my-app/en\n * - If the base path is not set, the URL will be https://example.com/en\n */\n basePath: customConfiguration?.basePath ?? BASE_PATH,\n\n /**\n * Custom URL rewriting rules that override the default routing mode for specific paths.\n * Allows you to define locale-specific paths that differ from the standard routing behavior.\n * Supports dynamic route parameters using `[param]` syntax.\n *\n * Default: undefined\n *\n * Example:\n * ```typescript\n * rewrite: {\n * \"/about\": {\n * en: \"/about\",\n * fr: \"/a-propos\",\n * },\n * \"/product/[slug]\": {\n * en: \"/product/[slug]\",\n * fr: \"/produit/[slug]\",\n * },\n * }\n * ```\n *\n * Note:\n * - The rewrite rules take precedence over the default `mode` behavior.\n * - If a path matches a rewrite rule, the localized path from the rewrite configuration will be used.\n * - Dynamic route parameters are supported using bracket notation (e.g., `[slug]`, `[id]`).\n * - Works with both Next.js and Vite applications.\n */\n rewrite: customConfiguration?.rewrite,\n});\n\nconst buildSystemFields = (\n baseDir?: string,\n customConfiguration?: Partial<SystemConfig>\n): SystemConfig => {\n const projectBaseDir = baseDir ?? process.cwd();\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n const requireFunction = getProjectRequire(projectBaseDir);\n\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [projectBaseDir],\n });\n } catch {\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(projectBaseDir, pathInput);\n }\n\n try {\n const stats = statSync(absolutePath);\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n return absolutePath;\n };\n\n const dictionariesDir = optionalJoinBaseDir(\n customConfiguration?.dictionariesDir ?? DICTIONARIES_DIR\n );\n\n return {\n baseDir: projectBaseDir,\n moduleAugmentationDir: optionalJoinBaseDir(\n customConfiguration?.moduleAugmentationDir ?? MODULE_AUGMENTATION_DIR\n ),\n unmergedDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.unmergedDictionariesDir ?? UNMERGED_DICTIONARIES_DIR\n ),\n remoteDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.remoteDictionariesDir ?? REMOTE_DICTIONARIES_DIR\n ),\n dictionariesDir,\n dynamicDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.dynamicDictionariesDir ?? DYNAMIC_DICTIONARIES_DIR\n ),\n fetchDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.fetchDictionariesDir ?? FETCH_DICTIONARIES_DIR\n ),\n typesDir: optionalJoinBaseDir(customConfiguration?.typesDir ?? TYPES_DIR),\n mainDir: optionalJoinBaseDir(customConfiguration?.mainDir ?? MAIN_DIR),\n configDir: optionalJoinBaseDir(\n customConfiguration?.configDir ?? CONFIG_DIR\n ),\n cacheDir: optionalJoinBaseDir(customConfiguration?.cacheDir ?? CACHE_DIR),\n tempDir: optionalJoinBaseDir(customConfiguration?.tempDir ?? TEMP_DIR),\n outputFilesPatternWithPath: `${normalizePath(dictionariesDir)}/**/*.json`,\n };\n};\n\nconst buildContentFields = (\n systemConfig: SystemConfig,\n customConfiguration?: Partial<ContentConfig>\n): ContentConfig => {\n const fileExtensions = customConfiguration?.fileExtensions ?? FILE_EXTENSIONS;\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n // Try resolving as a Node module first\n const requireFunction = getProjectRequire(systemConfig.baseDir);\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n try {\n // Fall back to native require.resolve if the custom require fails\n absolutePath = require.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n // If all resolution fails, fall back to standard path joining\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(systemConfig.baseDir, pathInput);\n }\n }\n\n try {\n // Smart Detection: File vs Directory\n const stats = statSync(absolutePath);\n\n // If it resolved to a file (like package.json \"main\" or index.js),\n // we want the FOLDER containing that file.\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n // Safety Fallback:\n // If statSync fails but it looks like a file (has an extension), strip it.\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n // Return the calculated path (usually a directory)\n return absolutePath;\n };\n\n const contentDir = (customConfiguration?.contentDir ?? CONTENT_DIR).map(\n optionalJoinBaseDir\n );\n\n const codeDirInput = customConfiguration?.codeDir;\n\n const codeDir = (codeDirInput ?? CODE_DIR).map(optionalJoinBaseDir);\n\n return {\n fileExtensions,\n contentDir,\n codeDir,\n excludedPath: customConfiguration?.excludedPath ?? EXCLUDED_PATHS,\n watch: customConfiguration?.watch ?? WATCH,\n formatCommand: customConfiguration?.formatCommand,\n watchedFilesPattern: fileExtensions.map((ext) => `/**/*${ext}`),\n watchedFilesPatternWithPath: fileExtensions.flatMap((ext) =>\n contentDir.map((dir) => `${normalizePath(dir)}/**/*${ext}`)\n ),\n };\n};\n\nconst buildEditorFields = (\n customConfiguration?: Partial<EditorConfig>\n): EditorConfig => ({\n /**\n * URL of the application. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n applicationURL: customConfiguration?.applicationURL ?? APPLICATION_URL,\n\n /**\n * URL of the editor server. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n editorURL: customConfiguration?.editorURL ?? EDITOR_URL,\n\n /**\n * URL of the CMS server. Used to restrict the origin of the editor for security reasons.\n */\n cmsURL: customConfiguration?.cmsURL ?? CMS_URL,\n\n /**\n * URL of the editor server\n *\n * Default: 'https://back.intlayer.org'\n */\n backendURL: customConfiguration?.backendURL ?? BACKEND_URL,\n\n /** Port of the editor server\n *\n * Default: 8000\n */\n port: customConfiguration?.port ?? PORT,\n\n /**\n * Indicates if the application interact with the visual editor\n *\n * Default: true;\n *\n * If true, the editor will be able to interact with the application.\n * If false, the editor will not be able to interact with the application.\n * In any case, the editor can only be enabled by the visual editor.\n * Disabling the editor for specific environments is a way to enforce the security.\n *\n * Usage:\n * ```js\n * {\n * // Other configurations\n * editor: {\n * enabled: process.env.NODE_ENV !== 'production',\n * }\n * };\n * ```\n */\n enabled: customConfiguration?.enabled ?? IS_ENABLED,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientId: customConfiguration?.clientId ?? undefined,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientSecret: customConfiguration?.clientSecret ?? undefined,\n\n /**\n * Strategy for prioritizing dictionaries. If a dictionary is both present online and locally, the content will be merge.\n * However, is a field is defined in both dictionary, this setting determines which fields takes the priority over the other.\n *\n * Default: 'local_first'\n *\n * The strategy for prioritizing dictionaries. It can be either 'local_first' or 'distant_first'.\n * - 'local_first': The first dictionary found in the locale is used.\n * - 'distant_first': The first dictionary found in the distant locales is used.\n */\n dictionaryPriorityStrategy:\n customConfiguration?.dictionaryPriorityStrategy ??\n DICTIONARY_PRIORITY_STRATEGY,\n\n /**\n * Indicates if the application should hot reload the locale configurations when a change is detected.\n * For example, when a new dictionary is added or updated, the application will update the content tu display in the page.\n *\n * The hot reload is only available for clients of the `enterprise` plan.\n *\n * Default: false\n */\n liveSync: customConfiguration?.liveSync ?? LIVE_SYNC,\n\n /**\n * Port of the live sync server\n *\n * Default: 4000\n */\n liveSyncPort: customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT,\n\n /**\n * URL of the live sync server in case of remote live sync server\n *\n * Default: `http://localhost:${LIVE_SYNC_PORT}`\n */\n liveSyncURL:\n customConfiguration?.liveSyncURL ??\n `http://localhost:${customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT}`,\n});\n\nconst buildLogFields = (\n customConfiguration?: Partial<LogConfig>,\n logFunctions?: LogFunctions\n): LogConfig => ({\n /**\n * Indicates if the logger is enabled\n *\n * Default: 'prefix-no-default'\n *\n * If 'default', the logger is enabled and can be used.\n * If 'verbose', the logger will be enabled and can be used, but will log more information.\n * If 'disabled', the logger is disabled and cannot be used.\n */\n mode: customConfiguration?.mode ?? MODE,\n\n /**\n * Prefix of the logger\n *\n * Default: '[intlayer]'\n *\n * The prefix of the logger.\n */\n prefix: customConfiguration?.prefix ?? PREFIX,\n\n /**\n * Functions to log\n */\n error: logFunctions?.error,\n log: logFunctions?.log,\n info: logFunctions?.info,\n warn: logFunctions?.warn,\n});\n\nconst buildAiFields = (customConfiguration?: Partial<AiConfig>): AiConfig => ({\n /**\n * AI configuration\n */\n provider: customConfiguration?.provider,\n\n /**\n * API key\n */\n apiKey: customConfiguration?.apiKey,\n\n /**\n * API model\n */\n model: customConfiguration?.model,\n\n /**\n * Temperature\n */\n temperature: customConfiguration?.temperature,\n\n /**\n * Application context\n *\n * Default: undefined\n *\n * The application context.\n *\n * Example: `'My application context'`\n *\n * Note: Can be used to provide additional context about the application to the AI model. You can add more rules (e.g. \"You should not transform urls\").\n */\n applicationContext: customConfiguration?.applicationContext,\n\n /**\n * Base URL for the AI API\n *\n * Default: undefined\n *\n * The base URL for the AI API.\n *\n * Example: `'http://localhost:5000'`\n *\n * Note: Can be used to point to a local, or custom AI API endpoint.\n */\n baseURL: customConfiguration?.baseURL,\n\n /**\n * Data serialization\n *\n * Options:\n * - \"json\": The industry standard. Highly reliable and structured, but consumes more tokens.\n * - \"toon\": An optimized format designed to reduce token consumption (cost-effective). However, it may slightly increase the risk of output inconsistency compared to standard JSON\n *\n * Default: \"json\"\n */\n dataSerialization: customConfiguration?.dataSerialization,\n});\n\nconst buildBuildFields = (\n customConfiguration?: Partial<BuildConfig>\n): BuildConfig => ({\n /**\n * Indicates the mode of the build\n *\n * Default: 'auto'\n *\n * If 'auto', the build will be enabled automatically when the application is built.\n * If 'manual', the build will be set only when the build command is executed.\n *\n * Can be used to disable dictionaries build, for instance when execution on Node.js environment should be avoided.\n */\n mode: customConfiguration?.mode ?? BUILD_MODE,\n\n /**\n * Indicates if the build should be optimized\n *\n * Default: process.env.NODE_ENV === 'production'\n *\n * If true, the build will be optimized.\n * If false, the build will not be optimized.\n *\n * Intlayer will replace all calls of dictionaries to optimize chunking. That way the final bundle will import only the dictionaries that are used.\n * All imports will stay as static import to avoid async processing when loading the dictionaries.\n *\n * Note:\n * - Intlayer will replace all call of `useIntlayer` with the defined mode by the `importMode` option.\n * - Intlayer will replace all call of `getIntlayer` with `getDictionary`.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - In most cases, \"dynamic\" will be used for React applications, \"async\" for Vue.js applications.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n */\n optimize: customConfiguration?.optimize,\n\n /**\n * Indicates the mode of import to use for the dictionaries.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionary`.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * Live mode will use the live sync API to fetch the dictionaries. If the API call fails, the dictionaries will be imported dynamically as \"dynamic\" mode.\n *\n * Default: \"static\"\n *\n * By default, when a dictionary is loaded, it imports content for all locales as it's imported statically.\n *\n * Note:\n * - Dynamic imports rely on Suspense and may slightly impact rendering performance.\n * - If disabled all locales will be loaded at once, even if they are not used.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n * - This option will be ignored if `optimize` is disabled.\n * - This option will not impact the `getIntlayer`, `getDictionary`, `useDictionary`, `useDictionaryAsync` and `useDictionaryDynamic` functions. You can still use them to refine you code on manual optimization.\n * - The \"live\" allows to sync the dictionaries to the live sync server.\n *\n * @deprecated Use `dictionary.importMode` instead.\n */\n importMode: customConfiguration?.importMode,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * Allows to avoid to traverse the code that is not relevant to the optimization.\n * Improve build performance.\n *\n * Default: ['**\\/*.{js,ts,mjs,cjs,jsx,tsx}', '!**\\/node_modules/**']\n *\n * Example: `['src/**\\/*.{ts,tsx}', '../ui-library/**\\/*.{ts,tsx}']`\n *\n * Note:\n * - This option will be ignored if `optimize` is disabled.\n * - Use glob pattern.\n */\n traversePattern: customConfiguration?.traversePattern ?? TRAVERSE_PATTERN,\n\n /**\n * Output format of the dictionaries\n *\n * Can be set on large projects to improve build performance.\n *\n * Default: ['cjs', 'esm']\n *\n * The output format of the dictionaries. It can be either 'cjs' or 'esm'.\n * - 'cjs': The dictionaries are outputted as CommonJS modules.\n * - 'esm': The dictionaries are outputted as ES modules.\n */\n outputFormat: customConfiguration?.outputFormat ?? OUTPUT_FORMAT,\n\n /**\n * Cache\n */\n cache: customConfiguration?.cache ?? CACHE,\n\n /**\n * Require function\n */\n require: customConfiguration?.require,\n\n /**\n * Indicates if the build should check TypeScript types\n *\n * Default: false\n *\n * If true, the build will check TypeScript types and log errors.\n * Note: This can slow down the build.\n */\n checkTypes: customConfiguration?.checkTypes ?? TYPE_CHECKING,\n});\n\nconst buildCompilerFields = (\n customConfiguration?: Partial<CompilerConfig>\n): CompilerConfig => ({\n /**\n * Indicates if the compiler should be enabled\n */\n enabled: customConfiguration?.enabled ?? COMPILER_ENABLED,\n\n /**\n * Prefix for the extracted dictionary keys\n */\n dictionaryKeyPrefix:\n customConfiguration?.dictionaryKeyPrefix ?? COMPILER_DICTIONARY_KEY_PREFIX,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * @deprecated use build.traversePattern instead\n */\n transformPattern: customConfiguration?.transformPattern,\n\n /**\n * Pattern to exclude from the optimization.\n *\n * @deprecated use build.traversePattern instead\n */\n excludePattern: customConfiguration?.excludePattern,\n\n /**\n * Output directory for the optimized dictionaries.\n * @deprecated use `output` instead\n */\n outputDir: customConfiguration?.outputDir,\n\n /**\n * File path pattern for generated dictionaries.\n */\n output: customConfiguration?.output,\n\n /**\n * Indicates if the metadata should be saved in the file.\n *\n * If true, the compiler will not save the metadata of the dictionaries.\n *\n * If true:\n *\n * ```json\n * {\n * \"key\": \"value\"\n * }\n * ```\n *\n * If false:\n *\n * ```json\n * {\n * \"key\": \"value\",\n * \"content\": {\n * \"key\": \"value\"\n * }\n * }\n * ```\n *\n * Default: false\n *\n * Note: Useful if used with loadJSON plugin\n */\n noMetadata: customConfiguration?.noMetadata ?? COMPILER_NO_METADATA,\n\n /**\n * Indicates if the components should be saved after being transformed.\n */\n saveComponents:\n customConfiguration?.saveComponents ?? COMPILER_SAVE_COMPONENTS,\n});\n\nconst buildDictionaryFields = (\n customConfiguration?: Partial<DictionaryConfig>\n): DictionaryConfig => {\n const contentAutoTransformation =\n customConfiguration?.contentAutoTransformation ??\n CONTENT_AUTO_TRANSFORMATION;\n\n return {\n /**\n * Indicate how the dictionary should be filled using AI.\n *\n * Default: true\n */\n fill: customConfiguration?.fill ?? FILL,\n\n /**\n * Indicates if the content of the dictionary should be automatically transformed.\n *\n * Default: false\n */\n contentAutoTransformation:\n typeof contentAutoTransformation === 'object'\n ? {\n markdown: contentAutoTransformation.markdown ?? false,\n html: contentAutoTransformation.html ?? false,\n insertion: contentAutoTransformation.insertion ?? false,\n }\n : contentAutoTransformation,\n\n /**\n * The location of the dictionary.\n *\n * Default: 'local'\n */\n location: customConfiguration?.location ?? LOCATION,\n\n /**\n * Transform the dictionary in a per-locale dictionary.\n * Each field declared in a per-locale dictionary will be transformed in a translation node.\n * If missing, the dictionary will be treated as a multilingual dictionary.\n */\n locale: customConfiguration?.locale,\n\n /**\n * The title of the dictionary.\n */\n title: customConfiguration?.title,\n\n /**\n * The description of the dictionary.\n */\n description: customConfiguration?.description,\n\n /**\n * Tags to categorize the dictionaries.\n */\n tags: customConfiguration?.tags,\n\n /**\n * The priority of the dictionary.\n */\n priority: customConfiguration?.priority,\n\n /**\n * Indicates the mode of import to use for the dictionary.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n *\n * Default: 'static'\n */\n importMode: customConfiguration?.importMode ?? IMPORT_MODE,\n\n /**\n * The version of the dictionary.\n */\n version: customConfiguration?.version,\n };\n};\n\n/**\n * Build the configuration fields by merging the default values with the custom configuration\n */\nexport const buildConfigurationFields = (\n customConfiguration?: CustomIntlayerConfig,\n baseDir?: string,\n logFunctions?: LogFunctions\n): IntlayerConfig => {\n const internationalizationConfig = buildInternationalizationFields(\n customConfiguration?.internationalization\n );\n\n const routingConfig = buildRoutingFields(customConfiguration?.routing);\n\n const systemConfig = buildSystemFields(baseDir, customConfiguration?.system);\n\n const contentConfig = buildContentFields(\n systemConfig,\n customConfiguration?.content\n );\n\n const editorConfig = buildEditorFields(customConfiguration?.editor);\n\n const logConfig = buildLogFields(customConfiguration?.log, logFunctions);\n\n const aiConfig = buildAiFields(customConfiguration?.ai);\n\n const buildConfig = buildBuildFields(customConfiguration?.build);\n\n const compilerConfig = buildCompilerFields(customConfiguration?.compiler);\n\n const dictionaryConfig = buildDictionaryFields(\n customConfiguration?.dictionary\n );\n\n storedConfiguration = {\n internationalization: internationalizationConfig,\n routing: routingConfig,\n content: contentConfig,\n system: systemConfig,\n editor: editorConfig,\n log: logConfig,\n ai: aiConfig,\n build: buildConfig,\n compiler: compilerConfig,\n dictionary: dictionaryConfig,\n plugins: customConfiguration?.plugins,\n schemas: customConfiguration?.schemas,\n metadata: {\n name: 'Intlayer',\n version: packageJson.version,\n doc: `https://intlayer.org/docs`,\n },\n } as IntlayerConfig;\n\n return storedConfiguration;\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"buildConfigurationFields.cjs","names":["LOCALES","REQUIRED_LOCALES","DEFAULT_LOCALE","STORAGE","getProjectRequire","normalizePath","FILE_EXTENSIONS","CONTENT_DIR","CODE_DIR","EXCLUDED_PATHS","PREFIX","TRAVERSE_PATTERN","OUTPUT_FORMAT","packageJson"],"sources":["../../../src/configFile/buildConfigurationFields.ts"],"sourcesContent":["import { statSync } from 'node:fs';\nimport { dirname, isAbsolute, join } from 'node:path';\nimport type {\n AiConfig,\n BuildConfig,\n CompilerConfig,\n ContentConfig,\n CustomIntlayerConfig,\n DictionaryConfig,\n EditorConfig,\n InternationalizationConfig,\n IntlayerConfig,\n LogConfig,\n LogFunctions,\n RoutingConfig,\n SystemConfig,\n} from '@intlayer/types/config';\nimport packageJson from '@intlayer/types/package.json' with { type: 'json' };\nimport {\n BUILD_MODE,\n CACHE,\n OUTPUT_FORMAT,\n TRAVERSE_PATTERN,\n TYPE_CHECKING,\n} from '../defaultValues/build';\nimport {\n COMPILER_DICTIONARY_KEY_PREFIX,\n COMPILER_ENABLED,\n COMPILER_NO_METADATA,\n COMPILER_OUTPUT,\n COMPILER_SAVE_COMPONENTS,\n} from '../defaultValues/compiler';\nimport {\n CODE_DIR,\n CONTENT_DIR,\n EXCLUDED_PATHS,\n FILE_EXTENSIONS,\n WATCH,\n} from '../defaultValues/content';\nimport {\n CONTENT_AUTO_TRANSFORMATION,\n FILL,\n IMPORT_MODE,\n LOCATION,\n} from '../defaultValues/dictionary';\nimport {\n APPLICATION_URL,\n BACKEND_URL,\n CMS_URL,\n DICTIONARY_PRIORITY_STRATEGY,\n EDITOR_URL,\n IS_ENABLED,\n LIVE_SYNC,\n LIVE_SYNC_PORT,\n PORT,\n} from '../defaultValues/editor';\nimport {\n DEFAULT_LOCALE,\n LOCALES,\n REQUIRED_LOCALES,\n STRICT_MODE,\n} from '../defaultValues/internationalization';\nimport { MODE, PREFIX } from '../defaultValues/log';\nimport { BASE_PATH, ROUTING_MODE, STORAGE } from '../defaultValues/routing';\nimport {\n CACHE_DIR,\n CONFIG_DIR,\n DICTIONARIES_DIR,\n DYNAMIC_DICTIONARIES_DIR,\n FETCH_DICTIONARIES_DIR,\n MAIN_DIR,\n MODULE_AUGMENTATION_DIR,\n REMOTE_DICTIONARIES_DIR,\n TEMP_DIR,\n TYPES_DIR,\n UNMERGED_DICTIONARIES_DIR,\n} from '../defaultValues/system';\nimport { getProjectRequire } from '../utils';\nimport { normalizePath } from '../utils/normalizePath';\n\nlet storedConfiguration: IntlayerConfig;\n\nconst buildInternationalizationFields = (\n customConfiguration?: Partial<InternationalizationConfig>\n): InternationalizationConfig => ({\n /**\n * Locales available in the application\n *\n * Default: ['en']\n *\n */\n locales: customConfiguration?.locales ?? LOCALES,\n\n /**\n * Locales required by TypeScript to ensure strong implementations of internationalized content using typescript.\n *\n * Default: []\n *\n * If empty, all locales are required in `strict` mode.\n *\n * Ensure required locales are also defined in the `locales` field.\n */\n requiredLocales:\n customConfiguration?.requiredLocales ??\n customConfiguration?.locales ??\n REQUIRED_LOCALES,\n\n /**\n * Ensure strong implementations of internationalized content using typescript.\n * - If set to \"strict\", the translation `t` function will require each declared locales to be defined. If one locale is missing, or if a locale is not declared in your config, it will throw an error.\n * - If set to \"inclusive\", the translation `t` function will require each declared locales to be defined. If one locale is missing, it will throw a warning. But will accept if a locale is not declared in your config, but exist.\n * - If set to \"loose\", the translation `t` function will accept any existing locale.\n *\n * Default: \"inclusive\"\n */\n strictMode: customConfiguration?.strictMode ?? STRICT_MODE,\n\n /**\n * Default locale of the application for fallback\n *\n * Default: 'en'\n */\n defaultLocale: customConfiguration?.defaultLocale ?? DEFAULT_LOCALE,\n});\n\nconst buildRoutingFields = (\n customConfiguration?: Partial<RoutingConfig>\n): RoutingConfig => ({\n /**\n * URL routing mode for locale handling\n *\n * Controls how locales are represented in application URLs:\n * - 'prefix-no-default': Prefix all locales except the default locale (default)\n * - en → /dashboard\n * - fr → /fr/dashboard\n *\n * - 'prefix-all': Prefix all locales including the default locale\n * - en → /en/dashboard\n * - fr → /fr/dashboard\n *\n * - 'search-params': Use search parameters for locale handling\n * - en → /dashboard?locale=en\n * - fr → /fr/dashboard?locale=fr\n *\n * - 'no-prefix': No locale prefixing in URLs\n * - en → /dashboard\n * - fr → /dashboard\n *\n * Default: 'prefix-no-default'\n */\n mode: customConfiguration?.mode ?? ROUTING_MODE,\n\n /**\n * Configuration for storing the locale in the client (localStorage or sessionStorage)\n *\n * If false, the locale will not be stored by the middleware.\n * If true, the locale storage will consider all default values. (cookie and header)\n *\n * Default: ['cookie', 'header']\n *\n */\n storage: customConfiguration?.storage ?? STORAGE,\n\n /**\n * Base path of the application URL\n *\n * Default: ''\n *\n * Example:\n * - If the application is hosted at https://example.com/my-app\n * - The base path is '/my-app'\n * - The URL will be https://example.com/my-app/en\n * - If the base path is not set, the URL will be https://example.com/en\n */\n basePath: customConfiguration?.basePath ?? BASE_PATH,\n\n /**\n * Custom URL rewriting rules that override the default routing mode for specific paths.\n * Allows you to define locale-specific paths that differ from the standard routing behavior.\n * Supports dynamic route parameters using `[param]` syntax.\n *\n * Default: undefined\n *\n * Example:\n * ```typescript\n * rewrite: {\n * \"/about\": {\n * en: \"/about\",\n * fr: \"/a-propos\",\n * },\n * \"/product/[slug]\": {\n * en: \"/product/[slug]\",\n * fr: \"/produit/[slug]\",\n * },\n * }\n * ```\n *\n * Note:\n * - The rewrite rules take precedence over the default `mode` behavior.\n * - If a path matches a rewrite rule, the localized path from the rewrite configuration will be used.\n * - Dynamic route parameters are supported using bracket notation (e.g., `[slug]`, `[id]`).\n * - Works with both Next.js and Vite applications.\n */\n rewrite: customConfiguration?.rewrite,\n});\n\nconst buildSystemFields = (\n baseDir?: string,\n customConfiguration?: Partial<SystemConfig>\n): SystemConfig => {\n const projectBaseDir = baseDir ?? process.cwd();\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n const requireFunction = getProjectRequire(projectBaseDir);\n\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [projectBaseDir],\n });\n } catch {\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(projectBaseDir, pathInput);\n }\n\n try {\n const stats = statSync(absolutePath);\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n return absolutePath;\n };\n\n const dictionariesDir = optionalJoinBaseDir(\n customConfiguration?.dictionariesDir ?? DICTIONARIES_DIR\n );\n\n return {\n baseDir: projectBaseDir,\n moduleAugmentationDir: optionalJoinBaseDir(\n customConfiguration?.moduleAugmentationDir ?? MODULE_AUGMENTATION_DIR\n ),\n unmergedDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.unmergedDictionariesDir ?? UNMERGED_DICTIONARIES_DIR\n ),\n remoteDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.remoteDictionariesDir ?? REMOTE_DICTIONARIES_DIR\n ),\n dictionariesDir,\n dynamicDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.dynamicDictionariesDir ?? DYNAMIC_DICTIONARIES_DIR\n ),\n fetchDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.fetchDictionariesDir ?? FETCH_DICTIONARIES_DIR\n ),\n typesDir: optionalJoinBaseDir(customConfiguration?.typesDir ?? TYPES_DIR),\n mainDir: optionalJoinBaseDir(customConfiguration?.mainDir ?? MAIN_DIR),\n configDir: optionalJoinBaseDir(\n customConfiguration?.configDir ?? CONFIG_DIR\n ),\n cacheDir: optionalJoinBaseDir(customConfiguration?.cacheDir ?? CACHE_DIR),\n tempDir: optionalJoinBaseDir(customConfiguration?.tempDir ?? TEMP_DIR),\n outputFilesPatternWithPath: `${normalizePath(dictionariesDir)}/**/*.json`,\n };\n};\n\nconst buildContentFields = (\n systemConfig: SystemConfig,\n customConfiguration?: Partial<ContentConfig>\n): ContentConfig => {\n const fileExtensions = customConfiguration?.fileExtensions ?? FILE_EXTENSIONS;\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n // Try resolving as a Node module first\n const requireFunction = getProjectRequire(systemConfig.baseDir);\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n try {\n // Fall back to native require.resolve if the custom require fails\n absolutePath = require.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n // If all resolution fails, fall back to standard path joining\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(systemConfig.baseDir, pathInput);\n }\n }\n\n try {\n // Smart Detection: File vs Directory\n const stats = statSync(absolutePath);\n\n // If it resolved to a file (like package.json \"main\" or index.js),\n // we want the FOLDER containing that file.\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n // Safety Fallback:\n // If statSync fails but it looks like a file (has an extension), strip it.\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n // Return the calculated path (usually a directory)\n return absolutePath;\n };\n\n const contentDir = (customConfiguration?.contentDir ?? CONTENT_DIR).map(\n optionalJoinBaseDir\n );\n\n const codeDirInput = customConfiguration?.codeDir;\n\n const codeDir = (codeDirInput ?? CODE_DIR).map(optionalJoinBaseDir);\n\n return {\n fileExtensions,\n contentDir,\n codeDir,\n excludedPath: customConfiguration?.excludedPath ?? EXCLUDED_PATHS,\n watch: customConfiguration?.watch ?? WATCH,\n formatCommand: customConfiguration?.formatCommand,\n watchedFilesPattern: fileExtensions.map((ext) => `/**/*${ext}`),\n watchedFilesPatternWithPath: fileExtensions.flatMap((ext) =>\n contentDir.map((dir) => `${normalizePath(dir)}/**/*${ext}`)\n ),\n };\n};\n\nconst buildEditorFields = (\n customConfiguration?: Partial<EditorConfig>\n): EditorConfig => ({\n /**\n * URL of the application. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n applicationURL: customConfiguration?.applicationURL || APPLICATION_URL,\n\n /**\n * URL of the editor server. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n editorURL: customConfiguration?.editorURL || EDITOR_URL,\n\n /**\n * URL of the CMS server. Used to restrict the origin of the editor for security reasons.\n */\n cmsURL: customConfiguration?.cmsURL || CMS_URL,\n\n /**\n * URL of the editor server\n *\n * Default: 'https://back.intlayer.org'\n */\n backendURL: customConfiguration?.backendURL || BACKEND_URL,\n\n /** Port of the editor server\n *\n * Default: 8000\n */\n port: customConfiguration?.port ?? PORT,\n\n /**\n * Indicates if the application interact with the visual editor\n *\n * Default: true;\n *\n * If true, the editor will be able to interact with the application.\n * If false, the editor will not be able to interact with the application.\n * In any case, the editor can only be enabled by the visual editor.\n * Disabling the editor for specific environments is a way to enforce the security.\n *\n * Usage:\n * ```js\n * {\n * // Other configurations\n * editor: {\n * enabled: process.env.NODE_ENV !== 'production',\n * }\n * };\n * ```\n */\n enabled: customConfiguration?.enabled ?? IS_ENABLED,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientId: customConfiguration?.clientId ?? undefined,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientSecret: customConfiguration?.clientSecret ?? undefined,\n\n /**\n * Strategy for prioritizing dictionaries. If a dictionary is both present online and locally, the content will be merge.\n * However, is a field is defined in both dictionary, this setting determines which fields takes the priority over the other.\n *\n * Default: 'local_first'\n *\n * The strategy for prioritizing dictionaries. It can be either 'local_first' or 'distant_first'.\n * - 'local_first': The first dictionary found in the locale is used.\n * - 'distant_first': The first dictionary found in the distant locales is used.\n */\n dictionaryPriorityStrategy:\n customConfiguration?.dictionaryPriorityStrategy ??\n DICTIONARY_PRIORITY_STRATEGY,\n\n /**\n * Indicates if the application should hot reload the locale configurations when a change is detected.\n * For example, when a new dictionary is added or updated, the application will update the content tu display in the page.\n *\n * The hot reload is only available for clients of the `enterprise` plan.\n *\n * Default: false\n */\n liveSync: customConfiguration?.liveSync ?? LIVE_SYNC,\n\n /**\n * Port of the live sync server\n *\n * Default: 4000\n */\n liveSyncPort: customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT,\n\n /**\n * URL of the live sync server in case of remote live sync server\n *\n * Default: `http://localhost:${LIVE_SYNC_PORT}`\n */\n liveSyncURL:\n customConfiguration?.liveSyncURL ??\n `http://localhost:${customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT}`,\n});\n\nconst buildLogFields = (\n customConfiguration?: Partial<LogConfig>,\n logFunctions?: LogFunctions\n): LogConfig => ({\n /**\n * Indicates if the logger is enabled\n *\n * Default: 'prefix-no-default'\n *\n * If 'default', the logger is enabled and can be used.\n * If 'verbose', the logger will be enabled and can be used, but will log more information.\n * If 'disabled', the logger is disabled and cannot be used.\n */\n mode: customConfiguration?.mode ?? MODE,\n\n /**\n * Prefix of the logger\n *\n * Default: '[intlayer]'\n *\n * The prefix of the logger.\n */\n prefix: customConfiguration?.prefix ?? PREFIX,\n\n /**\n * Functions to log\n */\n error: logFunctions?.error,\n log: logFunctions?.log,\n info: logFunctions?.info,\n warn: logFunctions?.warn,\n});\n\nconst buildAiFields = (customConfiguration?: Partial<AiConfig>): AiConfig => ({\n /**\n * AI configuration\n */\n provider: customConfiguration?.provider,\n\n /**\n * API key\n */\n apiKey: customConfiguration?.apiKey,\n\n /**\n * API model\n */\n model: customConfiguration?.model,\n\n /**\n * Temperature\n */\n temperature: customConfiguration?.temperature,\n\n /**\n * Application context\n *\n * Default: undefined\n *\n * The application context.\n *\n * Example: `'My application context'`\n *\n * Note: Can be used to provide additional context about the application to the AI model. You can add more rules (e.g. \"You should not transform urls\").\n */\n applicationContext: customConfiguration?.applicationContext,\n\n /**\n * Base URL for the AI API\n *\n * Default: undefined\n *\n * The base URL for the AI API.\n *\n * Example: `'http://localhost:5000'`\n *\n * Note: Can be used to point to a local, or custom AI API endpoint.\n */\n baseURL: customConfiguration?.baseURL,\n\n /**\n * Data serialization\n *\n * Options:\n * - \"json\": The industry standard. Highly reliable and structured, but consumes more tokens.\n * - \"toon\": An optimized format designed to reduce token consumption (cost-effective). However, it may slightly increase the risk of output inconsistency compared to standard JSON\n *\n * Default: \"json\"\n */\n dataSerialization: customConfiguration?.dataSerialization,\n});\n\nconst buildBuildFields = (\n customConfiguration?: Partial<BuildConfig>\n): BuildConfig => ({\n /**\n * Indicates the mode of the build\n *\n * Default: 'auto'\n *\n * If 'auto', the build will be enabled automatically when the application is built.\n * If 'manual', the build will be set only when the build command is executed.\n *\n * Can be used to disable dictionaries build, for instance when execution on Node.js environment should be avoided.\n */\n mode: customConfiguration?.mode ?? BUILD_MODE,\n\n /**\n * Indicates if the build should be optimized\n *\n * Default: process.env.NODE_ENV === 'production'\n *\n * If true, the build will be optimized.\n * If false, the build will not be optimized.\n *\n * Intlayer will replace all calls of dictionaries to optimize chunking. That way the final bundle will import only the dictionaries that are used.\n * All imports will stay as static import to avoid async processing when loading the dictionaries.\n *\n * Note:\n * - Intlayer will replace all call of `useIntlayer` with the defined mode by the `importMode` option.\n * - Intlayer will replace all call of `getIntlayer` with `getDictionary`.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - In most cases, \"dynamic\" will be used for React applications, \"async\" for Vue.js applications.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n */\n optimize: customConfiguration?.optimize,\n\n /**\n * Indicates the mode of import to use for the dictionaries.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionary`.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * Live mode will use the live sync API to fetch the dictionaries. If the API call fails, the dictionaries will be imported dynamically as \"dynamic\" mode.\n *\n * Default: \"static\"\n *\n * By default, when a dictionary is loaded, it imports content for all locales as it's imported statically.\n *\n * Note:\n * - Dynamic imports rely on Suspense and may slightly impact rendering performance.\n * - If disabled all locales will be loaded at once, even if they are not used.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n * - This option will be ignored if `optimize` is disabled.\n * - This option will not impact the `getIntlayer`, `getDictionary`, `useDictionary`, `useDictionaryAsync` and `useDictionaryDynamic` functions. You can still use them to refine you code on manual optimization.\n * - The \"live\" allows to sync the dictionaries to the live sync server.\n *\n * @deprecated Use `dictionary.importMode` instead.\n */\n importMode: customConfiguration?.importMode,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * Allows to avoid to traverse the code that is not relevant to the optimization.\n * Improve build performance.\n *\n * Default: ['**\\/*.{js,ts,mjs,cjs,jsx,tsx}', '!**\\/node_modules/**']\n *\n * Example: `['src/**\\/*.{ts,tsx}', '../ui-library/**\\/*.{ts,tsx}']`\n *\n * Note:\n * - This option will be ignored if `optimize` is disabled.\n * - Use glob pattern.\n */\n traversePattern: customConfiguration?.traversePattern ?? TRAVERSE_PATTERN,\n\n /**\n * Output format of the dictionaries\n *\n * Can be set on large projects to improve build performance.\n *\n * Default: ['cjs', 'esm']\n *\n * The output format of the dictionaries. It can be either 'cjs' or 'esm'.\n * - 'cjs': The dictionaries are outputted as CommonJS modules.\n * - 'esm': The dictionaries are outputted as ES modules.\n */\n outputFormat: customConfiguration?.outputFormat ?? OUTPUT_FORMAT,\n\n /**\n * Cache\n */\n cache: customConfiguration?.cache ?? CACHE,\n\n /**\n * Require function\n */\n require: customConfiguration?.require,\n\n /**\n * Indicates if the build should check TypeScript types\n *\n * Default: false\n *\n * If true, the build will check TypeScript types and log errors.\n * Note: This can slow down the build.\n */\n checkTypes: customConfiguration?.checkTypes ?? TYPE_CHECKING,\n});\n\nconst buildCompilerFields = (\n customConfiguration?: Partial<CompilerConfig>\n): CompilerConfig => ({\n /**\n * Indicates if the compiler should be enabled\n */\n enabled: customConfiguration?.enabled ?? COMPILER_ENABLED,\n\n /**\n * Prefix for the extracted dictionary keys\n */\n dictionaryKeyPrefix:\n customConfiguration?.dictionaryKeyPrefix ?? COMPILER_DICTIONARY_KEY_PREFIX,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * @deprecated use build.traversePattern instead\n */\n transformPattern: customConfiguration?.transformPattern,\n\n /**\n * Pattern to exclude from the optimization.\n *\n * @deprecated use build.traversePattern instead\n */\n excludePattern: customConfiguration?.excludePattern,\n\n /**\n * Output directory for the optimized dictionaries.\n * @deprecated use `output` instead\n */\n outputDir: customConfiguration?.outputDir,\n\n /**\n * File path pattern for generated dictionaries.\n */\n output: customConfiguration?.output,\n\n /**\n * Indicates if the metadata should be saved in the file.\n *\n * If true, the compiler will not save the metadata of the dictionaries.\n *\n * If true:\n *\n * ```json\n * {\n * \"key\": \"value\"\n * }\n * ```\n *\n * If false:\n *\n * ```json\n * {\n * \"key\": \"value\",\n * \"content\": {\n * \"key\": \"value\"\n * }\n * }\n * ```\n *\n * Default: false\n *\n * Note: Useful if used with loadJSON plugin\n */\n noMetadata: customConfiguration?.noMetadata ?? COMPILER_NO_METADATA,\n\n /**\n * Indicates if the components should be saved after being transformed.\n */\n saveComponents:\n customConfiguration?.saveComponents ?? COMPILER_SAVE_COMPONENTS,\n});\n\nconst buildDictionaryFields = (\n customConfiguration?: Partial<DictionaryConfig>\n): DictionaryConfig => {\n const contentAutoTransformation =\n customConfiguration?.contentAutoTransformation ??\n CONTENT_AUTO_TRANSFORMATION;\n\n return {\n /**\n * Indicate how the dictionary should be filled using AI.\n *\n * Default: true\n */\n fill: customConfiguration?.fill ?? FILL,\n\n /**\n * Indicates if the content of the dictionary should be automatically transformed.\n *\n * Default: false\n */\n contentAutoTransformation:\n typeof contentAutoTransformation === 'object'\n ? {\n markdown: contentAutoTransformation.markdown ?? false,\n html: contentAutoTransformation.html ?? false,\n insertion: contentAutoTransformation.insertion ?? false,\n }\n : contentAutoTransformation,\n\n /**\n * The location of the dictionary.\n *\n * Default: 'local'\n */\n location: customConfiguration?.location ?? LOCATION,\n\n /**\n * Transform the dictionary in a per-locale dictionary.\n * Each field declared in a per-locale dictionary will be transformed in a translation node.\n * If missing, the dictionary will be treated as a multilingual dictionary.\n */\n locale: customConfiguration?.locale,\n\n /**\n * The title of the dictionary.\n */\n title: customConfiguration?.title,\n\n /**\n * The description of the dictionary.\n */\n description: customConfiguration?.description,\n\n /**\n * Tags to categorize the dictionaries.\n */\n tags: customConfiguration?.tags,\n\n /**\n * The priority of the dictionary.\n */\n priority: customConfiguration?.priority,\n\n /**\n * Indicates the mode of import to use for the dictionary.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n *\n * Default: 'static'\n */\n importMode: customConfiguration?.importMode ?? IMPORT_MODE,\n\n /**\n * The version of the dictionary.\n */\n version: customConfiguration?.version,\n };\n};\n\n/**\n * Build the configuration fields by merging the default values with the custom configuration\n */\nexport const buildConfigurationFields = (\n customConfiguration?: CustomIntlayerConfig,\n baseDir?: string,\n logFunctions?: LogFunctions\n): IntlayerConfig => {\n const internationalizationConfig = buildInternationalizationFields(\n customConfiguration?.internationalization\n );\n\n const routingConfig = buildRoutingFields(customConfiguration?.routing);\n\n const systemConfig = buildSystemFields(baseDir, customConfiguration?.system);\n\n const contentConfig = buildContentFields(\n systemConfig,\n customConfiguration?.content\n );\n\n const editorConfig = buildEditorFields(customConfiguration?.editor);\n\n const logConfig = buildLogFields(customConfiguration?.log, logFunctions);\n\n const aiConfig = buildAiFields(customConfiguration?.ai);\n\n const buildConfig = buildBuildFields(customConfiguration?.build);\n\n const compilerConfig = buildCompilerFields(customConfiguration?.compiler);\n\n const dictionaryConfig = buildDictionaryFields(\n customConfiguration?.dictionary\n );\n\n storedConfiguration = {\n internationalization: internationalizationConfig,\n routing: routingConfig,\n content: contentConfig,\n system: systemConfig,\n editor: editorConfig,\n log: logConfig,\n ai: aiConfig,\n build: buildConfig,\n compiler: compilerConfig,\n dictionary: dictionaryConfig,\n plugins: customConfiguration?.plugins,\n schemas: customConfiguration?.schemas,\n metadata: {\n name: 'Intlayer',\n version: packageJson.version,\n doc: `https://intlayer.org/docs`,\n },\n } as IntlayerConfig;\n\n return storedConfiguration;\n};\n"],"mappings":"+rBAgFA,IAAI,EAEJ,MAAM,EACJ,IACgC,CAOhC,QAAS,GAAqB,SAAWA,EAAAA,QAWzC,gBACE,GAAqB,iBACrB,GAAqB,SACrBC,EAAAA,iBAUF,WAAY,GAAqB,YAAA,YAOjC,cAAe,GAAqB,eAAiBC,EAAAA,eACtD,EAEK,EACJ,IACmB,CAuBnB,KAAM,GAAqB,MAAA,oBAW3B,QAAS,GAAqB,SAAWC,EAAAA,QAazC,SAAU,GAAqB,UAAA,GA6B/B,QAAS,GAAqB,QAC/B,EAEK,GACJ,EACA,IACiB,CACjB,IAAM,EAAiB,GAAW,QAAQ,KAAK,CAEzC,EAAuB,GAAsB,CACjD,IAAI,EAEJ,GAAI,CAGF,EAFwBC,EAAAA,kBAAkB,EAAe,CAE1B,QAAQ,EAAW,CAChD,MAAO,CAAC,EAAe,CACxB,CAAC,MACI,CACN,GAAA,EAAA,EAAA,YAA0B,EAAU,CAChC,GAAA,EAAA,EAAA,MACK,EAAgB,EAAU,CAGrC,GAAI,CAEF,IAAA,EAAA,EAAA,UADuB,EAAa,CAC1B,QAAQ,CAChB,OAAA,EAAA,EAAA,SAAe,EAAa,MAExB,CACN,GAAI,gBAAgB,KAAK,EAAa,CACpC,OAAA,EAAA,EAAA,SAAe,EAAa,CAIhC,OAAO,GAGH,EAAkB,EACtB,GAAqB,iBAAA,uBACtB,CAED,MAAO,CACL,QAAS,EACT,sBAAuB,EACrB,GAAqB,uBAAA,kBACtB,CACD,wBAAyB,EACvB,GAAqB,yBAAA,gCACtB,CACD,sBAAuB,EACrB,GAAqB,uBAAA,8BACtB,CACD,kBACA,uBAAwB,EACtB,GAAqB,wBAAA,+BACtB,CACD,qBAAsB,EACpB,GAAqB,sBAAA,6BACtB,CACD,SAAU,EAAoB,GAAqB,UAAA,kBAAsB,CACzE,QAAS,EAAoB,GAAqB,SAAA,iBAAoB,CACtE,UAAW,EACT,GAAqB,WAAA,mBACtB,CACD,SAAU,EAAoB,GAAqB,UAAA,kBAAsB,CACzE,QAAS,EAAoB,GAAqB,SAAA,gBAAoB,CACtE,2BAA4B,GAAGC,EAAAA,cAAc,EAAgB,CAAC,YAC/D,EAGG,GACJ,EACA,IACkB,CAClB,IAAM,EAAiB,GAAqB,gBAAkBC,EAAAA,gBAExD,EAAuB,GAAsB,CACjD,IAAI,EAEJ,GAAI,CAGF,EADwBF,EAAAA,kBAAkB,EAAa,QAAQ,CAChC,QAAQ,EAAW,CAChD,MAAO,CAAC,EAAa,QAAQ,CAC9B,CAAC,MACI,CACN,GAAI,CAEF,EAAe,QAAQ,QAAQ,EAAW,CACxC,MAAO,CAAC,EAAa,QAAQ,CAC9B,CAAC,MACI,CAEN,GAAA,EAAA,EAAA,YAA0B,EAAU,CAChC,GAAA,EAAA,EAAA,MACK,EAAa,QAAS,EAAU,EAI7C,GAAI,CAMF,IAAA,EAAA,EAAA,UAJuB,EAAa,CAI1B,QAAQ,CAChB,OAAA,EAAA,EAAA,SAAe,EAAa,MAExB,CAGN,GAAI,gBAAgB,KAAK,EAAa,CACpC,OAAA,EAAA,EAAA,SAAe,EAAa,CAKhC,OAAO,GAGH,GAAc,GAAqB,YAAcG,EAAAA,aAAa,IAClE,EACD,CAMD,MAAO,CACL,iBACA,aACA,SAPmB,GAAqB,SAETC,EAAAA,UAAU,IAAI,EAAoB,CAMjE,aAAc,GAAqB,cAAgBC,EAAAA,eACnD,MAAO,GAAqB,OAAA,GAC5B,cAAe,GAAqB,cACpC,oBAAqB,EAAe,IAAK,GAAQ,QAAQ,IAAM,CAC/D,4BAA6B,EAAe,QAAS,GACnD,EAAW,IAAK,GAAQ,GAAGJ,EAAAA,cAAc,EAAI,CAAC,OAAO,IAAM,CAC5D,CACF,EAGG,EACJ,IACkB,CAQlB,eAAgB,GAAqB,gBAAA,IAAA,GASrC,UAAW,GAAqB,WAAA,wBAKhC,OAAQ,GAAqB,QAAA,2BAO7B,WAAY,GAAqB,YAAA,4BAMjC,KAAM,GAAqB,MAAA,IAsB3B,QAAS,GAAqB,SAAA,GAW9B,SAAU,GAAqB,UAAY,IAAA,GAW3C,aAAc,GAAqB,cAAgB,IAAA,GAYnD,2BACE,GAAqB,4BAAA,cAWvB,SAAU,GAAqB,UAAA,GAO/B,aAAc,GAAqB,cAAA,IAOnC,YACE,GAAqB,aACrB,oBAAoB,GAAqB,cAAA,MAC5C,EAEK,GACJ,EACA,KACe,CAUf,KAAM,GAAqB,MAAA,UAS3B,OAAQ,GAAqB,QAAUK,EAAAA,OAKvC,MAAO,GAAc,MACrB,IAAK,GAAc,IACnB,KAAM,GAAc,KACpB,KAAM,GAAc,KACrB,EAEK,EAAiB,IAAuD,CAI5E,SAAU,GAAqB,SAK/B,OAAQ,GAAqB,OAK7B,MAAO,GAAqB,MAK5B,YAAa,GAAqB,YAalC,mBAAoB,GAAqB,mBAazC,QAAS,GAAqB,QAW9B,kBAAmB,GAAqB,kBACzC,EAEK,EACJ,IACiB,CAWjB,KAAM,GAAqB,MAAA,OAoB3B,SAAU,GAAqB,SA6B/B,WAAY,GAAqB,WAgBjC,gBAAiB,GAAqB,iBAAmBC,EAAAA,iBAazD,aAAc,GAAqB,cAAgBC,EAAAA,cAKnD,MAAO,GAAqB,OAAA,GAK5B,QAAS,GAAqB,QAU9B,WAAY,GAAqB,YAAA,GAClC,EAEK,EACJ,IACoB,CAIpB,QAAS,GAAqB,SAAA,GAK9B,oBACE,GAAqB,qBAAA,QAOvB,iBAAkB,GAAqB,iBAOvC,eAAgB,GAAqB,eAMrC,UAAW,GAAqB,UAKhC,OAAQ,GAAqB,OA8B7B,WAAY,GAAqB,YAAA,GAKjC,eACE,GAAqB,gBAAA,GACxB,EAEK,EACJ,GACqB,CACrB,IAAM,EACJ,GAAqB,2BAAA,GAGvB,MAAO,CAML,KAAM,GAAqB,MAAA,GAO3B,0BACE,OAAO,GAA8B,SACjC,CACE,SAAU,EAA0B,UAAY,GAChD,KAAM,EAA0B,MAAQ,GACxC,UAAW,EAA0B,WAAa,GACnD,CACD,EAON,SAAU,GAAqB,UAAA,QAO/B,OAAQ,GAAqB,OAK7B,MAAO,GAAqB,MAK5B,YAAa,GAAqB,YAKlC,KAAM,GAAqB,KAK3B,SAAU,GAAqB,SAY/B,WAAY,GAAqB,YAAA,SAKjC,QAAS,GAAqB,QAC/B,EAMU,GACX,EACA,EACA,IACmB,CACnB,IAAM,EAA6B,EACjC,GAAqB,qBACtB,CAEK,EAAgB,EAAmB,GAAqB,QAAQ,CAEhE,EAAe,EAAkB,EAAS,GAAqB,OAAO,CAyC5E,MApBA,GAAsB,CACpB,qBAAsB,EACtB,QAAS,EACT,QAtBoB,EACpB,EACA,GAAqB,QACtB,CAoBC,OAAQ,EACR,OAnBmB,EAAkB,GAAqB,OAAO,CAoBjE,IAlBgB,EAAe,GAAqB,IAAK,EAAa,CAmBtE,GAjBe,EAAc,GAAqB,GAAG,CAkBrD,MAhBkB,EAAiB,GAAqB,MAAM,CAiB9D,SAfqB,EAAoB,GAAqB,SAAS,CAgBvE,WAduB,EACvB,GAAqB,WACtB,CAaC,QAAS,GAAqB,QAC9B,QAAS,GAAqB,QAC9B,SAAU,CACR,KAAM,WACN,QAASC,EAAAA,QAAY,QACrB,IAAK,4BACN,CACF,CAEM"}
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`../_virtual/_rolldown/runtime.cjs`);let e=require(`@intlayer/types/config`),t=require(`zod`);const n=t.z.object({locales:t.z.array(t.z.string()).min(1),requiredLocales:t.z.array(t.z.string()).optional(),strictMode:t.z.enum([`strict`,`inclusive`,`loose`]).optional(),defaultLocale:t.z.string().optional()}),r=t.z.object({type:t.z.literal(`cookie`),name:t.z.string().optional(),domain:t.z.string().optional(),path:t.z.string().optional(),secure:t.z.boolean().optional(),httpOnly:t.z.boolean().optional(),sameSite:t.z.enum([`strict`,`lax`,`none`]).optional(),expires:t.z.union([t.z.date(),t.z.number()]).optional()}),i=t.z.object({type:t.z.enum([`localStorage`,`sessionStorage`,`header`]),name:t.z.string().optional()}),a=t.z.union([t.z.literal(!1),t.z.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i,t.z.array(t.z.union([t.z.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i]))]),o=t.z.object({canonical:t.z.string(),localized:t.z.record(t.z.string(),t.z.string())}),s=t.z.object({rules:t.z.array(o)}),c=t.z.object({url:s,nextjs:s.optional(),vite:s.optional()}),l=t.z.object({rewrite:t.z.union([t.z.record(t.z.string(),t.z.record(t.z.string(),t.z.string())),c]).optional(),mode:t.z.enum([`prefix-no-default`,`prefix-all`,`no-prefix`,`search-params`]).optional(),storage:a.optional(),basePath:t.z.string().optional()}),u=t.z.object({fileExtensions:t.z.array(t.z.string()).optional(),baseDir:t.z.string().optional(),contentDir:t.z.array(t.z.string()).optional(),codeDir:t.z.array(t.z.string()).optional(),excludedPath:t.z.array(t.z.string()).optional(),watch:t.z.boolean().optional(),formatCommand:t.z.string().optional(),watchedFilesPattern:t.z.array(t.z.string()).optional(),watchedFilesPatternWithPath:t.z.array(t.z.string()).optional()}),d=t.z.object({moduleAugmentationDir:t.z.string().optional(),unmergedDictionariesDir:t.z.string().optional(),remoteDictionariesDir:t.z.string().optional(),dictionariesDir:t.z.string().optional(),dynamicDictionariesDir:t.z.string().optional(),fetchDictionariesDir:t.z.string().optional(),typesDir:t.z.string().optional(),mainDir:t.z.string().optional(),configDir:t.z.string().optional(),cacheDir:t.z.string().optional(),tempDir:t.z.string().optional(),outputFilesPatternWithPath:t.z.string().optional()}),f=t.z.object({applicationURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),editorURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),cmsURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),backendURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),port:t.z.number().int().positive().max(65535).optional(),enabled:t.z.boolean().optional(),clientId:t.z.string().optional(),clientSecret:t.z.string().optional(),dictionaryPriorityStrategy:t.z.enum([`local_first`,`distant_first`]).optional(),liveSync:t.z.boolean().optional(),liveSyncPort:t.z.number().int().positive().max(65535).optional(),liveSyncURL:t.z.union([t.z.url(),t.z.literal(``)]).optional()}),p=t.z.object({mode:t.z.enum([`default`,`verbose`,`disabled`]).optional(),prefix:t.z.string().optional(),error:t.z.function().optional(),log:t.z.function().optional(),info:t.z.function().optional(),warn:t.z.function().optional()}),m=t.z.object({provider:t.z.enum(e.AiProviders).optional(),apiKey:t.z.string().optional(),model:t.z.string().optional(),temperature:t.z.number().min(0).max(2).optional(),applicationContext:t.z.string().optional(),baseURL:t.z.url().optional(),dataSerialization:t.z.enum([`json`,`toon`]).optional()}),h=t.z.object({mode:t.z.enum([`auto`,`manual`]).optional(),optimize:t.z.boolean().optional(),importMode:t.z.enum([`static`,`dynamic`,`fetch`]).optional(),traversePattern:t.z.array(t.z.string()).optional(),outputFormat:t.z.array(t.z.enum([`cjs`,`esm`])).optional(),cache:t.z.boolean().optional(),require:t.z.unknown().optional(),checkTypes:t.z.boolean().optional()}),g=t.z.object({enabled:t.z.union([t.z.boolean(),t.z.literal(`build-only`)]).optional(),dictionaryKeyPrefix:t.z.string().optional(),transformPattern:t.z.union([t.z.string(),t.z.array(t.z.string())]).optional(),excludePattern:t.z.union([t.z.string(),t.z.array(t.z.string())]).optional(),outputDir:t.z.string().optional(),output:t.z.unknown().optional(),noMetadata:t.z.boolean().optional(),saveComponents:t.z.boolean().optional()}),_=t.z.object({fill:t.z.unknown().optional(),contentAutoTransformation:t.z.union([t.z.boolean(),t.z.object({markdown:t.z.boolean().optional(),html:t.z.boolean().optional(),insertion:t.z.boolean().optional()})]).optional(),location:t.z.string().optional(),locale:t.z.string().optional(),title:t.z.string().optional()}),v=t.z.object({internationalization:n.optional(),routing:l.optional(),content:u.optional(),system:d.optional(),editor:f.optional(),log:p.optional(),ai:m.optional(),build:h.optional(),compiler:g.optional(),dictionary:_.optional(),plugins:t.z.array(t.z.unknown()).optional(),schemas:t.z.record(t.z.string(),t.z.unknown()).optional(),metadata:t.z.object({name:t.z.string().optional(),version:t.z.string().optional(),doc:t.z.string().optional()}).optional()});exports.aiSchema=m,exports.buildSchema=h,exports.compilerSchema=g,exports.contentSchema=u,exports.cookiesAttributesSchema=r,exports.dictionarySchema=_,exports.editorSchema=f,exports.internationalizationSchema=n,exports.intlayerConfigSchema=v,exports.logSchema=p,exports.rewriteObjectSchema=c,exports.rewriteRuleSchema=o,exports.rewriteRulesSchema=s,exports.routingSchema=l,exports.storageAttributesSchema=i,exports.storageSchema=a,exports.systemSchema=d;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`../_virtual/_rolldown/runtime.cjs`);let e=require(`@intlayer/types/config`),t=require(`zod`);const n=t.z.object({locales:t.z.array(t.z.string()).min(1),requiredLocales:t.z.array(t.z.string()).optional(),strictMode:t.z.enum([`strict`,`inclusive`,`loose`]).optional(),defaultLocale:t.z.string().optional()}),r=t.z.object({type:t.z.literal(`cookie`),name:t.z.string().optional(),domain:t.z.string().optional(),path:t.z.string().optional(),secure:t.z.boolean().optional(),httpOnly:t.z.boolean().optional(),sameSite:t.z.enum([`strict`,`lax`,`none`]).optional(),expires:t.z.union([t.z.date(),t.z.number()]).optional()}),i=t.z.object({type:t.z.enum([`localStorage`,`sessionStorage`,`header`]),name:t.z.string().optional()}),a=t.z.union([t.z.literal(!1),t.z.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i,t.z.array(t.z.union([t.z.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i]))]),o=t.z.object({canonical:t.z.string(),localized:t.z.record(t.z.string(),t.z.string())}),s=t.z.object({rules:t.z.array(o)}),c=t.z.object({url:s,nextjs:s.optional(),vite:s.optional()}),l=t.z.object({rewrite:t.z.union([t.z.record(t.z.string(),t.z.record(t.z.string(),t.z.string())),c]).optional(),mode:t.z.enum([`prefix-no-default`,`prefix-all`,`no-prefix`,`search-params`]).optional(),storage:a.optional(),basePath:t.z.string().optional()}),u=t.z.object({baseDir:t.z.string().optional(),moduleAugmentationDir:t.z.string().optional(),unmergedDictionariesDir:t.z.string().optional(),remoteDictionariesDir:t.z.string().optional(),dictionariesDir:t.z.string().optional(),dynamicDictionariesDir:t.z.string().optional(),fetchDictionariesDir:t.z.string().optional(),typesDir:t.z.string().optional(),mainDir:t.z.string().optional(),configDir:t.z.string().optional(),cacheDir:t.z.string().optional(),tempDir:t.z.string().optional(),outputFilesPatternWithPath:t.z.string().optional()}),d=t.z.object({fileExtensions:t.z.array(t.z.string()).optional(),contentDir:t.z.array(t.z.string()).optional(),codeDir:t.z.array(t.z.string()).optional(),excludedPath:t.z.array(t.z.string()).optional(),watch:t.z.boolean().optional(),formatCommand:t.z.string().optional(),watchedFilesPattern:t.z.array(t.z.string()).optional(),watchedFilesPatternWithPath:t.z.array(t.z.string()).optional()}),f=t.z.object({applicationURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),editorURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),cmsURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),backendURL:t.z.union([t.z.url(),t.z.literal(``)]).optional(),port:t.z.number().int().positive().max(65535).optional(),enabled:t.z.boolean().optional(),clientId:t.z.string().optional(),clientSecret:t.z.string().optional(),dictionaryPriorityStrategy:t.z.enum([`local_first`,`distant_first`]).optional(),liveSync:t.z.boolean().optional(),liveSyncPort:t.z.number().int().positive().max(65535).optional(),liveSyncURL:t.z.union([t.z.url(),t.z.literal(``)]).optional()}),p=t.z.object({mode:t.z.enum([`default`,`verbose`,`disabled`]).optional(),prefix:t.z.string().optional(),error:t.z.function().optional(),log:t.z.function().optional(),info:t.z.function().optional(),warn:t.z.function().optional()}),m=t.z.object({provider:t.z.enum(e.AiProviders).optional(),apiKey:t.z.string().optional(),model:t.z.string().optional(),temperature:t.z.number().min(0).max(2).optional(),applicationContext:t.z.string().optional(),baseURL:t.z.url().optional(),dataSerialization:t.z.enum([`json`,`toon`]).optional()}),h=t.z.object({mode:t.z.enum([`auto`,`manual`]).optional(),optimize:t.z.boolean().optional(),importMode:t.z.enum([`static`,`dynamic`,`fetch`]).optional(),traversePattern:t.z.array(t.z.string()).optional(),outputFormat:t.z.array(t.z.enum([`cjs`,`esm`])).optional(),cache:t.z.boolean().optional(),require:t.z.unknown().optional(),checkTypes:t.z.boolean().optional()}),g=t.z.object({enabled:t.z.union([t.z.boolean(),t.z.literal(`build-only`)]).optional(),dictionaryKeyPrefix:t.z.string().optional(),transformPattern:t.z.union([t.z.string(),t.z.array(t.z.string())]).optional(),excludePattern:t.z.union([t.z.string(),t.z.array(t.z.string())]).optional(),outputDir:t.z.string().optional(),output:t.z.unknown().optional(),noMetadata:t.z.boolean().optional(),saveComponents:t.z.boolean().optional()}),_=t.z.object({fill:t.z.unknown().optional(),contentAutoTransformation:t.z.union([t.z.boolean(),t.z.object({markdown:t.z.boolean().optional(),html:t.z.boolean().optional(),insertion:t.z.boolean().optional()})]).optional(),location:t.z.string().optional(),locale:t.z.string().optional(),title:t.z.string().optional()}),v=t.z.object({internationalization:n.optional(),routing:l.optional(),content:d.optional(),system:u.optional(),editor:f.optional(),log:p.optional(),ai:m.optional(),build:h.optional(),compiler:g.optional(),dictionary:_.optional(),plugins:t.z.array(t.z.unknown()).optional(),schemas:t.z.record(t.z.string(),t.z.unknown()).optional(),metadata:t.z.object({name:t.z.string().optional(),version:t.z.string().optional(),doc:t.z.string().optional()}).optional()});exports.aiSchema=m,exports.buildSchema=h,exports.compilerSchema=g,exports.contentSchema=d,exports.cookiesAttributesSchema=r,exports.dictionarySchema=_,exports.editorSchema=f,exports.internationalizationSchema=n,exports.intlayerConfigSchema=v,exports.logSchema=p,exports.rewriteObjectSchema=c,exports.rewriteRuleSchema=o,exports.rewriteRulesSchema=s,exports.routingSchema=l,exports.storageAttributesSchema=i,exports.storageSchema=a,exports.systemSchema=u;
2
2
  //# sourceMappingURL=configurationSchema.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"configurationSchema.cjs","names":["z","AiProviders"],"sources":["../../../src/configFile/configurationSchema.ts"],"sourcesContent":["import { AiProviders } from '@intlayer/types/config';\nimport { z } from 'zod';\n\nexport const internationalizationSchema = z.object({\n locales: z.array(z.string()).min(1),\n requiredLocales: z.array(z.string()).optional(),\n strictMode: z.enum(['strict', 'inclusive', 'loose']).optional(),\n defaultLocale: z.string().optional(),\n});\n\nexport const cookiesAttributesSchema = z.object({\n type: z.literal('cookie'),\n name: z.string().optional(),\n domain: z.string().optional(),\n path: z.string().optional(),\n secure: z.boolean().optional(),\n httpOnly: z.boolean().optional(),\n sameSite: z.enum(['strict', 'lax', 'none']).optional(),\n expires: z.union([z.date(), z.number()]).optional(),\n});\n\nexport const storageAttributesSchema = z.object({\n type: z.enum(['localStorage', 'sessionStorage', 'header']),\n name: z.string().optional(),\n});\n\nexport const storageSchema = z.union([\n z.literal(false),\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n z.array(\n z.union([\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n ])\n ),\n]);\n\nexport const rewriteRuleSchema = z.object({\n canonical: z.string(),\n localized: z.record(z.string(), z.string()),\n});\n\nexport const rewriteRulesSchema = z.object({\n rules: z.array(rewriteRuleSchema),\n});\n\nexport const rewriteObjectSchema = z.object({\n url: rewriteRulesSchema,\n nextjs: rewriteRulesSchema.optional(),\n vite: rewriteRulesSchema.optional(),\n});\n\nexport const routingSchema = z.object({\n rewrite: z\n .union([\n z.record(z.string(), z.record(z.string(), z.string())),\n rewriteObjectSchema,\n ])\n .optional(),\n mode: z\n .enum(['prefix-no-default', 'prefix-all', 'no-prefix', 'search-params'])\n .optional(),\n storage: storageSchema.optional(),\n basePath: z.string().optional(),\n});\n\nexport const contentSchema = z.object({\n fileExtensions: z.array(z.string()).optional(),\n baseDir: z.string().optional(),\n contentDir: z.array(z.string()).optional(),\n codeDir: z.array(z.string()).optional(),\n excludedPath: z.array(z.string()).optional(),\n watch: z.boolean().optional(),\n formatCommand: z.string().optional(),\n watchedFilesPattern: z.array(z.string()).optional(),\n watchedFilesPatternWithPath: z.array(z.string()).optional(),\n});\n\nexport const systemSchema = z.object({\n moduleAugmentationDir: z.string().optional(),\n unmergedDictionariesDir: z.string().optional(),\n remoteDictionariesDir: z.string().optional(),\n dictionariesDir: z.string().optional(),\n dynamicDictionariesDir: z.string().optional(),\n fetchDictionariesDir: z.string().optional(),\n typesDir: z.string().optional(),\n mainDir: z.string().optional(),\n configDir: z.string().optional(),\n cacheDir: z.string().optional(),\n tempDir: z.string().optional(),\n outputFilesPatternWithPath: z.string().optional(),\n});\n\nexport const editorSchema = z.object({\n applicationURL: z.union([z.url(), z.literal('')]).optional(),\n editorURL: z.union([z.url(), z.literal('')]).optional(),\n cmsURL: z.union([z.url(), z.literal('')]).optional(),\n backendURL: z.union([z.url(), z.literal('')]).optional(),\n port: z.number().int().positive().max(65535).optional(),\n enabled: z.boolean().optional(),\n clientId: z.string().optional(),\n clientSecret: z.string().optional(),\n dictionaryPriorityStrategy: z\n .enum(['local_first', 'distant_first'])\n .optional(),\n liveSync: z.boolean().optional(),\n liveSyncPort: z.number().int().positive().max(65535).optional(),\n liveSyncURL: z.union([z.url(), z.literal('')]).optional(),\n});\n\nexport const logSchema = z.object({\n mode: z.enum(['default', 'verbose', 'disabled']).optional(),\n prefix: z.string().optional(),\n error: z.function().optional(),\n log: z.function().optional(),\n info: z.function().optional(),\n warn: z.function().optional(),\n});\n\nexport const aiSchema = z.object({\n provider: z.enum(AiProviders).optional(),\n apiKey: z.string().optional(),\n model: z.string().optional(),\n temperature: z.number().min(0).max(2).optional(),\n applicationContext: z.string().optional(),\n baseURL: z.url().optional(),\n dataSerialization: z.enum(['json', 'toon']).optional(),\n});\n\nexport const buildSchema = z.object({\n mode: z.enum(['auto', 'manual']).optional(),\n optimize: z.boolean().optional(),\n importMode: z.enum(['static', 'dynamic', 'fetch']).optional(),\n traversePattern: z.array(z.string()).optional(),\n outputFormat: z.array(z.enum(['cjs', 'esm'])).optional(),\n cache: z.boolean().optional(),\n require: z.unknown().optional(),\n checkTypes: z.boolean().optional(),\n});\n\nexport const compilerSchema = z.object({\n enabled: z.union([z.boolean(), z.literal('build-only')]).optional(),\n dictionaryKeyPrefix: z.string().optional(),\n transformPattern: z.union([z.string(), z.array(z.string())]).optional(),\n excludePattern: z.union([z.string(), z.array(z.string())]).optional(),\n outputDir: z.string().optional(),\n output: z.unknown().optional(),\n noMetadata: z.boolean().optional(),\n saveComponents: z.boolean().optional(),\n});\n\nexport const dictionarySchema = z.object({\n fill: z.unknown().optional(),\n contentAutoTransformation: z\n .union([\n z.boolean(),\n z.object({\n markdown: z.boolean().optional(),\n html: z.boolean().optional(),\n insertion: z.boolean().optional(),\n }),\n ])\n .optional(),\n location: z.string().optional(),\n locale: z.string().optional(),\n title: z.string().optional(),\n});\n\nexport const intlayerConfigSchema = z.object({\n internationalization: internationalizationSchema.optional(),\n routing: routingSchema.optional(),\n content: contentSchema.optional(),\n system: systemSchema.optional(),\n editor: editorSchema.optional(),\n log: logSchema.optional(),\n ai: aiSchema.optional(),\n build: buildSchema.optional(),\n compiler: compilerSchema.optional(),\n dictionary: dictionarySchema.optional(),\n plugins: z.array(z.unknown()).optional(),\n schemas: z.record(z.string(), z.unknown()).optional(),\n metadata: z\n .object({\n name: z.string().optional(),\n version: z.string().optional(),\n doc: z.string().optional(),\n })\n .optional(),\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"configurationSchema.cjs","names":["z","AiProviders"],"sources":["../../../src/configFile/configurationSchema.ts"],"sourcesContent":["import { AiProviders } from '@intlayer/types/config';\nimport { z } from 'zod';\n\nexport const internationalizationSchema = z.object({\n locales: z.array(z.string()).min(1),\n requiredLocales: z.array(z.string()).optional(),\n strictMode: z.enum(['strict', 'inclusive', 'loose']).optional(),\n defaultLocale: z.string().optional(),\n});\n\nexport const cookiesAttributesSchema = z.object({\n type: z.literal('cookie'),\n name: z.string().optional(),\n domain: z.string().optional(),\n path: z.string().optional(),\n secure: z.boolean().optional(),\n httpOnly: z.boolean().optional(),\n sameSite: z.enum(['strict', 'lax', 'none']).optional(),\n expires: z.union([z.date(), z.number()]).optional(),\n});\n\nexport const storageAttributesSchema = z.object({\n type: z.enum(['localStorage', 'sessionStorage', 'header']),\n name: z.string().optional(),\n});\n\nexport const storageSchema = z.union([\n z.literal(false),\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n z.array(\n z.union([\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n ])\n ),\n]);\n\nexport const rewriteRuleSchema = z.object({\n canonical: z.string(),\n localized: z.record(z.string(), z.string()),\n});\n\nexport const rewriteRulesSchema = z.object({\n rules: z.array(rewriteRuleSchema),\n});\n\nexport const rewriteObjectSchema = z.object({\n url: rewriteRulesSchema,\n nextjs: rewriteRulesSchema.optional(),\n vite: rewriteRulesSchema.optional(),\n});\n\nexport const routingSchema = z.object({\n rewrite: z\n .union([\n z.record(z.string(), z.record(z.string(), z.string())),\n rewriteObjectSchema,\n ])\n .optional(),\n mode: z\n .enum(['prefix-no-default', 'prefix-all', 'no-prefix', 'search-params'])\n .optional(),\n storage: storageSchema.optional(),\n basePath: z.string().optional(),\n});\n\nexport const systemSchema = z.object({\n baseDir: z.string().optional(),\n moduleAugmentationDir: z.string().optional(),\n unmergedDictionariesDir: z.string().optional(),\n remoteDictionariesDir: z.string().optional(),\n dictionariesDir: z.string().optional(),\n dynamicDictionariesDir: z.string().optional(),\n fetchDictionariesDir: z.string().optional(),\n typesDir: z.string().optional(),\n mainDir: z.string().optional(),\n configDir: z.string().optional(),\n cacheDir: z.string().optional(),\n tempDir: z.string().optional(),\n outputFilesPatternWithPath: z.string().optional(),\n});\n\nexport const contentSchema = z.object({\n fileExtensions: z.array(z.string()).optional(),\n contentDir: z.array(z.string()).optional(),\n codeDir: z.array(z.string()).optional(),\n excludedPath: z.array(z.string()).optional(),\n watch: z.boolean().optional(),\n formatCommand: z.string().optional(),\n watchedFilesPattern: z.array(z.string()).optional(),\n watchedFilesPatternWithPath: z.array(z.string()).optional(),\n});\n\nexport const editorSchema = z.object({\n applicationURL: z.union([z.url(), z.literal('')]).optional(),\n editorURL: z.union([z.url(), z.literal('')]).optional(),\n cmsURL: z.union([z.url(), z.literal('')]).optional(),\n backendURL: z.union([z.url(), z.literal('')]).optional(),\n port: z.number().int().positive().max(65535).optional(),\n enabled: z.boolean().optional(),\n clientId: z.string().optional(),\n clientSecret: z.string().optional(),\n dictionaryPriorityStrategy: z\n .enum(['local_first', 'distant_first'])\n .optional(),\n liveSync: z.boolean().optional(),\n liveSyncPort: z.number().int().positive().max(65535).optional(),\n liveSyncURL: z.union([z.url(), z.literal('')]).optional(),\n});\n\nexport const logSchema = z.object({\n mode: z.enum(['default', 'verbose', 'disabled']).optional(),\n prefix: z.string().optional(),\n error: z.function().optional(),\n log: z.function().optional(),\n info: z.function().optional(),\n warn: z.function().optional(),\n});\n\nexport const aiSchema = z.object({\n provider: z.enum(AiProviders).optional(),\n apiKey: z.string().optional(),\n model: z.string().optional(),\n temperature: z.number().min(0).max(2).optional(),\n applicationContext: z.string().optional(),\n baseURL: z.url().optional(),\n dataSerialization: z.enum(['json', 'toon']).optional(),\n});\n\nexport const buildSchema = z.object({\n mode: z.enum(['auto', 'manual']).optional(),\n optimize: z.boolean().optional(),\n importMode: z.enum(['static', 'dynamic', 'fetch']).optional(),\n traversePattern: z.array(z.string()).optional(),\n outputFormat: z.array(z.enum(['cjs', 'esm'])).optional(),\n cache: z.boolean().optional(),\n require: z.unknown().optional(),\n checkTypes: z.boolean().optional(),\n});\n\nexport const compilerSchema = z.object({\n enabled: z.union([z.boolean(), z.literal('build-only')]).optional(),\n dictionaryKeyPrefix: z.string().optional(),\n transformPattern: z.union([z.string(), z.array(z.string())]).optional(),\n excludePattern: z.union([z.string(), z.array(z.string())]).optional(),\n outputDir: z.string().optional(),\n output: z.unknown().optional(),\n noMetadata: z.boolean().optional(),\n saveComponents: z.boolean().optional(),\n});\n\nexport const dictionarySchema = z.object({\n fill: z.unknown().optional(),\n contentAutoTransformation: z\n .union([\n z.boolean(),\n z.object({\n markdown: z.boolean().optional(),\n html: z.boolean().optional(),\n insertion: z.boolean().optional(),\n }),\n ])\n .optional(),\n location: z.string().optional(),\n locale: z.string().optional(),\n title: z.string().optional(),\n});\n\nexport const intlayerConfigSchema = z.object({\n internationalization: internationalizationSchema.optional(),\n routing: routingSchema.optional(),\n content: contentSchema.optional(),\n system: systemSchema.optional(),\n editor: editorSchema.optional(),\n log: logSchema.optional(),\n ai: aiSchema.optional(),\n build: buildSchema.optional(),\n compiler: compilerSchema.optional(),\n dictionary: dictionarySchema.optional(),\n plugins: z.array(z.unknown()).optional(),\n schemas: z.record(z.string(), z.unknown()).optional(),\n metadata: z\n .object({\n name: z.string().optional(),\n version: z.string().optional(),\n doc: z.string().optional(),\n })\n .optional(),\n});\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});var e=require(`../_virtual/_rolldown/runtime.cjs`).__exportAll({BUILD_MODE:()=>t,CACHE:()=>!0,OPTIMIZE:()=>void 0,OUTPUT_FORMAT:()=>r,TRAVERSE_PATTERN:()=>n,TYPE_CHECKING:()=>!1});const t=`auto`,n=[`**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}`,`!**/node_modules/**`],r=[`esm`,`cjs`];exports.BUILD_MODE=t,exports.CACHE=!0,exports.OPTIMIZE=void 0,exports.OUTPUT_FORMAT=r,exports.TRAVERSE_PATTERN=n,exports.TYPE_CHECKING=!1,Object.defineProperty(exports,`build_exports`,{enumerable:!0,get:function(){return e}});
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});var e=require(`../_virtual/_rolldown/runtime.cjs`).__exportAll({BUILD_MODE:()=>t,CACHE:()=>!0,OPTIMIZE:()=>void 0,OUTPUT_FORMAT:()=>r,TRAVERSE_PATTERN:()=>n,TYPE_CHECKING:()=>!1});const t=`auto`,n=[`**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}`,`!**/node_modules/**`,`!**/*.config.*`],r=[`esm`,`cjs`];exports.BUILD_MODE=t,exports.CACHE=!0,exports.OPTIMIZE=void 0,exports.OUTPUT_FORMAT=r,exports.TRAVERSE_PATTERN=n,exports.TYPE_CHECKING=!1,Object.defineProperty(exports,`build_exports`,{enumerable:!0,get:function(){return e}});
2
2
  //# sourceMappingURL=build.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"build.cjs","names":[],"sources":["../../../src/defaultValues/build.ts"],"sourcesContent":["export const BUILD_MODE = 'auto';\n\nexport const OPTIMIZE = undefined;\n\nexport const TRAVERSE_PATTERN = [\n '**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}',\n '!**/node_modules/**',\n];\n\nexport const OUTPUT_FORMAT: ('cjs' | 'esm')[] = ['esm', 'cjs'];\n\nexport const CACHE = true;\n\nexport const TYPE_CHECKING = false;\n"],"mappings":"uPAAA,MAAa,EAAa,OAIb,EAAmB,CAC9B,+CACA,sBACD,CAEY,EAAmC,CAAC,MAAO,MAAM"}
1
+ {"version":3,"file":"build.cjs","names":[],"sources":["../../../src/defaultValues/build.ts"],"sourcesContent":["export const BUILD_MODE = 'auto';\n\nexport const OPTIMIZE = undefined;\n\nexport const TRAVERSE_PATTERN = [\n '**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}',\n '!**/node_modules/**',\n '!**/*.config.*',\n];\n\nexport const OUTPUT_FORMAT: ('cjs' | 'esm')[] = ['esm', 'cjs'];\n\nexport const CACHE = true;\n\nexport const TYPE_CHECKING = false;\n"],"mappings":"uPAAA,MAAa,EAAa,OAIb,EAAmB,CAC9B,+CACA,sBACA,iBACD,CAEY,EAAmC,CAAC,MAAO,MAAM"}
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});var e=require(`../_virtual/_rolldown/runtime.cjs`).__exportAll({APPLICATION_URL:()=>void 0,BACKEND_URL:()=>r,CMS_URL:()=>n,DICTIONARY_PRIORITY_STRATEGY:()=>a,EDITOR_URL:()=>t,IS_ENABLED:()=>!0,LIVE_SYNC:()=>!0,LIVE_SYNC_PORT:()=>o,PORT:()=>i});const t=`http://localhost:8000`,n=`https://app.intlayer.org`,r=`https://back.intlayer.org`,i=8e3,a=`local_first`,o=4e3;exports.APPLICATION_URL=void 0,exports.BACKEND_URL=r,exports.CMS_URL=n,exports.DICTIONARY_PRIORITY_STRATEGY=a,exports.EDITOR_URL=t,exports.IS_ENABLED=!0,exports.LIVE_SYNC=!0,exports.LIVE_SYNC_PORT=o,exports.PORT=i,Object.defineProperty(exports,`editor_exports`,{enumerable:!0,get:function(){return e}});
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});var e=require(`../_virtual/_rolldown/runtime.cjs`).__exportAll({APPLICATION_URL:()=>void 0,BACKEND_URL:()=>r,CMS_URL:()=>n,DICTIONARY_PRIORITY_STRATEGY:()=>a,EDITOR_URL:()=>t,IS_ENABLED:()=>!1,LIVE_SYNC:()=>!0,LIVE_SYNC_PORT:()=>o,PORT:()=>i});const t=`http://localhost:8000`,n=`https://app.intlayer.org`,r=`https://back.intlayer.org`,i=8e3,a=`local_first`,o=4e3;exports.APPLICATION_URL=void 0,exports.BACKEND_URL=r,exports.CMS_URL=n,exports.DICTIONARY_PRIORITY_STRATEGY=a,exports.EDITOR_URL=t,exports.IS_ENABLED=!1,exports.LIVE_SYNC=!0,exports.LIVE_SYNC_PORT=o,exports.PORT=i,Object.defineProperty(exports,`editor_exports`,{enumerable:!0,get:function(){return e}});
2
2
  //# sourceMappingURL=editor.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"editor.cjs","names":[],"sources":["../../../src/defaultValues/editor.ts"],"sourcesContent":["export const APPLICATION_URL = undefined;\nexport const EDITOR_URL = 'http://localhost:8000';\nexport const CMS_URL = 'https://app.intlayer.org';\nexport const BACKEND_URL = 'https://back.intlayer.org';\nexport const PORT = 8000;\nexport const IS_ENABLED = true;\nexport const LIVE_SYNC = true;\nexport const DICTIONARY_PRIORITY_STRATEGY = 'local_first';\nexport const LIVE_SYNC_PORT = 4000;\n"],"mappings":"uTAAA,MACa,EAAa,wBACb,EAAU,2BACV,EAAc,4BACd,EAAO,IAGP,EAA+B,cAC/B,EAAiB"}
1
+ {"version":3,"file":"editor.cjs","names":[],"sources":["../../../src/defaultValues/editor.ts"],"sourcesContent":["export const APPLICATION_URL = undefined;\nexport const EDITOR_URL = 'http://localhost:8000';\nexport const CMS_URL = 'https://app.intlayer.org';\nexport const BACKEND_URL = 'https://back.intlayer.org';\nexport const PORT = 8000;\nexport const IS_ENABLED = false;\nexport const LIVE_SYNC = true;\nexport const DICTIONARY_PRIORITY_STRATEGY = 'local_first';\nexport const LIVE_SYNC_PORT = 4000;\n"],"mappings":"uTAAA,MACa,EAAa,wBACb,EAAU,2BACV,EAAc,4BACd,EAAO,IAGP,EAA+B,cAC/B,EAAiB"}
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../logger.cjs`),n=require(`./parseFileContent.cjs`),r=require(`./transpileTSToCJS.cjs`);let i=require(`node:fs`),a=require(`node:path`),o=require(`node:fs/promises`),s=require(`json5`);s=e.__toESM(s);const c=(e,o)=>{let c=(0,a.extname)(e)||`.json`;try{if(c===`.json`||c===`.json5`||c===`.jsonc`)return s.default.parse((0,i.readFileSync)(e,`utf-8`));let a=r.transpileTSToCJSSync((0,i.readFileSync)(e,`utf-8`),e);if(!a){t.logger(`File could not be loaded.`,{level:`error`});return}let l=n.parseFileContent(a,{projectRequire:o?.projectRequire,envVarOptions:o?.envVarOptions,additionalEnvVars:o?.additionalEnvVars,mocks:o?.mocks,aliases:o?.aliases});if(l===void 0){t.logger(`File could not be loaded. Path : ${e}`);return}return l}catch(e){t.logger([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}},l=async(e,i)=>{let c=(0,a.extname)(e);try{if(c===`.json`||c===`.json5`||c===`.jsonc`){let t=await(0,o.readFile)(e,`utf-8`);return s.default.parse(t)}let a=await r.transpileTSToCJS(await(0,o.readFile)(e,`utf-8`),e,i?.buildOptions);if(!a){t.logger(`File could not be loaded.`,{level:`error`});return}let l=n.parseFileContent(a,{projectRequire:i?.projectRequire,envVarOptions:i?.envVarOptions,additionalEnvVars:i?.additionalEnvVars,mocks:i?.mocks,aliases:i?.aliases});if(l===void 0){t.logger(`File could not be loaded. Path : ${t.colorizePath(e)}`);return}return l}catch(e){t.logger([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}};exports.loadExternalFile=l,exports.loadExternalFileSync=c;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../logger.cjs`),n=require(`./parseFileContent.cjs`),r=require(`./transpileTSToCJS.cjs`);let i=require(`node:fs`),a=require(`node:path`),o=require(`node:fs/promises`),s=require(`json5`);s=e.__toESM(s);const c=(e,o)=>{let c=(0,a.extname)(e)||`.json`;try{if(c===`.json`||c===`.json5`||c===`.jsonc`)return s.default.parse((0,i.readFileSync)(e,`utf-8`));let a=r.transpileTSToCJSSync((0,i.readFileSync)(e,`utf-8`),e);if(!a){t.logger(`File could not be loaded.`,{level:`error`});return}let l=n.parseFileContent(a,{projectRequire:o?.projectRequire,envVarOptions:o?.envVarOptions,additionalEnvVars:o?.additionalEnvVars,mocks:o?.mocks,aliases:o?.aliases});if(l===void 0){t.logger(`File could not be loaded. Path : ${e}`);return}return l}catch(e){t.logger([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}},l=async(e,i)=>{let c=(0,a.extname)(e);try{if(c===`.json`||c===`.json5`||c===`.jsonc`){let t=await(0,o.readFile)(e,`utf-8`);return s.default.parse(t)}let a=await r.transpileTSToCJS(await(0,o.readFile)(e,`utf-8`),e,i?.buildOptions);if(!a){t.logger(`File could not be loaded.`,{level:`error`});return}let l=n.parseFileContent(a,{projectRequire:i?.projectRequire,envVarOptions:i?.envVarOptions,additionalEnvVars:i?.additionalEnvVars,mocks:i?.mocks,aliases:i?.aliases});if(l===void 0){t.logger(`File could not be loaded. Path : ${t.colorizePath(e)}`);return}return l}catch(e){(i?.logError??!0)&&t.logger([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}};exports.loadExternalFile=l,exports.loadExternalFileSync=c;
2
2
  //# sourceMappingURL=loadExternalFile.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"loadExternalFile.cjs","names":["JSON5","transpileTSToCJSSync","parseFileContent","transpileTSToCJS","colorizePath"],"sources":["../../../src/loadExternalFile/loadExternalFile.ts"],"sourcesContent":["import { readFileSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport { extname } from 'node:path';\nimport type { IntlayerConfig } from '@intlayer/types/config';\nimport type { BuildOptions } from 'esbuild';\nimport JSON5 from 'json5';\nimport { colorizePath, logger } from '../logger';\nimport {\n parseFileContent,\n type SandBoxContextOptions,\n} from './parseFileContent';\nimport { transpileTSToCJS, transpileTSToCJSSync } from './transpileTSToCJS';\n\nexport type LoadExternalFileOptions = {\n configuration?: IntlayerConfig;\n buildOptions?: BuildOptions;\n} & SandBoxContextOptions;\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFileSync = (\n filePath: string,\n options?: LoadExternalFileOptions\n): any | undefined => {\n const fileExtension = extname(filePath) || '.json';\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Assume JSON\n return JSON5.parse(readFileSync(filePath, 'utf-8'));\n }\n\n // Rest is JS, MJS or TS\n const code = readFileSync(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = transpileTSToCJSSync(\n code,\n filePath\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${filePath}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n};\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFile = async (\n filePath: string,\n options?: LoadExternalFileOptions\n): Promise<any | undefined> => {\n const fileExtension = extname(filePath);\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Remove cache to force getting fresh content\n const fileContent = await readFile(filePath, 'utf-8');\n return JSON5.parse(fileContent);\n }\n\n // Rest is JS, MJS or TS\n const code = await readFile(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = await transpileTSToCJS(\n code,\n filePath,\n options?.buildOptions\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${colorizePath(filePath)}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n};\n"],"mappings":"2UAuBA,MAAa,GACX,EACA,IACoB,CACpB,IAAM,GAAA,EAAA,EAAA,SAAwB,EAAS,EAAI,QAE3C,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAGlB,OAAOA,EAAAA,QAAM,OAAA,EAAA,EAAA,cAAmB,EAAU,QAAQ,CAAC,CAMrD,IAAM,EAAyCC,EAAAA,sBAAAA,EAAAA,EAAAA,cAFrB,EAAU,QAAQ,CAI1C,EACD,CAED,GAAI,CAAC,EAAoB,CACvB,EAAA,OAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAcC,EAAAA,iBAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAA,OAAO,oCAAoC,IAAW,CACtD,OAGF,OAAO,QACA,EAAO,CACd,EAAA,OACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF,GASQ,EAAmB,MAC9B,EACA,IAC6B,CAC7B,IAAM,GAAA,EAAA,EAAA,SAAwB,EAAS,CAEvC,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAClB,CAEA,IAAM,EAAc,MAAA,EAAA,EAAA,UAAe,EAAU,QAAQ,CACrD,OAAOF,EAAAA,QAAM,MAAM,EAAY,CAMjC,IAAM,EAAyC,MAAMG,EAAAA,iBAFxC,MAAA,EAAA,EAAA,UAAe,EAAU,QAAQ,CAI5C,EACA,GAAS,aACV,CAED,GAAI,CAAC,EAAoB,CACvB,EAAA,OAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAcD,EAAAA,iBAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAA,OAAO,oCAAoCE,EAAAA,aAAa,EAAS,GAAG,CACpE,OAGF,OAAO,QACA,EAAO,CACd,EAAA,OACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF"}
1
+ {"version":3,"file":"loadExternalFile.cjs","names":["JSON5","transpileTSToCJSSync","parseFileContent","transpileTSToCJS","colorizePath"],"sources":["../../../src/loadExternalFile/loadExternalFile.ts"],"sourcesContent":["import { readFileSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport { extname } from 'node:path';\nimport type { IntlayerConfig } from '@intlayer/types/config';\nimport type { BuildOptions } from 'esbuild';\nimport JSON5 from 'json5';\nimport { colorizePath, logger } from '../logger';\nimport {\n parseFileContent,\n type SandBoxContextOptions,\n} from './parseFileContent';\nimport { transpileTSToCJS, transpileTSToCJSSync } from './transpileTSToCJS';\n\nexport type LoadExternalFileOptions = {\n configuration?: IntlayerConfig;\n buildOptions?: BuildOptions;\n logError?: boolean;\n} & SandBoxContextOptions;\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFileSync = (\n filePath: string,\n options?: LoadExternalFileOptions\n): any | undefined => {\n const fileExtension = extname(filePath) || '.json';\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Assume JSON\n return JSON5.parse(readFileSync(filePath, 'utf-8'));\n }\n\n // Rest is JS, MJS or TS\n const code = readFileSync(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = transpileTSToCJSSync(\n code,\n filePath\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${filePath}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n};\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFile = async (\n filePath: string,\n options?: LoadExternalFileOptions\n): Promise<any | undefined> => {\n const fileExtension = extname(filePath);\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Remove cache to force getting fresh content\n const fileContent = await readFile(filePath, 'utf-8');\n return JSON5.parse(fileContent);\n }\n\n // Rest is JS, MJS or TS\n const code = await readFile(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = await transpileTSToCJS(\n code,\n filePath,\n options?.buildOptions\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${colorizePath(filePath)}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n if (options?.logError ?? true) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n }\n};\n"],"mappings":"2UAwBA,MAAa,GACX,EACA,IACoB,CACpB,IAAM,GAAA,EAAA,EAAA,SAAwB,EAAS,EAAI,QAE3C,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAGlB,OAAOA,EAAAA,QAAM,OAAA,EAAA,EAAA,cAAmB,EAAU,QAAQ,CAAC,CAMrD,IAAM,EAAyCC,EAAAA,sBAAAA,EAAAA,EAAAA,cAFrB,EAAU,QAAQ,CAI1C,EACD,CAED,GAAI,CAAC,EAAoB,CACvB,EAAA,OAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAcC,EAAAA,iBAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAA,OAAO,oCAAoC,IAAW,CACtD,OAGF,OAAO,QACA,EAAO,CACd,EAAA,OACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF,GASQ,EAAmB,MAC9B,EACA,IAC6B,CAC7B,IAAM,GAAA,EAAA,EAAA,SAAwB,EAAS,CAEvC,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAClB,CAEA,IAAM,EAAc,MAAA,EAAA,EAAA,UAAe,EAAU,QAAQ,CACrD,OAAOF,EAAAA,QAAM,MAAM,EAAY,CAMjC,IAAM,EAAyC,MAAMG,EAAAA,iBAFxC,MAAA,EAAA,EAAA,UAAe,EAAU,QAAQ,CAI5C,EACA,GAAS,aACV,CAED,GAAI,CAAC,EAAoB,CACvB,EAAA,OAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAcD,EAAAA,iBAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAA,OAAO,oCAAoCE,EAAAA,aAAa,EAAS,GAAG,CACpE,OAGF,OAAO,QACA,EAAO,EACV,GAAS,UAAY,KACvB,EAAA,OACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF"}
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=async(e,n)=>{if(typeof e==`function`)return await e(n);if(typeof e==`object`&&e&&n.locale){let r=e[n.locale];if(r)return typeof r==`function`?await r(n):t(r,n)}return typeof e==`string`?t(e,n):``},t=(e,t)=>e.replaceAll(/\{\{\s*locale\s*\}\}/g,t.locale??``).replaceAll(/\{\{\s*key\s*\}\}/g,t.key??``).replaceAll(/\{\{\s*fileName\s*\}\}/g,t.fileName??``).replaceAll(/\{\{\s*extension\s*\}\}/g,t.extension??``).replaceAll(/\{\{\s*componentFileName\s*\}\}/g,t.componentFileName??``).replaceAll(/\{\{\s*componentExtension\s*\}\}/g,t.componentExtension??``).replaceAll(/\{\{\s*format\s*\}\}/g,t.format??``).replaceAll(/\{\{\s*componentFormat\s*\}\}/g,t.componentFormat??``).replaceAll(/\{\{\s*dirPath\s*\}\}/g,t.dirPath??``);exports.parseFilePathPattern=e,exports.parseStringPattern=t;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=async(e,n)=>{if(typeof e==`function`)return await e(n);if(typeof e==`object`&&e&&n.locale){let r=e[n.locale];if(r)return typeof r==`function`?await r(n):t(r,n)}return typeof e==`string`?t(e,n):``},t=(e,t)=>e.replaceAll(/\{\{\s*locale\s*\}\}/g,t.locale??``).replaceAll(/\{\{\s*key\s*\}\}/g,t.key??``).replaceAll(/\{\{\s*fileName\s*\}\}/g,t.fileName??``).replaceAll(/\{\{\s*extension\s*\}\}/g,t.extension??``).replaceAll(/\{\{\s*componentFileName\s*\}\}/g,t.componentFileName??``).replaceAll(/\{\{\s*componentExtension\s*\}\}/g,t.componentExtension??``).replaceAll(/\{\{\s*format\s*\}\}/g,t.format??``).replaceAll(/\{\{\s*componentFormat\s*\}\}/g,t.componentFormat??``).replaceAll(/\{\{\s*componentDirPath\s*\}\}/g,t.componentDirPath??``);exports.parseFilePathPattern=e,exports.parseStringPattern=t;
2
2
  //# sourceMappingURL=parseFilePathPattern.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"parseFilePathPattern.cjs","names":[],"sources":["../../../src/utils/parseFilePathPattern.ts"],"sourcesContent":["import type {\n FilePathPattern,\n FilePathPatternContext,\n} from '@intlayer/types/filePathPattern';\n\n/**\n * Parses a FilePathPattern configuration string or function to a final string path.\n * Resolves context variables like `{{locale}}`, `{{key}}`, `{{fileName}}`, `{{extension}}`.\n */\nexport const parseFilePathPattern = async (\n pattern: FilePathPattern,\n context: FilePathPatternContext\n): Promise<string> => {\n if (typeof pattern === 'function') {\n return await (pattern as any)(context);\n }\n\n if (typeof pattern === 'object' && pattern !== null && context.locale) {\n const localePattern = (pattern as any)[context.locale];\n\n if (localePattern) {\n if (typeof localePattern === 'function') {\n return await localePattern(context);\n }\n return parseStringPattern(localePattern, context);\n }\n }\n\n if (typeof pattern === 'string') {\n return parseStringPattern(pattern, context);\n }\n\n return '';\n};\n\nexport const parseStringPattern = (\n pattern: string,\n context: FilePathPatternContext\n): string =>\n pattern\n .replaceAll(/\\{\\{\\s*locale\\s*\\}\\}/g, context.locale ?? '')\n .replaceAll(/\\{\\{\\s*key\\s*\\}\\}/g, context.key ?? '')\n .replaceAll(/\\{\\{\\s*fileName\\s*\\}\\}/g, context.fileName ?? '')\n .replaceAll(/\\{\\{\\s*extension\\s*\\}\\}/g, context.extension ?? '')\n .replaceAll(\n /\\{\\{\\s*componentFileName\\s*\\}\\}/g,\n context.componentFileName ?? ''\n )\n .replaceAll(\n /\\{\\{\\s*componentExtension\\s*\\}\\}/g,\n context.componentExtension ?? ''\n )\n .replaceAll(/\\{\\{\\s*format\\s*\\}\\}/g, context.format ?? '')\n .replaceAll(/\\{\\{\\s*componentFormat\\s*\\}\\}/g, context.componentFormat ?? '')\n .replaceAll(/\\{\\{\\s*dirPath\\s*\\}\\}/g, context.dirPath ?? '');\n"],"mappings":"mEASA,MAAa,EAAuB,MAClC,EACA,IACoB,CACpB,GAAI,OAAO,GAAY,WACrB,OAAO,MAAO,EAAgB,EAAQ,CAGxC,GAAI,OAAO,GAAY,UAAY,GAAoB,EAAQ,OAAQ,CACrE,IAAM,EAAiB,EAAgB,EAAQ,QAE/C,GAAI,EAIF,OAHI,OAAO,GAAkB,WACpB,MAAM,EAAc,EAAQ,CAE9B,EAAmB,EAAe,EAAQ,CAQrD,OAJI,OAAO,GAAY,SACd,EAAmB,EAAS,EAAQ,CAGtC,IAGI,GACX,EACA,IAEA,EACG,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,qBAAsB,EAAQ,KAAO,GAAG,CACnD,WAAW,0BAA2B,EAAQ,UAAY,GAAG,CAC7D,WAAW,2BAA4B,EAAQ,WAAa,GAAG,CAC/D,WACC,mCACA,EAAQ,mBAAqB,GAC9B,CACA,WACC,oCACA,EAAQ,oBAAsB,GAC/B,CACA,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,iCAAkC,EAAQ,iBAAmB,GAAG,CAC3E,WAAW,yBAA0B,EAAQ,SAAW,GAAG"}
1
+ {"version":3,"file":"parseFilePathPattern.cjs","names":[],"sources":["../../../src/utils/parseFilePathPattern.ts"],"sourcesContent":["import type {\n FilePathPattern,\n FilePathPatternContext,\n} from '@intlayer/types/filePathPattern';\n\n/**\n * Parses a FilePathPattern configuration string or function to a final string path.\n * Resolves context variables like `{{locale}}`, `{{key}}`, `{{fileName}}`, `{{extension}}`.\n */\nexport const parseFilePathPattern = async (\n pattern: FilePathPattern,\n context: FilePathPatternContext\n): Promise<string> => {\n if (typeof pattern === 'function') {\n return await (pattern as any)(context);\n }\n\n if (typeof pattern === 'object' && pattern !== null && context.locale) {\n const localePattern = (pattern as any)[context.locale];\n\n if (localePattern) {\n if (typeof localePattern === 'function') {\n return await localePattern(context);\n }\n return parseStringPattern(localePattern, context);\n }\n }\n\n if (typeof pattern === 'string') {\n return parseStringPattern(pattern, context);\n }\n\n return '';\n};\n\nexport const parseStringPattern = (\n pattern: string,\n context: FilePathPatternContext\n): string =>\n pattern\n .replaceAll(/\\{\\{\\s*locale\\s*\\}\\}/g, context.locale ?? '')\n .replaceAll(/\\{\\{\\s*key\\s*\\}\\}/g, context.key ?? '')\n .replaceAll(/\\{\\{\\s*fileName\\s*\\}\\}/g, context.fileName ?? '')\n .replaceAll(/\\{\\{\\s*extension\\s*\\}\\}/g, context.extension ?? '')\n .replaceAll(\n /\\{\\{\\s*componentFileName\\s*\\}\\}/g,\n context.componentFileName ?? ''\n )\n .replaceAll(\n /\\{\\{\\s*componentExtension\\s*\\}\\}/g,\n context.componentExtension ?? ''\n )\n .replaceAll(/\\{\\{\\s*format\\s*\\}\\}/g, context.format ?? '')\n .replaceAll(/\\{\\{\\s*componentFormat\\s*\\}\\}/g, context.componentFormat ?? '')\n .replaceAll(\n /\\{\\{\\s*componentDirPath\\s*\\}\\}/g,\n context.componentDirPath ?? ''\n );\n"],"mappings":"mEASA,MAAa,EAAuB,MAClC,EACA,IACoB,CACpB,GAAI,OAAO,GAAY,WACrB,OAAO,MAAO,EAAgB,EAAQ,CAGxC,GAAI,OAAO,GAAY,UAAY,GAAoB,EAAQ,OAAQ,CACrE,IAAM,EAAiB,EAAgB,EAAQ,QAE/C,GAAI,EAIF,OAHI,OAAO,GAAkB,WACpB,MAAM,EAAc,EAAQ,CAE9B,EAAmB,EAAe,EAAQ,CAQrD,OAJI,OAAO,GAAY,SACd,EAAmB,EAAS,EAAQ,CAGtC,IAGI,GACX,EACA,IAEA,EACG,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,qBAAsB,EAAQ,KAAO,GAAG,CACnD,WAAW,0BAA2B,EAAQ,UAAY,GAAG,CAC7D,WAAW,2BAA4B,EAAQ,WAAa,GAAG,CAC/D,WACC,mCACA,EAAQ,mBAAqB,GAC9B,CACA,WACC,oCACA,EAAQ,oBAAsB,GAC/B,CACA,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,iCAAkC,EAAQ,iBAAmB,GAAG,CAC3E,WACC,kCACA,EAAQ,kBAAoB,GAC7B"}
@@ -1,2 +1,2 @@
1
- import{__require as e}from"../_virtual/_rolldown/runtime.mjs";import{OUTPUT_FORMAT as t,TRAVERSE_PATTERN as n}from"../defaultValues/build.mjs";import"../defaultValues/compiler.mjs";import{CODE_DIR as r,CONTENT_DIR as i,EXCLUDED_PATHS as a,FILE_EXTENSIONS as o}from"../defaultValues/content.mjs";import"../defaultValues/dictionary.mjs";import"../defaultValues/editor.mjs";import{DEFAULT_LOCALE as s,LOCALES as c,REQUIRED_LOCALES as l}from"../defaultValues/internationalization.mjs";import{PREFIX as u}from"../defaultValues/log.mjs";import{STORAGE as d}from"../defaultValues/routing.mjs";import"../defaultValues/system.mjs";import{normalizePath as f}from"../utils/normalizePath.mjs";import{getProjectRequire as p}from"../utils/ESMxCJSHelpers.mjs";import{statSync as m}from"node:fs";import{dirname as h,isAbsolute as g,join as _}from"node:path";import v from"@intlayer/types/package.json"with{type:"json"};let y;const b=e=>({locales:e?.locales??c,requiredLocales:e?.requiredLocales??e?.locales??l,strictMode:e?.strictMode??`inclusive`,defaultLocale:e?.defaultLocale??s}),x=e=>({mode:e?.mode??`prefix-no-default`,storage:e?.storage??d,basePath:e?.basePath??``,rewrite:e?.rewrite}),S=(e,t)=>{let n=e??process.cwd(),r=e=>{let t;try{t=p(n).resolve(e,{paths:[n]})}catch{t=g(e)?e:_(n,e)}try{if(m(t).isFile())return h(t)}catch{if(/\.[a-z0-9]+$/i.test(t))return h(t)}return t},i=r(t?.dictionariesDir??`.intlayer/dictionary`);return{baseDir:n,moduleAugmentationDir:r(t?.moduleAugmentationDir??`.intlayer/types`),unmergedDictionariesDir:r(t?.unmergedDictionariesDir??`.intlayer/unmerged_dictionary`),remoteDictionariesDir:r(t?.remoteDictionariesDir??`.intlayer/remote_dictionary`),dictionariesDir:i,dynamicDictionariesDir:r(t?.dynamicDictionariesDir??`.intlayer/dynamic_dictionary`),fetchDictionariesDir:r(t?.fetchDictionariesDir??`.intlayer/fetch_dictionary`),typesDir:r(t?.typesDir??`.intlayer/types`),mainDir:r(t?.mainDir??`.intlayer/main`),configDir:r(t?.configDir??`.intlayer/config`),cacheDir:r(t?.cacheDir??`.intlayer/cache`),tempDir:r(t?.tempDir??`.intlayer/tmp`),outputFilesPatternWithPath:`${f(i)}/**/*.json`}},C=(t,n)=>{let s=n?.fileExtensions??o,c=n=>{let r;try{r=p(t.baseDir).resolve(n,{paths:[t.baseDir]})}catch{try{r=e.resolve(n,{paths:[t.baseDir]})}catch{r=g(n)?n:_(t.baseDir,n)}}try{if(m(r).isFile())return h(r)}catch{if(/\.[a-z0-9]+$/i.test(r))return h(r)}return r},l=(n?.contentDir??i).map(c);return{fileExtensions:s,contentDir:l,codeDir:(n?.codeDir??r).map(c),excludedPath:n?.excludedPath??a,watch:n?.watch??!0,formatCommand:n?.formatCommand,watchedFilesPattern:s.map(e=>`/**/*${e}`),watchedFilesPatternWithPath:s.flatMap(e=>l.map(t=>`${f(t)}/**/*${e}`))}},w=e=>({applicationURL:e?.applicationURL??void 0,editorURL:e?.editorURL??`http://localhost:8000`,cmsURL:e?.cmsURL??`https://app.intlayer.org`,backendURL:e?.backendURL??`https://back.intlayer.org`,port:e?.port??8e3,enabled:e?.enabled??!0,clientId:e?.clientId??void 0,clientSecret:e?.clientSecret??void 0,dictionaryPriorityStrategy:e?.dictionaryPriorityStrategy??`local_first`,liveSync:e?.liveSync??!0,liveSyncPort:e?.liveSyncPort??4e3,liveSyncURL:e?.liveSyncURL??`http://localhost:${e?.liveSyncPort??4e3}`}),T=(e,t)=>({mode:e?.mode??`default`,prefix:e?.prefix??u,error:t?.error,log:t?.log,info:t?.info,warn:t?.warn}),E=e=>({provider:e?.provider,apiKey:e?.apiKey,model:e?.model,temperature:e?.temperature,applicationContext:e?.applicationContext,baseURL:e?.baseURL,dataSerialization:e?.dataSerialization}),D=e=>({mode:e?.mode??`auto`,optimize:e?.optimize,importMode:e?.importMode,traversePattern:e?.traversePattern??n,outputFormat:e?.outputFormat??t,cache:e?.cache??!0,require:e?.require,checkTypes:e?.checkTypes??!1}),O=e=>({enabled:e?.enabled??!0,dictionaryKeyPrefix:e?.dictionaryKeyPrefix??`comp-`,transformPattern:e?.transformPattern,excludePattern:e?.excludePattern,outputDir:e?.outputDir,output:e?.output,noMetadata:e?.noMetadata??!1,saveComponents:e?.saveComponents??!1}),k=e=>{let t=e?.contentAutoTransformation??!1;return{fill:e?.fill??!0,contentAutoTransformation:typeof t==`object`?{markdown:t.markdown??!1,html:t.html??!1,insertion:t.insertion??!1}:t,location:e?.location??`local`,locale:e?.locale,title:e?.title,description:e?.description,tags:e?.tags,priority:e?.priority,importMode:e?.importMode??`static`,version:e?.version}},A=(e,t,n)=>{let r=b(e?.internationalization),i=x(e?.routing),a=S(t,e?.system);return y={internationalization:r,routing:i,content:C(a,e?.content),system:a,editor:w(e?.editor),log:T(e?.log,n),ai:E(e?.ai),build:D(e?.build),compiler:O(e?.compiler),dictionary:k(e?.dictionary),plugins:e?.plugins,schemas:e?.schemas,metadata:{name:`Intlayer`,version:v.version,doc:`https://intlayer.org/docs`}},y};export{A as buildConfigurationFields};
1
+ import{__require as e}from"../_virtual/_rolldown/runtime.mjs";import{OUTPUT_FORMAT as t,TRAVERSE_PATTERN as n}from"../defaultValues/build.mjs";import"../defaultValues/compiler.mjs";import{CODE_DIR as r,CONTENT_DIR as i,EXCLUDED_PATHS as a,FILE_EXTENSIONS as o}from"../defaultValues/content.mjs";import"../defaultValues/dictionary.mjs";import"../defaultValues/editor.mjs";import{DEFAULT_LOCALE as s,LOCALES as c,REQUIRED_LOCALES as l}from"../defaultValues/internationalization.mjs";import{PREFIX as u}from"../defaultValues/log.mjs";import{STORAGE as d}from"../defaultValues/routing.mjs";import"../defaultValues/system.mjs";import{normalizePath as f}from"../utils/normalizePath.mjs";import{getProjectRequire as p}from"../utils/ESMxCJSHelpers.mjs";import{statSync as m}from"node:fs";import{dirname as h,isAbsolute as g,join as _}from"node:path";import v from"@intlayer/types/package.json"with{type:"json"};let y;const b=e=>({locales:e?.locales??c,requiredLocales:e?.requiredLocales??e?.locales??l,strictMode:e?.strictMode??`inclusive`,defaultLocale:e?.defaultLocale??s}),x=e=>({mode:e?.mode??`prefix-no-default`,storage:e?.storage??d,basePath:e?.basePath??``,rewrite:e?.rewrite}),S=(e,t)=>{let n=e??process.cwd(),r=e=>{let t;try{t=p(n).resolve(e,{paths:[n]})}catch{t=g(e)?e:_(n,e)}try{if(m(t).isFile())return h(t)}catch{if(/\.[a-z0-9]+$/i.test(t))return h(t)}return t},i=r(t?.dictionariesDir??`.intlayer/dictionary`);return{baseDir:n,moduleAugmentationDir:r(t?.moduleAugmentationDir??`.intlayer/types`),unmergedDictionariesDir:r(t?.unmergedDictionariesDir??`.intlayer/unmerged_dictionary`),remoteDictionariesDir:r(t?.remoteDictionariesDir??`.intlayer/remote_dictionary`),dictionariesDir:i,dynamicDictionariesDir:r(t?.dynamicDictionariesDir??`.intlayer/dynamic_dictionary`),fetchDictionariesDir:r(t?.fetchDictionariesDir??`.intlayer/fetch_dictionary`),typesDir:r(t?.typesDir??`.intlayer/types`),mainDir:r(t?.mainDir??`.intlayer/main`),configDir:r(t?.configDir??`.intlayer/config`),cacheDir:r(t?.cacheDir??`.intlayer/cache`),tempDir:r(t?.tempDir??`.intlayer/tmp`),outputFilesPatternWithPath:`${f(i)}/**/*.json`}},C=(t,n)=>{let s=n?.fileExtensions??o,c=n=>{let r;try{r=p(t.baseDir).resolve(n,{paths:[t.baseDir]})}catch{try{r=e.resolve(n,{paths:[t.baseDir]})}catch{r=g(n)?n:_(t.baseDir,n)}}try{if(m(r).isFile())return h(r)}catch{if(/\.[a-z0-9]+$/i.test(r))return h(r)}return r},l=(n?.contentDir??i).map(c);return{fileExtensions:s,contentDir:l,codeDir:(n?.codeDir??r).map(c),excludedPath:n?.excludedPath??a,watch:n?.watch??!0,formatCommand:n?.formatCommand,watchedFilesPattern:s.map(e=>`/**/*${e}`),watchedFilesPatternWithPath:s.flatMap(e=>l.map(t=>`${f(t)}/**/*${e}`))}},w=e=>({applicationURL:e?.applicationURL||void 0,editorURL:e?.editorURL||`http://localhost:8000`,cmsURL:e?.cmsURL||`https://app.intlayer.org`,backendURL:e?.backendURL||`https://back.intlayer.org`,port:e?.port??8e3,enabled:e?.enabled??!1,clientId:e?.clientId??void 0,clientSecret:e?.clientSecret??void 0,dictionaryPriorityStrategy:e?.dictionaryPriorityStrategy??`local_first`,liveSync:e?.liveSync??!0,liveSyncPort:e?.liveSyncPort??4e3,liveSyncURL:e?.liveSyncURL??`http://localhost:${e?.liveSyncPort??4e3}`}),T=(e,t)=>({mode:e?.mode??`default`,prefix:e?.prefix??u,error:t?.error,log:t?.log,info:t?.info,warn:t?.warn}),E=e=>({provider:e?.provider,apiKey:e?.apiKey,model:e?.model,temperature:e?.temperature,applicationContext:e?.applicationContext,baseURL:e?.baseURL,dataSerialization:e?.dataSerialization}),D=e=>({mode:e?.mode??`auto`,optimize:e?.optimize,importMode:e?.importMode,traversePattern:e?.traversePattern??n,outputFormat:e?.outputFormat??t,cache:e?.cache??!0,require:e?.require,checkTypes:e?.checkTypes??!1}),O=e=>({enabled:e?.enabled??!0,dictionaryKeyPrefix:e?.dictionaryKeyPrefix??`comp-`,transformPattern:e?.transformPattern,excludePattern:e?.excludePattern,outputDir:e?.outputDir,output:e?.output,noMetadata:e?.noMetadata??!1,saveComponents:e?.saveComponents??!1}),k=e=>{let t=e?.contentAutoTransformation??!1;return{fill:e?.fill??!0,contentAutoTransformation:typeof t==`object`?{markdown:t.markdown??!1,html:t.html??!1,insertion:t.insertion??!1}:t,location:e?.location??`local`,locale:e?.locale,title:e?.title,description:e?.description,tags:e?.tags,priority:e?.priority,importMode:e?.importMode??`static`,version:e?.version}},A=(e,t,n)=>{let r=b(e?.internationalization),i=x(e?.routing),a=S(t,e?.system);return y={internationalization:r,routing:i,content:C(a,e?.content),system:a,editor:w(e?.editor),log:T(e?.log,n),ai:E(e?.ai),build:D(e?.build),compiler:O(e?.compiler),dictionary:k(e?.dictionary),plugins:e?.plugins,schemas:e?.schemas,metadata:{name:`Intlayer`,version:v.version,doc:`https://intlayer.org/docs`}},y};export{A as buildConfigurationFields};
2
2
  //# sourceMappingURL=buildConfigurationFields.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"buildConfigurationFields.mjs","names":[],"sources":["../../../src/configFile/buildConfigurationFields.ts"],"sourcesContent":["import { statSync } from 'node:fs';\nimport { dirname, isAbsolute, join } from 'node:path';\nimport type {\n AiConfig,\n BuildConfig,\n CompilerConfig,\n ContentConfig,\n CustomIntlayerConfig,\n DictionaryConfig,\n EditorConfig,\n InternationalizationConfig,\n IntlayerConfig,\n LogConfig,\n LogFunctions,\n RoutingConfig,\n SystemConfig,\n} from '@intlayer/types/config';\nimport packageJson from '@intlayer/types/package.json' with { type: 'json' };\nimport {\n BUILD_MODE,\n CACHE,\n OUTPUT_FORMAT,\n TRAVERSE_PATTERN,\n TYPE_CHECKING,\n} from '../defaultValues/build';\nimport {\n COMPILER_DICTIONARY_KEY_PREFIX,\n COMPILER_ENABLED,\n COMPILER_NO_METADATA,\n COMPILER_OUTPUT,\n COMPILER_SAVE_COMPONENTS,\n} from '../defaultValues/compiler';\nimport {\n CODE_DIR,\n CONTENT_DIR,\n EXCLUDED_PATHS,\n FILE_EXTENSIONS,\n WATCH,\n} from '../defaultValues/content';\nimport {\n CONTENT_AUTO_TRANSFORMATION,\n FILL,\n IMPORT_MODE,\n LOCATION,\n} from '../defaultValues/dictionary';\nimport {\n APPLICATION_URL,\n BACKEND_URL,\n CMS_URL,\n DICTIONARY_PRIORITY_STRATEGY,\n EDITOR_URL,\n IS_ENABLED,\n LIVE_SYNC,\n LIVE_SYNC_PORT,\n PORT,\n} from '../defaultValues/editor';\nimport {\n DEFAULT_LOCALE,\n LOCALES,\n REQUIRED_LOCALES,\n STRICT_MODE,\n} from '../defaultValues/internationalization';\nimport { MODE, PREFIX } from '../defaultValues/log';\nimport { BASE_PATH, ROUTING_MODE, STORAGE } from '../defaultValues/routing';\nimport {\n CACHE_DIR,\n CONFIG_DIR,\n DICTIONARIES_DIR,\n DYNAMIC_DICTIONARIES_DIR,\n FETCH_DICTIONARIES_DIR,\n MAIN_DIR,\n MODULE_AUGMENTATION_DIR,\n REMOTE_DICTIONARIES_DIR,\n TEMP_DIR,\n TYPES_DIR,\n UNMERGED_DICTIONARIES_DIR,\n} from '../defaultValues/system';\nimport { getProjectRequire } from '../utils';\nimport { normalizePath } from '../utils/normalizePath';\n\nlet storedConfiguration: IntlayerConfig;\n\nconst buildInternationalizationFields = (\n customConfiguration?: Partial<InternationalizationConfig>\n): InternationalizationConfig => ({\n /**\n * Locales available in the application\n *\n * Default: ['en']\n *\n */\n locales: customConfiguration?.locales ?? LOCALES,\n\n /**\n * Locales required by TypeScript to ensure strong implementations of internationalized content using typescript.\n *\n * Default: []\n *\n * If empty, all locales are required in `strict` mode.\n *\n * Ensure required locales are also defined in the `locales` field.\n */\n requiredLocales:\n customConfiguration?.requiredLocales ??\n customConfiguration?.locales ??\n REQUIRED_LOCALES,\n\n /**\n * Ensure strong implementations of internationalized content using typescript.\n * - If set to \"strict\", the translation `t` function will require each declared locales to be defined. If one locale is missing, or if a locale is not declared in your config, it will throw an error.\n * - If set to \"inclusive\", the translation `t` function will require each declared locales to be defined. If one locale is missing, it will throw a warning. But will accept if a locale is not declared in your config, but exist.\n * - If set to \"loose\", the translation `t` function will accept any existing locale.\n *\n * Default: \"inclusive\"\n */\n strictMode: customConfiguration?.strictMode ?? STRICT_MODE,\n\n /**\n * Default locale of the application for fallback\n *\n * Default: 'en'\n */\n defaultLocale: customConfiguration?.defaultLocale ?? DEFAULT_LOCALE,\n});\n\nconst buildRoutingFields = (\n customConfiguration?: Partial<RoutingConfig>\n): RoutingConfig => ({\n /**\n * URL routing mode for locale handling\n *\n * Controls how locales are represented in application URLs:\n * - 'prefix-no-default': Prefix all locales except the default locale (default)\n * - en → /dashboard\n * - fr → /fr/dashboard\n *\n * - 'prefix-all': Prefix all locales including the default locale\n * - en → /en/dashboard\n * - fr → /fr/dashboard\n *\n * - 'search-params': Use search parameters for locale handling\n * - en → /dashboard?locale=en\n * - fr → /fr/dashboard?locale=fr\n *\n * - 'no-prefix': No locale prefixing in URLs\n * - en → /dashboard\n * - fr → /dashboard\n *\n * Default: 'prefix-no-default'\n */\n mode: customConfiguration?.mode ?? ROUTING_MODE,\n\n /**\n * Configuration for storing the locale in the client (localStorage or sessionStorage)\n *\n * If false, the locale will not be stored by the middleware.\n * If true, the locale storage will consider all default values. (cookie and header)\n *\n * Default: ['cookie', 'header']\n *\n */\n storage: customConfiguration?.storage ?? STORAGE,\n\n /**\n * Base path of the application URL\n *\n * Default: ''\n *\n * Example:\n * - If the application is hosted at https://example.com/my-app\n * - The base path is '/my-app'\n * - The URL will be https://example.com/my-app/en\n * - If the base path is not set, the URL will be https://example.com/en\n */\n basePath: customConfiguration?.basePath ?? BASE_PATH,\n\n /**\n * Custom URL rewriting rules that override the default routing mode for specific paths.\n * Allows you to define locale-specific paths that differ from the standard routing behavior.\n * Supports dynamic route parameters using `[param]` syntax.\n *\n * Default: undefined\n *\n * Example:\n * ```typescript\n * rewrite: {\n * \"/about\": {\n * en: \"/about\",\n * fr: \"/a-propos\",\n * },\n * \"/product/[slug]\": {\n * en: \"/product/[slug]\",\n * fr: \"/produit/[slug]\",\n * },\n * }\n * ```\n *\n * Note:\n * - The rewrite rules take precedence over the default `mode` behavior.\n * - If a path matches a rewrite rule, the localized path from the rewrite configuration will be used.\n * - Dynamic route parameters are supported using bracket notation (e.g., `[slug]`, `[id]`).\n * - Works with both Next.js and Vite applications.\n */\n rewrite: customConfiguration?.rewrite,\n});\n\nconst buildSystemFields = (\n baseDir?: string,\n customConfiguration?: Partial<SystemConfig>\n): SystemConfig => {\n const projectBaseDir = baseDir ?? process.cwd();\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n const requireFunction = getProjectRequire(projectBaseDir);\n\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [projectBaseDir],\n });\n } catch {\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(projectBaseDir, pathInput);\n }\n\n try {\n const stats = statSync(absolutePath);\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n return absolutePath;\n };\n\n const dictionariesDir = optionalJoinBaseDir(\n customConfiguration?.dictionariesDir ?? DICTIONARIES_DIR\n );\n\n return {\n baseDir: projectBaseDir,\n moduleAugmentationDir: optionalJoinBaseDir(\n customConfiguration?.moduleAugmentationDir ?? MODULE_AUGMENTATION_DIR\n ),\n unmergedDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.unmergedDictionariesDir ?? UNMERGED_DICTIONARIES_DIR\n ),\n remoteDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.remoteDictionariesDir ?? REMOTE_DICTIONARIES_DIR\n ),\n dictionariesDir,\n dynamicDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.dynamicDictionariesDir ?? DYNAMIC_DICTIONARIES_DIR\n ),\n fetchDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.fetchDictionariesDir ?? FETCH_DICTIONARIES_DIR\n ),\n typesDir: optionalJoinBaseDir(customConfiguration?.typesDir ?? TYPES_DIR),\n mainDir: optionalJoinBaseDir(customConfiguration?.mainDir ?? MAIN_DIR),\n configDir: optionalJoinBaseDir(\n customConfiguration?.configDir ?? CONFIG_DIR\n ),\n cacheDir: optionalJoinBaseDir(customConfiguration?.cacheDir ?? CACHE_DIR),\n tempDir: optionalJoinBaseDir(customConfiguration?.tempDir ?? TEMP_DIR),\n outputFilesPatternWithPath: `${normalizePath(dictionariesDir)}/**/*.json`,\n };\n};\n\nconst buildContentFields = (\n systemConfig: SystemConfig,\n customConfiguration?: Partial<ContentConfig>\n): ContentConfig => {\n const fileExtensions = customConfiguration?.fileExtensions ?? FILE_EXTENSIONS;\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n // Try resolving as a Node module first\n const requireFunction = getProjectRequire(systemConfig.baseDir);\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n try {\n // Fall back to native require.resolve if the custom require fails\n absolutePath = require.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n // If all resolution fails, fall back to standard path joining\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(systemConfig.baseDir, pathInput);\n }\n }\n\n try {\n // Smart Detection: File vs Directory\n const stats = statSync(absolutePath);\n\n // If it resolved to a file (like package.json \"main\" or index.js),\n // we want the FOLDER containing that file.\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n // Safety Fallback:\n // If statSync fails but it looks like a file (has an extension), strip it.\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n // Return the calculated path (usually a directory)\n return absolutePath;\n };\n\n const contentDir = (customConfiguration?.contentDir ?? CONTENT_DIR).map(\n optionalJoinBaseDir\n );\n\n const codeDirInput = customConfiguration?.codeDir;\n\n const codeDir = (codeDirInput ?? CODE_DIR).map(optionalJoinBaseDir);\n\n return {\n fileExtensions,\n contentDir,\n codeDir,\n excludedPath: customConfiguration?.excludedPath ?? EXCLUDED_PATHS,\n watch: customConfiguration?.watch ?? WATCH,\n formatCommand: customConfiguration?.formatCommand,\n watchedFilesPattern: fileExtensions.map((ext) => `/**/*${ext}`),\n watchedFilesPatternWithPath: fileExtensions.flatMap((ext) =>\n contentDir.map((dir) => `${normalizePath(dir)}/**/*${ext}`)\n ),\n };\n};\n\nconst buildEditorFields = (\n customConfiguration?: Partial<EditorConfig>\n): EditorConfig => ({\n /**\n * URL of the application. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n applicationURL: customConfiguration?.applicationURL ?? APPLICATION_URL,\n\n /**\n * URL of the editor server. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n editorURL: customConfiguration?.editorURL ?? EDITOR_URL,\n\n /**\n * URL of the CMS server. Used to restrict the origin of the editor for security reasons.\n */\n cmsURL: customConfiguration?.cmsURL ?? CMS_URL,\n\n /**\n * URL of the editor server\n *\n * Default: 'https://back.intlayer.org'\n */\n backendURL: customConfiguration?.backendURL ?? BACKEND_URL,\n\n /** Port of the editor server\n *\n * Default: 8000\n */\n port: customConfiguration?.port ?? PORT,\n\n /**\n * Indicates if the application interact with the visual editor\n *\n * Default: true;\n *\n * If true, the editor will be able to interact with the application.\n * If false, the editor will not be able to interact with the application.\n * In any case, the editor can only be enabled by the visual editor.\n * Disabling the editor for specific environments is a way to enforce the security.\n *\n * Usage:\n * ```js\n * {\n * // Other configurations\n * editor: {\n * enabled: process.env.NODE_ENV !== 'production',\n * }\n * };\n * ```\n */\n enabled: customConfiguration?.enabled ?? IS_ENABLED,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientId: customConfiguration?.clientId ?? undefined,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientSecret: customConfiguration?.clientSecret ?? undefined,\n\n /**\n * Strategy for prioritizing dictionaries. If a dictionary is both present online and locally, the content will be merge.\n * However, is a field is defined in both dictionary, this setting determines which fields takes the priority over the other.\n *\n * Default: 'local_first'\n *\n * The strategy for prioritizing dictionaries. It can be either 'local_first' or 'distant_first'.\n * - 'local_first': The first dictionary found in the locale is used.\n * - 'distant_first': The first dictionary found in the distant locales is used.\n */\n dictionaryPriorityStrategy:\n customConfiguration?.dictionaryPriorityStrategy ??\n DICTIONARY_PRIORITY_STRATEGY,\n\n /**\n * Indicates if the application should hot reload the locale configurations when a change is detected.\n * For example, when a new dictionary is added or updated, the application will update the content tu display in the page.\n *\n * The hot reload is only available for clients of the `enterprise` plan.\n *\n * Default: false\n */\n liveSync: customConfiguration?.liveSync ?? LIVE_SYNC,\n\n /**\n * Port of the live sync server\n *\n * Default: 4000\n */\n liveSyncPort: customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT,\n\n /**\n * URL of the live sync server in case of remote live sync server\n *\n * Default: `http://localhost:${LIVE_SYNC_PORT}`\n */\n liveSyncURL:\n customConfiguration?.liveSyncURL ??\n `http://localhost:${customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT}`,\n});\n\nconst buildLogFields = (\n customConfiguration?: Partial<LogConfig>,\n logFunctions?: LogFunctions\n): LogConfig => ({\n /**\n * Indicates if the logger is enabled\n *\n * Default: 'prefix-no-default'\n *\n * If 'default', the logger is enabled and can be used.\n * If 'verbose', the logger will be enabled and can be used, but will log more information.\n * If 'disabled', the logger is disabled and cannot be used.\n */\n mode: customConfiguration?.mode ?? MODE,\n\n /**\n * Prefix of the logger\n *\n * Default: '[intlayer]'\n *\n * The prefix of the logger.\n */\n prefix: customConfiguration?.prefix ?? PREFIX,\n\n /**\n * Functions to log\n */\n error: logFunctions?.error,\n log: logFunctions?.log,\n info: logFunctions?.info,\n warn: logFunctions?.warn,\n});\n\nconst buildAiFields = (customConfiguration?: Partial<AiConfig>): AiConfig => ({\n /**\n * AI configuration\n */\n provider: customConfiguration?.provider,\n\n /**\n * API key\n */\n apiKey: customConfiguration?.apiKey,\n\n /**\n * API model\n */\n model: customConfiguration?.model,\n\n /**\n * Temperature\n */\n temperature: customConfiguration?.temperature,\n\n /**\n * Application context\n *\n * Default: undefined\n *\n * The application context.\n *\n * Example: `'My application context'`\n *\n * Note: Can be used to provide additional context about the application to the AI model. You can add more rules (e.g. \"You should not transform urls\").\n */\n applicationContext: customConfiguration?.applicationContext,\n\n /**\n * Base URL for the AI API\n *\n * Default: undefined\n *\n * The base URL for the AI API.\n *\n * Example: `'http://localhost:5000'`\n *\n * Note: Can be used to point to a local, or custom AI API endpoint.\n */\n baseURL: customConfiguration?.baseURL,\n\n /**\n * Data serialization\n *\n * Options:\n * - \"json\": The industry standard. Highly reliable and structured, but consumes more tokens.\n * - \"toon\": An optimized format designed to reduce token consumption (cost-effective). However, it may slightly increase the risk of output inconsistency compared to standard JSON\n *\n * Default: \"json\"\n */\n dataSerialization: customConfiguration?.dataSerialization,\n});\n\nconst buildBuildFields = (\n customConfiguration?: Partial<BuildConfig>\n): BuildConfig => ({\n /**\n * Indicates the mode of the build\n *\n * Default: 'auto'\n *\n * If 'auto', the build will be enabled automatically when the application is built.\n * If 'manual', the build will be set only when the build command is executed.\n *\n * Can be used to disable dictionaries build, for instance when execution on Node.js environment should be avoided.\n */\n mode: customConfiguration?.mode ?? BUILD_MODE,\n\n /**\n * Indicates if the build should be optimized\n *\n * Default: process.env.NODE_ENV === 'production'\n *\n * If true, the build will be optimized.\n * If false, the build will not be optimized.\n *\n * Intlayer will replace all calls of dictionaries to optimize chunking. That way the final bundle will import only the dictionaries that are used.\n * All imports will stay as static import to avoid async processing when loading the dictionaries.\n *\n * Note:\n * - Intlayer will replace all call of `useIntlayer` with the defined mode by the `importMode` option.\n * - Intlayer will replace all call of `getIntlayer` with `getDictionary`.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - In most cases, \"dynamic\" will be used for React applications, \"async\" for Vue.js applications.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n */\n optimize: customConfiguration?.optimize,\n\n /**\n * Indicates the mode of import to use for the dictionaries.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionary`.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * Live mode will use the live sync API to fetch the dictionaries. If the API call fails, the dictionaries will be imported dynamically as \"dynamic\" mode.\n *\n * Default: \"static\"\n *\n * By default, when a dictionary is loaded, it imports content for all locales as it's imported statically.\n *\n * Note:\n * - Dynamic imports rely on Suspense and may slightly impact rendering performance.\n * - If disabled all locales will be loaded at once, even if they are not used.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n * - This option will be ignored if `optimize` is disabled.\n * - This option will not impact the `getIntlayer`, `getDictionary`, `useDictionary`, `useDictionaryAsync` and `useDictionaryDynamic` functions. You can still use them to refine you code on manual optimization.\n * - The \"live\" allows to sync the dictionaries to the live sync server.\n *\n * @deprecated Use `dictionary.importMode` instead.\n */\n importMode: customConfiguration?.importMode,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * Allows to avoid to traverse the code that is not relevant to the optimization.\n * Improve build performance.\n *\n * Default: ['**\\/*.{js,ts,mjs,cjs,jsx,tsx}', '!**\\/node_modules/**']\n *\n * Example: `['src/**\\/*.{ts,tsx}', '../ui-library/**\\/*.{ts,tsx}']`\n *\n * Note:\n * - This option will be ignored if `optimize` is disabled.\n * - Use glob pattern.\n */\n traversePattern: customConfiguration?.traversePattern ?? TRAVERSE_PATTERN,\n\n /**\n * Output format of the dictionaries\n *\n * Can be set on large projects to improve build performance.\n *\n * Default: ['cjs', 'esm']\n *\n * The output format of the dictionaries. It can be either 'cjs' or 'esm'.\n * - 'cjs': The dictionaries are outputted as CommonJS modules.\n * - 'esm': The dictionaries are outputted as ES modules.\n */\n outputFormat: customConfiguration?.outputFormat ?? OUTPUT_FORMAT,\n\n /**\n * Cache\n */\n cache: customConfiguration?.cache ?? CACHE,\n\n /**\n * Require function\n */\n require: customConfiguration?.require,\n\n /**\n * Indicates if the build should check TypeScript types\n *\n * Default: false\n *\n * If true, the build will check TypeScript types and log errors.\n * Note: This can slow down the build.\n */\n checkTypes: customConfiguration?.checkTypes ?? TYPE_CHECKING,\n});\n\nconst buildCompilerFields = (\n customConfiguration?: Partial<CompilerConfig>\n): CompilerConfig => ({\n /**\n * Indicates if the compiler should be enabled\n */\n enabled: customConfiguration?.enabled ?? COMPILER_ENABLED,\n\n /**\n * Prefix for the extracted dictionary keys\n */\n dictionaryKeyPrefix:\n customConfiguration?.dictionaryKeyPrefix ?? COMPILER_DICTIONARY_KEY_PREFIX,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * @deprecated use build.traversePattern instead\n */\n transformPattern: customConfiguration?.transformPattern,\n\n /**\n * Pattern to exclude from the optimization.\n *\n * @deprecated use build.traversePattern instead\n */\n excludePattern: customConfiguration?.excludePattern,\n\n /**\n * Output directory for the optimized dictionaries.\n * @deprecated use `output` instead\n */\n outputDir: customConfiguration?.outputDir,\n\n /**\n * File path pattern for generated dictionaries.\n */\n output: customConfiguration?.output,\n\n /**\n * Indicates if the metadata should be saved in the file.\n *\n * If true, the compiler will not save the metadata of the dictionaries.\n *\n * If true:\n *\n * ```json\n * {\n * \"key\": \"value\"\n * }\n * ```\n *\n * If false:\n *\n * ```json\n * {\n * \"key\": \"value\",\n * \"content\": {\n * \"key\": \"value\"\n * }\n * }\n * ```\n *\n * Default: false\n *\n * Note: Useful if used with loadJSON plugin\n */\n noMetadata: customConfiguration?.noMetadata ?? COMPILER_NO_METADATA,\n\n /**\n * Indicates if the components should be saved after being transformed.\n */\n saveComponents:\n customConfiguration?.saveComponents ?? COMPILER_SAVE_COMPONENTS,\n});\n\nconst buildDictionaryFields = (\n customConfiguration?: Partial<DictionaryConfig>\n): DictionaryConfig => {\n const contentAutoTransformation =\n customConfiguration?.contentAutoTransformation ??\n CONTENT_AUTO_TRANSFORMATION;\n\n return {\n /**\n * Indicate how the dictionary should be filled using AI.\n *\n * Default: true\n */\n fill: customConfiguration?.fill ?? FILL,\n\n /**\n * Indicates if the content of the dictionary should be automatically transformed.\n *\n * Default: false\n */\n contentAutoTransformation:\n typeof contentAutoTransformation === 'object'\n ? {\n markdown: contentAutoTransformation.markdown ?? false,\n html: contentAutoTransformation.html ?? false,\n insertion: contentAutoTransformation.insertion ?? false,\n }\n : contentAutoTransformation,\n\n /**\n * The location of the dictionary.\n *\n * Default: 'local'\n */\n location: customConfiguration?.location ?? LOCATION,\n\n /**\n * Transform the dictionary in a per-locale dictionary.\n * Each field declared in a per-locale dictionary will be transformed in a translation node.\n * If missing, the dictionary will be treated as a multilingual dictionary.\n */\n locale: customConfiguration?.locale,\n\n /**\n * The title of the dictionary.\n */\n title: customConfiguration?.title,\n\n /**\n * The description of the dictionary.\n */\n description: customConfiguration?.description,\n\n /**\n * Tags to categorize the dictionaries.\n */\n tags: customConfiguration?.tags,\n\n /**\n * The priority of the dictionary.\n */\n priority: customConfiguration?.priority,\n\n /**\n * Indicates the mode of import to use for the dictionary.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n *\n * Default: 'static'\n */\n importMode: customConfiguration?.importMode ?? IMPORT_MODE,\n\n /**\n * The version of the dictionary.\n */\n version: customConfiguration?.version,\n };\n};\n\n/**\n * Build the configuration fields by merging the default values with the custom configuration\n */\nexport const buildConfigurationFields = (\n customConfiguration?: CustomIntlayerConfig,\n baseDir?: string,\n logFunctions?: LogFunctions\n): IntlayerConfig => {\n const internationalizationConfig = buildInternationalizationFields(\n customConfiguration?.internationalization\n );\n\n const routingConfig = buildRoutingFields(customConfiguration?.routing);\n\n const systemConfig = buildSystemFields(baseDir, customConfiguration?.system);\n\n const contentConfig = buildContentFields(\n systemConfig,\n customConfiguration?.content\n );\n\n const editorConfig = buildEditorFields(customConfiguration?.editor);\n\n const logConfig = buildLogFields(customConfiguration?.log, logFunctions);\n\n const aiConfig = buildAiFields(customConfiguration?.ai);\n\n const buildConfig = buildBuildFields(customConfiguration?.build);\n\n const compilerConfig = buildCompilerFields(customConfiguration?.compiler);\n\n const dictionaryConfig = buildDictionaryFields(\n customConfiguration?.dictionary\n );\n\n storedConfiguration = {\n internationalization: internationalizationConfig,\n routing: routingConfig,\n content: contentConfig,\n system: systemConfig,\n editor: editorConfig,\n log: logConfig,\n ai: aiConfig,\n build: buildConfig,\n compiler: compilerConfig,\n dictionary: dictionaryConfig,\n plugins: customConfiguration?.plugins,\n schemas: customConfiguration?.schemas,\n metadata: {\n name: 'Intlayer',\n version: packageJson.version,\n doc: `https://intlayer.org/docs`,\n },\n } as IntlayerConfig;\n\n return storedConfiguration;\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"buildConfigurationFields.mjs","names":["packageJson"],"sources":["../../../src/configFile/buildConfigurationFields.ts"],"sourcesContent":["import { statSync } from 'node:fs';\nimport { dirname, isAbsolute, join } from 'node:path';\nimport type {\n AiConfig,\n BuildConfig,\n CompilerConfig,\n ContentConfig,\n CustomIntlayerConfig,\n DictionaryConfig,\n EditorConfig,\n InternationalizationConfig,\n IntlayerConfig,\n LogConfig,\n LogFunctions,\n RoutingConfig,\n SystemConfig,\n} from '@intlayer/types/config';\nimport packageJson from '@intlayer/types/package.json' with { type: 'json' };\nimport {\n BUILD_MODE,\n CACHE,\n OUTPUT_FORMAT,\n TRAVERSE_PATTERN,\n TYPE_CHECKING,\n} from '../defaultValues/build';\nimport {\n COMPILER_DICTIONARY_KEY_PREFIX,\n COMPILER_ENABLED,\n COMPILER_NO_METADATA,\n COMPILER_OUTPUT,\n COMPILER_SAVE_COMPONENTS,\n} from '../defaultValues/compiler';\nimport {\n CODE_DIR,\n CONTENT_DIR,\n EXCLUDED_PATHS,\n FILE_EXTENSIONS,\n WATCH,\n} from '../defaultValues/content';\nimport {\n CONTENT_AUTO_TRANSFORMATION,\n FILL,\n IMPORT_MODE,\n LOCATION,\n} from '../defaultValues/dictionary';\nimport {\n APPLICATION_URL,\n BACKEND_URL,\n CMS_URL,\n DICTIONARY_PRIORITY_STRATEGY,\n EDITOR_URL,\n IS_ENABLED,\n LIVE_SYNC,\n LIVE_SYNC_PORT,\n PORT,\n} from '../defaultValues/editor';\nimport {\n DEFAULT_LOCALE,\n LOCALES,\n REQUIRED_LOCALES,\n STRICT_MODE,\n} from '../defaultValues/internationalization';\nimport { MODE, PREFIX } from '../defaultValues/log';\nimport { BASE_PATH, ROUTING_MODE, STORAGE } from '../defaultValues/routing';\nimport {\n CACHE_DIR,\n CONFIG_DIR,\n DICTIONARIES_DIR,\n DYNAMIC_DICTIONARIES_DIR,\n FETCH_DICTIONARIES_DIR,\n MAIN_DIR,\n MODULE_AUGMENTATION_DIR,\n REMOTE_DICTIONARIES_DIR,\n TEMP_DIR,\n TYPES_DIR,\n UNMERGED_DICTIONARIES_DIR,\n} from '../defaultValues/system';\nimport { getProjectRequire } from '../utils';\nimport { normalizePath } from '../utils/normalizePath';\n\nlet storedConfiguration: IntlayerConfig;\n\nconst buildInternationalizationFields = (\n customConfiguration?: Partial<InternationalizationConfig>\n): InternationalizationConfig => ({\n /**\n * Locales available in the application\n *\n * Default: ['en']\n *\n */\n locales: customConfiguration?.locales ?? LOCALES,\n\n /**\n * Locales required by TypeScript to ensure strong implementations of internationalized content using typescript.\n *\n * Default: []\n *\n * If empty, all locales are required in `strict` mode.\n *\n * Ensure required locales are also defined in the `locales` field.\n */\n requiredLocales:\n customConfiguration?.requiredLocales ??\n customConfiguration?.locales ??\n REQUIRED_LOCALES,\n\n /**\n * Ensure strong implementations of internationalized content using typescript.\n * - If set to \"strict\", the translation `t` function will require each declared locales to be defined. If one locale is missing, or if a locale is not declared in your config, it will throw an error.\n * - If set to \"inclusive\", the translation `t` function will require each declared locales to be defined. If one locale is missing, it will throw a warning. But will accept if a locale is not declared in your config, but exist.\n * - If set to \"loose\", the translation `t` function will accept any existing locale.\n *\n * Default: \"inclusive\"\n */\n strictMode: customConfiguration?.strictMode ?? STRICT_MODE,\n\n /**\n * Default locale of the application for fallback\n *\n * Default: 'en'\n */\n defaultLocale: customConfiguration?.defaultLocale ?? DEFAULT_LOCALE,\n});\n\nconst buildRoutingFields = (\n customConfiguration?: Partial<RoutingConfig>\n): RoutingConfig => ({\n /**\n * URL routing mode for locale handling\n *\n * Controls how locales are represented in application URLs:\n * - 'prefix-no-default': Prefix all locales except the default locale (default)\n * - en → /dashboard\n * - fr → /fr/dashboard\n *\n * - 'prefix-all': Prefix all locales including the default locale\n * - en → /en/dashboard\n * - fr → /fr/dashboard\n *\n * - 'search-params': Use search parameters for locale handling\n * - en → /dashboard?locale=en\n * - fr → /fr/dashboard?locale=fr\n *\n * - 'no-prefix': No locale prefixing in URLs\n * - en → /dashboard\n * - fr → /dashboard\n *\n * Default: 'prefix-no-default'\n */\n mode: customConfiguration?.mode ?? ROUTING_MODE,\n\n /**\n * Configuration for storing the locale in the client (localStorage or sessionStorage)\n *\n * If false, the locale will not be stored by the middleware.\n * If true, the locale storage will consider all default values. (cookie and header)\n *\n * Default: ['cookie', 'header']\n *\n */\n storage: customConfiguration?.storage ?? STORAGE,\n\n /**\n * Base path of the application URL\n *\n * Default: ''\n *\n * Example:\n * - If the application is hosted at https://example.com/my-app\n * - The base path is '/my-app'\n * - The URL will be https://example.com/my-app/en\n * - If the base path is not set, the URL will be https://example.com/en\n */\n basePath: customConfiguration?.basePath ?? BASE_PATH,\n\n /**\n * Custom URL rewriting rules that override the default routing mode for specific paths.\n * Allows you to define locale-specific paths that differ from the standard routing behavior.\n * Supports dynamic route parameters using `[param]` syntax.\n *\n * Default: undefined\n *\n * Example:\n * ```typescript\n * rewrite: {\n * \"/about\": {\n * en: \"/about\",\n * fr: \"/a-propos\",\n * },\n * \"/product/[slug]\": {\n * en: \"/product/[slug]\",\n * fr: \"/produit/[slug]\",\n * },\n * }\n * ```\n *\n * Note:\n * - The rewrite rules take precedence over the default `mode` behavior.\n * - If a path matches a rewrite rule, the localized path from the rewrite configuration will be used.\n * - Dynamic route parameters are supported using bracket notation (e.g., `[slug]`, `[id]`).\n * - Works with both Next.js and Vite applications.\n */\n rewrite: customConfiguration?.rewrite,\n});\n\nconst buildSystemFields = (\n baseDir?: string,\n customConfiguration?: Partial<SystemConfig>\n): SystemConfig => {\n const projectBaseDir = baseDir ?? process.cwd();\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n const requireFunction = getProjectRequire(projectBaseDir);\n\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [projectBaseDir],\n });\n } catch {\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(projectBaseDir, pathInput);\n }\n\n try {\n const stats = statSync(absolutePath);\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n return absolutePath;\n };\n\n const dictionariesDir = optionalJoinBaseDir(\n customConfiguration?.dictionariesDir ?? DICTIONARIES_DIR\n );\n\n return {\n baseDir: projectBaseDir,\n moduleAugmentationDir: optionalJoinBaseDir(\n customConfiguration?.moduleAugmentationDir ?? MODULE_AUGMENTATION_DIR\n ),\n unmergedDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.unmergedDictionariesDir ?? UNMERGED_DICTIONARIES_DIR\n ),\n remoteDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.remoteDictionariesDir ?? REMOTE_DICTIONARIES_DIR\n ),\n dictionariesDir,\n dynamicDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.dynamicDictionariesDir ?? DYNAMIC_DICTIONARIES_DIR\n ),\n fetchDictionariesDir: optionalJoinBaseDir(\n customConfiguration?.fetchDictionariesDir ?? FETCH_DICTIONARIES_DIR\n ),\n typesDir: optionalJoinBaseDir(customConfiguration?.typesDir ?? TYPES_DIR),\n mainDir: optionalJoinBaseDir(customConfiguration?.mainDir ?? MAIN_DIR),\n configDir: optionalJoinBaseDir(\n customConfiguration?.configDir ?? CONFIG_DIR\n ),\n cacheDir: optionalJoinBaseDir(customConfiguration?.cacheDir ?? CACHE_DIR),\n tempDir: optionalJoinBaseDir(customConfiguration?.tempDir ?? TEMP_DIR),\n outputFilesPatternWithPath: `${normalizePath(dictionariesDir)}/**/*.json`,\n };\n};\n\nconst buildContentFields = (\n systemConfig: SystemConfig,\n customConfiguration?: Partial<ContentConfig>\n): ContentConfig => {\n const fileExtensions = customConfiguration?.fileExtensions ?? FILE_EXTENSIONS;\n\n const optionalJoinBaseDir = (pathInput: string) => {\n let absolutePath: string;\n\n try {\n // Try resolving as a Node module first\n const requireFunction = getProjectRequire(systemConfig.baseDir);\n absolutePath = requireFunction.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n try {\n // Fall back to native require.resolve if the custom require fails\n absolutePath = require.resolve(pathInput, {\n paths: [systemConfig.baseDir],\n });\n } catch {\n // If all resolution fails, fall back to standard path joining\n absolutePath = isAbsolute(pathInput)\n ? pathInput\n : join(systemConfig.baseDir, pathInput);\n }\n }\n\n try {\n // Smart Detection: File vs Directory\n const stats = statSync(absolutePath);\n\n // If it resolved to a file (like package.json \"main\" or index.js),\n // we want the FOLDER containing that file.\n if (stats.isFile()) {\n return dirname(absolutePath);\n }\n } catch {\n // Safety Fallback:\n // If statSync fails but it looks like a file (has an extension), strip it.\n if (/\\.[a-z0-9]+$/i.test(absolutePath)) {\n return dirname(absolutePath);\n }\n }\n\n // Return the calculated path (usually a directory)\n return absolutePath;\n };\n\n const contentDir = (customConfiguration?.contentDir ?? CONTENT_DIR).map(\n optionalJoinBaseDir\n );\n\n const codeDirInput = customConfiguration?.codeDir;\n\n const codeDir = (codeDirInput ?? CODE_DIR).map(optionalJoinBaseDir);\n\n return {\n fileExtensions,\n contentDir,\n codeDir,\n excludedPath: customConfiguration?.excludedPath ?? EXCLUDED_PATHS,\n watch: customConfiguration?.watch ?? WATCH,\n formatCommand: customConfiguration?.formatCommand,\n watchedFilesPattern: fileExtensions.map((ext) => `/**/*${ext}`),\n watchedFilesPatternWithPath: fileExtensions.flatMap((ext) =>\n contentDir.map((dir) => `${normalizePath(dir)}/**/*${ext}`)\n ),\n };\n};\n\nconst buildEditorFields = (\n customConfiguration?: Partial<EditorConfig>\n): EditorConfig => ({\n /**\n * URL of the application. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n applicationURL: customConfiguration?.applicationURL || APPLICATION_URL,\n\n /**\n * URL of the editor server. Used to restrict the origin of the editor for security reasons.\n *\n * > '*' means that the editor is accessible from any origin\n *\n * Default: '*'\n */\n editorURL: customConfiguration?.editorURL || EDITOR_URL,\n\n /**\n * URL of the CMS server. Used to restrict the origin of the editor for security reasons.\n */\n cmsURL: customConfiguration?.cmsURL || CMS_URL,\n\n /**\n * URL of the editor server\n *\n * Default: 'https://back.intlayer.org'\n */\n backendURL: customConfiguration?.backendURL || BACKEND_URL,\n\n /** Port of the editor server\n *\n * Default: 8000\n */\n port: customConfiguration?.port ?? PORT,\n\n /**\n * Indicates if the application interact with the visual editor\n *\n * Default: true;\n *\n * If true, the editor will be able to interact with the application.\n * If false, the editor will not be able to interact with the application.\n * In any case, the editor can only be enabled by the visual editor.\n * Disabling the editor for specific environments is a way to enforce the security.\n *\n * Usage:\n * ```js\n * {\n * // Other configurations\n * editor: {\n * enabled: process.env.NODE_ENV !== 'production',\n * }\n * };\n * ```\n */\n enabled: customConfiguration?.enabled ?? IS_ENABLED,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientId: customConfiguration?.clientId ?? undefined,\n\n /**\n * clientId and clientSecret allow the intlayer packages to authenticate with the backend using oAuth2 authentication.\n * An access token is use to authenticate the user related to the project.\n * To get an access token, go to https://app.intlayer.org/project and create an account.\n *\n * Default: undefined\n *\n * > Important: The clientId and clientSecret should be kept secret and not shared publicly. Please ensure to keep them in a secure location, such as environment variables.\n */\n clientSecret: customConfiguration?.clientSecret ?? undefined,\n\n /**\n * Strategy for prioritizing dictionaries. If a dictionary is both present online and locally, the content will be merge.\n * However, is a field is defined in both dictionary, this setting determines which fields takes the priority over the other.\n *\n * Default: 'local_first'\n *\n * The strategy for prioritizing dictionaries. It can be either 'local_first' or 'distant_first'.\n * - 'local_first': The first dictionary found in the locale is used.\n * - 'distant_first': The first dictionary found in the distant locales is used.\n */\n dictionaryPriorityStrategy:\n customConfiguration?.dictionaryPriorityStrategy ??\n DICTIONARY_PRIORITY_STRATEGY,\n\n /**\n * Indicates if the application should hot reload the locale configurations when a change is detected.\n * For example, when a new dictionary is added or updated, the application will update the content tu display in the page.\n *\n * The hot reload is only available for clients of the `enterprise` plan.\n *\n * Default: false\n */\n liveSync: customConfiguration?.liveSync ?? LIVE_SYNC,\n\n /**\n * Port of the live sync server\n *\n * Default: 4000\n */\n liveSyncPort: customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT,\n\n /**\n * URL of the live sync server in case of remote live sync server\n *\n * Default: `http://localhost:${LIVE_SYNC_PORT}`\n */\n liveSyncURL:\n customConfiguration?.liveSyncURL ??\n `http://localhost:${customConfiguration?.liveSyncPort ?? LIVE_SYNC_PORT}`,\n});\n\nconst buildLogFields = (\n customConfiguration?: Partial<LogConfig>,\n logFunctions?: LogFunctions\n): LogConfig => ({\n /**\n * Indicates if the logger is enabled\n *\n * Default: 'prefix-no-default'\n *\n * If 'default', the logger is enabled and can be used.\n * If 'verbose', the logger will be enabled and can be used, but will log more information.\n * If 'disabled', the logger is disabled and cannot be used.\n */\n mode: customConfiguration?.mode ?? MODE,\n\n /**\n * Prefix of the logger\n *\n * Default: '[intlayer]'\n *\n * The prefix of the logger.\n */\n prefix: customConfiguration?.prefix ?? PREFIX,\n\n /**\n * Functions to log\n */\n error: logFunctions?.error,\n log: logFunctions?.log,\n info: logFunctions?.info,\n warn: logFunctions?.warn,\n});\n\nconst buildAiFields = (customConfiguration?: Partial<AiConfig>): AiConfig => ({\n /**\n * AI configuration\n */\n provider: customConfiguration?.provider,\n\n /**\n * API key\n */\n apiKey: customConfiguration?.apiKey,\n\n /**\n * API model\n */\n model: customConfiguration?.model,\n\n /**\n * Temperature\n */\n temperature: customConfiguration?.temperature,\n\n /**\n * Application context\n *\n * Default: undefined\n *\n * The application context.\n *\n * Example: `'My application context'`\n *\n * Note: Can be used to provide additional context about the application to the AI model. You can add more rules (e.g. \"You should not transform urls\").\n */\n applicationContext: customConfiguration?.applicationContext,\n\n /**\n * Base URL for the AI API\n *\n * Default: undefined\n *\n * The base URL for the AI API.\n *\n * Example: `'http://localhost:5000'`\n *\n * Note: Can be used to point to a local, or custom AI API endpoint.\n */\n baseURL: customConfiguration?.baseURL,\n\n /**\n * Data serialization\n *\n * Options:\n * - \"json\": The industry standard. Highly reliable and structured, but consumes more tokens.\n * - \"toon\": An optimized format designed to reduce token consumption (cost-effective). However, it may slightly increase the risk of output inconsistency compared to standard JSON\n *\n * Default: \"json\"\n */\n dataSerialization: customConfiguration?.dataSerialization,\n});\n\nconst buildBuildFields = (\n customConfiguration?: Partial<BuildConfig>\n): BuildConfig => ({\n /**\n * Indicates the mode of the build\n *\n * Default: 'auto'\n *\n * If 'auto', the build will be enabled automatically when the application is built.\n * If 'manual', the build will be set only when the build command is executed.\n *\n * Can be used to disable dictionaries build, for instance when execution on Node.js environment should be avoided.\n */\n mode: customConfiguration?.mode ?? BUILD_MODE,\n\n /**\n * Indicates if the build should be optimized\n *\n * Default: process.env.NODE_ENV === 'production'\n *\n * If true, the build will be optimized.\n * If false, the build will not be optimized.\n *\n * Intlayer will replace all calls of dictionaries to optimize chunking. That way the final bundle will import only the dictionaries that are used.\n * All imports will stay as static import to avoid async processing when loading the dictionaries.\n *\n * Note:\n * - Intlayer will replace all call of `useIntlayer` with the defined mode by the `importMode` option.\n * - Intlayer will replace all call of `getIntlayer` with `getDictionary`.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - In most cases, \"dynamic\" will be used for React applications, \"async\" for Vue.js applications.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n */\n optimize: customConfiguration?.optimize,\n\n /**\n * Indicates the mode of import to use for the dictionaries.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionary`.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n * In that case, Intlayer will replace all calls to `useIntlayer` with `useDictionaryDynamic`.\n * Live mode will use the live sync API to fetch the dictionaries. If the API call fails, the dictionaries will be imported dynamically as \"dynamic\" mode.\n *\n * Default: \"static\"\n *\n * By default, when a dictionary is loaded, it imports content for all locales as it's imported statically.\n *\n * Note:\n * - Dynamic imports rely on Suspense and may slightly impact rendering performance.\n * - If disabled all locales will be loaded at once, even if they are not used.\n * - This option relies on the `@intlayer/babel` and `@intlayer/swc` plugins.\n * - Ensure all keys are declared statically in the `useIntlayer` calls. e.g. `useIntlayer('navbar')`.\n * - This option will be ignored if `optimize` is disabled.\n * - This option will not impact the `getIntlayer`, `getDictionary`, `useDictionary`, `useDictionaryAsync` and `useDictionaryDynamic` functions. You can still use them to refine you code on manual optimization.\n * - The \"live\" allows to sync the dictionaries to the live sync server.\n *\n * @deprecated Use `dictionary.importMode` instead.\n */\n importMode: customConfiguration?.importMode,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * Allows to avoid to traverse the code that is not relevant to the optimization.\n * Improve build performance.\n *\n * Default: ['**\\/*.{js,ts,mjs,cjs,jsx,tsx}', '!**\\/node_modules/**']\n *\n * Example: `['src/**\\/*.{ts,tsx}', '../ui-library/**\\/*.{ts,tsx}']`\n *\n * Note:\n * - This option will be ignored if `optimize` is disabled.\n * - Use glob pattern.\n */\n traversePattern: customConfiguration?.traversePattern ?? TRAVERSE_PATTERN,\n\n /**\n * Output format of the dictionaries\n *\n * Can be set on large projects to improve build performance.\n *\n * Default: ['cjs', 'esm']\n *\n * The output format of the dictionaries. It can be either 'cjs' or 'esm'.\n * - 'cjs': The dictionaries are outputted as CommonJS modules.\n * - 'esm': The dictionaries are outputted as ES modules.\n */\n outputFormat: customConfiguration?.outputFormat ?? OUTPUT_FORMAT,\n\n /**\n * Cache\n */\n cache: customConfiguration?.cache ?? CACHE,\n\n /**\n * Require function\n */\n require: customConfiguration?.require,\n\n /**\n * Indicates if the build should check TypeScript types\n *\n * Default: false\n *\n * If true, the build will check TypeScript types and log errors.\n * Note: This can slow down the build.\n */\n checkTypes: customConfiguration?.checkTypes ?? TYPE_CHECKING,\n});\n\nconst buildCompilerFields = (\n customConfiguration?: Partial<CompilerConfig>\n): CompilerConfig => ({\n /**\n * Indicates if the compiler should be enabled\n */\n enabled: customConfiguration?.enabled ?? COMPILER_ENABLED,\n\n /**\n * Prefix for the extracted dictionary keys\n */\n dictionaryKeyPrefix:\n customConfiguration?.dictionaryKeyPrefix ?? COMPILER_DICTIONARY_KEY_PREFIX,\n\n /**\n * Pattern to traverse the code to optimize.\n *\n * @deprecated use build.traversePattern instead\n */\n transformPattern: customConfiguration?.transformPattern,\n\n /**\n * Pattern to exclude from the optimization.\n *\n * @deprecated use build.traversePattern instead\n */\n excludePattern: customConfiguration?.excludePattern,\n\n /**\n * Output directory for the optimized dictionaries.\n * @deprecated use `output` instead\n */\n outputDir: customConfiguration?.outputDir,\n\n /**\n * File path pattern for generated dictionaries.\n */\n output: customConfiguration?.output,\n\n /**\n * Indicates if the metadata should be saved in the file.\n *\n * If true, the compiler will not save the metadata of the dictionaries.\n *\n * If true:\n *\n * ```json\n * {\n * \"key\": \"value\"\n * }\n * ```\n *\n * If false:\n *\n * ```json\n * {\n * \"key\": \"value\",\n * \"content\": {\n * \"key\": \"value\"\n * }\n * }\n * ```\n *\n * Default: false\n *\n * Note: Useful if used with loadJSON plugin\n */\n noMetadata: customConfiguration?.noMetadata ?? COMPILER_NO_METADATA,\n\n /**\n * Indicates if the components should be saved after being transformed.\n */\n saveComponents:\n customConfiguration?.saveComponents ?? COMPILER_SAVE_COMPONENTS,\n});\n\nconst buildDictionaryFields = (\n customConfiguration?: Partial<DictionaryConfig>\n): DictionaryConfig => {\n const contentAutoTransformation =\n customConfiguration?.contentAutoTransformation ??\n CONTENT_AUTO_TRANSFORMATION;\n\n return {\n /**\n * Indicate how the dictionary should be filled using AI.\n *\n * Default: true\n */\n fill: customConfiguration?.fill ?? FILL,\n\n /**\n * Indicates if the content of the dictionary should be automatically transformed.\n *\n * Default: false\n */\n contentAutoTransformation:\n typeof contentAutoTransformation === 'object'\n ? {\n markdown: contentAutoTransformation.markdown ?? false,\n html: contentAutoTransformation.html ?? false,\n insertion: contentAutoTransformation.insertion ?? false,\n }\n : contentAutoTransformation,\n\n /**\n * The location of the dictionary.\n *\n * Default: 'local'\n */\n location: customConfiguration?.location ?? LOCATION,\n\n /**\n * Transform the dictionary in a per-locale dictionary.\n * Each field declared in a per-locale dictionary will be transformed in a translation node.\n * If missing, the dictionary will be treated as a multilingual dictionary.\n */\n locale: customConfiguration?.locale,\n\n /**\n * The title of the dictionary.\n */\n title: customConfiguration?.title,\n\n /**\n * The description of the dictionary.\n */\n description: customConfiguration?.description,\n\n /**\n * Tags to categorize the dictionaries.\n */\n tags: customConfiguration?.tags,\n\n /**\n * The priority of the dictionary.\n */\n priority: customConfiguration?.priority,\n\n /**\n * Indicates the mode of import to use for the dictionary.\n *\n * Available modes:\n * - \"static\": The dictionaries are imported statically.\n * - \"dynamic\": The dictionaries are imported dynamically in a synchronous component using the suspense API.\n * - \"live\": The dictionaries are imported dynamically using the live sync API.\n *\n * Default: 'static'\n */\n importMode: customConfiguration?.importMode ?? IMPORT_MODE,\n\n /**\n * The version of the dictionary.\n */\n version: customConfiguration?.version,\n };\n};\n\n/**\n * Build the configuration fields by merging the default values with the custom configuration\n */\nexport const buildConfigurationFields = (\n customConfiguration?: CustomIntlayerConfig,\n baseDir?: string,\n logFunctions?: LogFunctions\n): IntlayerConfig => {\n const internationalizationConfig = buildInternationalizationFields(\n customConfiguration?.internationalization\n );\n\n const routingConfig = buildRoutingFields(customConfiguration?.routing);\n\n const systemConfig = buildSystemFields(baseDir, customConfiguration?.system);\n\n const contentConfig = buildContentFields(\n systemConfig,\n customConfiguration?.content\n );\n\n const editorConfig = buildEditorFields(customConfiguration?.editor);\n\n const logConfig = buildLogFields(customConfiguration?.log, logFunctions);\n\n const aiConfig = buildAiFields(customConfiguration?.ai);\n\n const buildConfig = buildBuildFields(customConfiguration?.build);\n\n const compilerConfig = buildCompilerFields(customConfiguration?.compiler);\n\n const dictionaryConfig = buildDictionaryFields(\n customConfiguration?.dictionary\n );\n\n storedConfiguration = {\n internationalization: internationalizationConfig,\n routing: routingConfig,\n content: contentConfig,\n system: systemConfig,\n editor: editorConfig,\n log: logConfig,\n ai: aiConfig,\n build: buildConfig,\n compiler: compilerConfig,\n dictionary: dictionaryConfig,\n plugins: customConfiguration?.plugins,\n schemas: customConfiguration?.schemas,\n metadata: {\n name: 'Intlayer',\n version: packageJson.version,\n doc: `https://intlayer.org/docs`,\n },\n } as IntlayerConfig;\n\n return storedConfiguration;\n};\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{AiProviders as e}from"@intlayer/types/config";import{z as t}from"zod";const n=t.object({locales:t.array(t.string()).min(1),requiredLocales:t.array(t.string()).optional(),strictMode:t.enum([`strict`,`inclusive`,`loose`]).optional(),defaultLocale:t.string().optional()}),r=t.object({type:t.literal(`cookie`),name:t.string().optional(),domain:t.string().optional(),path:t.string().optional(),secure:t.boolean().optional(),httpOnly:t.boolean().optional(),sameSite:t.enum([`strict`,`lax`,`none`]).optional(),expires:t.union([t.date(),t.number()]).optional()}),i=t.object({type:t.enum([`localStorage`,`sessionStorage`,`header`]),name:t.string().optional()}),a=t.union([t.literal(!1),t.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i,t.array(t.union([t.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i]))]),o=t.object({canonical:t.string(),localized:t.record(t.string(),t.string())}),s=t.object({rules:t.array(o)}),c=t.object({url:s,nextjs:s.optional(),vite:s.optional()}),l=t.object({rewrite:t.union([t.record(t.string(),t.record(t.string(),t.string())),c]).optional(),mode:t.enum([`prefix-no-default`,`prefix-all`,`no-prefix`,`search-params`]).optional(),storage:a.optional(),basePath:t.string().optional()}),u=t.object({fileExtensions:t.array(t.string()).optional(),baseDir:t.string().optional(),contentDir:t.array(t.string()).optional(),codeDir:t.array(t.string()).optional(),excludedPath:t.array(t.string()).optional(),watch:t.boolean().optional(),formatCommand:t.string().optional(),watchedFilesPattern:t.array(t.string()).optional(),watchedFilesPatternWithPath:t.array(t.string()).optional()}),d=t.object({moduleAugmentationDir:t.string().optional(),unmergedDictionariesDir:t.string().optional(),remoteDictionariesDir:t.string().optional(),dictionariesDir:t.string().optional(),dynamicDictionariesDir:t.string().optional(),fetchDictionariesDir:t.string().optional(),typesDir:t.string().optional(),mainDir:t.string().optional(),configDir:t.string().optional(),cacheDir:t.string().optional(),tempDir:t.string().optional(),outputFilesPatternWithPath:t.string().optional()}),f=t.object({applicationURL:t.union([t.url(),t.literal(``)]).optional(),editorURL:t.union([t.url(),t.literal(``)]).optional(),cmsURL:t.union([t.url(),t.literal(``)]).optional(),backendURL:t.union([t.url(),t.literal(``)]).optional(),port:t.number().int().positive().max(65535).optional(),enabled:t.boolean().optional(),clientId:t.string().optional(),clientSecret:t.string().optional(),dictionaryPriorityStrategy:t.enum([`local_first`,`distant_first`]).optional(),liveSync:t.boolean().optional(),liveSyncPort:t.number().int().positive().max(65535).optional(),liveSyncURL:t.union([t.url(),t.literal(``)]).optional()}),p=t.object({mode:t.enum([`default`,`verbose`,`disabled`]).optional(),prefix:t.string().optional(),error:t.function().optional(),log:t.function().optional(),info:t.function().optional(),warn:t.function().optional()}),m=t.object({provider:t.enum(e).optional(),apiKey:t.string().optional(),model:t.string().optional(),temperature:t.number().min(0).max(2).optional(),applicationContext:t.string().optional(),baseURL:t.url().optional(),dataSerialization:t.enum([`json`,`toon`]).optional()}),h=t.object({mode:t.enum([`auto`,`manual`]).optional(),optimize:t.boolean().optional(),importMode:t.enum([`static`,`dynamic`,`fetch`]).optional(),traversePattern:t.array(t.string()).optional(),outputFormat:t.array(t.enum([`cjs`,`esm`])).optional(),cache:t.boolean().optional(),require:t.unknown().optional(),checkTypes:t.boolean().optional()}),g=t.object({enabled:t.union([t.boolean(),t.literal(`build-only`)]).optional(),dictionaryKeyPrefix:t.string().optional(),transformPattern:t.union([t.string(),t.array(t.string())]).optional(),excludePattern:t.union([t.string(),t.array(t.string())]).optional(),outputDir:t.string().optional(),output:t.unknown().optional(),noMetadata:t.boolean().optional(),saveComponents:t.boolean().optional()}),_=t.object({fill:t.unknown().optional(),contentAutoTransformation:t.union([t.boolean(),t.object({markdown:t.boolean().optional(),html:t.boolean().optional(),insertion:t.boolean().optional()})]).optional(),location:t.string().optional(),locale:t.string().optional(),title:t.string().optional()}),v=t.object({internationalization:n.optional(),routing:l.optional(),content:u.optional(),system:d.optional(),editor:f.optional(),log:p.optional(),ai:m.optional(),build:h.optional(),compiler:g.optional(),dictionary:_.optional(),plugins:t.array(t.unknown()).optional(),schemas:t.record(t.string(),t.unknown()).optional(),metadata:t.object({name:t.string().optional(),version:t.string().optional(),doc:t.string().optional()}).optional()});export{m as aiSchema,h as buildSchema,g as compilerSchema,u as contentSchema,r as cookiesAttributesSchema,_ as dictionarySchema,f as editorSchema,n as internationalizationSchema,v as intlayerConfigSchema,p as logSchema,c as rewriteObjectSchema,o as rewriteRuleSchema,s as rewriteRulesSchema,l as routingSchema,i as storageAttributesSchema,a as storageSchema,d as systemSchema};
1
+ import{AiProviders as e}from"@intlayer/types/config";import{z as t}from"zod";const n=t.object({locales:t.array(t.string()).min(1),requiredLocales:t.array(t.string()).optional(),strictMode:t.enum([`strict`,`inclusive`,`loose`]).optional(),defaultLocale:t.string().optional()}),r=t.object({type:t.literal(`cookie`),name:t.string().optional(),domain:t.string().optional(),path:t.string().optional(),secure:t.boolean().optional(),httpOnly:t.boolean().optional(),sameSite:t.enum([`strict`,`lax`,`none`]).optional(),expires:t.union([t.date(),t.number()]).optional()}),i=t.object({type:t.enum([`localStorage`,`sessionStorage`,`header`]),name:t.string().optional()}),a=t.union([t.literal(!1),t.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i,t.array(t.union([t.enum([`cookie`,`localStorage`,`sessionStorage`,`header`]),r,i]))]),o=t.object({canonical:t.string(),localized:t.record(t.string(),t.string())}),s=t.object({rules:t.array(o)}),c=t.object({url:s,nextjs:s.optional(),vite:s.optional()}),l=t.object({rewrite:t.union([t.record(t.string(),t.record(t.string(),t.string())),c]).optional(),mode:t.enum([`prefix-no-default`,`prefix-all`,`no-prefix`,`search-params`]).optional(),storage:a.optional(),basePath:t.string().optional()}),u=t.object({baseDir:t.string().optional(),moduleAugmentationDir:t.string().optional(),unmergedDictionariesDir:t.string().optional(),remoteDictionariesDir:t.string().optional(),dictionariesDir:t.string().optional(),dynamicDictionariesDir:t.string().optional(),fetchDictionariesDir:t.string().optional(),typesDir:t.string().optional(),mainDir:t.string().optional(),configDir:t.string().optional(),cacheDir:t.string().optional(),tempDir:t.string().optional(),outputFilesPatternWithPath:t.string().optional()}),d=t.object({fileExtensions:t.array(t.string()).optional(),contentDir:t.array(t.string()).optional(),codeDir:t.array(t.string()).optional(),excludedPath:t.array(t.string()).optional(),watch:t.boolean().optional(),formatCommand:t.string().optional(),watchedFilesPattern:t.array(t.string()).optional(),watchedFilesPatternWithPath:t.array(t.string()).optional()}),f=t.object({applicationURL:t.union([t.url(),t.literal(``)]).optional(),editorURL:t.union([t.url(),t.literal(``)]).optional(),cmsURL:t.union([t.url(),t.literal(``)]).optional(),backendURL:t.union([t.url(),t.literal(``)]).optional(),port:t.number().int().positive().max(65535).optional(),enabled:t.boolean().optional(),clientId:t.string().optional(),clientSecret:t.string().optional(),dictionaryPriorityStrategy:t.enum([`local_first`,`distant_first`]).optional(),liveSync:t.boolean().optional(),liveSyncPort:t.number().int().positive().max(65535).optional(),liveSyncURL:t.union([t.url(),t.literal(``)]).optional()}),p=t.object({mode:t.enum([`default`,`verbose`,`disabled`]).optional(),prefix:t.string().optional(),error:t.function().optional(),log:t.function().optional(),info:t.function().optional(),warn:t.function().optional()}),m=t.object({provider:t.enum(e).optional(),apiKey:t.string().optional(),model:t.string().optional(),temperature:t.number().min(0).max(2).optional(),applicationContext:t.string().optional(),baseURL:t.url().optional(),dataSerialization:t.enum([`json`,`toon`]).optional()}),h=t.object({mode:t.enum([`auto`,`manual`]).optional(),optimize:t.boolean().optional(),importMode:t.enum([`static`,`dynamic`,`fetch`]).optional(),traversePattern:t.array(t.string()).optional(),outputFormat:t.array(t.enum([`cjs`,`esm`])).optional(),cache:t.boolean().optional(),require:t.unknown().optional(),checkTypes:t.boolean().optional()}),g=t.object({enabled:t.union([t.boolean(),t.literal(`build-only`)]).optional(),dictionaryKeyPrefix:t.string().optional(),transformPattern:t.union([t.string(),t.array(t.string())]).optional(),excludePattern:t.union([t.string(),t.array(t.string())]).optional(),outputDir:t.string().optional(),output:t.unknown().optional(),noMetadata:t.boolean().optional(),saveComponents:t.boolean().optional()}),_=t.object({fill:t.unknown().optional(),contentAutoTransformation:t.union([t.boolean(),t.object({markdown:t.boolean().optional(),html:t.boolean().optional(),insertion:t.boolean().optional()})]).optional(),location:t.string().optional(),locale:t.string().optional(),title:t.string().optional()}),v=t.object({internationalization:n.optional(),routing:l.optional(),content:d.optional(),system:u.optional(),editor:f.optional(),log:p.optional(),ai:m.optional(),build:h.optional(),compiler:g.optional(),dictionary:_.optional(),plugins:t.array(t.unknown()).optional(),schemas:t.record(t.string(),t.unknown()).optional(),metadata:t.object({name:t.string().optional(),version:t.string().optional(),doc:t.string().optional()}).optional()});export{m as aiSchema,h as buildSchema,g as compilerSchema,d as contentSchema,r as cookiesAttributesSchema,_ as dictionarySchema,f as editorSchema,n as internationalizationSchema,v as intlayerConfigSchema,p as logSchema,c as rewriteObjectSchema,o as rewriteRuleSchema,s as rewriteRulesSchema,l as routingSchema,i as storageAttributesSchema,a as storageSchema,u as systemSchema};
2
2
  //# sourceMappingURL=configurationSchema.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"configurationSchema.mjs","names":[],"sources":["../../../src/configFile/configurationSchema.ts"],"sourcesContent":["import { AiProviders } from '@intlayer/types/config';\nimport { z } from 'zod';\n\nexport const internationalizationSchema = z.object({\n locales: z.array(z.string()).min(1),\n requiredLocales: z.array(z.string()).optional(),\n strictMode: z.enum(['strict', 'inclusive', 'loose']).optional(),\n defaultLocale: z.string().optional(),\n});\n\nexport const cookiesAttributesSchema = z.object({\n type: z.literal('cookie'),\n name: z.string().optional(),\n domain: z.string().optional(),\n path: z.string().optional(),\n secure: z.boolean().optional(),\n httpOnly: z.boolean().optional(),\n sameSite: z.enum(['strict', 'lax', 'none']).optional(),\n expires: z.union([z.date(), z.number()]).optional(),\n});\n\nexport const storageAttributesSchema = z.object({\n type: z.enum(['localStorage', 'sessionStorage', 'header']),\n name: z.string().optional(),\n});\n\nexport const storageSchema = z.union([\n z.literal(false),\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n z.array(\n z.union([\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n ])\n ),\n]);\n\nexport const rewriteRuleSchema = z.object({\n canonical: z.string(),\n localized: z.record(z.string(), z.string()),\n});\n\nexport const rewriteRulesSchema = z.object({\n rules: z.array(rewriteRuleSchema),\n});\n\nexport const rewriteObjectSchema = z.object({\n url: rewriteRulesSchema,\n nextjs: rewriteRulesSchema.optional(),\n vite: rewriteRulesSchema.optional(),\n});\n\nexport const routingSchema = z.object({\n rewrite: z\n .union([\n z.record(z.string(), z.record(z.string(), z.string())),\n rewriteObjectSchema,\n ])\n .optional(),\n mode: z\n .enum(['prefix-no-default', 'prefix-all', 'no-prefix', 'search-params'])\n .optional(),\n storage: storageSchema.optional(),\n basePath: z.string().optional(),\n});\n\nexport const contentSchema = z.object({\n fileExtensions: z.array(z.string()).optional(),\n baseDir: z.string().optional(),\n contentDir: z.array(z.string()).optional(),\n codeDir: z.array(z.string()).optional(),\n excludedPath: z.array(z.string()).optional(),\n watch: z.boolean().optional(),\n formatCommand: z.string().optional(),\n watchedFilesPattern: z.array(z.string()).optional(),\n watchedFilesPatternWithPath: z.array(z.string()).optional(),\n});\n\nexport const systemSchema = z.object({\n moduleAugmentationDir: z.string().optional(),\n unmergedDictionariesDir: z.string().optional(),\n remoteDictionariesDir: z.string().optional(),\n dictionariesDir: z.string().optional(),\n dynamicDictionariesDir: z.string().optional(),\n fetchDictionariesDir: z.string().optional(),\n typesDir: z.string().optional(),\n mainDir: z.string().optional(),\n configDir: z.string().optional(),\n cacheDir: z.string().optional(),\n tempDir: z.string().optional(),\n outputFilesPatternWithPath: z.string().optional(),\n});\n\nexport const editorSchema = z.object({\n applicationURL: z.union([z.url(), z.literal('')]).optional(),\n editorURL: z.union([z.url(), z.literal('')]).optional(),\n cmsURL: z.union([z.url(), z.literal('')]).optional(),\n backendURL: z.union([z.url(), z.literal('')]).optional(),\n port: z.number().int().positive().max(65535).optional(),\n enabled: z.boolean().optional(),\n clientId: z.string().optional(),\n clientSecret: z.string().optional(),\n dictionaryPriorityStrategy: z\n .enum(['local_first', 'distant_first'])\n .optional(),\n liveSync: z.boolean().optional(),\n liveSyncPort: z.number().int().positive().max(65535).optional(),\n liveSyncURL: z.union([z.url(), z.literal('')]).optional(),\n});\n\nexport const logSchema = z.object({\n mode: z.enum(['default', 'verbose', 'disabled']).optional(),\n prefix: z.string().optional(),\n error: z.function().optional(),\n log: z.function().optional(),\n info: z.function().optional(),\n warn: z.function().optional(),\n});\n\nexport const aiSchema = z.object({\n provider: z.enum(AiProviders).optional(),\n apiKey: z.string().optional(),\n model: z.string().optional(),\n temperature: z.number().min(0).max(2).optional(),\n applicationContext: z.string().optional(),\n baseURL: z.url().optional(),\n dataSerialization: z.enum(['json', 'toon']).optional(),\n});\n\nexport const buildSchema = z.object({\n mode: z.enum(['auto', 'manual']).optional(),\n optimize: z.boolean().optional(),\n importMode: z.enum(['static', 'dynamic', 'fetch']).optional(),\n traversePattern: z.array(z.string()).optional(),\n outputFormat: z.array(z.enum(['cjs', 'esm'])).optional(),\n cache: z.boolean().optional(),\n require: z.unknown().optional(),\n checkTypes: z.boolean().optional(),\n});\n\nexport const compilerSchema = z.object({\n enabled: z.union([z.boolean(), z.literal('build-only')]).optional(),\n dictionaryKeyPrefix: z.string().optional(),\n transformPattern: z.union([z.string(), z.array(z.string())]).optional(),\n excludePattern: z.union([z.string(), z.array(z.string())]).optional(),\n outputDir: z.string().optional(),\n output: z.unknown().optional(),\n noMetadata: z.boolean().optional(),\n saveComponents: z.boolean().optional(),\n});\n\nexport const dictionarySchema = z.object({\n fill: z.unknown().optional(),\n contentAutoTransformation: z\n .union([\n z.boolean(),\n z.object({\n markdown: z.boolean().optional(),\n html: z.boolean().optional(),\n insertion: z.boolean().optional(),\n }),\n ])\n .optional(),\n location: z.string().optional(),\n locale: z.string().optional(),\n title: z.string().optional(),\n});\n\nexport const intlayerConfigSchema = z.object({\n internationalization: internationalizationSchema.optional(),\n routing: routingSchema.optional(),\n content: contentSchema.optional(),\n system: systemSchema.optional(),\n editor: editorSchema.optional(),\n log: logSchema.optional(),\n ai: aiSchema.optional(),\n build: buildSchema.optional(),\n compiler: compilerSchema.optional(),\n dictionary: dictionarySchema.optional(),\n plugins: z.array(z.unknown()).optional(),\n schemas: z.record(z.string(), z.unknown()).optional(),\n metadata: z\n .object({\n name: z.string().optional(),\n version: z.string().optional(),\n doc: z.string().optional(),\n })\n .optional(),\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"configurationSchema.mjs","names":[],"sources":["../../../src/configFile/configurationSchema.ts"],"sourcesContent":["import { AiProviders } from '@intlayer/types/config';\nimport { z } from 'zod';\n\nexport const internationalizationSchema = z.object({\n locales: z.array(z.string()).min(1),\n requiredLocales: z.array(z.string()).optional(),\n strictMode: z.enum(['strict', 'inclusive', 'loose']).optional(),\n defaultLocale: z.string().optional(),\n});\n\nexport const cookiesAttributesSchema = z.object({\n type: z.literal('cookie'),\n name: z.string().optional(),\n domain: z.string().optional(),\n path: z.string().optional(),\n secure: z.boolean().optional(),\n httpOnly: z.boolean().optional(),\n sameSite: z.enum(['strict', 'lax', 'none']).optional(),\n expires: z.union([z.date(), z.number()]).optional(),\n});\n\nexport const storageAttributesSchema = z.object({\n type: z.enum(['localStorage', 'sessionStorage', 'header']),\n name: z.string().optional(),\n});\n\nexport const storageSchema = z.union([\n z.literal(false),\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n z.array(\n z.union([\n z.enum(['cookie', 'localStorage', 'sessionStorage', 'header']),\n cookiesAttributesSchema,\n storageAttributesSchema,\n ])\n ),\n]);\n\nexport const rewriteRuleSchema = z.object({\n canonical: z.string(),\n localized: z.record(z.string(), z.string()),\n});\n\nexport const rewriteRulesSchema = z.object({\n rules: z.array(rewriteRuleSchema),\n});\n\nexport const rewriteObjectSchema = z.object({\n url: rewriteRulesSchema,\n nextjs: rewriteRulesSchema.optional(),\n vite: rewriteRulesSchema.optional(),\n});\n\nexport const routingSchema = z.object({\n rewrite: z\n .union([\n z.record(z.string(), z.record(z.string(), z.string())),\n rewriteObjectSchema,\n ])\n .optional(),\n mode: z\n .enum(['prefix-no-default', 'prefix-all', 'no-prefix', 'search-params'])\n .optional(),\n storage: storageSchema.optional(),\n basePath: z.string().optional(),\n});\n\nexport const systemSchema = z.object({\n baseDir: z.string().optional(),\n moduleAugmentationDir: z.string().optional(),\n unmergedDictionariesDir: z.string().optional(),\n remoteDictionariesDir: z.string().optional(),\n dictionariesDir: z.string().optional(),\n dynamicDictionariesDir: z.string().optional(),\n fetchDictionariesDir: z.string().optional(),\n typesDir: z.string().optional(),\n mainDir: z.string().optional(),\n configDir: z.string().optional(),\n cacheDir: z.string().optional(),\n tempDir: z.string().optional(),\n outputFilesPatternWithPath: z.string().optional(),\n});\n\nexport const contentSchema = z.object({\n fileExtensions: z.array(z.string()).optional(),\n contentDir: z.array(z.string()).optional(),\n codeDir: z.array(z.string()).optional(),\n excludedPath: z.array(z.string()).optional(),\n watch: z.boolean().optional(),\n formatCommand: z.string().optional(),\n watchedFilesPattern: z.array(z.string()).optional(),\n watchedFilesPatternWithPath: z.array(z.string()).optional(),\n});\n\nexport const editorSchema = z.object({\n applicationURL: z.union([z.url(), z.literal('')]).optional(),\n editorURL: z.union([z.url(), z.literal('')]).optional(),\n cmsURL: z.union([z.url(), z.literal('')]).optional(),\n backendURL: z.union([z.url(), z.literal('')]).optional(),\n port: z.number().int().positive().max(65535).optional(),\n enabled: z.boolean().optional(),\n clientId: z.string().optional(),\n clientSecret: z.string().optional(),\n dictionaryPriorityStrategy: z\n .enum(['local_first', 'distant_first'])\n .optional(),\n liveSync: z.boolean().optional(),\n liveSyncPort: z.number().int().positive().max(65535).optional(),\n liveSyncURL: z.union([z.url(), z.literal('')]).optional(),\n});\n\nexport const logSchema = z.object({\n mode: z.enum(['default', 'verbose', 'disabled']).optional(),\n prefix: z.string().optional(),\n error: z.function().optional(),\n log: z.function().optional(),\n info: z.function().optional(),\n warn: z.function().optional(),\n});\n\nexport const aiSchema = z.object({\n provider: z.enum(AiProviders).optional(),\n apiKey: z.string().optional(),\n model: z.string().optional(),\n temperature: z.number().min(0).max(2).optional(),\n applicationContext: z.string().optional(),\n baseURL: z.url().optional(),\n dataSerialization: z.enum(['json', 'toon']).optional(),\n});\n\nexport const buildSchema = z.object({\n mode: z.enum(['auto', 'manual']).optional(),\n optimize: z.boolean().optional(),\n importMode: z.enum(['static', 'dynamic', 'fetch']).optional(),\n traversePattern: z.array(z.string()).optional(),\n outputFormat: z.array(z.enum(['cjs', 'esm'])).optional(),\n cache: z.boolean().optional(),\n require: z.unknown().optional(),\n checkTypes: z.boolean().optional(),\n});\n\nexport const compilerSchema = z.object({\n enabled: z.union([z.boolean(), z.literal('build-only')]).optional(),\n dictionaryKeyPrefix: z.string().optional(),\n transformPattern: z.union([z.string(), z.array(z.string())]).optional(),\n excludePattern: z.union([z.string(), z.array(z.string())]).optional(),\n outputDir: z.string().optional(),\n output: z.unknown().optional(),\n noMetadata: z.boolean().optional(),\n saveComponents: z.boolean().optional(),\n});\n\nexport const dictionarySchema = z.object({\n fill: z.unknown().optional(),\n contentAutoTransformation: z\n .union([\n z.boolean(),\n z.object({\n markdown: z.boolean().optional(),\n html: z.boolean().optional(),\n insertion: z.boolean().optional(),\n }),\n ])\n .optional(),\n location: z.string().optional(),\n locale: z.string().optional(),\n title: z.string().optional(),\n});\n\nexport const intlayerConfigSchema = z.object({\n internationalization: internationalizationSchema.optional(),\n routing: routingSchema.optional(),\n content: contentSchema.optional(),\n system: systemSchema.optional(),\n editor: editorSchema.optional(),\n log: logSchema.optional(),\n ai: aiSchema.optional(),\n build: buildSchema.optional(),\n compiler: compilerSchema.optional(),\n dictionary: dictionarySchema.optional(),\n plugins: z.array(z.unknown()).optional(),\n schemas: z.record(z.string(), z.unknown()).optional(),\n metadata: z\n .object({\n name: z.string().optional(),\n version: z.string().optional(),\n doc: z.string().optional(),\n })\n .optional(),\n});\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{__exportAll as e}from"../_virtual/_rolldown/runtime.mjs";var t=e({BUILD_MODE:()=>n,CACHE:()=>!0,OPTIMIZE:()=>void 0,OUTPUT_FORMAT:()=>a,TRAVERSE_PATTERN:()=>i,TYPE_CHECKING:()=>!1});const n=`auto`,r=void 0,i=[`**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}`,`!**/node_modules/**`],a=[`esm`,`cjs`],o=!0,s=!1;export{n as BUILD_MODE,o as CACHE,r as OPTIMIZE,a as OUTPUT_FORMAT,i as TRAVERSE_PATTERN,s as TYPE_CHECKING,t as build_exports};
1
+ import{__exportAll as e}from"../_virtual/_rolldown/runtime.mjs";var t=e({BUILD_MODE:()=>n,CACHE:()=>!0,OPTIMIZE:()=>void 0,OUTPUT_FORMAT:()=>a,TRAVERSE_PATTERN:()=>i,TYPE_CHECKING:()=>!1});const n=`auto`,r=void 0,i=[`**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}`,`!**/node_modules/**`,`!**/*.config.*`],a=[`esm`,`cjs`],o=!0,s=!1;export{n as BUILD_MODE,o as CACHE,r as OPTIMIZE,a as OUTPUT_FORMAT,i as TRAVERSE_PATTERN,s as TYPE_CHECKING,t as build_exports};
2
2
  //# sourceMappingURL=build.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"build.mjs","names":[],"sources":["../../../src/defaultValues/build.ts"],"sourcesContent":["export const BUILD_MODE = 'auto';\n\nexport const OPTIMIZE = undefined;\n\nexport const TRAVERSE_PATTERN = [\n '**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}',\n '!**/node_modules/**',\n];\n\nexport const OUTPUT_FORMAT: ('cjs' | 'esm')[] = ['esm', 'cjs'];\n\nexport const CACHE = true;\n\nexport const TYPE_CHECKING = false;\n"],"mappings":"6LAAA,MAAa,EAAa,OAEb,EAAW,IAAA,GAEX,EAAmB,CAC9B,+CACA,sBACD,CAEY,EAAmC,CAAC,MAAO,MAAM,CAEjD,EAAQ,GAER,EAAgB"}
1
+ {"version":3,"file":"build.mjs","names":[],"sources":["../../../src/defaultValues/build.ts"],"sourcesContent":["export const BUILD_MODE = 'auto';\n\nexport const OPTIMIZE = undefined;\n\nexport const TRAVERSE_PATTERN = [\n '**/*.{tsx,ts,js,mjs,cjs,jsx,vue,svelte,svte}',\n '!**/node_modules/**',\n '!**/*.config.*',\n];\n\nexport const OUTPUT_FORMAT: ('cjs' | 'esm')[] = ['esm', 'cjs'];\n\nexport const CACHE = true;\n\nexport const TYPE_CHECKING = false;\n"],"mappings":"6LAAA,MAAa,EAAa,OAEb,EAAW,IAAA,GAEX,EAAmB,CAC9B,+CACA,sBACA,iBACD,CAEY,EAAmC,CAAC,MAAO,MAAM,CAEjD,EAAQ,GAER,EAAgB"}
@@ -1,2 +1,2 @@
1
- import{__exportAll as e}from"../_virtual/_rolldown/runtime.mjs";var t=e({APPLICATION_URL:()=>void 0,BACKEND_URL:()=>a,CMS_URL:()=>i,DICTIONARY_PRIORITY_STRATEGY:()=>l,EDITOR_URL:()=>r,IS_ENABLED:()=>!0,LIVE_SYNC:()=>!0,LIVE_SYNC_PORT:()=>u,PORT:()=>o});const n=void 0,r=`http://localhost:8000`,i=`https://app.intlayer.org`,a=`https://back.intlayer.org`,o=8e3,s=!0,c=!0,l=`local_first`,u=4e3;export{n as APPLICATION_URL,a as BACKEND_URL,i as CMS_URL,l as DICTIONARY_PRIORITY_STRATEGY,r as EDITOR_URL,s as IS_ENABLED,c as LIVE_SYNC,u as LIVE_SYNC_PORT,o as PORT,t as editor_exports};
1
+ import{__exportAll as e}from"../_virtual/_rolldown/runtime.mjs";var t=e({APPLICATION_URL:()=>void 0,BACKEND_URL:()=>a,CMS_URL:()=>i,DICTIONARY_PRIORITY_STRATEGY:()=>l,EDITOR_URL:()=>r,IS_ENABLED:()=>!1,LIVE_SYNC:()=>!0,LIVE_SYNC_PORT:()=>u,PORT:()=>o});const n=void 0,r=`http://localhost:8000`,i=`https://app.intlayer.org`,a=`https://back.intlayer.org`,o=8e3,s=!1,c=!0,l=`local_first`,u=4e3;export{n as APPLICATION_URL,a as BACKEND_URL,i as CMS_URL,l as DICTIONARY_PRIORITY_STRATEGY,r as EDITOR_URL,s as IS_ENABLED,c as LIVE_SYNC,u as LIVE_SYNC_PORT,o as PORT,t as editor_exports};
2
2
  //# sourceMappingURL=editor.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"editor.mjs","names":[],"sources":["../../../src/defaultValues/editor.ts"],"sourcesContent":["export const APPLICATION_URL = undefined;\nexport const EDITOR_URL = 'http://localhost:8000';\nexport const CMS_URL = 'https://app.intlayer.org';\nexport const BACKEND_URL = 'https://back.intlayer.org';\nexport const PORT = 8000;\nexport const IS_ENABLED = true;\nexport const LIVE_SYNC = true;\nexport const DICTIONARY_PRIORITY_STRATEGY = 'local_first';\nexport const LIVE_SYNC_PORT = 4000;\n"],"mappings":"6PAAA,MAAa,EAAkB,IAAA,GAClB,EAAa,wBACb,EAAU,2BACV,EAAc,4BACd,EAAO,IACP,EAAa,GACb,EAAY,GACZ,EAA+B,cAC/B,EAAiB"}
1
+ {"version":3,"file":"editor.mjs","names":[],"sources":["../../../src/defaultValues/editor.ts"],"sourcesContent":["export const APPLICATION_URL = undefined;\nexport const EDITOR_URL = 'http://localhost:8000';\nexport const CMS_URL = 'https://app.intlayer.org';\nexport const BACKEND_URL = 'https://back.intlayer.org';\nexport const PORT = 8000;\nexport const IS_ENABLED = false;\nexport const LIVE_SYNC = true;\nexport const DICTIONARY_PRIORITY_STRATEGY = 'local_first';\nexport const LIVE_SYNC_PORT = 4000;\n"],"mappings":"6PAAA,MAAa,EAAkB,IAAA,GAClB,EAAa,wBACb,EAAU,2BACV,EAAc,4BACd,EAAO,IACP,EAAa,GACb,EAAY,GACZ,EAA+B,cAC/B,EAAiB"}
@@ -1,2 +1,2 @@
1
- import{colorizePath as e,logger as t}from"../logger.mjs";import{parseFileContent as n}from"./parseFileContent.mjs";import{transpileTSToCJS as r,transpileTSToCJSSync as i}from"./transpileTSToCJS.mjs";import{readFileSync as a}from"node:fs";import{extname as o}from"node:path";import{readFile as s}from"node:fs/promises";import c from"json5";const l=(e,r)=>{let s=o(e)||`.json`;try{if(s===`.json`||s===`.json5`||s===`.jsonc`)return c.parse(a(e,`utf-8`));let o=i(a(e,`utf-8`),e);if(!o){t(`File could not be loaded.`,{level:`error`});return}let l=n(o,{projectRequire:r?.projectRequire,envVarOptions:r?.envVarOptions,additionalEnvVars:r?.additionalEnvVars,mocks:r?.mocks,aliases:r?.aliases});if(l===void 0){t(`File could not be loaded. Path : ${e}`);return}return l}catch(e){t([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}},u=async(i,a)=>{let l=o(i);try{if(l===`.json`||l===`.json5`||l===`.jsonc`){let e=await s(i,`utf-8`);return c.parse(e)}let o=await r(await s(i,`utf-8`),i,a?.buildOptions);if(!o){t(`File could not be loaded.`,{level:`error`});return}let u=n(o,{projectRequire:a?.projectRequire,envVarOptions:a?.envVarOptions,additionalEnvVars:a?.additionalEnvVars,mocks:a?.mocks,aliases:a?.aliases});if(u===void 0){t(`File could not be loaded. Path : ${e(i)}`);return}return u}catch(e){t([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}};export{u as loadExternalFile,l as loadExternalFileSync};
1
+ import{colorizePath as e,logger as t}from"../logger.mjs";import{parseFileContent as n}from"./parseFileContent.mjs";import{transpileTSToCJS as r,transpileTSToCJSSync as i}from"./transpileTSToCJS.mjs";import{readFileSync as a}from"node:fs";import{extname as o}from"node:path";import{readFile as s}from"node:fs/promises";import c from"json5";const l=(e,r)=>{let s=o(e)||`.json`;try{if(s===`.json`||s===`.json5`||s===`.jsonc`)return c.parse(a(e,`utf-8`));let o=i(a(e,`utf-8`),e);if(!o){t(`File could not be loaded.`,{level:`error`});return}let l=n(o,{projectRequire:r?.projectRequire,envVarOptions:r?.envVarOptions,additionalEnvVars:r?.additionalEnvVars,mocks:r?.mocks,aliases:r?.aliases});if(l===void 0){t(`File could not be loaded. Path : ${e}`);return}return l}catch(e){t([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}},u=async(i,a)=>{let l=o(i);try{if(l===`.json`||l===`.json5`||l===`.jsonc`){let e=await s(i,`utf-8`);return c.parse(e)}let o=await r(await s(i,`utf-8`),i,a?.buildOptions);if(!o){t(`File could not be loaded.`,{level:`error`});return}let u=n(o,{projectRequire:a?.projectRequire,envVarOptions:a?.envVarOptions,additionalEnvVars:a?.additionalEnvVars,mocks:a?.mocks,aliases:a?.aliases});if(u===void 0){t(`File could not be loaded. Path : ${e(i)}`);return}return u}catch(e){(a?.logError??!0)&&t([`Error: ${e.message} - `,JSON.stringify(e.stack,null,2)],{level:`error`})}};export{u as loadExternalFile,l as loadExternalFileSync};
2
2
  //# sourceMappingURL=loadExternalFile.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"loadExternalFile.mjs","names":[],"sources":["../../../src/loadExternalFile/loadExternalFile.ts"],"sourcesContent":["import { readFileSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport { extname } from 'node:path';\nimport type { IntlayerConfig } from '@intlayer/types/config';\nimport type { BuildOptions } from 'esbuild';\nimport JSON5 from 'json5';\nimport { colorizePath, logger } from '../logger';\nimport {\n parseFileContent,\n type SandBoxContextOptions,\n} from './parseFileContent';\nimport { transpileTSToCJS, transpileTSToCJSSync } from './transpileTSToCJS';\n\nexport type LoadExternalFileOptions = {\n configuration?: IntlayerConfig;\n buildOptions?: BuildOptions;\n} & SandBoxContextOptions;\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFileSync = (\n filePath: string,\n options?: LoadExternalFileOptions\n): any | undefined => {\n const fileExtension = extname(filePath) || '.json';\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Assume JSON\n return JSON5.parse(readFileSync(filePath, 'utf-8'));\n }\n\n // Rest is JS, MJS or TS\n const code = readFileSync(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = transpileTSToCJSSync(\n code,\n filePath\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${filePath}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n};\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFile = async (\n filePath: string,\n options?: LoadExternalFileOptions\n): Promise<any | undefined> => {\n const fileExtension = extname(filePath);\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Remove cache to force getting fresh content\n const fileContent = await readFile(filePath, 'utf-8');\n return JSON5.parse(fileContent);\n }\n\n // Rest is JS, MJS or TS\n const code = await readFile(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = await transpileTSToCJS(\n code,\n filePath,\n options?.buildOptions\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${colorizePath(filePath)}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n};\n"],"mappings":"mVAuBA,MAAa,GACX,EACA,IACoB,CACpB,IAAM,EAAgB,EAAQ,EAAS,EAAI,QAE3C,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAGlB,OAAO,EAAM,MAAM,EAAa,EAAU,QAAQ,CAAC,CAMrD,IAAM,EAAyC,EAFlC,EAAa,EAAU,QAAQ,CAI1C,EACD,CAED,GAAI,CAAC,EAAoB,CACvB,EAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAc,EAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAO,oCAAoC,IAAW,CACtD,OAGF,OAAO,QACA,EAAO,CACd,EACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF,GASQ,EAAmB,MAC9B,EACA,IAC6B,CAC7B,IAAM,EAAgB,EAAQ,EAAS,CAEvC,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAClB,CAEA,IAAM,EAAc,MAAM,EAAS,EAAU,QAAQ,CACrD,OAAO,EAAM,MAAM,EAAY,CAMjC,IAAM,EAAyC,MAAM,EAFxC,MAAM,EAAS,EAAU,QAAQ,CAI5C,EACA,GAAS,aACV,CAED,GAAI,CAAC,EAAoB,CACvB,EAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAc,EAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAO,oCAAoC,EAAa,EAAS,GAAG,CACpE,OAGF,OAAO,QACA,EAAO,CACd,EACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF"}
1
+ {"version":3,"file":"loadExternalFile.mjs","names":[],"sources":["../../../src/loadExternalFile/loadExternalFile.ts"],"sourcesContent":["import { readFileSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport { extname } from 'node:path';\nimport type { IntlayerConfig } from '@intlayer/types/config';\nimport type { BuildOptions } from 'esbuild';\nimport JSON5 from 'json5';\nimport { colorizePath, logger } from '../logger';\nimport {\n parseFileContent,\n type SandBoxContextOptions,\n} from './parseFileContent';\nimport { transpileTSToCJS, transpileTSToCJSSync } from './transpileTSToCJS';\n\nexport type LoadExternalFileOptions = {\n configuration?: IntlayerConfig;\n buildOptions?: BuildOptions;\n logError?: boolean;\n} & SandBoxContextOptions;\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFileSync = (\n filePath: string,\n options?: LoadExternalFileOptions\n): any | undefined => {\n const fileExtension = extname(filePath) || '.json';\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Assume JSON\n return JSON5.parse(readFileSync(filePath, 'utf-8'));\n }\n\n // Rest is JS, MJS or TS\n const code = readFileSync(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = transpileTSToCJSSync(\n code,\n filePath\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${filePath}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n};\n\n/**\n * Load the content declaration from the given path\n *\n * Accepts JSON, JS, MJS and TS files as configuration\n */\nexport const loadExternalFile = async (\n filePath: string,\n options?: LoadExternalFileOptions\n): Promise<any | undefined> => {\n const fileExtension = extname(filePath);\n\n try {\n if (\n fileExtension === '.json' ||\n fileExtension === '.json5' ||\n fileExtension === '.jsonc'\n ) {\n // Remove cache to force getting fresh content\n const fileContent = await readFile(filePath, 'utf-8');\n return JSON5.parse(fileContent);\n }\n\n // Rest is JS, MJS or TS\n const code = await readFile(filePath, 'utf-8');\n\n const moduleResultString: string | undefined = await transpileTSToCJS(\n code,\n filePath,\n options?.buildOptions\n );\n\n if (!moduleResultString) {\n logger('File could not be loaded.', { level: 'error' });\n return undefined;\n }\n\n const fileContent = parseFileContent(moduleResultString, {\n projectRequire: options?.projectRequire,\n envVarOptions: options?.envVarOptions,\n additionalEnvVars: options?.additionalEnvVars,\n mocks: options?.mocks,\n aliases: options?.aliases,\n });\n\n if (typeof fileContent === 'undefined') {\n logger(`File could not be loaded. Path : ${colorizePath(filePath)}`);\n return undefined;\n }\n\n return fileContent;\n } catch (error) {\n if (options?.logError ?? true) {\n logger(\n [\n `Error: ${(error as Error).message} - `,\n JSON.stringify((error as Error).stack, null, 2),\n ],\n {\n level: 'error',\n }\n );\n }\n }\n};\n"],"mappings":"mVAwBA,MAAa,GACX,EACA,IACoB,CACpB,IAAM,EAAgB,EAAQ,EAAS,EAAI,QAE3C,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAGlB,OAAO,EAAM,MAAM,EAAa,EAAU,QAAQ,CAAC,CAMrD,IAAM,EAAyC,EAFlC,EAAa,EAAU,QAAQ,CAI1C,EACD,CAED,GAAI,CAAC,EAAoB,CACvB,EAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAc,EAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAO,oCAAoC,IAAW,CACtD,OAGF,OAAO,QACA,EAAO,CACd,EACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF,GASQ,EAAmB,MAC9B,EACA,IAC6B,CAC7B,IAAM,EAAgB,EAAQ,EAAS,CAEvC,GAAI,CACF,GACE,IAAkB,SAClB,IAAkB,UAClB,IAAkB,SAClB,CAEA,IAAM,EAAc,MAAM,EAAS,EAAU,QAAQ,CACrD,OAAO,EAAM,MAAM,EAAY,CAMjC,IAAM,EAAyC,MAAM,EAFxC,MAAM,EAAS,EAAU,QAAQ,CAI5C,EACA,GAAS,aACV,CAED,GAAI,CAAC,EAAoB,CACvB,EAAO,4BAA6B,CAAE,MAAO,QAAS,CAAC,CACvD,OAGF,IAAM,EAAc,EAAiB,EAAoB,CACvD,eAAgB,GAAS,eACzB,cAAe,GAAS,cACxB,kBAAmB,GAAS,kBAC5B,MAAO,GAAS,MAChB,QAAS,GAAS,QACnB,CAAC,CAEF,GAAW,IAAgB,OAAa,CACtC,EAAO,oCAAoC,EAAa,EAAS,GAAG,CACpE,OAGF,OAAO,QACA,EAAO,EACV,GAAS,UAAY,KACvB,EACE,CACE,UAAW,EAAgB,QAAQ,KACnC,KAAK,UAAW,EAAgB,MAAO,KAAM,EAAE,CAChD,CACD,CACE,MAAO,QACR,CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"cacheDisk.mjs","names":["configPackageJson"],"sources":["../../../src/utils/cacheDisk.ts"],"sourcesContent":["import {\n mkdir,\n readFile,\n rename,\n rm,\n stat,\n unlink,\n writeFile,\n} from 'node:fs/promises';\nimport { basename, dirname, join } from 'node:path';\nimport { deserialize, serialize } from 'node:v8';\nimport { gunzipSync, gzipSync } from 'node:zlib';\nimport type { IntlayerConfig } from '@intlayer/types/config';\nimport configPackageJson from '@intlayer/types/package.json' with {\n type: 'json',\n};\nimport { type CacheKey, clearAllCache, computeKeyId } from './cacheMemory';\n\n/** ------------------------- Persistence layer ------------------------- **/\n\n/** Cache envelope structure stored on disk */\ntype CacheEnvelope = {\n /** Version of the config package (for cache invalidation) */\n version: string;\n /** Timestamp when the cache entry was created (in milliseconds) */\n timestamp: number;\n /** Data payload (the actual cached value) */\n data: unknown;\n};\n\ntype LocalCacheOptions = {\n /** Preferred new option name */\n persistent?: boolean;\n /** Time-to-live in ms; if expired, disk entry is ignored. */\n ttlMs?: number;\n /** Max age in ms based on stored creation timestamp; invalidates on exceed. */\n maxTimeMs?: number;\n /** Optional namespace to separate different logical caches. */\n namespace?: string;\n /** Gzip values on disk (on by default for blobs > 1KB). */\n compress?: boolean;\n};\n\nconst DEFAULTS: Required<Pick<LocalCacheOptions, 'compress'>> = {\n compress: true,\n};\n\nconst ensureDir = async (dir: string) => {\n await mkdir(dir, { recursive: true });\n};\n\nconst atomicWriteFile = async (\n file: string,\n data: Buffer,\n tempDir?: string\n) => {\n if (tempDir) {\n try {\n await ensureDir(tempDir);\n } catch {}\n }\n\n const tempFileName = `${basename(file)}.tmp-${process.pid}-${Math.random().toString(36).slice(2)}`;\n const tmp = tempDir\n ? join(tempDir, tempFileName)\n : `${file}.tmp-${process.pid}-${Math.random().toString(36).slice(2)}`;\n try {\n await writeFile(tmp, data);\n await rename(tmp, file);\n } catch (error) {\n try {\n await rm(tmp, { force: true });\n } catch {\n // Ignore\n }\n throw error;\n }\n};\n\nconst shouldUseCompression = (buf: Buffer, force?: boolean) =>\n force === true || (force !== false && buf.byteLength > 1024);\n\n/** Derive on-disk path from config dir + namespace + key id. */\nconst cachePath = (cacheDir: string, id: string, ns?: string) =>\n join(cacheDir, ns ? join(ns, id) : id);\n\n/** ------------------------- Local cache facade ------------------------- **/\n\nconst cacheMap = new Map<string, any>();\n\nexport const cacheDisk = (\n intlayerConfig: IntlayerConfig,\n keys: CacheKey[],\n options?: LocalCacheOptions\n) => {\n const { cacheDir, tempDir } = intlayerConfig.system;\n const buildCacheEnabled = intlayerConfig.build.cache ?? true;\n const persistent =\n options?.persistent === true ||\n (typeof options?.persistent === 'undefined' && buildCacheEnabled);\n\n const { compress, ttlMs, maxTimeMs, namespace } = {\n ...DEFAULTS,\n ...options,\n };\n\n // single stable id for this key tuple (works for both memory & disk)\n const id = computeKeyId(keys);\n const filePath = cachePath(cacheDir, id, namespace);\n\n const readFromDisk = async (): Promise<unknown | undefined> => {\n try {\n const statValue = await stat(filePath).catch(() => undefined);\n\n if (!statValue) return undefined;\n\n if (typeof ttlMs === 'number' && ttlMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > ttlMs) return undefined;\n }\n let raw = await readFile(filePath);\n // header: 1 byte flag (0x00 raw, 0x01 gzip)\n const flag = raw[0];\n\n raw = raw.subarray(1);\n\n const payload = flag === 0x01 ? gunzipSync(raw) : raw;\n const deserialized = deserialize(payload) as unknown;\n\n let value: unknown;\n const maybeObj = deserialized as Record<string, unknown> | null;\n const isEnvelope =\n !!maybeObj &&\n typeof maybeObj === 'object' &&\n typeof (maybeObj as any).version === 'string' &&\n typeof (maybeObj as any).timestamp === 'number' &&\n Object.hasOwn(maybeObj, 'data');\n\n if (isEnvelope) {\n const entry = maybeObj as CacheEnvelope;\n\n if (entry.version !== configPackageJson.version) {\n try {\n await unlink(filePath);\n } catch {}\n return undefined;\n }\n\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - entry.timestamp;\n if (age > maxTimeMs) {\n try {\n await unlink(filePath);\n } catch {}\n return undefined;\n }\n }\n\n value = entry.data;\n } else {\n // Backward compatibility: old entries had raw serialized value.\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > maxTimeMs) {\n try {\n await unlink(filePath);\n } catch {}\n return undefined;\n }\n }\n value = deserialized;\n }\n\n // hydrate memory cache as well\n cacheMap.set(id, value);\n return value;\n } catch {\n return undefined;\n }\n };\n\n const writeToDisk = async (value: unknown) => {\n try {\n await ensureDir(dirname(filePath));\n const envelope: CacheEnvelope = {\n version: configPackageJson.version,\n timestamp: Date.now(),\n data: value,\n };\n const payload = Buffer.from(serialize(envelope));\n\n const gz = shouldUseCompression(payload, compress)\n ? gzipSync(payload)\n : payload;\n\n // prepend a 1-byte header indicating compression\n const buf = Buffer.concat([\n Buffer.from([gz === payload ? 0x00 : 0x01]),\n gz,\n ]);\n\n await atomicWriteFile(filePath, buf, tempDir);\n } catch {\n // swallow disk errors for cache writes\n }\n };\n\n return {\n /** In-memory first, then disk (if enabled), otherwise undefined. */\n get: async <T>(): Promise<T | undefined> => {\n const mem = cacheMap.get(id);\n\n if (mem !== undefined) return mem as T;\n\n if (persistent && buildCacheEnabled) {\n return (await readFromDisk()) as T | undefined;\n }\n return undefined;\n },\n /** Sets in-memory (always) and persists to disk if enabled. */\n set: async (value: unknown): Promise<void> => {\n cacheMap.set(id, value);\n\n if (persistent && buildCacheEnabled) {\n await writeToDisk(value);\n }\n },\n /** Clears only this entry from memory and disk. */\n clear: async (): Promise<void> => {\n cacheMap.delete(id);\n\n try {\n await unlink(filePath);\n } catch {}\n },\n /** Clears ALL cached entries (memory Map and entire cacheDir namespace if persistent). */\n clearAll: async (): Promise<void> => {\n clearAllCache();\n if (persistent && buildCacheEnabled) {\n // remove only the current namespace (if provided), else the root dir\n const base = namespace ? join(cacheDir, namespace) : cacheDir;\n\n try {\n await rm(base, { recursive: true, force: true });\n } catch {}\n\n try {\n await mkdir(base, { recursive: true });\n } catch {}\n }\n },\n /** Expose the computed id (useful if you want to key other structures). */\n isValid: async (): Promise<boolean> => {\n const cachedValue = cacheMap.get(id);\n if (cachedValue !== undefined) return true;\n\n // If persistence is disabled or build cache disabled, only memory can be valid\n if (!persistent || !buildCacheEnabled) return false;\n\n try {\n const statValue = await stat(filePath).catch(() => undefined);\n if (!statValue) return false;\n\n if (typeof ttlMs === 'number' && ttlMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > ttlMs) return false;\n }\n\n let raw = await readFile(filePath);\n const flag = raw[0];\n raw = raw.subarray(1);\n const payload = flag === 0x01 ? gunzipSync(raw) : raw;\n const deserialized = deserialize(payload) as unknown;\n\n const maybeObj = deserialized as Record<string, unknown> | null;\n const isEnvelope =\n !!maybeObj &&\n typeof maybeObj === 'object' &&\n typeof maybeObj.version === 'string' &&\n typeof maybeObj.timestamp === 'number' &&\n Object.hasOwn(maybeObj, 'data');\n\n if (isEnvelope) {\n const entry = maybeObj as CacheEnvelope;\n if (entry.version !== configPackageJson.version) return false;\n\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - entry.timestamp;\n if (age > maxTimeMs) return false;\n }\n return true;\n }\n\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > maxTimeMs) return false;\n }\n return true;\n } catch {\n return false;\n }\n },\n /** Expose the computed id (useful if you want to key other structures). */\n id,\n /** Expose the absolute file path for debugging. */\n filePath,\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"cacheDisk.mjs","names":[],"sources":["../../../src/utils/cacheDisk.ts"],"sourcesContent":["import {\n mkdir,\n readFile,\n rename,\n rm,\n stat,\n unlink,\n writeFile,\n} from 'node:fs/promises';\nimport { basename, dirname, join } from 'node:path';\nimport { deserialize, serialize } from 'node:v8';\nimport { gunzipSync, gzipSync } from 'node:zlib';\nimport type { IntlayerConfig } from '@intlayer/types/config';\nimport configPackageJson from '@intlayer/types/package.json' with {\n type: 'json',\n};\nimport { type CacheKey, clearAllCache, computeKeyId } from './cacheMemory';\n\n/** ------------------------- Persistence layer ------------------------- **/\n\n/** Cache envelope structure stored on disk */\ntype CacheEnvelope = {\n /** Version of the config package (for cache invalidation) */\n version: string;\n /** Timestamp when the cache entry was created (in milliseconds) */\n timestamp: number;\n /** Data payload (the actual cached value) */\n data: unknown;\n};\n\ntype LocalCacheOptions = {\n /** Preferred new option name */\n persistent?: boolean;\n /** Time-to-live in ms; if expired, disk entry is ignored. */\n ttlMs?: number;\n /** Max age in ms based on stored creation timestamp; invalidates on exceed. */\n maxTimeMs?: number;\n /** Optional namespace to separate different logical caches. */\n namespace?: string;\n /** Gzip values on disk (on by default for blobs > 1KB). */\n compress?: boolean;\n};\n\nconst DEFAULTS: Required<Pick<LocalCacheOptions, 'compress'>> = {\n compress: true,\n};\n\nconst ensureDir = async (dir: string) => {\n await mkdir(dir, { recursive: true });\n};\n\nconst atomicWriteFile = async (\n file: string,\n data: Buffer,\n tempDir?: string\n) => {\n if (tempDir) {\n try {\n await ensureDir(tempDir);\n } catch {}\n }\n\n const tempFileName = `${basename(file)}.tmp-${process.pid}-${Math.random().toString(36).slice(2)}`;\n const tmp = tempDir\n ? join(tempDir, tempFileName)\n : `${file}.tmp-${process.pid}-${Math.random().toString(36).slice(2)}`;\n try {\n await writeFile(tmp, data);\n await rename(tmp, file);\n } catch (error) {\n try {\n await rm(tmp, { force: true });\n } catch {\n // Ignore\n }\n throw error;\n }\n};\n\nconst shouldUseCompression = (buf: Buffer, force?: boolean) =>\n force === true || (force !== false && buf.byteLength > 1024);\n\n/** Derive on-disk path from config dir + namespace + key id. */\nconst cachePath = (cacheDir: string, id: string, ns?: string) =>\n join(cacheDir, ns ? join(ns, id) : id);\n\n/** ------------------------- Local cache facade ------------------------- **/\n\nconst cacheMap = new Map<string, any>();\n\nexport const cacheDisk = (\n intlayerConfig: IntlayerConfig,\n keys: CacheKey[],\n options?: LocalCacheOptions\n) => {\n const { cacheDir, tempDir } = intlayerConfig.system;\n const buildCacheEnabled = intlayerConfig.build.cache ?? true;\n const persistent =\n options?.persistent === true ||\n (typeof options?.persistent === 'undefined' && buildCacheEnabled);\n\n const { compress, ttlMs, maxTimeMs, namespace } = {\n ...DEFAULTS,\n ...options,\n };\n\n // single stable id for this key tuple (works for both memory & disk)\n const id = computeKeyId(keys);\n const filePath = cachePath(cacheDir, id, namespace);\n\n const readFromDisk = async (): Promise<unknown | undefined> => {\n try {\n const statValue = await stat(filePath).catch(() => undefined);\n\n if (!statValue) return undefined;\n\n if (typeof ttlMs === 'number' && ttlMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > ttlMs) return undefined;\n }\n let raw = await readFile(filePath);\n // header: 1 byte flag (0x00 raw, 0x01 gzip)\n const flag = raw[0];\n\n raw = raw.subarray(1);\n\n const payload = flag === 0x01 ? gunzipSync(raw) : raw;\n const deserialized = deserialize(payload) as unknown;\n\n let value: unknown;\n const maybeObj = deserialized as Record<string, unknown> | null;\n const isEnvelope =\n !!maybeObj &&\n typeof maybeObj === 'object' &&\n typeof (maybeObj as any).version === 'string' &&\n typeof (maybeObj as any).timestamp === 'number' &&\n Object.hasOwn(maybeObj, 'data');\n\n if (isEnvelope) {\n const entry = maybeObj as CacheEnvelope;\n\n if (entry.version !== configPackageJson.version) {\n try {\n await unlink(filePath);\n } catch {}\n return undefined;\n }\n\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - entry.timestamp;\n if (age > maxTimeMs) {\n try {\n await unlink(filePath);\n } catch {}\n return undefined;\n }\n }\n\n value = entry.data;\n } else {\n // Backward compatibility: old entries had raw serialized value.\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > maxTimeMs) {\n try {\n await unlink(filePath);\n } catch {}\n return undefined;\n }\n }\n value = deserialized;\n }\n\n // hydrate memory cache as well\n cacheMap.set(id, value);\n return value;\n } catch {\n return undefined;\n }\n };\n\n const writeToDisk = async (value: unknown) => {\n try {\n await ensureDir(dirname(filePath));\n const envelope: CacheEnvelope = {\n version: configPackageJson.version,\n timestamp: Date.now(),\n data: value,\n };\n const payload = Buffer.from(serialize(envelope));\n\n const gz = shouldUseCompression(payload, compress)\n ? gzipSync(payload)\n : payload;\n\n // prepend a 1-byte header indicating compression\n const buf = Buffer.concat([\n Buffer.from([gz === payload ? 0x00 : 0x01]),\n gz,\n ]);\n\n await atomicWriteFile(filePath, buf, tempDir);\n } catch {\n // swallow disk errors for cache writes\n }\n };\n\n return {\n /** In-memory first, then disk (if enabled), otherwise undefined. */\n get: async <T>(): Promise<T | undefined> => {\n const mem = cacheMap.get(id);\n\n if (mem !== undefined) return mem as T;\n\n if (persistent && buildCacheEnabled) {\n return (await readFromDisk()) as T | undefined;\n }\n return undefined;\n },\n /** Sets in-memory (always) and persists to disk if enabled. */\n set: async (value: unknown): Promise<void> => {\n cacheMap.set(id, value);\n\n if (persistent && buildCacheEnabled) {\n await writeToDisk(value);\n }\n },\n /** Clears only this entry from memory and disk. */\n clear: async (): Promise<void> => {\n cacheMap.delete(id);\n\n try {\n await unlink(filePath);\n } catch {}\n },\n /** Clears ALL cached entries (memory Map and entire cacheDir namespace if persistent). */\n clearAll: async (): Promise<void> => {\n clearAllCache();\n if (persistent && buildCacheEnabled) {\n // remove only the current namespace (if provided), else the root dir\n const base = namespace ? join(cacheDir, namespace) : cacheDir;\n\n try {\n await rm(base, { recursive: true, force: true });\n } catch {}\n\n try {\n await mkdir(base, { recursive: true });\n } catch {}\n }\n },\n /** Expose the computed id (useful if you want to key other structures). */\n isValid: async (): Promise<boolean> => {\n const cachedValue = cacheMap.get(id);\n if (cachedValue !== undefined) return true;\n\n // If persistence is disabled or build cache disabled, only memory can be valid\n if (!persistent || !buildCacheEnabled) return false;\n\n try {\n const statValue = await stat(filePath).catch(() => undefined);\n if (!statValue) return false;\n\n if (typeof ttlMs === 'number' && ttlMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > ttlMs) return false;\n }\n\n let raw = await readFile(filePath);\n const flag = raw[0];\n raw = raw.subarray(1);\n const payload = flag === 0x01 ? gunzipSync(raw) : raw;\n const deserialized = deserialize(payload) as unknown;\n\n const maybeObj = deserialized as Record<string, unknown> | null;\n const isEnvelope =\n !!maybeObj &&\n typeof maybeObj === 'object' &&\n typeof maybeObj.version === 'string' &&\n typeof maybeObj.timestamp === 'number' &&\n Object.hasOwn(maybeObj, 'data');\n\n if (isEnvelope) {\n const entry = maybeObj as CacheEnvelope;\n if (entry.version !== configPackageJson.version) return false;\n\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - entry.timestamp;\n if (age > maxTimeMs) return false;\n }\n return true;\n }\n\n if (typeof maxTimeMs === 'number' && maxTimeMs > 0) {\n const age = Date.now() - statValue.mtimeMs;\n if (age > maxTimeMs) return false;\n }\n return true;\n } catch {\n return false;\n }\n },\n /** Expose the computed id (useful if you want to key other structures). */\n id,\n /** Expose the absolute file path for debugging. */\n filePath,\n };\n};\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- const e=async(e,n)=>{if(typeof e==`function`)return await e(n);if(typeof e==`object`&&e&&n.locale){let r=e[n.locale];if(r)return typeof r==`function`?await r(n):t(r,n)}return typeof e==`string`?t(e,n):``},t=(e,t)=>e.replaceAll(/\{\{\s*locale\s*\}\}/g,t.locale??``).replaceAll(/\{\{\s*key\s*\}\}/g,t.key??``).replaceAll(/\{\{\s*fileName\s*\}\}/g,t.fileName??``).replaceAll(/\{\{\s*extension\s*\}\}/g,t.extension??``).replaceAll(/\{\{\s*componentFileName\s*\}\}/g,t.componentFileName??``).replaceAll(/\{\{\s*componentExtension\s*\}\}/g,t.componentExtension??``).replaceAll(/\{\{\s*format\s*\}\}/g,t.format??``).replaceAll(/\{\{\s*componentFormat\s*\}\}/g,t.componentFormat??``).replaceAll(/\{\{\s*dirPath\s*\}\}/g,t.dirPath??``);export{e as parseFilePathPattern,t as parseStringPattern};
1
+ const e=async(e,n)=>{if(typeof e==`function`)return await e(n);if(typeof e==`object`&&e&&n.locale){let r=e[n.locale];if(r)return typeof r==`function`?await r(n):t(r,n)}return typeof e==`string`?t(e,n):``},t=(e,t)=>e.replaceAll(/\{\{\s*locale\s*\}\}/g,t.locale??``).replaceAll(/\{\{\s*key\s*\}\}/g,t.key??``).replaceAll(/\{\{\s*fileName\s*\}\}/g,t.fileName??``).replaceAll(/\{\{\s*extension\s*\}\}/g,t.extension??``).replaceAll(/\{\{\s*componentFileName\s*\}\}/g,t.componentFileName??``).replaceAll(/\{\{\s*componentExtension\s*\}\}/g,t.componentExtension??``).replaceAll(/\{\{\s*format\s*\}\}/g,t.format??``).replaceAll(/\{\{\s*componentFormat\s*\}\}/g,t.componentFormat??``).replaceAll(/\{\{\s*componentDirPath\s*\}\}/g,t.componentDirPath??``);export{e as parseFilePathPattern,t as parseStringPattern};
2
2
  //# sourceMappingURL=parseFilePathPattern.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"parseFilePathPattern.mjs","names":[],"sources":["../../../src/utils/parseFilePathPattern.ts"],"sourcesContent":["import type {\n FilePathPattern,\n FilePathPatternContext,\n} from '@intlayer/types/filePathPattern';\n\n/**\n * Parses a FilePathPattern configuration string or function to a final string path.\n * Resolves context variables like `{{locale}}`, `{{key}}`, `{{fileName}}`, `{{extension}}`.\n */\nexport const parseFilePathPattern = async (\n pattern: FilePathPattern,\n context: FilePathPatternContext\n): Promise<string> => {\n if (typeof pattern === 'function') {\n return await (pattern as any)(context);\n }\n\n if (typeof pattern === 'object' && pattern !== null && context.locale) {\n const localePattern = (pattern as any)[context.locale];\n\n if (localePattern) {\n if (typeof localePattern === 'function') {\n return await localePattern(context);\n }\n return parseStringPattern(localePattern, context);\n }\n }\n\n if (typeof pattern === 'string') {\n return parseStringPattern(pattern, context);\n }\n\n return '';\n};\n\nexport const parseStringPattern = (\n pattern: string,\n context: FilePathPatternContext\n): string =>\n pattern\n .replaceAll(/\\{\\{\\s*locale\\s*\\}\\}/g, context.locale ?? '')\n .replaceAll(/\\{\\{\\s*key\\s*\\}\\}/g, context.key ?? '')\n .replaceAll(/\\{\\{\\s*fileName\\s*\\}\\}/g, context.fileName ?? '')\n .replaceAll(/\\{\\{\\s*extension\\s*\\}\\}/g, context.extension ?? '')\n .replaceAll(\n /\\{\\{\\s*componentFileName\\s*\\}\\}/g,\n context.componentFileName ?? ''\n )\n .replaceAll(\n /\\{\\{\\s*componentExtension\\s*\\}\\}/g,\n context.componentExtension ?? ''\n )\n .replaceAll(/\\{\\{\\s*format\\s*\\}\\}/g, context.format ?? '')\n .replaceAll(/\\{\\{\\s*componentFormat\\s*\\}\\}/g, context.componentFormat ?? '')\n .replaceAll(/\\{\\{\\s*dirPath\\s*\\}\\}/g, context.dirPath ?? '');\n"],"mappings":"AASA,MAAa,EAAuB,MAClC,EACA,IACoB,CACpB,GAAI,OAAO,GAAY,WACrB,OAAO,MAAO,EAAgB,EAAQ,CAGxC,GAAI,OAAO,GAAY,UAAY,GAAoB,EAAQ,OAAQ,CACrE,IAAM,EAAiB,EAAgB,EAAQ,QAE/C,GAAI,EAIF,OAHI,OAAO,GAAkB,WACpB,MAAM,EAAc,EAAQ,CAE9B,EAAmB,EAAe,EAAQ,CAQrD,OAJI,OAAO,GAAY,SACd,EAAmB,EAAS,EAAQ,CAGtC,IAGI,GACX,EACA,IAEA,EACG,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,qBAAsB,EAAQ,KAAO,GAAG,CACnD,WAAW,0BAA2B,EAAQ,UAAY,GAAG,CAC7D,WAAW,2BAA4B,EAAQ,WAAa,GAAG,CAC/D,WACC,mCACA,EAAQ,mBAAqB,GAC9B,CACA,WACC,oCACA,EAAQ,oBAAsB,GAC/B,CACA,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,iCAAkC,EAAQ,iBAAmB,GAAG,CAC3E,WAAW,yBAA0B,EAAQ,SAAW,GAAG"}
1
+ {"version":3,"file":"parseFilePathPattern.mjs","names":[],"sources":["../../../src/utils/parseFilePathPattern.ts"],"sourcesContent":["import type {\n FilePathPattern,\n FilePathPatternContext,\n} from '@intlayer/types/filePathPattern';\n\n/**\n * Parses a FilePathPattern configuration string or function to a final string path.\n * Resolves context variables like `{{locale}}`, `{{key}}`, `{{fileName}}`, `{{extension}}`.\n */\nexport const parseFilePathPattern = async (\n pattern: FilePathPattern,\n context: FilePathPatternContext\n): Promise<string> => {\n if (typeof pattern === 'function') {\n return await (pattern as any)(context);\n }\n\n if (typeof pattern === 'object' && pattern !== null && context.locale) {\n const localePattern = (pattern as any)[context.locale];\n\n if (localePattern) {\n if (typeof localePattern === 'function') {\n return await localePattern(context);\n }\n return parseStringPattern(localePattern, context);\n }\n }\n\n if (typeof pattern === 'string') {\n return parseStringPattern(pattern, context);\n }\n\n return '';\n};\n\nexport const parseStringPattern = (\n pattern: string,\n context: FilePathPatternContext\n): string =>\n pattern\n .replaceAll(/\\{\\{\\s*locale\\s*\\}\\}/g, context.locale ?? '')\n .replaceAll(/\\{\\{\\s*key\\s*\\}\\}/g, context.key ?? '')\n .replaceAll(/\\{\\{\\s*fileName\\s*\\}\\}/g, context.fileName ?? '')\n .replaceAll(/\\{\\{\\s*extension\\s*\\}\\}/g, context.extension ?? '')\n .replaceAll(\n /\\{\\{\\s*componentFileName\\s*\\}\\}/g,\n context.componentFileName ?? ''\n )\n .replaceAll(\n /\\{\\{\\s*componentExtension\\s*\\}\\}/g,\n context.componentExtension ?? ''\n )\n .replaceAll(/\\{\\{\\s*format\\s*\\}\\}/g, context.format ?? '')\n .replaceAll(/\\{\\{\\s*componentFormat\\s*\\}\\}/g, context.componentFormat ?? '')\n .replaceAll(\n /\\{\\{\\s*componentDirPath\\s*\\}\\}/g,\n context.componentDirPath ?? ''\n );\n"],"mappings":"AASA,MAAa,EAAuB,MAClC,EACA,IACoB,CACpB,GAAI,OAAO,GAAY,WACrB,OAAO,MAAO,EAAgB,EAAQ,CAGxC,GAAI,OAAO,GAAY,UAAY,GAAoB,EAAQ,OAAQ,CACrE,IAAM,EAAiB,EAAgB,EAAQ,QAE/C,GAAI,EAIF,OAHI,OAAO,GAAkB,WACpB,MAAM,EAAc,EAAQ,CAE9B,EAAmB,EAAe,EAAQ,CAQrD,OAJI,OAAO,GAAY,SACd,EAAmB,EAAS,EAAQ,CAGtC,IAGI,GACX,EACA,IAEA,EACG,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,qBAAsB,EAAQ,KAAO,GAAG,CACnD,WAAW,0BAA2B,EAAQ,UAAY,GAAG,CAC7D,WAAW,2BAA4B,EAAQ,WAAa,GAAG,CAC/D,WACC,mCACA,EAAQ,mBAAqB,GAC9B,CACA,WACC,oCACA,EAAQ,oBAAsB,GAC/B,CACA,WAAW,wBAAyB,EAAQ,QAAU,GAAG,CACzD,WAAW,iCAAkC,EAAQ,iBAAmB,GAAG,CAC3E,WACC,kCACA,EAAQ,kBAAoB,GAC7B"}
@@ -20,9 +20,9 @@ declare const cookiesAttributesSchema: z.ZodObject<{
20
20
  secure: z.ZodOptional<z.ZodBoolean>;
21
21
  httpOnly: z.ZodOptional<z.ZodBoolean>;
22
22
  sameSite: z.ZodOptional<z.ZodEnum<{
23
+ none: "none";
23
24
  strict: "strict";
24
25
  lax: "lax";
25
- none: "none";
26
26
  }>>;
27
27
  expires: z.ZodOptional<z.ZodUnion<readonly [z.ZodDate, z.ZodNumber]>>;
28
28
  }, z.core.$strip>;
@@ -47,9 +47,9 @@ declare const storageSchema: z.ZodUnion<readonly [z.ZodLiteral<false>, z.ZodEnum
47
47
  secure: z.ZodOptional<z.ZodBoolean>;
48
48
  httpOnly: z.ZodOptional<z.ZodBoolean>;
49
49
  sameSite: z.ZodOptional<z.ZodEnum<{
50
+ none: "none";
50
51
  strict: "strict";
51
52
  lax: "lax";
52
- none: "none";
53
53
  }>>;
54
54
  expires: z.ZodOptional<z.ZodUnion<readonly [z.ZodDate, z.ZodNumber]>>;
55
55
  }, z.core.$strip>, z.ZodObject<{
@@ -72,9 +72,9 @@ declare const storageSchema: z.ZodUnion<readonly [z.ZodLiteral<false>, z.ZodEnum
72
72
  secure: z.ZodOptional<z.ZodBoolean>;
73
73
  httpOnly: z.ZodOptional<z.ZodBoolean>;
74
74
  sameSite: z.ZodOptional<z.ZodEnum<{
75
+ none: "none";
75
76
  strict: "strict";
76
77
  lax: "lax";
77
- none: "none";
78
78
  }>>;
79
79
  expires: z.ZodOptional<z.ZodUnion<readonly [z.ZodDate, z.ZodNumber]>>;
80
80
  }, z.core.$strip>, z.ZodObject<{
@@ -155,9 +155,9 @@ declare const routingSchema: z.ZodObject<{
155
155
  secure: z.ZodOptional<z.ZodBoolean>;
156
156
  httpOnly: z.ZodOptional<z.ZodBoolean>;
157
157
  sameSite: z.ZodOptional<z.ZodEnum<{
158
+ none: "none";
158
159
  strict: "strict";
159
160
  lax: "lax";
160
- none: "none";
161
161
  }>>;
162
162
  expires: z.ZodOptional<z.ZodUnion<readonly [z.ZodDate, z.ZodNumber]>>;
163
163
  }, z.core.$strip>, z.ZodObject<{
@@ -180,9 +180,9 @@ declare const routingSchema: z.ZodObject<{
180
180
  secure: z.ZodOptional<z.ZodBoolean>;
181
181
  httpOnly: z.ZodOptional<z.ZodBoolean>;
182
182
  sameSite: z.ZodOptional<z.ZodEnum<{
183
+ none: "none";
183
184
  strict: "strict";
184
185
  lax: "lax";
185
- none: "none";
186
186
  }>>;
187
187
  expires: z.ZodOptional<z.ZodUnion<readonly [z.ZodDate, z.ZodNumber]>>;
188
188
  }, z.core.$strip>, z.ZodObject<{
@@ -195,18 +195,8 @@ declare const routingSchema: z.ZodObject<{
195
195
  }, z.core.$strip>]>>]>>;
196
196
  basePath: z.ZodOptional<z.ZodString>;
197
197
  }, z.core.$strip>;
198
- declare const contentSchema: z.ZodObject<{
199
- fileExtensions: z.ZodOptional<z.ZodArray<z.ZodString>>;
200
- baseDir: z.ZodOptional<z.ZodString>;
201
- contentDir: z.ZodOptional<z.ZodArray<z.ZodString>>;
202
- codeDir: z.ZodOptional<z.ZodArray<z.ZodString>>;
203
- excludedPath: z.ZodOptional<z.ZodArray<z.ZodString>>;
204
- watch: z.ZodOptional<z.ZodBoolean>;
205
- formatCommand: z.ZodOptional<z.ZodString>;
206
- watchedFilesPattern: z.ZodOptional<z.ZodArray<z.ZodString>>;
207
- watchedFilesPatternWithPath: z.ZodOptional<z.ZodArray<z.ZodString>>;
208
- }, z.core.$strip>;
209
198
  declare const systemSchema: z.ZodObject<{
199
+ baseDir: z.ZodOptional<z.ZodString>;
210
200
  moduleAugmentationDir: z.ZodOptional<z.ZodString>;
211
201
  unmergedDictionariesDir: z.ZodOptional<z.ZodString>;
212
202
  remoteDictionariesDir: z.ZodOptional<z.ZodString>;
@@ -220,6 +210,16 @@ declare const systemSchema: z.ZodObject<{
220
210
  tempDir: z.ZodOptional<z.ZodString>;
221
211
  outputFilesPatternWithPath: z.ZodOptional<z.ZodString>;
222
212
  }, z.core.$strip>;
213
+ declare const contentSchema: z.ZodObject<{
214
+ fileExtensions: z.ZodOptional<z.ZodArray<z.ZodString>>;
215
+ contentDir: z.ZodOptional<z.ZodArray<z.ZodString>>;
216
+ codeDir: z.ZodOptional<z.ZodArray<z.ZodString>>;
217
+ excludedPath: z.ZodOptional<z.ZodArray<z.ZodString>>;
218
+ watch: z.ZodOptional<z.ZodBoolean>;
219
+ formatCommand: z.ZodOptional<z.ZodString>;
220
+ watchedFilesPattern: z.ZodOptional<z.ZodArray<z.ZodString>>;
221
+ watchedFilesPatternWithPath: z.ZodOptional<z.ZodArray<z.ZodString>>;
222
+ }, z.core.$strip>;
223
223
  declare const editorSchema: z.ZodObject<{
224
224
  applicationURL: z.ZodOptional<z.ZodUnion<readonly [z.ZodURL, z.ZodLiteral<"">]>>;
225
225
  editorURL: z.ZodOptional<z.ZodUnion<readonly [z.ZodURL, z.ZodLiteral<"">]>>;
@@ -239,8 +239,8 @@ declare const editorSchema: z.ZodObject<{
239
239
  }, z.core.$strip>;
240
240
  declare const logSchema: z.ZodObject<{
241
241
  mode: z.ZodOptional<z.ZodEnum<{
242
- default: "default";
243
242
  verbose: "verbose";
243
+ default: "default";
244
244
  disabled: "disabled";
245
245
  }>>;
246
246
  prefix: z.ZodOptional<z.ZodString>;
@@ -353,9 +353,9 @@ declare const intlayerConfigSchema: z.ZodObject<{
353
353
  secure: z.ZodOptional<z.ZodBoolean>;
354
354
  httpOnly: z.ZodOptional<z.ZodBoolean>;
355
355
  sameSite: z.ZodOptional<z.ZodEnum<{
356
+ none: "none";
356
357
  strict: "strict";
357
358
  lax: "lax";
358
- none: "none";
359
359
  }>>;
360
360
  expires: z.ZodOptional<z.ZodUnion<readonly [z.ZodDate, z.ZodNumber]>>;
361
361
  }, z.core.$strip>, z.ZodObject<{
@@ -378,9 +378,9 @@ declare const intlayerConfigSchema: z.ZodObject<{
378
378
  secure: z.ZodOptional<z.ZodBoolean>;
379
379
  httpOnly: z.ZodOptional<z.ZodBoolean>;
380
380
  sameSite: z.ZodOptional<z.ZodEnum<{
381
+ none: "none";
381
382
  strict: "strict";
382
383
  lax: "lax";
383
- none: "none";
384
384
  }>>;
385
385
  expires: z.ZodOptional<z.ZodUnion<readonly [z.ZodDate, z.ZodNumber]>>;
386
386
  }, z.core.$strip>, z.ZodObject<{
@@ -395,7 +395,6 @@ declare const intlayerConfigSchema: z.ZodObject<{
395
395
  }, z.core.$strip>>;
396
396
  content: z.ZodOptional<z.ZodObject<{
397
397
  fileExtensions: z.ZodOptional<z.ZodArray<z.ZodString>>;
398
- baseDir: z.ZodOptional<z.ZodString>;
399
398
  contentDir: z.ZodOptional<z.ZodArray<z.ZodString>>;
400
399
  codeDir: z.ZodOptional<z.ZodArray<z.ZodString>>;
401
400
  excludedPath: z.ZodOptional<z.ZodArray<z.ZodString>>;
@@ -405,6 +404,7 @@ declare const intlayerConfigSchema: z.ZodObject<{
405
404
  watchedFilesPatternWithPath: z.ZodOptional<z.ZodArray<z.ZodString>>;
406
405
  }, z.core.$strip>>;
407
406
  system: z.ZodOptional<z.ZodObject<{
407
+ baseDir: z.ZodOptional<z.ZodString>;
408
408
  moduleAugmentationDir: z.ZodOptional<z.ZodString>;
409
409
  unmergedDictionariesDir: z.ZodOptional<z.ZodString>;
410
410
  remoteDictionariesDir: z.ZodOptional<z.ZodString>;
@@ -437,8 +437,8 @@ declare const intlayerConfigSchema: z.ZodObject<{
437
437
  }, z.core.$strip>>;
438
438
  log: z.ZodOptional<z.ZodObject<{
439
439
  mode: z.ZodOptional<z.ZodEnum<{
440
- default: "default";
441
440
  verbose: "verbose";
441
+ default: "default";
442
442
  disabled: "disabled";
443
443
  }>>;
444
444
  prefix: z.ZodOptional<z.ZodString>;
@@ -1 +1 @@
1
- {"version":3,"file":"configurationSchema.d.ts","names":[],"sources":["../../../src/configFile/configurationSchema.ts"],"mappings":";;;;cAGa,0BAAA,EAA0B,CAAA,CAAA,SAAA;;;;;;;;;;cAO1B,uBAAA,EAAuB,CAAA,CAAA,SAAA;;;;;;;;;;;;;;cAWvB,uBAAA,EAAuB,CAAA,CAAA,SAAA;;;;;;;;cAKvB,aAAA,EAAa,CAAA,CAAA,QAAA,WAAA,CAAA,CAAA,UAAA,SAAA,CAAA,CAAA,OAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAcb,iBAAA,EAAiB,CAAA,CAAA,SAAA;;;;cAKjB,kBAAA,EAAkB,CAAA,CAAA,SAAA;;;;;;cAIlB,mBAAA,EAAmB,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;;;;cAMnB,aAAA,EAAa,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAcb,aAAA,EAAa,CAAA,CAAA,SAAA;;;;;;;;;;;cAYb,YAAA,EAAY,CAAA,CAAA,SAAA;;;;;;;;;;;;;;cAeZ,YAAA,EAAY,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;cAiBZ,SAAA,EAAS,CAAA,CAAA,SAAA;;;;;;;;;;;;cAST,QAAA,EAAQ,CAAA,CAAA,SAAA;;;;;;;;;;;;cAUR,WAAA,EAAW,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;;;;cAWX,cAAA,EAAc,CAAA,CAAA,SAAA;;;;;;;;;;cAWd,gBAAA,EAAgB,CAAA,CAAA,SAAA;;;;;;;;;;;cAiBhB,oBAAA,EAAoB,CAAA,CAAA,SAAA"}
1
+ {"version":3,"file":"configurationSchema.d.ts","names":[],"sources":["../../../src/configFile/configurationSchema.ts"],"mappings":";;;;cAGa,0BAAA,EAA0B,CAAA,CAAA,SAAA;;;;;;;;;;cAO1B,uBAAA,EAAuB,CAAA,CAAA,SAAA;;;;;;;;;;;;;;cAWvB,uBAAA,EAAuB,CAAA,CAAA,SAAA;;;;;;;;cAKvB,aAAA,EAAa,CAAA,CAAA,QAAA,WAAA,CAAA,CAAA,UAAA,SAAA,CAAA,CAAA,OAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAcb,iBAAA,EAAiB,CAAA,CAAA,SAAA;;;;cAKjB,kBAAA,EAAkB,CAAA,CAAA,SAAA;;;;;;cAIlB,mBAAA,EAAmB,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;;;;cAMnB,aAAA,EAAa,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAcb,YAAA,EAAY,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;cAgBZ,aAAA,EAAa,CAAA,CAAA,SAAA;;;;;;;;;;cAWb,YAAA,EAAY,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;cAiBZ,SAAA,EAAS,CAAA,CAAA,SAAA;;;;;;;;;;;;cAST,QAAA,EAAQ,CAAA,CAAA,SAAA;;;;;;;;;;;;cAUR,WAAA,EAAW,CAAA,CAAA,SAAA;;;;;;;;;;;;;;;;;;;;cAWX,cAAA,EAAc,CAAA,CAAA,SAAA;;;;;;;;;;cAWd,gBAAA,EAAgB,CAAA,CAAA,SAAA;;;;;;;;;;;cAiBhB,oBAAA,EAAoB,CAAA,CAAA,SAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"build.d.ts","names":[],"sources":["../../../src/defaultValues/build.ts"],"mappings":";;;cAAa,UAAA;AAAA,cAEA,QAAA;AAAA,cAEA,gBAAA;AAAA,cAKA,aAAA;AAAA,cAEA,KAAA;AAAA,cAEA,aAAA"}
1
+ {"version":3,"file":"build.d.ts","names":[],"sources":["../../../src/defaultValues/build.ts"],"mappings":";;;cAAa,UAAA;AAAA,cAEA,QAAA;AAAA,cAEA,gBAAA;AAAA,cAMA,aAAA;AAAA,cAEA,KAAA;AAAA,cAEA,aAAA"}
@@ -6,7 +6,7 @@ declare const EDITOR_URL = "http://localhost:8000";
6
6
  declare const CMS_URL = "https://app.intlayer.org";
7
7
  declare const BACKEND_URL = "https://back.intlayer.org";
8
8
  declare const PORT = 8000;
9
- declare const IS_ENABLED = true;
9
+ declare const IS_ENABLED = false;
10
10
  declare const LIVE_SYNC = true;
11
11
  declare const DICTIONARY_PRIORITY_STRATEGY = "local_first";
12
12
  declare const LIVE_SYNC_PORT = 4000;
@@ -6,6 +6,7 @@ import { BuildOptions } from "esbuild";
6
6
  type LoadExternalFileOptions = {
7
7
  configuration?: IntlayerConfig;
8
8
  buildOptions?: BuildOptions;
9
+ logError?: boolean;
9
10
  } & SandBoxContextOptions;
10
11
  /**
11
12
  * Load the content declaration from the given path
@@ -1 +1 @@
1
- {"version":3,"file":"loadExternalFile.d.ts","names":[],"sources":["../../../src/loadExternalFile/loadExternalFile.ts"],"mappings":";;;;;KAaY,uBAAA;EACV,aAAA,GAAgB,cAAA;EAChB,YAAA,GAAe,YAAA;AAAA,IACb,qBAAA;;;;;;cAOS,oBAAA,GACX,QAAA,UACA,OAAA,GAAU,uBAAA;;;;;;cA2DC,gBAAA,GACX,QAAA,UACA,OAAA,GAAU,uBAAA,KACT,OAAA"}
1
+ {"version":3,"file":"loadExternalFile.d.ts","names":[],"sources":["../../../src/loadExternalFile/loadExternalFile.ts"],"mappings":";;;;;KAaY,uBAAA;EACV,aAAA,GAAgB,cAAA;EAChB,YAAA,GAAe,YAAA;EACf,QAAA;AAAA,IACE,qBAAA;;;;;;cAOS,oBAAA,GACX,QAAA,UACA,OAAA,GAAU,uBAAA;;;;;;cA2DC,gBAAA,GACX,QAAA,UACA,OAAA,GAAU,uBAAA,KACT,OAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@intlayer/config",
3
- "version": "8.3.0-canary.0",
3
+ "version": "8.3.0-canary.2",
4
4
  "private": false,
5
5
  "description": "Retrieve Intlayer configurations and manage environment variables for both server-side and client-side environments.",
6
6
  "keywords": [
@@ -127,7 +127,7 @@
127
127
  "typecheck": "tsc --noEmit --project tsconfig.types.json"
128
128
  },
129
129
  "dependencies": {
130
- "@intlayer/types": "8.3.0-canary.0",
130
+ "@intlayer/types": "8.3.0-canary.2",
131
131
  "defu": "6.1.4",
132
132
  "dotenv": "17.3.1",
133
133
  "esbuild": "0.27.2",
@@ -135,12 +135,12 @@
135
135
  "zod": "4.3.6"
136
136
  },
137
137
  "devDependencies": {
138
- "@types/node": "25.3.5",
138
+ "@types/node": "25.4.0",
139
139
  "@utils/ts-config": "1.0.4",
140
140
  "@utils/ts-config-types": "1.0.4",
141
141
  "@utils/tsdown-config": "1.0.4",
142
142
  "rimraf": "6.1.3",
143
- "tsdown": "0.21.1",
143
+ "tsdown": "0.21.2",
144
144
  "typescript": "5.9.3",
145
145
  "vitest": "4.0.18"
146
146
  },