GraphCommerce builds on top of the Next.js internationalization feature.
Locales are UTS Locale Identifiers, a standardized format for defining locales.
Generally a Locale Identifier is made up of a language, region, and script
separated by a dash: language-region-script. The region and script are
optional. An example how to configure it in GraphCommerce:
const config = {
  storefront: [
    { locale: 'en-US', defaultLocale: true },
    { locale: 'nl-NL' },
    { locale: 'de' },
  ],
}
This will result in the following URLs:
https://www.graphcommerce.org/some-path/herehttps://www.graphcommerce.org/nl-NL/some-path/herehttps://www.graphcommerce.org/de/some-path/hereThe domains can be subdomains or top-level domains. The configuration is the same for both.
const config = {
  storefront: [
    { domain: 'www.graphcommerce.org', locale: 'en-US', defaultLocale: true },
    { domain: 'www.graphcommerce.org', locale: 'fr' },
    { domain: 'www.graphcommerce.nl', locale: 'nl-NL' },
    { domain: 'de.graphcommerce.org', locale: 'de-DE' },
  ],
}
This will result in the following URLs:
https://www.graphcommerce.org/some-path/herehttps://www.graphcommerce.org/fr/some-path/herehttps://www.graphcommerce.nl/some-path/herehttps://de.graphcommerce.org/some-path/hereNext.js does not allow reusing locales (even if it is on different domains), to
work around this, we're using the fact that a locale is allowed to have a
'script' value in the format: language-region-script. We use this part to
differentiate between the same locales on different domains.
Configuring the linguiLocale makes sure the correct translation file is loaded
here.
const config = {
  storefront: [
    { domain: 'domain1.com', locale: 'en-us-domain1', linguiLocale: 'en' },
    { domain: 'domain2.com', locale: 'en-us-domain2', linguiLocale: 'en' },
    { domain: 'domain3.com', locale: 'en-us-domain3', linguiLocale: 'en' },
  ],
}
Note: Available from GraphCommerce 8.1.0
Warning: Separating paths form locales will break Next.js' automatic redirect functionality.
const config = {
  storefront: [
    { locale: 'default', linguiLocale: 'en', defaultLocale: true },
    { locale: 'fr_fr', linguiLocale: 'fr' },
    { locale: 'nl_nl', linguiLocale: 'nl' },
  ],
}
This will result in the following URLs:
https://www.graphcommerce.org/some-path/herehttps://www.graphcommerce.org/fr_fr/some-path/herehttps://www.graphcommerce.org/nl_nl/some-path/here