@angular/material 18.1.1 → 18.2.0-next.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/esm2022/core/version.mjs +1 -1
- package/esm2022/tooltip/tooltip.mjs +1 -1
- package/esm2022/tree/data-source/flat-data-source.mjs +9 -1
- package/esm2022/tree/node.mjs +99 -19
- package/esm2022/tree/testing/node-harness.mjs +5 -1
- package/esm2022/tree/tree.mjs +2 -3
- package/fesm2022/core.mjs +1 -1
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/tooltip.mjs.map +1 -1
- package/fesm2022/tree/testing.mjs +4 -0
- package/fesm2022/tree/testing.mjs.map +1 -1
- package/fesm2022/tree.mjs +108 -21
- package/fesm2022/tree.mjs.map +1 -1
- package/package.json +7 -7
- package/schematics/ng-add/index.js +2 -2
- package/schematics/ng-add/index.mjs +2 -2
- package/tooltip/index.d.ts +1 -1
- package/tree/index.d.ts +60 -11
- package/tree/testing/index.d.ts +2 -0
package/esm2022/tree/node.mjs
CHANGED
|
@@ -9,15 +9,70 @@ import { CDK_TREE_NODE_OUTLET_NODE, CdkNestedTreeNode, CdkTree, CdkTreeNode, Cdk
|
|
|
9
9
|
import { Attribute, Directive, ElementRef, Input, IterableDiffers, booleanAttribute, numberAttribute, } from '@angular/core';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "@angular/cdk/tree";
|
|
12
|
+
/**
|
|
13
|
+
* Determinte if argument TreeKeyManager is the NoopTreeKeyManager. This function is safe to use with SSR.
|
|
14
|
+
*/
|
|
15
|
+
function isNoopTreeKeyManager(keyManager) {
|
|
16
|
+
return !!keyManager._isNoopTreeKeyManager;
|
|
17
|
+
}
|
|
12
18
|
/**
|
|
13
19
|
* Wrapper for the CdkTree node with Material design styles.
|
|
14
20
|
*/
|
|
15
21
|
export class MatTreeNode extends CdkTreeNode {
|
|
16
|
-
|
|
22
|
+
/**
|
|
23
|
+
* The tabindex of the tree node.
|
|
24
|
+
*
|
|
25
|
+
* @deprecated By default MatTreeNode manages focus using TreeKeyManager instead of tabIndex.
|
|
26
|
+
* Recommend to avoid setting tabIndex directly to prevent TreeKeyManager form getting into
|
|
27
|
+
* an unexpected state. Tabindex to be removed in a future version.
|
|
28
|
+
* @breaking-change 21.0.0 Remove this attribute.
|
|
29
|
+
*/
|
|
30
|
+
get tabIndexInputBinding() {
|
|
31
|
+
return this._tabIndexInputBinding;
|
|
32
|
+
}
|
|
33
|
+
set tabIndexInputBinding(value) {
|
|
34
|
+
// If the specified tabIndex value is null or undefined, fall back to the default value.
|
|
35
|
+
this._tabIndexInputBinding = value;
|
|
36
|
+
}
|
|
37
|
+
_getTabindexAttribute() {
|
|
38
|
+
if (isNoopTreeKeyManager(this._tree._keyManager)) {
|
|
39
|
+
return this.tabIndexInputBinding;
|
|
40
|
+
}
|
|
41
|
+
return this._tabindex;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Whether the component is disabled.
|
|
45
|
+
*
|
|
46
|
+
* @deprecated This is an alias for `isDisabled`.
|
|
47
|
+
* @breaking-change 21.0.0 Remove this input
|
|
48
|
+
*/
|
|
49
|
+
get disabled() {
|
|
50
|
+
return this.isDisabled;
|
|
51
|
+
}
|
|
52
|
+
set disabled(value) {
|
|
53
|
+
this.isDisabled = value;
|
|
54
|
+
}
|
|
55
|
+
constructor(elementRef, tree,
|
|
56
|
+
/**
|
|
57
|
+
* The tabindex of the tree node.
|
|
58
|
+
*
|
|
59
|
+
* @deprecated By default MatTreeNode manages focus using TreeKeyManager instead of tabIndex.
|
|
60
|
+
* Recommend to avoid setting tabIndex directly to prevent TreeKeyManager form getting into
|
|
61
|
+
* an unexpected state. Tabindex to be removed in a future version.
|
|
62
|
+
* @breaking-change 21.0.0 Remove this attribute.
|
|
63
|
+
*/
|
|
64
|
+
tabIndex) {
|
|
17
65
|
super(elementRef, tree);
|
|
18
|
-
/**
|
|
19
|
-
|
|
20
|
-
|
|
66
|
+
/**
|
|
67
|
+
* The default tabindex of the tree node.
|
|
68
|
+
*
|
|
69
|
+
* @deprecated By default MatTreeNode manages focus using TreeKeyManager instead of tabIndex.
|
|
70
|
+
* Recommend to avoid setting tabIndex directly to prevent TreeKeyManager form getting into
|
|
71
|
+
* an unexpected state. Tabindex to be removed in a future version.
|
|
72
|
+
* @breaking-change 21.0.0 Remove this attribute.
|
|
73
|
+
*/
|
|
74
|
+
this.defaultTabIndex = 0;
|
|
75
|
+
this.tabIndexInputBinding = Number(tabIndex) || this.defaultTabIndex;
|
|
21
76
|
}
|
|
22
77
|
// This is a workaround for https://github.com/angular/angular/issues/23091
|
|
23
78
|
// In aot mode, the lifecycle hooks from parent class are not called.
|
|
@@ -28,30 +83,38 @@ export class MatTreeNode extends CdkTreeNode {
|
|
|
28
83
|
super.ngOnDestroy();
|
|
29
84
|
}
|
|
30
85
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: MatTreeNode, deps: [{ token: i0.ElementRef }, { token: i1.CdkTree }, { token: 'tabindex', attribute: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
31
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.1.0", type: MatTreeNode, isStandalone: true, selector: "mat-tree-node", inputs: { disabled: ["disabled", "disabled", booleanAttribute],
|
|
86
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.1.0", type: MatTreeNode, isStandalone: true, selector: "mat-tree-node", inputs: { tabIndexInputBinding: ["tabIndex", "tabIndexInputBinding", (value) => (value == null ? 0 : numberAttribute(value))], disabled: ["disabled", "disabled", booleanAttribute] }, outputs: { activation: "activation", expandedChange: "expandedChange" }, host: { listeners: { "click": "_focusItem()" }, properties: { "attr.aria-expanded": "_getAriaExpanded()", "attr.aria-level": "level + 1", "attr.aria-posinset": "_getPositionInSet()", "attr.aria-setsize": "_getSetSize()", "tabindex": "_getTabindexAttribute()" }, classAttribute: "mat-tree-node" }, providers: [{ provide: CdkTreeNode, useExisting: MatTreeNode }], exportAs: ["matTreeNode"], usesInheritance: true, ngImport: i0 }); }
|
|
32
87
|
}
|
|
33
88
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: MatTreeNode, decorators: [{
|
|
34
89
|
type: Directive,
|
|
35
90
|
args: [{
|
|
36
91
|
selector: 'mat-tree-node',
|
|
37
92
|
exportAs: 'matTreeNode',
|
|
93
|
+
outputs: ['activation', 'expandedChange'],
|
|
38
94
|
providers: [{ provide: CdkTreeNode, useExisting: MatTreeNode }],
|
|
39
95
|
host: {
|
|
40
96
|
'class': 'mat-tree-node',
|
|
97
|
+
'[attr.aria-expanded]': '_getAriaExpanded()',
|
|
98
|
+
'[attr.aria-level]': 'level + 1',
|
|
99
|
+
'[attr.aria-posinset]': '_getPositionInSet()',
|
|
100
|
+
'[attr.aria-setsize]': '_getSetSize()',
|
|
101
|
+
'(click)': '_focusItem()',
|
|
102
|
+
'[tabindex]': '_getTabindexAttribute()',
|
|
41
103
|
},
|
|
42
104
|
standalone: true,
|
|
43
105
|
}]
|
|
44
106
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.CdkTree }, { type: undefined, decorators: [{
|
|
45
107
|
type: Attribute,
|
|
46
108
|
args: ['tabindex']
|
|
47
|
-
}] }], propDecorators: {
|
|
48
|
-
type: Input,
|
|
49
|
-
args: [{ transform: booleanAttribute }]
|
|
50
|
-
}], tabIndex: [{
|
|
109
|
+
}] }], propDecorators: { tabIndexInputBinding: [{
|
|
51
110
|
type: Input,
|
|
52
111
|
args: [{
|
|
53
112
|
transform: (value) => (value == null ? 0 : numberAttribute(value)),
|
|
113
|
+
alias: 'tabIndex',
|
|
54
114
|
}]
|
|
115
|
+
}], disabled: [{
|
|
116
|
+
type: Input,
|
|
117
|
+
args: [{ transform: booleanAttribute }]
|
|
55
118
|
}] } });
|
|
56
119
|
/**
|
|
57
120
|
* Wrapper for the CdkTree node definition with Material design styles.
|
|
@@ -77,19 +140,32 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
77
140
|
* Wrapper for the CdkTree nested node with Material design styles.
|
|
78
141
|
*/
|
|
79
142
|
export class MatNestedTreeNode extends CdkNestedTreeNode {
|
|
80
|
-
/**
|
|
143
|
+
/**
|
|
144
|
+
* Whether the node is disabled.
|
|
145
|
+
*
|
|
146
|
+
* @deprecated This is an alias for `isDisabled`.
|
|
147
|
+
* @breaking-change 21.0.0 Remove this input
|
|
148
|
+
*/
|
|
149
|
+
get disabled() {
|
|
150
|
+
return this.isDisabled;
|
|
151
|
+
}
|
|
152
|
+
set disabled(value) {
|
|
153
|
+
this.isDisabled = value;
|
|
154
|
+
}
|
|
155
|
+
/** Tabindex of the node. */
|
|
81
156
|
get tabIndex() {
|
|
82
|
-
return this.
|
|
157
|
+
return this.isDisabled ? -1 : this._tabIndex;
|
|
83
158
|
}
|
|
84
159
|
set tabIndex(value) {
|
|
85
160
|
// If the specified tabIndex value is null or undefined, fall back to the default value.
|
|
86
|
-
this._tabIndex = value
|
|
161
|
+
this._tabIndex = value;
|
|
87
162
|
}
|
|
88
|
-
constructor(elementRef, tree, differs,
|
|
163
|
+
constructor(elementRef, tree, differs,
|
|
164
|
+
// Ignore tabindex attribute. MatTree manages its own active state using TreeKeyManager.
|
|
165
|
+
// Keeping tabIndex in constructor for backwards compatibility with trees created before
|
|
166
|
+
// introducing TreeKeyManager.
|
|
167
|
+
tabIndex) {
|
|
89
168
|
super(elementRef, tree, differs);
|
|
90
|
-
/** Whether the node is disabled. */
|
|
91
|
-
this.disabled = false;
|
|
92
|
-
this.tabIndex = Number(tabIndex) || 0;
|
|
93
169
|
}
|
|
94
170
|
// This is a workaround for https://github.com/angular/angular/issues/19145
|
|
95
171
|
// In aot mode, the lifecycle hooks from parent class are not called.
|
|
@@ -104,7 +180,7 @@ export class MatNestedTreeNode extends CdkNestedTreeNode {
|
|
|
104
180
|
super.ngOnDestroy();
|
|
105
181
|
}
|
|
106
182
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: MatNestedTreeNode, deps: [{ token: i0.ElementRef }, { token: i1.CdkTree }, { token: i0.IterableDiffers }, { token: 'tabindex', attribute: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
107
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.1.0", type: MatNestedTreeNode, isStandalone: true, selector: "mat-nested-tree-node", inputs: { node: ["matNestedTreeNode", "node"], disabled: ["disabled", "disabled", booleanAttribute], tabIndex: "tabIndex" }, host: { classAttribute: "mat-nested-tree-node" }, providers: [
|
|
183
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.1.0", type: MatNestedTreeNode, isStandalone: true, selector: "mat-nested-tree-node", inputs: { node: ["matNestedTreeNode", "node"], disabled: ["disabled", "disabled", booleanAttribute], tabIndex: ["tabIndex", "tabIndex", (value) => (value == null ? 0 : numberAttribute(value))] }, outputs: { activation: "activation", expandedChange: "expandedChange" }, host: { classAttribute: "mat-nested-tree-node" }, providers: [
|
|
108
184
|
{ provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode },
|
|
109
185
|
{ provide: CdkTreeNode, useExisting: MatNestedTreeNode },
|
|
110
186
|
{ provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: MatNestedTreeNode },
|
|
@@ -115,6 +191,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
115
191
|
args: [{
|
|
116
192
|
selector: 'mat-nested-tree-node',
|
|
117
193
|
exportAs: 'matNestedTreeNode',
|
|
194
|
+
outputs: ['activation', 'expandedChange'],
|
|
118
195
|
providers: [
|
|
119
196
|
{ provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode },
|
|
120
197
|
{ provide: CdkTreeNode, useExisting: MatNestedTreeNode },
|
|
@@ -135,6 +212,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
135
212
|
type: Input,
|
|
136
213
|
args: [{ transform: booleanAttribute }]
|
|
137
214
|
}], tabIndex: [{
|
|
138
|
-
type: Input
|
|
215
|
+
type: Input,
|
|
216
|
+
args: [{
|
|
217
|
+
transform: (value) => (value == null ? 0 : numberAttribute(value)),
|
|
218
|
+
}]
|
|
139
219
|
}] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../../../../src/material/tree/node.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  CDK_TREE_NODE_OUTLET_NODE,\n  CdkNestedTreeNode,\n  CdkTree,\n  CdkTreeNode,\n  CdkTreeNodeDef,\n} from '@angular/cdk/tree';\nimport {\n  AfterContentInit,\n  Attribute,\n  Directive,\n  ElementRef,\n  Input,\n  IterableDiffers,\n  OnDestroy,\n  OnInit,\n  booleanAttribute,\n  numberAttribute,\n} from '@angular/core';\n\n/**\n * Wrapper for the CdkTree node with Material design styles.\n */\n@Directive({\n  selector: 'mat-tree-node',\n  exportAs: 'matTreeNode',\n  providers: [{provide: CdkTreeNode, useExisting: MatTreeNode}],\n  host: {\n    'class': 'mat-tree-node',\n  },\n  standalone: true,\n})\nexport class MatTreeNode<T, K = T> extends CdkTreeNode<T, K> implements OnInit, OnDestroy {\n  /** Whether the node is disabled. */\n  @Input({transform: booleanAttribute})\n  disabled: boolean = false;\n\n  /** Tabindex of the node. */\n  @Input({\n    transform: (value: unknown) => (value == null ? 0 : numberAttribute(value)),\n  })\n  tabIndex: number;\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    tree: CdkTree<T, K>,\n    @Attribute('tabindex') tabIndex: string,\n  ) {\n    super(elementRef, tree);\n    this.tabIndex = Number(tabIndex) || 0;\n  }\n\n  // This is a workaround for https://github.com/angular/angular/issues/23091\n  // In aot mode, the lifecycle hooks from parent class are not called.\n  override ngOnInit() {\n    super.ngOnInit();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n  }\n}\n\n/**\n * Wrapper for the CdkTree node definition with Material design styles.\n * Captures the node's template and a when predicate that describes when this node should be used.\n */\n@Directive({\n  selector: '[matTreeNodeDef]',\n  inputs: [{name: 'when', alias: 'matTreeNodeDefWhen'}],\n  providers: [{provide: CdkTreeNodeDef, useExisting: MatTreeNodeDef}],\n  standalone: true,\n})\nexport class MatTreeNodeDef<T> extends CdkTreeNodeDef<T> {\n  @Input('matTreeNode') data: T;\n}\n\n/**\n * Wrapper for the CdkTree nested node with Material design styles.\n */\n@Directive({\n  selector: 'mat-nested-tree-node',\n  exportAs: 'matNestedTreeNode',\n  providers: [\n    {provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode},\n    {provide: CdkTreeNode, useExisting: MatNestedTreeNode},\n    {provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: MatNestedTreeNode},\n  ],\n  host: {\n    'class': 'mat-nested-tree-node',\n  },\n  standalone: true,\n})\nexport class MatNestedTreeNode<T, K = T>\n  extends CdkNestedTreeNode<T, K>\n  implements AfterContentInit, OnDestroy, OnInit\n{\n  @Input('matNestedTreeNode') node: T;\n\n  /** Whether the node is disabled. */\n  @Input({transform: booleanAttribute})\n  disabled: boolean = false;\n\n  /** Tabindex for the node. */\n  @Input()\n  get tabIndex(): number {\n    return this.disabled ? -1 : this._tabIndex;\n  }\n  set tabIndex(value: number) {\n    // If the specified tabIndex value is null or undefined, fall back to the default value.\n    this._tabIndex = value != null ? value : 0;\n  }\n  private _tabIndex: number;\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    tree: CdkTree<T, K>,\n    differs: IterableDiffers,\n    @Attribute('tabindex') tabIndex: string,\n  ) {\n    super(elementRef, tree, differs);\n    this.tabIndex = Number(tabIndex) || 0;\n  }\n\n  // This is a workaround for https://github.com/angular/angular/issues/19145\n  // In aot mode, the lifecycle hooks from parent class are not called.\n  // TODO(tinayuangao): Remove when the angular issue #19145 is fixed\n  override ngOnInit() {\n    super.ngOnInit();\n  }\n\n  override ngAfterContentInit() {\n    super.ngAfterContentInit();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n  }\n}\n"]}
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../../../../src/material/tree/node.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  CDK_TREE_NODE_OUTLET_NODE,\n  CdkNestedTreeNode,\n  CdkTree,\n  CdkTreeNode,\n  CdkTreeNodeDef,\n} from '@angular/cdk/tree';\nimport {\n  AfterContentInit,\n  Attribute,\n  Directive,\n  ElementRef,\n  Input,\n  IterableDiffers,\n  OnDestroy,\n  OnInit,\n  booleanAttribute,\n  numberAttribute,\n} from '@angular/core';\nimport {NoopTreeKeyManager, TreeKeyManagerItem, TreeKeyManagerStrategy} from '@angular/cdk/a11y';\n\n/**\n * Determinte if argument TreeKeyManager is the NoopTreeKeyManager. This function is safe to use with SSR.\n */\nfunction isNoopTreeKeyManager<T extends TreeKeyManagerItem>(\n  keyManager: TreeKeyManagerStrategy<T>,\n): keyManager is NoopTreeKeyManager<T> {\n  return !!(keyManager as any)._isNoopTreeKeyManager;\n}\n\n/**\n * Wrapper for the CdkTree node with Material design styles.\n */\n@Directive({\n  selector: 'mat-tree-node',\n  exportAs: 'matTreeNode',\n  outputs: ['activation', 'expandedChange'],\n  providers: [{provide: CdkTreeNode, useExisting: MatTreeNode}],\n  host: {\n    'class': 'mat-tree-node',\n    '[attr.aria-expanded]': '_getAriaExpanded()',\n    '[attr.aria-level]': 'level + 1',\n    '[attr.aria-posinset]': '_getPositionInSet()',\n    '[attr.aria-setsize]': '_getSetSize()',\n    '(click)': '_focusItem()',\n    '[tabindex]': '_getTabindexAttribute()',\n  },\n  standalone: true,\n})\nexport class MatTreeNode<T, K = T> extends CdkTreeNode<T, K> implements OnInit, OnDestroy {\n  /**\n   * The tabindex of the tree node.\n   *\n   * @deprecated By default MatTreeNode manages focus using TreeKeyManager instead of tabIndex.\n   *   Recommend to avoid setting tabIndex directly to prevent TreeKeyManager form getting into\n   *   an unexpected state. Tabindex to be removed in a future version.\n   * @breaking-change 21.0.0 Remove this attribute.\n   */\n  @Input({\n    transform: (value: unknown) => (value == null ? 0 : numberAttribute(value)),\n    alias: 'tabIndex',\n  })\n  get tabIndexInputBinding(): number {\n    return this._tabIndexInputBinding;\n  }\n  set tabIndexInputBinding(value: number) {\n    // If the specified tabIndex value is null or undefined, fall back to the default value.\n    this._tabIndexInputBinding = value;\n  }\n  private _tabIndexInputBinding: number;\n\n  /**\n   * The default tabindex of the tree node.\n   *\n   * @deprecated By default MatTreeNode manages focus using TreeKeyManager instead of tabIndex.\n   *   Recommend to avoid setting tabIndex directly to prevent TreeKeyManager form getting into\n   *   an unexpected state. Tabindex to be removed in a future version.\n   * @breaking-change 21.0.0 Remove this attribute.\n   */\n  defaultTabIndex = 0;\n\n  protected _getTabindexAttribute() {\n    if (isNoopTreeKeyManager(this._tree._keyManager)) {\n      return this.tabIndexInputBinding;\n    }\n    return this._tabindex;\n  }\n\n  /**\n   * Whether the component is disabled.\n   *\n   * @deprecated This is an alias for `isDisabled`.\n   * @breaking-change 21.0.0 Remove this input\n   */\n  @Input({transform: booleanAttribute})\n  get disabled(): boolean {\n    return this.isDisabled;\n  }\n  set disabled(value: boolean) {\n    this.isDisabled = value;\n  }\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    tree: CdkTree<T, K>,\n    /**\n     * The tabindex of the tree node.\n     *\n     * @deprecated By default MatTreeNode manages focus using TreeKeyManager instead of tabIndex.\n     *   Recommend to avoid setting tabIndex directly to prevent TreeKeyManager form getting into\n     *   an unexpected state. Tabindex to be removed in a future version.\n     * @breaking-change 21.0.0 Remove this attribute.\n     */\n    @Attribute('tabindex') tabIndex: string,\n  ) {\n    super(elementRef, tree);\n\n    this.tabIndexInputBinding = Number(tabIndex) || this.defaultTabIndex;\n  }\n\n  // This is a workaround for https://github.com/angular/angular/issues/23091\n  // In aot mode, the lifecycle hooks from parent class are not called.\n  override ngOnInit() {\n    super.ngOnInit();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n  }\n}\n\n/**\n * Wrapper for the CdkTree node definition with Material design styles.\n * Captures the node's template and a when predicate that describes when this node should be used.\n */\n@Directive({\n  selector: '[matTreeNodeDef]',\n  inputs: [{name: 'when', alias: 'matTreeNodeDefWhen'}],\n  providers: [{provide: CdkTreeNodeDef, useExisting: MatTreeNodeDef}],\n  standalone: true,\n})\nexport class MatTreeNodeDef<T> extends CdkTreeNodeDef<T> {\n  @Input('matTreeNode') data: T;\n}\n\n/**\n * Wrapper for the CdkTree nested node with Material design styles.\n */\n@Directive({\n  selector: 'mat-nested-tree-node',\n  exportAs: 'matNestedTreeNode',\n  outputs: ['activation', 'expandedChange'],\n  providers: [\n    {provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode},\n    {provide: CdkTreeNode, useExisting: MatNestedTreeNode},\n    {provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: MatNestedTreeNode},\n  ],\n  host: {\n    'class': 'mat-nested-tree-node',\n  },\n  standalone: true,\n})\nexport class MatNestedTreeNode<T, K = T>\n  extends CdkNestedTreeNode<T, K>\n  implements AfterContentInit, OnDestroy, OnInit\n{\n  @Input('matNestedTreeNode') node: T;\n\n  /**\n   * Whether the node is disabled.\n   *\n   * @deprecated This is an alias for `isDisabled`.\n   * @breaking-change 21.0.0 Remove this input\n   */\n  @Input({transform: booleanAttribute})\n  get disabled(): boolean {\n    return this.isDisabled;\n  }\n  set disabled(value: boolean) {\n    this.isDisabled = value;\n  }\n\n  /** Tabindex of the node. */\n  @Input({\n    transform: (value: unknown) => (value == null ? 0 : numberAttribute(value)),\n  })\n  get tabIndex(): number {\n    return this.isDisabled ? -1 : this._tabIndex;\n  }\n  set tabIndex(value: number) {\n    // If the specified tabIndex value is null or undefined, fall back to the default value.\n    this._tabIndex = value;\n  }\n  private _tabIndex: number;\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    tree: CdkTree<T, K>,\n    differs: IterableDiffers,\n    // Ignore tabindex attribute. MatTree manages its own active state using TreeKeyManager.\n    // Keeping tabIndex in constructor for backwards compatibility with trees created before\n    // introducing TreeKeyManager.\n    @Attribute('tabindex') tabIndex: string,\n  ) {\n    super(elementRef, tree, differs);\n  }\n\n  // This is a workaround for https://github.com/angular/angular/issues/19145\n  // In aot mode, the lifecycle hooks from parent class are not called.\n  // TODO(tinayuangao): Remove when the angular issue #19145 is fixed\n  override ngOnInit() {\n    super.ngOnInit();\n  }\n\n  override ngAfterContentInit() {\n    super.ngAfterContentInit();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n  }\n}\n"]}
|
|
@@ -27,6 +27,10 @@ export class MatTreeNodeHarness extends ContentContainerComponentHarness {
|
|
|
27
27
|
async isExpanded() {
|
|
28
28
|
return coerceBooleanProperty(await (await this.host()).getAttribute('aria-expanded'));
|
|
29
29
|
}
|
|
30
|
+
/** Whether the tree node is expandable. */
|
|
31
|
+
async isExpandable() {
|
|
32
|
+
return (await (await this.host()).getAttribute('aria-expanded')) !== null;
|
|
33
|
+
}
|
|
30
34
|
/** Whether the tree node is disabled. */
|
|
31
35
|
async isDisabled() {
|
|
32
36
|
return coerceBooleanProperty(await (await this.host()).getProperty('aria-disabled'));
|
|
@@ -66,4 +70,4 @@ function getNodePredicate(type, options) {
|
|
|
66
70
|
.addOption('expanded', options.expanded, async (harness, expanded) => (await harness.isExpanded()) === expanded)
|
|
67
71
|
.addOption('level', options.level, async (harness, level) => (await harness.getLevel()) === level);
|
|
68
72
|
}
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-harness.js","sourceRoot":"","sources":["../../../../../../../src/material/tree/testing/node-harness.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  ComponentHarnessConstructor,\n  ContentContainerComponentHarness,\n  HarnessPredicate,\n} from '@angular/cdk/testing';\nimport {TreeNodeHarnessFilters} from './tree-harness-filters';\nimport {coerceBooleanProperty, coerceNumberProperty} from '@angular/cdk/coercion';\n\n/** Harness for interacting with a standard Angular Material tree node. */\nexport class MatTreeNodeHarness extends ContentContainerComponentHarness<string> {\n  /** The selector of the host element of a `MatTreeNode` instance. */\n  static hostSelector = '.mat-tree-node, .mat-nested-tree-node';\n\n  _toggle = this.locatorForOptional('[matTreeNodeToggle]');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a tree node with specific attributes.\n   * @param options Options for narrowing the search\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: TreeNodeHarnessFilters = {}): HarnessPredicate<MatTreeNodeHarness> {\n    return getNodePredicate(MatTreeNodeHarness, options);\n  }\n\n  /** Whether the tree node is expanded. */\n  async isExpanded(): Promise<boolean> {\n    return coerceBooleanProperty(await (await this.host()).getAttribute('aria-expanded'));\n  }\n\n  /** Whether the tree node is expandable. */\n  async isExpandable(): Promise<boolean> {\n    return (await (await this.host()).getAttribute('aria-expanded')) !== null;\n  }\n\n  /** Whether the tree node is disabled. */\n  async isDisabled(): Promise<boolean> {\n    return coerceBooleanProperty(await (await this.host()).getProperty('aria-disabled'));\n  }\n\n  /** Gets the level of the tree node. Note that this gets the aria-level and is 1 indexed. */\n  async getLevel(): Promise<number> {\n    return coerceNumberProperty(await (await this.host()).getAttribute('aria-level'));\n  }\n\n  /** Gets the tree node's text. */\n  async getText(): Promise<string> {\n    return (await this.host()).text({exclude: '.mat-tree-node, .mat-nested-tree-node, button'});\n  }\n\n  /** Toggles node between expanded/collapsed. Only works when node is not disabled. */\n  async toggle(): Promise<void> {\n    const toggle = await this._toggle();\n    if (toggle) {\n      return toggle.click();\n    }\n  }\n\n  /** Expands the node if it is collapsed. Only works when node is not disabled. */\n  async expand(): Promise<void> {\n    if (!(await this.isExpanded())) {\n      await this.toggle();\n    }\n  }\n\n  /** Collapses the node if it is expanded. Only works when node is not disabled. */\n  async collapse(): Promise<void> {\n    if (await this.isExpanded()) {\n      await this.toggle();\n    }\n  }\n}\n\nfunction getNodePredicate<T extends MatTreeNodeHarness>(\n  type: ComponentHarnessConstructor<T>,\n  options: TreeNodeHarnessFilters,\n): HarnessPredicate<T> {\n  return new HarnessPredicate(type, options)\n    .addOption('text', options.text, (harness, text) =>\n      HarnessPredicate.stringMatches(harness.getText(), text),\n    )\n    .addOption(\n      'disabled',\n      options.disabled,\n      async (harness, disabled) => (await harness.isDisabled()) === disabled,\n    )\n    .addOption(\n      'expanded',\n      options.expanded,\n      async (harness, expanded) => (await harness.isExpanded()) === expanded,\n    )\n    .addOption(\n      'level',\n      options.level,\n      async (harness, level) => (await harness.getLevel()) === level,\n    );\n}\n"]}
|
package/esm2022/tree/tree.mjs
CHANGED
|
@@ -20,16 +20,15 @@ export class MatTree extends CdkTree {
|
|
|
20
20
|
this._nodeOutlet = undefined;
|
|
21
21
|
}
|
|
22
22
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: MatTree, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: MatTree, isStandalone: true, selector: "mat-tree", host: {
|
|
23
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: MatTree, isStandalone: true, selector: "mat-tree", host: { classAttribute: "mat-tree" }, providers: [{ provide: CdkTree, useExisting: MatTree }], viewQueries: [{ propertyName: "_nodeOutlet", first: true, predicate: MatTreeNodeOutlet, descendants: true, static: true }], exportAs: ["matTree"], usesInheritance: true, ngImport: i0, template: `<ng-container matTreeNodeOutlet></ng-container>`, isInline: true, styles: [".mat-tree{display:block;background-color:var(--mat-tree-container-background-color)}.mat-tree-node,.mat-nested-tree-node{color:var(--mat-tree-node-text-color);font-family:var(--mat-tree-node-text-font);font-size:var(--mat-tree-node-text-size);font-weight:var(--mat-tree-node-text-weight)}.mat-tree-node{display:flex;align-items:center;flex:1;word-wrap:break-word;min-height:var(--mat-tree-node-min-height)}.mat-nested-tree-node{border-bottom-width:0}"], dependencies: [{ kind: "directive", type: MatTreeNodeOutlet, selector: "[matTreeNodeOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
|
|
24
24
|
}
|
|
25
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: MatTree, decorators: [{
|
|
26
26
|
type: Component,
|
|
27
27
|
args: [{ selector: 'mat-tree', exportAs: 'matTree', template: `<ng-container matTreeNodeOutlet></ng-container>`, host: {
|
|
28
28
|
'class': 'mat-tree',
|
|
29
|
-
'role': 'tree',
|
|
30
29
|
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.Default, providers: [{ provide: CdkTree, useExisting: MatTree }], standalone: true, imports: [MatTreeNodeOutlet], styles: [".mat-tree{display:block;background-color:var(--mat-tree-container-background-color)}.mat-tree-node,.mat-nested-tree-node{color:var(--mat-tree-node-text-color);font-family:var(--mat-tree-node-text-font);font-size:var(--mat-tree-node-text-size);font-weight:var(--mat-tree-node-text-weight)}.mat-tree-node{display:flex;align-items:center;flex:1;word-wrap:break-word;min-height:var(--mat-tree-node-min-height)}.mat-nested-tree-node{border-bottom-width:0}"] }]
|
|
31
30
|
}], propDecorators: { _nodeOutlet: [{
|
|
32
31
|
type: ViewChild,
|
|
33
32
|
args: [MatTreeNodeOutlet, { static: true }]
|
|
34
33
|
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9tYXRlcmlhbC90cmVlL3RyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzFDLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQy9GLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLFVBQVUsQ0FBQzs7QUFFM0M7O0dBRUc7QUFpQkgsTUFBTSxPQUFPLE9BQWtCLFNBQVEsT0FBYTtJQWhCcEQ7O1FBaUJFLDJFQUEyRTtRQUMzRSwrRkFBK0Y7UUFDeEMsZ0JBQVcsR0FDaEUsU0FBVSxDQUFDO0tBQ2Q7OEdBTFksT0FBTztrR0FBUCxPQUFPLDZGQUpQLENBQUMsRUFBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUMsQ0FBQyx1RUFPMUMsaUJBQWlCLDRHQWhCbEIsaURBQWlELDRnQkFXakQsaUJBQWlCOzsyRkFFaEIsT0FBTztrQkFoQm5CLFNBQVM7K0JBQ0UsVUFBVSxZQUNWLFNBQVMsWUFDVCxpREFBaUQsUUFDckQ7d0JBQ0osT0FBTyxFQUFFLFVBQVU7cUJBQ3BCLGlCQUVjLGlCQUFpQixDQUFDLElBQUksbUJBR3BCLHVCQUF1QixDQUFDLE9BQU8sYUFDckMsQ0FBQyxFQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsV0FBVyxTQUFTLEVBQUMsQ0FBQyxjQUN6QyxJQUFJLFdBQ1AsQ0FBQyxpQkFBaUIsQ0FBQzs4QkFLMkIsV0FBVztzQkFBakUsU0FBUzt1QkFBQyxpQkFBaUIsRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtDZGtUcmVlfSBmcm9tICdAYW5ndWxhci9jZGsvdHJlZSc7XG5pbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIFZpZXdDaGlsZCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtNYXRUcmVlTm9kZU91dGxldH0gZnJvbSAnLi9vdXRsZXQnO1xuXG4vKipcbiAqIFdyYXBwZXIgZm9yIHRoZSBDZGtUYWJsZSB3aXRoIE1hdGVyaWFsIGRlc2lnbiBzdHlsZXMuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21hdC10cmVlJyxcbiAgZXhwb3J0QXM6ICdtYXRUcmVlJyxcbiAgdGVtcGxhdGU6IGA8bmctY29udGFpbmVyIG1hdFRyZWVOb2RlT3V0bGV0PjwvbmctY29udGFpbmVyPmAsXG4gIGhvc3Q6IHtcbiAgICAnY2xhc3MnOiAnbWF0LXRyZWUnLFxuICB9LFxuICBzdHlsZVVybDogJ3RyZWUuY3NzJyxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgLy8gU2VlIG5vdGUgb24gQ2RrVHJlZSBmb3IgZXhwbGFuYXRpb24gb24gd2h5IHRoaXMgdXNlcyB0aGUgZGVmYXVsdCBjaGFuZ2UgZGV0ZWN0aW9uIHN0cmF0ZWd5LlxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6dmFsaWRhdGUtZGVjb3JhdG9yc1xuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LkRlZmF1bHQsXG4gIHByb3ZpZGVyczogW3twcm92aWRlOiBDZGtUcmVlLCB1c2VFeGlzdGluZzogTWF0VHJlZX1dLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTWF0VHJlZU5vZGVPdXRsZXRdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXRUcmVlPFQsIEsgPSBUPiBleHRlbmRzIENka1RyZWU8VCwgSz4ge1xuICAvLyBPdXRsZXRzIHdpdGhpbiB0aGUgdHJlZSdzIHRlbXBsYXRlIHdoZXJlIHRoZSBkYXRhTm9kZXMgd2lsbCBiZSBpbnNlcnRlZC5cbiAgLy8gV2UgbmVlZCBhbiBpbml0aWFsaXplciBoZXJlIHRvIGF2b2lkIGEgVFMgZXJyb3IuIFRoZSB2YWx1ZSB3aWxsIGJlIHNldCBpbiBgbmdBZnRlclZpZXdJbml0YC5cbiAgQFZpZXdDaGlsZChNYXRUcmVlTm9kZU91dGxldCwge3N0YXRpYzogdHJ1ZX0pIG92ZXJyaWRlIF9ub2RlT3V0bGV0OiBNYXRUcmVlTm9kZU91dGxldCA9XG4gICAgdW5kZWZpbmVkITtcbn1cbiJdfQ==
|
package/fesm2022/core.mjs
CHANGED
|
@@ -13,7 +13,7 @@ import { startWith } from 'rxjs/operators';
|
|
|
13
13
|
import { ENTER, SPACE, hasModifierKey } from '@angular/cdk/keycodes';
|
|
14
14
|
|
|
15
15
|
/** Current version of Angular Material. */
|
|
16
|
-
const VERSION = new Version('18.
|
|
16
|
+
const VERSION = new Version('18.2.0-next.1');
|
|
17
17
|
|
|
18
18
|
/** @docs-private */
|
|
19
19
|
class AnimationCurves {
|