Description
Problem
Currently this library seems to ignore format
information on data types. Most formats just add some metadata, so they are fine to skip, but format: date-time
actually has semantic meaning that could be understood by a typescript client.
Right now, if we have a model definition like this:
"SomeType": {
"properties": {
"created": {
"type": "string",
"format": "date-time"
}
}
}
it generates this kind of model:
interface SomeType {
created: string;
}
There is no way for the client to know that this string represents a date. It would be really useful if it could generate this model instead:
interface SomeType {
created: Date;
}
Implementation
I realize that adding custom data transformations is tricky and probably outside the scope of this library. But making only dates work might actually be possible.
Serializing data would be relatively straightforward. JSON serialization would just work. For form serialization there would need to be a special case for Date
instances.
The main challenge for implementation seems to make safeParseResponse work, because type information is not available at run-time. I think the only way to make that work is generate a custom parser per API type. Is that outside the scope of this library too?
Further steps
I'd be happy to lend a hand if you think this would be a useful addition to the library. I am aware that templates can be customized, so I might also be able to work around this if necessary.