UNPKG

dfx-bootstrap-table

Version:

Angular table CDK implementation for Bootstrap with filtering, sorting and pagination.

164 lines 17.3 kB
/** * @license * Original work Copyright Google LLC All Rights Reserved. * Modified work Copyright DatePoll-Systems * * 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 { CdkCell, CdkCellDef, CdkColumnDef, CdkFooterCell, CdkFooterCellDef, CdkHeaderCell, CdkHeaderCellDef, CdkTable, } from '@angular/cdk/table'; import { Directive, HostBinding, Input } from '@angular/core'; import * as i0 from "@angular/core"; /** * Cell definition for the ngb-table. * Captures the template of a column's data row cell as well as cell-specific properties. */ export class NgbCellDef extends CdkCellDef { // ngTemplateContextGuard flag to help with the Language Service static ngTemplateContextGuard(dir, ctx) { return true; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbCellDef, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.2", type: NgbCellDef, isStandalone: true, selector: "[ngbCellDef]", inputs: { ngbCellDefTable: "ngbCellDefTable" }, providers: [{ provide: CdkCellDef, useExisting: NgbCellDef }], usesInheritance: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbCellDef, decorators: [{ type: Directive, args: [{ selector: '[ngbCellDef]', providers: [{ provide: CdkCellDef, useExisting: NgbCellDef }], standalone: true, }] }], propDecorators: { ngbCellDefTable: [{ type: Input }] } }); /** * Header cell definition for the ngb-table. * Captures the template of a column's header cell and as well as cell-specific properties. */ export class NgbHeaderCellDef extends CdkHeaderCellDef { constructor() { super(...arguments); this.whiteSpace = 'nowrap'; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbHeaderCellDef, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.2", type: NgbHeaderCellDef, isStandalone: true, selector: "[ngbHeaderCellDef]", inputs: { whiteSpace: "whiteSpace" }, host: { properties: { "style.white-space": "this.whiteSpace" } }, providers: [{ provide: CdkHeaderCellDef, useExisting: NgbHeaderCellDef }], usesInheritance: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbHeaderCellDef, decorators: [{ type: Directive, args: [{ selector: '[ngbHeaderCellDef]', providers: [{ provide: CdkHeaderCellDef, useExisting: NgbHeaderCellDef }], standalone: true, }] }], propDecorators: { whiteSpace: [{ type: HostBinding, args: ['style.white-space'] }, { type: Input }] } }); /** * Footer cell definition for the ngb-table. * Captures the template of a column's footer cell and as well as cell-specific properties. */ export class NgbFooterCellDef extends CdkFooterCellDef { constructor() { super(...arguments); this.whiteSpace = 'nowrap'; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbFooterCellDef, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.2", type: NgbFooterCellDef, isStandalone: true, selector: "[ngbFooterCellDef]", inputs: { whiteSpace: "whiteSpace" }, host: { properties: { "style.white-space": "this.whiteSpace" } }, providers: [{ provide: CdkFooterCellDef, useExisting: NgbFooterCellDef }], usesInheritance: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbFooterCellDef, decorators: [{ type: Directive, args: [{ selector: '[ngbFooterCellDef]', providers: [{ provide: CdkFooterCellDef, useExisting: NgbFooterCellDef }], standalone: true, }] }], propDecorators: { whiteSpace: [{ type: HostBinding, args: ['style.white-space'] }, { type: Input }] } }); /** * Column definition for the ngb-table. * Defines a set of cells available for a table column. */ export class NgbColumnDef extends CdkColumnDef { /** Unique name for this column. */ get name() { return this._name; } set name(name) { this._setNameInput(name); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbColumnDef, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.2", type: NgbColumnDef, isStandalone: true, selector: "[ngbColumnDef]", inputs: { name: ["ngbColumnDef", "name"] }, providers: [ { provide: CdkColumnDef, useExisting: NgbColumnDef }, { provide: 'NGB_SORT_HEADER_COLUMN_DEF', useExisting: NgbColumnDef }, ], usesInheritance: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbColumnDef, decorators: [{ type: Directive, args: [{ selector: '[ngbColumnDef]', providers: [ { provide: CdkColumnDef, useExisting: NgbColumnDef }, { provide: 'NGB_SORT_HEADER_COLUMN_DEF', useExisting: NgbColumnDef }, ], standalone: true, }] }], propDecorators: { name: [{ type: Input, args: ['ngbColumnDef'] }] } }); /** Header cell template container that adds the right classes and role. */ export class NgbHeaderCell extends CdkHeaderCell { static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbHeaderCell, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.2", type: NgbHeaderCell, isStandalone: true, selector: "ngb-header-cell, th[ngb-header-cell]", host: { attributes: { "role": "columnheader" } }, usesInheritance: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbHeaderCell, decorators: [{ type: Directive, args: [{ selector: 'ngb-header-cell, th[ngb-header-cell]', host: { role: 'columnheader', }, standalone: true, }] }] }); /** Footer cell template container that adds the right classes and role. */ export class NgbFooterCell extends CdkFooterCell { static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbFooterCell, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.2", type: NgbFooterCell, isStandalone: true, selector: "ngb-footer-cell, td[ngb-footer-cell]", usesInheritance: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbFooterCell, decorators: [{ type: Directive, args: [{ selector: 'ngb-footer-cell, td[ngb-footer-cell]', standalone: true, }] }] }); /** Cell template container that adds the right classes and role. */ export class NgbCell extends CdkCell { constructor() { super(...arguments); this.whiteSpace = 'nowrap'; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbCell, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.2", type: NgbCell, isStandalone: true, selector: "ngb-cell, td[ngb-cell]", inputs: { whiteSpace: "whiteSpace" }, host: { properties: { "style.white-space": "this.whiteSpace" } }, usesInheritance: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbCell, decorators: [{ type: Directive, args: [{ selector: 'ngb-cell, td[ngb-cell]', standalone: true, }] }], propDecorators: { whiteSpace: [{ type: HostBinding, args: ['style.white-space'] }, { type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.js","sourceRoot":"","sources":["../../../../../../libs/dfx-bootstrap-table/src/lib/table/cell.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Original work Copyright Google LLC All Rights Reserved.\n * Modified work Copyright DatePoll-Systems\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 */\nimport {\n  CdkCell,\n  CdkCellDef,\n  CdkColumnDef,\n  CdkFooterCell,\n  CdkFooterCellDef,\n  CdkHeaderCell,\n  CdkHeaderCellDef,\n  CdkTable,\n} from '@angular/cdk/table';\nimport { Directive, HostBinding, Input } from '@angular/core';\n\n/**\n * Cell definition for the ngb-table.\n * Captures the template of a column's data row cell as well as cell-specific properties.\n */\n@Directive({\n  selector: '[ngbCellDef]',\n  providers: [{ provide: CdkCellDef, useExisting: NgbCellDef }],\n  standalone: true,\n})\nexport class NgbCellDef<T> extends CdkCellDef {\n  // leveraging syntactic-sugar syntax when we use *ngbCellDef\n  @Input() ngbCellDefTable?: CdkTable<T>;\n\n  // ngTemplateContextGuard flag to help with the Language Service\n  static ngTemplateContextGuard<T>(dir: NgbCellDef<T>, ctx: unknown): ctx is { $implicit: T; index: number } {\n    return true;\n  }\n}\n\n/**\n * Header cell definition for the ngb-table.\n * Captures the template of a column's header cell and as well as cell-specific properties.\n */\n@Directive({\n  selector: '[ngbHeaderCellDef]',\n  providers: [{ provide: CdkHeaderCellDef, useExisting: NgbHeaderCellDef }],\n  standalone: true,\n})\nexport class NgbHeaderCellDef extends CdkHeaderCellDef {\n  @HostBinding('style.white-space')\n  @Input()\n  whiteSpace = 'nowrap';\n}\n\n/**\n * Footer cell definition for the ngb-table.\n * Captures the template of a column's footer cell and as well as cell-specific properties.\n */\n@Directive({\n  selector: '[ngbFooterCellDef]',\n  providers: [{ provide: CdkFooterCellDef, useExisting: NgbFooterCellDef }],\n  standalone: true,\n})\nexport class NgbFooterCellDef extends CdkFooterCellDef {\n  @HostBinding('style.white-space')\n  @Input()\n  whiteSpace = 'nowrap';\n}\n\n/**\n * Column definition for the ngb-table.\n * Defines a set of cells available for a table column.\n */\n@Directive({\n  selector: '[ngbColumnDef]',\n  providers: [\n    { provide: CdkColumnDef, useExisting: NgbColumnDef },\n    { provide: 'NGB_SORT_HEADER_COLUMN_DEF', useExisting: NgbColumnDef },\n  ],\n  standalone: true,\n})\nexport class NgbColumnDef extends CdkColumnDef {\n  /** Unique name for this column. */\n  @Input('ngbColumnDef')\n  override get name(): string {\n    return this._name;\n  }\n\n  override set name(name: string) {\n    this._setNameInput(name);\n  }\n}\n\n/** Header cell template container that adds the right classes and role. */\n@Directive({\n  selector: 'ngb-header-cell, th[ngb-header-cell]',\n  host: {\n    role: 'columnheader',\n  },\n  standalone: true,\n})\nexport class NgbHeaderCell extends CdkHeaderCell {}\n\n/** Footer cell template container that adds the right classes and role. */\n@Directive({\n  selector: 'ngb-footer-cell, td[ngb-footer-cell]',\n  standalone: true,\n})\nexport class NgbFooterCell extends CdkFooterCell {}\n\n/** Cell template container that adds the right classes and role. */\n@Directive({\n  selector: 'ngb-cell, td[ngb-cell]',\n  standalone: true,\n})\nexport class NgbCell extends CdkCell {\n  @HostBinding('style.white-space')\n  @Input()\n  whiteSpace = 'nowrap';\n}\n"]}