@ng-matero/extensions 12.9.2 → 12.10.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/mtxColorpicker.umd.js +18 -11
- package/bundles/mtxColorpicker.umd.js.map +1 -1
- package/bundles/mtxCore.umd.js.map +1 -1
- package/bundles/mtxDatetimepicker.umd.js +27 -15
- package/bundles/mtxDatetimepicker.umd.js.map +1 -1
- package/bundles/mtxGrid.umd.js +24 -21
- package/bundles/mtxGrid.umd.js.map +1 -1
- package/bundles/mtxPopover.umd.js +997 -803
- package/bundles/mtxPopover.umd.js.map +1 -1
- package/bundles/mtxSelect.umd.js +237 -156
- package/bundles/mtxSelect.umd.js.map +1 -1
- package/colorpicker/colorpicker-toggle.d.ts +5 -3
- package/colorpicker/mtxColorpicker.metadata.json +1 -1
- package/core/datetime/datetime-formats.d.ts +2 -0
- package/datetimepicker/datetimepicker-toggle.d.ts +2 -2
- package/datetimepicker/mtxDatetimepicker.metadata.json +1 -1
- package/esm2015/colorpicker/colorpicker-toggle.js +23 -16
- package/esm2015/core/datetime/datetime-formats.js +1 -1
- package/esm2015/datetimepicker/datetimepicker-input.js +6 -1
- package/esm2015/datetimepicker/datetimepicker-toggle.js +19 -14
- package/esm2015/datetimepicker/datetimepicker.js +6 -4
- package/esm2015/grid/cell.component.js +7 -4
- package/esm2015/grid/column-menu.component.js +10 -14
- package/esm2015/grid/grid.component.js +10 -6
- package/esm2015/popover/popover-animations.js +10 -13
- package/esm2015/popover/popover-content.js +99 -0
- package/esm2015/popover/popover-interfaces.js +1 -1
- package/esm2015/popover/popover-module.js +7 -5
- package/esm2015/popover/popover-target.js +3 -3
- package/esm2015/popover/popover-trigger.js +210 -172
- package/esm2015/popover/popover-types.js +1 -1
- package/esm2015/popover/popover.js +173 -125
- package/esm2015/popover/public-api.js +2 -1
- package/esm2015/select/option.component.js +4 -6
- package/esm2015/select/select.component.js +111 -31
- package/fesm2015/mtxColorpicker.js +19 -12
- package/fesm2015/mtxColorpicker.js.map +1 -1
- package/fesm2015/mtxCore.js.map +1 -1
- package/fesm2015/mtxDatetimepicker.js +28 -16
- package/fesm2015/mtxDatetimepicker.js.map +1 -1
- package/fesm2015/mtxGrid.js +24 -21
- package/fesm2015/mtxGrid.js.map +1 -1
- package/fesm2015/mtxPopover.js +526 -351
- package/fesm2015/mtxPopover.js.map +1 -1
- package/fesm2015/mtxSelect.js +169 -92
- package/fesm2015/mtxSelect.js.map +1 -1
- package/grid/cell.component.d.ts +4 -2
- package/grid/column-menu.component.d.ts +3 -5
- package/grid/grid.component.d.ts +6 -4
- package/grid/mtxGrid.metadata.json +1 -1
- package/package.json +1 -1
- package/popover/mtxPopover.metadata.json +1 -1
- package/popover/popover-animations.d.ts +1 -1
- package/popover/popover-content.d.ts +38 -0
- package/popover/popover-interfaces.d.ts +37 -31
- package/popover/popover-target.d.ts +2 -2
- package/popover/popover-trigger.d.ts +65 -60
- package/popover/popover-types.d.ts +6 -1
- package/popover/popover.d.ts +97 -69
- package/popover/popover.scss +2 -0
- package/popover/public-api.d.ts +1 -0
- package/select/mtxSelect.metadata.json +1 -1
- package/select/option.component.d.ts +7 -6
- package/select/select.component.d.ts +59 -20
|
@@ -1,16 +1,17 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
1
2
|
import { ChangeDetectionStrategy, Component, ElementRef, Input, } from '@angular/core';
|
|
2
3
|
import { Subject } from 'rxjs';
|
|
3
4
|
export class MtxOptionComponent {
|
|
4
5
|
constructor(elementRef) {
|
|
5
6
|
this.elementRef = elementRef;
|
|
6
|
-
this.stateChange$ = new Subject();
|
|
7
7
|
this._disabled = false;
|
|
8
|
+
this.stateChange$ = new Subject();
|
|
8
9
|
}
|
|
9
10
|
get disabled() {
|
|
10
11
|
return this._disabled;
|
|
11
12
|
}
|
|
12
13
|
set disabled(value) {
|
|
13
|
-
this._disabled =
|
|
14
|
+
this._disabled = coerceBooleanProperty(value);
|
|
14
15
|
}
|
|
15
16
|
get label() {
|
|
16
17
|
return (this.elementRef.nativeElement.textContent || '').trim();
|
|
@@ -36,9 +37,6 @@ export class MtxOptionComponent {
|
|
|
36
37
|
ngOnDestroy() {
|
|
37
38
|
this.stateChange$.complete();
|
|
38
39
|
}
|
|
39
|
-
_isDisabled(value) {
|
|
40
|
-
return value != null && `${value}` !== 'false';
|
|
41
|
-
}
|
|
42
40
|
}
|
|
43
41
|
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
|
|
44
42
|
MtxOptionComponent.decorators = [
|
|
@@ -64,4 +62,4 @@ MtxOptionComponent.propDecorators = {
|
|
|
64
62
|
value: [{ type: Input }],
|
|
65
63
|
disabled: [{ type: Input }]
|
|
66
64
|
};
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvc2VsZWN0L29wdGlvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVFLE9BQU8sRUFFTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixLQUFLLEdBSU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQVEvQixNQUFNLE9BQU8sa0JBQWtCO0lBdUI3QixZQUFtQixVQUFtQztRQUFuQyxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQWI5QyxjQUFTLEdBQUcsS0FBSyxDQUFDO1FBT2pCLGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBSS9CLENBQUM7SUFFb0QsQ0FBQztJQXBCMUQsSUFDSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxJQUFJLFFBQVEsQ0FBQyxLQUFjO1FBQ3pCLElBQUksQ0FBQyxTQUFTLEdBQUcscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUdELElBQUksS0FBSztRQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxXQUFXLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDbEUsQ0FBQztJQVdELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUM7Z0JBQ3JCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztnQkFDakIsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTO2FBQ3pCLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQztJQUVELGtCQUFrQjtRQUNoQixJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssSUFBSSxDQUFDLGNBQWMsRUFBRTtZQUN0QyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7WUFDakMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUM7Z0JBQ3JCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztnQkFDakIsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTO2dCQUN4QixLQUFLLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsU0FBUzthQUMvQyxDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMvQixDQUFDOzs7O1lBckRGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIsUUFBUSxFQUFFLFdBQVc7Z0JBQ3JCLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2dCQUMvQyxRQUFRLEVBQUUsMkJBQTJCO2FBQ3RDOzs7Ozs7Ozs7O1lBYkMsVUFBVTs7OztvQkFlVCxLQUFLO3VCQUVMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCb29sZWFuSW5wdXQsIGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQge1xuICBBZnRlclZpZXdDaGVja2VkLFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPbkRlc3Ryb3ksXG4gIFNpbXBsZUNoYW5nZXMsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtdHgtb3B0aW9uJyxcbiAgZXhwb3J0QXM6ICdtdHhPcHRpb24nLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudD48L25nLWNvbnRlbnQ+YCxcbn0pXG5leHBvcnQgY2xhc3MgTXR4T3B0aW9uQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzLCBBZnRlclZpZXdDaGVja2VkLCBPbkRlc3Ryb3kge1xuICBASW5wdXQoKSB2YWx1ZTogYW55O1xuXG4gIEBJbnB1dCgpXG4gIGdldCBkaXNhYmxlZCgpIHtcbiAgICByZXR1cm4gdGhpcy5fZGlzYWJsZWQ7XG4gIH1cbiAgc2V0IGRpc2FibGVkKHZhbHVlOiBib29sZWFuKSB7XG4gICAgdGhpcy5fZGlzYWJsZWQgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkodmFsdWUpO1xuICB9XG4gIHByaXZhdGUgX2Rpc2FibGVkID0gZmFsc2U7XG5cbiAgZ2V0IGxhYmVsKCkge1xuICAgIHJldHVybiAodGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQudGV4dENvbnRlbnQgfHwgJycpLnRyaW0oKTtcbiAgfVxuICBwcml2YXRlIF9wcmV2aW91c0xhYmVsPzogc3RyaW5nO1xuXG4gIHJlYWRvbmx5IHN0YXRlQ2hhbmdlJCA9IG5ldyBTdWJqZWN0PHtcbiAgICB2YWx1ZTogYW55O1xuICAgIGRpc2FibGVkOiBib29sZWFuO1xuICAgIGxhYmVsPzogc3RyaW5nO1xuICB9PigpO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50Pikge31cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgaWYgKGNoYW5nZXMuZGlzYWJsZWQpIHtcbiAgICAgIHRoaXMuc3RhdGVDaGFuZ2UkLm5leHQoe1xuICAgICAgICB2YWx1ZTogdGhpcy52YWx1ZSxcbiAgICAgICAgZGlzYWJsZWQ6IHRoaXMuX2Rpc2FibGVkLFxuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgbmdBZnRlclZpZXdDaGVja2VkKCkge1xuICAgIGlmICh0aGlzLmxhYmVsICE9PSB0aGlzLl9wcmV2aW91c0xhYmVsKSB7XG4gICAgICB0aGlzLl9wcmV2aW91c0xhYmVsID0gdGhpcy5sYWJlbDtcbiAgICAgIHRoaXMuc3RhdGVDaGFuZ2UkLm5leHQoe1xuICAgICAgICB2YWx1ZTogdGhpcy52YWx1ZSxcbiAgICAgICAgZGlzYWJsZWQ6IHRoaXMuX2Rpc2FibGVkLFxuICAgICAgICBsYWJlbDogdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuaW5uZXJIVE1MLFxuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5zdGF0ZUNoYW5nZSQuY29tcGxldGUoKTtcbiAgfVxuXG4gIHN0YXRpYyBuZ0FjY2VwdElucHV0VHlwZV9kaXNhYmxlZDogQm9vbGVhbklucHV0O1xufVxuIl19
|
|
@@ -1,24 +1,44 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, ElementRef, ChangeDetectorRef, Optional, Self, Output, EventEmitter, TemplateRef, ContentChild, ContentChildren, QueryList, ViewChild, } from '@angular/core';
|
|
2
|
-
import { NgControl } from '@angular/forms';
|
|
3
|
-
import { MatFormFieldControl } from '@angular/material/form-field';
|
|
4
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
5
1
|
import { FocusMonitor } from '@angular/cdk/a11y';
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
2
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, Inject, Input, Optional, Output, QueryList, Self, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
4
|
+
import { ErrorStateMatcher, mixinErrorState } from '@angular/material/core';
|
|
5
|
+
import { FormGroupDirective, NgControl, NgForm } from '@angular/forms';
|
|
6
|
+
import { MatFormField, MatFormFieldControl, MAT_FORM_FIELD } from '@angular/material/form-field';
|
|
7
|
+
import { merge, Subject } from 'rxjs';
|
|
8
|
+
import { startWith, takeUntil } from 'rxjs/operators';
|
|
10
9
|
import { NgSelectComponent } from '@ng-select/ng-select';
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
}
|
|
10
|
+
import { MtxOptionComponent } from './option.component';
|
|
11
|
+
import { MtxSelectFooterTemplateDirective, MtxSelectHeaderTemplateDirective, MtxSelectLabelTemplateDirective, MtxSelectLoadingSpinnerTemplateDirective, MtxSelectLoadingTextTemplateDirective, MtxSelectMultiLabelTemplateDirective, MtxSelectNotFoundTemplateDirective, MtxSelectOptgroupTemplateDirective, MtxSelectOptionTemplateDirective, MtxSelectTagTemplateDirective, MtxSelectTypeToSearchTemplateDirective, } from './templates.directive';
|
|
14
12
|
let nextUniqueId = 0;
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
13
|
+
// Boilerplate for applying mixins to MtxSelect.
|
|
14
|
+
/** @docs-private */
|
|
15
|
+
const _MtxSelectMixinBase = mixinErrorState(class {
|
|
16
|
+
constructor(_defaultErrorStateMatcher, _parentForm, _parentFormGroup,
|
|
17
|
+
/**
|
|
18
|
+
* Form control bound to the component.
|
|
19
|
+
* Implemented as part of `MatFormFieldControl`.
|
|
20
|
+
* @docs-private
|
|
21
|
+
*/
|
|
22
|
+
ngControl) {
|
|
23
|
+
this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
|
|
24
|
+
this._parentForm = _parentForm;
|
|
25
|
+
this._parentFormGroup = _parentFormGroup;
|
|
20
26
|
this.ngControl = ngControl;
|
|
21
|
-
/**
|
|
27
|
+
/**
|
|
28
|
+
* Emits whenever the component state changes and should cause the parent
|
|
29
|
+
* form-field to update. Implemented as part of `MatFormFieldControl`.
|
|
30
|
+
* @docs-private
|
|
31
|
+
*/
|
|
32
|
+
this.stateChanges = new Subject();
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
export class MtxSelectComponent extends _MtxSelectMixinBase {
|
|
36
|
+
constructor(_changeDetectorRef, _elementRef, _focusMonitor, _defaultErrorStateMatcher, _parentForm, _parentFormGroup, ngControl, _parentFormField) {
|
|
37
|
+
super(_defaultErrorStateMatcher, _parentForm, _parentFormGroup, ngControl);
|
|
38
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
39
|
+
this._elementRef = _elementRef;
|
|
40
|
+
this._focusMonitor = _focusMonitor;
|
|
41
|
+
this._parentFormField = _parentFormField;
|
|
22
42
|
this.addTag = false;
|
|
23
43
|
this.addTagText = 'Add item';
|
|
24
44
|
this.appearance = 'underline';
|
|
@@ -60,23 +80,32 @@ export class MtxSelectComponent {
|
|
|
60
80
|
this.scroll = new EventEmitter();
|
|
61
81
|
this.scrollToEnd = new EventEmitter();
|
|
62
82
|
this._items = [];
|
|
83
|
+
this._itemsAreUsed = false;
|
|
84
|
+
/** Emits whenever the component is destroyed. */
|
|
63
85
|
this._destroy$ = new Subject();
|
|
64
86
|
this._value = null;
|
|
65
87
|
/** Implemented as part of MatFormFieldControl. */
|
|
66
88
|
this.stateChanges = new Subject();
|
|
67
|
-
/** Unique id for this
|
|
89
|
+
/** Unique id for this select. */
|
|
68
90
|
this._uid = `mtx-select-${nextUniqueId++}`;
|
|
69
91
|
this._focused = false;
|
|
70
92
|
this._required = false;
|
|
71
93
|
this._disabled = false;
|
|
72
|
-
|
|
94
|
+
/** Aria label of the select. */
|
|
95
|
+
this.ariaLabel = '';
|
|
96
|
+
/** Input that can be used to specify the `aria-labelledby` attribute. */
|
|
97
|
+
this.ariaLabelledby = null;
|
|
98
|
+
/** The aria-describedby attribute on the select for improved a11y. */
|
|
99
|
+
this._ariaDescribedby = null;
|
|
73
100
|
/** A name for this control that can be used by `mat-form-field`. */
|
|
74
101
|
this.controlType = 'mtx-select';
|
|
75
102
|
/** `View -> model callback called when value changes` */
|
|
76
103
|
this._onChange = () => { };
|
|
77
104
|
/** `View -> model callback called when select has been touched` */
|
|
78
105
|
this._onTouched = () => { };
|
|
79
|
-
|
|
106
|
+
/** ID for the DOM node containing the select's value. */
|
|
107
|
+
this._valueId = `mtx-select-value-${nextUniqueId++}`;
|
|
108
|
+
_focusMonitor.monitor(this._elementRef, true).subscribe(origin => {
|
|
80
109
|
if (this._focused && !origin) {
|
|
81
110
|
this._onTouched();
|
|
82
111
|
}
|
|
@@ -84,11 +113,17 @@ export class MtxSelectComponent {
|
|
|
84
113
|
this.stateChanges.next();
|
|
85
114
|
});
|
|
86
115
|
if (this.ngControl != null) {
|
|
116
|
+
// Note: we provide the value accessor through here, instead of
|
|
117
|
+
// the `providers` to avoid running into a circular import.
|
|
87
118
|
this.ngControl.valueAccessor = this;
|
|
88
119
|
}
|
|
120
|
+
// Force setter to be called in case id was not specified.
|
|
121
|
+
// eslint-disable-next-line no-self-assign
|
|
122
|
+
this.id = this.id;
|
|
89
123
|
}
|
|
90
124
|
get clearSearchOnAdd() {
|
|
91
|
-
|
|
125
|
+
var _a;
|
|
126
|
+
return (_a = this._clearSearchOnAdd) !== null && _a !== void 0 ? _a : this.closeOnSelect;
|
|
92
127
|
}
|
|
93
128
|
set clearSearchOnAdd(value) {
|
|
94
129
|
this._clearSearchOnAdd = value;
|
|
@@ -125,16 +160,22 @@ export class MtxSelectComponent {
|
|
|
125
160
|
this._placeholder = value;
|
|
126
161
|
this.stateChanges.next();
|
|
127
162
|
}
|
|
128
|
-
/** Whether the
|
|
163
|
+
/** Whether the select is focused. */
|
|
129
164
|
get focused() {
|
|
130
165
|
return this._focused;
|
|
131
166
|
}
|
|
167
|
+
/** Whether the select has a value. */
|
|
132
168
|
get empty() {
|
|
133
169
|
return this.value == null || (Array.isArray(this.value) && this.value.length === 0);
|
|
134
170
|
}
|
|
171
|
+
/**
|
|
172
|
+
* Implemented as part of MatFormFieldControl.
|
|
173
|
+
* @docs-private
|
|
174
|
+
*/
|
|
135
175
|
get shouldLabelFloat() {
|
|
136
176
|
return this.focused || !this.empty;
|
|
137
177
|
}
|
|
178
|
+
/** Whether the component is required. */
|
|
138
179
|
get required() {
|
|
139
180
|
return this._required;
|
|
140
181
|
}
|
|
@@ -142,6 +183,7 @@ export class MtxSelectComponent {
|
|
|
142
183
|
this._required = coerceBooleanProperty(value);
|
|
143
184
|
this.stateChanges.next();
|
|
144
185
|
}
|
|
186
|
+
/** Whether the select is disabled. */
|
|
145
187
|
get disabled() {
|
|
146
188
|
return this._disabled;
|
|
147
189
|
}
|
|
@@ -151,6 +193,10 @@ export class MtxSelectComponent {
|
|
|
151
193
|
this.stateChanges.next();
|
|
152
194
|
this._changeDetectorRef.markForCheck();
|
|
153
195
|
}
|
|
196
|
+
/** Whether or not the overlay panel is open. */
|
|
197
|
+
get panelOpen() {
|
|
198
|
+
return !!this.ngSelect.isOpen;
|
|
199
|
+
}
|
|
154
200
|
ngOnInit() {
|
|
155
201
|
// Fix compareWith warning of undefined value
|
|
156
202
|
// https://github.com/ng-select/ng-select/issues/1537
|
|
@@ -165,8 +211,10 @@ export class MtxSelectComponent {
|
|
|
165
211
|
}
|
|
166
212
|
ngDoCheck() {
|
|
167
213
|
if (this.ngControl) {
|
|
168
|
-
|
|
169
|
-
|
|
214
|
+
// We need to re-evaluate this on every change detection cycle, because there are some
|
|
215
|
+
// error triggers that we can't subscribe to (e.g. parent form submissions). This means
|
|
216
|
+
// that whatever logic is in here has to be super lean or we risk destroying the performance.
|
|
217
|
+
this.updateErrorState();
|
|
170
218
|
}
|
|
171
219
|
}
|
|
172
220
|
ngOnDestroy() {
|
|
@@ -175,9 +223,22 @@ export class MtxSelectComponent {
|
|
|
175
223
|
this.stateChanges.complete();
|
|
176
224
|
this._focusMonitor.stopMonitoring(this._elementRef);
|
|
177
225
|
}
|
|
226
|
+
/** Gets the value for the `aria-labelledby` attribute of the inputs. */
|
|
227
|
+
_getAriaLabelledby() {
|
|
228
|
+
var _a;
|
|
229
|
+
if (this.ariaLabel) {
|
|
230
|
+
return null;
|
|
231
|
+
}
|
|
232
|
+
const labelId = (_a = this._parentFormField) === null || _a === void 0 ? void 0 : _a.getLabelId();
|
|
233
|
+
let value = (labelId ? labelId + ' ' : '') + this._valueId;
|
|
234
|
+
if (this.ariaLabelledby) {
|
|
235
|
+
value += ' ' + this.ariaLabelledby;
|
|
236
|
+
}
|
|
237
|
+
return value;
|
|
238
|
+
}
|
|
178
239
|
/** Implemented as part of MatFormFieldControl. */
|
|
179
240
|
setDescribedByIds(ids) {
|
|
180
|
-
this._ariaDescribedby = ids.join(' ');
|
|
241
|
+
this._ariaDescribedby = ids.length ? ids.join(' ') : null;
|
|
181
242
|
}
|
|
182
243
|
/**
|
|
183
244
|
* Disables the select. Part of the ControlValueAccessor interface required
|
|
@@ -227,7 +288,7 @@ export class MtxSelectComponent {
|
|
|
227
288
|
registerOnTouched(fn) {
|
|
228
289
|
this._onTouched = fn;
|
|
229
290
|
}
|
|
230
|
-
/** NgSelect
|
|
291
|
+
/** NgSelect's `_setItemsFromNgOptions` */
|
|
231
292
|
_setItemsFromMtxOptions() {
|
|
232
293
|
const mapMtxOptions = (options) => {
|
|
233
294
|
this.items = options.map(option => ({
|
|
@@ -278,10 +339,22 @@ MtxSelectComponent.decorators = [
|
|
|
278
339
|
selector: 'mtx-select',
|
|
279
340
|
exportAs: 'mtxSelect',
|
|
280
341
|
host: {
|
|
342
|
+
'role': 'combobox',
|
|
343
|
+
'aria-autocomplete': 'none',
|
|
281
344
|
'[attr.id]': 'id',
|
|
345
|
+
'[attr.aria-expanded]': 'panelOpen',
|
|
346
|
+
'[attr.aria-label]': 'ariaLabel || null',
|
|
347
|
+
'[attr.aria-labelledby]': '_getAriaLabelledby()',
|
|
282
348
|
'[attr.aria-describedby]': '_ariaDescribedby || null',
|
|
349
|
+
'[attr.aria-required]': 'required.toString()',
|
|
350
|
+
'[attr.aria-disabled]': 'disabled.toString()',
|
|
351
|
+
'[attr.aria-invalid]': 'errorState',
|
|
283
352
|
'[class.mtx-select-floating]': 'shouldLabelFloat',
|
|
353
|
+
'[class.mtx-select-disabled]': 'disabled',
|
|
284
354
|
'[class.mtx-select-invalid]': 'errorState',
|
|
355
|
+
'[class.mtx-select-required]': 'required',
|
|
356
|
+
'[class.mtx-select-empty]': 'empty',
|
|
357
|
+
'[class.mtx-select-multiple]': 'multiple',
|
|
285
358
|
'class': 'mtx-select',
|
|
286
359
|
},
|
|
287
360
|
template: "<ng-select #ngSelect [class.ng-select-invalid]=\"errorState\"\n [(ngModel)]=\"value\"\n [placeholder]=\"placeholder\"\n [items]=\"items\"\n [addTag]=\"addTag\"\n [addTagText]=\"addTagText\"\n [appendTo]=\"appendTo\"\n [appearance]=\"appearance\"\n [bindLabel]=\"bindLabel\"\n [bindValue]=\"bindValue\"\n [closeOnSelect]=\"closeOnSelect\"\n [clearAllText]=\"clearAllText\"\n [clearable]=\"clearable\"\n [clearOnBackspace]=\"clearOnBackspace\"\n [dropdownPosition]=\"dropdownPosition\"\n [groupBy]=\"groupBy\"\n [groupValue]=\"groupValue\"\n [hideSelected]=\"hideSelected\"\n [isOpen]=\"isOpen\"\n [inputAttrs]=\"inputAttrs\"\n [loading]=\"loading\"\n [loadingText]=\"loadingText\"\n [labelForId]=\"labelForId\"\n [markFirst]=\"markFirst\"\n [maxSelectedItems]=\"maxSelectedItems\"\n [multiple]=\"multiple\"\n [notFoundText]=\"notFoundText\"\n [readonly]=\"readonly\"\n [typeahead]=\"typeahead\"\n [typeToSearchText]=\"typeToSearchText\"\n [trackByFn]=\"trackByFn\"\n [searchable]=\"searchable\"\n [searchFn]=\"searchFn\"\n [searchWhileComposing]=\"searchWhileComposing\"\n [clearSearchOnAdd]=\"clearSearchOnAdd\"\n [selectableGroup]=\"selectableGroup\"\n [selectableGroupAsModel]=\"selectableGroupAsModel\"\n [selectOnTab]=\"selectOnTab\"\n [tabIndex]=\"tabIndex\"\n [openOnEnter]=\"openOnEnter\"\n [minTermLength]=\"minTermLength\"\n [editableSearchTerm]=\"editableSearchTerm\"\n [keyDownFn]=\"keyDownFn\"\n [virtualScroll]=\"virtualScroll\"\n (blur)=\"blurEvent.emit($event)\"\n (focus)=\"focusEvent.emit($event)\"\n (change)=\"changeEvent.emit($event)\"\n (open)=\"openEvent.emit($event)\"\n (close)=\"closeEvent.emit($event)\"\n (search)=\"searchEvent.emit($event)\"\n (clear)=\"clearEvent.emit($event)\"\n (add)=\"addEvent.emit($event)\"\n (remove)=\"removeEvent.emit($event)\"\n (scroll)=\"scroll.emit($event)\"\n (scrollToEnd)=\"scrollToEnd.emit($event)\">\n\n <ng-container *ngIf=\"optionTemplate\">\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\"\n let-searchTerm=\"searchTerm\">\n <ng-template [ngTemplateOutlet]=\"optionTemplate\"\n [ngTemplateOutletContext]=\"{ item: item, item$: item$, index: index, searchTerm: searchTerm }\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"optgroupTemplate\">\n <ng-template ng-optgroup-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\"\n let-searchTerm=\"searchTerm\">\n <ng-template [ngTemplateOutlet]=\"optgroupTemplate\"\n [ngTemplateOutletContext]=\"{ item: item, item$: item$, index: index, searchTerm: searchTerm }\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"labelTemplate\">\n <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" let-label=\"label\">\n <ng-template [ngTemplateOutlet]=\"labelTemplate\"\n [ngTemplateOutletContext]=\"{ item: item, clear: clear, label: label }\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"multiLabelTemplate\">\n <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <ng-template [ngTemplateOutlet]=\"multiLabelTemplate\"\n [ngTemplateOutletContext]=\"{ items: items, clear: clear }\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"headerTemplate\">\n <ng-template ng-header-tmp>\n <ng-template [ngTemplateOutlet]=\"headerTemplate\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"footerTemplate\">\n <ng-template ng-footer-tmp>\n <ng-template [ngTemplateOutlet]=\"footerTemplate\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"notFoundTemplate\">\n <ng-template ng-notfound-tmp let-searchTerm=\"searchTerm\">\n <ng-template [ngTemplateOutlet]=\"notFoundTemplate\"\n [ngTemplateOutletContext]=\"{ searchTerm: searchTerm }\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"typeToSearchTemplate\">\n <ng-template ng-typetosearch-tmp>\n <ng-template [ngTemplateOutlet]=\"typeToSearchTemplate\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"loadingTextTemplate\">\n <ng-template ng-loadingtext-tmp let-searchTerm=\"searchTerm\">\n <ng-template [ngTemplateOutlet]=\"loadingTextTemplate\"\n [ngTemplateOutletContext]=\"{ searchTerm: searchTerm }\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"tagTemplate\">\n <ng-template ng-tag-tmp let-searchTerm=\"searchTerm\">\n <ng-template [ngTemplateOutlet]=\"tagTemplate\"\n [ngTemplateOutletContext]=\"{ searchTerm: searchTerm }\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"loadingSpinnerTemplate\">\n <ng-template ng-loadingspinner-tmp>\n <ng-template [ngTemplateOutlet]=\"loadingSpinnerTemplate\">\n </ng-template>\n </ng-template>\n </ng-container>\n\n</ng-select>\n",
|
|
@@ -299,10 +372,14 @@ MtxSelectComponent.decorators = [
|
|
|
299
372
|
* @nocollapse
|
|
300
373
|
*/
|
|
301
374
|
MtxSelectComponent.ctorParameters = () => [
|
|
302
|
-
{ type: FocusMonitor },
|
|
303
|
-
{ type: ElementRef },
|
|
304
375
|
{ type: ChangeDetectorRef },
|
|
305
|
-
{ type:
|
|
376
|
+
{ type: ElementRef },
|
|
377
|
+
{ type: FocusMonitor },
|
|
378
|
+
{ type: ErrorStateMatcher },
|
|
379
|
+
{ type: NgForm, decorators: [{ type: Optional }] },
|
|
380
|
+
{ type: FormGroupDirective, decorators: [{ type: Optional }] },
|
|
381
|
+
{ type: NgControl, decorators: [{ type: Optional }, { type: Self }] },
|
|
382
|
+
{ type: MatFormField, decorators: [{ type: Optional }, { type: Inject, args: [MAT_FORM_FIELD,] }] }
|
|
306
383
|
];
|
|
307
384
|
/** @type {!Object<string, !Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
|
|
308
385
|
MtxSelectComponent.propDecorators = {
|
|
@@ -376,6 +453,9 @@ MtxSelectComponent.propDecorators = {
|
|
|
376
453
|
id: [{ type: Input }],
|
|
377
454
|
placeholder: [{ type: Input }],
|
|
378
455
|
required: [{ type: Input }],
|
|
379
|
-
disabled: [{ type: Input }]
|
|
456
|
+
disabled: [{ type: Input }],
|
|
457
|
+
errorStateMatcher: [{ type: Input }],
|
|
458
|
+
ariaLabel: [{ type: Input, args: ['aria-label',] }],
|
|
459
|
+
ariaLabelledby: [{ type: Input, args: ['aria-labelledby',] }]
|
|
380
460
|
};
|
|
381
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../projects/extensions/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnDestroy,\n  DoCheck,\n  ViewEncapsulation,\n  ChangeDetectionStrategy,\n  Input,\n  ElementRef,\n  ChangeDetectorRef,\n  Optional,\n  Self,\n  Output,\n  EventEmitter,\n  TemplateRef,\n  ContentChild,\n  ContentChildren,\n  QueryList,\n  AfterViewInit,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport { Subject, merge } from 'rxjs';\nimport { takeUntil, startWith } from 'rxjs/operators';\n\nimport {\n  MtxSelectOptionTemplateDirective,\n  MtxSelectLabelTemplateDirective,\n  MtxSelectHeaderTemplateDirective,\n  MtxSelectFooterTemplateDirective,\n  MtxSelectOptgroupTemplateDirective,\n  MtxSelectNotFoundTemplateDirective,\n  MtxSelectTypeToSearchTemplateDirective,\n  MtxSelectLoadingTextTemplateDirective,\n  MtxSelectMultiLabelTemplateDirective,\n  MtxSelectTagTemplateDirective,\n  MtxSelectLoadingSpinnerTemplateDirective,\n} from './templates.directive';\nimport { MtxOptionComponent } from './option.component';\nimport { NgSelectComponent } from '@ng-select/ng-select';\n\nexport type DropdownPosition = 'bottom' | 'top' | 'auto';\nexport type AddTagFn = (term: string) => any | Promise<any>;\nexport type CompareWithFn = (a: any, b: any) => boolean;\nexport type GroupValueFn = (\n  key: string | Record<string, any>,\n  children: any[]\n) => string | Record<string, any>;\nexport type SearchFn = (term: string, item: any) => boolean;\nexport type TrackByFn = (item: any) => any;\n\nexport function isDefined(value: any) {\n  return value !== undefined && value !== null;\n}\n\nlet nextUniqueId = 0;\n\n@Component({\n  selector: 'mtx-select',\n  exportAs: 'mtxSelect',\n  host: {\n    '[attr.id]': 'id',\n    '[attr.aria-describedby]': '_ariaDescribedby || null',\n    '[class.mtx-select-floating]': 'shouldLabelFloat',\n    '[class.mtx-select-invalid]': 'errorState',\n    'class': 'mtx-select',\n  },\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: MatFormFieldControl, useExisting: MtxSelectComponent }],\n})\nexport class MtxSelectComponent\n  implements\n    OnInit,\n    OnDestroy,\n    DoCheck,\n    AfterViewInit,\n    ControlValueAccessor,\n    MatFormFieldControl<any>\n{\n  @ViewChild('ngSelect', { static: true }) ngSelect!: NgSelectComponent;\n\n  // MtxSelect custom templates\n  @ContentChild(MtxSelectOptionTemplateDirective, { read: TemplateRef })\n  optionTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectOptgroupTemplateDirective, { read: TemplateRef })\n  optgroupTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectLabelTemplateDirective, { read: TemplateRef })\n  labelTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectMultiLabelTemplateDirective, { read: TemplateRef })\n  multiLabelTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectHeaderTemplateDirective, { read: TemplateRef })\n  headerTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectFooterTemplateDirective, { read: TemplateRef })\n  footerTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectNotFoundTemplateDirective, { read: TemplateRef })\n  notFoundTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectTypeToSearchTemplateDirective, { read: TemplateRef })\n  typeToSearchTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectLoadingTextTemplateDirective, { read: TemplateRef })\n  loadingTextTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectTagTemplateDirective, { read: TemplateRef })\n  tagTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectLoadingSpinnerTemplateDirective, { read: TemplateRef })\n  loadingSpinnerTemplate!: TemplateRef<any>;\n\n  @ContentChildren(MtxOptionComponent, { descendants: true })\n  mtxOptions!: QueryList<MtxOptionComponent>;\n\n  /** MtxSelect options */\n  @Input() addTag: boolean | AddTagFn = false;\n  @Input() addTagText = 'Add item';\n  @Input() appearance = 'underline';\n  @Input() appendTo!: string;\n  @Input() bindLabel!: string;\n  @Input() bindValue!: string;\n  @Input() closeOnSelect = true;\n  @Input() clearAllText = 'Clear all';\n  @Input() clearable = true;\n  @Input() clearOnBackspace = true;\n  @Input() compareWith!: CompareWithFn;\n  @Input() dropdownPosition: DropdownPosition = 'auto';\n  @Input() groupBy!: string | (() => void);\n  @Input() groupValue!: GroupValueFn;\n  @Input() selectableGroup = false;\n  @Input() selectableGroupAsModel = true;\n  @Input() hideSelected = false;\n  @Input() isOpen!: boolean;\n  @Input() loading = false;\n  @Input() loadingText = 'Loading...';\n  @Input() labelForId: string | null = null;\n  @Input() markFirst = true;\n  @Input() maxSelectedItems!: number;\n  @Input() multiple = false;\n  @Input() notFoundText = 'No items found';\n  @Input() searchable = true;\n  @Input() readonly = false;\n  @Input() searchFn: SearchFn | null = null;\n  @Input() searchWhileComposing = true;\n  @Input() selectOnTab = false;\n  @Input() trackByFn: TrackByFn | null = null;\n  @Input() inputAttrs: { [key: string]: string } = {};\n  @Input() tabIndex!: number;\n  @Input() openOnEnter!: boolean;\n  @Input() minTermLength = 0;\n  @Input() editableSearchTerm = false;\n  @Input() keyDownFn = (_: KeyboardEvent) => true;\n  @Input() virtualScroll = false;\n  @Input() typeToSearchText = 'Type to search';\n  @Input() typeahead!: Subject<string>;\n\n  @Output('blur') blurEvent = new EventEmitter();\n  @Output('focus') focusEvent = new EventEmitter();\n  @Output('change') changeEvent = new EventEmitter();\n  @Output('open') openEvent = new EventEmitter();\n  @Output('close') closeEvent = new EventEmitter();\n  @Output('search') searchEvent = new EventEmitter<{ term: string; items: any[] }>();\n  @Output('clear') clearEvent = new EventEmitter();\n  @Output('add') addEvent = new EventEmitter();\n  @Output('remove') removeEvent = new EventEmitter();\n  @Output('scroll') scroll = new EventEmitter<{ start: number; end: number }>();\n  @Output('scrollToEnd') scrollToEnd = new EventEmitter();\n\n  @Input()\n  get clearSearchOnAdd() {\n    return isDefined(this._clearSearchOnAdd) ? this._clearSearchOnAdd : this.closeOnSelect;\n  }\n  set clearSearchOnAdd(value) {\n    this._clearSearchOnAdd = value;\n  }\n  private _clearSearchOnAdd!: boolean;\n\n  @Input()\n  get items() {\n    return this._items;\n  }\n  set items(value: any[]) {\n    this._itemsAreUsed = true;\n    this._items = value;\n  }\n  private _items: any[] = [];\n  private _itemsAreUsed!: boolean;\n  private readonly _destroy$ = new Subject<void>();\n\n  /** Value of the select control. */\n  @Input()\n  get value(): any {\n    return this._value;\n  }\n  set value(newValue: any) {\n    this._value = newValue;\n    this._onChange(newValue);\n    this.stateChanges.next();\n  }\n  private _value = null;\n\n  /** Implemented as part of MatFormFieldControl. */\n  readonly stateChanges: Subject<void> = new Subject<void>();\n\n  /** Unique id of the element. */\n  @Input()\n  get id(): string {\n    return this._id;\n  }\n  set id(value: string) {\n    this._id = value || this._uid;\n    this.stateChanges.next();\n  }\n  private _id!: string;\n\n  /** Unique id for this input. */\n  private _uid = `mtx-select-${nextUniqueId++}`;\n\n  /** Placeholder to be shown if value is empty. */\n  @Input()\n  get placeholder(): string {\n    return this._placeholder;\n  }\n  set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n  private _placeholder!: string;\n\n  /** Whether the input is focused. */\n  get focused(): boolean {\n    return this._focused;\n  }\n  private _focused = false;\n\n  get empty(): boolean {\n    return this.value == null || (Array.isArray(this.value) && this.value.length === 0);\n  }\n\n  get shouldLabelFloat(): boolean {\n    return this.focused || !this.empty;\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n  private _required = false;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n    this.readonly = this._disabled;\n    this.stateChanges.next();\n    this._changeDetectorRef.markForCheck();\n  }\n  private _disabled = false;\n\n  errorState = false;\n\n  /** A name for this control that can be used by `mat-form-field`. */\n  controlType = 'mtx-select';\n\n  /** The aria-describedby attribute on the select for improved a11y. */\n  _ariaDescribedby!: string;\n\n  /** `View -> model callback called when value changes` */\n  _onChange: (value: any) => void = () => {};\n\n  /** `View -> model callback called when select has been touched` */\n  _onTouched = () => {};\n\n  constructor(\n    private _focusMonitor: FocusMonitor,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Self() public ngControl: NgControl\n  ) {\n    _focusMonitor.monitor(_elementRef, true).subscribe(origin => {\n      if (this._focused && !origin) {\n        this._onTouched();\n      }\n      this._focused = !!origin;\n      this.stateChanges.next();\n    });\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    // Fix compareWith warning of undefined value\n    // https://github.com/ng-select/ng-select/issues/1537\n    if (this.compareWith) {\n      this.ngSelect.compareWith = this.compareWith;\n    }\n  }\n\n  ngAfterViewInit() {\n    if (!this._itemsAreUsed) {\n      this._setItemsFromMtxOptions();\n    }\n  }\n\n  ngDoCheck(): void {\n    if (this.ngControl) {\n      this.errorState = (this.ngControl.invalid && this.ngControl.touched) as boolean;\n      this.stateChanges.next();\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n    this.stateChanges.complete();\n    this._focusMonitor.stopMonitoring(this._elementRef);\n  }\n\n  /** Implemented as part of MatFormFieldControl. */\n  setDescribedByIds(ids: string[]) {\n    this._ariaDescribedby = ids.join(' ');\n  }\n\n  /**\n   * Disables the select. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param isDisabled Sets whether the component is disabled.\n   */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /** Implemented as part of MatFormFieldControl. */\n  onContainerClick(event: MouseEvent) {\n    const target = event.target as HTMLElement;\n    if (/mat-form-field|mtx-select/g.test(target.parentElement?.classList[0] || '')) {\n      this.focus();\n      this.open();\n    }\n  }\n\n  /**\n   * Sets the select's value. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param value New value to be written to the model.\n   */\n  writeValue(value: any): void {\n    this.value = value;\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select's value\n   * changes from user input. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the value changes.\n   */\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select is blurred\n   * by the user. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the component has been touched.\n   */\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  /** NgSelect: _setItemsFromNgOptions */\n  private _setItemsFromMtxOptions() {\n    const mapMtxOptions = (options: QueryList<MtxOptionComponent>) => {\n      this.items = options.map(option => ({\n        $ngOptionValue: option.value,\n        $ngOptionLabel: option.elementRef.nativeElement.innerHTML,\n        disabled: option.disabled,\n      }));\n      this.ngSelect.itemsList.setItems(this.items);\n      if (this.ngSelect.hasValue) {\n        this.ngSelect.itemsList.mapSelectedItems();\n      }\n      this.ngSelect.detectChanges();\n    };\n\n    const handleOptionChange = () => {\n      const changedOrDestroyed = merge(this.mtxOptions.changes, this._destroy$);\n      merge(...this.mtxOptions.map(option => option.stateChange$))\n        .pipe(takeUntil(changedOrDestroyed))\n        .subscribe(option => {\n          const item = this.ngSelect.itemsList.findItem(option.value);\n          item.disabled = option.disabled;\n          item.label = option.label || item.label;\n          this.ngSelect.detectChanges();\n        });\n    };\n\n    this.mtxOptions.changes\n      .pipe(startWith(this.mtxOptions), takeUntil(this._destroy$))\n      .subscribe(options => {\n        mapMtxOptions(options);\n        handleOptionChange();\n      });\n  }\n\n  open() {\n    this.ngSelect.open();\n  }\n\n  close() {\n    this.ngSelect.close();\n  }\n\n  focus() {\n    this.ngSelect.focus();\n  }\n\n  blur() {\n    this.ngSelect.blur();\n  }\n\n  static ngAcceptInputType_required: BooleanInput;\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n"]}
|
|
461
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../projects/extensions/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Self,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ErrorStateMatcher, mixinErrorState } from '@angular/material/core';\nimport { ControlValueAccessor, FormGroupDirective, NgControl, NgForm } from '@angular/forms';\nimport { MatFormField, MatFormFieldControl, MAT_FORM_FIELD } from '@angular/material/form-field';\nimport { merge, Subject } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\nimport { NgSelectComponent } from '@ng-select/ng-select';\nimport { MtxOptionComponent } from './option.component';\nimport {\n  MtxSelectFooterTemplateDirective,\n  MtxSelectHeaderTemplateDirective,\n  MtxSelectLabelTemplateDirective,\n  MtxSelectLoadingSpinnerTemplateDirective,\n  MtxSelectLoadingTextTemplateDirective,\n  MtxSelectMultiLabelTemplateDirective,\n  MtxSelectNotFoundTemplateDirective,\n  MtxSelectOptgroupTemplateDirective,\n  MtxSelectOptionTemplateDirective,\n  MtxSelectTagTemplateDirective,\n  MtxSelectTypeToSearchTemplateDirective,\n} from './templates.directive';\n\nexport type DropdownPosition = 'bottom' | 'top' | 'auto';\nexport type AddTagFn = (term: string) => any | Promise<any>;\nexport type CompareWithFn = (a: any, b: any) => boolean;\nexport type GroupValueFn = (\n  key: string | Record<string, any>,\n  children: any[]\n) => string | Record<string, any>;\nexport type SearchFn = (term: string, item: any) => boolean;\nexport type TrackByFn = (item: any) => any;\n\nlet nextUniqueId = 0;\n\n// Boilerplate for applying mixins to MtxSelect.\n/** @docs-private */\nconst _MtxSelectMixinBase = mixinErrorState(\n  class {\n    /**\n     * Emits whenever the component state changes and should cause the parent\n     * form-field to update. Implemented as part of `MatFormFieldControl`.\n     * @docs-private\n     */\n    readonly stateChanges = new Subject<void>();\n\n    constructor(\n      public _defaultErrorStateMatcher: ErrorStateMatcher,\n      public _parentForm: NgForm,\n      public _parentFormGroup: FormGroupDirective,\n      /**\n       * Form control bound to the component.\n       * Implemented as part of `MatFormFieldControl`.\n       * @docs-private\n       */\n      public ngControl: NgControl\n    ) {}\n  }\n);\n\n@Component({\n  selector: 'mtx-select',\n  exportAs: 'mtxSelect',\n  host: {\n    'role': 'combobox',\n    'aria-autocomplete': 'none',\n    '[attr.id]': 'id',\n    '[attr.aria-expanded]': 'panelOpen',\n    '[attr.aria-label]': 'ariaLabel || null',\n    '[attr.aria-labelledby]': '_getAriaLabelledby()',\n    '[attr.aria-describedby]': '_ariaDescribedby || null',\n    '[attr.aria-required]': 'required.toString()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-invalid]': 'errorState',\n    '[class.mtx-select-floating]': 'shouldLabelFloat',\n    '[class.mtx-select-disabled]': 'disabled',\n    '[class.mtx-select-invalid]': 'errorState',\n    '[class.mtx-select-required]': 'required',\n    '[class.mtx-select-empty]': 'empty',\n    '[class.mtx-select-multiple]': 'multiple',\n    'class': 'mtx-select',\n  },\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: MatFormFieldControl, useExisting: MtxSelectComponent }],\n})\nexport class MtxSelectComponent\n  extends _MtxSelectMixinBase\n  implements\n    OnInit,\n    OnDestroy,\n    DoCheck,\n    AfterViewInit,\n    ControlValueAccessor,\n    MatFormFieldControl<any>\n{\n  @ViewChild('ngSelect', { static: true }) ngSelect!: NgSelectComponent;\n\n  @ContentChild(MtxSelectOptionTemplateDirective, { read: TemplateRef })\n  optionTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectOptgroupTemplateDirective, { read: TemplateRef })\n  optgroupTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectLabelTemplateDirective, { read: TemplateRef })\n  labelTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectMultiLabelTemplateDirective, { read: TemplateRef })\n  multiLabelTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectHeaderTemplateDirective, { read: TemplateRef })\n  headerTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectFooterTemplateDirective, { read: TemplateRef })\n  footerTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectNotFoundTemplateDirective, { read: TemplateRef })\n  notFoundTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectTypeToSearchTemplateDirective, { read: TemplateRef })\n  typeToSearchTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectLoadingTextTemplateDirective, { read: TemplateRef })\n  loadingTextTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectTagTemplateDirective, { read: TemplateRef })\n  tagTemplate!: TemplateRef<any>;\n  @ContentChild(MtxSelectLoadingSpinnerTemplateDirective, { read: TemplateRef })\n  loadingSpinnerTemplate!: TemplateRef<any>;\n\n  @ContentChildren(MtxOptionComponent, { descendants: true })\n  mtxOptions!: QueryList<MtxOptionComponent>;\n\n  @Input() addTag: boolean | AddTagFn = false;\n  @Input() addTagText = 'Add item';\n  @Input() appearance = 'underline';\n  @Input() appendTo!: string;\n  @Input() bindLabel!: string;\n  @Input() bindValue!: string;\n  @Input() closeOnSelect = true;\n  @Input() clearAllText = 'Clear all';\n  @Input() clearable = true;\n  @Input() clearOnBackspace = true;\n  @Input() compareWith!: CompareWithFn;\n  @Input() dropdownPosition: DropdownPosition = 'auto';\n  @Input() groupBy!: string | (() => void);\n  @Input() groupValue!: GroupValueFn;\n  @Input() selectableGroup = false;\n  @Input() selectableGroupAsModel = true;\n  @Input() hideSelected = false;\n  @Input() isOpen!: boolean;\n  @Input() loading = false;\n  @Input() loadingText = 'Loading...';\n  @Input() labelForId: string | null = null;\n  @Input() markFirst = true;\n  @Input() maxSelectedItems!: number;\n  @Input() multiple = false;\n  @Input() notFoundText = 'No items found';\n  @Input() searchable = true;\n  @Input() readonly = false;\n  @Input() searchFn: SearchFn | null = null;\n  @Input() searchWhileComposing = true;\n  @Input() selectOnTab = false;\n  @Input() trackByFn: TrackByFn | null = null;\n  @Input() inputAttrs: { [key: string]: string } = {};\n  @Input() tabIndex!: number;\n  @Input() openOnEnter!: boolean;\n  @Input() minTermLength = 0;\n  @Input() editableSearchTerm = false;\n  @Input() keyDownFn = (_: KeyboardEvent) => true;\n  @Input() virtualScroll = false;\n  @Input() typeToSearchText = 'Type to search';\n  @Input() typeahead!: Subject<string>;\n\n  @Output('blur') blurEvent = new EventEmitter();\n  @Output('focus') focusEvent = new EventEmitter();\n  @Output('change') changeEvent = new EventEmitter();\n  @Output('open') openEvent = new EventEmitter();\n  @Output('close') closeEvent = new EventEmitter();\n  @Output('search') searchEvent = new EventEmitter<{ term: string; items: any[] }>();\n  @Output('clear') clearEvent = new EventEmitter();\n  @Output('add') addEvent = new EventEmitter();\n  @Output('remove') removeEvent = new EventEmitter();\n  @Output('scroll') scroll = new EventEmitter<{ start: number; end: number }>();\n  @Output('scrollToEnd') scrollToEnd = new EventEmitter();\n\n  @Input()\n  get clearSearchOnAdd() {\n    return this._clearSearchOnAdd ?? this.closeOnSelect;\n  }\n  set clearSearchOnAdd(value) {\n    this._clearSearchOnAdd = value;\n  }\n  private _clearSearchOnAdd?: boolean;\n\n  @Input()\n  get items() {\n    return this._items;\n  }\n  set items(value: any[]) {\n    this._itemsAreUsed = true;\n    this._items = value;\n  }\n  private _items: any[] = [];\n  private _itemsAreUsed = false;\n\n  /** Emits whenever the component is destroyed. */\n  private readonly _destroy$ = new Subject<void>();\n\n  /** Value of the select control. */\n  @Input()\n  get value(): any {\n    return this._value;\n  }\n  set value(newValue: any) {\n    this._value = newValue;\n    this._onChange(newValue);\n    this.stateChanges.next();\n  }\n  private _value = null;\n\n  /** Implemented as part of MatFormFieldControl. */\n  readonly stateChanges: Subject<void> = new Subject<void>();\n\n  /** Unique id of the element. */\n  @Input()\n  get id(): string {\n    return this._id;\n  }\n  set id(value: string) {\n    this._id = value || this._uid;\n    this.stateChanges.next();\n  }\n  private _id!: string;\n\n  /** Unique id for this select. */\n  private _uid = `mtx-select-${nextUniqueId++}`;\n\n  /** Placeholder to be shown if value is empty. */\n  @Input()\n  get placeholder(): string {\n    return this._placeholder;\n  }\n  set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n  private _placeholder!: string;\n\n  /** Whether the select is focused. */\n  get focused(): boolean {\n    return this._focused;\n  }\n  private _focused = false;\n\n  /** Whether the select has a value. */\n  get empty(): boolean {\n    return this.value == null || (Array.isArray(this.value) && this.value.length === 0);\n  }\n\n  /**\n   * Implemented as part of MatFormFieldControl.\n   * @docs-private\n   */\n  get shouldLabelFloat(): boolean {\n    return this.focused || !this.empty;\n  }\n\n  /** Whether the component is required. */\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n  private _required = false;\n\n  /** Whether the select is disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n    this.readonly = this._disabled;\n    this.stateChanges.next();\n    this._changeDetectorRef.markForCheck();\n  }\n  private _disabled = false;\n\n  /** Object used to control when error messages are shown. */\n  @Input() override errorStateMatcher!: ErrorStateMatcher;\n\n  /** Aria label of the select. */\n  @Input('aria-label') ariaLabel: string = '';\n\n  /** Input that can be used to specify the `aria-labelledby` attribute. */\n  @Input('aria-labelledby') ariaLabelledby: string | null = null;\n\n  /** The aria-describedby attribute on the select for improved a11y. */\n  _ariaDescribedby: string | null = null;\n\n  /** A name for this control that can be used by `mat-form-field`. */\n  controlType = 'mtx-select';\n\n  /** `View -> model callback called when value changes` */\n  _onChange: (value: any) => void = () => {};\n\n  /** `View -> model callback called when select has been touched` */\n  _onTouched = () => {};\n\n  /** ID for the DOM node containing the select's value. */\n  _valueId = `mtx-select-value-${nextUniqueId++}`;\n\n  /** Whether or not the overlay panel is open. */\n  get panelOpen(): boolean {\n    return !!this.ngSelect.isOpen;\n  }\n\n  constructor(\n    protected _changeDetectorRef: ChangeDetectorRef,\n    protected _elementRef: ElementRef,\n    protected _focusMonitor: FocusMonitor,\n    _defaultErrorStateMatcher: ErrorStateMatcher,\n    @Optional() _parentForm: NgForm,\n    @Optional() _parentFormGroup: FormGroupDirective,\n    @Optional() @Self() ngControl: NgControl,\n    @Optional() @Inject(MAT_FORM_FIELD) private _parentFormField?: MatFormField\n  ) {\n    super(_defaultErrorStateMatcher, _parentForm, _parentFormGroup, ngControl);\n\n    _focusMonitor.monitor(this._elementRef, true).subscribe(origin => {\n      if (this._focused && !origin) {\n        this._onTouched();\n      }\n      this._focused = !!origin;\n      this.stateChanges.next();\n    });\n\n    if (this.ngControl != null) {\n      // Note: we provide the value accessor through here, instead of\n      // the `providers` to avoid running into a circular import.\n      this.ngControl.valueAccessor = this;\n    }\n\n    // Force setter to be called in case id was not specified.\n    // eslint-disable-next-line no-self-assign\n    this.id = this.id;\n  }\n\n  ngOnInit() {\n    // Fix compareWith warning of undefined value\n    // https://github.com/ng-select/ng-select/issues/1537\n    if (this.compareWith) {\n      this.ngSelect.compareWith = this.compareWith;\n    }\n  }\n\n  ngAfterViewInit() {\n    if (!this._itemsAreUsed) {\n      this._setItemsFromMtxOptions();\n    }\n  }\n\n  ngDoCheck(): void {\n    if (this.ngControl) {\n      // We need to re-evaluate this on every change detection cycle, because there are some\n      // error triggers that we can't subscribe to (e.g. parent form submissions). This means\n      // that whatever logic is in here has to be super lean or we risk destroying the performance.\n      this.updateErrorState();\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n    this.stateChanges.complete();\n    this._focusMonitor.stopMonitoring(this._elementRef);\n  }\n\n  /** Gets the value for the `aria-labelledby` attribute of the inputs. */\n  _getAriaLabelledby() {\n    if (this.ariaLabel) {\n      return null;\n    }\n\n    const labelId = this._parentFormField?.getLabelId();\n    let value = (labelId ? labelId + ' ' : '') + this._valueId;\n\n    if (this.ariaLabelledby) {\n      value += ' ' + this.ariaLabelledby;\n    }\n\n    return value;\n  }\n\n  /** Implemented as part of MatFormFieldControl. */\n  setDescribedByIds(ids: string[]) {\n    this._ariaDescribedby = ids.length ? ids.join(' ') : null;\n  }\n\n  /**\n   * Disables the select. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param isDisabled Sets whether the component is disabled.\n   */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /** Implemented as part of MatFormFieldControl. */\n  onContainerClick(event: MouseEvent) {\n    const target = event.target as HTMLElement;\n    if (/mat-form-field|mtx-select/g.test(target.parentElement?.classList[0] || '')) {\n      this.focus();\n      this.open();\n    }\n  }\n\n  /**\n   * Sets the select's value. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param value New value to be written to the model.\n   */\n  writeValue(value: any): void {\n    this.value = value;\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select's value\n   * changes from user input. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the value changes.\n   */\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select is blurred\n   * by the user. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the component has been touched.\n   */\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  /** NgSelect's `_setItemsFromNgOptions` */\n  private _setItemsFromMtxOptions() {\n    const mapMtxOptions = (options: QueryList<MtxOptionComponent>) => {\n      this.items = options.map(option => ({\n        $ngOptionValue: option.value,\n        $ngOptionLabel: option.elementRef.nativeElement.innerHTML,\n        disabled: option.disabled,\n      }));\n      this.ngSelect.itemsList.setItems(this.items);\n      if (this.ngSelect.hasValue) {\n        this.ngSelect.itemsList.mapSelectedItems();\n      }\n      this.ngSelect.detectChanges();\n    };\n\n    const handleOptionChange = () => {\n      const changedOrDestroyed = merge(this.mtxOptions.changes, this._destroy$);\n      merge(...this.mtxOptions.map(option => option.stateChange$))\n        .pipe(takeUntil(changedOrDestroyed))\n        .subscribe(option => {\n          const item = this.ngSelect.itemsList.findItem(option.value);\n          item.disabled = option.disabled;\n          item.label = option.label || item.label;\n          this.ngSelect.detectChanges();\n        });\n    };\n\n    this.mtxOptions.changes\n      .pipe(startWith(this.mtxOptions), takeUntil(this._destroy$))\n      .subscribe(options => {\n        mapMtxOptions(options);\n        handleOptionChange();\n      });\n  }\n\n  open() {\n    this.ngSelect.open();\n  }\n\n  close() {\n    this.ngSelect.close();\n  }\n\n  focus() {\n    this.ngSelect.focus();\n  }\n\n  blur() {\n    this.ngSelect.blur();\n  }\n\n  static ngAcceptInputType_required: BooleanInput;\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { DOCUMENT, CommonModule } from '@angular/common';
|
|
2
|
-
import { InjectionToken, Component, ViewEncapsulation, ChangeDetectionStrategy, ElementRef, ChangeDetectorRef, EventEmitter, NgZone, ViewContainerRef, Inject, Optional, Input, Output, forwardRef, Directive, ContentChild, ViewChild, NgModule } from '@angular/core';
|
|
2
|
+
import { InjectionToken, Component, ViewEncapsulation, ChangeDetectionStrategy, ElementRef, ChangeDetectorRef, EventEmitter, NgZone, ViewContainerRef, Inject, Optional, Input, Output, forwardRef, Directive, Attribute, ContentChild, ViewChild, NgModule } from '@angular/core';
|
|
3
3
|
import { Overlay, OverlayConfig, OverlayModule } from '@angular/cdk/overlay';
|
|
4
4
|
import { A11yModule } from '@angular/cdk/a11y';
|
|
5
5
|
import { ComponentPortal, PortalModule } from '@angular/cdk/portal';
|
|
@@ -622,9 +622,11 @@ MtxColorpickerToggleIcon.decorators = [
|
|
|
622
622
|
},] }
|
|
623
623
|
];
|
|
624
624
|
class MtxColorpickerToggle {
|
|
625
|
-
constructor(_changeDetectorRef) {
|
|
625
|
+
constructor(_changeDetectorRef, defaultTabIndex) {
|
|
626
626
|
this._changeDetectorRef = _changeDetectorRef;
|
|
627
627
|
this._stateChanges = Subscription.EMPTY;
|
|
628
|
+
const parsedTabIndex = Number(defaultTabIndex);
|
|
629
|
+
this.tabIndex = parsedTabIndex || parsedTabIndex === 0 ? parsedTabIndex : null;
|
|
628
630
|
}
|
|
629
631
|
/** Whether the toggle button is disabled. */
|
|
630
632
|
get disabled() {
|
|
@@ -647,7 +649,7 @@ class MtxColorpickerToggle {
|
|
|
647
649
|
ngAfterContentInit() {
|
|
648
650
|
this._watchStateChanges();
|
|
649
651
|
}
|
|
650
|
-
|
|
652
|
+
_open(event) {
|
|
651
653
|
if (this.picker && !this.disabled) {
|
|
652
654
|
this.picker.open();
|
|
653
655
|
event.stopPropagation();
|
|
@@ -655,28 +657,31 @@ class MtxColorpickerToggle {
|
|
|
655
657
|
}
|
|
656
658
|
_watchStateChanges() {
|
|
657
659
|
const pickerDisabled = this.picker ? this.picker._disabledChange : of();
|
|
658
|
-
const inputDisabled = this.picker && this.picker.pickerInput
|
|
659
|
-
|
|
660
|
+
const inputDisabled = this.picker && this.picker.pickerInput
|
|
661
|
+
? this.picker.pickerInput._disabledChange
|
|
662
|
+
: of();
|
|
663
|
+
const pickerToggled = this.picker
|
|
660
664
|
? merge(this.picker.openedStream, this.picker.closedStream)
|
|
661
665
|
: of();
|
|
662
666
|
this._stateChanges.unsubscribe();
|
|
663
|
-
this._stateChanges = merge(
|
|
667
|
+
this._stateChanges = merge(pickerDisabled, inputDisabled, pickerToggled).subscribe(() => this._changeDetectorRef.markForCheck());
|
|
664
668
|
}
|
|
665
669
|
}
|
|
666
670
|
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
|
|
667
671
|
MtxColorpickerToggle.decorators = [
|
|
668
672
|
{ type: Component, args: [{
|
|
669
673
|
selector: 'mtx-colorpicker-toggle',
|
|
670
|
-
template: "<button #button\n mat-icon-button\n type=\"button\"\n [attr.aria-haspopup]=\"picker ? 'dialog' : null\"\n [attr.tabindex]=\"disabled ? -1 : tabIndex\"\n [disabled]=\"disabled\"\n [disableRipple]=\"disableRipple\"
|
|
674
|
+
template: "<button #button\n mat-icon-button\n type=\"button\"\n [attr.aria-haspopup]=\"picker ? 'dialog' : null\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.tabindex]=\"disabled ? -1 : tabIndex\"\n [disabled]=\"disabled\"\n [disableRipple]=\"disableRipple\">\n\n <svg *ngIf=\"!_customIcon\"\n class=\"mtx-colorpicker-toggle-default-icon\"\n viewBox=\"0 0 24 24\"\n width=\"24px\"\n height=\"24px\"\n fill=\"currentColor\"\n focusable=\"false\">\n <path\n d=\"M17.5,12A1.5,1.5 0 0,1 16,10.5A1.5,1.5 0 0,1 17.5,9A1.5,1.5 0 0,1 19,10.5A1.5,1.5 0 0,1 17.5,12M14.5,8A1.5,1.5 0 0,1 13,6.5A1.5,1.5 0 0,1 14.5,5A1.5,1.5 0 0,1 16,6.5A1.5,1.5 0 0,1 14.5,8M9.5,8A1.5,1.5 0 0,1 8,6.5A1.5,1.5 0 0,1 9.5,5A1.5,1.5 0 0,1 11,6.5A1.5,1.5 0 0,1 9.5,8M6.5,12A1.5,1.5 0 0,1 5,10.5A1.5,1.5 0 0,1 6.5,9A1.5,1.5 0 0,1 8,10.5A1.5,1.5 0 0,1 6.5,12M12,3A9,9 0 0,0 3,12A9,9 0 0,0 12,21A1.5,1.5 0 0,0 13.5,19.5C13.5,19.11 13.35,18.76 13.11,18.5C12.88,18.23 12.73,17.88 12.73,17.5A1.5,1.5 0 0,1 14.23,16H16A5,5 0 0,0 21,11C21,6.58 16.97,3 12,3Z\" />\n </svg>\n\n <ng-content select=\"[mtxColorpickerToggleIcon]\"></ng-content>\n</button>\n",
|
|
671
675
|
host: {
|
|
672
676
|
'class': 'mtx-colorpicker-toggle',
|
|
673
|
-
|
|
674
|
-
// consumer may have provided, while still being able to receive focus.
|
|
675
|
-
'[attr.tabindex]': 'disabled ? null : -1',
|
|
677
|
+
'[attr.tabindex]': 'null',
|
|
676
678
|
'[class.mtx-colorpicker-toggle-active]': 'picker && picker.opened',
|
|
677
679
|
'[class.mat-accent]': 'picker && picker.color === "accent"',
|
|
678
680
|
'[class.mat-warn]': 'picker && picker.color === "warn"',
|
|
679
|
-
|
|
681
|
+
// Bind the `click` on the host, rather than the inner `button`, so that we can call
|
|
682
|
+
// `stopPropagation` on it without affecting the user's `click` handlers. We need to stop
|
|
683
|
+
// it so that the input doesn't get focused automatically by the form field (See #21836).
|
|
684
|
+
'(click)': '_open($event)',
|
|
680
685
|
},
|
|
681
686
|
exportAs: 'mtxColorpickerToggle',
|
|
682
687
|
encapsulation: ViewEncapsulation.None,
|
|
@@ -692,12 +697,14 @@ MtxColorpickerToggle.decorators = [
|
|
|
692
697
|
* @nocollapse
|
|
693
698
|
*/
|
|
694
699
|
MtxColorpickerToggle.ctorParameters = () => [
|
|
695
|
-
{ type: ChangeDetectorRef }
|
|
700
|
+
{ type: ChangeDetectorRef },
|
|
701
|
+
{ type: String, decorators: [{ type: Attribute, args: ['tabindex',] }] }
|
|
696
702
|
];
|
|
697
703
|
/** @type {!Object<string, !Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
|
|
698
704
|
MtxColorpickerToggle.propDecorators = {
|
|
699
705
|
picker: [{ type: Input, args: ['for',] }],
|
|
700
706
|
tabIndex: [{ type: Input }],
|
|
707
|
+
ariaLabel: [{ type: Input, args: ['aria-label',] }],
|
|
701
708
|
disabled: [{ type: Input }],
|
|
702
709
|
disableRipple: [{ type: Input }],
|
|
703
710
|
_customIcon: [{ type: ContentChild, args: [MtxColorpickerToggleIcon,] }],
|