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 { ChangeDetectionStrategy, Component, Directive, IterableDiffers, TemplateRef, ViewContainerRef, ViewEncapsulation, Inject, Optional, } from '@angular/core';
|
9 | import { mixinHasStickyInput } from './can-stick';
|
10 | import { CDK_TABLE } from './tokens';
|
11 | import * as i0 from "@angular/core";
|
12 | /**
|
13 | * The row template that can be used by the mat-table. Should not be used outside of the
|
14 | * material library.
|
15 | */
|
16 | export const CDK_ROW_TEMPLATE = `<ng-container cdkCellOutlet></ng-container>`;
|
17 | /**
|
18 | * Base class for the CdkHeaderRowDef and CdkRowDef that handles checking their columns inputs
|
19 | * for changes and notifying the table.
|
20 | */
|
21 | export class BaseRowDef {
|
22 | constructor(
|
23 | /** @docs-private */ template, _differs) {
|
24 | this.template = template;
|
25 | this._differs = _differs;
|
26 | }
|
27 | ngOnChanges(changes) {
|
28 | // Create a new columns differ if one does not yet exist. Initialize it based on initial value
|
29 | // of the columns property or an empty array if none is provided.
|
30 | if (!this._columnsDiffer) {
|
31 | const columns = (changes['columns'] && changes['columns'].currentValue) || [];
|
32 | this._columnsDiffer = this._differs.find(columns).create();
|
33 | this._columnsDiffer.diff(columns);
|
34 | }
|
35 | }
|
36 | /**
|
37 | * Returns the difference between the current columns and the columns from the last diff, or null
|
38 | * if there is no difference.
|
39 | */
|
40 | getColumnsDiff() {
|
41 | return this._columnsDiffer.diff(this.columns);
|
42 | }
|
43 | /** Gets this row def's relevant cell template from the provided column def. */
|
44 | extractCellTemplate(column) {
|
45 | if (this instanceof CdkHeaderRowDef) {
|
46 | return column.headerCell.template;
|
47 | }
|
48 | if (this instanceof CdkFooterRowDef) {
|
49 | return column.footerCell.template;
|
50 | }
|
51 | else {
|
52 | return column.cell.template;
|
53 | }
|
54 | }
|
55 | }
|
56 | BaseRowDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: BaseRowDef, deps: [{ token: i0.TemplateRef }, { token: i0.IterableDiffers }], target: i0.ɵɵFactoryTarget.Directive });
|
57 | BaseRowDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: BaseRowDef, usesOnChanges: true, ngImport: i0 });
|
58 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: BaseRowDef, decorators: [{
|
59 | type: Directive
|
60 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.IterableDiffers }]; } });
|
61 | // Boilerplate for applying mixins to CdkHeaderRowDef.
|
62 | /** @docs-private */
|
63 | class CdkHeaderRowDefBase extends BaseRowDef {
|
64 | }
|
65 | const _CdkHeaderRowDefBase = mixinHasStickyInput(CdkHeaderRowDefBase);
|
66 | /**
|
67 | * Header row definition for the CDK table.
|
68 | * Captures the header row's template and other header properties such as the columns to display.
|
69 | */
|
70 | export class CdkHeaderRowDef extends _CdkHeaderRowDefBase {
|
71 | constructor(template, _differs, _table) {
|
72 | super(template, _differs);
|
73 | this._table = _table;
|
74 | }
|
75 | // Prerender fails to recognize that ngOnChanges in a part of this class through inheritance.
|
76 | // Explicitly define it so that the method is called as part of the Angular lifecycle.
|
77 | ngOnChanges(changes) {
|
78 | super.ngOnChanges(changes);
|
79 | }
|
80 | }
|
81 | CdkHeaderRowDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderRowDef, deps: [{ token: i0.TemplateRef }, { token: i0.IterableDiffers }, { token: CDK_TABLE, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
82 | CdkHeaderRowDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkHeaderRowDef, selector: "[cdkHeaderRowDef]", inputs: { columns: ["cdkHeaderRowDef", "columns"], sticky: ["cdkHeaderRowDefSticky", "sticky"] }, usesInheritance: true, usesOnChanges: true, ngImport: i0 });
|
83 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderRowDef, decorators: [{
|
84 | type: Directive,
|
85 | args: [{
|
86 | selector: '[cdkHeaderRowDef]',
|
87 | inputs: ['columns: cdkHeaderRowDef', 'sticky: cdkHeaderRowDefSticky'],
|
88 | }]
|
89 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.IterableDiffers }, { type: undefined, decorators: [{
|
90 | type: Inject,
|
91 | args: [CDK_TABLE]
|
92 | }, {
|
93 | type: Optional
|
94 | }] }]; } });
|
95 | // Boilerplate for applying mixins to CdkFooterRowDef.
|
96 | /** @docs-private */
|
97 | class CdkFooterRowDefBase extends BaseRowDef {
|
98 | }
|
99 | const _CdkFooterRowDefBase = mixinHasStickyInput(CdkFooterRowDefBase);
|
100 | /**
|
101 | * Footer row definition for the CDK table.
|
102 | * Captures the footer row's template and other footer properties such as the columns to display.
|
103 | */
|
104 | export class CdkFooterRowDef extends _CdkFooterRowDefBase {
|
105 | constructor(template, _differs, _table) {
|
106 | super(template, _differs);
|
107 | this._table = _table;
|
108 | }
|
109 | // Prerender fails to recognize that ngOnChanges in a part of this class through inheritance.
|
110 | // Explicitly define it so that the method is called as part of the Angular lifecycle.
|
111 | ngOnChanges(changes) {
|
112 | super.ngOnChanges(changes);
|
113 | }
|
114 | }
|
115 | CdkFooterRowDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterRowDef, deps: [{ token: i0.TemplateRef }, { token: i0.IterableDiffers }, { token: CDK_TABLE, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
116 | CdkFooterRowDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkFooterRowDef, selector: "[cdkFooterRowDef]", inputs: { columns: ["cdkFooterRowDef", "columns"], sticky: ["cdkFooterRowDefSticky", "sticky"] }, usesInheritance: true, usesOnChanges: true, ngImport: i0 });
|
117 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterRowDef, decorators: [{
|
118 | type: Directive,
|
119 | args: [{
|
120 | selector: '[cdkFooterRowDef]',
|
121 | inputs: ['columns: cdkFooterRowDef', 'sticky: cdkFooterRowDefSticky'],
|
122 | }]
|
123 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.IterableDiffers }, { type: undefined, decorators: [{
|
124 | type: Inject,
|
125 | args: [CDK_TABLE]
|
126 | }, {
|
127 | type: Optional
|
128 | }] }]; } });
|
129 | /**
|
130 | * Data row definition for the CDK table.
|
131 | * Captures the header row's template and other row properties such as the columns to display and
|
132 | * a when predicate that describes when this row should be used.
|
133 | */
|
134 | export class CdkRowDef extends BaseRowDef {
|
135 | // TODO(andrewseguin): Add an input for providing a switch function to determine
|
136 | // if this template should be used.
|
137 | constructor(template, _differs, _table) {
|
138 | super(template, _differs);
|
139 | this._table = _table;
|
140 | }
|
141 | }
|
142 | CdkRowDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkRowDef, deps: [{ token: i0.TemplateRef }, { token: i0.IterableDiffers }, { token: CDK_TABLE, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
143 | CdkRowDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkRowDef, selector: "[cdkRowDef]", inputs: { columns: ["cdkRowDefColumns", "columns"], when: ["cdkRowDefWhen", "when"] }, usesInheritance: true, ngImport: i0 });
|
144 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkRowDef, decorators: [{
|
145 | type: Directive,
|
146 | args: [{
|
147 | selector: '[cdkRowDef]',
|
148 | inputs: ['columns: cdkRowDefColumns', 'when: cdkRowDefWhen'],
|
149 | }]
|
150 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.IterableDiffers }, { type: undefined, decorators: [{
|
151 | type: Inject,
|
152 | args: [CDK_TABLE]
|
153 | }, {
|
154 | type: Optional
|
155 | }] }]; } });
|
156 | /**
|
157 | * Outlet for rendering cells inside of a row or header row.
|
158 | * @docs-private
|
159 | */
|
160 | export class CdkCellOutlet {
|
161 | constructor(_viewContainer) {
|
162 | this._viewContainer = _viewContainer;
|
163 | CdkCellOutlet.mostRecentCellOutlet = this;
|
164 | }
|
165 | ngOnDestroy() {
|
166 | // If this was the last outlet being rendered in the view, remove the reference
|
167 | // from the static property after it has been destroyed to avoid leaking memory.
|
168 | if (CdkCellOutlet.mostRecentCellOutlet === this) {
|
169 | CdkCellOutlet.mostRecentCellOutlet = null;
|
170 | }
|
171 | }
|
172 | }
|
173 | /**
|
174 | * Static property containing the latest constructed instance of this class.
|
175 | * Used by the CDK table when each CdkHeaderRow and CdkRow component is created using
|
176 | * createEmbeddedView. After one of these components are created, this property will provide
|
177 | * a handle to provide that component's cells and context. After init, the CdkCellOutlet will
|
178 | * construct the cells with the provided context.
|
179 | */
|
180 | CdkCellOutlet.mostRecentCellOutlet = null;
|
181 | CdkCellOutlet.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkCellOutlet, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
182 | CdkCellOutlet.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkCellOutlet, selector: "[cdkCellOutlet]", ngImport: i0 });
|
183 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkCellOutlet, decorators: [{
|
184 | type: Directive,
|
185 | args: [{ selector: '[cdkCellOutlet]' }]
|
186 | }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
|
187 | /** Header template container that contains the cell outlet. Adds the right class and role. */
|
188 | export class CdkHeaderRow {
|
189 | }
|
190 | CdkHeaderRow.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderRow, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
191 | CdkHeaderRow.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.1", type: CdkHeaderRow, selector: "cdk-header-row, tr[cdk-header-row]", host: { attributes: { "role": "row" }, classAttribute: "cdk-header-row" }, ngImport: i0, template: "<ng-container cdkCellOutlet></ng-container>", isInline: true, dependencies: [{ kind: "directive", type: CdkCellOutlet, selector: "[cdkCellOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
192 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkHeaderRow, decorators: [{
|
193 | type: Component,
|
194 | args: [{
|
195 | selector: 'cdk-header-row, tr[cdk-header-row]',
|
196 | template: CDK_ROW_TEMPLATE,
|
197 | host: {
|
198 | 'class': 'cdk-header-row',
|
199 | 'role': 'row',
|
200 | },
|
201 | // See note on CdkTable for explanation on why this uses the default change detection strategy.
|
202 | // tslint:disable-next-line:validate-decorators
|
203 | changeDetection: ChangeDetectionStrategy.Default,
|
204 | encapsulation: ViewEncapsulation.None,
|
205 | }]
|
206 | }] });
|
207 | /** Footer template container that contains the cell outlet. Adds the right class and role. */
|
208 | export class CdkFooterRow {
|
209 | }
|
210 | CdkFooterRow.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterRow, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
211 | CdkFooterRow.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.1", type: CdkFooterRow, selector: "cdk-footer-row, tr[cdk-footer-row]", host: { attributes: { "role": "row" }, classAttribute: "cdk-footer-row" }, ngImport: i0, template: "<ng-container cdkCellOutlet></ng-container>", isInline: true, dependencies: [{ kind: "directive", type: CdkCellOutlet, selector: "[cdkCellOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
212 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkFooterRow, decorators: [{
|
213 | type: Component,
|
214 | args: [{
|
215 | selector: 'cdk-footer-row, tr[cdk-footer-row]',
|
216 | template: CDK_ROW_TEMPLATE,
|
217 | host: {
|
218 | 'class': 'cdk-footer-row',
|
219 | 'role': 'row',
|
220 | },
|
221 | // See note on CdkTable for explanation on why this uses the default change detection strategy.
|
222 | // tslint:disable-next-line:validate-decorators
|
223 | changeDetection: ChangeDetectionStrategy.Default,
|
224 | encapsulation: ViewEncapsulation.None,
|
225 | }]
|
226 | }] });
|
227 | /** Data row template container that contains the cell outlet. Adds the right class and role. */
|
228 | export class CdkRow {
|
229 | }
|
230 | CdkRow.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkRow, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
231 | CdkRow.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.1", type: CdkRow, selector: "cdk-row, tr[cdk-row]", host: { attributes: { "role": "row" }, classAttribute: "cdk-row" }, ngImport: i0, template: "<ng-container cdkCellOutlet></ng-container>", isInline: true, dependencies: [{ kind: "directive", type: CdkCellOutlet, selector: "[cdkCellOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
232 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkRow, decorators: [{
|
233 | type: Component,
|
234 | args: [{
|
235 | selector: 'cdk-row, tr[cdk-row]',
|
236 | template: CDK_ROW_TEMPLATE,
|
237 | host: {
|
238 | 'class': 'cdk-row',
|
239 | 'role': 'row',
|
240 | },
|
241 | // See note on CdkTable for explanation on why this uses the default change detection strategy.
|
242 | // tslint:disable-next-line:validate-decorators
|
243 | changeDetection: ChangeDetectionStrategy.Default,
|
244 | encapsulation: ViewEncapsulation.None,
|
245 | }]
|
246 | }] });
|
247 | /** Row that can be used to display a message when no data is shown in the table. */
|
248 | export class CdkNoDataRow {
|
249 | constructor(templateRef) {
|
250 | this.templateRef = templateRef;
|
251 | this._contentClassName = 'cdk-no-data-row';
|
252 | }
|
253 | }
|
254 | CdkNoDataRow.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkNoDataRow, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
255 | CdkNoDataRow.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: CdkNoDataRow, selector: "ng-template[cdkNoDataRow]", ngImport: i0 });
|
256 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: CdkNoDataRow, decorators: [{
|
257 | type: Directive,
|
258 | args: [{
|
259 | selector: 'ng-template[cdkNoDataRow]',
|
260 | }]
|
261 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
|
262 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row.js","sourceRoot":"","sources":["../../../../../../src/cdk/table/row.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  ChangeDetectionStrategy,\n  Component,\n  Directive,\n  IterableChanges,\n  IterableDiffer,\n  IterableDiffers,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef,\n  ViewEncapsulation,\n  Inject,\n  Optional,\n} from '@angular/core';\nimport {CanStick, CanStickCtor, mixinHasStickyInput} from './can-stick';\nimport {CdkCellDef, CdkColumnDef} from './cell';\nimport {CDK_TABLE} from './tokens';\n\n/**\n * The row template that can be used by the mat-table. Should not be used outside of the\n * material library.\n */\nexport const CDK_ROW_TEMPLATE = `<ng-container cdkCellOutlet></ng-container>`;\n\n/**\n * Base class for the CdkHeaderRowDef and CdkRowDef that handles checking their columns inputs\n * for changes and notifying the table.\n */\n@Directive()\nexport abstract class BaseRowDef implements OnChanges {\n  /** The columns to be displayed on this row. */\n  columns: Iterable<string>;\n\n  /** Differ used to check if any changes were made to the columns. */\n  protected _columnsDiffer: IterableDiffer<any>;\n\n  constructor(\n    /** @docs-private */ public template: TemplateRef<any>,\n    protected _differs: IterableDiffers,\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Create a new columns differ if one does not yet exist. Initialize it based on initial value\n    // of the columns property or an empty array if none is provided.\n    if (!this._columnsDiffer) {\n      const columns = (changes['columns'] && changes['columns'].currentValue) || [];\n      this._columnsDiffer = this._differs.find(columns).create();\n      this._columnsDiffer.diff(columns);\n    }\n  }\n\n  /**\n   * Returns the difference between the current columns and the columns from the last diff, or null\n   * if there is no difference.\n   */\n  getColumnsDiff(): IterableChanges<any> | null {\n    return this._columnsDiffer.diff(this.columns);\n  }\n\n  /** Gets this row def's relevant cell template from the provided column def. */\n  extractCellTemplate(column: CdkColumnDef): TemplateRef<any> {\n    if (this instanceof CdkHeaderRowDef) {\n      return column.headerCell.template;\n    }\n    if (this instanceof CdkFooterRowDef) {\n      return column.footerCell.template;\n    } else {\n      return column.cell.template;\n    }\n  }\n}\n\n// Boilerplate for applying mixins to CdkHeaderRowDef.\n/** @docs-private */\nclass CdkHeaderRowDefBase extends BaseRowDef {}\nconst _CdkHeaderRowDefBase: CanStickCtor & typeof CdkHeaderRowDefBase =\n  mixinHasStickyInput(CdkHeaderRowDefBase);\n\n/**\n * Header row definition for the CDK table.\n * Captures the header row's template and other header properties such as the columns to display.\n */\n@Directive({\n  selector: '[cdkHeaderRowDef]',\n  inputs: ['columns: cdkHeaderRowDef', 'sticky: cdkHeaderRowDefSticky'],\n})\nexport class CdkHeaderRowDef extends _CdkHeaderRowDefBase implements CanStick, OnChanges {\n  constructor(\n    template: TemplateRef<any>,\n    _differs: IterableDiffers,\n    @Inject(CDK_TABLE) @Optional() public _table?: any,\n  ) {\n    super(template, _differs);\n  }\n\n  // Prerender fails to recognize that ngOnChanges in a part of this class through inheritance.\n  // Explicitly define it so that the method is called as part of the Angular lifecycle.\n  override ngOnChanges(changes: SimpleChanges): void {\n    super.ngOnChanges(changes);\n  }\n}\n\n// Boilerplate for applying mixins to CdkFooterRowDef.\n/** @docs-private */\nclass CdkFooterRowDefBase extends BaseRowDef {}\nconst _CdkFooterRowDefBase: CanStickCtor & typeof CdkFooterRowDefBase =\n  mixinHasStickyInput(CdkFooterRowDefBase);\n\n/**\n * Footer row definition for the CDK table.\n * Captures the footer row's template and other footer properties such as the columns to display.\n */\n@Directive({\n  selector: '[cdkFooterRowDef]',\n  inputs: ['columns: cdkFooterRowDef', 'sticky: cdkFooterRowDefSticky'],\n})\nexport class CdkFooterRowDef extends _CdkFooterRowDefBase implements CanStick, OnChanges {\n  constructor(\n    template: TemplateRef<any>,\n    _differs: IterableDiffers,\n    @Inject(CDK_TABLE) @Optional() public _table?: any,\n  ) {\n    super(template, _differs);\n  }\n\n  // Prerender fails to recognize that ngOnChanges in a part of this class through inheritance.\n  // Explicitly define it so that the method is called as part of the Angular lifecycle.\n  override ngOnChanges(changes: SimpleChanges): void {\n    super.ngOnChanges(changes);\n  }\n}\n\n/**\n * Data row definition for the CDK table.\n * Captures the header row's template and other row properties such as the columns to display and\n * a when predicate that describes when this row should be used.\n */\n@Directive({\n  selector: '[cdkRowDef]',\n  inputs: ['columns: cdkRowDefColumns', 'when: cdkRowDefWhen'],\n})\nexport class CdkRowDef<T> extends BaseRowDef {\n  /**\n   * Function that should return true if this row template should be used for the provided index\n   * and row data. If left undefined, this row will be considered the default row template to use\n   * when no other when functions return true for the data.\n   * For every row, there must be at least one when function that passes or an undefined to default.\n   */\n  when: (index: number, rowData: T) => boolean;\n\n  // TODO(andrewseguin): Add an input for providing a switch function to determine\n  //   if this template should be used.\n  constructor(\n    template: TemplateRef<any>,\n    _differs: IterableDiffers,\n    @Inject(CDK_TABLE) @Optional() public _table?: any,\n  ) {\n    super(template, _differs);\n  }\n}\n\n/** Context provided to the row cells when `multiTemplateDataRows` is false */\nexport interface CdkCellOutletRowContext<T> {\n  /** Data for the row that this cell is located within. */\n  $implicit?: T;\n\n  /** Index of the data object in the provided data array. */\n  index?: number;\n\n  /** Length of the number of total rows. */\n  count?: number;\n\n  /** True if this cell is contained in the first row. */\n  first?: boolean;\n\n  /** True if this cell is contained in the last row. */\n  last?: boolean;\n\n  /** True if this cell is contained in a row with an even-numbered index. */\n  even?: boolean;\n\n  /** True if this cell is contained in a row with an odd-numbered index. */\n  odd?: boolean;\n}\n\n/**\n * Context provided to the row cells when `multiTemplateDataRows` is true. This context is the same\n * as CdkCellOutletRowContext except that the single `index` value is replaced by `dataIndex` and\n * `renderIndex`.\n */\nexport interface CdkCellOutletMultiRowContext<T> {\n  /** Data for the row that this cell is located within. */\n  $implicit?: T;\n\n  /** Index of the data object in the provided data array. */\n  dataIndex?: number;\n\n  /** Index location of the rendered row that this cell is located within. */\n  renderIndex?: number;\n\n  /** Length of the number of total rows. */\n  count?: number;\n\n  /** True if this cell is contained in the first row. */\n  first?: boolean;\n\n  /** True if this cell is contained in the last row. */\n  last?: boolean;\n\n  /** True if this cell is contained in a row with an even-numbered index. */\n  even?: boolean;\n\n  /** True if this cell is contained in a row with an odd-numbered index. */\n  odd?: boolean;\n}\n\n/**\n * Outlet for rendering cells inside of a row or header row.\n * @docs-private\n */\n@Directive({selector: '[cdkCellOutlet]'})\nexport class CdkCellOutlet implements OnDestroy {\n  /** The ordered list of cells to render within this outlet's view container */\n  cells: CdkCellDef[];\n\n  /** The data context to be provided to each cell */\n  context: any;\n\n  /**\n   * Static property containing the latest constructed instance of this class.\n   * Used by the CDK table when each CdkHeaderRow and CdkRow component is created using\n   * createEmbeddedView. After one of these components are created, this property will provide\n   * a handle to provide that component's cells and context. After init, the CdkCellOutlet will\n   * construct the cells with the provided context.\n   */\n  static mostRecentCellOutlet: CdkCellOutlet | null = null;\n\n  constructor(public _viewContainer: ViewContainerRef) {\n    CdkCellOutlet.mostRecentCellOutlet = this;\n  }\n\n  ngOnDestroy() {\n    // If this was the last outlet being rendered in the view, remove the reference\n    // from the static property after it has been destroyed to avoid leaking memory.\n    if (CdkCellOutlet.mostRecentCellOutlet === this) {\n      CdkCellOutlet.mostRecentCellOutlet = null;\n    }\n  }\n}\n\n/** Header template container that contains the cell outlet. Adds the right class and role. */\n@Component({\n  selector: 'cdk-header-row, tr[cdk-header-row]',\n  template: CDK_ROW_TEMPLATE,\n  host: {\n    'class': 'cdk-header-row',\n    'role': 'row',\n  },\n  // See note on CdkTable for explanation on why this uses the default change detection strategy.\n  // tslint:disable-next-line:validate-decorators\n  changeDetection: ChangeDetectionStrategy.Default,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CdkHeaderRow {}\n\n/** Footer template container that contains the cell outlet. Adds the right class and role. */\n@Component({\n  selector: 'cdk-footer-row, tr[cdk-footer-row]',\n  template: CDK_ROW_TEMPLATE,\n  host: {\n    'class': 'cdk-footer-row',\n    'role': 'row',\n  },\n  // See note on CdkTable for explanation on why this uses the default change detection strategy.\n  // tslint:disable-next-line:validate-decorators\n  changeDetection: ChangeDetectionStrategy.Default,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CdkFooterRow {}\n\n/** Data row template container that contains the cell outlet. Adds the right class and role. */\n@Component({\n  selector: 'cdk-row, tr[cdk-row]',\n  template: CDK_ROW_TEMPLATE,\n  host: {\n    'class': 'cdk-row',\n    'role': 'row',\n  },\n  // See note on CdkTable for explanation on why this uses the default change detection strategy.\n  // tslint:disable-next-line:validate-decorators\n  changeDetection: ChangeDetectionStrategy.Default,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CdkRow {}\n\n/** Row that can be used to display a message when no data is shown in the table. */\n@Directive({\n  selector: 'ng-template[cdkNoDataRow]',\n})\nexport class CdkNoDataRow {\n  _contentClassName = 'cdk-no-data-row';\n  constructor(public templateRef: TemplateRef<any>) {}\n}\n"]} |
\ | No newline at end of file |