-
-
Notifications
You must be signed in to change notification settings - Fork 338
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
Spec for human readable date and time parsing #845
Comments
Here's the docs page with all info about how PostgreSQL parses dates and times: https://www.postgresql.org/docs/13/datetime-appendix.html Here's the page with info about date/time types: https://www.postgresql.org/docs/13/datatype-datetime.html |
So far we've been talking about human-language (human-readable is a bit of a misnomer, since a human can read ISO8601) relative time (e.g. 5 hours ago) and relative period (e.g. within last 5 hours) specification.
It's good for the user to get a lot of feedback about what implications we're making about his specification. I'm sometimes surprised by a device defaulting to weeks starting on Sundays (relevant when parsing "since last week" for example). Similarly, it's good to communicate to a user to what type (is it a date, a time, a period, a relative time, a relative period) his specifications will be parsed to. The most holistic approach might be to introduce new types for relative time/period specifications: "5 minutes ago" specifies a point in time relative to another unspecified point in time: so we save it as such (relative point in time) and let the user cast it to an absolute point in time if he wants to (he might not want to); if he does cast he can then specify the absolute point in time required to turn a relative point in time to an absolute. |
You've pointed out a number of things that we will need to specify. One quick note about:
I don't think the relative time has meaning beyond the |
Good point. I didn't realise |
After fiddling / struggling with the Questions:
Ideas I tried / partially implemented, then discarded:
|
Just to make sure I understand your question correctly, you're proposing that we standardize the API to always transfer date, time, date-time, and duration data as a string in conformance with ISO-8601. Correct? This would be opposed to, say, transferring a date as a unix timestamp number or as a formatted string like "Jan 27, 2022". If I'm understanding correctly, then yes! That sounds great! |
@seancolsen Yes, that's what I'm proposing. Note that the ISO8601 format is pretty ugly by default. Edit: The API will accept non-conforming strings and use the default PostgreSQL functionality to attempt to understand them (the PostgreSQL implementation is quite featureful). The returned value will always be ISO8601 conforming. |
@mathemancer I think it’s ok to have it later unless it creates inconsistencies for the user. If when we introduce it later we break things then it might be better to have it as part of this. I mean for the week date system. |
It wouldn't break anything to introduce later. It would be strictly additive. The reason I want to hold off is that only a few countries care about week numbers, and it adds a bunch of pain to the implementation. However, it is a feature that Germans using the product would probably expect. |
I think it's fine to use ISO8601 representations in the API and rely on the frontend to do date/time parsing when interacting with the API. We will still need to parse dates, times, and durations in the backend while doing imports. @mathemancer, it sounds like we're going to rely on default Postgres parsing here. Can you document what formats it supports or link to it when you write the spec? We should make sure that the frontend parsing is the same so that users can expect the same behavior however they enter dates. It's fine to defer support for the ISO week date system, please create a ticket to track the work and put it in the future consideration milestone. |
I also agree that it is better to always use one particular format, in this case ISO8601, for data returned by our APIs. The frontend can format it for display however required. |
Sure thing. |
@mathemancer Please close this once you're done with the spec updates. |
This was resolved in mathesar-foundation/mathesar-wiki#40 |
Problem
We'd like to support parsing human readable dates and times when users are interacting with data with date/time types. For example, a user might want to filter on a column "within the next 3 months" or "2 hours ago". However, we don't have a clear spec for what formats to support and how to make sure parsing is consistent across the frontend and backend.
Proposed solution
We should write a spec for what formats we will support and how to make sure it's consistent between the frontend and backend. We want frontend parsing so that we can validate user input without being slowed down by a round trip to the backend. We also want backend parsing so that we can parse data in bulk imports.
The desired output is a spec on the wiki's Architecture section that outlines a solution that works for both frontend and backend. Once the spec is ready, we will create new issues to implement it.
Additional context
TIME
data type in the backend #426The text was updated successfully, but these errors were encountered: