1 | /**
|
2 | * @license
|
3 | * Copyright Google LLC All Rights Reserved.
|
4 | *
|
5 | * Use of this source code is governed by an MIT-style license that can be
|
6 | * found in the LICENSE file at https://angular.io/license
|
7 | */
|
8 | import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
9 | import { ContentChild, Directive, ElementRef, Inject, Input, Optional, TemplateRef, } from '@angular/core';
|
10 | import { mixinHasStickyInput } from './can-stick';
|
11 | import { CDK_TABLE } from './tokens';
|
12 | import * as i0 from "@angular/core";
|
13 | /**
|
14 | * Cell definition for a CDK table.
|
15 | * Captures the template of a column's data row cell as well as cell-specific properties.
|
16 | */
|
17 | export class CdkCellDef {
|
18 | constructor(/** @docs-private */ template) {
|
19 | this.template = template;
|
20 | }
|
21 | }
|
22 | CdkCellDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkCellDef, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
23 | CdkCellDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkCellDef, selector: "[cdkCellDef]", ngImport: i0 });
|
24 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkCellDef, decorators: [{
|
25 | type: Directive,
|
26 | args: [{ selector: '[cdkCellDef]' }]
|
27 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
|
28 | /**
|
29 | * Header cell definition for a CDK table.
|
30 | * Captures the template of a column's header cell and as well as cell-specific properties.
|
31 | */
|
32 | export class CdkHeaderCellDef {
|
33 | constructor(/** @docs-private */ template) {
|
34 | this.template = template;
|
35 | }
|
36 | }
|
37 | CdkHeaderCellDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderCellDef, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
38 | CdkHeaderCellDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkHeaderCellDef, selector: "[cdkHeaderCellDef]", ngImport: i0 });
|
39 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderCellDef, decorators: [{
|
40 | type: Directive,
|
41 | args: [{ selector: '[cdkHeaderCellDef]' }]
|
42 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
|
43 | /**
|
44 | * Footer cell definition for a CDK table.
|
45 | * Captures the template of a column's footer cell and as well as cell-specific properties.
|
46 | */
|
47 | export class CdkFooterCellDef {
|
48 | constructor(/** @docs-private */ template) {
|
49 | this.template = template;
|
50 | }
|
51 | }
|
52 | CdkFooterCellDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterCellDef, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
53 | CdkFooterCellDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkFooterCellDef, selector: "[cdkFooterCellDef]", ngImport: i0 });
|
54 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterCellDef, decorators: [{
|
55 | type: Directive,
|
56 | args: [{ selector: '[cdkFooterCellDef]' }]
|
57 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
|
58 | // Boilerplate for applying mixins to CdkColumnDef.
|
59 | /** @docs-private */
|
60 | class CdkColumnDefBase {
|
61 | }
|
62 | const _CdkColumnDefBase = mixinHasStickyInput(CdkColumnDefBase);
|
63 | /**
|
64 | * Column definition for the CDK table.
|
65 | * Defines a set of cells available for a table column.
|
66 | */
|
67 | export class CdkColumnDef extends _CdkColumnDefBase {
|
68 | constructor(_table) {
|
69 | super();
|
70 | this._table = _table;
|
71 | this._stickyEnd = false;
|
72 | }
|
73 | /** Unique name for this column. */
|
74 | get name() {
|
75 | return this._name;
|
76 | }
|
77 | set name(name) {
|
78 | this._setNameInput(name);
|
79 | }
|
80 | /**
|
81 | * Whether this column should be sticky positioned on the end of the row. Should make sure
|
82 | * that it mimics the `CanStick` mixin such that `_hasStickyChanged` is set to true if the value
|
83 | * has been changed.
|
84 | */
|
85 | get stickyEnd() {
|
86 | return this._stickyEnd;
|
87 | }
|
88 | set stickyEnd(v) {
|
89 | const prevValue = this._stickyEnd;
|
90 | this._stickyEnd = coerceBooleanProperty(v);
|
91 | this._hasStickyChanged = prevValue !== this._stickyEnd;
|
92 | }
|
93 | /**
|
94 | * Overridable method that sets the css classes that will be added to every cell in this
|
95 | * column.
|
96 | * In the future, columnCssClassName will change from type string[] to string and this
|
97 | * will set a single string value.
|
98 | * @docs-private
|
99 | */
|
100 | _updateColumnCssClassName() {
|
101 | this._columnCssClassName = [`cdk-column-${this.cssClassFriendlyName}`];
|
102 | }
|
103 | /**
|
104 | * This has been extracted to a util because of TS 4 and VE.
|
105 | * View Engine doesn't support property rename inheritance.
|
106 | * TS 4.0 doesn't allow properties to override accessors or vice-versa.
|
107 | * @docs-private
|
108 | */
|
109 | _setNameInput(value) {
|
110 | // If the directive is set without a name (updated programmatically), then this setter will
|
111 | // trigger with an empty string and should not overwrite the programmatically set value.
|
112 | if (value) {
|
113 | this._name = value;
|
114 | this.cssClassFriendlyName = value.replace(/[^a-z0-9_-]/gi, '-');
|
115 | this._updateColumnCssClassName();
|
116 | }
|
117 | }
|
118 | }
|
119 | CdkColumnDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkColumnDef, deps: [{ token: CDK_TABLE, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
120 | CdkColumnDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkColumnDef, selector: "[cdkColumnDef]", inputs: { sticky: "sticky", name: ["cdkColumnDef", "name"], stickyEnd: "stickyEnd" }, providers: [{ provide: 'MAT_SORT_HEADER_COLUMN_DEF', useExisting: CdkColumnDef }], queries: [{ propertyName: "cell", first: true, predicate: CdkCellDef, descendants: true }, { propertyName: "headerCell", first: true, predicate: CdkHeaderCellDef, descendants: true }, { propertyName: "footerCell", first: true, predicate: CdkFooterCellDef, descendants: true }], usesInheritance: true, ngImport: i0 });
|
121 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkColumnDef, decorators: [{
|
122 | type: Directive,
|
123 | args: [{
|
124 | selector: '[cdkColumnDef]',
|
125 | inputs: ['sticky'],
|
126 | providers: [{ provide: 'MAT_SORT_HEADER_COLUMN_DEF', useExisting: CdkColumnDef }],
|
127 | }]
|
128 | }], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
129 | type: Inject,
|
130 | args: [CDK_TABLE]
|
131 | }, {
|
132 | type: Optional
|
133 | }] }]; }, propDecorators: { name: [{
|
134 | type: Input,
|
135 | args: ['cdkColumnDef']
|
136 | }], stickyEnd: [{
|
137 | type: Input,
|
138 | args: ['stickyEnd']
|
139 | }], cell: [{
|
140 | type: ContentChild,
|
141 | args: [CdkCellDef]
|
142 | }], headerCell: [{
|
143 | type: ContentChild,
|
144 | args: [CdkHeaderCellDef]
|
145 | }], footerCell: [{
|
146 | type: ContentChild,
|
147 | args: [CdkFooterCellDef]
|
148 | }] } });
|
149 | /** Base class for the cells. Adds a CSS classname that identifies the column it renders in. */
|
150 | export class BaseCdkCell {
|
151 | constructor(columnDef, elementRef) {
|
152 | elementRef.nativeElement.classList.add(...columnDef._columnCssClassName);
|
153 | }
|
154 | }
|
155 | /** Header cell template container that adds the right classes and role. */
|
156 | export class CdkHeaderCell extends BaseCdkCell {
|
157 | constructor(columnDef, elementRef) {
|
158 | super(columnDef, elementRef);
|
159 | }
|
160 | }
|
161 | CdkHeaderCell.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderCell, deps: [{ token: CdkColumnDef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
162 | CdkHeaderCell.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkHeaderCell, selector: "cdk-header-cell, th[cdk-header-cell]", host: { attributes: { "role": "columnheader" }, classAttribute: "cdk-header-cell" }, usesInheritance: true, ngImport: i0 });
|
163 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderCell, decorators: [{
|
164 | type: Directive,
|
165 | args: [{
|
166 | selector: 'cdk-header-cell, th[cdk-header-cell]',
|
167 | host: {
|
168 | 'class': 'cdk-header-cell',
|
169 | 'role': 'columnheader',
|
170 | },
|
171 | }]
|
172 | }], ctorParameters: function () { return [{ type: CdkColumnDef }, { type: i0.ElementRef }]; } });
|
173 | /** Footer cell template container that adds the right classes and role. */
|
174 | export class CdkFooterCell extends BaseCdkCell {
|
175 | constructor(columnDef, elementRef) {
|
176 | super(columnDef, elementRef);
|
177 | if (columnDef._table?._elementRef.nativeElement.nodeType === 1) {
|
178 | const tableRole = columnDef._table._elementRef.nativeElement.getAttribute('role');
|
179 | const role = tableRole === 'grid' || tableRole === 'treegrid' ? 'gridcell' : 'cell';
|
180 | elementRef.nativeElement.setAttribute('role', role);
|
181 | }
|
182 | }
|
183 | }
|
184 | CdkFooterCell.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterCell, deps: [{ token: CdkColumnDef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
185 | CdkFooterCell.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkFooterCell, selector: "cdk-footer-cell, td[cdk-footer-cell]", host: { classAttribute: "cdk-footer-cell" }, usesInheritance: true, ngImport: i0 });
|
186 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterCell, decorators: [{
|
187 | type: Directive,
|
188 | args: [{
|
189 | selector: 'cdk-footer-cell, td[cdk-footer-cell]',
|
190 | host: {
|
191 | 'class': 'cdk-footer-cell',
|
192 | },
|
193 | }]
|
194 | }], ctorParameters: function () { return [{ type: CdkColumnDef }, { type: i0.ElementRef }]; } });
|
195 | /** Cell template container that adds the right classes and role. */
|
196 | export class CdkCell extends BaseCdkCell {
|
197 | constructor(columnDef, elementRef) {
|
198 | super(columnDef, elementRef);
|
199 | if (columnDef._table?._elementRef.nativeElement.nodeType === 1) {
|
200 | const tableRole = columnDef._table._elementRef.nativeElement.getAttribute('role');
|
201 | const role = tableRole === 'grid' || tableRole === 'treegrid' ? 'gridcell' : 'cell';
|
202 | elementRef.nativeElement.setAttribute('role', role);
|
203 | }
|
204 | }
|
205 | }
|
206 | CdkCell.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkCell, deps: [{ token: CdkColumnDef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
207 | CdkCell.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkCell, selector: "cdk-cell, td[cdk-cell]", host: { classAttribute: "cdk-cell" }, usesInheritance: true, ngImport: i0 });
|
208 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkCell, decorators: [{
|
209 | type: Directive,
|
210 | args: [{
|
211 | selector: 'cdk-cell, td[cdk-cell]',
|
212 | host: {
|
213 | 'class': 'cdk-cell',
|
214 | },
|
215 | }]
|
216 | }], ctorParameters: function () { return [{ type: CdkColumnDef }, { type: i0.ElementRef }]; } });
|
217 | //# 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 {\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/** 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    this._setNameInput(name);\n  }\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: BooleanInput) {\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_-]/gi, '-');\n      this._updateColumnCssClassName();\n    }\n  }\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    elementRef.nativeElement.classList.add(...columnDef._columnCssClassName);\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.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.getAttribute('role');\n      const role = tableRole === 'grid' || tableRole === 'treegrid' ? 'gridcell' : 'cell';\n      elementRef.nativeElement.setAttribute('role', role);\n    }\n  }\n}\n"]} |
\ | No newline at end of file |