Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

valueAsTemporal: date/time input integration with JavaScript Temporal API #10882

Open
o-t-w opened this issue Dec 22, 2024 · 3 comments
Open
Labels
addition/proposal New features or enhancements needs implementer interest Moving the issue forward requires implementers to express interest topic: forms

Comments

@o-t-w
Copy link

o-t-w commented Dec 22, 2024

What problem are you trying to solve?

Now that Temporal is on its way to stage 4, it is worth considering how <input type="date">, <input type="time">, <input type="week">, <input type="month"> could integrate with this API.

What solutions exist today?

Getting the value of a date input with valueAsDate returns a Date object. The value of a date input can be set by providing a Date object to valueAsDate. Converting between a Date object and Temporal is possible but far from ideal. valueAsNumber returns the number of milliseconds since the Unix epoch, which is also problematic. The optimal approach at the moment is working with the string value of .value and converting using Temporal.PlainDate.from()/ Temporal.PlainDateTime.from() / Temporal.PlainTime.from().

How would you solve it?

Previous discussion: tc39/proposal-temporal#107 Below is the strawman from that thread updated with the current syntax (the Civil prefix has been changed to Plain).

Add a valueAsTemporal getter/setter to HTMLInputElement
<input type=date> accepts/returns PlainDate
<input type=time> accepts/returns PlainTime
<input type=datetime-local> accepts/returns PlainDateTime
<input type=month> accepts/returns PlainYearMonth

<input type=week> does not have a mapping.

Alternatively, separate valueAsPlainDate, valueAsPlainTime, valueAsPlainDateTime, valueAsPlainYearMonth.

@o-t-w o-t-w added addition/proposal New features or enhancements needs implementer interest Moving the issue forward requires implementers to express interest labels Dec 22, 2024
@o-t-w o-t-w changed the title date/time input integration with JavaScript Temporal API valueAsTemporal: date/time input integration with JavaScript Temporal API Dec 23, 2024
@hsivonen
Copy link
Member

AFAICT, the Plain objects need an associated calendar. Since HTML input does not deal with years before 0001, it seems to me that HTML does not already have constraints that only one of "iso8601" and "gregory" would fit given that type=week (clearly "iso8601") would not participate. Am I missing something? Is this already constrained in a way that answers which one the calendar should be? If not, I can think of spec principle reasons for saying "iso8601", but are there practical reasons for saying "gregory"?

CC @anba @dminor

@annevk
Copy link
Member

annevk commented Jan 16, 2025

@ptomato is there an overarching issue somewhere for tracking Temporal integration into the web platform?

@ptomato
Copy link

ptomato commented Jan 16, 2025

There wasn't one, but there is now: tc39/proposal-temporal#3075

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
addition/proposal New features or enhancements needs implementer interest Moving the issue forward requires implementers to express interest topic: forms
Development

No branches or pull requests

4 participants