(old name "Intl Temporal Proposal")
To specify necessary details about era, eraYear and monthCode usage with Temporal in internationalization setting (for calendars other than "iso8601").
This proposal is advanced to Stage 1 for ECMA402 during the TC39 meeting, Dec 1 2022.
- Intl era and monthCode proposal for Stage 1, TC39 Nov 2022 Meeting, Nov 29-Dec 1, 2022
- Intl era and monthCode proposal for Stage 2, TC39 Jan 2023 Meeting, Jan 23-Jan 26, 2023
- Draft Spec
- Study of modles of year and era in ICU Calendar
- Temporal Internationalization Calendars Design Doc.
Temporal proposal is a ECMA262 Stage proposal to “provide standard objects and functions for working with dates and times.” The Temporal proposal specification text clearly specified how the “iso8601” Calendar and “UTC” TimeZone should behave as well as define name and some basic aspect of Calenders other than “iso8601” and TimeZone other than “UTC”. However, there are additional requirements needed for implementation purposes. This proposal aims to define these details which should be eventually merged into ECMA402 specification.
We believe the following Abstract Opertaions defined in the Temporal proposal need to be defined in more details in this proposal:
- 15.6.1.3 CalendarDateToISO ( calendar, fields, overflow )
- Need to specify the condition of throwing RangeError exception
- 15.6.1.4 CalendarDateAddition ( calendar, date, duration, overflow )
- Need to specify the condition of throwing RangeError exception
- 15.6.1.5 CalendarDateDifference ( calendar, one, two, largestUnit )
- Need to specify the condition of throwing RangeError exception
- 15.6.1.6 CalendarDateEra ( calendar, date )
- Need to define the possible era codes for each calendar and which calnedar will return undefined.
- 15.6.1.7 CalendarDateEraYear ( calendar, date() )
- Need to define which calnedar will return undefined.
- 15.6.1.9 CalendarDateMonth ( calendar, date )
- Need to define the meaning of month for some calendars.
- 15.6.1.10 CalendarDateMonthCode ( calendar, date )
- Need to define the valid set of monthCodes for each calendar.
- 15.6.1.20 CalendarDateFields ( calendar, fields )
- Need to define which calendar will add "era" and "eraYear".
- 15.6.1.21 CalendarDateMergeFields ( calendar, fields, additionalFields )
- Need to define which calendar will merge "era" and "eraYear" and how it merge "era" and "eraYear" .
We may choose to specify certain calendar arithmetic for some calendars if they are very simple to conver from/to "iso8601" calendar- For example, for "gregory", "roc", "buddhist", "japanese" calendar, but leave the arithmetic in vague language for others.
We are NOT aiming to specify the calendar arithmetic for the following part of Temporal proposal:
- 15.6.1.8 CalendarDateYear ( calendar, date )
- 15.6.1.11 CalendarDateDay ( calendar, date )
- 15.6.1.12 CalendarDateDayOfWeek ( calendar, date )
- 15.6.1.13 CalendarDateDayOfYear ( calendar, date )
- 15.6.1.14 CalendarDateWeekOfYear ( calendar, date )
- 15.6.1.15 CalendarDateDaysInWeek ( calendar, date )
- 15.6.1.16 CalendarDateDaysInMonth ( calendar, date )
- 15.6.1.17 CalendarDateDaysInYear ( calendar, date )
- 15.6.1.18 CalendarDateMonthsInYear ( calendar, date )
- 15.6.1.19 CalendarDateInLeapYear ( calendar, date )
Related spec text in Temporal proposal:
- 15.6.2.6 Temporal.Calendar.prototype.era ( temporalDateLike )
- 15.6.5.2 get Temporal.PlainDate.prototype.era
- 15.6.6.2 get Temporal.PlainDateTime.prototype.era
- 15.6.9.2 get Temporal.PlainYearMonth.prototype.era
- 15.6.10.2 get Temporal.ZonedDateTime.prototype.era
- 15.6.1.3 CalendarDateToISO ( calendar, fields, overflow )
For Calendar:
-
List of 'calendar': CLDR and ICU support the following calendars beside "iso8601" and currently supported by Intl.DateTimeFormat API in different browsers.
- "gregory""
- "roc" (same as "gregory" except handling of era and year)
- "buddhist" (same as "gregory" except handling of era and year)
- "japanese" (same as "gregory" except handling of era and year)
- "persian"
- "coptic"
- "ethiopic"
- "ethiopic-ameta-alem" (same as "ethiopic" except handling of era and year)
- "indian""
- "hebrew"
- "chinese"
- "dangi" (same as "chinese" except the referencing timeZone)
- "islamic"
- "islamic-tbla"
- "islamic-umalqura"
- "islamic-civil"
-
Requirement for era and eraYear:
- The combination of era and eraYear in a calendar need to be able to uniquely identify a particular year in the timeline.
- era need to be a String (per 15.6.1.1 CalendarEra in Temporal).
- eraYear need to be an Integer (per 15.6.1.2 CalendarEraYear in Temporal).
- If there is only one era in a calendar, we do not need to and should avoid using the era/eraYear in that calendar (e.g. "hebrew", "persian")
- If we define era, we need to also define the behavior if the field(s) is/are absent. (fallback to use year or fallback to a default value and what is the default value)
-
'gregory': TBW
Related spec text in Temporal proposal:
- 15.6.2.7 Temporal.Calendar.prototype.eraYear ( temporalDateLike )
- 15.6.5.3 get Temporal.PlainDate.prototype.eraYear
- 15.6.6.3 get Temporal.PlainDateTime.prototype.eraYear
- 15.6.9.3 get Temporal.PlainYearMonth.prototype.eraYear
- 15.6.10.3 get Temporal.ZonedDateTime.prototype.eraYear
- 15.6.1.3 CalendarDateToISO ( calendar, fields, overflow )
For Calendar:
- 'gregory': TBW
Related spec text in Temporal proposal: *
For Calendar:
- 'gregory': TBW
Related spec text in Temporal proposal: *
For Calendar:
- 'gregory': TBW
Please ensure the following:
- You have read the process document
- You have reviewed the existing proposals
- You are aware that your proposal requires being a member of TC39, or locating a TC39 delegate to "champion" your proposal
Follow these steps:
- Click the green "use this template" button in the repo header. (Note: Do not fork this repo in GitHub's web interface, as that will later prevent transfer into the TC39 organization)
- Update the biblio to the latest version:
npm install --save-dev --save-exact @tc39/ecma262-biblio@latest
. - Go to your repo settings “Options” page, under “GitHub Pages”, and set the source to the main branch under the root (and click Save, if it does not autosave this setting)
- check "Enforce HTTPS"
- On "Options", under "Features", Ensure "Issues" is checked, and disable "Wiki", and "Projects" (unless you intend to use Projects)
- Under "Merge button", check "automatically delete head branches"
-
"How to write a good explainer" explains how to make a good first impression.
Each TC39 proposal should have a
README.md
file which explains the purpose of the proposal and its shape at a high level....
The rest of this page can be used as a template ...
Your explainer can point readers to the
index.html
generated fromspec.emu
via markdown likeYou can browse the [ecmarkup output](https://ACCOUNT.github.io/PROJECT/) or browse the [source](https://github.com/ACCOUNT/PROJECT/blob/HEAD/spec.emu).
where ACCOUNT and PROJECT are the first two path elements in your project's Github URL. For example, for github.com/tc39/template-for-proposals, ACCOUNT is "tc39" and PROJECT is "template-for-proposals".
- Make your changes to
spec.emu
(ecmarkup uses HTML syntax, but is not HTML, so I strongly suggest not naming it ".html") - Any commit that makes meaningful changes to the spec, should run
npm run build
and commit the resulting output. - Whenever you update
ecmarkup
, runnpm run build
and commit any changes that come from that dependency.