Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/formatjs/date-time-format-timezone

Surgically polyfills timezone support in Intl.DateTimeFormat API
https://github.com/formatjs/date-time-format-timezone

cldr datetimeformat ecma-402 iana icu intl polyfill

Last synced: 2 months ago
JSON representation

Surgically polyfills timezone support in Intl.DateTimeFormat API

Awesome Lists containing this project

README

        

# Intl.DateTimeFormat timezone polyfill
Surgically polyfills timezone support in `Intl.DateTimeFormat` API

[![Build Status](https://travis-ci.org/formatjs/date-time-format-timezone.svg?branch=master)](https://travis-ci.org/formatjs/date-time-format-timezone) [![NPMRel](https://img.shields.io/npm/v/date-time-format-timezone.svg)](https://www.npmjs.com/package/date-time-format-timezone)

Some [browsers do not support arbitrary time zone ](http://kangax.github.io/compat-table/esintl/) in Intl.DateTimeFormat API (becuase its optional as per [ECMA-402 standard](https://www.ecma-international.org/ecma-402/1.0/#sec-6.4)). This polyfill is only to bring this support. Polyfill contains historical timezone data, CLDR data & tiny code to polyfill this support.

## How to use?

1. Install via nodejs:
```
npm i date-time-format-timezone
```
And then import in your code:
```
require('date-time-format-timezone'); // polyfill is ready
```

2. In the browser

include everything:
```

```
or include individual files:

```
<script src="https://unpkg.com/date-time-format-timezone@latest/build/browserified/date-time-format-timezone-no-data-min.js">
<script src="https://unpkg.com/date-time-format-timezone@latest/build/browserified/data/locales/locale-en-US-POSIX.js">
<script src="https://unpkg.com/date-time-format-timezone@latest/build/browserified/data/metazone.js">
<script src="https://unpkg.com/date-time-format-timezone@latest/build/browserified/data/timezones/tzdata-america-los_angeles.js">
```
This polyfill can add this support.

```javascript
new Intl.DateTimeFormat('hi', {
timeZone: 'Asia/Calcutta',
timeZoneName:'long',
year: 'numeric',
month: 'numeric',
day: 'numeric',
hour: 'numeric',
minute: 'numeric',
}).format(new Date());

"११/१/२०१७, पू १:२६ भारतीय मानक समय"

new Intl.DateTimeFormat('en', {
timeZone: 'America/Los_Angeles',
timeZoneName:'long',
year: 'numeric',
month: 'numeric',
day: 'numeric',
hour: 'numeric',
minute: 'numeric',
}).format(new Date());

"1/10/2017, 12:00 PM Pacific Standard Time"
```

## Support
| API |Support|
|--------------------------------- |------ |
| Intl.DateTimeFormat | ✅ |
| Date.toLocaleString | ✅ |
| Date.toLocaleTimeString | ✅ |
| Date.toLocaleTimeString | ✅ |

## Generate latest data from [www.iana.org](http://www.iana.org/time-zones).
```
git checkout https://github.com/yahoo/date-time-format-timezone.git
npm install
grunt download
grunt
npm publish
```

## Browserified file size

| | Minified | gzipped |
|----------------------------|----------|---------|
| complete | 2.64MB | 322KB |
| top zones<sup>1</sup> only no locale | 369.32KB | 71KB |
| all zones no locale | 303.19KB | 75KB |
| top zones<sup>1</sup> top locale<sup>2</sup> | 641.86KB | 148KB |

*1. top zones are custom listed timezones [here](https://github.com/yahoo/date-time-format-timezone/blob/master/tasks/gen-package.js#L51).

*2. top locales are custom listed locales [here](https://github.com/yahoo/date-time-format-timezone/blob/master/tasks/gen-package.js#L13).

## References
1. http://www.unicode.org/reports/tr35/tr35-dates.html#Using_Time_Zone_Names
1. http://icu-project.org/apiref/icu4j/com/ibm/icu/text/TimeZoneNames.html