Skip to content

Parses the accept-language header from an HTTP request and produces an array of language objects sorted by quality.

License

MPL-2.0, MIT licenses found

Licenses found

MPL-2.0
LICENSE
MIT
LICENSE-OPENTABLE
Notifications You must be signed in to change notification settings

escapace/accept-language-parser

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

accept-language-parser

Parses the accept-language header from an HTTP request and produces an array of language objects sorted by quality.

Installation

npm install @escapace/accept-language-parser

API

parse(acceptLanguageHeader)

import { parse } from '@escapace/accept-language-parser'

const languages = parse('en-GB,en;q=0.8')

console.log(languages)

Output will be:

;[
  {
    code: 'en',
    region: 'GB',
    quality: 1.0
  },
  {
    code: 'en',
    region: undefined,
    quality: 0.8
  }
]

Output is always sorted in quality order from highest -> lowest. As per the HTTP spec, omitting the quality value implies 1.0.

pick(supportedLangugagesArray, acceptLanguageHeader, options = {})

import { pick } from '@escapace/accept-language-parser'

const language = pick(
  ['fr-CA', 'fr-FR', 'fr'],
  'en-GB,en-US;q=0.9,fr-CA;q=0.7,en;q=0.8'
)

console.log(language)

Output will be:

'fr-CA'

The options supports the loose flag which allows partial matching on supported languages.

For example:

pick(['fr', 'en'], 'en-GB,en-US;q=0.9,fr-CA;q=0.7,en;q=0.8', {
  loose: true
})

Would return:

'fr'

In loose mode the order of supportedLanguagesArray matters, as it is the first partially matching language that is returned. It means that if you want to pick more specific langauges first, you should list it first as well.

For example:

;['fr-CA', 'fr']

About

Parses the accept-language header from an HTTP request and produces an array of language objects sorted by quality.

Resources

License

MPL-2.0, MIT licenses found

Licenses found

MPL-2.0
LICENSE
MIT
LICENSE-OPENTABLE

Code of conduct

Security policy

Stars

Watchers

Forks

Packages