Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bug with i18n and translation in component #703

Open
6 tasks done
juleshry opened this issue Mar 27, 2024 · 18 comments · May be fixed by #750
Open
6 tasks done

Bug with i18n and translation in component #703

juleshry opened this issue Mar 27, 2024 · 18 comments · May be fixed by #750
Labels
to triage This issue needs to be triaged

Comments

@juleshry
Copy link

Describe the bug

Hello,

First of all, thank you for building this project.

I'm working on a Nuxt project with i18n but I can't make histoire work correctly. I've been looking for the source of the problem and here's what I've discovered so far:

  • when the module @nuxtjs/i18n is active, there an error 500 displayed in the story iframe that says Cannot read properties of undefined (reading 'public'). I think it happens on module i18n initialization because it doesn't know the Nuxt App context or something (I'm not sure).
  • if I disabled the module @nuxtjs/i18n, there's an error when histoire is building that says RollupError: Expected ';', '}' or <eof>. I think this is due to translations 'in-component' using the <i18n></i18n> tag.

Reproduction

I have made a small project that reproduce the problem : https://stackblitz.com/edit/nuxt-starter-xfql3e?file=nuxt.config.ts

System Info

packages versions :
- nuxt: 3.10.3
- @nuxtjs/i18n: 8.2.0
- histoire: 0.17.14
- @histoire/plugin-vue: 0.17.14
- @histoire/plugin-nuxt: 0.17.14

Used Package Manager

npm

Validations

@juleshry juleshry added the to triage This issue needs to be triaged label Mar 27, 2024
Copy link

stackblitz bot commented Mar 27, 2024

Fix this issue in StackBlitz Codeflow Start a new pull request in StackBlitz Codeflow.

@SteinRobert
Copy link

I can confirm this and tracked it down to this change:
nuxt-modules/i18n#2828

Not sure what to do about it though. Any idea? I'd be happy to contribute.

@seosmmbusiness
Copy link

Same problem. Fresh install of Nuxt + I18n + Histoire

 "dependencies": {
    "@nuxtjs/i18n": "^8.3.0",
    "nuxt": "^3.11.1",
    "vue": "^3.4.21",
    "vue-router": "^4.3.0"
  },
  "devDependencies": {
    "@histoire/plugin-nuxt": "^0.17.15",
    "@histoire/plugin-vue": "^0.17.15",
    "histoire": "^0.17.15"
  }

juleshry pushed a commit to juleshry/histoire that referenced this issue Apr 12, 2024
…viors

remove useNuxtApp mock since it prevents some plugins to run (e.g. @nuxtjs/i18n). It fixes the issue histoire-dev#703 .
@kstraszewski
Copy link

Same problem here. Has someone manage to implement some kind of workaround?

@letoast
Copy link

letoast commented Apr 30, 2024

+1

@TheNaschkatze
Copy link

TheNaschkatze commented Jun 21, 2024

please take care of this i dont want to fork @letoast repo xD and i want to deploy our component documentation :)

@letoast
Copy link

letoast commented Jun 21, 2024

please take care of this i dont want to fork @letoast repo xD and i want to deploy our component documentation :)

TBH I'm going to try out nuxt storybook and see if everything works there.

@alexardra
Copy link

Having the same issue. As mentioned #703 (comment) - downgrading @nuxtjs/i18n to the version below 8.0.2 removed the error for me.

Would be nice to get some followup on this though.

@9M6
Copy link

9M6 commented Jul 30, 2024

+1

@BBoehm
Copy link

BBoehm commented Jul 31, 2024

Found a solution/workaround for our project:

Versions used (not tested with other versions):

  • nuxt: 3.12.2
  • @nuxtjs/i18n: 8.3.1
  • @nuxtjs/i18n-edge@8.0.0-rc.9-28375354.2a7ee97 (not sure if needed at all)
  • histoire: 0.17.17
  • @histoire/plugin-vue: 0.17.17
  • @histoire/plugin-nuxt: 0.17.17

Code adaptions

histoire.config.ts

process.env.IS_HISTOIRE = 'true'; // we need to know if we're running histoire or not

export default defineConfig({
  //...
});

nuxt.config.ts

export default defineNuxtConfig({
  //...
  modules: [
    //...
    process.env.IS_HISTOIRE === 'true' ? false : '@nuxtjs/i18n', // only use i18n outside histoire
  ],
});

histoire.setup.ts

export const setupVue3 = defineSetupVue3(({ app }) => {
  const pinia = createPinia();
  
  app.use(pinia); // no i18n here!

  window.useI18n = () => ({ // mock the useI18n function to not run into an error
    locale: 'xx',
    t: (string: string) => string,
  });
});

Notes

  • We're not using $t in our project.
    Histoire documentation suggests to use app.config.globalProperties.$t, but adding to the window object might work as well or better.
  • For useNuxtApp().$i18n only solution we found was to add a check if it exists, which is sufficient for our needs for now

Edit:
In case someone else searches for it:
For @nuxt/test-utils/module (needed for vitest) we're using the same strategy to temporarily disable it inside the nuxt.config; thereby enabling the common use of vitest and histoire.

@filiphazardous filiphazardous linked a pull request Aug 2, 2024 that will close this issue
10 tasks
@yuuzora
Copy link

yuuzora commented Oct 16, 2024

+1

2 similar comments
@juanlessa
Copy link

+1

@Riadz
Copy link

Riadz commented Oct 30, 2024

+1

@aqz236
Copy link

aqz236 commented Dec 17, 2024

Disabling @ nuxtjs/i18n in nuxt-config.ts is useful, but not elegant. I hope it can be compatible with i18n, and supporting i18n's history is very cool

export default defineNuxtConfig({
  modules: [
    process.env.IS_HISTOIRE === "true" ? false : "@nuxtjs/i18n",
  ],
  compatibilityDate: "2024-11-01",
  i18n: {
  },
});

@VanillaCocaCola
Copy link

+1
If I disable @nuxtjs/i18n, I encounter a different error.
Cannot read properties of undefined (reading 't')

"@histoire/plugin-nuxt": "^0.17.17",
 "nuxt": "^3.13.2",
  "@nuxtjs/i18n": "^8.0.2",

@genu
Copy link

genu commented Dec 20, 2024

If you disable the module, you'd also need to mock the composables that it provides.

@yuuzora
Copy link

yuuzora commented Jan 6, 2025

I'm confronted to another problem due to this. I'm using useLocalePath to navigate between routes in my project, while I was able to mock the t function like this successfully :
window.useI18n = () => ({ // mock the useI18n function to not run into an error locale: 'en', t: (string: string) => string, })

I'm hitting an error everytime "useLocalePath is not defined", and tried to mock it too but it's not working
window.useLocalePath = () => { return (path: string) => path; }

Did anyone manage to make this works ?

@BBoehm
Copy link

BBoehm commented Jan 13, 2025

@yuuzora did you try vi.stubGlobal for useLocalePath? Works for several other auto-imported composables for me.

Otherwise you can try mocking the whole import, e.g. in nuxt.config (see my previous post for process.env.IS_HISTOIRE:

alias: {
    ...(process.env.IS_HISTOIRE === 'true' // add the following aliases for histoire only
      ? {
        'path/to/composable': resolve(__dirname, './histoireMocks/myMockComposable'),
      } : {}

Then create ./histoireMocks/myMockComposable, and export a mock there.

Never tried it with an external library, but for internal composables that works for us.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
to triage This issue needs to be triaged
Projects
None yet
Development

Successfully merging a pull request may close this issue.