https://github.com/wojtekmaj/get-user-locale
A function that returns user's locale as an IETF language tag, based on all available sources.
https://github.com/wojtekmaj/get-user-locale
i18n language language-detection locale
Last synced: about 1 year ago
JSON representation
A function that returns user's locale as an IETF language tag, based on all available sources.
- Host: GitHub
- URL: https://github.com/wojtekmaj/get-user-locale
- Owner: wojtekmaj
- License: mit
- Created: 2018-08-15T09:17:55.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2025-04-30T19:09:34.000Z (about 1 year ago)
- Last Synced: 2025-05-08T20:53:40.928Z (about 1 year ago)
- Topics: i18n, language, language-detection, locale
- Language: TypeScript
- Homepage:
- Size: 3.48 MB
- Stars: 61
- Watchers: 2
- Forks: 10
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
[](https://www.npmjs.com/package/get-user-locale)  [](https://github.com/wojtekmaj/get-user-locale/actions)
# Get-User-Locale
A function that returns user's locale as an [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag), based on all available sources.
## tl;dr
- Install by executing `npm install get-user-locale` or `yarn add get-user-locale`.
- Import by adding `import getUserLocale from 'get-user-locale'`.
- Do stuff with it!
```ts
const userLocale = getUserLocale();
```
## User guide
### `getUserLocale()`
A function that returns user's preferred locale as an [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag), based on all available sources.
#### Sample usage
```ts
import getUserLocale from 'get-user-locale';
getUserLocale(); // 'de-DE'
```
or
```ts
import { getUserLocale } from 'get-user-locale';
getUserLocale(); // 'de-DE'
```
##### Options
`getUserLocale()` may be called with an optional `options` argument.
`options` object may contain the following properties:
| Property | Description | Default value |
| ------------------- | ----------------------------------- | ------------- |
| `fallbackLocale` | A locale to use as a fallback. | `en-US` |
| `useFallbackLocale` | Whether to use the fallback locale. | `true` |
### `getUserLocales()`
A function that returns an array of user's preferred locales as an [IETF language tags](https://en.wikipedia.org/wiki/IETF_language_tag), based on all available sources.
#### Sample usage
```ts
import { getUserLocales } from 'get-user-locale';
getUserLocales(); // ['de-DE', 'de', 'en-US', 'en']
```
##### Options
`getUserLocales()` may be called with an optional `options` argument.
`options` object may contain the following properties:
| Property | Description | Default value |
| ------------------- | ----------------------------------- | ------------- |
| `fallbackLocale` | A locale to use as a fallback. | `en-US` |
| `useFallbackLocale` | Whether to use the fallback locale. | `true` |
## Technical details
There are a few ways of determining user's locale:
- `window.navigator.languages`
- `window.navigator.language`
`…languages` is an array of strings, `…language` is a string. Some browsers return mixed-case [IETF language tags](https://en.wikipedia.org/wiki/IETF_language_tag) (e.g. `de-DE`), while others return lowercase ones (e.g. `de-de`). Finally, non-browser environments will not return anything, so you need a fallback.
Get-User-Locale does the following:
- Combines all of them into one sane set of locales - in that particular order,
- Dedupes them,
- Fixes invalid, lowercased [IETF language tags](https://en.wikipedia.org/wiki/IETF_language_tag) (so that the part after `-` is always uppercased),
- Adds a fallback to `en-US`, so if all else fails, you will get a result that won't crash your app.
## License
The MIT License.
## Author