-
-
Notifications
You must be signed in to change notification settings - Fork 68
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
Too strict types for e.g. selectedMonth
and FormatDateString
?
#327
Comments
I saw similar strictness when giving a try to the Beta release and looking at the internal code, I simply went with importing and using the same type as internal which is In real world, I would say that it's the |
@johanrd I agree with the month, but what about `FormatDateString'? Are there any options?) |
@uvarov-frontend I'm not sure if you heard about TypeScript
|
@ghiscoding This is useful to know, thanks, but as you noted, it is useless in this case. |
Maybe yes. But also maybe no; There are no runtime errors if you pass in e.g.
An option is to allow just a normal 'string': These return types are how many developers will pass dates into vanilla-calendar, and when they do, it may feel weird to need to cast or //@ts-ignore values you 'know will work in practice' when interacting with vanilla-calendar.
Yes. And this is of course highly subjective. I see there have been several discussions (36401, 43222). I do understand the usefulness/sophistication when manually typing dates – it just felt a bit unexpected when passing in return types of standard javascript date objects (and other date libraries). Another beauty of relying on the typescript return types, is that the bikeshedding I am now guilty of (sorry:p) is 'outsourced' to typescript. If/when typescript ever decides to narrow their types from 'simple' to 'correct', vanilla calendar will get the update 'for free' at the same time as the rest of the wider js ecosystem. |
@johanrd You can enter any knowledge in any format in the line and it would be strange to allow it and expect a normal reaction from the calendar, the same with the dates, why specify the 13th month of the calendar and count on the fact that there will be no error? Or we need to add validation for each disputed parameter, and I would not want to do it, since there is a typescript for this. And besides, you can import all existing types from the library and apply them, especially since there are not so many such parameters, but they bring clarity on which value is allowed and which is not. In any case, I agree with you that it is unexpected to receive a notification of a typing error when you use the standard method of receiving the month, but I think it is a problem that this method objects to the type of any number and not a range of real months. |
In short, I’ll close this because everything is clear already 😀 |
Currently the allowed type for
selectedMonth
is quite strict:This makes sense in an of itself, but given typescript's return type of
.getMonth()
is justnumber
, it feels strict that this return type gives an error:Not sure at all, it could easily be considered a bug in typescript, instead of a bug in vanilla-calendar pro.
The alternative approach is to type
selectedMonth: ReturnType<Date["getMonth"]>
. This way, the types of vanilla-calendar-pro just "uses the platform" (i.e. using the typescript types instead of maintaining its own type definitions), and will be updated automatically whenever typescript evolves.Posting as dx feedback, please feel free to close if you disagree.
The text was updated successfully, but these errors were encountered: