BCP-47 language tags types and validators.
Always bear in mind that the golden rule is to keep your language tag as short as possible. Only add further subtags to your language tag if they are needed to distinguish the language from something else in the context where your content is used.
What is a language tag?
A language tag is a code that represents a language. It is used to identify the language of a text or other content. Language tags are defined by the IETF in BCP-47.
Validation
Further information on choosing the language tag for your content can be found in the W3C article on choosing language tags.
/^(
(?<grandfathered>
(en-GB-oed|i-ami|i-bnn|i-default|i-enochian|i-hak|i-klingon|i-lux|
i-mingo|i-navajo|i-pwn|i-tao|i-tay|i-tsu|sgn-BE-FR|sgn-BE-NL|sgn-CH-DE)|
(art-lojban|cel-gaulish|no-bok|no-nyn|zh-guoyu|zh-hakka|zh-min|zh-min-nan|zh-xiang)
)|
(
(?<language>
([A-Za-z]{2,3}(-(?<extlang>[A-Za-z]{3}(-[A-Za-z]{3}){0,2}))?)
([A-Za-z]{2,3}(-(?<extlang>[A-Za-z]{3}(-[A-Za-z]{3}){0,2}))?)|
[A-Za-z]{4}|[A-Za-z]{5,8}
)
(-(?<script>[A-Za-z]{4}))?
(-(?<region>[A-Za-z]{2}|[0-9]{3}))?
(-(?<variant>[A-Za-z0-9]{5,8}|[0-9][A-Za-z0-9]{3}))*
(-(?<extension>[0-9A-WY-Za-wy-z](-[A-Za-z0-9]{2,8})+))*
(-(?<privateUse>x(-[A-Za-z0-9]{1,8})+))?
)
|
(?<privateUse>x(-[A-Za-z0-9]{1,8})+)
)$/;
How to use
Use this library to validate language tags in your application.
You can import the types to validate language tags in your application:
import { LanguageTag } from "@inlang/language-tag"
myLanguageTag = exampleTag as LanguageTag
Install
You can install the @inlang/cli with this command:
npm install @inlang/language-tag
or
yarn add @inlang/language-tag