UNPKG

@angular/material

Version:
147 lines 15.2 kB
/** * @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 { __extends } from "tslib"; 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'; var _MatTreeNodeMixinBase = mixinTabIndex(mixinDisabled(CdkTreeNode)); /** * Wrapper for the CdkTree node with Material design styles. */ var MatTreeNode = /** @class */ (function (_super) { __extends(MatTreeNode, _super); function MatTreeNode(_elementRef, _tree, tabIndex) { var _this = _super.call(this, _elementRef, _tree) || this; _this._elementRef = _elementRef; _this._tree = _tree; _this.role = 'treeitem'; _this.tabIndex = Number(tabIndex) || 0; return _this; } MatTreeNode.decorators = [ { type: Directive, args: [{ selector: 'mat-tree-node', exportAs: 'matTreeNode', inputs: ['disabled', 'tabIndex'], host: { '[attr.aria-expanded]': 'isExpanded', '[attr.aria-level]': 'role === "treeitem" ? level : null', '[attr.role]': 'role', 'class': 'mat-tree-node' }, providers: [{ provide: CdkTreeNode, useExisting: MatTreeNode }] },] } ]; /** @nocollapse */ MatTreeNode.ctorParameters = function () { return [ { type: ElementRef }, { type: CdkTree }, { type: String, decorators: [{ type: Attribute, args: ['tabindex',] }] } ]; }; MatTreeNode.propDecorators = { role: [{ type: Input }] }; return MatTreeNode; }(_MatTreeNodeMixinBase)); export { MatTreeNode }; /** * Wrapper for the CdkTree node definition with Material design styles. */ var MatTreeNodeDef = /** @class */ (function (_super) { __extends(MatTreeNodeDef, _super); function MatTreeNodeDef() { return _super !== null && _super.apply(this, arguments) || this; } MatTreeNodeDef.decorators = [ { type: Directive, args: [{ selector: '[matTreeNodeDef]', inputs: [ 'when: matTreeNodeDefWhen' ], providers: [{ provide: CdkTreeNodeDef, useExisting: MatTreeNodeDef }] },] } ]; MatTreeNodeDef.propDecorators = { data: [{ type: Input, args: ['matTreeNode',] }] }; return MatTreeNodeDef; }(CdkTreeNodeDef)); export { MatTreeNodeDef }; /** * Wrapper for the CdkTree nested node with Material design styles. */ var MatNestedTreeNode = /** @class */ (function (_super) { __extends(MatNestedTreeNode, _super); function MatNestedTreeNode(_elementRef, _tree, _differs, tabIndex) { var _this = _super.call(this, _elementRef, _tree, _differs) || this; _this._elementRef = _elementRef; _this._tree = _tree; _this._differs = _differs; _this._disabled = false; _this.tabIndex = Number(tabIndex) || 0; return _this; } Object.defineProperty(MatNestedTreeNode.prototype, "disabled", { /** Whether the node is disabled. */ get: function () { return this._disabled; }, set: function (value) { this._disabled = coerceBooleanProperty(value); }, enumerable: true, configurable: true }); Object.defineProperty(MatNestedTreeNode.prototype, "tabIndex", { /** Tabindex for the node. */ get: function () { return this.disabled ? -1 : this._tabIndex; }, set: function (value) { // If the specified tabIndex value is null or undefined, fall back to the default value. this._tabIndex = value != null ? value : 0; }, enumerable: true, configurable: true }); // This is a workaround for https://github.com/angular/angular/issues/23091 // In aot mode, the lifecycle hooks from parent class are not called. // TODO(tinayuangao): Remove when the angular issue #23091 is fixed MatNestedTreeNode.prototype.ngAfterContentInit = function () { _super.prototype.ngAfterContentInit.call(this); }; MatNestedTreeNode.prototype.ngOnDestroy = function () { _super.prototype.ngOnDestroy.call(this); }; MatNestedTreeNode.decorators = [ { type: Directive, args: [{ selector: 'mat-nested-tree-node', exportAs: 'matNestedTreeNode', host: { '[attr.aria-expanded]': 'isExpanded', '[attr.role]': 'role', 'class': 'mat-nested-tree-node', }, providers: [ { provide: CdkNestedTreeNode, useExisting: MatNestedTreeNode }, { provide: CdkTreeNode, useExisting: MatNestedTreeNode }, { provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: MatNestedTreeNode } ] },] } ]; /** @nocollapse */ MatNestedTreeNode.ctorParameters = function () { return [ { 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 }] }; return MatNestedTreeNode; }(CdkNestedTreeNode)); export { MatNestedTreeNode }; //# 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} from '@angular/core';\nimport {\n  CanDisable,\n  CanDisableCtor,\n  HasTabIndex,\n  HasTabIndexCtor,\n  mixinDisabled,\n  mixinTabIndex,\n} from '@angular/material/core';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\n\nconst _MatTreeNodeMixinBase: HasTabIndexCtor & CanDisableCtor & typeof CdkTreeNode =\n    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: ['disabled', 'tabIndex'],\n  host: {\n    '[attr.aria-expanded]': 'isExpanded',\n    '[attr.aria-level]': 'role === \"treeitem\" ? level : null',\n    '[attr.role]': 'role',\n    'class': 'mat-tree-node'\n  },\n  providers: [{provide: CdkTreeNode, useExisting: MatTreeNode}]\n})\nexport class MatTreeNode<T> extends _MatTreeNodeMixinBase<T>\n    implements CanDisable, HasTabIndex {\n  @Input() role: 'treeitem' | 'group' = 'treeitem';\n\n  constructor(protected _elementRef: ElementRef<HTMLElement>,\n              protected _tree: CdkTree<T>,\n              @Attribute('tabindex') tabIndex: string) {\n    super(_elementRef, _tree);\n\n    this.tabIndex = Number(tabIndex) || 0;\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n\n/**\n * Wrapper for the CdkTree node definition with Material design styles.\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  host: {\n    '[attr.aria-expanded]': 'isExpanded',\n    '[attr.role]': 'role',\n    'class': 'mat-nested-tree-node',\n  },\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> extends CdkNestedTreeNode<T> implements AfterContentInit,\n  OnDestroy {\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(protected _elementRef: ElementRef<HTMLElement>,\n              protected _tree: CdkTree<T>,\n              protected _differs: IterableDiffers,\n              @Attribute('tabindex') tabIndex: string) {\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/23091\n  // In aot mode, the lifecycle hooks from parent class are not called.\n  // TODO(tinayuangao): Remove when the angular issue #23091 is fixed\n  ngAfterContentInit() {\n    super.ngAfterContentInit();\n  }\n\n  ngOnDestroy() {\n    super.ngOnDestroy();\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n"]}