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.
263 lines
28 KiB
263 lines
28 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 { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
import { ContentChild, Directive, ElementRef, Inject, Input, Optional, TemplateRef, } from '@angular/core';
|
|
import { mixinHasStickyInput } from './can-stick';
|
|
import { CDK_TABLE } from './tokens';
|
|
/**
|
|
* Cell definition for a CDK table.
|
|
* Captures the template of a column's data row cell as well as cell-specific properties.
|
|
*/
|
|
import * as ɵngcc0 from '@angular/core';
|
|
export class CdkCellDef {
|
|
constructor(/** @docs-private */ template) {
|
|
this.template = template;
|
|
}
|
|
}
|
|
CdkCellDef.ɵfac = function CdkCellDef_Factory(t) { return new (t || CdkCellDef)(ɵngcc0.ɵɵdirectiveInject(ɵngcc0.TemplateRef)); };
|
|
CdkCellDef.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkCellDef, selectors: [["", "cdkCellDef", ""]] });
|
|
CdkCellDef.ctorParameters = () => [
|
|
{ type: TemplateRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkCellDef, [{
|
|
type: Directive,
|
|
args: [{ selector: '[cdkCellDef]' }]
|
|
}], function () { return [{ type: ɵngcc0.TemplateRef }]; }, null); })();
|
|
/**
|
|
* Header cell definition for a CDK table.
|
|
* Captures the template of a column's header cell and as well as cell-specific properties.
|
|
*/
|
|
export class CdkHeaderCellDef {
|
|
constructor(/** @docs-private */ template) {
|
|
this.template = template;
|
|
}
|
|
}
|
|
CdkHeaderCellDef.ɵfac = function CdkHeaderCellDef_Factory(t) { return new (t || CdkHeaderCellDef)(ɵngcc0.ɵɵdirectiveInject(ɵngcc0.TemplateRef)); };
|
|
CdkHeaderCellDef.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkHeaderCellDef, selectors: [["", "cdkHeaderCellDef", ""]] });
|
|
CdkHeaderCellDef.ctorParameters = () => [
|
|
{ type: TemplateRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkHeaderCellDef, [{
|
|
type: Directive,
|
|
args: [{ selector: '[cdkHeaderCellDef]' }]
|
|
}], function () { return [{ type: ɵngcc0.TemplateRef }]; }, null); })();
|
|
/**
|
|
* Footer cell definition for a CDK table.
|
|
* Captures the template of a column's footer cell and as well as cell-specific properties.
|
|
*/
|
|
export class CdkFooterCellDef {
|
|
constructor(/** @docs-private */ template) {
|
|
this.template = template;
|
|
}
|
|
}
|
|
CdkFooterCellDef.ɵfac = function CdkFooterCellDef_Factory(t) { return new (t || CdkFooterCellDef)(ɵngcc0.ɵɵdirectiveInject(ɵngcc0.TemplateRef)); };
|
|
CdkFooterCellDef.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkFooterCellDef, selectors: [["", "cdkFooterCellDef", ""]] });
|
|
CdkFooterCellDef.ctorParameters = () => [
|
|
{ type: TemplateRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkFooterCellDef, [{
|
|
type: Directive,
|
|
args: [{ selector: '[cdkFooterCellDef]' }]
|
|
}], function () { return [{ type: ɵngcc0.TemplateRef }]; }, null); })();
|
|
// Boilerplate for applying mixins to CdkColumnDef.
|
|
/** @docs-private */
|
|
class CdkColumnDefBase {
|
|
}
|
|
const _CdkColumnDefBase = mixinHasStickyInput(CdkColumnDefBase);
|
|
/**
|
|
* Column definition for the CDK table.
|
|
* Defines a set of cells available for a table column.
|
|
*/
|
|
export class CdkColumnDef extends _CdkColumnDefBase {
|
|
constructor(_table) {
|
|
super();
|
|
this._table = _table;
|
|
this._stickyEnd = false;
|
|
}
|
|
/** Unique name for this column. */
|
|
get name() { return this._name; }
|
|
set name(name) { this._setNameInput(name); }
|
|
/**
|
|
* 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 stickyEnd() {
|
|
return this._stickyEnd;
|
|
}
|
|
set stickyEnd(v) {
|
|
const prevValue = this._stickyEnd;
|
|
this._stickyEnd = coerceBooleanProperty(v);
|
|
this._hasStickyChanged = prevValue !== this._stickyEnd;
|
|
}
|
|
/**
|
|
* Overridable method that sets the css classes that will be added to every cell in this
|
|
* column.
|
|
* In the future, columnCssClassName will change from type string[] to string and this
|
|
* will set a single string value.
|
|
* @docs-private
|
|
*/
|
|
_updateColumnCssClassName() {
|
|
this._columnCssClassName = [`cdk-column-${this.cssClassFriendlyName}`];
|
|
}
|
|
/**
|
|
* 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
|
|
*/
|
|
_setNameInput(value) {
|
|
// If the directive is set without a name (updated programmatically), then this setter will
|
|
// trigger with an empty string and should not overwrite the programmatically set value.
|
|
if (value) {
|
|
this._name = value;
|
|
this.cssClassFriendlyName = value.replace(/[^a-z0-9_-]/ig, '-');
|
|
this._updateColumnCssClassName();
|
|
}
|
|
}
|
|
}
|
|
CdkColumnDef.ɵfac = function CdkColumnDef_Factory(t) { return new (t || CdkColumnDef)(ɵngcc0.ɵɵdirectiveInject(CDK_TABLE, 8)); };
|
|
CdkColumnDef.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkColumnDef, selectors: [["", "cdkColumnDef", ""]], contentQueries: function CdkColumnDef_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
ɵngcc0.ɵɵcontentQuery(dirIndex, CdkCellDef, 5);
|
|
ɵngcc0.ɵɵcontentQuery(dirIndex, CdkHeaderCellDef, 5);
|
|
ɵngcc0.ɵɵcontentQuery(dirIndex, CdkFooterCellDef, 5);
|
|
} if (rf & 2) {
|
|
let _t;
|
|
ɵngcc0.ɵɵqueryRefresh(_t = ɵngcc0.ɵɵloadQuery()) && (ctx.cell = _t.first);
|
|
ɵngcc0.ɵɵqueryRefresh(_t = ɵngcc0.ɵɵloadQuery()) && (ctx.headerCell = _t.first);
|
|
ɵngcc0.ɵɵqueryRefresh(_t = ɵngcc0.ɵɵloadQuery()) && (ctx.footerCell = _t.first);
|
|
} }, inputs: { sticky: "sticky", name: ["cdkColumnDef", "name"], stickyEnd: "stickyEnd" }, features: [ɵngcc0.ɵɵProvidersFeature([{ provide: 'MAT_SORT_HEADER_COLUMN_DEF', useExisting: CdkColumnDef }]), ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
CdkColumnDef.ctorParameters = () => [
|
|
{ type: undefined, decorators: [{ type: Inject, args: [CDK_TABLE,] }, { type: Optional }] }
|
|
];
|
|
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,] }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkColumnDef, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: '[cdkColumnDef]',
|
|
inputs: ['sticky'],
|
|
providers: [{ provide: 'MAT_SORT_HEADER_COLUMN_DEF', useExisting: CdkColumnDef }]
|
|
}]
|
|
}], function () { return [{ type: undefined, decorators: [{
|
|
type: Inject,
|
|
args: [CDK_TABLE]
|
|
}, {
|
|
type: Optional
|
|
}] }]; }, { 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]
|
|
}] }); })();
|
|
/** Base class for the cells. Adds a CSS classname that identifies the column it renders in. */
|
|
export class BaseCdkCell {
|
|
constructor(columnDef, elementRef) {
|
|
// If IE 11 is dropped before we switch to setting a single class name, change to multi param
|
|
// with destructuring.
|
|
const classList = elementRef.nativeElement.classList;
|
|
for (const className of columnDef._columnCssClassName) {
|
|
classList.add(className);
|
|
}
|
|
}
|
|
}
|
|
/** Header cell template container that adds the right classes and role. */
|
|
export class CdkHeaderCell extends BaseCdkCell {
|
|
constructor(columnDef, elementRef) {
|
|
super(columnDef, elementRef);
|
|
}
|
|
}
|
|
CdkHeaderCell.ɵfac = function CdkHeaderCell_Factory(t) { return new (t || CdkHeaderCell)(ɵngcc0.ɵɵdirectiveInject(CdkColumnDef), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef)); };
|
|
CdkHeaderCell.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkHeaderCell, selectors: [["cdk-header-cell"], ["th", "cdk-header-cell", ""]], hostAttrs: ["role", "columnheader", 1, "cdk-header-cell"], features: [ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
CdkHeaderCell.ctorParameters = () => [
|
|
{ type: CdkColumnDef },
|
|
{ type: ElementRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkHeaderCell, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'cdk-header-cell, th[cdk-header-cell]',
|
|
host: {
|
|
'class': 'cdk-header-cell',
|
|
'role': 'columnheader'
|
|
}
|
|
}]
|
|
}], function () { return [{ type: CdkColumnDef }, { type: ɵngcc0.ElementRef }]; }, null); })();
|
|
/** Footer cell template container that adds the right classes and role. */
|
|
export class CdkFooterCell extends BaseCdkCell {
|
|
constructor(columnDef, elementRef) {
|
|
var _a;
|
|
super(columnDef, elementRef);
|
|
if (((_a = columnDef._table) === null || _a === void 0 ? void 0 : _a._elementRef.nativeElement.nodeType) === 1) {
|
|
const tableRole = columnDef._table._elementRef.nativeElement
|
|
.getAttribute('role');
|
|
const role = (tableRole === 'grid' || tableRole === 'treegrid') ? 'gridcell' : 'cell';
|
|
elementRef.nativeElement.setAttribute('role', role);
|
|
}
|
|
}
|
|
}
|
|
CdkFooterCell.ɵfac = function CdkFooterCell_Factory(t) { return new (t || CdkFooterCell)(ɵngcc0.ɵɵdirectiveInject(CdkColumnDef), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef)); };
|
|
CdkFooterCell.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkFooterCell, selectors: [["cdk-footer-cell"], ["td", "cdk-footer-cell", ""]], hostAttrs: [1, "cdk-footer-cell"], features: [ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
CdkFooterCell.ctorParameters = () => [
|
|
{ type: CdkColumnDef },
|
|
{ type: ElementRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkFooterCell, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'cdk-footer-cell, td[cdk-footer-cell]',
|
|
host: {
|
|
'class': 'cdk-footer-cell'
|
|
}
|
|
}]
|
|
}], function () { return [{ type: CdkColumnDef }, { type: ɵngcc0.ElementRef }]; }, null); })();
|
|
/** Cell template container that adds the right classes and role. */
|
|
export class CdkCell extends BaseCdkCell {
|
|
constructor(columnDef, elementRef) {
|
|
var _a;
|
|
super(columnDef, elementRef);
|
|
if (((_a = columnDef._table) === null || _a === void 0 ? void 0 : _a._elementRef.nativeElement.nodeType) === 1) {
|
|
const tableRole = columnDef._table._elementRef.nativeElement
|
|
.getAttribute('role');
|
|
const role = (tableRole === 'grid' || tableRole === 'treegrid') ? 'gridcell' : 'cell';
|
|
elementRef.nativeElement.setAttribute('role', role);
|
|
}
|
|
}
|
|
}
|
|
CdkCell.ɵfac = function CdkCell_Factory(t) { return new (t || CdkCell)(ɵngcc0.ɵɵdirectiveInject(CdkColumnDef), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef)); };
|
|
CdkCell.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: CdkCell, selectors: [["cdk-cell"], ["td", "cdk-cell", ""]], hostAttrs: [1, "cdk-cell"], features: [ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
CdkCell.ctorParameters = () => [
|
|
{ type: CdkColumnDef },
|
|
{ type: ElementRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(CdkCell, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'cdk-cell, td[cdk-cell]',
|
|
host: {
|
|
'class': 'cdk-cell'
|
|
}
|
|
}]
|
|
}], function () { return [{ type: CdkColumnDef }, { type: ɵngcc0.ElementRef }]; }, null); })();
|
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"cell.js","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 {\n  ContentChild,\n  Directive,\n  ElementRef,\n  Inject,\n  Input,\n  Optional,\n  TemplateRef,\n} from '@angular/core';\nimport {CanStick, CanStickCtor, mixinHasStickyInput} from './can-stick';\nimport {CDK_TABLE} from './tokens';\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 { return this._name; }\n  set name(name: string) { this._setNameInput(name); }\n  protected _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  /**\n   * Class name for cells in this column.\n   * @docs-private\n   */\n  _columnCssClassName: string[];\n\n  constructor(@Inject(CDK_TABLE) @Optional() public _table?: any) {\n    super();\n  }\n\n  /**\n   * Overridable method that sets the css classes that will be added to every cell in this\n   * column.\n   * In the future, columnCssClassName will change from type string[] to string and this\n   * will set a single string value.\n   * @docs-private\n   */\n  protected _updateColumnCssClassName() {\n    this._columnCssClassName = [`cdk-column-${this.cssClassFriendlyName}`];\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 _setNameInput(value: string) {\n    // If the directive is set without a name (updated programmatically), then this setter will\n    // trigger with an empty string and should not overwrite the programmatically set value.\n    if (value) {\n      this._name = value;\n      this.cssClassFriendlyName = value.replace(/[^a-z0-9_-]/ig, '-');\n      this._updateColumnCssClassName();\n    }\n  }\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    // If IE 11 is dropped before we switch to setting a single class name, change to multi param\n    // with destructuring.\n    const classList = elementRef.nativeElement.classList;\n    for (const className of columnDef._columnCssClassName) {\n      classList.add(className);\n    }\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  },\n})\nexport class CdkFooterCell extends BaseCdkCell {\n  constructor(columnDef: CdkColumnDef, elementRef: ElementRef) {\n    super(columnDef, elementRef);\n    if (columnDef._table?._elementRef.nativeElement.nodeType === 1) {\n      const tableRole = columnDef._table._elementRef.nativeElement\n        .getAttribute('role');\n      const role = (tableRole === 'grid' || tableRole === 'treegrid') ? 'gridcell' : 'cell';\n      elementRef.nativeElement.setAttribute('role', role);\n    }\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  },\n})\nexport class CdkCell extends BaseCdkCell {\n  constructor(columnDef: CdkColumnDef, elementRef: ElementRef) {\n    super(columnDef, elementRef);\n    if (columnDef._table?._elementRef.nativeElement.nodeType === 1) {\n      const tableRole = columnDef._table._elementRef.nativeElement\n        .getAttribute('role');\n      const role = (tableRole === 'grid' || tableRole === 'treegrid') ? 'gridcell' : 'cell';\n      elementRef.nativeElement.setAttribute('role', role);\n    }\n  }\n}\n"]}
|