-
Notifications
You must be signed in to change notification settings - Fork 6.8k
Description
Bug, feature request, or proposal:
Bug (probably, otherwise docs need to be updated to clarify this behavior).
What is the expected behavior?
I expect the entire application to be in a certain locale, thus it should be enough to set it once using the DateAdapter's setLocale(..)
.
What is the current behavior?
Apparently the DateAdapter
is not a single instance, but rather lazy modules get their own instance. As a result, setting the locale (like in the app.component.ts
might not work (as one expects) when loading some components within a lazy loaded module (via routing).
What are the steps to reproduce?
Here's a Stackblitz to reproduce the issue: https://stackblitz.com/edit/angular-material-datepicker-locale?file=src%2Fapp%2Fapp.component.ts
- Clicking the "test" link loads the lazy
/test
route. Both,app.module
andlazy.module
importSharedModule
which imports the Material stuff. - The datepicker is in English by default. Clicking the button "set locale on app module" should set it to German, but it doesn't.
- Clicking the button "set locale in lazy module" however works as expected.
That makes me think there are 2 instances of the DateAdapter
, one for the lazy module and one for the app module.
What is the use-case or motivation for changing an existing behavior?
Usually the locale is very much related to the application language. In most cases you load the user profile when the app starts and based on his settings, cookies or whatever, you set the language and locale respectively. Similarly at the same point you also want to adjust other components' locales such as the Material Datepicker.
The current behavior however is misleading, as one might expect that setting the locale on the DateAdapter
object should automatically adjust them for all datepickers. Due to the bug that is not the case for lazy loaded modules however.