UNPKG

@angular/cdk

Version:

Angular Material Component Development Kit

214 lines 18.9 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 { coerceBooleanProperty } from '@angular/cdk/coercion'; import { ContentChild, Directive, ElementRef, Input, TemplateRef } from '@angular/core'; import { mixinHasStickyInput } from './can-stick'; /** * Cell definition for a CDK table. * Captures the template of a column's data row cell as well as cell-specific properties. */ var CdkCellDef = /** @class */ (function () { function CdkCellDef(/** @docs-private */ template) { this.template = template; } CdkCellDef.decorators = [ { type: Directive, args: [{ selector: '[cdkCellDef]' },] } ]; /** @nocollapse */ CdkCellDef.ctorParameters = function () { return [ { type: TemplateRef } ]; }; return CdkCellDef; }()); export { CdkCellDef }; /** * Header cell definition for a CDK table. * Captures the template of a column's header cell and as well as cell-specific properties. */ var CdkHeaderCellDef = /** @class */ (function () { function CdkHeaderCellDef(/** @docs-private */ template) { this.template = template; } CdkHeaderCellDef.decorators = [ { type: Directive, args: [{ selector: '[cdkHeaderCellDef]' },] } ]; /** @nocollapse */ CdkHeaderCellDef.ctorParameters = function () { return [ { type: TemplateRef } ]; }; return CdkHeaderCellDef; }()); export { CdkHeaderCellDef }; /** * Footer cell definition for a CDK table. * Captures the template of a column's footer cell and as well as cell-specific properties. */ var CdkFooterCellDef = /** @class */ (function () { function CdkFooterCellDef(/** @docs-private */ template) { this.template = template; } CdkFooterCellDef.decorators = [ { type: Directive, args: [{ selector: '[cdkFooterCellDef]' },] } ]; /** @nocollapse */ CdkFooterCellDef.ctorParameters = function () { return [ { type: TemplateRef } ]; }; return CdkFooterCellDef; }()); export { CdkFooterCellDef }; // Boilerplate for applying mixins to CdkColumnDef. /** @docs-private */ var CdkColumnDefBase = /** @class */ (function () { function CdkColumnDefBase() { } return CdkColumnDefBase; }()); var _CdkColumnDefBase = mixinHasStickyInput(CdkColumnDefBase); /** * Column definition for the CDK table. * Defines a set of cells available for a table column. */ var CdkColumnDef = /** @class */ (function (_super) { __extends(CdkColumnDef, _super); function CdkColumnDef() { var _this = _super !== null && _super.apply(this, arguments) || this; _this._stickyEnd = false; return _this; } Object.defineProperty(CdkColumnDef.prototype, "name", { /** Unique name for this column. */ get: function () { return this._name; }, set: function (name) { // If the directive is set without a name (updated programatically), then this setter will // trigger with an empty string and should not overwrite the programatically set value. if (!name) { return; } this._name = name; this.cssClassFriendlyName = name.replace(/[^a-z0-9_-]/ig, '-'); }, enumerable: true, configurable: true }); Object.defineProperty(CdkColumnDef.prototype, "stickyEnd", { /** * Whether this column should be sticky positioned on the end of the row. Should make sure * that it mimics the `CanStick` mixin such that `_hasStickyChanged` is set to true if the value * has been changed. */ get: function () { return this._stickyEnd; }, set: function (v) { var prevValue = this._stickyEnd; this._stickyEnd = coerceBooleanProperty(v); this._hasStickyChanged = prevValue !== this._stickyEnd; }, enumerable: true, configurable: true }); CdkColumnDef.decorators = [ { type: Directive, args: [{ selector: '[cdkColumnDef]', inputs: ['sticky'], providers: [{ provide: 'MAT_SORT_HEADER_COLUMN_DEF', useExisting: CdkColumnDef }], },] } ]; CdkColumnDef.propDecorators = { name: [{ type: Input, args: ['cdkColumnDef',] }], stickyEnd: [{ type: Input, args: ['stickyEnd',] }], cell: [{ type: ContentChild, args: [CdkCellDef,] }], headerCell: [{ type: ContentChild, args: [CdkHeaderCellDef,] }], footerCell: [{ type: ContentChild, args: [CdkFooterCellDef,] }] }; return CdkColumnDef; }(_CdkColumnDefBase)); export { CdkColumnDef }; /** Base class for the cells. Adds a CSS classname that identifies the column it renders in. */ var BaseCdkCell = /** @class */ (function () { function BaseCdkCell(columnDef, elementRef) { var columnClassName = "cdk-column-" + columnDef.cssClassFriendlyName; elementRef.nativeElement.classList.add(columnClassName); } return BaseCdkCell; }()); export { BaseCdkCell }; /** Header cell template container that adds the right classes and role. */ var CdkHeaderCell = /** @class */ (function (_super) { __extends(CdkHeaderCell, _super); function CdkHeaderCell(columnDef, elementRef) { return _super.call(this, columnDef, elementRef) || this; } CdkHeaderCell.decorators = [ { type: Directive, args: [{ selector: 'cdk-header-cell, th[cdk-header-cell]', host: { 'class': 'cdk-header-cell', 'role': 'columnheader', }, },] } ]; /** @nocollapse */ CdkHeaderCell.ctorParameters = function () { return [ { type: CdkColumnDef }, { type: ElementRef } ]; }; return CdkHeaderCell; }(BaseCdkCell)); export { CdkHeaderCell }; /** Footer cell template container that adds the right classes and role. */ var CdkFooterCell = /** @class */ (function (_super) { __extends(CdkFooterCell, _super); function CdkFooterCell(columnDef, elementRef) { return _super.call(this, columnDef, elementRef) || this; } CdkFooterCell.decorators = [ { type: Directive, args: [{ selector: 'cdk-footer-cell, td[cdk-footer-cell]', host: { 'class': 'cdk-footer-cell', 'role': 'gridcell', }, },] } ]; /** @nocollapse */ CdkFooterCell.ctorParameters = function () { return [ { type: CdkColumnDef }, { type: ElementRef } ]; }; return CdkFooterCell; }(BaseCdkCell)); export { CdkFooterCell }; /** Cell template container that adds the right classes and role. */ var CdkCell = /** @class */ (function (_super) { __extends(CdkCell, _super); function CdkCell(columnDef, elementRef) { return _super.call(this, columnDef, elementRef) || this; } CdkCell.decorators = [ { type: Directive, args: [{ selector: 'cdk-cell, td[cdk-cell]', host: { 'class': 'cdk-cell', 'role': 'gridcell', }, },] } ]; /** @nocollapse */ CdkCell.ctorParameters = function () { return [ { type: CdkColumnDef }, { type: ElementRef } ]; }; return CdkCell; }(BaseCdkCell)); export { CdkCell }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.js","sourceRoot":"","sources":["../../../../../../../../../../src/cdk/table/cell.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 {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {ContentChild, Directive, ElementRef, Input, TemplateRef} from '@angular/core';\nimport {CanStick, CanStickCtor, mixinHasStickyInput} from './can-stick';\n\n\n/** Base interface for a cell definition. Captures a column's cell template definition. */\nexport interface CellDef {\n  template: TemplateRef<any>;\n}\n\n/**\n * Cell definition for a CDK table.\n * Captures the template of a column's data row cell as well as cell-specific properties.\n */\n@Directive({selector: '[cdkCellDef]'})\nexport class CdkCellDef implements CellDef {\n  constructor(/** @docs-private */ public template: TemplateRef<any>) {}\n}\n\n/**\n * Header cell definition for a CDK table.\n * Captures the template of a column's header cell and as well as cell-specific properties.\n */\n@Directive({selector: '[cdkHeaderCellDef]'})\nexport class CdkHeaderCellDef implements CellDef {\n  constructor(/** @docs-private */ public template: TemplateRef<any>) {}\n}\n\n/**\n * Footer cell definition for a CDK table.\n * Captures the template of a column's footer cell and as well as cell-specific properties.\n */\n@Directive({selector: '[cdkFooterCellDef]'})\nexport class CdkFooterCellDef implements CellDef {\n  constructor(/** @docs-private */ public template: TemplateRef<any>) {}\n}\n\n// Boilerplate for applying mixins to CdkColumnDef.\n/** @docs-private */\nclass CdkColumnDefBase {}\nconst _CdkColumnDefBase: CanStickCtor&typeof CdkColumnDefBase =\n    mixinHasStickyInput(CdkColumnDefBase);\n\n/**\n * Column definition for the CDK table.\n * Defines a set of cells available for a table column.\n */\n@Directive({\n  selector: '[cdkColumnDef]',\n  inputs: ['sticky'],\n  providers: [{provide: 'MAT_SORT_HEADER_COLUMN_DEF', useExisting: CdkColumnDef}],\n})\nexport class CdkColumnDef extends _CdkColumnDefBase implements CanStick {\n  /** Unique name for this column. */\n  @Input('cdkColumnDef')\n  get name(): string {\n    return this._name;\n  }\n  set name(name: string) {\n    // If the directive is set without a name (updated programatically), then this setter will\n    // trigger with an empty string and should not overwrite the programatically set value.\n    if (!name) {\n      return;\n    }\n\n    this._name = name;\n    this.cssClassFriendlyName = name.replace(/[^a-z0-9_-]/ig, '-');\n  }\n  _name: string;\n\n  /**\n   * Whether this column should be sticky positioned on the end of the row. Should make sure\n   * that it mimics the `CanStick` mixin such that `_hasStickyChanged` is set to true if the value\n   * has been changed.\n   */\n  @Input('stickyEnd')\n  get stickyEnd(): boolean {\n    return this._stickyEnd;\n  }\n  set stickyEnd(v: boolean) {\n    const prevValue = this._stickyEnd;\n    this._stickyEnd = coerceBooleanProperty(v);\n    this._hasStickyChanged = prevValue !== this._stickyEnd;\n  }\n  _stickyEnd: boolean = false;\n\n  /** @docs-private */\n  @ContentChild(CdkCellDef) cell: CdkCellDef;\n\n  /** @docs-private */\n  @ContentChild(CdkHeaderCellDef) headerCell: CdkHeaderCellDef;\n\n  /** @docs-private */\n  @ContentChild(CdkFooterCellDef) footerCell: CdkFooterCellDef;\n\n  /**\n   * Transformed version of the column name that can be used as part of a CSS classname. Excludes\n   * all non-alphanumeric characters and the special characters '-' and '_'. Any characters that\n   * do not match are replaced by the '-' character.\n   */\n  cssClassFriendlyName: string;\n\n  static ngAcceptInputType_sticky: BooleanInput;\n  static ngAcceptInputType_stickyEnd: BooleanInput;\n}\n\n/** Base class for the cells. Adds a CSS classname that identifies the column it renders in. */\nexport class BaseCdkCell {\n  constructor(columnDef: CdkColumnDef, elementRef: ElementRef) {\n    const columnClassName = `cdk-column-${columnDef.cssClassFriendlyName}`;\n    elementRef.nativeElement.classList.add(columnClassName);\n  }\n}\n\n/** Header cell template container that adds the right classes and role. */\n@Directive({\n  selector: 'cdk-header-cell, th[cdk-header-cell]',\n  host: {\n    'class': 'cdk-header-cell',\n    'role': 'columnheader',\n  },\n})\nexport class CdkHeaderCell extends BaseCdkCell {\n  constructor(columnDef: CdkColumnDef, elementRef: ElementRef) {\n    super(columnDef, elementRef);\n  }\n}\n\n/** Footer cell template container that adds the right classes and role. */\n@Directive({\n  selector: 'cdk-footer-cell, td[cdk-footer-cell]',\n  host: {\n    'class': 'cdk-footer-cell',\n    'role': 'gridcell',\n  },\n})\nexport class CdkFooterCell extends BaseCdkCell {\n  constructor(columnDef: CdkColumnDef, elementRef: ElementRef) {\n    super(columnDef, elementRef);\n  }\n}\n\n/** Cell template container that adds the right classes and role. */\n@Directive({\n  selector: 'cdk-cell, td[cdk-cell]',\n  host: {\n    'class': 'cdk-cell',\n    'role': 'gridcell',\n  },\n})\nexport class CdkCell extends BaseCdkCell {\n  constructor(columnDef: CdkColumnDef, elementRef: ElementRef) {\n    super(columnDef, elementRef);\n  }\n}\n"]}