ngx-tethys 17.0.6 → 17.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +32 -1
- package/breadcrumb/breadcrumb.component.d.ts +30 -2
- package/breadcrumb/module.d.ts +3 -1
- package/breadcrumb/styles/breadcrumb.scss +8 -0
- package/date-picker/abstract-picker.component.d.ts +8 -1
- package/date-picker/date-picker.config.d.ts +1 -0
- package/date-picker/date-picker.service.d.ts +1 -0
- package/date-picker/lib/popups/date-popup.component.d.ts +2 -1
- package/date-picker/picker.util.d.ts +2 -0
- package/esm2022/breadcrumb/breadcrumb.component.mjs +73 -32
- package/esm2022/breadcrumb/module.mjs +6 -4
- package/esm2022/cascader/cascader-search-option.component.mjs +2 -2
- package/esm2022/cascader/cascader.component.mjs +3 -3
- package/esm2022/date-picker/abstract-picker.component.mjs +20 -10
- package/esm2022/date-picker/abstract-picker.directive.mjs +3 -2
- package/esm2022/date-picker/date-picker.component.mjs +3 -3
- package/esm2022/date-picker/date-picker.config.mjs +2 -1
- package/esm2022/date-picker/date-picker.service.mjs +4 -1
- package/esm2022/date-picker/lib/popups/date-popup.component.mjs +7 -4
- package/esm2022/date-picker/month-picker.component.mjs +3 -3
- package/esm2022/date-picker/picker.util.mjs +14 -2
- package/esm2022/date-picker/quarter-picker.component.mjs +3 -3
- package/esm2022/date-picker/range-picker.component.mjs +3 -3
- package/esm2022/date-picker/week-picker.component.mjs +3 -3
- package/esm2022/date-picker/year-picker.component.mjs +3 -3
- package/esm2022/pagination/pagination.class.mjs +1 -1
- package/esm2022/pagination/pagination.component.mjs +15 -3
- package/esm2022/pagination/pagination.config.mjs +3 -2
- package/esm2022/table/table-skeleton.component.mjs +4 -4
- package/esm2022/table/table.component.mjs +6 -4
- package/esm2022/util/helpers/helpers.mjs +2 -2
- package/esm2022/version.mjs +2 -2
- package/fesm2022/ngx-tethys-breadcrumb.mjs +117 -77
- package/fesm2022/ngx-tethys-breadcrumb.mjs.map +1 -1
- package/fesm2022/ngx-tethys-cascader.mjs +3 -3
- package/fesm2022/ngx-tethys-cascader.mjs.map +1 -1
- package/fesm2022/ngx-tethys-date-picker.mjs +54 -25
- package/fesm2022/ngx-tethys-date-picker.mjs.map +1 -1
- package/fesm2022/ngx-tethys-pagination.mjs +16 -3
- package/fesm2022/ngx-tethys-pagination.mjs.map +1 -1
- package/fesm2022/ngx-tethys-table.mjs +8 -6
- package/fesm2022/ngx-tethys-table.mjs.map +1 -1
- package/fesm2022/ngx-tethys-util.mjs +1 -1
- package/fesm2022/ngx-tethys-util.mjs.map +1 -1
- package/fesm2022/ngx-tethys.mjs +1 -1
- package/fesm2022/ngx-tethys.mjs.map +1 -1
- package/package.json +1 -1
- package/pagination/pagination.class.d.ts +4 -0
- package/pagination/pagination.component.d.ts +6 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/table/table.component.d.ts +3 -1
- package/util/helpers/helpers.d.ts +1 -1
|
@@ -18,7 +18,8 @@ export const PaginationDefaultConfig = {
|
|
|
18
18
|
nextIcon: 'angle-right',
|
|
19
19
|
totalPagesFormat: '共{total}页',
|
|
20
20
|
showSizeChanger: false,
|
|
21
|
-
pageSizeOptions: [10, 20, 50, 100]
|
|
21
|
+
pageSizeOptions: [10, 20, 50, 100],
|
|
22
|
+
unit: '条'
|
|
22
23
|
};
|
|
23
24
|
export const THY_PAGINATION_CONFIG = new InjectionToken('THY_PAGINATION_CONFIG', {
|
|
24
25
|
providedIn: 'root',
|
|
@@ -26,4 +27,4 @@ export const THY_PAGINATION_CONFIG = new InjectionToken('THY_PAGINATION_CONFIG',
|
|
|
26
27
|
return {};
|
|
27
28
|
}
|
|
28
29
|
});
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcGFnaW5hdGlvbi9wYWdpbmF0aW9uLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9DLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsQ0FBQztBQUVyQyxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBNkI7SUFDN0QsYUFBYSxFQUFFLEtBQUs7SUFDcEIsY0FBYyxFQUFFLElBQUk7SUFDcEIsUUFBUSxFQUFFLEVBQUU7SUFDWixRQUFRLEVBQUUsQ0FBQztJQUNYLFVBQVUsRUFBRSxtQkFBbUI7SUFDL0IsZUFBZSxFQUFFLElBQUk7SUFDckIsa0JBQWtCLEVBQUUsSUFBSTtJQUN4QixTQUFTLEVBQUUsS0FBSztJQUNoQixRQUFRLEVBQUUsTUFBTTtJQUNoQixZQUFZLEVBQUUsRUFBRTtJQUNoQixRQUFRLEVBQUUsRUFBRTtJQUNaLFNBQVMsRUFBRSxFQUFFO0lBQ2IsUUFBUSxFQUFFLEVBQUU7SUFDWixZQUFZLEVBQUUsWUFBWTtJQUMxQixRQUFRLEVBQUUsYUFBYTtJQUN2QixnQkFBZ0IsRUFBRSxXQUFXO0lBQzdCLGVBQWUsRUFBRSxLQUFLO0lBQ3RCLGVBQWUsRUFBRSxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEdBQUcsQ0FBQztJQUNsQyxJQUFJLEVBQUUsR0FBRztDQUNaLENBQUM7QUFLRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLGNBQWMsQ0FBc0IsdUJBQXVCLEVBQUU7SUFDbEcsVUFBVSxFQUFFLE1BQU07SUFDbEIsT0FBTyxFQUFFLEdBQUcsRUFBRTtRQUNWLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQztDQUNKLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlQYWdpbmF0aW9uQ29uZmlnTW9kZWwgfSBmcm9tICcuL3BhZ2luYXRpb24uY2xhc3MnO1xuXG5leHBvcnQgY29uc3QgREVGQVVMVF9SQU5HRV9DT1VOVCA9IDU7XG5cbmV4cG9ydCBjb25zdCBQYWdpbmF0aW9uRGVmYXVsdENvbmZpZzogVGh5UGFnaW5hdGlvbkNvbmZpZ01vZGVsID0ge1xuICAgIGJvdW5kYXJ5TGlua3M6IGZhbHNlLFxuICAgIGRpcmVjdGlvbkxpbmtzOiB0cnVlLFxuICAgIHBhZ2VTaXplOiAyMCxcbiAgICBtYXhDb3VudDogNyxcbiAgICByYW5nZUNvdW50OiBERUZBVUxUX1JBTkdFX0NPVU5ULFxuICAgIHNob3dRdWlja0p1bXBlcjogdHJ1ZSxcbiAgICBzaG93VG90YWxQYWdlQ291bnQ6IHRydWUsXG4gICAgZmlyc3RUZXh0OiAn56ys5LiA6aG1JyxcbiAgICBsYXN0VGV4dDogJ+acgOWQjuS4gOmhtScsXG4gICAgcHJldmlvdXNUZXh0OiAnJyxcbiAgICBuZXh0VGV4dDogJycsXG4gICAgZmlyc3RJY29uOiAnJyxcbiAgICBsYXN0SWNvbjogJycsXG4gICAgcHJldmlvdXNJY29uOiAnYW5nbGUtbGVmdCcsXG4gICAgbmV4dEljb246ICdhbmdsZS1yaWdodCcsXG4gICAgdG90YWxQYWdlc0Zvcm1hdDogJ+WFsXt0b3RhbH3pobUnLFxuICAgIHNob3dTaXplQ2hhbmdlcjogZmFsc2UsXG4gICAgcGFnZVNpemVPcHRpb25zOiBbMTAsIDIwLCA1MCwgMTAwXSxcbiAgICB1bml0OiAn5p2hJ1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgVGh5UGFnaW5hdGlvbkNvbmZpZyB7XG4gICAgbWFpbj86IFRoeVBhZ2luYXRpb25Db25maWdNb2RlbDtcbn1cblxuZXhwb3J0IGNvbnN0IFRIWV9QQUdJTkFUSU9OX0NPTkZJRyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUaHlQYWdpbmF0aW9uQ29uZmlnPignVEhZX1BBR0lOQVRJT05fQ09ORklHJywge1xuICAgIHByb3ZpZGVkSW46ICdyb290JyxcbiAgICBmYWN0b3J5OiAoKSA9PiB7XG4gICAgICAgIHJldHVybiB7fTtcbiAgICB9XG59KTtcbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { NgClass, NgFor, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { NgClass, NgFor, NgIf, NgStyle, NgTemplateOutlet } from '@angular/common';
|
|
3
3
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Input, ViewChild, ViewEncapsulation, booleanAttribute } from '@angular/core';
|
|
4
4
|
import { InputCssPixel } from 'ngx-tethys/core';
|
|
5
5
|
import { ThySkeletonCircle, ThySkeletonRectangle } from 'ngx-tethys/skeleton';
|
|
@@ -106,7 +106,7 @@ export class ThyTableSkeleton {
|
|
|
106
106
|
this.cdr.detectChanges();
|
|
107
107
|
}
|
|
108
108
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyTableSkeleton, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
109
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyTableSkeleton, isStandalone: true, selector: "thy-table-skeleton", inputs: { thyBorderRadius: "thyBorderRadius", thyRowHeight: "thyRowHeight", thyAnimated: ["thyAnimated", "thyAnimated", booleanAttribute], thyAnimatedInterval: "thyAnimatedInterval", thyPrimaryColor: "thyPrimaryColor", thySecondaryColor: "thySecondaryColor", thyRowCount: "thyRowCount", thyHeadless: ["thyHeadless", "thyHeadless", booleanAttribute], thyTheme: "thyTheme", thySize: "thySize", thyMinWidth: "thyMinWidth", thyColumns: "thyColumns" }, host: { classAttribute: "thy-table-skeleton" }, viewQueries: [{ propertyName: "titleTemplate", first: true, predicate: ["titleTemplate"], descendants: true }, { propertyName: "memberTemplate", first: true, predicate: ["memberTemplate"], descendants: true }, { propertyName: "defaultTemplate", first: true, predicate: ["defaultTemplate"], descendants: true }, { propertyName: "checkboxTemplate", first: true, predicate: ["checkboxTemplate"], descendants: true }], ngImport: i0, template: "<table [ngClass]=\"tableClassMap\" [
|
|
109
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyTableSkeleton, isStandalone: true, selector: "thy-table-skeleton", inputs: { thyBorderRadius: "thyBorderRadius", thyRowHeight: "thyRowHeight", thyAnimated: ["thyAnimated", "thyAnimated", booleanAttribute], thyAnimatedInterval: "thyAnimatedInterval", thyPrimaryColor: "thyPrimaryColor", thySecondaryColor: "thySecondaryColor", thyRowCount: "thyRowCount", thyHeadless: ["thyHeadless", "thyHeadless", booleanAttribute], thyTheme: "thyTheme", thySize: "thySize", thyMinWidth: "thyMinWidth", thyColumns: "thyColumns" }, host: { classAttribute: "thy-table-skeleton" }, viewQueries: [{ propertyName: "titleTemplate", first: true, predicate: ["titleTemplate"], descendants: true }, { propertyName: "memberTemplate", first: true, predicate: ["memberTemplate"], descendants: true }, { propertyName: "defaultTemplate", first: true, predicate: ["defaultTemplate"], descendants: true }, { propertyName: "checkboxTemplate", first: true, predicate: ["checkboxTemplate"], descendants: true }], ngImport: i0, template: "<table [ngClass]=\"tableClassMap\" [ngStyle]=\"{ 'min-width': thyMinWidth }\">\n <colgroup>\n <col *ngFor=\"let column of columns; trackBy: trackByFn\" [width]=\"column.width\" />\n </colgroup>\n <ng-container *ngIf=\"!thyHeadless\">\n <thead>\n <tr>\n <th *ngFor=\"let column of columns; trackBy: trackByFn\">\n <thy-skeleton-rectangle\n [thyRowWidth]=\"column?.type === columnType.checkbox ? checkboxWidth : titleWidth\"\n [thyRowHeight]=\"titleHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyTheme === 'bordered' || thyTheme === 'boxed' ? '#eee' : thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n </th>\n </tr>\n </thead>\n </ng-container>\n <tbody>\n <ng-container *ngFor=\"let item of rowCount; let i = index\">\n <tr>\n <ng-container *ngFor=\"let column of columns; trackBy: trackByFn\">\n <td>\n <ng-container\n *thyViewOutlet=\"\n skeletonColumnsMap[column.type] || defaultTemplate\n context:{\n trIndex: i,\n }\n \">\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </tbody>\n</table>\n\n<ng-template #titleTemplate let-trIndex=\"trIndex\">\n <div class=\"d-flex align-items-center\">\n <thy-skeleton-rectangle\n class=\"mr-2 flex-shrink-0\"\n [thyRowWidth]=\"checkboxWidth\"\n [thyRowHeight]=\"thyRowHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n\n <ng-container\n *thyViewOutlet=\"defaultTemplate;\n context:{\n rowWidth: trIndex % 3 === 0 ? '75%' : trIndex % 3 === 1 ? '100%' : trIndex % 3 === 2 ? '65%' : '',\n }\"></ng-container>\n </div>\n</ng-template>\n\n<ng-template #checkboxTemplate>\n <thy-skeleton-rectangle\n [thyRowWidth]=\"checkboxWidth\"\n [thyRowHeight]=\"thyRowHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n\n<ng-template #memberTemplate>\n <div class=\"d-flex align-items-center\">\n <thy-skeleton-circle\n class=\"mr-2 flex-shrink-0\"\n [thySize]=\"avatarSize\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-circle>\n\n <ng-container *thyViewOutlet=\"defaultTemplate\"></ng-container>\n </div>\n</ng-template>\n\n<ng-template #defaultTemplate let-rowWidth=\"rowWidth\">\n <thy-skeleton-rectangle\n [thyRowWidth]=\"rowWidth\"\n [thyRowHeight]=\"thyRowHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: ThyViewOutletDirective, selector: "[thyViewOutlet]", inputs: ["thyViewOutlet", "thyViewOutletContext"] }, { kind: "component", type: ThySkeletonRectangle, selector: "thy-skeleton-rectangle", inputs: ["thyAnimated", "thyAnimatedInterval", "thyBorderRadius", "thyRowWidth", "thyRowHeight", "thyPrimaryColor", "thySecondaryColor"] }, { kind: "component", type: ThySkeletonCircle, selector: "thy-skeleton-circle", inputs: ["thyAnimatedInterval", "thySize", "thyPrimaryColor", "thySecondaryColor", "thyAnimated"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
110
110
|
}
|
|
111
111
|
__decorate([
|
|
112
112
|
InputCssPixel(),
|
|
@@ -124,7 +124,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
124
124
|
type: Component,
|
|
125
125
|
args: [{ selector: 'thy-table-skeleton', host: {
|
|
126
126
|
class: 'thy-table-skeleton'
|
|
127
|
-
}, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [NgFor, NgClass, NgIf, NgTemplateOutlet, ThyViewOutletDirective, ThySkeletonRectangle, ThySkeletonCircle], template: "<table [ngClass]=\"tableClassMap\" [
|
|
127
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [NgFor, NgClass, NgIf, NgStyle, NgTemplateOutlet, ThyViewOutletDirective, ThySkeletonRectangle, ThySkeletonCircle], template: "<table [ngClass]=\"tableClassMap\" [ngStyle]=\"{ 'min-width': thyMinWidth }\">\n <colgroup>\n <col *ngFor=\"let column of columns; trackBy: trackByFn\" [width]=\"column.width\" />\n </colgroup>\n <ng-container *ngIf=\"!thyHeadless\">\n <thead>\n <tr>\n <th *ngFor=\"let column of columns; trackBy: trackByFn\">\n <thy-skeleton-rectangle\n [thyRowWidth]=\"column?.type === columnType.checkbox ? checkboxWidth : titleWidth\"\n [thyRowHeight]=\"titleHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyTheme === 'bordered' || thyTheme === 'boxed' ? '#eee' : thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n </th>\n </tr>\n </thead>\n </ng-container>\n <tbody>\n <ng-container *ngFor=\"let item of rowCount; let i = index\">\n <tr>\n <ng-container *ngFor=\"let column of columns; trackBy: trackByFn\">\n <td>\n <ng-container\n *thyViewOutlet=\"\n skeletonColumnsMap[column.type] || defaultTemplate\n context:{\n trIndex: i,\n }\n \">\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </tbody>\n</table>\n\n<ng-template #titleTemplate let-trIndex=\"trIndex\">\n <div class=\"d-flex align-items-center\">\n <thy-skeleton-rectangle\n class=\"mr-2 flex-shrink-0\"\n [thyRowWidth]=\"checkboxWidth\"\n [thyRowHeight]=\"thyRowHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n\n <ng-container\n *thyViewOutlet=\"defaultTemplate;\n context:{\n rowWidth: trIndex % 3 === 0 ? '75%' : trIndex % 3 === 1 ? '100%' : trIndex % 3 === 2 ? '65%' : '',\n }\"></ng-container>\n </div>\n</ng-template>\n\n<ng-template #checkboxTemplate>\n <thy-skeleton-rectangle\n [thyRowWidth]=\"checkboxWidth\"\n [thyRowHeight]=\"thyRowHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n\n<ng-template #memberTemplate>\n <div class=\"d-flex align-items-center\">\n <thy-skeleton-circle\n class=\"mr-2 flex-shrink-0\"\n [thySize]=\"avatarSize\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-circle>\n\n <ng-container *thyViewOutlet=\"defaultTemplate\"></ng-container>\n </div>\n</ng-template>\n\n<ng-template #defaultTemplate let-rowWidth=\"rowWidth\">\n <thy-skeleton-rectangle\n [thyRowWidth]=\"rowWidth\"\n [thyRowHeight]=\"thyRowHeight\"\n [thyBorderRadius]=\"thyBorderRadius\"\n [thyAnimated]=\"thyAnimated\"\n [thyAnimatedInterval]=\"thyAnimatedInterval\"\n [thyPrimaryColor]=\"thyPrimaryColor\"\n [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n" }]
|
|
128
128
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { titleTemplate: [{
|
|
129
129
|
type: ViewChild,
|
|
130
130
|
args: ['titleTemplate']
|
|
@@ -164,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
164
164
|
}], thyColumns: [{
|
|
165
165
|
type: Input
|
|
166
166
|
}] } });
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-skeleton.component.js","sourceRoot":"","sources":["../../../../src/table/table-skeleton.component.ts","../../../../src/table/table-skeleton.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgFor, NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Input,\n    ViewChild,\n    ViewEncapsulation,\n    booleanAttribute\n} from '@angular/core';\nimport { InputCssPixel } from 'ngx-tethys/core';\nimport { ThySkeletonCircle, ThySkeletonRectangle } from 'ngx-tethys/skeleton';\nimport { ThyTableSkeletonColumn } from './table.interface';\nimport { ThyViewOutletDirective } from 'ngx-tethys/shared';\nimport { ThyTableColumnSkeletonType } from './enums';\nimport { ThyTableSize, ThyTableTheme } from './table.component';\n\nconst COLUMN_COUNT = 5;\n\n/**\n * 表格的骨架屏组件\n * @name thy-table-skeleton\n */\n@Component({\n    selector: 'thy-table-skeleton',\n    templateUrl: './table-skeleton.component.html',\n    host: {\n        class: 'thy-table-skeleton'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [NgFor, NgClass, NgIf, NgTemplateOutlet, ThyViewOutletDirective, ThySkeletonRectangle, ThySkeletonCircle]\n})\nexport class ThyTableSkeleton implements AfterViewInit {\n    @ViewChild('titleTemplate') titleTemplate: ElementRef<HTMLElement>;\n\n    @ViewChild('memberTemplate') memberTemplate: ElementRef<HTMLElement>;\n\n    @ViewChild('defaultTemplate') defaultTemplate: ElementRef<HTMLElement>;\n\n    @ViewChild('checkboxTemplate') checkboxTemplate: ElementRef<HTMLElement>;\n\n    /**\n     * 骨架边框圆角\n     */\n    @Input()\n    @InputCssPixel()\n    thyBorderRadius: string | number;\n\n    /**\n     * 表格内容骨架高度\n     */\n    @Input()\n    @InputCssPixel()\n    thyRowHeight: string | number = '20px';\n\n    /**\n     * 是否开启动画\n     * @default true\n     */\n    @Input({ transform: booleanAttribute })\n    thyAnimated: boolean = true;\n\n    /**\n     * 动画速度\n     */\n    @Input() thyAnimatedInterval: string;\n\n    /**\n     * 骨架主色\n     */\n    @Input() thyPrimaryColor: string;\n\n    /**\n     * 骨架次色\n     */\n    @Input() thySecondaryColor: string;\n\n    rowCount: number[] = [];\n\n    /**\n     * 行数\n     */\n    @Input()\n    set thyRowCount(value: number | string) {\n        this.rowCount = Array.from({ length: +value });\n    }\n\n    /**\n     * 是否展示骨架头\n     * @default false\n     */\n    @Input({ transform: booleanAttribute }) thyHeadless = false;\n\n    /**\n     * 骨架屏的风格\n     * @type default | bordered | boxed\n     */\n    @Input() thyTheme: ThyTableTheme = 'default';\n\n    /**\n     * 骨架屏的大小\n     * @type xs | sm | md | lg | xlg | default\n     * @default md\n     */\n    @Input() thySize: ThyTableSize = 'md';\n\n    /**\n     * 设置表格最小宽度\n     */\n    @Input()\n    @InputCssPixel()\n    thyMinWidth: string | number;\n\n    /**\n     * 表格列骨架的配置项，支持配置列宽、骨架类型\n     * @type ThyTableSkeletonColumn[]\n     */\n    @Input() set thyColumns(columns: ThyTableSkeletonColumn[]) {\n        if (columns && columns.length) {\n            this.columns = columns;\n        } else {\n            this.columns = [...this.defaultColumns];\n        }\n    }\n\n    public titleHeight = '20px';\n\n    public titleWidth = '50px';\n\n    public checkboxWidth = '20px';\n\n    public avatarSize = '24px';\n\n    public columnType = ThyTableColumnSkeletonType;\n\n    public skeletonColumnsMap: {\n        [key: string]: ElementRef<HTMLElement>;\n    } = {};\n\n    get tableClassMap() {\n        return {\n            table: true,\n            'table-bordered': this.thyTheme === 'bordered',\n            'table-boxed': this.thyTheme === 'boxed',\n            [`table-${this.thySize}`]: !!this.thySize\n        };\n    }\n\n    private defaultColumns = Array.from({ length: COLUMN_COUNT }).map((item, index: number) => {\n        if (index === 0) {\n            return {\n                width: '40%',\n                type: ThyTableColumnSkeletonType.title\n            };\n        } else if (index === 1) {\n            return {\n                width: '17%',\n                type: ThyTableColumnSkeletonType.member\n            };\n        } else {\n            return {\n                width: 'auto',\n                type: ThyTableColumnSkeletonType.default\n            };\n        }\n    });\n\n    public columns: ThyTableSkeletonColumn[] = [...this.defaultColumns];\n\n    public trackByFn(index: number) {\n        return index;\n    }\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngAfterViewInit(): void {\n        this.skeletonColumnsMap = {\n            [ThyTableColumnSkeletonType.title]: this.titleTemplate,\n            [ThyTableColumnSkeletonType.member]: this.memberTemplate,\n            [ThyTableColumnSkeletonType.checkbox]: this.checkboxTemplate\n        };\n        this.cdr.detectChanges();\n    }\n}\n","<table [ngClass]=\"tableClassMap\" [style.min-width]=\"thyMinWidth\">\n  <colgroup>\n    <col *ngFor=\"let column of columns; trackBy: trackByFn\" [width]=\"column.width\" />\n  </colgroup>\n  <ng-container *ngIf=\"!thyHeadless\">\n    <thead>\n      <tr>\n        <th *ngFor=\"let column of columns; trackBy: trackByFn\">\n          <thy-skeleton-rectangle\n            [thyRowWidth]=\"column?.type === columnType.checkbox ? checkboxWidth : titleWidth\"\n            [thyRowHeight]=\"titleHeight\"\n            [thyBorderRadius]=\"thyBorderRadius\"\n            [thyAnimated]=\"thyAnimated\"\n            [thyAnimatedInterval]=\"thyAnimatedInterval\"\n            [thyPrimaryColor]=\"thyTheme === 'bordered' || thyTheme === 'boxed' ? '#eee' : thyPrimaryColor\"\n            [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n        </th>\n      </tr>\n    </thead>\n  </ng-container>\n  <tbody>\n    <ng-container *ngFor=\"let item of rowCount; let i = index\">\n      <tr>\n        <ng-container *ngFor=\"let column of columns; trackBy: trackByFn\">\n          <td>\n            <ng-container\n              *thyViewOutlet=\"\n              skeletonColumnsMap[column.type] || defaultTemplate\n              context:{\n                  trIndex: i,\n              }\n            \">\n            </ng-container>\n          </td>\n        </ng-container>\n      </tr>\n    </ng-container>\n  </tbody>\n</table>\n\n<ng-template #titleTemplate let-trIndex=\"trIndex\">\n  <div class=\"d-flex align-items-center\">\n    <thy-skeleton-rectangle\n      class=\"mr-2 flex-shrink-0\"\n      [thyRowWidth]=\"checkboxWidth\"\n      [thyRowHeight]=\"thyRowHeight\"\n      [thyBorderRadius]=\"thyBorderRadius\"\n      [thyAnimated]=\"thyAnimated\"\n      [thyAnimatedInterval]=\"thyAnimatedInterval\"\n      [thyPrimaryColor]=\"thyPrimaryColor\"\n      [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n\n    <ng-container\n      *thyViewOutlet=\"defaultTemplate;\n      context:{\n        rowWidth: trIndex % 3 === 0 ? '75%' : trIndex % 3 === 1 ? '100%' : trIndex % 3 === 2 ? '65%' : '',\n      }\"></ng-container>\n  </div>\n</ng-template>\n\n<ng-template #checkboxTemplate>\n  <thy-skeleton-rectangle\n    [thyRowWidth]=\"checkboxWidth\"\n    [thyRowHeight]=\"thyRowHeight\"\n    [thyBorderRadius]=\"thyBorderRadius\"\n    [thyAnimated]=\"thyAnimated\"\n    [thyAnimatedInterval]=\"thyAnimatedInterval\"\n    [thyPrimaryColor]=\"thyPrimaryColor\"\n    [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n\n<ng-template #memberTemplate>\n  <div class=\"d-flex align-items-center\">\n    <thy-skeleton-circle\n      class=\"mr-2 flex-shrink-0\"\n      [thySize]=\"avatarSize\"\n      [thyAnimated]=\"thyAnimated\"\n      [thyAnimatedInterval]=\"thyAnimatedInterval\"\n      [thyPrimaryColor]=\"thyPrimaryColor\"\n      [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-circle>\n\n    <ng-container *thyViewOutlet=\"defaultTemplate\"></ng-container>\n  </div>\n</ng-template>\n\n<ng-template #defaultTemplate let-rowWidth=\"rowWidth\">\n  <thy-skeleton-rectangle\n    [thyRowWidth]=\"rowWidth\"\n    [thyRowHeight]=\"thyRowHeight\"\n    [thyBorderRadius]=\"thyBorderRadius\"\n    [thyAnimated]=\"thyAnimated\"\n    [thyAnimatedInterval]=\"thyAnimatedInterval\"\n    [thyPrimaryColor]=\"thyPrimaryColor\"\n    [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-skeleton.component.js","sourceRoot":"","sources":["../../../../src/table/table-skeleton.component.ts","../../../../src/table/table-skeleton.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAClF,OAAO,EAEH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,KAAK,EACL,SAAS,EACT,iBAAiB,EACjB,gBAAgB,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAE9E,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,0BAA0B,EAAE,MAAM,SAAS,CAAC;;AAGrD,MAAM,YAAY,GAAG,CAAC,CAAC;AAEvB;;;GAGG;AAYH,MAAM,OAAO,gBAAgB;IA+CzB;;OAEG;IACH,IACI,WAAW,CAAC,KAAsB;QAClC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC;IACnD,CAAC;IA4BD;;;OAGG;IACH,IAAa,UAAU,CAAC,OAAiC;QACrD,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YAC5B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QAC3B,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;QAC5C,CAAC;IACL,CAAC;IAgBD,IAAI,aAAa;QACb,OAAO;YACH,KAAK,EAAE,IAAI;YACX,gBAAgB,EAAE,IAAI,CAAC,QAAQ,KAAK,UAAU;YAC9C,aAAa,EAAE,IAAI,CAAC,QAAQ,KAAK,OAAO;YACxC,CAAC,SAAS,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO;SAC5C,CAAC;IACN,CAAC;IAuBM,SAAS,CAAC,KAAa;QAC1B,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QA7H1C;;WAEG;QAGH,iBAAY,GAAoB,MAAM,CAAC;QAEvC;;;WAGG;QAEH,gBAAW,GAAY,IAAI,CAAC;QAiB5B,aAAQ,GAAa,EAAE,CAAC;QAUxB;;;WAGG;QACqC,gBAAW,GAAG,KAAK,CAAC;QAE5D;;;WAGG;QACM,aAAQ,GAAkB,SAAS,CAAC;QAE7C;;;;WAIG;QACM,YAAO,GAAiB,IAAI,CAAC;QAqB/B,gBAAW,GAAG,MAAM,CAAC;QAErB,eAAU,GAAG,MAAM,CAAC;QAEpB,kBAAa,GAAG,MAAM,CAAC;QAEvB,eAAU,GAAG,MAAM,CAAC;QAEpB,eAAU,GAAG,0BAA0B,CAAC;QAExC,uBAAkB,GAErB,EAAE,CAAC;QAWC,mBAAc,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAa,EAAE,EAAE;YACtF,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;gBACd,OAAO;oBACH,KAAK,EAAE,KAAK;oBACZ,IAAI,EAAE,0BAA0B,CAAC,KAAK;iBACzC,CAAC;YACN,CAAC;iBAAM,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;gBACrB,OAAO;oBACH,KAAK,EAAE,KAAK;oBACZ,IAAI,EAAE,0BAA0B,CAAC,MAAM;iBAC1C,CAAC;YACN,CAAC;iBAAM,CAAC;gBACJ,OAAO;oBACH,KAAK,EAAE,MAAM;oBACb,IAAI,EAAE,0BAA0B,CAAC,OAAO;iBAC3C,CAAC;YACN,CAAC;QACL,CAAC,CAAC,CAAC;QAEI,YAAO,GAA6B,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;IAMvB,CAAC;IAE9C,eAAe;QACX,IAAI,CAAC,kBAAkB,GAAG;YACtB,CAAC,0BAA0B,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,aAAa;YACtD,CAAC,0BAA0B,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,cAAc;YACxD,CAAC,0BAA0B,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,gBAAgB;SAC/D,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;8GAtJQ,gBAAgB;kGAAhB,gBAAgB,8KA2BL,gBAAgB,mMAgChB,gBAAgB,4kBC/FxC,g5GA+FA,4CD7Dc,KAAK,mHAAE,OAAO,oFAAE,IAAI,6FAAE,OAAO,2EAAoB,sBAAsB,+GAAE,oBAAoB,6MAAE,iBAAiB;;AAgB1H;IADC,aAAa,EAAE;;yDACiB;AAOjC;IADC,aAAa,EAAE;;sDACuB;AA0DvC;IADC,aAAa,EAAE;;qDACa;2FA/EpB,gBAAgB;kBAX5B,SAAS;+BACI,oBAAoB,QAExB;wBACF,KAAK,EAAE,oBAAoB;qBAC9B,mBACgB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,cACzB,IAAI,WACP,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,oBAAoB,EAAE,iBAAiB,CAAC;sFAG/F,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBAEG,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB;gBAEG,eAAe;sBAA5C,SAAS;uBAAC,iBAAiB;gBAEG,gBAAgB;sBAA9C,SAAS;uBAAC,kBAAkB;gBAO7B,eAAe;sBAFd,KAAK;gBASN,YAAY;sBAFX,KAAK;gBASN,WAAW;sBADV,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAM7B,mBAAmB;sBAA3B,KAAK;gBAKG,eAAe;sBAAvB,KAAK;gBAKG,iBAAiB;sBAAzB,KAAK;gBAQF,WAAW;sBADd,KAAK;gBASkC,WAAW;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAM7B,QAAQ;sBAAhB,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBAON,WAAW;sBAFV,KAAK;gBAQO,UAAU;sBAAtB,KAAK","sourcesContent":["import { NgClass, NgFor, NgIf, NgStyle, NgTemplateOutlet } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Input,\n    ViewChild,\n    ViewEncapsulation,\n    booleanAttribute\n} from '@angular/core';\nimport { InputCssPixel } from 'ngx-tethys/core';\nimport { ThySkeletonCircle, ThySkeletonRectangle } from 'ngx-tethys/skeleton';\nimport { ThyTableSkeletonColumn } from './table.interface';\nimport { ThyViewOutletDirective } from 'ngx-tethys/shared';\nimport { ThyTableColumnSkeletonType } from './enums';\nimport { ThyTableSize, ThyTableTheme } from './table.component';\n\nconst COLUMN_COUNT = 5;\n\n/**\n * 表格的骨架屏组件\n * @name thy-table-skeleton\n */\n@Component({\n    selector: 'thy-table-skeleton',\n    templateUrl: './table-skeleton.component.html',\n    host: {\n        class: 'thy-table-skeleton'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [NgFor, NgClass, NgIf, NgStyle, NgTemplateOutlet, ThyViewOutletDirective, ThySkeletonRectangle, ThySkeletonCircle]\n})\nexport class ThyTableSkeleton implements AfterViewInit {\n    @ViewChild('titleTemplate') titleTemplate: ElementRef<HTMLElement>;\n\n    @ViewChild('memberTemplate') memberTemplate: ElementRef<HTMLElement>;\n\n    @ViewChild('defaultTemplate') defaultTemplate: ElementRef<HTMLElement>;\n\n    @ViewChild('checkboxTemplate') checkboxTemplate: ElementRef<HTMLElement>;\n\n    /**\n     * 骨架边框圆角\n     */\n    @Input()\n    @InputCssPixel()\n    thyBorderRadius: string | number;\n\n    /**\n     * 表格内容骨架高度\n     */\n    @Input()\n    @InputCssPixel()\n    thyRowHeight: string | number = '20px';\n\n    /**\n     * 是否开启动画\n     * @default true\n     */\n    @Input({ transform: booleanAttribute })\n    thyAnimated: boolean = true;\n\n    /**\n     * 动画速度\n     */\n    @Input() thyAnimatedInterval: string;\n\n    /**\n     * 骨架主色\n     */\n    @Input() thyPrimaryColor: string;\n\n    /**\n     * 骨架次色\n     */\n    @Input() thySecondaryColor: string;\n\n    rowCount: number[] = [];\n\n    /**\n     * 行数\n     */\n    @Input()\n    set thyRowCount(value: number | string) {\n        this.rowCount = Array.from({ length: +value });\n    }\n\n    /**\n     * 是否展示骨架头\n     * @default false\n     */\n    @Input({ transform: booleanAttribute }) thyHeadless = false;\n\n    /**\n     * 骨架屏的风格\n     * @type default | bordered | boxed\n     */\n    @Input() thyTheme: ThyTableTheme = 'default';\n\n    /**\n     * 骨架屏的大小\n     * @type xs | sm | md | lg | xlg | default\n     * @default md\n     */\n    @Input() thySize: ThyTableSize = 'md';\n\n    /**\n     * 设置表格最小宽度\n     */\n    @Input()\n    @InputCssPixel()\n    thyMinWidth: string | number;\n\n    /**\n     * 表格列骨架的配置项，支持配置列宽、骨架类型\n     * @type ThyTableSkeletonColumn[]\n     */\n    @Input() set thyColumns(columns: ThyTableSkeletonColumn[]) {\n        if (columns && columns.length) {\n            this.columns = columns;\n        } else {\n            this.columns = [...this.defaultColumns];\n        }\n    }\n\n    public titleHeight = '20px';\n\n    public titleWidth = '50px';\n\n    public checkboxWidth = '20px';\n\n    public avatarSize = '24px';\n\n    public columnType = ThyTableColumnSkeletonType;\n\n    public skeletonColumnsMap: {\n        [key: string]: ElementRef<HTMLElement>;\n    } = {};\n\n    get tableClassMap() {\n        return {\n            table: true,\n            'table-bordered': this.thyTheme === 'bordered',\n            'table-boxed': this.thyTheme === 'boxed',\n            [`table-${this.thySize}`]: !!this.thySize\n        };\n    }\n\n    private defaultColumns = Array.from({ length: COLUMN_COUNT }).map((item, index: number) => {\n        if (index === 0) {\n            return {\n                width: '40%',\n                type: ThyTableColumnSkeletonType.title\n            };\n        } else if (index === 1) {\n            return {\n                width: '17%',\n                type: ThyTableColumnSkeletonType.member\n            };\n        } else {\n            return {\n                width: 'auto',\n                type: ThyTableColumnSkeletonType.default\n            };\n        }\n    });\n\n    public columns: ThyTableSkeletonColumn[] = [...this.defaultColumns];\n\n    public trackByFn(index: number) {\n        return index;\n    }\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngAfterViewInit(): void {\n        this.skeletonColumnsMap = {\n            [ThyTableColumnSkeletonType.title]: this.titleTemplate,\n            [ThyTableColumnSkeletonType.member]: this.memberTemplate,\n            [ThyTableColumnSkeletonType.checkbox]: this.checkboxTemplate\n        };\n        this.cdr.detectChanges();\n    }\n}\n","<table [ngClass]=\"tableClassMap\" [ngStyle]=\"{ 'min-width': thyMinWidth }\">\n  <colgroup>\n    <col *ngFor=\"let column of columns; trackBy: trackByFn\" [width]=\"column.width\" />\n  </colgroup>\n  <ng-container *ngIf=\"!thyHeadless\">\n    <thead>\n      <tr>\n        <th *ngFor=\"let column of columns; trackBy: trackByFn\">\n          <thy-skeleton-rectangle\n            [thyRowWidth]=\"column?.type === columnType.checkbox ? checkboxWidth : titleWidth\"\n            [thyRowHeight]=\"titleHeight\"\n            [thyBorderRadius]=\"thyBorderRadius\"\n            [thyAnimated]=\"thyAnimated\"\n            [thyAnimatedInterval]=\"thyAnimatedInterval\"\n            [thyPrimaryColor]=\"thyTheme === 'bordered' || thyTheme === 'boxed' ? '#eee' : thyPrimaryColor\"\n            [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n        </th>\n      </tr>\n    </thead>\n  </ng-container>\n  <tbody>\n    <ng-container *ngFor=\"let item of rowCount; let i = index\">\n      <tr>\n        <ng-container *ngFor=\"let column of columns; trackBy: trackByFn\">\n          <td>\n            <ng-container\n              *thyViewOutlet=\"\n              skeletonColumnsMap[column.type] || defaultTemplate\n              context:{\n                  trIndex: i,\n              }\n            \">\n            </ng-container>\n          </td>\n        </ng-container>\n      </tr>\n    </ng-container>\n  </tbody>\n</table>\n\n<ng-template #titleTemplate let-trIndex=\"trIndex\">\n  <div class=\"d-flex align-items-center\">\n    <thy-skeleton-rectangle\n      class=\"mr-2 flex-shrink-0\"\n      [thyRowWidth]=\"checkboxWidth\"\n      [thyRowHeight]=\"thyRowHeight\"\n      [thyBorderRadius]=\"thyBorderRadius\"\n      [thyAnimated]=\"thyAnimated\"\n      [thyAnimatedInterval]=\"thyAnimatedInterval\"\n      [thyPrimaryColor]=\"thyPrimaryColor\"\n      [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n\n    <ng-container\n      *thyViewOutlet=\"defaultTemplate;\n      context:{\n        rowWidth: trIndex % 3 === 0 ? '75%' : trIndex % 3 === 1 ? '100%' : trIndex % 3 === 2 ? '65%' : '',\n      }\"></ng-container>\n  </div>\n</ng-template>\n\n<ng-template #checkboxTemplate>\n  <thy-skeleton-rectangle\n    [thyRowWidth]=\"checkboxWidth\"\n    [thyRowHeight]=\"thyRowHeight\"\n    [thyBorderRadius]=\"thyBorderRadius\"\n    [thyAnimated]=\"thyAnimated\"\n    [thyAnimatedInterval]=\"thyAnimatedInterval\"\n    [thyPrimaryColor]=\"thyPrimaryColor\"\n    [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n\n<ng-template #memberTemplate>\n  <div class=\"d-flex align-items-center\">\n    <thy-skeleton-circle\n      class=\"mr-2 flex-shrink-0\"\n      [thySize]=\"avatarSize\"\n      [thyAnimated]=\"thyAnimated\"\n      [thyAnimatedInterval]=\"thyAnimatedInterval\"\n      [thyPrimaryColor]=\"thyPrimaryColor\"\n      [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-circle>\n\n    <ng-container *thyViewOutlet=\"defaultTemplate\"></ng-container>\n  </div>\n</ng-template>\n\n<ng-template #defaultTemplate let-rowWidth=\"rowWidth\">\n  <thy-skeleton-rectangle\n    [thyRowWidth]=\"rowWidth\"\n    [thyRowHeight]=\"thyRowHeight\"\n    [thyBorderRadius]=\"thyBorderRadius\"\n    [thyAnimated]=\"thyAnimated\"\n    [thyAnimatedInterval]=\"thyAnimatedInterval\"\n    [thyPrimaryColor]=\"thyPrimaryColor\"\n    [thySecondaryColor]=\"thySecondaryColor\"></thy-skeleton-rectangle>\n</ng-template>\n"]}
|