1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC All Rights Reserved.
|
---|
4 | *
|
---|
5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
6 | * found in the LICENSE file at https://angular.io/license
|
---|
7 | */
|
---|
8 | import { Directive, ElementRef, forwardRef, Inject, Input, Optional, } from '@angular/core';
|
---|
9 | import { NG_VALIDATORS, NG_VALUE_ACCESSOR, Validators, } from '@angular/forms';
|
---|
10 | import { DateAdapter, MAT_DATE_FORMATS, } from '@angular/material/core';
|
---|
11 | import { MatFormField, MAT_FORM_FIELD } from '@angular/material/form-field';
|
---|
12 | import { MAT_INPUT_VALUE_ACCESSOR } from '@angular/material/input';
|
---|
13 | import { Subscription } from 'rxjs';
|
---|
14 | import { MatDatepickerInputBase } from './datepicker-input-base';
|
---|
15 | /** @docs-private */
|
---|
16 | export const MAT_DATEPICKER_VALUE_ACCESSOR = {
|
---|
17 | provide: NG_VALUE_ACCESSOR,
|
---|
18 | useExisting: forwardRef(() => MatDatepickerInput),
|
---|
19 | multi: true
|
---|
20 | };
|
---|
21 | /** @docs-private */
|
---|
22 | export const MAT_DATEPICKER_VALIDATORS = {
|
---|
23 | provide: NG_VALIDATORS,
|
---|
24 | useExisting: forwardRef(() => MatDatepickerInput),
|
---|
25 | multi: true
|
---|
26 | };
|
---|
27 | /** Directive used to connect an input to a MatDatepicker. */
|
---|
28 | export class MatDatepickerInput extends MatDatepickerInputBase {
|
---|
29 | constructor(elementRef, dateAdapter, dateFormats, _formField) {
|
---|
30 | super(elementRef, dateAdapter, dateFormats);
|
---|
31 | this._formField = _formField;
|
---|
32 | this._closedSubscription = Subscription.EMPTY;
|
---|
33 | this._validator = Validators.compose(super._getValidators());
|
---|
34 | }
|
---|
35 | /** The datepicker that this input is associated with. */
|
---|
36 | set matDatepicker(datepicker) {
|
---|
37 | if (datepicker) {
|
---|
38 | this._datepicker = datepicker;
|
---|
39 | this._closedSubscription = datepicker.closedStream.subscribe(() => this._onTouched());
|
---|
40 | this._registerModel(datepicker.registerInput(this));
|
---|
41 | }
|
---|
42 | }
|
---|
43 | /** The minimum valid date. */
|
---|
44 | get min() { return this._min; }
|
---|
45 | set min(value) {
|
---|
46 | const validValue = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
---|
47 | if (!this._dateAdapter.sameDate(validValue, this._min)) {
|
---|
48 | this._min = validValue;
|
---|
49 | this._validatorOnChange();
|
---|
50 | }
|
---|
51 | }
|
---|
52 | /** The maximum valid date. */
|
---|
53 | get max() { return this._max; }
|
---|
54 | set max(value) {
|
---|
55 | const validValue = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));
|
---|
56 | if (!this._dateAdapter.sameDate(validValue, this._max)) {
|
---|
57 | this._max = validValue;
|
---|
58 | this._validatorOnChange();
|
---|
59 | }
|
---|
60 | }
|
---|
61 | /** Function that can be used to filter out dates within the datepicker. */
|
---|
62 | get dateFilter() { return this._dateFilter; }
|
---|
63 | set dateFilter(value) {
|
---|
64 | const wasMatchingValue = this._matchesFilter(this.value);
|
---|
65 | this._dateFilter = value;
|
---|
66 | if (this._matchesFilter(this.value) !== wasMatchingValue) {
|
---|
67 | this._validatorOnChange();
|
---|
68 | }
|
---|
69 | }
|
---|
70 | /**
|
---|
71 | * Gets the element that the datepicker popup should be connected to.
|
---|
72 | * @return The element to connect the popup to.
|
---|
73 | */
|
---|
74 | getConnectedOverlayOrigin() {
|
---|
75 | return this._formField ? this._formField.getConnectedOverlayOrigin() : this._elementRef;
|
---|
76 | }
|
---|
77 | /** Gets the ID of an element that should be used a description for the calendar overlay. */
|
---|
78 | getOverlayLabelId() {
|
---|
79 | if (this._formField) {
|
---|
80 | return this._formField.getLabelId();
|
---|
81 | }
|
---|
82 | return this._elementRef.nativeElement.getAttribute('aria-labelledby');
|
---|
83 | }
|
---|
84 | /** Returns the palette used by the input's form field, if any. */
|
---|
85 | getThemePalette() {
|
---|
86 | return this._formField ? this._formField.color : undefined;
|
---|
87 | }
|
---|
88 | /** Gets the value at which the calendar should start. */
|
---|
89 | getStartValue() {
|
---|
90 | return this.value;
|
---|
91 | }
|
---|
92 | ngOnDestroy() {
|
---|
93 | super.ngOnDestroy();
|
---|
94 | this._closedSubscription.unsubscribe();
|
---|
95 | }
|
---|
96 | /** Opens the associated datepicker. */
|
---|
97 | _openPopup() {
|
---|
98 | if (this._datepicker) {
|
---|
99 | this._datepicker.open();
|
---|
100 | }
|
---|
101 | }
|
---|
102 | _getValueFromModel(modelValue) {
|
---|
103 | return modelValue;
|
---|
104 | }
|
---|
105 | _assignValueToModel(value) {
|
---|
106 | if (this._model) {
|
---|
107 | this._model.updateSelection(value, this);
|
---|
108 | }
|
---|
109 | }
|
---|
110 | /** Gets the input's minimum date. */
|
---|
111 | _getMinDate() {
|
---|
112 | return this._min;
|
---|
113 | }
|
---|
114 | /** Gets the input's maximum date. */
|
---|
115 | _getMaxDate() {
|
---|
116 | return this._max;
|
---|
117 | }
|
---|
118 | /** Gets the input's date filtering function. */
|
---|
119 | _getDateFilter() {
|
---|
120 | return this._dateFilter;
|
---|
121 | }
|
---|
122 | _shouldHandleChangeEvent(event) {
|
---|
123 | return event.source !== this;
|
---|
124 | }
|
---|
125 | }
|
---|
126 | MatDatepickerInput.decorators = [
|
---|
127 | { type: Directive, args: [{
|
---|
128 | selector: 'input[matDatepicker]',
|
---|
129 | providers: [
|
---|
130 | MAT_DATEPICKER_VALUE_ACCESSOR,
|
---|
131 | MAT_DATEPICKER_VALIDATORS,
|
---|
132 | { provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MatDatepickerInput },
|
---|
133 | ],
|
---|
134 | host: {
|
---|
135 | 'class': 'mat-datepicker-input',
|
---|
136 | '[attr.aria-haspopup]': '_datepicker ? "dialog" : null',
|
---|
137 | '[attr.aria-owns]': '(_datepicker?.opened && _datepicker.id) || null',
|
---|
138 | '[attr.min]': 'min ? _dateAdapter.toIso8601(min) : null',
|
---|
139 | '[attr.max]': 'max ? _dateAdapter.toIso8601(max) : null',
|
---|
140 | // Used by the test harness to tie this input to its calendar. We can't depend on
|
---|
141 | // `aria-owns` for this, because it's only defined while the calendar is open.
|
---|
142 | '[attr.data-mat-calendar]': '_datepicker ? _datepicker.id : null',
|
---|
143 | '[disabled]': 'disabled',
|
---|
144 | '(input)': '_onInput($event.target.value)',
|
---|
145 | '(change)': '_onChange()',
|
---|
146 | '(blur)': '_onBlur()',
|
---|
147 | '(keydown)': '_onKeydown($event)',
|
---|
148 | },
|
---|
149 | exportAs: 'matDatepickerInput',
|
---|
150 | },] }
|
---|
151 | ];
|
---|
152 | MatDatepickerInput.ctorParameters = () => [
|
---|
153 | { type: ElementRef },
|
---|
154 | { type: DateAdapter, decorators: [{ type: Optional }] },
|
---|
155 | { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [MAT_DATE_FORMATS,] }] },
|
---|
156 | { type: MatFormField, decorators: [{ type: Optional }, { type: Inject, args: [MAT_FORM_FIELD,] }] }
|
---|
157 | ];
|
---|
158 | MatDatepickerInput.propDecorators = {
|
---|
159 | matDatepicker: [{ type: Input }],
|
---|
160 | min: [{ type: Input }],
|
---|
161 | max: [{ type: Input }],
|
---|
162 | dateFilter: [{ type: Input, args: ['matDatepickerFilter',] }]
|
---|
163 | };
|
---|
164 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input.js","sourceRoot":"","sources":["../../../../../../src/material/datepicker/datepicker-input.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {\n  Directive,\n  ElementRef,\n  forwardRef,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n} from '@angular/core';\nimport {\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport {\n  DateAdapter,\n  MAT_DATE_FORMATS,\n  MatDateFormats,\n  ThemePalette,\n} from '@angular/material/core';\nimport {MatFormField, MAT_FORM_FIELD} from '@angular/material/form-field';\nimport {MAT_INPUT_VALUE_ACCESSOR} from '@angular/material/input';\nimport {Subscription} from 'rxjs';\nimport {MatDatepickerInputBase, DateFilterFn} from './datepicker-input-base';\nimport {MatDatepickerControl, MatDatepickerPanel} from './datepicker-base';\nimport {DateSelectionModelChange} from './date-selection-model';\n\n/** @docs-private */\nexport const MAT_DATEPICKER_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => MatDatepickerInput),\n  multi: true\n};\n\n/** @docs-private */\nexport const MAT_DATEPICKER_VALIDATORS: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MatDatepickerInput),\n  multi: true\n};\n\n/** Directive used to connect an input to a MatDatepicker. */\n@Directive({\n  selector: 'input[matDatepicker]',\n  providers: [\n    MAT_DATEPICKER_VALUE_ACCESSOR,\n    MAT_DATEPICKER_VALIDATORS,\n    {provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MatDatepickerInput},\n  ],\n  host: {\n    'class': 'mat-datepicker-input',\n    '[attr.aria-haspopup]': '_datepicker ? \"dialog\" : null',\n    '[attr.aria-owns]': '(_datepicker?.opened && _datepicker.id) || null',\n    '[attr.min]': 'min ? _dateAdapter.toIso8601(min) : null',\n    '[attr.max]': 'max ? _dateAdapter.toIso8601(max) : null',\n    // Used by the test harness to tie this input to its calendar. We can't depend on\n    // `aria-owns` for this, because it's only defined while the calendar is open.\n    '[attr.data-mat-calendar]': '_datepicker ? _datepicker.id : null',\n    '[disabled]': 'disabled',\n    '(input)': '_onInput($event.target.value)',\n    '(change)': '_onChange()',\n    '(blur)': '_onBlur()',\n    '(keydown)': '_onKeydown($event)',\n  },\n  exportAs: 'matDatepickerInput',\n})\nexport class MatDatepickerInput<D> extends MatDatepickerInputBase<D | null, D>\n  implements MatDatepickerControl<D | null>, OnDestroy {\n  private _closedSubscription = Subscription.EMPTY;\n\n  /** The datepicker that this input is associated with. */\n  @Input()\n  set matDatepicker(datepicker: MatDatepickerPanel<MatDatepickerControl<D>, D | null, D>) {\n    if (datepicker) {\n      this._datepicker = datepicker;\n      this._closedSubscription = datepicker.closedStream.subscribe(() => this._onTouched());\n      this._registerModel(datepicker.registerInput(this));\n    }\n  }\n  _datepicker: MatDatepickerPanel<MatDatepickerControl<D>, D | null, D>;\n\n  /** The minimum valid date. */\n  @Input()\n  get min(): D | null { return this._min; }\n  set min(value: D | null) {\n    const validValue = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n\n    if (!this._dateAdapter.sameDate(validValue, this._min)) {\n      this._min = validValue;\n      this._validatorOnChange();\n    }\n  }\n  private _min: D | null;\n\n  /** The maximum valid date. */\n  @Input()\n  get max(): D | null { return this._max; }\n  set max(value: D | null) {\n    const validValue = this._dateAdapter.getValidDateOrNull(this._dateAdapter.deserialize(value));\n\n    if (!this._dateAdapter.sameDate(validValue, this._max)) {\n      this._max = validValue;\n      this._validatorOnChange();\n    }\n  }\n  private _max: D | null;\n\n  /** Function that can be used to filter out dates within the datepicker. */\n  @Input('matDatepickerFilter')\n  get dateFilter() { return this._dateFilter; }\n  set dateFilter(value: DateFilterFn<D | null>) {\n    const wasMatchingValue = this._matchesFilter(this.value);\n    this._dateFilter = value;\n\n    if (this._matchesFilter(this.value) !== wasMatchingValue) {\n      this._validatorOnChange();\n    }\n  }\n  private _dateFilter: DateFilterFn<D | null>;\n\n  /** The combined form control validator for this input. */\n  protected _validator: ValidatorFn | null;\n\n  constructor(\n      elementRef: ElementRef<HTMLInputElement>,\n      @Optional() dateAdapter: DateAdapter<D>,\n      @Optional() @Inject(MAT_DATE_FORMATS) dateFormats: MatDateFormats,\n      @Optional() @Inject(MAT_FORM_FIELD) private _formField?: MatFormField) {\n    super(elementRef, dateAdapter, dateFormats);\n    this._validator = Validators.compose(super._getValidators());\n  }\n\n  /**\n   * Gets the element that the datepicker popup should be connected to.\n   * @return The element to connect the popup to.\n   */\n  getConnectedOverlayOrigin(): ElementRef {\n    return this._formField ? this._formField.getConnectedOverlayOrigin() : this._elementRef;\n  }\n\n  /** Gets the ID of an element that should be used a description for the calendar overlay. */\n  getOverlayLabelId(): string | null {\n    if (this._formField) {\n      return this._formField.getLabelId();\n    }\n\n    return this._elementRef.nativeElement.getAttribute('aria-labelledby');\n  }\n\n  /** Returns the palette used by the input's form field, if any. */\n  getThemePalette(): ThemePalette {\n    return this._formField ? this._formField.color : undefined;\n  }\n\n  /** Gets the value at which the calendar should start. */\n  getStartValue(): D | null {\n    return this.value;\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this._closedSubscription.unsubscribe();\n  }\n\n  /** Opens the associated datepicker. */\n  protected _openPopup(): void {\n    if (this._datepicker) {\n      this._datepicker.open();\n    }\n  }\n\n  protected _getValueFromModel(modelValue: D | null): D | null {\n    return modelValue;\n  }\n\n  protected _assignValueToModel(value: D | null): void {\n    if (this._model) {\n      this._model.updateSelection(value, this);\n    }\n  }\n\n  /** Gets the input's minimum date. */\n  _getMinDate() {\n    return this._min;\n  }\n\n  /** Gets the input's maximum date. */\n  _getMaxDate() {\n    return this._max;\n  }\n\n  /** Gets the input's date filtering function. */\n  protected _getDateFilter() {\n    return this._dateFilter;\n  }\n\n  protected _shouldHandleChangeEvent(event: DateSelectionModelChange<D>) {\n    return event.source !== this;\n  }\n}\n"]} |
---|