nuxt-i18n-micro 1.29.6 → 1.30.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/client/200.html +6 -6
- package/dist/client/404.html +6 -6
- package/dist/client/_nuxt/{Czi4MokJ.js → BVj0VN8T.js} +47 -47
- package/dist/client/_nuxt/{2C6ahHCU.js → C4U-Ow4Y.js} +1 -1
- package/dist/client/_nuxt/{BfH8Q6Ot.js → Tv92-dPW.js} +1 -1
- package/dist/client/_nuxt/builds/latest.json +1 -1
- package/dist/client/_nuxt/builds/meta/afd22cd8-fdee-49d4-9541-5a6f75690f13.json +1 -0
- package/dist/client/_nuxt/{0GmYR_kR.js → zWEC3ICT.js} +1 -1
- package/dist/client/index.html +6 -6
- package/dist/module.json +1 -1
- package/dist/module.mjs +16 -2
- package/dist/runtime/composables/useLocaleHead.js +1 -1
- package/dist/runtime/plugins/01.plugin.js +24 -3
- package/dist/runtime/plugins/03.define.js +1 -1
- package/dist/runtime/plugins/04.auto-detect.js +1 -1
- package/package.json +2 -2
- package/dist/client/_nuxt/builds/meta/66d7665e-5819-42e7-bffd-4eea374483d8.json +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{_ as s,o as a,c as i,a as e,t as o}from"./
|
|
1
|
+
import{_ as s,o as a,c as i,a as e,t as o}from"./BVj0VN8T.js";import{u}from"./zWEC3ICT.js";const l={class:"antialiased bg-white dark:bg-black dark:text-white font-sans grid min-h-screen overflow-hidden place-content-center text-black"},c={class:"max-w-520px text-center"},d=["textContent"],p=["textContent"],f={__name:"error-500",props:{appName:{type:String,default:"Nuxt"},version:{type:String,default:""},statusCode:{type:Number,default:500},statusMessage:{type:String,default:"Server error"},description:{type:String,default:"This page is temporarily unavailable."}},setup(t){const r=t;return u({title:`${r.statusCode} - ${r.statusMessage} | ${r.appName}`,script:[{children:`!function(){const e=document.createElement("link").relList;if(!(e&&e.supports&&e.supports("modulepreload"))){for(const e of document.querySelectorAll('link[rel="modulepreload"]'))r(e);new MutationObserver((e=>{for(const o of e)if("childList"===o.type)for(const e of o.addedNodes)"LINK"===e.tagName&&"modulepreload"===e.rel&&r(e)})).observe(document,{childList:!0,subtree:!0})}function r(e){if(e.ep)return;e.ep=!0;const r=function(e){const r={};return e.integrity&&(r.integrity=e.integrity),e.referrerPolicy&&(r.referrerPolicy=e.referrerPolicy),"use-credentials"===e.crossOrigin?r.credentials="include":"anonymous"===e.crossOrigin?r.credentials="omit":r.credentials="same-origin",r}(e);fetch(e.href,r)}}();`}],style:[{children:'*,:after,:before{border-color:var(--un-default-border-color,#e5e7eb);border-style:solid;border-width:0;box-sizing:border-box}:after,:before{--un-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-moz-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}h1{font-size:inherit;font-weight:inherit}h1,p{margin:0}*,:after,:before{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 transparent;--un-ring-shadow:0 0 transparent;--un-shadow-inset: ;--un-shadow:0 0 transparent;--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgba(147,197,253,.5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }'}]}),(g,n)=>(a(),i("div",l,[n[0]||(n[0]=e("div",{class:"-bottom-1/2 fixed h-1/2 left-0 right-0 spotlight"},null,-1)),e("div",c,[e("h1",{class:"font-medium mb-8 sm:text-10xl text-8xl",textContent:o(t.statusCode)},null,8,d),e("p",{class:"font-light leading-tight mb-16 px-8 sm:px-0 sm:text-4xl text-xl",textContent:o(t.description)},null,8,p)])]))}},b=s(f,[["__scopeId","data-v-d6cbdfc0"]]);export{b as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{_ as a,o as i,c as u,a as e,t as r,b as c,w as l,d,e as p}from"./
|
|
1
|
+
import{_ as a,o as i,c as u,a as e,t as r,b as c,w as l,d,e as p}from"./BVj0VN8T.js";import{u as f}from"./zWEC3ICT.js";const m={class:"antialiased bg-white dark:bg-black dark:text-white font-sans grid min-h-screen overflow-hidden place-content-center text-black"},g={class:"max-w-520px text-center z-20"},h=["textContent"],b=["textContent"],x={class:"flex items-center justify-center w-full"},y={__name:"error-404",props:{appName:{type:String,default:"Nuxt"},version:{type:String,default:""},statusCode:{type:Number,default:404},statusMessage:{type:String,default:"Not Found"},description:{type:String,default:"Sorry, the page you are looking for could not be found."},backHome:{type:String,default:"Go back home"}},setup(t){const n=t;return f({title:`${n.statusCode} - ${n.statusMessage} | ${n.appName}`,script:[{children:`!function(){const e=document.createElement("link").relList;if(!(e&&e.supports&&e.supports("modulepreload"))){for(const e of document.querySelectorAll('link[rel="modulepreload"]'))r(e);new MutationObserver((e=>{for(const o of e)if("childList"===o.type)for(const e of o.addedNodes)"LINK"===e.tagName&&"modulepreload"===e.rel&&r(e)})).observe(document,{childList:!0,subtree:!0})}function r(e){if(e.ep)return;e.ep=!0;const r=function(e){const r={};return e.integrity&&(r.integrity=e.integrity),e.referrerPolicy&&(r.referrerPolicy=e.referrerPolicy),"use-credentials"===e.crossOrigin?r.credentials="include":"anonymous"===e.crossOrigin?r.credentials="omit":r.credentials="same-origin",r}(e);fetch(e.href,r)}}();`}],style:[{children:'*,:after,:before{border-color:var(--un-default-border-color,#e5e7eb);border-style:solid;border-width:0;box-sizing:border-box}:after,:before{--un-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-moz-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}h1{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}h1,p{margin:0}*,:after,:before{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 transparent;--un-ring-shadow:0 0 transparent;--un-shadow-inset: ;--un-shadow:0 0 transparent;--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgba(147,197,253,.5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }'}]}),(k,o)=>{const s=p;return i(),u("div",m,[o[0]||(o[0]=e("div",{class:"fixed left-0 right-0 spotlight z-10"},null,-1)),e("div",g,[e("h1",{class:"font-medium mb-8 sm:text-10xl text-8xl",textContent:r(t.statusCode)},null,8,h),e("p",{class:"font-light leading-tight mb-16 px-8 sm:px-0 sm:text-4xl text-xl",textContent:r(t.description)},null,8,b),e("div",x,[c(s,{to:"/",class:"cursor-pointer gradient-border px-4 py-2 sm:px-6 sm:py-3 sm:text-xl text-md"},{default:l(()=>[d(r(t.backHome),1)]),_:1})])])])}}},v=a(y,[["__scopeId","data-v-28c488d2"]]);export{v as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"id":"
|
|
1
|
+
{"id":"afd22cd8-fdee-49d4-9541-5a6f75690f13","timestamp":1729770728847}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"id":"afd22cd8-fdee-49d4-9541-5a6f75690f13","timestamp":1729770728847,"matcher":{"static":{},"wildcard":{},"dynamic":{}},"prerendered":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{i as f,r as u,f as o,g as d,h as v,j as l,k as i,l as h,m}from"./
|
|
1
|
+
import{i as f,r as u,f as o,g as d,h as v,j as l,k as i,l as h,m}from"./BVj0VN8T.js";function U(t,a={}){const e=a.head||f();if(e)return e.ssr?e.push(t,a):p(e,t,a)}function p(t,a,e={}){const s=u(!1),n=u({});o(()=>{n.value=s.value?{}:d(a)});const r=t.push(n.value,e);return v(n,c=>{r.patch(c)}),m()&&(l(()=>{r.dispose()}),i(()=>{s.value=!0}),h(()=>{s.value=!1})),r}export{U as u};
|
package/dist/client/index.html
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
<!DOCTYPE html><html data-capo=""><head><meta charset="utf-8">
|
|
2
2
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
3
3
|
<link rel="stylesheet" href="/__nuxt-i18n-micro/_nuxt/entry.BqOlM4b6.css">
|
|
4
|
-
<link rel="modulepreload" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/
|
|
4
|
+
<link rel="modulepreload" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/BVj0VN8T.js">
|
|
5
5
|
<link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/B6E6ObS_.js">
|
|
6
6
|
<link rel="prefetch" as="style" crossorigin href="/__nuxt-i18n-micro/_nuxt/error-404.C_4C5G96.css">
|
|
7
|
-
<link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/
|
|
8
|
-
<link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/
|
|
7
|
+
<link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/Tv92-dPW.js">
|
|
8
|
+
<link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/zWEC3ICT.js">
|
|
9
9
|
<link rel="prefetch" as="style" crossorigin href="/__nuxt-i18n-micro/_nuxt/error-500.CBAEdpZV.css">
|
|
10
|
-
<link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/
|
|
11
|
-
<script type="module" src="/__nuxt-i18n-micro/_nuxt/
|
|
12
|
-
<script>window.__NUXT__={};window.__NUXT__.config={public:{},app:{baseURL:"/__nuxt-i18n-micro",buildId:"
|
|
10
|
+
<link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/C4U-Ow4Y.js">
|
|
11
|
+
<script type="module" src="/__nuxt-i18n-micro/_nuxt/BVj0VN8T.js" crossorigin></script></head><body><div id="__nuxt"></div><div id="teleports"></div><script type="application/json" data-nuxt-data="nuxt-app" data-ssr="false" id="__NUXT_DATA__">[{"prerenderedAt":1,"serverRendered":2},1729770742142,false]</script>
|
|
12
|
+
<script>window.__NUXT__={};window.__NUXT__.config={public:{},app:{baseURL:"/__nuxt-i18n-micro",buildId:"afd22cd8-fdee-49d4-9541-5a6f75690f13",buildAssetsDir:"/_nuxt/",cdnURL:""}}</script></body></html>
|
package/dist/module.json
CHANGED
package/dist/module.mjs
CHANGED
|
@@ -179,6 +179,20 @@ class PageManager {
|
|
|
179
179
|
this.localizePage(page, additionalRoutes, customRegex);
|
|
180
180
|
}
|
|
181
181
|
});
|
|
182
|
+
if (this.includeDefaultLocaleRoute) {
|
|
183
|
+
for (let i = pages.length - 1; i >= 0; i--) {
|
|
184
|
+
const defaultLocalePath = this.localizedPaths[pages[i].path]?.[this.defaultLocale.code];
|
|
185
|
+
if (defaultLocalePath !== null) {
|
|
186
|
+
continue;
|
|
187
|
+
}
|
|
188
|
+
if (this.globalLocaleRoutes[pages[i].name ?? ""] !== null) {
|
|
189
|
+
continue;
|
|
190
|
+
}
|
|
191
|
+
if (!/^\/:locale/.test(pages[i].path) && pages[i].path !== "/") {
|
|
192
|
+
pages.splice(i, 1);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
182
196
|
pages.push(...additionalRoutes);
|
|
183
197
|
}
|
|
184
198
|
extractLocalizedPaths(pages, rootDir, parentPath = "") {
|
|
@@ -286,7 +300,7 @@ class PageManager {
|
|
|
286
300
|
return localeCodes.map((locale) => this.createLocalizedChildRoute(route, routePath, locale, customLocalePaths, localizedChildren, modifyName, addLocalePrefix));
|
|
287
301
|
}
|
|
288
302
|
createLocalizedRoute(page, localeCodes, originalChildren, isCustom, customPath = "", customRegex) {
|
|
289
|
-
const routePath = this.buildRoutePath(localeCodes, page.path, customPath, isCustom, customRegex);
|
|
303
|
+
const routePath = this.buildRoutePath(localeCodes, page.path, encodeURI(customPath), isCustom, customRegex);
|
|
290
304
|
const routeName = buildRouteName(buildRouteNameFromRoute(page.name, page.path), localeCodes[0], isCustom);
|
|
291
305
|
return {
|
|
292
306
|
...page,
|
|
@@ -307,7 +321,7 @@ class PageManager {
|
|
|
307
321
|
}
|
|
308
322
|
buildLocalizedRoutePath(routePath, locale, customLocalePaths, addLocalePrefix) {
|
|
309
323
|
const basePath = customLocalePaths?.[locale] || routePath;
|
|
310
|
-
const normalizedBasePath = normalizePath(basePath);
|
|
324
|
+
const normalizedBasePath = encodeURI(normalizePath(basePath));
|
|
311
325
|
return shouldAddLocalePrefix(locale, this.defaultLocale, addLocalePrefix, this.includeDefaultLocaleRoute) ? buildFullPath(locale, normalizedBasePath) : normalizedBasePath;
|
|
312
326
|
}
|
|
313
327
|
buildLocalizedRouteName(baseName, locale, modifyName) {
|
|
@@ -8,7 +8,7 @@ export const useLocaleHead = ({ addDirAttribute = true, identifierAttribute = "i
|
|
|
8
8
|
});
|
|
9
9
|
function updateMeta() {
|
|
10
10
|
const { defaultLocale, includeDefaultLocaleRoute } = useRuntimeConfig().public.i18nConfig;
|
|
11
|
-
const { $getLocales, $getLocale } = useNuxtApp()
|
|
11
|
+
const { $getLocales, $getLocale } = useNuxtApp();
|
|
12
12
|
const route = useRoute();
|
|
13
13
|
const locale = unref($getLocale());
|
|
14
14
|
const routeName = (route.name ?? "").toString();
|
|
@@ -70,9 +70,6 @@ function switchLocale(fromLocale, toLocale, route, router, i18nConfig, i18nRoute
|
|
|
70
70
|
return router.push(switchedRoute);
|
|
71
71
|
}
|
|
72
72
|
function getLocalizedRoute(to, router, route, i18nConfig, locale, hashLocale) {
|
|
73
|
-
const currentLocale = locale || getCurrentLocale(route, i18nConfig, hashLocale);
|
|
74
|
-
const selectRoute = router.resolve(to);
|
|
75
|
-
const routeName = getRouteName(selectRoute, currentLocale);
|
|
76
73
|
const resolveParams = (to2) => {
|
|
77
74
|
const params = typeof to2 === "object" && "params" in to2 && typeof to2.params === "object" ? { ...to2.params } : {};
|
|
78
75
|
if (typeof to2 === "string") {
|
|
@@ -83,6 +80,30 @@ function getLocalizedRoute(to, router, route, i18nConfig, locale, hashLocale) {
|
|
|
83
80
|
}
|
|
84
81
|
return params;
|
|
85
82
|
};
|
|
83
|
+
if (i18nConfig.includeDefaultLocaleRoute) {
|
|
84
|
+
const defaultLocale = i18nConfig.defaultLocale;
|
|
85
|
+
let resolvedTo = to;
|
|
86
|
+
if (typeof to === "string") {
|
|
87
|
+
resolvedTo = router.resolve("/" + defaultLocale + to);
|
|
88
|
+
}
|
|
89
|
+
const defaultRouteName = getRouteName(resolvedTo, defaultLocale);
|
|
90
|
+
const newParams2 = resolveParams(to);
|
|
91
|
+
newParams2.locale = defaultLocale;
|
|
92
|
+
if (router.hasRoute(`localized-${defaultRouteName}`)) {
|
|
93
|
+
to = router.resolve({
|
|
94
|
+
name: `localized-${defaultRouteName}`,
|
|
95
|
+
params: newParams2
|
|
96
|
+
});
|
|
97
|
+
} else if (router.hasRoute(`localized-${defaultRouteName}-${defaultLocale}`)) {
|
|
98
|
+
to = router.resolve({
|
|
99
|
+
name: `localized-${defaultRouteName}-${defaultLocale}`,
|
|
100
|
+
params: newParams2
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
const currentLocale = locale || getCurrentLocale(route, i18nConfig, hashLocale);
|
|
105
|
+
const selectRoute = router.resolve(to);
|
|
106
|
+
const routeName = getRouteName(selectRoute, currentLocale).replace(new RegExp(`-${i18nConfig.defaultLocale}$`), "");
|
|
86
107
|
if (!routeName || routeName === "") {
|
|
87
108
|
const resolved = router.resolve(to);
|
|
88
109
|
let url = resolved.path.replace(new RegExp(`^/${currentLocale}/`), "/");
|
|
@@ -53,7 +53,7 @@ export default defineNuxtPlugin(async (_nuxtApp) => {
|
|
|
53
53
|
if (Object.values(normalizedLocales).length) {
|
|
54
54
|
if (normalizedLocales[currentLocale]) {
|
|
55
55
|
const translation = normalizedLocales[currentLocale];
|
|
56
|
-
const { $mergeTranslations } = useNuxtApp()
|
|
56
|
+
const { $mergeTranslations } = useNuxtApp();
|
|
57
57
|
$mergeTranslations(translation);
|
|
58
58
|
}
|
|
59
59
|
if (!normalizedLocales[currentLocale]) {
|
|
@@ -48,7 +48,7 @@ export default defineNuxtPlugin(async (nuxtApp) => {
|
|
|
48
48
|
if (i18nConfig.hashMode) {
|
|
49
49
|
hashCookie.value = detectedLocale;
|
|
50
50
|
}
|
|
51
|
-
await navigateTo(router.resolve({ name: newRouteName, params: newParams }).href, { redirectCode:
|
|
51
|
+
await navigateTo(router.resolve({ name: newRouteName, params: newParams }).href, { redirectCode: 302, external: true });
|
|
52
52
|
} else {
|
|
53
53
|
userLocaleCookie.value = defaultLocale;
|
|
54
54
|
if (i18nConfig.hashMode) {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "nuxt-i18n-micro",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.30.1",
|
|
4
4
|
"description": "Nuxt I18n Micro is a lightweight, high-performance internationalization module for Nuxt, designed to handle multi-language support with minimal overhead, fast build times, and efficient runtime performance.",
|
|
5
5
|
"repository": "s00d/nuxt-i18n-micro",
|
|
6
6
|
"license": "MIT",
|
|
@@ -44,7 +44,7 @@
|
|
|
44
44
|
"dev:build": "nuxi build playground",
|
|
45
45
|
"dev:prepare": "nuxt-module-build build --stub && nuxt-module-build prepare && nuxi prepare playground",
|
|
46
46
|
"dev:generate": "nuxi generate playground",
|
|
47
|
-
"release": "npm run lint && npm run test && npm run prepack && changelogen --release && npm publish && git push --follow-tags",
|
|
47
|
+
"release": "npm run lint && npm run typecheck && npm run test && npm run prepack && changelogen --release && npm publish && git push --follow-tags",
|
|
48
48
|
"lint": "eslint .",
|
|
49
49
|
"lint:fix": "eslint . --fix",
|
|
50
50
|
"test": "playwright test --grep-invert \"test/performance\\.test\\.ts\"",
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"id":"66d7665e-5819-42e7-bffd-4eea374483d8","timestamp":1729592509211,"matcher":{"static":{},"wildcard":{},"dynamic":{}},"prerendered":[]}
|