You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
163 lines
19 KiB
163 lines
19 KiB
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
import { CDK_TREE_NODE_OUTLET_NODE, CdkNestedTreeNode, CdkTree, CdkTreeNode, CdkTreeNodeDef, } from '@angular/cdk/tree';
|
|
import { Attribute, Directive, ElementRef, Input, IterableDiffers, } from '@angular/core';
|
|
import { mixinDisabled, mixinTabIndex, } from '@angular/material/core';
|
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
import * as ɵngcc0 from '@angular/core';
|
|
import * as ɵngcc1 from '@angular/cdk/tree';
|
|
const _MatTreeNodeBase = mixinTabIndex(mixinDisabled(CdkTreeNode));
|
|
/**
|
|
* Wrapper for the CdkTree node with Material design styles.
|
|
*/
|
|
export class MatTreeNode extends _MatTreeNodeBase {
|
|
constructor(elementRef, tree, tabIndex) {
|
|
super(elementRef, tree);
|
|
this.tabIndex = Number(tabIndex) || 0;
|
|
// The classes are directly added here instead of in the host property because classes on
|
|
// the host property are not inherited with View Engine. It is not set as a @HostBinding because
|
|
// it is not set by the time it's children nodes try to read the class from it.
|
|
// TODO: move to host after View Engine deprecation
|
|
elementRef.nativeElement.classList.add('mat-tree-node');
|
|
}
|
|
// This is a workaround for https://github.com/angular/angular/issues/23091
|
|
// In aot mode, the lifecycle hooks from parent class are not called.
|
|
ngOnInit() {
|
|
super.ngOnInit();
|
|
}
|
|
ngDoCheck() {
|
|
super.ngDoCheck();
|
|
}
|
|
ngOnDestroy() {
|
|
super.ngOnDestroy();
|
|
}
|
|
}
|
|
MatTreeNode.ɵfac = function MatTreeNode_Factory(t) { return new (t || MatTreeNode)(ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc1.CdkTree), ɵngcc0.ɵɵinjectAttribute('tabindex')); };
|
|
MatTreeNode.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatTreeNode, selectors: [["mat-tree-node"]], inputs: { role: "role", disabled: "disabled", tabIndex: "tabIndex" }, exportAs: ["matTreeNode"], features: [ɵngcc0.ɵɵProvidersFeature([{ provide: CdkTreeNode, useExisting: MatTreeNode }]), ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
MatTreeNode.ctorParameters = () => [
|
|
{ type: ElementRef },
|
|
{ type: CdkTree },
|
|
{ type: String, decorators: [{ type: Attribute, args: ['tabindex',] }] }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatTreeNode, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'mat-tree-node',
|
|
exportAs: 'matTreeNode',
|
|
inputs: ['role', 'disabled', 'tabIndex'],
|
|
providers: [{ provide: CdkTreeNode, useExisting: MatTreeNode }]
|
|
}]
|
|
}], function () { return [{ type: ɵngcc0.ElementRef }, { type: ɵngcc1.CdkTree }, { type: String, decorators: [{
|
|
type: Attribute,
|
|
args: ['tabindex']
|
|
}] }]; }, null); })();
|
|
/**
|
|
* Wrapper for the CdkTree node definition with Material design styles.
|
|
* Captures the node's template and a when predicate that describes when this node should be used.
|
|
*/
|
|
export class MatTreeNodeDef extends CdkTreeNodeDef {
|
|
}
|
|
MatTreeNodeDef.ɵfac = /*@__PURE__*/ function () { let ɵMatTreeNodeDef_BaseFactory; return function MatTreeNodeDef_Factory(t) { return (ɵMatTreeNodeDef_BaseFactory || (ɵMatTreeNodeDef_BaseFactory = ɵngcc0.ɵɵgetInheritedFactory(MatTreeNodeDef)))(t || MatTreeNodeDef); }; }();
|
|
MatTreeNodeDef.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatTreeNodeDef, selectors: [["", "matTreeNodeDef", ""]], inputs: { when: ["matTreeNodeDefWhen", "when"], data: ["matTreeNode", "data"] }, features: [ɵngcc0.ɵɵProvidersFeature([{ provide: CdkTreeNodeDef, useExisting: MatTreeNodeDef }]), ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
MatTreeNodeDef.propDecorators = {
|
|
data: [{ type: Input, args: ['matTreeNode',] }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatTreeNodeDef, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: '[matTreeNodeDef]',
|
|
inputs: [
|
|
'when: matTreeNodeDefWhen'
|
|
],
|
|
providers: [{ provide: CdkTreeNodeDef, useExisting: MatTreeNodeDef }]
|
|
}]
|
|
}], null, { data: [{
|
|
type: Input,
|
|
args: ['matTreeNode']
|
|
}] }); })();
|
|
/**
|
|
* Wrapper for the CdkTree nested node with Material design styles.
|
|
*/
|
|
export class MatNestedTreeNode extends CdkNestedTreeNode {
|
|
constructor(elementRef, tree, differs, tabIndex) {
|
|
super(elementRef, tree, differs);
|
|
this._disabled = false;
|
|
this.tabIndex = Number(tabIndex) || 0;
|
|
// The classes are directly added here instead of in the host property because classes on
|
|
// the host property are not inherited with View Engine. It is not set as a @HostBinding because
|
|
// it is not set by the time it's children nodes try to read the class from it.
|
|
// TODO: move to host after View Engine deprecation
|
|
elementRef.nativeElement.classList.add('mat-nested-tree-node');
|
|
}
|
|
/** Whether the node is disabled. */
|
|
get disabled() { return this._disabled; }
|
|
set disabled(value) { this._disabled = coerceBooleanProperty(value); }
|
|
/** Tabindex for the node. */
|
|
get tabIndex() { return this.disabled ? -1 : this._tabIndex; }
|
|
set tabIndex(value) {
|
|
// If the specified tabIndex value is null or undefined, fall back to the default value.
|
|
this._tabIndex = value != null ? value : 0;
|
|
}
|
|
// This is a workaround for https://github.com/angular/angular/issues/19145
|
|
// In aot mode, the lifecycle hooks from parent class are not called.
|
|
// TODO(tinayuangao): Remove when the angular issue #19145 is fixed
|
|
ngOnInit() {
|
|
super.ngOnInit();
|
|
}
|
|
ngDoCheck() {
|
|
super.ngDoCheck();
|
|
}
|
|
ngAfterContentInit() {
|
|
super.ngAfterContentInit();
|
|
}
|
|
ngOnDestroy() {
|
|
super.ngOnDestroy();
|
|
}
|
|
}
|
|
MatNestedTreeNode.ɵfac = function MatNestedTreeNode_Factory(t) { return new (t || MatNestedTreeNode)(ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc1.CdkTree), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.IterableDiffers), ɵngcc0.ɵɵinjectAttribute('tabindex')); };
|
|
MatNestedTreeNode.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatNestedTreeNode, selectors: [["mat-nested-tree-node"]], inputs: { role: "role", disabled: "disabled", tabIndex: "tabIndex", node: ["matNestedTreeNode", "node"] }, exportAs: ["matNestedTreeNode"], features: [ɵngcc0.ɵɵProvidersFeature([
|
|
{ provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode },
|
|
{ provide: CdkTreeNode, useExisting: MatNestedTreeNode },
|
|
{ provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: MatNestedTreeNode }
|
|
]), ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
MatNestedTreeNode.ctorParameters = () => [
|
|
{ type: ElementRef },
|
|
{ type: CdkTree },
|
|
{ type: IterableDiffers },
|
|
{ type: String, decorators: [{ type: Attribute, args: ['tabindex',] }] }
|
|
];
|
|
MatNestedTreeNode.propDecorators = {
|
|
node: [{ type: Input, args: ['matNestedTreeNode',] }],
|
|
disabled: [{ type: Input }],
|
|
tabIndex: [{ type: Input }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatNestedTreeNode, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'mat-nested-tree-node',
|
|
exportAs: 'matNestedTreeNode',
|
|
inputs: ['role', 'disabled', 'tabIndex'],
|
|
providers: [
|
|
{ provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode },
|
|
{ provide: CdkTreeNode, useExisting: MatNestedTreeNode },
|
|
{ provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: MatNestedTreeNode }
|
|
]
|
|
}]
|
|
}], function () { return [{ type: ɵngcc0.ElementRef }, { type: ɵngcc1.CdkTree }, { type: ɵngcc0.IterableDiffers }, { type: String, decorators: [{
|
|
type: Attribute,
|
|
args: ['tabindex']
|
|
}] }]; }, { tabIndex: [{
|
|
type: Input
|
|
}], disabled: [{
|
|
type: Input
|
|
}], node: [{
|
|
type: Input,
|
|
args: ['matNestedTreeNode']
|
|
}] }); })();
|
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"node.js","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  DoCheck,\n  ElementRef,\n  Input,\n  IterableDiffers,\n  OnDestroy, OnInit,\n} from '@angular/core';\nimport {\n  CanDisable,\n  HasTabIndex,\n  mixinDisabled,\n  mixinTabIndex,\n} from '@angular/material/core';\nimport {BooleanInput, coerceBooleanProperty, NumberInput} from '@angular/cdk/coercion';\n\nconst _MatTreeNodeBase = mixinTabIndex(mixinDisabled(CdkTreeNode));\n\n/**\n * Wrapper for the CdkTree node with Material design styles.\n */\n@Directive({\n  selector: 'mat-tree-node',\n  exportAs: 'matTreeNode',\n  inputs: ['role', 'disabled', 'tabIndex'],\n  providers: [{provide: CdkTreeNode, useExisting: MatTreeNode}]\n})\nexport class MatTreeNode<T, K = T> extends _MatTreeNodeBase<T, K>\n    implements CanDisable, DoCheck, HasTabIndex, OnInit, OnDestroy {\n\n\n  constructor(elementRef: ElementRef<HTMLElement>,\n              tree: CdkTree<T, K>,\n              @Attribute('tabindex') tabIndex: string) {\n    super(elementRef, tree);\n\n    this.tabIndex = Number(tabIndex) || 0;\n    // The classes are directly added here instead of in the host property because classes on\n    // the host property are not inherited with View Engine. It is not set as a @HostBinding because\n    // it is not set by the time it's children nodes try to read the class from it.\n    // TODO: move to host after View Engine deprecation\n    elementRef.nativeElement.classList.add('mat-tree-node');\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 ngDoCheck() {\n    super.ngDoCheck();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n  static ngAcceptInputType_tabIndex: NumberInput;\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: [\n    'when: matTreeNodeDefWhen'\n  ],\n  providers: [{provide: CdkTreeNodeDef, useExisting: MatTreeNodeDef}]\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  inputs: ['role', 'disabled', 'tabIndex'],\n  providers: [\n    {provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode},\n    {provide: CdkTreeNode, useExisting: MatNestedTreeNode},\n    {provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: MatNestedTreeNode}\n  ]\n})\nexport class MatNestedTreeNode<T, K = T> extends CdkNestedTreeNode<T, K>\n    implements AfterContentInit, DoCheck, OnDestroy, OnInit {\n  @Input('matNestedTreeNode') node: T;\n\n  /** Whether the node is disabled. */\n  @Input()\n  get disabled() { return this._disabled; }\n  set disabled(value: any) { this._disabled = coerceBooleanProperty(value); }\n  private _disabled = false;\n\n  /** Tabindex for the node. */\n  @Input()\n  get tabIndex(): number { return this.disabled ? -1 : this._tabIndex; }\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(elementRef: ElementRef<HTMLElement>,\n              tree: CdkTree<T, K>,\n              differs: IterableDiffers,\n              @Attribute('tabindex') tabIndex: string) {\n    super(elementRef, tree, differs);\n    this.tabIndex = Number(tabIndex) || 0;\n    // The classes are directly added here instead of in the host property because classes on\n    // the host property are not inherited with View Engine. It is not set as a @HostBinding because\n    // it is not set by the time it's children nodes try to read the class from it.\n    // TODO: move to host after View Engine deprecation\n    elementRef.nativeElement.classList.add('mat-nested-tree-node');\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 ngDoCheck() {\n    super.ngDoCheck();\n  }\n\n  override ngAfterContentInit() {\n    super.ngAfterContentInit();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n"]}
|