nuxt-i18n-micro 1.10.1 → 1.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- import{i as o,r as u,g as f,h as d,j as v,k as l,l as i,m as h,n as m}from"./D1fvHJQV.js";function U(t,a={}){const e=a.head||o();if(e)return e.ssr?e.push(t,a):p(e,t,a)}function p(t,a,e={}){const s=u(!1),n=u({});f(()=>{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};
1
+ import{i as o,r as u,g as f,h as d,j as v,k as l,l as i,m as h,n as m}from"./CX2tGbR4.js";function U(t,a={}){const e=a.head||o();if(e)return e.ssr?e.push(t,a):p(e,t,a)}function p(t,a,e={}){const s=u(!1),n=u({});f(()=>{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};
@@ -1 +1 @@
1
- {"id":"12fb941a-fcb7-4438-a5ba-415cd42d46f9","timestamp":1725088672978}
1
+ {"id":"188e6c4c-cf5a-4166-a467-e82e4c5b743c","timestamp":1725090966238}
@@ -0,0 +1 @@
1
+ {"id":"188e6c4c-cf5a-4166-a467-e82e4c5b743c","timestamp":1725090966238,"matcher":{"static":{},"wildcard":{},"dynamic":{}},"prerendered":[]}
@@ -1 +1 @@
1
- import{u as o}from"./DxMn4SAe.js";import{_ as a,o as s,c as i,a as e,t as r,p as u,f as l}from"./D1fvHJQV.js";const c=t=>(u("data-v-b63e9691"),t=t(),l(),t),d={class:"font-sans antialiased bg-white dark:bg-black text-black dark:text-white grid min-h-screen place-content-center overflow-hidden"},p=c(()=>e("div",{class:"fixed -bottom-1/2 left-0 right-0 h-1/2 spotlight"},null,-1)),h={class:"max-w-520px text-center"},b=["textContent"],g=["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 n=t;return o({title:`${n.statusCode} - ${n.statusMessage} | ${n.appName}`,script:[],style:[{children:'*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:var(--un-default-border-color, #e5e7eb)}:before,:after{--un-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;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;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}h1{font-size:inherit;font-weight:inherit}h1,p{margin:0}*,:before,:after{--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 rgb(0 0 0 / 0);--un-ring-shadow:0 0 rgb(0 0 0 / 0);--un-shadow-inset: ;--un-shadow:0 0 rgb(0 0 0 / 0);--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgb(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: }'}]}),(m,x)=>(s(),i("div",d,[p,e("div",h,[e("h1",{class:"text-8xl sm:text-10xl font-medium mb-8",textContent:r(t.statusCode)},null,8,b),e("p",{class:"text-xl px-8 sm:px-0 sm:text-4xl font-light mb-16 leading-tight",textContent:r(t.description)},null,8,g)])]))}},w=a(f,[["__scopeId","data-v-b63e9691"]]);export{w as default};
1
+ import{u as o}from"./DulLifOC.js";import{_ as a,o as s,c as i,a as e,t as r,p as u,f as l}from"./CX2tGbR4.js";const c=t=>(u("data-v-b63e9691"),t=t(),l(),t),d={class:"font-sans antialiased bg-white dark:bg-black text-black dark:text-white grid min-h-screen place-content-center overflow-hidden"},p=c(()=>e("div",{class:"fixed -bottom-1/2 left-0 right-0 h-1/2 spotlight"},null,-1)),h={class:"max-w-520px text-center"},b=["textContent"],g=["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 n=t;return o({title:`${n.statusCode} - ${n.statusMessage} | ${n.appName}`,script:[],style:[{children:'*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:var(--un-default-border-color, #e5e7eb)}:before,:after{--un-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;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;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}h1{font-size:inherit;font-weight:inherit}h1,p{margin:0}*,:before,:after{--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 rgb(0 0 0 / 0);--un-ring-shadow:0 0 rgb(0 0 0 / 0);--un-shadow-inset: ;--un-shadow:0 0 rgb(0 0 0 / 0);--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgb(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: }'}]}),(m,x)=>(s(),i("div",d,[p,e("div",h,[e("h1",{class:"text-8xl sm:text-10xl font-medium mb-8",textContent:r(t.statusCode)},null,8,b),e("p",{class:"text-xl px-8 sm:px-0 sm:text-4xl font-light mb-16 leading-tight",textContent:r(t.description)},null,8,g)])]))}},w=a(f,[["__scopeId","data-v-b63e9691"]]);export{w as default};
@@ -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.DjxsrOxm.css">
4
- <link rel="modulepreload" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/D1fvHJQV.js">
4
+ <link rel="modulepreload" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/CX2tGbR4.js">
5
5
  <link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/B6E6ObS_.js">
6
6
  <link rel="prefetch" as="style" href="/__nuxt-i18n-micro/_nuxt/error-404.D-AvUzLt.css">
7
- <link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/BpNRGTHy.js">
8
- <link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/DxMn4SAe.js">
7
+ <link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/5O6Zkut2.js">
8
+ <link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/DulLifOC.js">
9
9
  <link rel="prefetch" as="style" href="/__nuxt-i18n-micro/_nuxt/error-500.21ZDxC33.css">
10
- <link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/DzdJBprQ.js">
11
- <script type="module" src="/__nuxt-i18n-micro/_nuxt/D1fvHJQV.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__">[{"serverRendered":1},false]</script>
12
- <script>window.__NUXT__={};window.__NUXT__.config={public:{},app:{baseURL:"/__nuxt-i18n-micro",buildId:"12fb941a-fcb7-4438-a5ba-415cd42d46f9",buildAssetsDir:"/_nuxt/",cdnURL:""}}</script></body></html>
10
+ <link rel="prefetch" as="script" crossorigin href="/__nuxt-i18n-micro/_nuxt/hsW9SqPc.js">
11
+ <script type="module" src="/__nuxt-i18n-micro/_nuxt/CX2tGbR4.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__">[{"serverRendered":1},false]</script>
12
+ <script>window.__NUXT__={};window.__NUXT__.config={public:{},app:{baseURL:"/__nuxt-i18n-micro",buildId:"188e6c4c-cf5a-4166-a467-e82e4c5b743c",buildAssetsDir:"/_nuxt/",cdnURL:""}}</script></body></html>
package/dist/module.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "nuxt-i18n-micro",
3
3
  "configKey": "i18n",
4
- "version": "1.10.1",
4
+ "version": "1.11.0",
5
5
  "builder": {
6
6
  "@nuxt/module-builder": "0.8.3",
7
7
  "unbuild": "2.0.0"
package/dist/module.mjs CHANGED
@@ -190,7 +190,7 @@ const module = defineNuxtModule({
190
190
  if (page.file) {
191
191
  const filePath = path.resolve(nuxt.options.rootDir, page.file);
192
192
  const fileContent = readFileSync(filePath, "utf-8");
193
- const i18nRouteConfig = extractDefineI18nRouteConfig(fileContent);
193
+ const i18nRouteConfig = extractDefineI18nRouteConfig(fileContent, filePath);
194
194
  if (i18nRouteConfig && i18nRouteConfig.localeRoutes) {
195
195
  customPaths[page.path] = i18nRouteConfig.localeRoutes;
196
196
  }
@@ -321,18 +321,32 @@ const module = defineNuxtModule({
321
321
  }
322
322
  }
323
323
  });
324
- function extractDefineI18nRouteConfig(content) {
324
+ function cleanObjectString(objectString) {
325
+ let cleanedString = objectString.replace(/'/g, '"');
326
+ cleanedString = cleanedString.replace(/([{,]\s*)(\w+)(\s*:)/g, '$1"$2"$3');
327
+ cleanedString = cleanedString.replace(/,(\s*[}\]])/g, "$1");
328
+ cleanedString = cleanedString.replace(/,+/g, ",");
329
+ cleanedString = cleanedString.replace(/(\{|\[)\s*,/g, "$1");
330
+ cleanedString = cleanedString.replace(/,(\s*[}\]])/g, "$1");
331
+ cleanedString = cleanedString.trim();
332
+ if (!cleanedString.startsWith("{") || !cleanedString.endsWith("}")) {
333
+ throw new Error("Invalid object format after cleaning");
334
+ }
335
+ return cleanedString;
336
+ }
337
+ function extractDefineI18nRouteConfig(content, path2) {
325
338
  const match = content.match(/\$defineI18nRoute\((\{[\s\S]*?\})\)/);
326
339
  if (match && match[1]) {
327
340
  try {
328
- const configObject = eval(`(${match[1]})`);
341
+ const cleanedString = cleanObjectString(match[1]);
342
+ const configObject = JSON.parse(cleanedString);
329
343
  if (validateDefineI18nRouteConfig(configObject)) {
330
344
  return configObject;
331
345
  } else {
332
- console.error("Invalid defineI18nRoute configuration format:", configObject);
346
+ console.error("Invalid defineI18nRoute configuration format:", configObject, "in file: ", path2);
333
347
  }
334
348
  } catch (error) {
335
- console.error("Failed to parse defineI18nRoute configuration:", error);
349
+ console.error("Failed to parse defineI18nRoute configuration:", error, "in file: ", path2);
336
350
  }
337
351
  }
338
352
  return null;
@@ -5,6 +5,8 @@ export function useI18n() {
5
5
  $getLocale: nuxtApp.$getLocale,
6
6
  $getLocales: nuxtApp.$getLocales,
7
7
  $t: nuxtApp.$t,
8
+ $tn: nuxtApp.$tn,
9
+ $td: nuxtApp.$td,
8
10
  $has: nuxtApp.$has,
9
11
  $tc: nuxtApp.$tc,
10
12
  $mergeTranslations: nuxtApp.$mergeTranslations,
@@ -12,6 +12,8 @@ declare const _default: import("#app").Plugin<{
12
12
  getLocales: () => Locale[];
13
13
  t: (key: string, params?: Record<string, string | number | boolean>, defaultValue?: string) => unknown;
14
14
  tc: (key: string, count: number, defaultValue?: string) => string;
15
+ tn: (value: number, options?: Intl.NumberFormatOptions) => string;
16
+ td: (value: Date | number | string, options?: Intl.DateTimeFormatOptions) => string;
15
17
  has: (key: string) => boolean;
16
18
  mergeTranslations: (newTranslations: Translations) => void;
17
19
  switchLocale: (locale: string) => void;
@@ -21,6 +23,8 @@ declare const _default: import("#app").Plugin<{
21
23
  getLocales: () => Locale[];
22
24
  t: (key: string, params?: Record<string, string | number | boolean>, defaultValue?: string) => unknown;
23
25
  tc: (key: string, count: number, defaultValue?: string) => string;
26
+ tn: (value: number, options?: Intl.NumberFormatOptions) => string;
27
+ td: (value: Date | number | string, options?: Intl.DateTimeFormatOptions) => string;
24
28
  has: (key: string) => boolean;
25
29
  mergeTranslations: (newTranslations: Translations) => void;
26
30
  switchLocale: (locale: string) => void;
@@ -32,6 +36,8 @@ export interface PluginsInjections {
32
36
  $getLocales: () => Locale[];
33
37
  $t: <T extends Record<string, string | number | boolean>>(key: string, params?: T, defaultValue?: string) => string | number | boolean | Translations | PluralTranslations | unknown[] | unknown | null;
34
38
  $tc: (key: string, count: number, defaultValue?: string) => string;
39
+ $tn: (value: number, options?: Intl.NumberFormatOptions) => string;
40
+ $td: (value: Date | number | string, options?: Intl.DateTimeFormatOptions) => string;
35
41
  $has: (key: string) => boolean;
36
42
  $mergeTranslations: (newTranslations: Translations) => void;
37
43
  $switchLocale: (locale: string) => void;
@@ -55,6 +55,12 @@ function getLocalizedRoute(to, router, route, i18nConfig, locale) {
55
55
  }
56
56
  return router.resolve({ name: newRouteName, params: newParams });
57
57
  }
58
+ function formatNumber(value, locale, options) {
59
+ return new Intl.NumberFormat(locale, options).format(value);
60
+ }
61
+ function formatDate(value, locale, options) {
62
+ return new Intl.DateTimeFormat(locale, options).format(new Date(value));
63
+ }
58
64
  export default defineNuxtPlugin(async (nuxtApp) => {
59
65
  const registerI18nModule = (translations, locale) => {
60
66
  i18nHelper.mergeGlobalTranslation(locale, translations);
@@ -117,6 +123,14 @@ export default defineNuxtPlugin(async (nuxtApp) => {
117
123
  const translation = getTranslation(key, {}, defaultValue);
118
124
  return plural(translation?.toString(), count, getCurrentLocale(useRoute(), i18nConfig));
119
125
  },
126
+ tn: (value, options) => {
127
+ const locale = getCurrentLocale(useRoute(), i18nConfig);
128
+ return formatNumber(value, locale, options);
129
+ },
130
+ td: (value, options) => {
131
+ const locale = getCurrentLocale(useRoute(), i18nConfig);
132
+ return formatDate(value, locale, options);
133
+ },
120
134
  has: (key) => {
121
135
  return !!getTranslation(key);
122
136
  },
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nuxt-i18n-micro",
3
- "version": "1.10.1",
3
+ "version": "1.11.0",
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",