-
-
Notifications
You must be signed in to change notification settings - Fork 145
Use start date, if one is supplied, for initial_visible_month. #687
Conversation
…al_visible_month is undefined.
f5bedde
to
f5afd37
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Needs a changelog and some tdd with a test (jest is sufficient) showing that the value gets assigned correctly with the fix - a case for each value that overrides the default / is incorrect without the fix.
src/utils/convertToMoment.js
Outdated
@@ -11,7 +11,9 @@ export default (newProps, momentProps) => { | |||
dest[key] = null; | |||
|
|||
if (key === 'initial_visible_month') { | |||
dest[key] = moment(); | |||
dest[key] = newProps['start_date'] || newProps['min_date_allowed'] ? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
From the PR:
the component is not responsive (nothing can be selected)
The selection is not actually disabled but as the initial month used to open the menu is after the end_date
the dates are disabled -- moving back to a month before the end_date
enables the menu. That said, this is a technicality, the behavior is unexpected and annoying especially if the date range is far in the future / past.
With the change here, the default behavior can also be confusig if end_date
or max_date_allowed
is set because they are not being used to decide the initial month displayed.
I think we could go further and also use end_date
and max_date_allowed
in determining the initial_visible_month
if start_date
and min_date_allowed
are not available.
With
from datetime import datetime as dt
import dash
from dash.dependencies import Input, Output
import dash_core_components as dcc
import dash_html_components as html
app = dash.Dash('app',
suppress_callback_exceptions=True)
app.layout = dcc.DatePickerRange(
id='date-picker-range',
# start_date = dt(2017, 1, 31),
end_date = dt(2018, 3, 21),
# min_date_allowed = dt(2017, 1, 31),
max_date_allowed = dt(2018, 3, 21),
)
if __name__ == "__main__":
app.run_server(debug=True)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So far I have start_date
-> min_date_allowed
, and it makes the most sense to me to then look for end_date
and max_date_allowed
in that order if neither of those values are supplied. Do you think this is the best order to use?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yup. Makes sense to me :) low current -> lowest -> high current -> highest
src/utils/convertToMoment.js
Outdated
dest[key] = newProps['start_date'] || newProps['min_date_allowed'] | ||
|| newProps['end_date'] || newProps['max_date_allowed'] ? | ||
moment(newProps['start_date'] || newProps['min_date_allowed'] | ||
|| newProps['end_date'] || newProps['max_date_allowed']) : | ||
moment(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since moment()
and moment(undefined)
are equivalent (but not moment(null)
🙄), this can be simplified to:
dest[key] = moment(newProps['start_date'] || newProps['min_date_allowed'] || newProps['end_date'] || newProps['max_date_allowed'] || undefined);
@shammamah One small suggested code change and |
e9cc38e
to
2d628c1
Compare
d15d912
to
c1bbde2
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
💃
Closes #679.