next-intlayer 8.1.5 → 8.1.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -46,25 +46,26 @@ With **per-locale content files**, **TypeScript autocompletion**, **tree-shakabl
46
46
 
47
47
  ## Keys benefits of Intlayer:
48
48
 
49
- | Feature | Description |
50
- | --------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
51
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/frameworks.png?raw=true" alt="Feature" width="700"> | **Cross-Frameworks Support**<br><br>Intlayer is compatible with all major frameworks and libraries, including Next.js, React, Vite, Vue.js, Nuxt, Preact, Express, and more. |
52
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/javascript_content_management.jpg?raw=true" alt="Feature" width="700"> | **JavaScript-Powered Content Management**<br><br>Harness the flexibility of JavaScript to define and manage your content efficiently. <br><br> - [Content declaration](https://intlayer.org/doc/concept/content) |
53
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/per_locale_content_declaration_file.png?raw=true" alt="Feature" width="700"> | **Per-Locale Content Declaration File**<br><br>Speed up your development by declaring your content once, before auto generation.<br><br> - [Per-Locale Content Declaration File](https://intlayer.org/doc/concept/per-locale-file) |
54
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/autocompletion.png?raw=true" alt="Feature" width="700"> | **Type-Safe Environment**<br><br>Leverage TypeScript to ensure your content definitions and code are error-free, while also benefiting from IDE autocompletion.<br><br> - [TypeScript configuration](https://intlayer.org/doc/environment/vite-and-react#configure-typescript) |
55
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/config_file.png?raw=true" alt="Feature" width="700"> | **Simplified Setup**<br><br>Get up and running quickly with minimal configuration. Adjust settings for internationalization, routing, AI, build, and content handling with ease. <br><br> - [Explore Next.js integration](https://intlayer.org/doc/environment/nextjs) |
56
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/content_retrieval.png?raw=true" alt="Feature" width="700"> | **Simplified Content Retrieval**<br><br>No need to call your `t` function for each piece of content. Retrieve all your content directly using a single hook.<br><br> - [React integration](https://intlayer.org/doc/environment/create-react-app) |
57
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/server_component.png?raw=true" alt="Feature" width="700"> | **Consistent Server Component Implementation**<br><br>Perfectly suited for Next.js server components, use the same implementation for both client and server components, no need to pass your `t` function across each server component. <br><br> - [Server Components](https://intlayer.org/doc/environment/nextjs#step-7-utilize-content-in-your-code) |
58
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/file_tree.png?raw=true" alt="Feature" width="700"> | **Organized Codebase**<br><br>Keep your codebase more organized: 1 component = 1 dictionary in the same folder. Translations close to their respective components, enhance maintainability and clarity. <br><br> - [How Intlayer works](https://intlayer.org/doc/concept/how-works-intlayer) |
59
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/url_routing.png?raw=true" alt="Feature" width="700"> | **Enhanced Routing**<br><br>Full support of app routing, adapting seamlessly to complex application structures, for Next.js, React, Vite, Vue.js, etc.<br><br> - [Explore Next.js integration](https://intlayer.org/doc/environment/nextjs) |
60
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/markdown.png?raw=true" alt="Feature" width="700"> | **Markdown Support**<br><br>Import and interpret, locale files and remote Markdown for multilingual content like privacy policies, documentation, etc. Interpret and make Markdown metadata accessible in your code.<br><br> - [Content files](https://intlayer.org/doc/concept/content/file) |
61
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/visual_editor.png?raw=true" alt="Feature" width="700"> | **Free Visual Editor & CMS**<br><br>A free visual editor and CMS are available for content writers, removing the need for a localization platform. Keep your content synchronized using Git, or externalize it totally or partially with the CMS.<br><br> - [Intlayer Editor](https://intlayer.org/doc/concept/editor) <br> - [Intlayer CMS](https://intlayer.org/doc/concept/cms) |
62
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/bundle.png?raw=true" alt="Feature" width="700"> | **Tree-shakable Content**<br><br>Tree-shakable content, reducing the size of the final bundle. Loads content per component, excluding any unused content from your bundle. Supports lazy loading to enhance app loading efficiency. <br><br> - [App build optimization](https://intlayer.org/doc/concept/how-works-intlayer#app-build-optimization) |
63
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/static_rendering.png?raw=true" alt="Feature" width="700"> | **Static Rendering**<br><br>Doesn't block Static Rendering. <br><br> - [Next.js integration](https://intlayer.org/doc/environment/nextjs) |
64
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/AI_translation.png?raw=true" alt="Feature" width="700"> | **AI-Powered Translation**<br><br>Transform your website into 231 languages with just one click using Intlayer's advanced AI-powered translation tools using your own AI provider / API key. <br><br> - [CI/CD integration](https://intlayer.org/doc/concept/ci-cd) <br> - [Intlayer CLI](https://intlayer.org/doc/concept/cli) <br> - [Auto fill](https://intlayer.org/doc/concept/auto-fill) |
65
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/mcp.png?raw=true" alt="Feature" width="700"> | **MCP Server Integration**<br><br>Provides an MCP (Model Context Protocol) server for IDE automation, enabling seamless content management and i18n workflows directly within your development environment. <br><br> - [MCP Server](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/mcp_server.md) |
66
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/vscode_extension.png?raw=true" alt="Feature" width="700"> | **VSCode Extension**<br><br>Intlayer provides a VSCode extension to help you manage your content and translations, building your dictionaries, translating your content, and more. <br><br> - [VSCode Extension](https://intlayer.org/doc/vs-code-extension) |
67
- | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/interoperability.png?raw=true" alt="Feature" width="700"> | **Interoperability**<br><br>Allow interoperability with react-i18next, next-i18next, next-intl, and react-intl. <br><br> - [Intlayer and react-intl](https://intlayer.org/blog/intlayer-with-react-intl) <br> - [Intlayer and next-intl](https://intlayer.org/blog/intlayer-with-next-intl) <br> - [Intlayer and next-i18next](https://intlayer.org/blog/intlayer-with-next-i18next) |
49
+ | Feature | Description |
50
+ | --------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
51
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/frameworks.png?raw=true" alt="Feature" width="700"> | **Cross-Frameworks Support**<br><br>Intlayer is compatible with all major frameworks and libraries, including Next.js, React, Vite, Vue.js, Nuxt, Preact, Express, and more. |
52
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/javascript_content_management.jpg?raw=true" alt="Feature" width="700"> | **JavaScript-Powered Content Management**<br><br>Harness the flexibility of JavaScript to define and manage your content efficiently. <br><br> - [Content declaration](https://intlayer.org/doc/concept/content) |
53
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/per_locale_content_declaration_file.png?raw=true" alt="Feature" width="700"> | **Per-Locale Content Declaration File**<br><br>Speed up your development by declaring your content once, before auto generation.<br><br> - [Per-Locale Content Declaration File](https://intlayer.org/doc/concept/per-locale-file) |
54
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/compiler.jpg?raw=true" alt="Feature" width="700"> | **Compiler**<br><br>The Intlayer Compiler extract automatically the content from the components and generate the dictionary files.<br><br> - [Compiler](https://intlayer.org/doc/compiler) |
55
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/autocompletion.png?raw=true" alt="Feature" width="700"> | **Type-Safe Environment**<br><br>Leverage TypeScript to ensure your content definitions and code are error-free, while also benefiting from IDE autocompletion.<br><br> - [TypeScript configuration](https://intlayer.org/doc/environment/vite-and-react#configure-typescript) |
56
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/config_file.png?raw=true" alt="Feature" width="700"> | **Simplified Setup**<br><br>Get up and running quickly with minimal configuration. Adjust settings for internationalization, routing, AI, build, and content handling with ease. <br><br> - [Explore Next.js integration](https://intlayer.org/doc/environment/nextjs) |
57
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/content_retrieval.png?raw=true" alt="Feature" width="700"> | **Simplified Content Retrieval**<br><br>No need to call your `t` function for each piece of content. Retrieve all your content directly using a single hook.<br><br> - [React integration](https://intlayer.org/doc/environment/create-react-app) |
58
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/server_component.png?raw=true" alt="Feature" width="700"> | **Consistent Server Component Implementation**<br><br>Perfectly suited for Next.js server components, use the same implementation for both client and server components, no need to pass your `t` function across each server component. <br><br> - [Server Components](https://intlayer.org/doc/environment/nextjs#step-7-utilize-content-in-your-code) |
59
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/file_tree.png?raw=true" alt="Feature" width="700"> | **Organized Codebase**<br><br>Keep your codebase more organized: 1 component = 1 dictionary in the same folder. Translations close to their respective components, enhance maintainability and clarity. <br><br> - [How Intlayer works](https://intlayer.org/doc/concept/how-works-intlayer) |
60
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/url_routing.png?raw=true" alt="Feature" width="700"> | **Enhanced Routing**<br><br>Full support of app routing, adapting seamlessly to complex application structures, for Next.js, React, Vite, Vue.js, etc.<br><br> - [Explore Next.js integration](https://intlayer.org/doc/environment/nextjs) |
61
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/markdown.png?raw=true" alt="Feature" width="700"> | **Markdown Support**<br><br>Import and interpret, locale files and remote Markdown for multilingual content like privacy policies, documentation, etc. Interpret and make Markdown metadata accessible in your code.<br><br> - [Content files](https://intlayer.org/doc/concept/content/file) |
62
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/visual_editor.png?raw=true" alt="Feature" width="700"> | **Free Visual Editor & CMS**<br><br>A free visual editor and CMS are available for content writers, removing the need for a localization platform. Keep your content synchronized using Git, or externalize it totally or partially with the CMS.<br><br> - [Intlayer Editor](https://intlayer.org/doc/concept/editor) <br> - [Intlayer CMS](https://intlayer.org/doc/concept/cms) |
63
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/bundle.png?raw=true" alt="Feature" width="700"> | **Tree-shakable Content**<br><br>Tree-shakable content, reducing the size of the final bundle. Loads content per component, excluding any unused content from your bundle. Supports lazy loading to enhance app loading efficiency. <br><br> - [App build optimization](https://intlayer.org/doc/concept/how-works-intlayer#app-build-optimization) |
64
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/static_rendering.png?raw=true" alt="Feature" width="700"> | **Static Rendering**<br><br>Doesn't block Static Rendering. <br><br> - [Next.js integration](https://intlayer.org/doc/environment/nextjs) |
65
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/AI_translation.png?raw=true" alt="Feature" width="700"> | **AI-Powered Translation**<br><br>Transform your website into 231 languages with just one click using Intlayer's advanced AI-powered translation tools using your own AI provider / API key. <br><br> - [CI/CD integration](https://intlayer.org/doc/concept/ci-cd) <br> - [Intlayer CLI](https://intlayer.org/doc/concept/cli) <br> - [Auto fill](https://intlayer.org/doc/concept/auto-fill) |
66
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/mcp.png?raw=true" alt="Feature" width="700"> | **MCP Server Integration**<br><br>Provides an MCP (Model Context Protocol) server for IDE automation, enabling seamless content management and i18n workflows directly within your development environment. <br><br> - [MCP Server](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/mcp_server.md) |
67
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/vscode_extension.png?raw=true" alt="Feature" width="700"> | **VSCode Extension**<br><br>Intlayer provides a VSCode extension to help you manage your content and translations, building your dictionaries, translating your content, and more. <br><br> - [VSCode Extension](https://intlayer.org/doc/vs-code-extension) |
68
+ | <img src="https://github.com/aymericzip/intlayer/blob/main/docs/assets/interoperability.png?raw=true" alt="Feature" width="700"> | **Interoperability**<br><br>Allow interoperability with react-i18next, next-i18next, next-intl, react-intl, vue-i18n. <br><br> - [Intlayer and react-intl](https://intlayer.org/blog/intlayer-with-react-intl) <br> - [Intlayer and next-intl](https://intlayer.org/blog/intlayer-with-next-intl) <br> - [Intlayer and next-i18next](https://intlayer.org/blog/intlayer-with-next-i18next) <br> - [Intlayer and vue-i18n](https://intlayer.org/blog/intlayer-with-vue-i18n) |
68
69
 
69
70
  ---
70
71
 
@@ -153,6 +154,8 @@ Explore our comprehensive documentation to get started with Intlayer and learn h
153
154
  <li><a href="https://intlayer.org/doc/concept/how-works-intlayer" rel=''>How Intlayer Works</a></li>
154
155
  <li><a href="https://intlayer.org/doc/concept/configuration" rel=''>Configuration</a></li>
155
156
  <li><a href="https://intlayer.org/doc/concept/cli" rel=''>Intlayer CLI</a></li>
157
+ <li><a href="https://intlayer.org/doc/compiler" rel=''>Compiler</a></li>
158
+
156
159
  <li><a href="https://intlayer.org/doc/concept/editor" rel=''>Intlayer Editor</a></li>
157
160
  <li><a href="https://intlayer.org/doc/concept/cms" rel=''>Intlayer CMS</a></li>
158
161
  <li><a href="https://intlayer.org/doc/concept/content" rel=''>Dictionary</a>
@@ -179,17 +182,15 @@ Explore our comprehensive documentation to get started with Intlayer and learn h
179
182
  <li><a href="https://intlayer.org/doc/environment/nextjs/15" rel=''>Next.js 15</a></li>
180
183
  <li><a href="https://intlayer.org/doc/environment/nextjs/14" rel=''>Next.js 14 (App Router)</a></li>
181
184
  <li><a href="https://intlayer.org/doc/environment/nextjs/next-with-Page-Router" rel=''>Next.js Page Router</a></li>
185
+ <li><a href="https://intlayer.org/doc/environment/nextjs/compiler" rel=''>Next.js using Compiler</a></li>
182
186
  </ul>
183
187
  </li>
184
188
  <li><a href="https://intlayer.org/doc/environment/create-react-app" rel=''>React CRA</a></li>
185
- <li><a href="https://intlayer.org/doc/environment/vite-and-react" rel=''>Vite + React</a>
186
- <ul>
187
- <li><a href="https://intlayer.org/doc/environment/vite-and-react/react-router-v7" rel=''>React-router-v7</a></li>
188
- <li><a href="https://intlayer.org/doc/environment/vite-and-react/tanstack-start" rel=''>Tanstack start</a></li>
189
- </ul>
190
- </li>
189
+ <li><a href="https://intlayer.org/doc/environment/vite-and-react" rel=''>Vite + React</a></li>
190
+ <li><a href="https://intlayer.org/doc/environment/vite-and-react" rel=''>Vite + React using Compiler</a></li>
191
+ <li><a href="https://intlayer.org/doc/environment/vite-and-react/compiler" rel=''>React-router-v7</a></li>
192
+ <li><a href="https://intlayer.org/doc/environment/vite-and-react/tanstack-start" rel=''>Tanstack start</a></li>
191
193
  <li><a href="https://intlayer.org/doc/environment/react-native-and-expo" rel=''>React Native</a></li>
192
- <li><a href="https://intlayer.org/doc/environment/lynx-and-react" rel=''>Lynx + React</a></li>
193
194
  <li><a href="https://intlayer.org/doc/environment/vite-and-svelte" rel=''>Vite + Svelte</a></li>
194
195
  <li><a href="https://intlayer.org/doc/environment/sveltekit" rel=''>SvelteKit</a></li>
195
196
  <li><a href="https://intlayer.org/doc/environment/vite-and-preact" rel=''>Vite + Preact</a></li>
@@ -197,8 +198,16 @@ Explore our comprehensive documentation to get started with Intlayer and learn h
197
198
  <li><a href="https://intlayer.org/doc/environment/vite-and-nuxt" rel=''>Vite + Nuxt</a></li>
198
199
  <li><a href="https://intlayer.org/doc/environment/vite-and-solid" rel=''>Vite + Solid</a></li>
199
200
  <li><a href="https://intlayer.org/doc/environment/angular" rel=''>Angular</a></li>
200
- <li><a href="https://intlayer.org/doc/environment/express" rel=''>Express</a></li>
201
- <li><a href="https://intlayer.org/doc/environment/nest" rel=''>NestJS</a></li>
201
+ <li>
202
+ <a href="https://intlayer.org/doc/environment/express" rel=''>Backend</a>
203
+ <ul>
204
+ <li><a href="https://intlayer.org/doc/environment/express" rel=''>Express</a></li>
205
+ <li><a href="https://intlayer.org/doc/environment/nest" rel=''>NestJS</a></li>
206
+ <li><a href="https://intlayer.org/doc/environment/fastify" rel=''>Fastify</a></li>
207
+ <li><a href="https://intlayer.org/doc/environment/adonisjs" rel=''>AdonisJS</a></li>
208
+ <li><a href="https://intlayer.org/doc/environment/hono" rel=''>Hono</a></li>
209
+ </ul>
210
+ </li>
202
211
  </ul>
203
212
  </details>
204
213
 
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`../_virtual/_rolldown/runtime.cjs`);let t=require(`@intlayer/config/client`),n=require(`node:path`),r=require(`@intlayer/chokidar/build`),i=require(`@intlayer/chokidar/utils`),a=require(`@intlayer/config/logger`),o=require(`@intlayer/config/node`),s=require(`@intlayer/config/utils`),c=require(`@intlayer/dictionaries-entry`),l=require(`@intlayer/webpack`),u=require(`defu`),d=require(`next/package.json`);d=e.__toESM(d);const f=(0,s.compareVersions)(d.default.version,`≥`,`13.0.0`),p=(0,s.compareVersions)(d.default.version,`≥`,`15.0.0`),m=(0,s.compareVersions)(d.default.version,`≥`,`16.0.0`),h=(0,s.compareVersions)(d.default.version,`≥`,`15.3.0`),g=m?!process.env.npm_lifecycle_script?.includes(`--webpack`):process.env.npm_lifecycle_script?.includes(`--turbo`),_=e=>{try{return(e.build?.require??(0,s.getProjectRequire)()).resolve(`@intlayer/swc`),!0}catch{return!1}},v=e=>{try{return(e.build?.require??(0,s.getProjectRequire)()).resolve(`@intlayer/babel`),!0}catch{return!1}},y=(e,t,r)=>{let i=(t.build?.require??(0,s.getProjectRequire)())?.resolve(e);return r?(0,s.normalizePath)(`./${(0,n.relative)(process.cwd(),i)}`):i},b=(e,r,o,s)=>{let{optimize:l}=e.build,u=e.build.importMode??e.dictionary?.importMode,{dictionariesDir:d,unmergedDictionariesDir:p,dynamicDictionariesDir:m,fetchDictionariesDir:h,mainDir:g}=e.system,{baseDir:b}=e.content,x=(0,a.getAppLogger)(e);if(l===!1||l===void 0&&!r||!f)return{};let S=_(e);if((0,i.runOnce)((0,n.join)(b,`.intlayer`,`cache`,`intlayer-prune-plugin-enabled.lock`),()=>{x(S?`Build optimization enabled`:[(0,a.colorize)(`Recommended: Install`,a.ANSIColors.GREY),(0,a.colorize)(`@intlayer/swc`,a.ANSIColors.GREY_LIGHT),(0,a.colorize)(`package to enable build optimization. See documentation: `,a.ANSIColors.GREY),(0,a.colorize)(`https://intlayer.org/docs/en/bundle_optimization`,a.ANSIColors.GREY_LIGHT)])},{cacheTimeoutMs:1e3*30}),(0,i.runOnce)((0,n.join)(b,`.intlayer`,`cache`,`intlayer-compiler-plugin-enabled.lock`),()=>{if(v(e)){let t=e.compiler?.enabled??!0;t===`build-only`&&(t=!s),x(t?`Intlayer compiler enabled`:`Intlayer compiler disabled`)}},{cacheTimeoutMs:1e3*30}),!S)return{};let C=(0,n.join)(g,`dictionaries.mjs`),w=(0,n.join)(g,`dynamic_dictionaries.mjs`),T=(0,n.join)(g,`unmerged_dictionaries.mjs`),E=(0,n.join)(g,`fetch_dictionaries.mjs`),D=[...(0,i.getComponentTransformPatternSync)(e),C,T],O=(0,c.getDictionaries)(e),k={};return Object.values(O).forEach(e=>{k[e.key]=e.importMode??u??t.DefaultValues.Dictionary.IMPORT_MODE}),{experimental:{swcPlugins:[[y(`@intlayer/swc`,e,o),{dictionariesDir:d,dictionariesEntryPath:C,unmergedDictionariesEntryPath:T,unmergedDictionariesDir:p,dynamicDictionariesDir:m,dynamicDictionariesEntryPath:w,fetchDictionariesDir:h,fetchDictionariesEntryPath:E,importMode:u,filesList:D,replaceDictionaryEntry:!0,dictionaryModeMap:k}]]}}},x=()=>{let e=process.env.npm_lifecycle_event,t=process.env.npm_lifecycle_script??``;return{isDevCommand:e===`dev`||process.argv.some(e=>e===`dev`)||/(^|\s)(next\s+)?dev(\s|$)/.test(t),isBuildCommand:e===`build`||process.argv.some(e=>e===`build`)||/(^|\s)(next\s+)?build(\s|$)/.test(t),isStartCommand:e===`start`||process.argv.some(e=>e===`start`)||/(^|\s)(next\s+)?start(\s|$)/.test(t)}},S=(e={},t)=>{typeof e!=`object`&&(e={});let r=(0,o.getConfiguration)(t),i=(0,a.getAppLogger)(r),c=t?.enableTurbopack??g;c&&e.webpack!==void 0&&i(`Turbopack is enabled but a custom webpack config is present. It will be ignored.`);let{isBuildCommand:d,isDevCommand:m}=x(),_={resolveAlias:(0,s.getAlias)({configuration:r,formatter:e=>`./${e}`}),rules:{"*.node":{as:`*.node`,loaders:[`node-loader`]}}},v=[`esbuild`,`module`,`fs`,`chokidar`,`fsevents`],y=()=>{let t={};return p&&(t={...t,serverExternalPackages:v}),f&&!p&&(t={...t,experimental:{...t?.experimental??{},serverComponentsExternalPackages:v}}),t=c?p&&h?{...t,turbopack:_}:{...t,experimental:{...t?.experimental??{},turbo:_}}:{...t,webpack:(t,i)=>{let{isServer:a,nextRuntime:o}=i;return typeof e.webpack==`function`&&(t=e.webpack(t,i)),t.externals===!1&&(t.externals=[]),t.externals.push({esbuild:`esbuild`,module:`module`,fs:`fs`,chokidar:`chokidar`,fsevents:`fsevents`}),t.module.rules.push({test:/\.node$/,loader:`node-loader`}),t.resolve.alias={...t.resolve.alias,...(0,s.getAlias)({configuration:r,formatter:e=>(0,n.resolve)(e)})},m&&a&&o===`nodejs`&&t.plugins.push(new l.IntlayerPlugin(r)),t}},t},S=b(r,d,c??!1,m);return(0,u.defu)((0,u.defu)(y(),S),e)},C=async(e={},t)=>{let{isBuildCommand:n,isDevCommand:i}=x();process.env.INTLAYER_IS_DEV_COMMAND=i?`true`:`false`;let a=(0,o.getConfiguration)(t),{mode:s}=a.build;return(i||n||s===`auto`)&&await(0,r.prepareIntlayer)(a,{clean:n,cacheTimeoutMs:n?1e3*30:1e3*60*60}),S(await e,t)};exports.withIntlayer=C,exports.withIntlayerSync=S;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`../_virtual/_rolldown/runtime.cjs`);let t=require(`@intlayer/config/client`),n=require(`node:path`),r=require(`@intlayer/chokidar/build`),i=require(`@intlayer/chokidar/utils`),a=require(`@intlayer/config/logger`),o=require(`@intlayer/config/node`),s=require(`@intlayer/config/utils`),c=require(`@intlayer/dictionaries-entry`),l=require(`@intlayer/webpack`),u=require(`defu`),d=require(`next/package.json`);d=e.__toESM(d);const f=(0,s.compareVersions)(d.default.version,`≥`,`13.0.0`),p=(0,s.compareVersions)(d.default.version,`≥`,`15.0.0`),m=(0,s.compareVersions)(d.default.version,`≥`,`16.0.0`),h=(0,s.compareVersions)(d.default.version,`≥`,`15.3.0`),g=m?!process.env.npm_lifecycle_script?.includes(`--webpack`):process.env.npm_lifecycle_script?.includes(`--turbo`),_=e=>{try{return(e.build?.require??(0,s.getProjectRequire)()).resolve(`@intlayer/swc`),!0}catch{return!1}},v=e=>{try{return(e.build?.require??(0,s.getProjectRequire)()).resolve(`@intlayer/babel`),!0}catch{return!1}},y=(e,t,r)=>{let i=(t.build?.require??(0,s.getProjectRequire)())?.resolve(e);return r?(0,s.normalizePath)(`./${(0,n.relative)(process.cwd(),i)}`):i},b=(e,r,o,s)=>{let{optimize:l}=e.build,u=e.build.importMode??e.dictionary?.importMode,{dictionariesDir:d,unmergedDictionariesDir:p,dynamicDictionariesDir:m,fetchDictionariesDir:h,mainDir:g}=e.system,{baseDir:b}=e.content,x=(0,a.getAppLogger)(e);if(l===!1||l===void 0&&!r||!f)return{};let S=_(e);if((0,i.runOnce)((0,n.join)(b,`.intlayer`,`cache`,`intlayer-prune-plugin-enabled.lock`),()=>{x(S?`Build optimization enabled`:[(0,a.colorize)(`Recommended: Install`,a.ANSIColors.GREY),(0,a.colorize)(`@intlayer/swc`,a.ANSIColors.GREY_LIGHT),(0,a.colorize)(`package to enable build optimization. See documentation: `,a.ANSIColors.GREY),(0,a.colorize)(`https://intlayer.org/docs/en/bundle_optimization`,a.ANSIColors.GREY_LIGHT)])},{cacheTimeoutMs:1e3*30}),(0,i.runOnce)((0,n.join)(b,`.intlayer`,`cache`,`intlayer-compiler-plugin-enabled.lock`),()=>{if(v(e)){let t=e.compiler?.enabled??!0;t===`build-only`&&(t=!s),x(t?`Intlayer compiler enabled`:`Intlayer compiler disabled`)}},{cacheTimeoutMs:1e3*30}),!S)return{};let C=(0,n.join)(g,`dictionaries.mjs`),w=(0,n.join)(g,`dynamic_dictionaries.mjs`),T=(0,n.join)(g,`unmerged_dictionaries.mjs`),E=(0,n.join)(g,`fetch_dictionaries.mjs`),D=[...(0,i.getComponentTransformPatternSync)(e),C,T],O=(0,c.getDictionaries)(e),k={};return Object.values(O).forEach(e=>{k[e.key]=e.importMode??u??t.DefaultValues.Dictionary.IMPORT_MODE}),{experimental:{swcPlugins:[[y(`@intlayer/swc`,e,o),{dictionariesDir:d,dictionariesEntryPath:C,unmergedDictionariesEntryPath:T,unmergedDictionariesDir:p,dynamicDictionariesDir:m,dynamicDictionariesEntryPath:w,fetchDictionariesDir:h,fetchDictionariesEntryPath:E,importMode:u,filesList:D,replaceDictionaryEntry:!0,dictionaryModeMap:k}]]}}},x=()=>{let e=process.env.npm_lifecycle_event,t=process.env.npm_lifecycle_script??``;return{isDevCommand:e===`dev`||process.argv.some(e=>e===`dev`)||/(^|\s)(next\s+)?dev(\s|$)/.test(t),isBuildCommand:e===`build`||process.argv.some(e=>e===`build`)||/(^|\s)(next\s+)?build(\s|$)/.test(t),isStartCommand:e===`start`||process.argv.some(e=>e===`start`)||/(^|\s)(next\s+)?start(\s|$)/.test(t)}},S=(e={},t)=>{typeof e!=`object`&&(e={});let r=(0,o.getConfiguration)(t),i=(0,a.getAppLogger)(r),c=t?.enableTurbopack??g;c&&e.webpack!==void 0&&i(`Turbopack is enabled but a custom webpack config is present. It will be ignored.`);let{isBuildCommand:d,isDevCommand:m}=x(),_={resolveAlias:(0,s.getAlias)({configuration:r,formatter:e=>`./${e}`}),rules:{"*.node":{as:`*.node`,loaders:[`node-loader`]}}},v=[`esbuild`,`module`,`fs`,`chokidar`,`fsevents`],y=()=>{let t={};return p&&(t={...t,serverExternalPackages:v}),f&&!p&&(t={...t,experimental:{...t?.experimental??{},serverComponentsExternalPackages:v}}),t=c?p&&h?{...t,turbopack:_}:{...t,experimental:{...t?.experimental??{},turbo:_}}:{...t,webpack:(t,i)=>{let{isServer:a,nextRuntime:o}=i;return typeof e.webpack==`function`&&(t=e.webpack(t,i)),t.externals===!1&&(t.externals=[]),t.externals.push({esbuild:`esbuild`,module:`module`,fs:`fs`,chokidar:`chokidar`,fsevents:`fsevents`}),t.module.rules.push({test:/\.node$/,loader:`node-loader`}),t.resolve.alias={...t.resolve.alias,...(0,s.getAlias)({configuration:r,formatter:e=>(0,n.resolve)(e)})},m&&a&&o===`nodejs`&&t.plugins.push(new l.IntlayerPlugin(r)),t}},t},S=b(r,d,c??!1,m);return(0,u.defu)((0,u.defu)(y(),S),e)},C=async(e={},t)=>{let{isBuildCommand:n,isDevCommand:i,isStartCommand:a}=x();process.env.INTLAYER_IS_DEV_COMMAND=i?`true`:`false`;let s=(0,o.getConfiguration)(t),{mode:c}=s.build;return!a&&(i||n||c===`auto`)&&await(0,r.prepareIntlayer)(s,{clean:n,cacheTimeoutMs:n?1e3*30:1e3*60*60}),S(await e,t)};exports.withIntlayer=C,exports.withIntlayerSync=S;
2
2
  //# sourceMappingURL=withIntlayer.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"withIntlayer.cjs","names":["nextPackageJSON","ANSIColors","DefaultValues","IntlayerPlugin"],"sources":["../../../src/server/withIntlayer.ts"],"sourcesContent":["import { join, relative, resolve } from 'node:path';\nimport { prepareIntlayer } from '@intlayer/chokidar/build';\nimport {\n getComponentTransformPatternSync,\n runOnce,\n} from '@intlayer/chokidar/utils';\nimport { DefaultValues } from '@intlayer/config/client';\nimport { ANSIColors, colorize, getAppLogger } from '@intlayer/config/logger';\nimport {\n type GetConfigurationOptions,\n getConfiguration,\n} from '@intlayer/config/node';\nimport {\n compareVersions,\n getAlias,\n getProjectRequire,\n normalizePath,\n} from '@intlayer/config/utils';\nimport { getDictionaries } from '@intlayer/dictionaries-entry';\nimport type { Dictionary, IntlayerConfig } from '@intlayer/types';\nimport { IntlayerPlugin } from '@intlayer/webpack';\nimport { defu } from 'defu';\nimport type { NextConfig } from 'next';\nimport type { NextJsWebpackConfig } from 'next/dist/server/config-shared';\nimport nextPackageJSON from 'next/package.json' with { type: 'json' };\n\nconst isGteNext13 = compareVersions(nextPackageJSON.version, '≥', '13.0.0');\nconst isGteNext15 = compareVersions(nextPackageJSON.version, '≥', '15.0.0');\nconst isGteNext16 = compareVersions(nextPackageJSON.version, '≥', '16.0.0');\nconst isTurbopackStable = compareVersions(\n nextPackageJSON.version,\n '≥',\n '15.3.0'\n);\n\nconst isTurbopackEnabledFromCommand = isGteNext16\n ? // Next@16 enable turbopack by default, and offer the possibility to disable it if --webpack flag is used\n !process.env.npm_lifecycle_script?.includes('--webpack')\n : // Next@15 use --turbopack flag, Next@14 use --turbo flag\n process.env.npm_lifecycle_script?.includes('--turbo');\n\n// Check if SWC plugin is available\nconst getIsSwcPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/swc');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\n// Check if Babel plugin is available\nconst getIsBabelExtractPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/babel');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\nconst resolvePluginPath = (\n pluginPath: string,\n intlayerConfig: IntlayerConfig,\n isTurbopackEnabled: boolean\n): string => {\n const requireFunction = intlayerConfig.build?.require ?? getProjectRequire();\n const pluginPathResolved = requireFunction?.resolve(pluginPath);\n\n if (isTurbopackEnabled)\n // Relative path for turbopack\n return normalizePath(`./${relative(process.cwd(), pluginPathResolved)}`);\n\n // Absolute path for webpack\n return pluginPathResolved;\n};\n\nconst getPruneConfig = (\n intlayerConfig: IntlayerConfig,\n isBuildCommand: boolean,\n isTurbopackEnabled: boolean,\n isDevCommand: boolean\n): Partial<NextConfig> => {\n const { optimize } = intlayerConfig.build;\n const importMode =\n intlayerConfig.build.importMode ?? intlayerConfig.dictionary?.importMode;\n const {\n dictionariesDir,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n fetchDictionariesDir,\n mainDir,\n } = intlayerConfig.system;\n const { baseDir } = intlayerConfig.content;\n const logger = getAppLogger(intlayerConfig);\n\n if (optimize === false) {\n return {};\n }\n if (optimize === undefined && !isBuildCommand) {\n return {};\n }\n\n if (!isGteNext13) return {};\n\n const isSwcPluginAvailable = getIsSwcPluginAvailable(intlayerConfig);\n\n runOnce(\n join(baseDir, '.intlayer', 'cache', 'intlayer-prune-plugin-enabled.lock'),\n () => {\n if (isSwcPluginAvailable) {\n logger('Build optimization enabled');\n } else {\n logger([\n colorize('Recommended: Install', ANSIColors.GREY),\n colorize('@intlayer/swc', ANSIColors.GREY_LIGHT),\n colorize(\n 'package to enable build optimization. See documentation: ',\n ANSIColors.GREY\n ),\n colorize(\n 'https://intlayer.org/docs/en/bundle_optimization',\n ANSIColors.GREY_LIGHT\n ),\n ]);\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n runOnce(\n join(\n baseDir,\n '.intlayer',\n 'cache',\n 'intlayer-compiler-plugin-enabled.lock'\n ),\n () => {\n const isBabelExtractPluginAvailable =\n getIsBabelExtractPluginAvailable(intlayerConfig);\n\n if (isBabelExtractPluginAvailable) {\n let isEnabled = intlayerConfig.compiler?.enabled ?? true;\n\n if (isEnabled === 'build-only') {\n isEnabled = !isDevCommand;\n }\n\n if (isEnabled) {\n logger('Intlayer compiler enabled');\n } else {\n logger('Intlayer compiler disabled');\n }\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n if (!isSwcPluginAvailable) {\n return {};\n }\n\n const dictionariesEntryPath = join(mainDir, 'dictionaries.mjs');\n\n const dynamicDictionariesEntryPath = join(\n mainDir,\n 'dynamic_dictionaries.mjs'\n );\n\n const unmergedDictionariesEntryPath = join(\n mainDir,\n 'unmerged_dictionaries.mjs'\n );\n\n const fetchDictionariesEntryPath = join(mainDir, 'fetch_dictionaries.mjs');\n\n const filesListPattern = getComponentTransformPatternSync(intlayerConfig);\n\n const filesList = [\n ...filesListPattern,\n dictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n unmergedDictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n ];\n\n const dictionaries = getDictionaries(intlayerConfig);\n\n const dictionaryModeMap: Record<string, 'static' | 'dynamic' | 'fetch'> = {};\n\n (Object.values(dictionaries) as Dictionary[]).forEach((dictionary) => {\n dictionaryModeMap[dictionary.key] =\n dictionary.importMode ??\n importMode ??\n DefaultValues.Dictionary.IMPORT_MODE;\n });\n\n return {\n experimental: {\n swcPlugins: [\n [\n resolvePluginPath(\n '@intlayer/swc',\n intlayerConfig,\n isTurbopackEnabled\n ),\n {\n dictionariesDir,\n dictionariesEntryPath,\n unmergedDictionariesEntryPath,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n dynamicDictionariesEntryPath,\n fetchDictionariesDir,\n fetchDictionariesEntryPath,\n importMode,\n filesList,\n replaceDictionaryEntry: true,\n dictionaryModeMap,\n },\n ],\n ],\n },\n };\n};\n\nconst getCommandsEvent = () => {\n const lifecycleEvent = process.env.npm_lifecycle_event;\n const lifecycleScript = process.env.npm_lifecycle_script ?? '';\n\n const isDevCommand =\n lifecycleEvent === 'dev' ||\n process.argv.some((arg) => arg === 'dev') ||\n /(^|\\s)(next\\s+)?dev(\\s|$)/.test(lifecycleScript);\n\n const isBuildCommand =\n lifecycleEvent === 'build' ||\n process.argv.some((arg) => arg === 'build') ||\n /(^|\\s)(next\\s+)?build(\\s|$)/.test(lifecycleScript);\n\n const isStartCommand =\n lifecycleEvent === 'start' ||\n process.argv.some((arg) => arg === 'start') ||\n /(^|\\s)(next\\s+)?start(\\s|$)/.test(lifecycleScript);\n\n return {\n isDevCommand,\n isBuildCommand,\n isStartCommand,\n };\n};\n\ntype WebpackParams = Parameters<NextJsWebpackConfig>;\n\ntype WithIntlayerOptions = GetConfigurationOptions & {\n enableTurbopack?: boolean;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayerSync(nextConfig)\n * ```\n */\nexport const withIntlayerSync = <T extends Partial<NextConfig>>(\n nextConfig: T = {} as T,\n configOptions?: WithIntlayerOptions\n): NextConfig & T => {\n if (typeof nextConfig !== 'object') {\n nextConfig = {} as T;\n }\n\n const intlayerConfig = getConfiguration(configOptions);\n const logger = getAppLogger(intlayerConfig);\n\n const isTurbopackEnabled =\n configOptions?.enableTurbopack ?? isTurbopackEnabledFromCommand;\n\n if (isTurbopackEnabled && typeof nextConfig.webpack !== 'undefined') {\n logger(\n 'Turbopack is enabled but a custom webpack config is present. It will be ignored.'\n );\n }\n\n const { isBuildCommand, isDevCommand } = getCommandsEvent();\n\n // Only provide turbo-specific config if user explicitly sets it\n const turboConfig = {\n resolveAlias: getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => `./${value}`, // prefix by './' to consider the path as relative to the project root. This is necessary for turbopack to work correctly.\n }),\n\n rules: {\n '*.node': {\n as: '*.node',\n loaders: ['node-loader'],\n },\n },\n };\n\n const serverExternalPackages = [\n 'esbuild',\n 'module',\n 'fs',\n 'chokidar',\n 'fsevents',\n ];\n\n const getNewConfig = (): Partial<NextConfig> => {\n let config: Partial<NextConfig> = {};\n\n if (isGteNext15) {\n config = {\n ...config,\n serverExternalPackages,\n };\n }\n\n if (isGteNext13 && !isGteNext15) {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n serverComponentsExternalPackages: serverExternalPackages,\n },\n };\n }\n\n if (isTurbopackEnabled) {\n if (isGteNext15 && isTurbopackStable) {\n config = {\n ...config,\n turbopack: turboConfig,\n };\n } else {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n // @ts-ignore exist in next@14\n turbo: turboConfig,\n },\n };\n }\n } else {\n config = {\n ...config,\n webpack: (config: WebpackParams['0'], options: WebpackParams[1]) => {\n // Only add Intlayer plugin on server side (node runtime)\n const { isServer, nextRuntime } = options;\n\n // If the user has defined their own webpack config, call it\n if (typeof nextConfig.webpack === 'function') {\n config = nextConfig.webpack(config, options);\n }\n\n // Rspack set external as false by default\n // Overwrite it to allow pushing the desired externals\n if (config.externals === false) {\n config.externals = [];\n }\n\n // Mark these modules as externals\n config.externals.push({\n esbuild: 'esbuild',\n module: 'module',\n fs: 'fs',\n chokidar: 'chokidar',\n fsevents: 'fsevents',\n });\n\n // Use `node-loader` for any `.node` files\n config.module.rules.push({\n test: /\\.node$/,\n loader: 'node-loader',\n });\n\n // Always alias on the server (node/edge) for stability.\n // On the client, alias only when not using live sync.\n config.resolve.alias = {\n ...config.resolve.alias,\n ...getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => resolve(value), // get absolute path\n }),\n };\n\n // Activate watch mode webpack plugin\n if (isDevCommand && isServer && nextRuntime === 'nodejs') {\n // Optional as rspack not support plugin yet\n config.plugins.push(new IntlayerPlugin(intlayerConfig));\n }\n\n return config;\n },\n };\n }\n\n return config;\n };\n\n const pruneConfig: Partial<NextConfig> = getPruneConfig(\n intlayerConfig,\n isBuildCommand,\n isTurbopackEnabled ?? false,\n isDevCommand\n );\n\n const intlayerNextConfig: Partial<NextConfig> = defu(\n getNewConfig(),\n pruneConfig\n );\n\n // Merge the new config with the user's config\n const result = defu(intlayerNextConfig, nextConfig) as NextConfig & T;\n\n return result;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayer(nextConfig)\n * ```\n *\n * > Node withIntlayer is a promise function. Use withIntlayerSync instead if you want to use it synchronously.\n * > Using the promise allows to prepare the intlayer dictionaries before the build starts.\n *\n */\nexport const withIntlayer = async <T extends Partial<NextConfig>>(\n nextConfig: T | Promise<T> = {} as T,\n configOptions?: WithIntlayerOptions\n): Promise<NextConfig & T> => {\n const { isBuildCommand, isDevCommand } = getCommandsEvent();\n\n process.env.INTLAYER_IS_DEV_COMMAND = isDevCommand ? 'true' : 'false';\n\n const intlayerConfig = getConfiguration(configOptions);\n\n const { mode } = intlayerConfig.build;\n\n // Only call prepareIntlayer during `dev` or `build` (not during `start`)\n // If prod: clean and rebuild once\n // If dev: rebuild only once if it's more than 1 hour since last rebuild\n if (isDevCommand || isBuildCommand || mode === 'auto') {\n // prepareIntlayer use runOnce to ensure to run only once because will run twice on client and server side otherwise\n await prepareIntlayer(intlayerConfig, {\n clean: isBuildCommand,\n cacheTimeoutMs: isBuildCommand\n ? 1000 * 30 // 30 seconds for build (to ensure to rebuild all dictionaries)\n : 1000 * 60 * 60, // 1 hour for dev (default cache timeout)\n });\n }\n\n const nextConfigResolved = await nextConfig;\n\n return withIntlayerSync(nextConfigResolved, configOptions);\n};\n"],"mappings":"yfA0BA,MAAM,GAAA,EAAA,EAAA,iBAA8BA,EAAAA,QAAgB,QAAS,IAAK,SAAS,CACrE,GAAA,EAAA,EAAA,iBAA8BA,EAAAA,QAAgB,QAAS,IAAK,SAAS,CACrE,GAAA,EAAA,EAAA,iBAA8BA,EAAAA,QAAgB,QAAS,IAAK,SAAS,CACrE,GAAA,EAAA,EAAA,iBACJA,EAAAA,QAAgB,QAChB,IACA,SACD,CAEK,EAAgC,EAElC,CAAC,QAAQ,IAAI,sBAAsB,SAAS,YAAY,CAExD,QAAQ,IAAI,sBAAsB,SAAS,UAAU,CAGnD,EAA2B,GAAmC,CAClE,GAAI,CAIF,OAFE,EAAe,OAAO,UAAA,EAAA,EAAA,oBAA8B,EACtC,QAAQ,gBAAgB,CACjC,QACI,CACX,MAAO,KAKL,EAAoC,GAAmC,CAC3E,GAAI,CAIF,OAFE,EAAe,OAAO,UAAA,EAAA,EAAA,oBAA8B,EACtC,QAAQ,kBAAkB,CACnC,QACI,CACX,MAAO,KAIL,GACJ,EACA,EACA,IACW,CAEX,IAAM,GADkB,EAAe,OAAO,UAAA,EAAA,EAAA,oBAA8B,GAChC,QAAQ,EAAW,CAO/D,OALI,GAEF,EAAA,EAAA,eAAqB,MAAA,EAAA,EAAA,UAAc,QAAQ,KAAK,CAAE,EAAmB,GAAG,CAGnE,GAGH,GACJ,EACA,EACA,EACA,IACwB,CACxB,GAAM,CAAE,YAAa,EAAe,MAC9B,EACJ,EAAe,MAAM,YAAc,EAAe,YAAY,WAC1D,CACJ,kBACA,0BACA,yBACA,uBACA,WACE,EAAe,OACb,CAAE,WAAY,EAAe,QAC7B,GAAA,EAAA,EAAA,cAAsB,EAAe,CAS3C,GAPI,IAAa,IAGb,IAAa,IAAA,IAAa,CAAC,GAI3B,CAAC,EAAa,MAAO,EAAE,CAE3B,IAAM,EAAuB,EAAwB,EAAe,CAyDpE,IAvDA,EAAA,EAAA,UAAA,EAAA,EAAA,MACO,EAAS,YAAa,QAAS,qCAAqC,KACnE,CAEF,EADE,EACK,6BAEA,gBACI,uBAAwBC,EAAAA,WAAW,KAAK,gBACxC,gBAAiBA,EAAAA,WAAW,WAAW,gBAE9C,4DACAA,EAAAA,WAAW,KACZ,gBAEC,mDACAA,EAAAA,WAAW,WACZ,CACF,CAAC,EAGN,CACE,eAAgB,IAAO,GACxB,CACF,EAED,EAAA,EAAA,UAAA,EAAA,EAAA,MAEI,EACA,YACA,QACA,wCACD,KACK,CAIJ,GAFE,EAAiC,EAAe,CAEf,CACjC,IAAI,EAAY,EAAe,UAAU,SAAW,GAEhD,IAAc,eAChB,EAAY,CAAC,GAIb,EADE,EACK,4BAEA,6BAA6B,GAI1C,CACE,eAAgB,IAAO,GACxB,CACF,CAEG,CAAC,EACH,MAAO,EAAE,CAGX,IAAM,GAAA,EAAA,EAAA,MAA6B,EAAS,mBAAmB,CAEzD,GAAA,EAAA,EAAA,MACJ,EACA,2BACD,CAEK,GAAA,EAAA,EAAA,MACJ,EACA,4BACD,CAEK,GAAA,EAAA,EAAA,MAAkC,EAAS,yBAAyB,CAIpE,EAAY,CAChB,IAAA,EAAA,EAAA,kCAHwD,EAAe,CAIvE,EACA,EACD,CAEK,GAAA,EAAA,EAAA,iBAA+B,EAAe,CAE9C,EAAoE,EAAE,CAS5E,OAPC,OAAO,OAAO,EAAa,CAAkB,QAAS,GAAe,CACpE,EAAkB,EAAW,KAC3B,EAAW,YACX,GACAC,EAAAA,cAAc,WAAW,aAC3B,CAEK,CACL,aAAc,CACZ,WAAY,CACV,CACE,EACE,gBACA,EACA,EACD,CACD,CACE,kBACA,wBACA,gCACA,0BACA,yBACA,+BACA,uBACA,6BACA,aACA,YACA,uBAAwB,GACxB,oBACD,CACF,CACF,CACF,CACF,EAGG,MAAyB,CAC7B,IAAM,EAAiB,QAAQ,IAAI,oBAC7B,EAAkB,QAAQ,IAAI,sBAAwB,GAiB5D,MAAO,CACL,aAfA,IAAmB,OACnB,QAAQ,KAAK,KAAM,GAAQ,IAAQ,MAAM,EACzC,4BAA4B,KAAK,EAAgB,CAcjD,eAXA,IAAmB,SACnB,QAAQ,KAAK,KAAM,GAAQ,IAAQ,QAAQ,EAC3C,8BAA8B,KAAK,EAAgB,CAUnD,eAPA,IAAmB,SACnB,QAAQ,KAAK,KAAM,GAAQ,IAAQ,QAAQ,EAC3C,8BAA8B,KAAK,EAAgB,CAMpD,EAoBU,GACX,EAAgB,EAAE,CAClB,IACmB,CACf,OAAO,GAAe,WACxB,EAAa,EAAE,EAGjB,IAAM,GAAA,EAAA,EAAA,kBAAkC,EAAc,CAChD,GAAA,EAAA,EAAA,cAAsB,EAAe,CAErC,EACJ,GAAe,iBAAmB,EAEhC,GAA6B,EAAW,UAAY,QACtD,EACE,mFACD,CAGH,GAAM,CAAE,iBAAgB,gBAAiB,GAAkB,CAGrD,EAAc,CAClB,cAAA,EAAA,EAAA,UAAuB,CACrB,cAAe,EACf,UAAY,GAAkB,KAAK,IACpC,CAAC,CAEF,MAAO,CACL,SAAU,CACR,GAAI,SACJ,QAAS,CAAC,cAAc,CACzB,CACF,CACF,CAEK,EAAyB,CAC7B,UACA,SACA,KACA,WACA,WACD,CAEK,MAA0C,CAC9C,IAAI,EAA8B,EAAE,CAyFpC,OAvFI,IACF,EAAS,CACP,GAAG,EACH,yBACD,EAGC,GAAe,CAAC,IAClB,EAAS,CACP,GAAG,EACH,aAAc,CACZ,GAAI,GAAQ,cAAgB,EAAE,CAC9B,iCAAkC,EACnC,CACF,EAGH,AAiBE,EAjBE,EACE,GAAe,EACR,CACP,GAAG,EACH,UAAW,EACZ,CAEQ,CACP,GAAG,EACH,aAAc,CACZ,GAAI,GAAQ,cAAgB,EAAE,CAE9B,MAAO,EACR,CACF,CAGM,CACP,GAAG,EACH,SAAU,EAA4B,IAA8B,CAElE,GAAM,CAAE,WAAU,eAAgB,EA4ClC,OAzCI,OAAO,EAAW,SAAY,aAChC,EAAS,EAAW,QAAQ,EAAQ,EAAQ,EAK1C,EAAO,YAAc,KACvB,EAAO,UAAY,EAAE,EAIvB,EAAO,UAAU,KAAK,CACpB,QAAS,UACT,OAAQ,SACR,GAAI,KACJ,SAAU,WACV,SAAU,WACX,CAAC,CAGF,EAAO,OAAO,MAAM,KAAK,CACvB,KAAM,UACN,OAAQ,cACT,CAAC,CAIF,EAAO,QAAQ,MAAQ,CACrB,GAAG,EAAO,QAAQ,MAClB,IAAA,EAAA,EAAA,UAAY,CACV,cAAe,EACf,UAAY,IAAA,EAAA,EAAA,SAA0B,EAAM,CAC7C,CAAC,CACH,CAGG,GAAgB,GAAY,IAAgB,UAE9C,EAAO,QAAQ,KAAK,IAAIC,EAAAA,eAAe,EAAe,CAAC,CAGlD,GAEV,CAGI,GAGH,EAAmC,EACvC,EACA,EACA,GAAsB,GACtB,EACD,CAUD,OAAA,EAAA,EAAA,OAAA,EAAA,EAAA,MAPE,GAAc,CACd,EACD,CAGuC,EAAW,EAoBxC,EAAe,MAC1B,EAA6B,EAAE,CAC/B,IAC4B,CAC5B,GAAM,CAAE,iBAAgB,gBAAiB,GAAkB,CAE3D,QAAQ,IAAI,wBAA0B,EAAe,OAAS,QAE9D,IAAM,GAAA,EAAA,EAAA,kBAAkC,EAAc,CAEhD,CAAE,QAAS,EAAe,MAiBhC,OAZI,GAAgB,GAAkB,IAAS,SAE7C,MAAA,EAAA,EAAA,iBAAsB,EAAgB,CACpC,MAAO,EACP,eAAgB,EACZ,IAAO,GACP,IAAO,GAAK,GACjB,CAAC,CAKG,EAFoB,MAAM,EAEW,EAAc"}
1
+ {"version":3,"file":"withIntlayer.cjs","names":["nextPackageJSON","ANSIColors","DefaultValues","IntlayerPlugin"],"sources":["../../../src/server/withIntlayer.ts"],"sourcesContent":["import { join, relative, resolve } from 'node:path';\nimport { prepareIntlayer } from '@intlayer/chokidar/build';\nimport {\n getComponentTransformPatternSync,\n runOnce,\n} from '@intlayer/chokidar/utils';\nimport { DefaultValues } from '@intlayer/config/client';\nimport { ANSIColors, colorize, getAppLogger } from '@intlayer/config/logger';\nimport {\n type GetConfigurationOptions,\n getConfiguration,\n} from '@intlayer/config/node';\nimport {\n compareVersions,\n getAlias,\n getProjectRequire,\n normalizePath,\n} from '@intlayer/config/utils';\nimport { getDictionaries } from '@intlayer/dictionaries-entry';\nimport type { Dictionary, IntlayerConfig } from '@intlayer/types';\nimport { IntlayerPlugin } from '@intlayer/webpack';\nimport { defu } from 'defu';\nimport type { NextConfig } from 'next';\nimport type { NextJsWebpackConfig } from 'next/dist/server/config-shared';\nimport nextPackageJSON from 'next/package.json' with { type: 'json' };\n\nconst isGteNext13 = compareVersions(nextPackageJSON.version, '≥', '13.0.0');\nconst isGteNext15 = compareVersions(nextPackageJSON.version, '≥', '15.0.0');\nconst isGteNext16 = compareVersions(nextPackageJSON.version, '≥', '16.0.0');\nconst isTurbopackStable = compareVersions(\n nextPackageJSON.version,\n '≥',\n '15.3.0'\n);\n\nconst isTurbopackEnabledFromCommand = isGteNext16\n ? // Next@16 enable turbopack by default, and offer the possibility to disable it if --webpack flag is used\n !process.env.npm_lifecycle_script?.includes('--webpack')\n : // Next@15 use --turbopack flag, Next@14 use --turbo flag\n process.env.npm_lifecycle_script?.includes('--turbo');\n\n// Check if SWC plugin is available\nconst getIsSwcPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/swc');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\n// Check if Babel plugin is available\nconst getIsBabelExtractPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/babel');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\nconst resolvePluginPath = (\n pluginPath: string,\n intlayerConfig: IntlayerConfig,\n isTurbopackEnabled: boolean\n): string => {\n const requireFunction = intlayerConfig.build?.require ?? getProjectRequire();\n const pluginPathResolved = requireFunction?.resolve(pluginPath);\n\n if (isTurbopackEnabled)\n // Relative path for turbopack\n return normalizePath(`./${relative(process.cwd(), pluginPathResolved)}`);\n\n // Absolute path for webpack\n return pluginPathResolved;\n};\n\nconst getPruneConfig = (\n intlayerConfig: IntlayerConfig,\n isBuildCommand: boolean,\n isTurbopackEnabled: boolean,\n isDevCommand: boolean\n): Partial<NextConfig> => {\n const { optimize } = intlayerConfig.build;\n const importMode =\n intlayerConfig.build.importMode ?? intlayerConfig.dictionary?.importMode;\n const {\n dictionariesDir,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n fetchDictionariesDir,\n mainDir,\n } = intlayerConfig.system;\n const { baseDir } = intlayerConfig.content;\n const logger = getAppLogger(intlayerConfig);\n\n if (optimize === false) {\n return {};\n }\n if (optimize === undefined && !isBuildCommand) {\n return {};\n }\n\n if (!isGteNext13) return {};\n\n const isSwcPluginAvailable = getIsSwcPluginAvailable(intlayerConfig);\n\n runOnce(\n join(baseDir, '.intlayer', 'cache', 'intlayer-prune-plugin-enabled.lock'),\n () => {\n if (isSwcPluginAvailable) {\n logger('Build optimization enabled');\n } else {\n logger([\n colorize('Recommended: Install', ANSIColors.GREY),\n colorize('@intlayer/swc', ANSIColors.GREY_LIGHT),\n colorize(\n 'package to enable build optimization. See documentation: ',\n ANSIColors.GREY\n ),\n colorize(\n 'https://intlayer.org/docs/en/bundle_optimization',\n ANSIColors.GREY_LIGHT\n ),\n ]);\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n runOnce(\n join(\n baseDir,\n '.intlayer',\n 'cache',\n 'intlayer-compiler-plugin-enabled.lock'\n ),\n () => {\n const isBabelExtractPluginAvailable =\n getIsBabelExtractPluginAvailable(intlayerConfig);\n\n if (isBabelExtractPluginAvailable) {\n let isEnabled = intlayerConfig.compiler?.enabled ?? true;\n\n if (isEnabled === 'build-only') {\n isEnabled = !isDevCommand;\n }\n\n if (isEnabled) {\n logger('Intlayer compiler enabled');\n } else {\n logger('Intlayer compiler disabled');\n }\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n if (!isSwcPluginAvailable) {\n return {};\n }\n\n const dictionariesEntryPath = join(mainDir, 'dictionaries.mjs');\n\n const dynamicDictionariesEntryPath = join(\n mainDir,\n 'dynamic_dictionaries.mjs'\n );\n\n const unmergedDictionariesEntryPath = join(\n mainDir,\n 'unmerged_dictionaries.mjs'\n );\n\n const fetchDictionariesEntryPath = join(mainDir, 'fetch_dictionaries.mjs');\n\n const filesListPattern = getComponentTransformPatternSync(intlayerConfig);\n\n const filesList = [\n ...filesListPattern,\n dictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n unmergedDictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n ];\n\n const dictionaries = getDictionaries(intlayerConfig);\n\n const dictionaryModeMap: Record<string, 'static' | 'dynamic' | 'fetch'> = {};\n\n (Object.values(dictionaries) as Dictionary[]).forEach((dictionary) => {\n dictionaryModeMap[dictionary.key] =\n dictionary.importMode ??\n importMode ??\n DefaultValues.Dictionary.IMPORT_MODE;\n });\n\n return {\n experimental: {\n swcPlugins: [\n [\n resolvePluginPath(\n '@intlayer/swc',\n intlayerConfig,\n isTurbopackEnabled\n ),\n {\n dictionariesDir,\n dictionariesEntryPath,\n unmergedDictionariesEntryPath,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n dynamicDictionariesEntryPath,\n fetchDictionariesDir,\n fetchDictionariesEntryPath,\n importMode,\n filesList,\n replaceDictionaryEntry: true,\n dictionaryModeMap,\n },\n ],\n ],\n },\n };\n};\n\nconst getCommandsEvent = () => {\n const lifecycleEvent = process.env.npm_lifecycle_event;\n const lifecycleScript = process.env.npm_lifecycle_script ?? '';\n\n const isDevCommand =\n lifecycleEvent === 'dev' ||\n process.argv.some((arg) => arg === 'dev') ||\n /(^|\\s)(next\\s+)?dev(\\s|$)/.test(lifecycleScript);\n\n const isBuildCommand =\n lifecycleEvent === 'build' ||\n process.argv.some((arg) => arg === 'build') ||\n /(^|\\s)(next\\s+)?build(\\s|$)/.test(lifecycleScript);\n\n const isStartCommand =\n lifecycleEvent === 'start' ||\n process.argv.some((arg) => arg === 'start') ||\n /(^|\\s)(next\\s+)?start(\\s|$)/.test(lifecycleScript);\n\n return {\n isDevCommand,\n isBuildCommand,\n isStartCommand,\n };\n};\n\ntype WebpackParams = Parameters<NextJsWebpackConfig>;\n\ntype WithIntlayerOptions = GetConfigurationOptions & {\n enableTurbopack?: boolean;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayerSync(nextConfig)\n * ```\n */\nexport const withIntlayerSync = <T extends Partial<NextConfig>>(\n nextConfig: T = {} as T,\n configOptions?: WithIntlayerOptions\n): NextConfig & T => {\n if (typeof nextConfig !== 'object') {\n nextConfig = {} as T;\n }\n\n const intlayerConfig = getConfiguration(configOptions);\n const logger = getAppLogger(intlayerConfig);\n\n const isTurbopackEnabled =\n configOptions?.enableTurbopack ?? isTurbopackEnabledFromCommand;\n\n if (isTurbopackEnabled && typeof nextConfig.webpack !== 'undefined') {\n logger(\n 'Turbopack is enabled but a custom webpack config is present. It will be ignored.'\n );\n }\n\n const { isBuildCommand, isDevCommand } = getCommandsEvent();\n\n // Only provide turbo-specific config if user explicitly sets it\n const turboConfig = {\n resolveAlias: getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => `./${value}`, // prefix by './' to consider the path as relative to the project root. This is necessary for turbopack to work correctly.\n }),\n\n rules: {\n '*.node': {\n as: '*.node',\n loaders: ['node-loader'],\n },\n },\n };\n\n const serverExternalPackages = [\n 'esbuild',\n 'module',\n 'fs',\n 'chokidar',\n 'fsevents',\n ];\n\n const getNewConfig = (): Partial<NextConfig> => {\n let config: Partial<NextConfig> = {};\n\n if (isGteNext15) {\n config = {\n ...config,\n serverExternalPackages,\n };\n }\n\n if (isGteNext13 && !isGteNext15) {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n serverComponentsExternalPackages: serverExternalPackages,\n },\n };\n }\n\n if (isTurbopackEnabled) {\n if (isGteNext15 && isTurbopackStable) {\n config = {\n ...config,\n turbopack: turboConfig,\n };\n } else {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n // @ts-ignore exist in next@14\n turbo: turboConfig,\n },\n };\n }\n } else {\n config = {\n ...config,\n webpack: (config: WebpackParams['0'], options: WebpackParams[1]) => {\n // Only add Intlayer plugin on server side (node runtime)\n const { isServer, nextRuntime } = options;\n\n // If the user has defined their own webpack config, call it\n if (typeof nextConfig.webpack === 'function') {\n config = nextConfig.webpack(config, options);\n }\n\n // Rspack set external as false by default\n // Overwrite it to allow pushing the desired externals\n if (config.externals === false) {\n config.externals = [];\n }\n\n // Mark these modules as externals\n config.externals.push({\n esbuild: 'esbuild',\n module: 'module',\n fs: 'fs',\n chokidar: 'chokidar',\n fsevents: 'fsevents',\n });\n\n // Use `node-loader` for any `.node` files\n config.module.rules.push({\n test: /\\.node$/,\n loader: 'node-loader',\n });\n\n // Always alias on the server (node/edge) for stability.\n // On the client, alias only when not using live sync.\n config.resolve.alias = {\n ...config.resolve.alias,\n ...getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => resolve(value), // get absolute path\n }),\n };\n\n // Activate watch mode webpack plugin\n if (isDevCommand && isServer && nextRuntime === 'nodejs') {\n // Optional as rspack not support plugin yet\n config.plugins.push(new IntlayerPlugin(intlayerConfig));\n }\n\n return config;\n },\n };\n }\n\n return config;\n };\n\n const pruneConfig: Partial<NextConfig> = getPruneConfig(\n intlayerConfig,\n isBuildCommand,\n isTurbopackEnabled ?? false,\n isDevCommand\n );\n\n const intlayerNextConfig: Partial<NextConfig> = defu(\n getNewConfig(),\n pruneConfig\n );\n\n // Merge the new config with the user's config\n const result = defu(intlayerNextConfig, nextConfig) as NextConfig & T;\n\n return result;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayer(nextConfig)\n * ```\n *\n * > Node withIntlayer is a promise function. Use withIntlayerSync instead if you want to use it synchronously.\n * > Using the promise allows to prepare the intlayer dictionaries before the build starts.\n *\n */\nexport const withIntlayer = async <T extends Partial<NextConfig>>(\n nextConfig: T | Promise<T> = {} as T,\n configOptions?: WithIntlayerOptions\n): Promise<NextConfig & T> => {\n const { isBuildCommand, isDevCommand, isStartCommand } = getCommandsEvent();\n\n process.env.INTLAYER_IS_DEV_COMMAND = isDevCommand ? 'true' : 'false';\n\n const intlayerConfig = getConfiguration(configOptions);\n\n const { mode } = intlayerConfig.build;\n\n // Only call prepareIntlayer during `dev` or `build` (not during `start`)\n // If prod: clean and rebuild once\n // If dev: rebuild only once if it's more than 1 hour since last rebuild\n if (!isStartCommand && (isDevCommand || isBuildCommand || mode === 'auto')) {\n // prepareIntlayer use runOnce to ensure to run only once because will run twice on client and server side otherwise\n await prepareIntlayer(intlayerConfig, {\n clean: isBuildCommand,\n cacheTimeoutMs: isBuildCommand\n ? 1000 * 30 // 30 seconds for build (to ensure to rebuild all dictionaries)\n : 1000 * 60 * 60, // 1 hour for dev (default cache timeout)\n });\n }\n\n const nextConfigResolved = await nextConfig;\n\n return withIntlayerSync(nextConfigResolved, configOptions);\n};\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{DefaultValues as e}from"@intlayer/config/client";import{join as t,relative as n,resolve as r}from"node:path";import{prepareIntlayer as i}from"@intlayer/chokidar/build";import{getComponentTransformPatternSync as a,runOnce as o}from"@intlayer/chokidar/utils";import{ANSIColors as s,colorize as c,getAppLogger as l}from"@intlayer/config/logger";import{getConfiguration as u}from"@intlayer/config/node";import{compareVersions as d,getAlias as f,getProjectRequire as p,normalizePath as m}from"@intlayer/config/utils";import{getDictionaries as h}from"@intlayer/dictionaries-entry";import{IntlayerPlugin as g}from"@intlayer/webpack";import{defu as _}from"defu";import v from"next/package.json"with{type:"json"};const y=d(v.version,`≥`,`13.0.0`),b=d(v.version,`≥`,`15.0.0`),x=d(v.version,`≥`,`16.0.0`),S=d(v.version,`≥`,`15.3.0`),C=x?!process.env.npm_lifecycle_script?.includes(`--webpack`):process.env.npm_lifecycle_script?.includes(`--turbo`),w=e=>{try{return(e.build?.require??p()).resolve(`@intlayer/swc`),!0}catch{return!1}},T=e=>{try{return(e.build?.require??p()).resolve(`@intlayer/babel`),!0}catch{return!1}},E=(e,t,r)=>{let i=(t.build?.require??p())?.resolve(e);return r?m(`./${n(process.cwd(),i)}`):i},D=(n,r,i,u)=>{let{optimize:d}=n.build,f=n.build.importMode??n.dictionary?.importMode,{dictionariesDir:p,unmergedDictionariesDir:m,dynamicDictionariesDir:g,fetchDictionariesDir:_,mainDir:v}=n.system,{baseDir:b}=n.content,x=l(n);if(d===!1||d===void 0&&!r||!y)return{};let S=w(n);if(o(t(b,`.intlayer`,`cache`,`intlayer-prune-plugin-enabled.lock`),()=>{x(S?`Build optimization enabled`:[c(`Recommended: Install`,s.GREY),c(`@intlayer/swc`,s.GREY_LIGHT),c(`package to enable build optimization. See documentation: `,s.GREY),c(`https://intlayer.org/docs/en/bundle_optimization`,s.GREY_LIGHT)])},{cacheTimeoutMs:1e3*30}),o(t(b,`.intlayer`,`cache`,`intlayer-compiler-plugin-enabled.lock`),()=>{if(T(n)){let e=n.compiler?.enabled??!0;e===`build-only`&&(e=!u),x(e?`Intlayer compiler enabled`:`Intlayer compiler disabled`)}},{cacheTimeoutMs:1e3*30}),!S)return{};let C=t(v,`dictionaries.mjs`),D=t(v,`dynamic_dictionaries.mjs`),O=t(v,`unmerged_dictionaries.mjs`),k=t(v,`fetch_dictionaries.mjs`),A=[...a(n),C,O],j=h(n),M={};return Object.values(j).forEach(t=>{M[t.key]=t.importMode??f??e.Dictionary.IMPORT_MODE}),{experimental:{swcPlugins:[[E(`@intlayer/swc`,n,i),{dictionariesDir:p,dictionariesEntryPath:C,unmergedDictionariesEntryPath:O,unmergedDictionariesDir:m,dynamicDictionariesDir:g,dynamicDictionariesEntryPath:D,fetchDictionariesDir:_,fetchDictionariesEntryPath:k,importMode:f,filesList:A,replaceDictionaryEntry:!0,dictionaryModeMap:M}]]}}},O=()=>{let e=process.env.npm_lifecycle_event,t=process.env.npm_lifecycle_script??``;return{isDevCommand:e===`dev`||process.argv.some(e=>e===`dev`)||/(^|\s)(next\s+)?dev(\s|$)/.test(t),isBuildCommand:e===`build`||process.argv.some(e=>e===`build`)||/(^|\s)(next\s+)?build(\s|$)/.test(t),isStartCommand:e===`start`||process.argv.some(e=>e===`start`)||/(^|\s)(next\s+)?start(\s|$)/.test(t)}},k=(e={},t)=>{typeof e!=`object`&&(e={});let n=u(t),i=l(n),a=t?.enableTurbopack??C;a&&e.webpack!==void 0&&i(`Turbopack is enabled but a custom webpack config is present. It will be ignored.`);let{isBuildCommand:o,isDevCommand:s}=O(),c={resolveAlias:f({configuration:n,formatter:e=>`./${e}`}),rules:{"*.node":{as:`*.node`,loaders:[`node-loader`]}}},d=[`esbuild`,`module`,`fs`,`chokidar`,`fsevents`],p=()=>{let t={};return b&&(t={...t,serverExternalPackages:d}),y&&!b&&(t={...t,experimental:{...t?.experimental??{},serverComponentsExternalPackages:d}}),t=a?b&&S?{...t,turbopack:c}:{...t,experimental:{...t?.experimental??{},turbo:c}}:{...t,webpack:(t,i)=>{let{isServer:a,nextRuntime:o}=i;return typeof e.webpack==`function`&&(t=e.webpack(t,i)),t.externals===!1&&(t.externals=[]),t.externals.push({esbuild:`esbuild`,module:`module`,fs:`fs`,chokidar:`chokidar`,fsevents:`fsevents`}),t.module.rules.push({test:/\.node$/,loader:`node-loader`}),t.resolve.alias={...t.resolve.alias,...f({configuration:n,formatter:e=>r(e)})},s&&a&&o===`nodejs`&&t.plugins.push(new g(n)),t}},t},m=D(n,o,a??!1,s);return _(_(p(),m),e)},A=async(e={},t)=>{let{isBuildCommand:n,isDevCommand:r}=O();process.env.INTLAYER_IS_DEV_COMMAND=r?`true`:`false`;let a=u(t),{mode:o}=a.build;return(r||n||o===`auto`)&&await i(a,{clean:n,cacheTimeoutMs:n?1e3*30:1e3*60*60}),k(await e,t)};export{A as withIntlayer,k as withIntlayerSync};
1
+ import{DefaultValues as e}from"@intlayer/config/client";import{join as t,relative as n,resolve as r}from"node:path";import{prepareIntlayer as i}from"@intlayer/chokidar/build";import{getComponentTransformPatternSync as a,runOnce as o}from"@intlayer/chokidar/utils";import{ANSIColors as s,colorize as c,getAppLogger as l}from"@intlayer/config/logger";import{getConfiguration as u}from"@intlayer/config/node";import{compareVersions as d,getAlias as f,getProjectRequire as p,normalizePath as m}from"@intlayer/config/utils";import{getDictionaries as h}from"@intlayer/dictionaries-entry";import{IntlayerPlugin as g}from"@intlayer/webpack";import{defu as _}from"defu";import v from"next/package.json"with{type:"json"};const y=d(v.version,`≥`,`13.0.0`),b=d(v.version,`≥`,`15.0.0`),x=d(v.version,`≥`,`16.0.0`),S=d(v.version,`≥`,`15.3.0`),C=x?!process.env.npm_lifecycle_script?.includes(`--webpack`):process.env.npm_lifecycle_script?.includes(`--turbo`),w=e=>{try{return(e.build?.require??p()).resolve(`@intlayer/swc`),!0}catch{return!1}},T=e=>{try{return(e.build?.require??p()).resolve(`@intlayer/babel`),!0}catch{return!1}},E=(e,t,r)=>{let i=(t.build?.require??p())?.resolve(e);return r?m(`./${n(process.cwd(),i)}`):i},D=(n,r,i,u)=>{let{optimize:d}=n.build,f=n.build.importMode??n.dictionary?.importMode,{dictionariesDir:p,unmergedDictionariesDir:m,dynamicDictionariesDir:g,fetchDictionariesDir:_,mainDir:v}=n.system,{baseDir:b}=n.content,x=l(n);if(d===!1||d===void 0&&!r||!y)return{};let S=w(n);if(o(t(b,`.intlayer`,`cache`,`intlayer-prune-plugin-enabled.lock`),()=>{x(S?`Build optimization enabled`:[c(`Recommended: Install`,s.GREY),c(`@intlayer/swc`,s.GREY_LIGHT),c(`package to enable build optimization. See documentation: `,s.GREY),c(`https://intlayer.org/docs/en/bundle_optimization`,s.GREY_LIGHT)])},{cacheTimeoutMs:1e3*30}),o(t(b,`.intlayer`,`cache`,`intlayer-compiler-plugin-enabled.lock`),()=>{if(T(n)){let e=n.compiler?.enabled??!0;e===`build-only`&&(e=!u),x(e?`Intlayer compiler enabled`:`Intlayer compiler disabled`)}},{cacheTimeoutMs:1e3*30}),!S)return{};let C=t(v,`dictionaries.mjs`),D=t(v,`dynamic_dictionaries.mjs`),O=t(v,`unmerged_dictionaries.mjs`),k=t(v,`fetch_dictionaries.mjs`),A=[...a(n),C,O],j=h(n),M={};return Object.values(j).forEach(t=>{M[t.key]=t.importMode??f??e.Dictionary.IMPORT_MODE}),{experimental:{swcPlugins:[[E(`@intlayer/swc`,n,i),{dictionariesDir:p,dictionariesEntryPath:C,unmergedDictionariesEntryPath:O,unmergedDictionariesDir:m,dynamicDictionariesDir:g,dynamicDictionariesEntryPath:D,fetchDictionariesDir:_,fetchDictionariesEntryPath:k,importMode:f,filesList:A,replaceDictionaryEntry:!0,dictionaryModeMap:M}]]}}},O=()=>{let e=process.env.npm_lifecycle_event,t=process.env.npm_lifecycle_script??``;return{isDevCommand:e===`dev`||process.argv.some(e=>e===`dev`)||/(^|\s)(next\s+)?dev(\s|$)/.test(t),isBuildCommand:e===`build`||process.argv.some(e=>e===`build`)||/(^|\s)(next\s+)?build(\s|$)/.test(t),isStartCommand:e===`start`||process.argv.some(e=>e===`start`)||/(^|\s)(next\s+)?start(\s|$)/.test(t)}},k=(e={},t)=>{typeof e!=`object`&&(e={});let n=u(t),i=l(n),a=t?.enableTurbopack??C;a&&e.webpack!==void 0&&i(`Turbopack is enabled but a custom webpack config is present. It will be ignored.`);let{isBuildCommand:o,isDevCommand:s}=O(),c={resolveAlias:f({configuration:n,formatter:e=>`./${e}`}),rules:{"*.node":{as:`*.node`,loaders:[`node-loader`]}}},d=[`esbuild`,`module`,`fs`,`chokidar`,`fsevents`],p=()=>{let t={};return b&&(t={...t,serverExternalPackages:d}),y&&!b&&(t={...t,experimental:{...t?.experimental??{},serverComponentsExternalPackages:d}}),t=a?b&&S?{...t,turbopack:c}:{...t,experimental:{...t?.experimental??{},turbo:c}}:{...t,webpack:(t,i)=>{let{isServer:a,nextRuntime:o}=i;return typeof e.webpack==`function`&&(t=e.webpack(t,i)),t.externals===!1&&(t.externals=[]),t.externals.push({esbuild:`esbuild`,module:`module`,fs:`fs`,chokidar:`chokidar`,fsevents:`fsevents`}),t.module.rules.push({test:/\.node$/,loader:`node-loader`}),t.resolve.alias={...t.resolve.alias,...f({configuration:n,formatter:e=>r(e)})},s&&a&&o===`nodejs`&&t.plugins.push(new g(n)),t}},t},m=D(n,o,a??!1,s);return _(_(p(),m),e)},A=async(e={},t)=>{let{isBuildCommand:n,isDevCommand:r,isStartCommand:a}=O();process.env.INTLAYER_IS_DEV_COMMAND=r?`true`:`false`;let o=u(t),{mode:s}=o.build;return!a&&(r||n||s===`auto`)&&await i(o,{clean:n,cacheTimeoutMs:n?1e3*30:1e3*60*60}),k(await e,t)};export{A as withIntlayer,k as withIntlayerSync};
2
2
  //# sourceMappingURL=withIntlayer.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"withIntlayer.mjs","names":[],"sources":["../../../src/server/withIntlayer.ts"],"sourcesContent":["import { join, relative, resolve } from 'node:path';\nimport { prepareIntlayer } from '@intlayer/chokidar/build';\nimport {\n getComponentTransformPatternSync,\n runOnce,\n} from '@intlayer/chokidar/utils';\nimport { DefaultValues } from '@intlayer/config/client';\nimport { ANSIColors, colorize, getAppLogger } from '@intlayer/config/logger';\nimport {\n type GetConfigurationOptions,\n getConfiguration,\n} from '@intlayer/config/node';\nimport {\n compareVersions,\n getAlias,\n getProjectRequire,\n normalizePath,\n} from '@intlayer/config/utils';\nimport { getDictionaries } from '@intlayer/dictionaries-entry';\nimport type { Dictionary, IntlayerConfig } from '@intlayer/types';\nimport { IntlayerPlugin } from '@intlayer/webpack';\nimport { defu } from 'defu';\nimport type { NextConfig } from 'next';\nimport type { NextJsWebpackConfig } from 'next/dist/server/config-shared';\nimport nextPackageJSON from 'next/package.json' with { type: 'json' };\n\nconst isGteNext13 = compareVersions(nextPackageJSON.version, '≥', '13.0.0');\nconst isGteNext15 = compareVersions(nextPackageJSON.version, '≥', '15.0.0');\nconst isGteNext16 = compareVersions(nextPackageJSON.version, '≥', '16.0.0');\nconst isTurbopackStable = compareVersions(\n nextPackageJSON.version,\n '≥',\n '15.3.0'\n);\n\nconst isTurbopackEnabledFromCommand = isGteNext16\n ? // Next@16 enable turbopack by default, and offer the possibility to disable it if --webpack flag is used\n !process.env.npm_lifecycle_script?.includes('--webpack')\n : // Next@15 use --turbopack flag, Next@14 use --turbo flag\n process.env.npm_lifecycle_script?.includes('--turbo');\n\n// Check if SWC plugin is available\nconst getIsSwcPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/swc');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\n// Check if Babel plugin is available\nconst getIsBabelExtractPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/babel');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\nconst resolvePluginPath = (\n pluginPath: string,\n intlayerConfig: IntlayerConfig,\n isTurbopackEnabled: boolean\n): string => {\n const requireFunction = intlayerConfig.build?.require ?? getProjectRequire();\n const pluginPathResolved = requireFunction?.resolve(pluginPath);\n\n if (isTurbopackEnabled)\n // Relative path for turbopack\n return normalizePath(`./${relative(process.cwd(), pluginPathResolved)}`);\n\n // Absolute path for webpack\n return pluginPathResolved;\n};\n\nconst getPruneConfig = (\n intlayerConfig: IntlayerConfig,\n isBuildCommand: boolean,\n isTurbopackEnabled: boolean,\n isDevCommand: boolean\n): Partial<NextConfig> => {\n const { optimize } = intlayerConfig.build;\n const importMode =\n intlayerConfig.build.importMode ?? intlayerConfig.dictionary?.importMode;\n const {\n dictionariesDir,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n fetchDictionariesDir,\n mainDir,\n } = intlayerConfig.system;\n const { baseDir } = intlayerConfig.content;\n const logger = getAppLogger(intlayerConfig);\n\n if (optimize === false) {\n return {};\n }\n if (optimize === undefined && !isBuildCommand) {\n return {};\n }\n\n if (!isGteNext13) return {};\n\n const isSwcPluginAvailable = getIsSwcPluginAvailable(intlayerConfig);\n\n runOnce(\n join(baseDir, '.intlayer', 'cache', 'intlayer-prune-plugin-enabled.lock'),\n () => {\n if (isSwcPluginAvailable) {\n logger('Build optimization enabled');\n } else {\n logger([\n colorize('Recommended: Install', ANSIColors.GREY),\n colorize('@intlayer/swc', ANSIColors.GREY_LIGHT),\n colorize(\n 'package to enable build optimization. See documentation: ',\n ANSIColors.GREY\n ),\n colorize(\n 'https://intlayer.org/docs/en/bundle_optimization',\n ANSIColors.GREY_LIGHT\n ),\n ]);\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n runOnce(\n join(\n baseDir,\n '.intlayer',\n 'cache',\n 'intlayer-compiler-plugin-enabled.lock'\n ),\n () => {\n const isBabelExtractPluginAvailable =\n getIsBabelExtractPluginAvailable(intlayerConfig);\n\n if (isBabelExtractPluginAvailable) {\n let isEnabled = intlayerConfig.compiler?.enabled ?? true;\n\n if (isEnabled === 'build-only') {\n isEnabled = !isDevCommand;\n }\n\n if (isEnabled) {\n logger('Intlayer compiler enabled');\n } else {\n logger('Intlayer compiler disabled');\n }\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n if (!isSwcPluginAvailable) {\n return {};\n }\n\n const dictionariesEntryPath = join(mainDir, 'dictionaries.mjs');\n\n const dynamicDictionariesEntryPath = join(\n mainDir,\n 'dynamic_dictionaries.mjs'\n );\n\n const unmergedDictionariesEntryPath = join(\n mainDir,\n 'unmerged_dictionaries.mjs'\n );\n\n const fetchDictionariesEntryPath = join(mainDir, 'fetch_dictionaries.mjs');\n\n const filesListPattern = getComponentTransformPatternSync(intlayerConfig);\n\n const filesList = [\n ...filesListPattern,\n dictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n unmergedDictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n ];\n\n const dictionaries = getDictionaries(intlayerConfig);\n\n const dictionaryModeMap: Record<string, 'static' | 'dynamic' | 'fetch'> = {};\n\n (Object.values(dictionaries) as Dictionary[]).forEach((dictionary) => {\n dictionaryModeMap[dictionary.key] =\n dictionary.importMode ??\n importMode ??\n DefaultValues.Dictionary.IMPORT_MODE;\n });\n\n return {\n experimental: {\n swcPlugins: [\n [\n resolvePluginPath(\n '@intlayer/swc',\n intlayerConfig,\n isTurbopackEnabled\n ),\n {\n dictionariesDir,\n dictionariesEntryPath,\n unmergedDictionariesEntryPath,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n dynamicDictionariesEntryPath,\n fetchDictionariesDir,\n fetchDictionariesEntryPath,\n importMode,\n filesList,\n replaceDictionaryEntry: true,\n dictionaryModeMap,\n },\n ],\n ],\n },\n };\n};\n\nconst getCommandsEvent = () => {\n const lifecycleEvent = process.env.npm_lifecycle_event;\n const lifecycleScript = process.env.npm_lifecycle_script ?? '';\n\n const isDevCommand =\n lifecycleEvent === 'dev' ||\n process.argv.some((arg) => arg === 'dev') ||\n /(^|\\s)(next\\s+)?dev(\\s|$)/.test(lifecycleScript);\n\n const isBuildCommand =\n lifecycleEvent === 'build' ||\n process.argv.some((arg) => arg === 'build') ||\n /(^|\\s)(next\\s+)?build(\\s|$)/.test(lifecycleScript);\n\n const isStartCommand =\n lifecycleEvent === 'start' ||\n process.argv.some((arg) => arg === 'start') ||\n /(^|\\s)(next\\s+)?start(\\s|$)/.test(lifecycleScript);\n\n return {\n isDevCommand,\n isBuildCommand,\n isStartCommand,\n };\n};\n\ntype WebpackParams = Parameters<NextJsWebpackConfig>;\n\ntype WithIntlayerOptions = GetConfigurationOptions & {\n enableTurbopack?: boolean;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayerSync(nextConfig)\n * ```\n */\nexport const withIntlayerSync = <T extends Partial<NextConfig>>(\n nextConfig: T = {} as T,\n configOptions?: WithIntlayerOptions\n): NextConfig & T => {\n if (typeof nextConfig !== 'object') {\n nextConfig = {} as T;\n }\n\n const intlayerConfig = getConfiguration(configOptions);\n const logger = getAppLogger(intlayerConfig);\n\n const isTurbopackEnabled =\n configOptions?.enableTurbopack ?? isTurbopackEnabledFromCommand;\n\n if (isTurbopackEnabled && typeof nextConfig.webpack !== 'undefined') {\n logger(\n 'Turbopack is enabled but a custom webpack config is present. It will be ignored.'\n );\n }\n\n const { isBuildCommand, isDevCommand } = getCommandsEvent();\n\n // Only provide turbo-specific config if user explicitly sets it\n const turboConfig = {\n resolveAlias: getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => `./${value}`, // prefix by './' to consider the path as relative to the project root. This is necessary for turbopack to work correctly.\n }),\n\n rules: {\n '*.node': {\n as: '*.node',\n loaders: ['node-loader'],\n },\n },\n };\n\n const serverExternalPackages = [\n 'esbuild',\n 'module',\n 'fs',\n 'chokidar',\n 'fsevents',\n ];\n\n const getNewConfig = (): Partial<NextConfig> => {\n let config: Partial<NextConfig> = {};\n\n if (isGteNext15) {\n config = {\n ...config,\n serverExternalPackages,\n };\n }\n\n if (isGteNext13 && !isGteNext15) {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n serverComponentsExternalPackages: serverExternalPackages,\n },\n };\n }\n\n if (isTurbopackEnabled) {\n if (isGteNext15 && isTurbopackStable) {\n config = {\n ...config,\n turbopack: turboConfig,\n };\n } else {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n // @ts-ignore exist in next@14\n turbo: turboConfig,\n },\n };\n }\n } else {\n config = {\n ...config,\n webpack: (config: WebpackParams['0'], options: WebpackParams[1]) => {\n // Only add Intlayer plugin on server side (node runtime)\n const { isServer, nextRuntime } = options;\n\n // If the user has defined their own webpack config, call it\n if (typeof nextConfig.webpack === 'function') {\n config = nextConfig.webpack(config, options);\n }\n\n // Rspack set external as false by default\n // Overwrite it to allow pushing the desired externals\n if (config.externals === false) {\n config.externals = [];\n }\n\n // Mark these modules as externals\n config.externals.push({\n esbuild: 'esbuild',\n module: 'module',\n fs: 'fs',\n chokidar: 'chokidar',\n fsevents: 'fsevents',\n });\n\n // Use `node-loader` for any `.node` files\n config.module.rules.push({\n test: /\\.node$/,\n loader: 'node-loader',\n });\n\n // Always alias on the server (node/edge) for stability.\n // On the client, alias only when not using live sync.\n config.resolve.alias = {\n ...config.resolve.alias,\n ...getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => resolve(value), // get absolute path\n }),\n };\n\n // Activate watch mode webpack plugin\n if (isDevCommand && isServer && nextRuntime === 'nodejs') {\n // Optional as rspack not support plugin yet\n config.plugins.push(new IntlayerPlugin(intlayerConfig));\n }\n\n return config;\n },\n };\n }\n\n return config;\n };\n\n const pruneConfig: Partial<NextConfig> = getPruneConfig(\n intlayerConfig,\n isBuildCommand,\n isTurbopackEnabled ?? false,\n isDevCommand\n );\n\n const intlayerNextConfig: Partial<NextConfig> = defu(\n getNewConfig(),\n pruneConfig\n );\n\n // Merge the new config with the user's config\n const result = defu(intlayerNextConfig, nextConfig) as NextConfig & T;\n\n return result;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayer(nextConfig)\n * ```\n *\n * > Node withIntlayer is a promise function. Use withIntlayerSync instead if you want to use it synchronously.\n * > Using the promise allows to prepare the intlayer dictionaries before the build starts.\n *\n */\nexport const withIntlayer = async <T extends Partial<NextConfig>>(\n nextConfig: T | Promise<T> = {} as T,\n configOptions?: WithIntlayerOptions\n): Promise<NextConfig & T> => {\n const { isBuildCommand, isDevCommand } = getCommandsEvent();\n\n process.env.INTLAYER_IS_DEV_COMMAND = isDevCommand ? 'true' : 'false';\n\n const intlayerConfig = getConfiguration(configOptions);\n\n const { mode } = intlayerConfig.build;\n\n // Only call prepareIntlayer during `dev` or `build` (not during `start`)\n // If prod: clean and rebuild once\n // If dev: rebuild only once if it's more than 1 hour since last rebuild\n if (isDevCommand || isBuildCommand || mode === 'auto') {\n // prepareIntlayer use runOnce to ensure to run only once because will run twice on client and server side otherwise\n await prepareIntlayer(intlayerConfig, {\n clean: isBuildCommand,\n cacheTimeoutMs: isBuildCommand\n ? 1000 * 30 // 30 seconds for build (to ensure to rebuild all dictionaries)\n : 1000 * 60 * 60, // 1 hour for dev (default cache timeout)\n });\n }\n\n const nextConfigResolved = await nextConfig;\n\n return withIntlayerSync(nextConfigResolved, configOptions);\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"withIntlayer.mjs","names":[],"sources":["../../../src/server/withIntlayer.ts"],"sourcesContent":["import { join, relative, resolve } from 'node:path';\nimport { prepareIntlayer } from '@intlayer/chokidar/build';\nimport {\n getComponentTransformPatternSync,\n runOnce,\n} from '@intlayer/chokidar/utils';\nimport { DefaultValues } from '@intlayer/config/client';\nimport { ANSIColors, colorize, getAppLogger } from '@intlayer/config/logger';\nimport {\n type GetConfigurationOptions,\n getConfiguration,\n} from '@intlayer/config/node';\nimport {\n compareVersions,\n getAlias,\n getProjectRequire,\n normalizePath,\n} from '@intlayer/config/utils';\nimport { getDictionaries } from '@intlayer/dictionaries-entry';\nimport type { Dictionary, IntlayerConfig } from '@intlayer/types';\nimport { IntlayerPlugin } from '@intlayer/webpack';\nimport { defu } from 'defu';\nimport type { NextConfig } from 'next';\nimport type { NextJsWebpackConfig } from 'next/dist/server/config-shared';\nimport nextPackageJSON from 'next/package.json' with { type: 'json' };\n\nconst isGteNext13 = compareVersions(nextPackageJSON.version, '≥', '13.0.0');\nconst isGteNext15 = compareVersions(nextPackageJSON.version, '≥', '15.0.0');\nconst isGteNext16 = compareVersions(nextPackageJSON.version, '≥', '16.0.0');\nconst isTurbopackStable = compareVersions(\n nextPackageJSON.version,\n '≥',\n '15.3.0'\n);\n\nconst isTurbopackEnabledFromCommand = isGteNext16\n ? // Next@16 enable turbopack by default, and offer the possibility to disable it if --webpack flag is used\n !process.env.npm_lifecycle_script?.includes('--webpack')\n : // Next@15 use --turbopack flag, Next@14 use --turbo flag\n process.env.npm_lifecycle_script?.includes('--turbo');\n\n// Check if SWC plugin is available\nconst getIsSwcPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/swc');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\n// Check if Babel plugin is available\nconst getIsBabelExtractPluginAvailable = (intlayerConfig: IntlayerConfig) => {\n try {\n const requireFunction =\n intlayerConfig.build?.require ?? getProjectRequire();\n requireFunction.resolve('@intlayer/babel');\n return true;\n } catch (_e) {\n return false;\n }\n};\n\nconst resolvePluginPath = (\n pluginPath: string,\n intlayerConfig: IntlayerConfig,\n isTurbopackEnabled: boolean\n): string => {\n const requireFunction = intlayerConfig.build?.require ?? getProjectRequire();\n const pluginPathResolved = requireFunction?.resolve(pluginPath);\n\n if (isTurbopackEnabled)\n // Relative path for turbopack\n return normalizePath(`./${relative(process.cwd(), pluginPathResolved)}`);\n\n // Absolute path for webpack\n return pluginPathResolved;\n};\n\nconst getPruneConfig = (\n intlayerConfig: IntlayerConfig,\n isBuildCommand: boolean,\n isTurbopackEnabled: boolean,\n isDevCommand: boolean\n): Partial<NextConfig> => {\n const { optimize } = intlayerConfig.build;\n const importMode =\n intlayerConfig.build.importMode ?? intlayerConfig.dictionary?.importMode;\n const {\n dictionariesDir,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n fetchDictionariesDir,\n mainDir,\n } = intlayerConfig.system;\n const { baseDir } = intlayerConfig.content;\n const logger = getAppLogger(intlayerConfig);\n\n if (optimize === false) {\n return {};\n }\n if (optimize === undefined && !isBuildCommand) {\n return {};\n }\n\n if (!isGteNext13) return {};\n\n const isSwcPluginAvailable = getIsSwcPluginAvailable(intlayerConfig);\n\n runOnce(\n join(baseDir, '.intlayer', 'cache', 'intlayer-prune-plugin-enabled.lock'),\n () => {\n if (isSwcPluginAvailable) {\n logger('Build optimization enabled');\n } else {\n logger([\n colorize('Recommended: Install', ANSIColors.GREY),\n colorize('@intlayer/swc', ANSIColors.GREY_LIGHT),\n colorize(\n 'package to enable build optimization. See documentation: ',\n ANSIColors.GREY\n ),\n colorize(\n 'https://intlayer.org/docs/en/bundle_optimization',\n ANSIColors.GREY_LIGHT\n ),\n ]);\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n runOnce(\n join(\n baseDir,\n '.intlayer',\n 'cache',\n 'intlayer-compiler-plugin-enabled.lock'\n ),\n () => {\n const isBabelExtractPluginAvailable =\n getIsBabelExtractPluginAvailable(intlayerConfig);\n\n if (isBabelExtractPluginAvailable) {\n let isEnabled = intlayerConfig.compiler?.enabled ?? true;\n\n if (isEnabled === 'build-only') {\n isEnabled = !isDevCommand;\n }\n\n if (isEnabled) {\n logger('Intlayer compiler enabled');\n } else {\n logger('Intlayer compiler disabled');\n }\n }\n },\n {\n cacheTimeoutMs: 1000 * 30, // 30 seconds\n }\n );\n\n if (!isSwcPluginAvailable) {\n return {};\n }\n\n const dictionariesEntryPath = join(mainDir, 'dictionaries.mjs');\n\n const dynamicDictionariesEntryPath = join(\n mainDir,\n 'dynamic_dictionaries.mjs'\n );\n\n const unmergedDictionariesEntryPath = join(\n mainDir,\n 'unmerged_dictionaries.mjs'\n );\n\n const fetchDictionariesEntryPath = join(mainDir, 'fetch_dictionaries.mjs');\n\n const filesListPattern = getComponentTransformPatternSync(intlayerConfig);\n\n const filesList = [\n ...filesListPattern,\n dictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n unmergedDictionariesEntryPath, // should add dictionariesEntryPath to replace it by a empty object if import made dynamic\n ];\n\n const dictionaries = getDictionaries(intlayerConfig);\n\n const dictionaryModeMap: Record<string, 'static' | 'dynamic' | 'fetch'> = {};\n\n (Object.values(dictionaries) as Dictionary[]).forEach((dictionary) => {\n dictionaryModeMap[dictionary.key] =\n dictionary.importMode ??\n importMode ??\n DefaultValues.Dictionary.IMPORT_MODE;\n });\n\n return {\n experimental: {\n swcPlugins: [\n [\n resolvePluginPath(\n '@intlayer/swc',\n intlayerConfig,\n isTurbopackEnabled\n ),\n {\n dictionariesDir,\n dictionariesEntryPath,\n unmergedDictionariesEntryPath,\n unmergedDictionariesDir,\n dynamicDictionariesDir,\n dynamicDictionariesEntryPath,\n fetchDictionariesDir,\n fetchDictionariesEntryPath,\n importMode,\n filesList,\n replaceDictionaryEntry: true,\n dictionaryModeMap,\n },\n ],\n ],\n },\n };\n};\n\nconst getCommandsEvent = () => {\n const lifecycleEvent = process.env.npm_lifecycle_event;\n const lifecycleScript = process.env.npm_lifecycle_script ?? '';\n\n const isDevCommand =\n lifecycleEvent === 'dev' ||\n process.argv.some((arg) => arg === 'dev') ||\n /(^|\\s)(next\\s+)?dev(\\s|$)/.test(lifecycleScript);\n\n const isBuildCommand =\n lifecycleEvent === 'build' ||\n process.argv.some((arg) => arg === 'build') ||\n /(^|\\s)(next\\s+)?build(\\s|$)/.test(lifecycleScript);\n\n const isStartCommand =\n lifecycleEvent === 'start' ||\n process.argv.some((arg) => arg === 'start') ||\n /(^|\\s)(next\\s+)?start(\\s|$)/.test(lifecycleScript);\n\n return {\n isDevCommand,\n isBuildCommand,\n isStartCommand,\n };\n};\n\ntype WebpackParams = Parameters<NextJsWebpackConfig>;\n\ntype WithIntlayerOptions = GetConfigurationOptions & {\n enableTurbopack?: boolean;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayerSync(nextConfig)\n * ```\n */\nexport const withIntlayerSync = <T extends Partial<NextConfig>>(\n nextConfig: T = {} as T,\n configOptions?: WithIntlayerOptions\n): NextConfig & T => {\n if (typeof nextConfig !== 'object') {\n nextConfig = {} as T;\n }\n\n const intlayerConfig = getConfiguration(configOptions);\n const logger = getAppLogger(intlayerConfig);\n\n const isTurbopackEnabled =\n configOptions?.enableTurbopack ?? isTurbopackEnabledFromCommand;\n\n if (isTurbopackEnabled && typeof nextConfig.webpack !== 'undefined') {\n logger(\n 'Turbopack is enabled but a custom webpack config is present. It will be ignored.'\n );\n }\n\n const { isBuildCommand, isDevCommand } = getCommandsEvent();\n\n // Only provide turbo-specific config if user explicitly sets it\n const turboConfig = {\n resolveAlias: getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => `./${value}`, // prefix by './' to consider the path as relative to the project root. This is necessary for turbopack to work correctly.\n }),\n\n rules: {\n '*.node': {\n as: '*.node',\n loaders: ['node-loader'],\n },\n },\n };\n\n const serverExternalPackages = [\n 'esbuild',\n 'module',\n 'fs',\n 'chokidar',\n 'fsevents',\n ];\n\n const getNewConfig = (): Partial<NextConfig> => {\n let config: Partial<NextConfig> = {};\n\n if (isGteNext15) {\n config = {\n ...config,\n serverExternalPackages,\n };\n }\n\n if (isGteNext13 && !isGteNext15) {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n serverComponentsExternalPackages: serverExternalPackages,\n },\n };\n }\n\n if (isTurbopackEnabled) {\n if (isGteNext15 && isTurbopackStable) {\n config = {\n ...config,\n turbopack: turboConfig,\n };\n } else {\n config = {\n ...config,\n experimental: {\n ...(config?.experimental ?? {}),\n // @ts-ignore exist in next@14\n turbo: turboConfig,\n },\n };\n }\n } else {\n config = {\n ...config,\n webpack: (config: WebpackParams['0'], options: WebpackParams[1]) => {\n // Only add Intlayer plugin on server side (node runtime)\n const { isServer, nextRuntime } = options;\n\n // If the user has defined their own webpack config, call it\n if (typeof nextConfig.webpack === 'function') {\n config = nextConfig.webpack(config, options);\n }\n\n // Rspack set external as false by default\n // Overwrite it to allow pushing the desired externals\n if (config.externals === false) {\n config.externals = [];\n }\n\n // Mark these modules as externals\n config.externals.push({\n esbuild: 'esbuild',\n module: 'module',\n fs: 'fs',\n chokidar: 'chokidar',\n fsevents: 'fsevents',\n });\n\n // Use `node-loader` for any `.node` files\n config.module.rules.push({\n test: /\\.node$/,\n loader: 'node-loader',\n });\n\n // Always alias on the server (node/edge) for stability.\n // On the client, alias only when not using live sync.\n config.resolve.alias = {\n ...config.resolve.alias,\n ...getAlias({\n configuration: intlayerConfig,\n formatter: (value: string) => resolve(value), // get absolute path\n }),\n };\n\n // Activate watch mode webpack plugin\n if (isDevCommand && isServer && nextRuntime === 'nodejs') {\n // Optional as rspack not support plugin yet\n config.plugins.push(new IntlayerPlugin(intlayerConfig));\n }\n\n return config;\n },\n };\n }\n\n return config;\n };\n\n const pruneConfig: Partial<NextConfig> = getPruneConfig(\n intlayerConfig,\n isBuildCommand,\n isTurbopackEnabled ?? false,\n isDevCommand\n );\n\n const intlayerNextConfig: Partial<NextConfig> = defu(\n getNewConfig(),\n pruneConfig\n );\n\n // Merge the new config with the user's config\n const result = defu(intlayerNextConfig, nextConfig) as NextConfig & T;\n\n return result;\n};\n\n/**\n * A Next.js plugin that adds the intlayer configuration to the webpack configuration\n * and sets the environment variables\n *\n * Usage:\n *\n * ```ts\n * // next.config.js\n * export default withIntlayer(nextConfig)\n * ```\n *\n * > Node withIntlayer is a promise function. Use withIntlayerSync instead if you want to use it synchronously.\n * > Using the promise allows to prepare the intlayer dictionaries before the build starts.\n *\n */\nexport const withIntlayer = async <T extends Partial<NextConfig>>(\n nextConfig: T | Promise<T> = {} as T,\n configOptions?: WithIntlayerOptions\n): Promise<NextConfig & T> => {\n const { isBuildCommand, isDevCommand, isStartCommand } = getCommandsEvent();\n\n process.env.INTLAYER_IS_DEV_COMMAND = isDevCommand ? 'true' : 'false';\n\n const intlayerConfig = getConfiguration(configOptions);\n\n const { mode } = intlayerConfig.build;\n\n // Only call prepareIntlayer during `dev` or `build` (not during `start`)\n // If prod: clean and rebuild once\n // If dev: rebuild only once if it's more than 1 hour since last rebuild\n if (!isStartCommand && (isDevCommand || isBuildCommand || mode === 'auto')) {\n // prepareIntlayer use runOnce to ensure to run only once because will run twice on client and server side otherwise\n await prepareIntlayer(intlayerConfig, {\n clean: isBuildCommand,\n cacheTimeoutMs: isBuildCommand\n ? 1000 * 30 // 30 seconds for build (to ensure to rebuild all dictionaries)\n : 1000 * 60 * 60, // 1 hour for dev (default cache timeout)\n });\n }\n\n const nextConfigResolved = await nextConfig;\n\n return withIntlayerSync(nextConfigResolved, configOptions);\n};\n"],"mappings":"usBA0BA,MAAM,EAAc,EAAgB,EAAgB,QAAS,IAAK,SAAS,CACrE,EAAc,EAAgB,EAAgB,QAAS,IAAK,SAAS,CACrE,EAAc,EAAgB,EAAgB,QAAS,IAAK,SAAS,CACrE,EAAoB,EACxB,EAAgB,QAChB,IACA,SACD,CAEK,EAAgC,EAElC,CAAC,QAAQ,IAAI,sBAAsB,SAAS,YAAY,CAExD,QAAQ,IAAI,sBAAsB,SAAS,UAAU,CAGnD,EAA2B,GAAmC,CAClE,GAAI,CAIF,OAFE,EAAe,OAAO,SAAW,GAAmB,EACtC,QAAQ,gBAAgB,CACjC,QACI,CACX,MAAO,KAKL,EAAoC,GAAmC,CAC3E,GAAI,CAIF,OAFE,EAAe,OAAO,SAAW,GAAmB,EACtC,QAAQ,kBAAkB,CACnC,QACI,CACX,MAAO,KAIL,GACJ,EACA,EACA,IACW,CAEX,IAAM,GADkB,EAAe,OAAO,SAAW,GAAmB,GAChC,QAAQ,EAAW,CAO/D,OALI,EAEK,EAAc,KAAK,EAAS,QAAQ,KAAK,CAAE,EAAmB,GAAG,CAGnE,GAGH,GACJ,EACA,EACA,EACA,IACwB,CACxB,GAAM,CAAE,YAAa,EAAe,MAC9B,EACJ,EAAe,MAAM,YAAc,EAAe,YAAY,WAC1D,CACJ,kBACA,0BACA,yBACA,uBACA,WACE,EAAe,OACb,CAAE,WAAY,EAAe,QAC7B,EAAS,EAAa,EAAe,CAS3C,GAPI,IAAa,IAGb,IAAa,IAAA,IAAa,CAAC,GAI3B,CAAC,EAAa,MAAO,EAAE,CAE3B,IAAM,EAAuB,EAAwB,EAAe,CAyDpE,GAvDA,EACE,EAAK,EAAS,YAAa,QAAS,qCAAqC,KACnE,CAEF,EADE,EACK,6BAEA,CACL,EAAS,uBAAwB,EAAW,KAAK,CACjD,EAAS,gBAAiB,EAAW,WAAW,CAChD,EACE,4DACA,EAAW,KACZ,CACD,EACE,mDACA,EAAW,WACZ,CACF,CAAC,EAGN,CACE,eAAgB,IAAO,GACxB,CACF,CAED,EACE,EACE,EACA,YACA,QACA,wCACD,KACK,CAIJ,GAFE,EAAiC,EAAe,CAEf,CACjC,IAAI,EAAY,EAAe,UAAU,SAAW,GAEhD,IAAc,eAChB,EAAY,CAAC,GAIb,EADE,EACK,4BAEA,6BAA6B,GAI1C,CACE,eAAgB,IAAO,GACxB,CACF,CAEG,CAAC,EACH,MAAO,EAAE,CAGX,IAAM,EAAwB,EAAK,EAAS,mBAAmB,CAEzD,EAA+B,EACnC,EACA,2BACD,CAEK,EAAgC,EACpC,EACA,4BACD,CAEK,EAA6B,EAAK,EAAS,yBAAyB,CAIpE,EAAY,CAChB,GAHuB,EAAiC,EAAe,CAIvE,EACA,EACD,CAEK,EAAe,EAAgB,EAAe,CAE9C,EAAoE,EAAE,CAS5E,OAPC,OAAO,OAAO,EAAa,CAAkB,QAAS,GAAe,CACpE,EAAkB,EAAW,KAC3B,EAAW,YACX,GACA,EAAc,WAAW,aAC3B,CAEK,CACL,aAAc,CACZ,WAAY,CACV,CACE,EACE,gBACA,EACA,EACD,CACD,CACE,kBACA,wBACA,gCACA,0BACA,yBACA,+BACA,uBACA,6BACA,aACA,YACA,uBAAwB,GACxB,oBACD,CACF,CACF,CACF,CACF,EAGG,MAAyB,CAC7B,IAAM,EAAiB,QAAQ,IAAI,oBAC7B,EAAkB,QAAQ,IAAI,sBAAwB,GAiB5D,MAAO,CACL,aAfA,IAAmB,OACnB,QAAQ,KAAK,KAAM,GAAQ,IAAQ,MAAM,EACzC,4BAA4B,KAAK,EAAgB,CAcjD,eAXA,IAAmB,SACnB,QAAQ,KAAK,KAAM,GAAQ,IAAQ,QAAQ,EAC3C,8BAA8B,KAAK,EAAgB,CAUnD,eAPA,IAAmB,SACnB,QAAQ,KAAK,KAAM,GAAQ,IAAQ,QAAQ,EAC3C,8BAA8B,KAAK,EAAgB,CAMpD,EAoBU,GACX,EAAgB,EAAE,CAClB,IACmB,CACf,OAAO,GAAe,WACxB,EAAa,EAAE,EAGjB,IAAM,EAAiB,EAAiB,EAAc,CAChD,EAAS,EAAa,EAAe,CAErC,EACJ,GAAe,iBAAmB,EAEhC,GAA6B,EAAW,UAAY,QACtD,EACE,mFACD,CAGH,GAAM,CAAE,iBAAgB,gBAAiB,GAAkB,CAGrD,EAAc,CAClB,aAAc,EAAS,CACrB,cAAe,EACf,UAAY,GAAkB,KAAK,IACpC,CAAC,CAEF,MAAO,CACL,SAAU,CACR,GAAI,SACJ,QAAS,CAAC,cAAc,CACzB,CACF,CACF,CAEK,EAAyB,CAC7B,UACA,SACA,KACA,WACA,WACD,CAEK,MAA0C,CAC9C,IAAI,EAA8B,EAAE,CAyFpC,OAvFI,IACF,EAAS,CACP,GAAG,EACH,yBACD,EAGC,GAAe,CAAC,IAClB,EAAS,CACP,GAAG,EACH,aAAc,CACZ,GAAI,GAAQ,cAAgB,EAAE,CAC9B,iCAAkC,EACnC,CACF,EAGH,AAiBE,EAjBE,EACE,GAAe,EACR,CACP,GAAG,EACH,UAAW,EACZ,CAEQ,CACP,GAAG,EACH,aAAc,CACZ,GAAI,GAAQ,cAAgB,EAAE,CAE9B,MAAO,EACR,CACF,CAGM,CACP,GAAG,EACH,SAAU,EAA4B,IAA8B,CAElE,GAAM,CAAE,WAAU,eAAgB,EA4ClC,OAzCI,OAAO,EAAW,SAAY,aAChC,EAAS,EAAW,QAAQ,EAAQ,EAAQ,EAK1C,EAAO,YAAc,KACvB,EAAO,UAAY,EAAE,EAIvB,EAAO,UAAU,KAAK,CACpB,QAAS,UACT,OAAQ,SACR,GAAI,KACJ,SAAU,WACV,SAAU,WACX,CAAC,CAGF,EAAO,OAAO,MAAM,KAAK,CACvB,KAAM,UACN,OAAQ,cACT,CAAC,CAIF,EAAO,QAAQ,MAAQ,CACrB,GAAG,EAAO,QAAQ,MAClB,GAAG,EAAS,CACV,cAAe,EACf,UAAY,GAAkB,EAAQ,EAAM,CAC7C,CAAC,CACH,CAGG,GAAgB,GAAY,IAAgB,UAE9C,EAAO,QAAQ,KAAK,IAAI,EAAe,EAAe,CAAC,CAGlD,GAEV,CAGI,GAGH,EAAmC,EACvC,EACA,EACA,GAAsB,GACtB,EACD,CAUD,OAFe,EANiC,EAC9C,GAAc,CACd,EACD,CAGuC,EAAW,EAoBxC,EAAe,MAC1B,EAA6B,EAAE,CAC/B,IAC4B,CAC5B,GAAM,CAAE,iBAAgB,eAAc,kBAAmB,GAAkB,CAE3E,QAAQ,IAAI,wBAA0B,EAAe,OAAS,QAE9D,IAAM,EAAiB,EAAiB,EAAc,CAEhD,CAAE,QAAS,EAAe,MAiBhC,MAZI,CAAC,IAAmB,GAAgB,GAAkB,IAAS,SAEjE,MAAM,EAAgB,EAAgB,CACpC,MAAO,EACP,eAAgB,EACZ,IAAO,GACP,IAAO,GAAK,GACjB,CAAC,CAKG,EAFoB,MAAM,EAEW,EAAc"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "next-intlayer",
3
- "version": "8.1.5",
3
+ "version": "8.1.7",
4
4
  "private": false,
5
5
  "description": "Simplify internationalization i18n in Next.js with context providers, hooks, locale detection, and multilingual content integration.",
6
6
  "keywords": [
@@ -107,7 +107,6 @@
107
107
  "./package.json"
108
108
  ],
109
109
  "scripts": {
110
- "_prepublish": "cp -f ../../README.md ./README.md",
111
110
  "build": "tsdown --config tsdown.config.ts",
112
111
  "build:ci": "tsdown --config tsdown.config.ts",
113
112
  "clean": "rimraf ./dist .turbo",
@@ -116,7 +115,7 @@
116
115
  "format:fix": "biome format --write .",
117
116
  "lint": "biome lint .",
118
117
  "lint:fix": "biome lint --write .",
119
- "prepublish": "echo prepublish temporally disabled to avoid rewrite readme",
118
+ "prepublish": "cp -f ../../README.md ./README.md",
120
119
  "publish": "bun publish || true",
121
120
  "publish:canary": "bun publish --access public --tag canary || true",
122
121
  "publish:latest": "bun publish --access public --tag latest || true",
@@ -125,15 +124,15 @@
125
124
  "typecheck": "tsc --noEmit --project tsconfig.types.json"
126
125
  },
127
126
  "dependencies": {
128
- "@intlayer/chokidar": "8.1.5",
129
- "@intlayer/config": "8.1.5",
130
- "@intlayer/core": "8.1.5",
131
- "@intlayer/dictionaries-entry": "8.1.5",
132
- "@intlayer/types": "8.1.5",
133
- "@intlayer/webpack": "8.1.5",
127
+ "@intlayer/chokidar": "8.1.7",
128
+ "@intlayer/config": "8.1.7",
129
+ "@intlayer/core": "8.1.7",
130
+ "@intlayer/dictionaries-entry": "8.1.7",
131
+ "@intlayer/types": "8.1.7",
132
+ "@intlayer/webpack": "8.1.7",
134
133
  "defu": "6.1.4",
135
134
  "node-loader": "2.1.0",
136
- "react-intlayer": "8.1.5"
135
+ "react-intlayer": "8.1.7"
137
136
  },
138
137
  "devDependencies": {
139
138
  "@types/node": "25.3.0",