Skip to content

Commit

Permalink
Merge pull request #2 from GregJPreece/master
Browse files Browse the repository at this point in the history
Adding Typescript definitions
  • Loading branch information
TiagoDanin authored May 24, 2020
2 parents 56733d2 + 30cc25f commit 0730e35
Show file tree
Hide file tree
Showing 2 changed files with 115 additions and 0 deletions.
9 changes: 9 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,15 @@ locale.all // [language: '...]
locale.getByTag('pt-br').name // 'Portuguese'
```

Or in Typescript:

```typescript
import * as LocaleCodes from "locale-codes";

LocaleCodes.all // ILocale[]
LocaleCodes.getByTag('pt-br').name // 'Portuguese'
```

## Documentation

### API
Expand Down
106 changes: 106 additions & 0 deletions index.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
declare module 'locale-codes' {

/**
* Represents a single locale and its properties
*/
export interface ILocale {

/**
* The name of the locale in English
*/
name: string;

/**
* The name of the language/locale as recognised by those who use it
* e.g. Arabic becomes: العربية
*/
local?: string;

/**
* A textual name of the geographic location in which this
* locale/language is generally utilised
*/
location?: string;

/**
* Tag for the locale - e.g. English (UK) becomes: en-GB
* Provided by LCID
*/
tag: string;

/**
* Windows LCID decimal identifier for a locale
* e.g. English (UK) becomes: 2057
*/
lcid: number;

/**
* Three-letter ISO 639-2 code for the given locale
* NOTE: Where differing codes appear in ISO 639-2/B and ISO 639-2/T,
* both are provided separated by a slash (B/T)
* e.g. Basque becomes: baq/eus
*/
'iso639-2'?: string;

/**
* Two-letter ISO 639-1 code for the given locale
* e.g. English becomes: en
*/
'iso639-1'?: string;
}

/**
* Array of every locale code available
*/
export const all: ILocale[];

/**
* Searches for a locale according to the parameter and value given
* @param key Parameter to search - name, tag, etc (see ILocale)
* @param text The value to search for
*/
export function where(key?: string, text?: string): ILocale;

/**
* Searches for a locale according to the English name given
* @param text English name of the locale to find
*/
export function getByName(text: string): ILocale;

/**
* Searches for a locale according to its localised name
* @param text Localised name of the locale to find
*/
export function getByNameLocal(text: string): ILocale;

/**
* Searches for a locale according to its geographic location
* @param text Locale's geographic location - e.g. "Spain"
*/
export function getByLocation(text: string): ILocale;

/**
* Searches for a locale according to its tag
* @param text Locale tag - e.g. "en-GB"
*/
export function getByTag(text: string): ILocale;

/**
* Searches for a locale according to its Window LCID decimal code
* @param id LCID decimal code - e.g. 2057
*/
export function getByLCID(id: number): ILocale;

/**
* Searches for a locale according to its three-character ISO 639-2 code
* @param text ISO 639-2 code - e.g. "eng"
*/
export function getByISO6392(text: string): ILocale;

/**
* Searches for a locale according to its two-character ISO 639-1 code
* @param text ISO 639-1 code - e.g. "en"
*/
export function getByISO6391(text: string): ILocale;

}

0 comments on commit 0730e35

Please sign in to comment.