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.
134 lines
17 KiB
134 lines
17 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 { Directionality } from '@angular/cdk/bidi';
|
|
import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
import { Directive, ElementRef, Input, Optional } from '@angular/core';
|
|
import { takeUntil } from 'rxjs/operators';
|
|
import { Subject } from 'rxjs';
|
|
import { CdkTree, CdkTreeNode } from './tree';
|
|
/** Regex used to split a string on its CSS units. */
|
|
import * as ɵngcc0 from '@angular/core';
|
|
import * as ɵngcc1 from './tree';
|
|
import * as ɵngcc2 from '@angular/cdk/bidi';
|
|
const cssUnitPattern = /([A-Za-z%]+)$/;
|
|
/**
|
|
* Indent for the children tree dataNodes.
|
|
* This directive will add left-padding to the node to show hierarchy.
|
|
*/
|
|
export class CdkTreeNodePadding {
|
|
constructor(_treeNode, _tree, _element, _dir) {
|
|
this._treeNode = _treeNode;
|
|
this._tree = _tree;
|
|
this._element = _element;
|
|
this._dir = _dir;
|
|
/** Subject that emits when the component has been destroyed. */
|
|
this._destroyed = new Subject();
|
|
/** CSS units used for the indentation value. */
|
|
this.indentUnits = 'px';
|
|
this._indent = 40;
|
|
this._setPadding();
|
|
if (_dir) {
|
|
_dir.change.pipe(takeUntil(this._destroyed)).subscribe(() => this._setPadding(true));
|
|
}
|
|
// In Ivy the indentation binding might be set before the tree node's data has been added,
|
|
// which means that we'll miss the first render. We have to subscribe to changes in the
|
|
// data to ensure that everything is up to date.
|
|
_treeNode._dataChanges.subscribe(() => this._setPadding());
|
|
}
|
|
/** The level of depth of the tree node. The padding will be `level * indent` pixels. */
|
|
get level() { return this._level; }
|
|
set level(value) { this._setLevelInput(value); }
|
|
/**
|
|
* The indent for each level. Can be a number or a CSS string.
|
|
* Default number 40px from material design menu sub-menu spec.
|
|
*/
|
|
get indent() { return this._indent; }
|
|
set indent(indent) { this._setIndentInput(indent); }
|
|
ngOnDestroy() {
|
|
this._destroyed.next();
|
|
this._destroyed.complete();
|
|
}
|
|
/** The padding indent value for the tree node. Returns a string with px numbers if not null. */
|
|
_paddingIndent() {
|
|
const nodeLevel = (this._treeNode.data && this._tree.treeControl.getLevel)
|
|
? this._tree.treeControl.getLevel(this._treeNode.data)
|
|
: null;
|
|
const level = this._level == null ? nodeLevel : this._level;
|
|
return typeof level === 'number' ? `${level * this._indent}${this.indentUnits}` : null;
|
|
}
|
|
_setPadding(forceChange = false) {
|
|
const padding = this._paddingIndent();
|
|
if (padding !== this._currentPadding || forceChange) {
|
|
const element = this._element.nativeElement;
|
|
const paddingProp = this._dir && this._dir.value === 'rtl' ? 'paddingRight' : 'paddingLeft';
|
|
const resetProp = paddingProp === 'paddingLeft' ? 'paddingRight' : 'paddingLeft';
|
|
element.style[paddingProp] = padding || '';
|
|
element.style[resetProp] = '';
|
|
this._currentPadding = padding;
|
|
}
|
|
}
|
|
/**
|
|
* This has been extracted to a util because of TS 4 and VE.
|
|
* View Engine doesn't support property rename inheritance.
|
|
* TS 4.0 doesn't allow properties to override accessors or vice-versa.
|
|
* @docs-private
|
|
*/
|
|
_setLevelInput(value) {
|
|
// Set to null as the fallback value so that _setPadding can fall back to the node level if the
|
|
// consumer set the directive as `cdkTreeNodePadding=""`. We still want to take this value if
|
|
// they set 0 explicitly.
|
|
this._level = coerceNumberProperty(value, null);
|
|
this._setPadding();
|
|
}
|
|
/**
|
|
* This has been extracted to a util because of TS 4 and VE.
|
|
* View Engine doesn't support property rename inheritance.
|
|
* TS 4.0 doesn't allow properties to override accessors or vice-versa.
|
|
* @docs-private
|
|
*/
|
|
_setIndentInput(indent) {
|
|
let value = indent;
|
|
let units = 'px';
|
|
if (typeof indent === 'string') {
|
|
const parts = indent.split(cssUnitPattern);
|
|
value = parts[0];
|
|
units = parts[1] || units;
|
|
}
|
|
this.indentUnits = units;
|
|
this._indent = coerceNumberProperty(value);
|
|
this._setPadding();
|
|
}
|
|
}
|
|
CdkTreeNodePadding.ɵfac = function CdkTreeNodePadding_Factory(t) { return new (t || CdkTreeNodePadding)(ɵngcc0.ɵɵdirectiveInject(ɵngcc1.CdkTreeNode), ɵngcc0.ɵɵdirectiveInject(ɵngcc1.CdkTree), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc2.Directionality, 8)); };
|
|
CdkTreeNodePadding.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkTreeNodePadding, selectors: [["", "cdkTreeNodePadding", ""]], inputs: { level: ["cdkTreeNodePadding", "level"], indent: ["cdkTreeNodePaddingIndent", "indent"] } });
|
|
CdkTreeNodePadding.ctorParameters = () => [
|
|
{ type: CdkTreeNode },
|
|
{ type: CdkTree },
|
|
{ type: ElementRef },
|
|
{ type: Directionality, decorators: [{ type: Optional }] }
|
|
];
|
|
CdkTreeNodePadding.propDecorators = {
|
|
level: [{ type: Input, args: ['cdkTreeNodePadding',] }],
|
|
indent: [{ type: Input, args: ['cdkTreeNodePaddingIndent',] }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkTreeNodePadding, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: '[cdkTreeNodePadding]'
|
|
}]
|
|
}], function () { return [{ type: ɵngcc1.CdkTreeNode }, { type: ɵngcc1.CdkTree }, { type: ɵngcc0.ElementRef }, { type: ɵngcc2.Directionality, decorators: [{
|
|
type: Optional
|
|
}] }]; }, { level: [{
|
|
type: Input,
|
|
args: ['cdkTreeNodePadding']
|
|
}], indent: [{
|
|
type: Input,
|
|
args: ['cdkTreeNodePaddingIndent']
|
|
}] }); })();
|
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"padding.js","sources":["../../../../../../src/cdk/tree/padding.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 {Directionality} from '@angular/cdk/bidi';\nimport {coerceNumberProperty, NumberInput} from '@angular/cdk/coercion';\nimport {Directive, ElementRef, Input, OnDestroy, Optional} from '@angular/core';\nimport {takeUntil} from 'rxjs/operators';\nimport {Subject} from 'rxjs';\nimport {CdkTree, CdkTreeNode} from './tree';\n\n/** Regex used to split a string on its CSS units. */\nconst cssUnitPattern = /([A-Za-z%]+)$/;\n\n/**\n * Indent for the children tree dataNodes.\n * This directive will add left-padding to the node to show hierarchy.\n */\n@Directive({\n  selector: '[cdkTreeNodePadding]',\n})\nexport class CdkTreeNodePadding<T, K = T> implements OnDestroy {\n  /** Current padding value applied to the element. Used to avoid unnecessarily hitting the DOM. */\n  private _currentPadding: string|null;\n\n  /** Subject that emits when the component has been destroyed. */\n  private readonly _destroyed = new Subject<void>();\n\n  /** CSS units used for the indentation value. */\n  indentUnits = 'px';\n\n  /** The level of depth of the tree node. The padding will be `level * indent` pixels. */\n  @Input('cdkTreeNodePadding')\n  get level(): number { return this._level; }\n  set level(value: number) { this._setLevelInput(value); }\n  _level: number;\n\n  /**\n   * The indent for each level. Can be a number or a CSS string.\n   * Default number 40px from material design menu sub-menu spec.\n   */\n  @Input('cdkTreeNodePaddingIndent')\n  get indent(): number | string { return this._indent; }\n  set indent(indent: number | string) { this._setIndentInput(indent); }\n  _indent: number = 40;\n\n  constructor(private _treeNode: CdkTreeNode<T, K>,\n              private _tree: CdkTree<T, K>,\n              private _element: ElementRef<HTMLElement>,\n              @Optional() private _dir: Directionality) {\n    this._setPadding();\n    if (_dir) {\n      _dir.change.pipe(takeUntil(this._destroyed)).subscribe(() => this._setPadding(true));\n    }\n\n    // In Ivy the indentation binding might be set before the tree node's data has been added,\n    // which means that we'll miss the first render. We have to subscribe to changes in the\n    // data to ensure that everything is up to date.\n    _treeNode._dataChanges.subscribe(() => this._setPadding());\n  }\n\n  ngOnDestroy() {\n    this._destroyed.next();\n    this._destroyed.complete();\n  }\n\n  /** The padding indent value for the tree node. Returns a string with px numbers if not null. */\n  _paddingIndent(): string|null {\n    const nodeLevel = (this._treeNode.data && this._tree.treeControl.getLevel)\n      ? this._tree.treeControl.getLevel(this._treeNode.data)\n      : null;\n    const level = this._level == null ? nodeLevel : this._level;\n    return typeof level === 'number' ? `${level * this._indent}${this.indentUnits}` : null;\n  }\n\n  _setPadding(forceChange = false) {\n    const padding = this._paddingIndent();\n\n    if (padding !== this._currentPadding || forceChange) {\n      const element = this._element.nativeElement;\n      const paddingProp = this._dir && this._dir.value === 'rtl' ? 'paddingRight' : 'paddingLeft';\n      const resetProp = paddingProp === 'paddingLeft' ? 'paddingRight' : 'paddingLeft';\n      element.style[paddingProp] = padding || '';\n      element.style[resetProp] = '';\n      this._currentPadding = padding;\n    }\n  }\n\n  /**\n   * This has been extracted to a util because of TS 4 and VE.\n   * View Engine doesn't support property rename inheritance.\n   * TS 4.0 doesn't allow properties to override accessors or vice-versa.\n   * @docs-private\n   */\n  protected _setLevelInput(value: number) {\n    // Set to null as the fallback value so that _setPadding can fall back to the node level if the\n    // consumer set the directive as `cdkTreeNodePadding=\"\"`. We still want to take this value if\n    // they set 0 explicitly.\n    this._level = coerceNumberProperty(value, null)!;\n    this._setPadding();\n  }\n\n  /**\n   * This has been extracted to a util because of TS 4 and VE.\n   * View Engine doesn't support property rename inheritance.\n   * TS 4.0 doesn't allow properties to override accessors or vice-versa.\n   * @docs-private\n   */\n  protected _setIndentInput(indent: number | string) {\n    let value = indent;\n    let units = 'px';\n\n    if (typeof indent === 'string') {\n      const parts = indent.split(cssUnitPattern);\n      value = parts[0];\n      units = parts[1] || units;\n    }\n\n    this.indentUnits = units;\n    this._indent = coerceNumberProperty(value);\n    this._setPadding();\n  }\n\n  static ngAcceptInputType_level: NumberInput;\n}\n"]}
|