@one-paragon/angular-utilities 0.1.1 → 0.1.2
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/esm2020/table-builder/components/column-builder/column-builder.component.mjs +23 -9
- package/esm2020/table-builder/components/initialization-component/initialization-component.mjs +8 -20
- package/esm2020/table-builder/interfaces/report-def.mjs +1 -1
- package/esm2020/table-builder/services/table-template-service.mjs +5 -5
- package/esm2020/table-builder/services/transform-creator.mjs +27 -10
- package/esm2020/utilities/directives/conditional-classes.directive.mjs +36 -0
- package/esm2020/utilities/index.mjs +2 -1
- package/esm2020/utilities/module.mjs +8 -3
- package/fesm2015/one-paragon-angular-utilities.mjs +739 -690
- package/fesm2015/one-paragon-angular-utilities.mjs.map +1 -1
- package/fesm2020/one-paragon-angular-utilities.mjs +744 -689
- package/fesm2020/one-paragon-angular-utilities.mjs.map +1 -1
- package/package.json +1 -1
- package/table-builder/components/column-builder/column-builder.component.d.ts +3 -1
- package/table-builder/components/initialization-component/initialization-component.d.ts +0 -5
- package/table-builder/interfaces/report-def.d.ts +4 -1
- package/table-builder/services/transform-creator.d.ts +3 -1
- package/utilities/directives/conditional-classes.directive.d.ts +14 -0
- package/utilities/index.d.ts +1 -0
- package/utilities/module.d.ts +2 -1
|
@@ -12,12 +12,14 @@ import * as i4 from "../../services/table-template-service";
|
|
|
12
12
|
import * as i5 from "@angular/material/sort";
|
|
13
13
|
import * as i6 from "../header-menu/header-menu.component";
|
|
14
14
|
import * as i7 from "@ngrx/component";
|
|
15
|
-
import * as i8 from "
|
|
16
|
-
import * as i9 from "
|
|
17
|
-
import * as i10 from "
|
|
18
|
-
import * as i11 from "
|
|
19
|
-
import * as i12 from "
|
|
20
|
-
import * as i13 from "../../
|
|
15
|
+
import * as i8 from "@angular/material/tooltip";
|
|
16
|
+
import * as i9 from "../../../utilities/directives/conditional-classes.directive";
|
|
17
|
+
import * as i10 from "../../../utilities/directives/styler";
|
|
18
|
+
import * as i11 from "@angular/common";
|
|
19
|
+
import * as i12 from "@angular/cdk/drag-drop";
|
|
20
|
+
import * as i13 from "../../directives/resize-column.directive";
|
|
21
|
+
import * as i14 from "../../../utilities/pipes/space-case.pipes";
|
|
22
|
+
import * as i15 from "../../pipes/column-total.pipe";
|
|
21
23
|
export class ColumnBuilderComponent {
|
|
22
24
|
constructor(transformCreator, table, state, templateService) {
|
|
23
25
|
this.transformCreator = transformCreator;
|
|
@@ -49,6 +51,18 @@ export class ColumnBuilderComponent {
|
|
|
49
51
|
return this.customCell?.columnDef?.cell?.template ?? this.bodyTemplate;
|
|
50
52
|
}
|
|
51
53
|
ngOnInit() {
|
|
54
|
+
if (this.metaData.fieldType === FieldType.Currency) {
|
|
55
|
+
this.classes = {
|
|
56
|
+
['negative-currency']: (element) => element[this.metaData.key] < 0,
|
|
57
|
+
...this.metaData.classes
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
this.classes = this.metaData.classes;
|
|
62
|
+
}
|
|
63
|
+
if (this.metaData.fieldType === FieldType.Boolean) {
|
|
64
|
+
this.metaData = { ...this.metaData, useIcon: true };
|
|
65
|
+
}
|
|
52
66
|
this.filter = { key: this.metaData.key, fieldType: this.metaData.fieldType };
|
|
53
67
|
const width$ = this.state.getUserDefinedWidth$(this.metaData.key).pipe(previousAndCurrent(0), map(this.mapWidth));
|
|
54
68
|
const fullMetaStyles = this.metaData.additional?.styles ?? {};
|
|
@@ -75,14 +89,14 @@ export class ColumnBuilderComponent {
|
|
|
75
89
|
}
|
|
76
90
|
}
|
|
77
91
|
ColumnBuilderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: ColumnBuilderComponent, deps: [{ token: i1.TransformCreator }, { token: i2.MatTable }, { token: i3.TableStore }, { token: i4.TableTemplateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
78
|
-
ColumnBuilderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: ColumnBuilderComponent, selector: "tb-column-builder", inputs: { metaData: "metaData", customCell: "customCell", data$: "data$" }, viewQueries: [{ propertyName: "columnDef", first: true, predicate: MatColumnDef, descendants: true }, { propertyName: "bodyTemplate", first: true, predicate: ["body"], descendants: true }], ngImport: i0, template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\">\n\n <ng-template #body let-element='element' >\n
|
|
92
|
+
ColumnBuilderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: ColumnBuilderComponent, selector: "tb-column-builder", inputs: { metaData: "metaData", customCell: "customCell", data$: "data$" }, viewQueries: [{ propertyName: "columnDef", first: true, predicate: MatColumnDef, descendants: true }, { propertyName: "bodyTemplate", first: true, predicate: ["body"], descendants: true }], ngImport: i0, template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\" >\n\n <ng-template #body let-element='element' >\n <mat-cell [matTooltip]=\"metaData.toolTip ?? ''\" [conditionalClasses]='metaData.classes' [element]='element' [styler]='styles.body' [class.group-footer]=\"element.isGroupFooter\" (click)='cellClicked(element, metaData.key)' >\n <ng-container *ngTemplateOutlet=\"innerTemplate;context: {metaData: metaData, element: element, transform: transform }\">\n </ng-container>\n <span class=\"no-val\" *ngIf=\"\n !element.isGroupFooter &&\n metaData.fieldType !== FieldType.Expression &&\n (element[metaData.key] == null) &&\n !((customCell && customCell.TemplateRef) || metaData.template)\n \"> - </span>\n </mat-cell>\n\n </ng-template>\n\n <ng-template matHeaderCellDef #myHeader>\n\n <ng-container *ngIf=\"customCell?.columnDef?.headerCell;else header;\">\n <ng-container *ngTemplateOutlet=\"customCell.columnDef.headerCell.template; context: {metaData: metaData, styles: styles.header} \">\n </ng-container>\n </ng-container>\n\n <ng-template #header>\n\n <mat-header-cell cdkDrag [styler]='styles.header' [resizeColumn]=\"true\" [key]=\"metaData.key\" class=\"column-head drag-header\" #headref >\n <div class=\"header-container\" cdkDragHandle>\n <div *ngIf=\"!metaData._internalNotUserDefined || !customCell?.columnDef?.cell ; else headerWithoutMenu\" mat-sort-header style=\"width: 100%\">\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\n </div>\n <ng-template #headerWithoutMenu >\n <div *ngIf=\"metaData._internalNotUserDefined;\" style=\"width: 100%\">\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\n </div>\n </ng-template>\n <tb-header-menu\n *ngIf=\"(!metaData._internalNotUserDefined || !customCell?.columnDef?.cell) && (showfilters$ | async);\" #menu [metaData]='metaData' [filter]='filter' >\n </tb-header-menu>\n </div>\n </mat-header-cell>\n\n </ng-template>\n\n </ng-template>\n\n\n <ng-container *matCellDef=\"let element;\">\n <ng-container *ngTemplateOutlet=\"outerTemplate; context: {metaData: metaData, element: element , styles: styles.body }\">\n </ng-container>\n </ng-container>\n\n <ng-template matFooterCellDef>\n <ng-container *ngIf=\"customCell?.columnDef?.footerCell;else footer\">\n <ng-container\n *ngTemplateOutlet=\"customCell.columnDef.footerCell.template;context: {metaData: metaData, data: data$, styles : styles.footer }\">\n </ng-container>\n </ng-container>\n\n <ng-template #footer>\n <mat-footer-cell [styler]='styles.footer' *ngrxLet=\"data$ as data\">\n <span *ngIf=\"data?.length && metaData.additional?.footer\" [ngSwitch]=\"metaData.fieldType\" class=\"bold\">\n <span *ngSwitchCase=\"FieldType.Currency\">\n {{ data | columnTotal: metaData | currency }}\n </span>\n <span *ngSwitchCase=\"FieldType.Number\">\n {{ data | columnTotal: metaData | number }}\n </span>\n </span>\n </mat-footer-cell>\n </ng-template>\n </ng-template>\n</ng-container>\n", styles: [".header-container{display:flex;flex-direction:row;width:100%;align-items:center}.negative-currency{color:red}.column-head{position:relative}.bold,.group-footer{font-weight:900}.cdk-drag-preview{background:white;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:33%;border-right-width:0px}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.drag-handle{color:#add8e6;cursor:move;margin-right:9px}\n"], components: [{ type: i5.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { type: i6.HeaderMenuComponent, selector: "tb-header-menu", inputs: ["filter", "metaData"] }], directives: [{ type: i7.LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet"] }, { type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i8.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i9.ConditionalClassesDirective, selector: "[conditionalClasses]", inputs: ["element", "conditionalClasses"] }, { type: i10.StylerDirective, selector: "[styler]", inputs: ["styler"] }, { type: i11.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i12.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { type: i13.ResizeColumnDirective, selector: "[resizeColumn]", inputs: ["resizeColumn", "key"] }, { type: i12.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { type: i2.MatCellDef, selector: "[matCellDef]" }, { type: i2.MatFooterCellDef, selector: "[matFooterCellDef]" }, { type: i2.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { type: i11.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i11.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "spaceCase": i14.SpaceCasePipe, "async": i11.AsyncPipe, "currency": i11.CurrencyPipe, "columnTotal": i15.ColumnTotalPipe, "number": i11.DecimalPipe }, viewProviders: [
|
|
79
93
|
{ provide: CDK_DROP_LIST, useExisting: CdkDropList },
|
|
80
94
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
81
95
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: ColumnBuilderComponent, decorators: [{
|
|
82
96
|
type: Component,
|
|
83
97
|
args: [{ selector: 'tb-column-builder', changeDetection: ChangeDetectionStrategy.OnPush, viewProviders: [
|
|
84
98
|
{ provide: CDK_DROP_LIST, useExisting: CdkDropList },
|
|
85
|
-
], template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\">\n\n <ng-template #body let-element='element' >\n
|
|
99
|
+
], template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\" >\n\n <ng-template #body let-element='element' >\n <mat-cell [matTooltip]=\"metaData.toolTip ?? ''\" [conditionalClasses]='metaData.classes' [element]='element' [styler]='styles.body' [class.group-footer]=\"element.isGroupFooter\" (click)='cellClicked(element, metaData.key)' >\n <ng-container *ngTemplateOutlet=\"innerTemplate;context: {metaData: metaData, element: element, transform: transform }\">\n </ng-container>\n <span class=\"no-val\" *ngIf=\"\n !element.isGroupFooter &&\n metaData.fieldType !== FieldType.Expression &&\n (element[metaData.key] == null) &&\n !((customCell && customCell.TemplateRef) || metaData.template)\n \"> - </span>\n </mat-cell>\n\n </ng-template>\n\n <ng-template matHeaderCellDef #myHeader>\n\n <ng-container *ngIf=\"customCell?.columnDef?.headerCell;else header;\">\n <ng-container *ngTemplateOutlet=\"customCell.columnDef.headerCell.template; context: {metaData: metaData, styles: styles.header} \">\n </ng-container>\n </ng-container>\n\n <ng-template #header>\n\n <mat-header-cell cdkDrag [styler]='styles.header' [resizeColumn]=\"true\" [key]=\"metaData.key\" class=\"column-head drag-header\" #headref >\n <div class=\"header-container\" cdkDragHandle>\n <div *ngIf=\"!metaData._internalNotUserDefined || !customCell?.columnDef?.cell ; else headerWithoutMenu\" mat-sort-header style=\"width: 100%\">\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\n </div>\n <ng-template #headerWithoutMenu >\n <div *ngIf=\"metaData._internalNotUserDefined;\" style=\"width: 100%\">\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\n </div>\n </ng-template>\n <tb-header-menu\n *ngIf=\"(!metaData._internalNotUserDefined || !customCell?.columnDef?.cell) && (showfilters$ | async);\" #menu [metaData]='metaData' [filter]='filter' >\n </tb-header-menu>\n </div>\n </mat-header-cell>\n\n </ng-template>\n\n </ng-template>\n\n\n <ng-container *matCellDef=\"let element;\">\n <ng-container *ngTemplateOutlet=\"outerTemplate; context: {metaData: metaData, element: element , styles: styles.body }\">\n </ng-container>\n </ng-container>\n\n <ng-template matFooterCellDef>\n <ng-container *ngIf=\"customCell?.columnDef?.footerCell;else footer\">\n <ng-container\n *ngTemplateOutlet=\"customCell.columnDef.footerCell.template;context: {metaData: metaData, data: data$, styles : styles.footer }\">\n </ng-container>\n </ng-container>\n\n <ng-template #footer>\n <mat-footer-cell [styler]='styles.footer' *ngrxLet=\"data$ as data\">\n <span *ngIf=\"data?.length && metaData.additional?.footer\" [ngSwitch]=\"metaData.fieldType\" class=\"bold\">\n <span *ngSwitchCase=\"FieldType.Currency\">\n {{ data | columnTotal: metaData | currency }}\n </span>\n <span *ngSwitchCase=\"FieldType.Number\">\n {{ data | columnTotal: metaData | number }}\n </span>\n </span>\n </mat-footer-cell>\n </ng-template>\n </ng-template>\n</ng-container>\n", styles: [".header-container{display:flex;flex-direction:row;width:100%;align-items:center}.negative-currency{color:red}.column-head{position:relative}.bold,.group-footer{font-weight:900}.cdk-drag-preview{background:white;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:33%;border-right-width:0px}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.drag-handle{color:#add8e6;cursor:move;margin-right:9px}\n"] }]
|
|
86
100
|
}], ctorParameters: function () { return [{ type: i1.TransformCreator }, { type: i2.MatTable }, { type: i3.TableStore }, { type: i4.TableTemplateService }]; }, propDecorators: { metaData: [{
|
|
87
101
|
type: Input
|
|
88
102
|
}], customCell: [{
|
|
@@ -96,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
|
|
|
96
110
|
type: ViewChild,
|
|
97
111
|
args: ['body']
|
|
98
112
|
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-builder.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ChangeDetectionStrategy, TemplateRef, ViewChild, OnInit, HostBinding, ContentChild, ContentChildren } from '@angular/core';\nimport { FieldType, MetaData } from '../../interfaces/report-def';\nimport { MatColumnDef, MatTable } from '@angular/material/table';\nimport { Observable } from 'rxjs';\nimport { CustomCellDirective } from '../../directives';\nimport { FilterInfo } from '../../classes/filter-info';\nimport { TransformCreator } from '../../services/transform-creator';\nimport { TableStore } from '../../classes/table-store';\nimport { map } from 'rxjs/operators';\nimport { TableTemplateService } from '../../services/table-template-service';\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\nimport { CdkDropList, CDK_DROP_LIST } from '@angular/cdk/drag-drop';\n\n\ninterface widthStyle {\n    flex?: string;\n    maxWidth?: string;\n}\n\ninterface allStyles {\n  body: widthStyle;\n  header: widthStyle;\n  footer: widthStyle;\n}\n\n@Component({\n  selector: 'tb-column-builder',\n  templateUrl: './column-builder.component.html',\n  styleUrls: ['./column-builder.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  viewProviders: [\n    { provide: CDK_DROP_LIST, useExisting: CdkDropList },\n  ]\n})\nexport class ColumnBuilderComponent implements OnInit {\n  FieldType = FieldType;\n  filter!: Partial<FilterInfo>;\n  @Input() metaData!: MetaData\n  @Input() customCell!: CustomCellDirective;\n  @Input() data$!: Observable<any[]>;\n\n  @ViewChild(MatColumnDef) columnDef!: MatColumnDef;\n  outerTemplate!: TemplateRef<any>;\n  innerTemplate!: TemplateRef<any>;\n  transform!: (o: any, ...args: any[])=> any ;\n\n  @ViewChild('body') bodyTemplate!: TemplateRef<any>;\n\n\n  constructor(\n    private transformCreator: TransformCreator,\n    private table: MatTable<any>,\n    public state: TableStore,\n    private templateService: TableTemplateService,\n    ) { }\n\n  getInnerTemplate() :TemplateRef<any> {\n    if(this.metaData.template) return this.metaData.template;\n    if (this.customCell?.TemplateRef)  return this.customCell.TemplateRef;\n    return this.templateService.getTemplate(this.metaData.fieldType);\n  }\n  showfilters$!: Observable<boolean>;\n  getOuterTemplate() {\n    return this.customCell?.columnDef?.cell?.template ?? this.bodyTemplate;\n  }\n\n  ngOnInit() {\n    this.filter = {key: this.metaData.key, fieldType: this.metaData.fieldType};\n    const width$ = this.state.getUserDefinedWidth$(this.metaData.key).pipe(\n      previousAndCurrent(0),\n      map(this.mapWidth),\n    );\n    const fullMetaStyles = this.metaData.additional?.styles ?? {};\n    this.styles$ = width$.pipe(map(width => {\n      const styles: allStyles = {\n        header : {...fullMetaStyles,...this.metaData.additional?.columnPartStyles?.header, ...width},\n        footer: {...fullMetaStyles,...this.metaData.additional?.columnPartStyles?.footer, ...width},\n        body: {...fullMetaStyles,...this.metaData.additional?.columnPartStyles?.body, ...width},\n      };\n      return styles;\n    }));\n    this.showfilters$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeaderFilters || this.metaData.noFilter)));\n  }\n\n  ngAfterViewInit() {\n    this.outerTemplate = this.getOuterTemplate();\n    this.innerTemplate = this.getInnerTemplate();\n    this.transform = this.transformCreator.createTransformer(this.metaData);\n    this.table.addColumnDef(this.columnDef);\n  }\n\n  cellClicked(element: any, key: string) {\n    if(this.metaData.click) {\n      this.metaData.click(element,key);\n    }\n  }\n\n  mapWidth = ([previousUserDefinedWidth, currentUserDefinedWidth] : [number, number]) : widthStyle => {\n\n    if( currentUserDefinedWidth ){\n      return ({flex:`0 0 ${currentUserDefinedWidth}px`, maxWidth:'none'});\n    } if( wasReset() ){\n      return ({flex:'1'});\n    }\n    return ({});\n    function wasReset(){\n      return previousUserDefinedWidth >=0 && currentUserDefinedWidth == null;\n    }\n  }\n\n  styles$!:Observable<allStyles>\n\n}\n","<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\">\n\n  <ng-template #body let-element='element' >\n\n      <mat-cell [styler]='styles.body' [class.group-footer]=\"element.isGroupFooter\" (click)='cellClicked(element, metaData.key)'>\n        <ng-container *ngTemplateOutlet=\"innerTemplate;context: {metaData: metaData, element: element, transform: transform }\">\n        </ng-container>\n      <span class=\"no-val\" *ngIf=\"\n        !element.isGroupFooter &&\n        metaData.fieldType !== FieldType.Expression &&\n        (element[metaData.key] == null) &&\n        !((customCell && customCell.TemplateRef) || metaData.template)\n      \"> - </span>\n    </mat-cell>\n\n  </ng-template>\n\n  <ng-template matHeaderCellDef #myHeader>\n\n    <ng-container *ngIf=\"customCell?.columnDef?.headerCell;else header;\">\n      <ng-container *ngTemplateOutlet=\"customCell.columnDef.headerCell.template; context: {metaData: metaData, styles:  styles.header} \">\n      </ng-container>\n    </ng-container>\n\n    <ng-template #header>\n\n      <mat-header-cell  cdkDrag [styler]='styles.header' [resizeColumn]=\"true\" [key]=\"metaData.key\"   class=\"column-head drag-header\" #headref >\n        <div class=\"header-container\" cdkDragHandle>\n          <div *ngIf=\"!metaData._internalNotUserDefined || !customCell?.columnDef?.cell ; else headerWithoutMenu\" mat-sort-header style=\"width: 100%\">\n            {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\n          </div>\n          <ng-template #headerWithoutMenu >\n            <div *ngIf=\"metaData._internalNotUserDefined;\" style=\"width: 100%\">\n              {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\n            </div>\n          </ng-template>\n          <tb-header-menu \n            *ngIf=\"(!metaData._internalNotUserDefined || !customCell?.columnDef?.cell) && (showfilters$ | async);\" #menu [metaData]='metaData' [filter]='filter' >\n          </tb-header-menu>\n        </div>\n      </mat-header-cell>\n\n    </ng-template>\n\n  </ng-template>\n\n\n  <ng-container *matCellDef=\"let element;\">\n    <ng-container *ngTemplateOutlet=\"outerTemplate; context: {metaData: metaData, element: element , styles: styles.body }\">\n    </ng-container>\n  </ng-container>\n\n  <ng-template matFooterCellDef>\n    <ng-container *ngIf=\"customCell?.columnDef?.footerCell;else footer\">\n      <ng-container\n        *ngTemplateOutlet=\"customCell.columnDef.footerCell.template;context: {metaData: metaData, data: data$, styles : styles.footer }\">\n      </ng-container>\n    </ng-container>\n\n    <ng-template #footer>\n      <mat-footer-cell  [styler]='styles.footer' *ngrxLet=\"data$ as data\">\n        <span *ngIf=\"data?.length && metaData.additional?.footer\" [ngSwitch]=\"metaData.fieldType\" class=\"bold\">\n          <span *ngSwitchCase=\"FieldType.Currency\">\n            {{ data | columnTotal: metaData | currency }}\n          </span>\n          <span *ngSwitchCase=\"FieldType.Number\">\n            {{ data | columnTotal: metaData | number }}\n          </span>\n        </span>\n      </mat-footer-cell>\n    </ng-template>\n  </ng-template>\n</ng-container>"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-builder.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/column-builder/column-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ChangeDetectionStrategy, TemplateRef, ViewChild, OnInit, HostBinding, ContentChild, ContentChildren, Predicate } from '@angular/core';\nimport { FieldType, MetaData } from '../../interfaces/report-def';\nimport { MatColumnDef, MatTable } from '@angular/material/table';\nimport { Observable } from 'rxjs';\nimport { CustomCellDirective } from '../../directives';\nimport { FilterInfo } from '../../classes/filter-info';\nimport { TransformCreator } from '../../services/transform-creator';\nimport { TableStore } from '../../classes/table-store';\nimport { map } from 'rxjs/operators';\nimport { TableTemplateService } from '../../services/table-template-service';\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\nimport { CdkDropList, CDK_DROP_LIST } from '@angular/cdk/drag-drop';\nimport { Dictionary } from '@ngrx/entity';\n\n\ninterface widthStyle {\n    flex?: string;\n    maxWidth?: string;\n}\n\ninterface allStyles {\n  body: widthStyle;\n  header: widthStyle;\n  footer: widthStyle;\n}\n\n@Component({\n  selector: 'tb-column-builder',\n  templateUrl: './column-builder.component.html',\n  styleUrls: ['./column-builder.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  viewProviders: [\n    { provide: CDK_DROP_LIST, useExisting: CdkDropList },\n  ]\n})\nexport class ColumnBuilderComponent implements OnInit {\n  FieldType = FieldType;\n  filter!: Partial<FilterInfo>;\n  @Input() metaData!: MetaData\n  @Input() customCell!: CustomCellDirective;\n  @Input() data$!: Observable<any[]>;\n\n  @ViewChild(MatColumnDef) columnDef!: MatColumnDef;\n  outerTemplate!: TemplateRef<any>;\n  innerTemplate!: TemplateRef<any>;\n  transform!: (o: any, ...args: any[])=> any ;\n\n  @ViewChild('body') bodyTemplate!: TemplateRef<any>;\n\n\n  constructor(\n    private transformCreator: TransformCreator,\n    private table: MatTable<any>,\n    public state: TableStore,\n    private templateService: TableTemplateService,\n    ) { }\n\n  getInnerTemplate() :TemplateRef<any> {\n    if(this.metaData.template) return this.metaData.template;\n    if (this.customCell?.TemplateRef)  return this.customCell.TemplateRef;\n    return this.templateService.getTemplate(this.metaData.fieldType);\n  }\n  showfilters$!: Observable<boolean>;\n  getOuterTemplate() {\n    return this.customCell?.columnDef?.cell?.template ?? this.bodyTemplate;\n  }\n  classes?: Dictionary<Predicate<any>>;\n\n  ngOnInit() {\n    if(this.metaData.fieldType === FieldType.Currency) {\n      this.classes = {\n        ['negative-currency']: (element) => element[this.metaData.key] < 0,\n        ...this.metaData.classes\n      }\n    }\n    else {\n      this.classes = this.metaData.classes;\n    }\n\n    if(this.metaData.fieldType === FieldType.Boolean) {\n      this. metaData = {...this.metaData, useIcon: true};\n    }\n\n    this.filter = {key: this.metaData.key, fieldType: this.metaData.fieldType};\n    const width$ = this.state.getUserDefinedWidth$(this.metaData.key).pipe(\n      previousAndCurrent(0),\n      map(this.mapWidth),\n    );\n    const fullMetaStyles = this.metaData.additional?.styles ?? {};\n    this.styles$ = width$.pipe(map(width => {\n      const styles: allStyles = {\n        header : {...fullMetaStyles,...this.metaData.additional?.columnPartStyles?.header, ...width},\n        footer: {...fullMetaStyles,...this.metaData.additional?.columnPartStyles?.footer, ...width},\n        body: {...fullMetaStyles,...this.metaData.additional?.columnPartStyles?.body, ...width},\n      };\n      return styles;\n    }));\n    this.showfilters$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeaderFilters || this.metaData.noFilter)));\n  }\n\n  ngAfterViewInit() {\n    this.outerTemplate = this.getOuterTemplate();\n    this.innerTemplate = this.getInnerTemplate();\n    this.transform = this.transformCreator.createTransformer(this.metaData);\n    this.table.addColumnDef(this.columnDef);\n  }\n\n  cellClicked(element: any, key: string) {\n    if(this.metaData.click) {\n      this.metaData.click(element,key);\n    }\n  }\n\n  mapWidth = ([previousUserDefinedWidth, currentUserDefinedWidth] : [number, number]) : widthStyle => {\n\n    if( currentUserDefinedWidth ){\n      return ({flex:`0 0 ${currentUserDefinedWidth}px`, maxWidth:'none'});\n    } if( wasReset() ){\n      return ({flex:'1'});\n    }\n    return ({});\n    function wasReset(){\n      return previousUserDefinedWidth >=0 && currentUserDefinedWidth == null;\n    }\n  }\n\n  styles$!:Observable<allStyles>\n\n}\n","<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\" >\n\n  <ng-template #body let-element='element' >\n      <mat-cell  [matTooltip]=\"metaData.toolTip ?? ''\"  [conditionalClasses]='metaData.classes' [element]='element' [styler]='styles.body' [class.group-footer]=\"element.isGroupFooter\" (click)='cellClicked(element, metaData.key)' >\n        <ng-container *ngTemplateOutlet=\"innerTemplate;context: {metaData: metaData, element: element, transform: transform }\">\n        </ng-container>\n      <span class=\"no-val\" *ngIf=\"\n        !element.isGroupFooter &&\n        metaData.fieldType !== FieldType.Expression &&\n        (element[metaData.key] == null) &&\n        !((customCell && customCell.TemplateRef) || metaData.template)\n      \"> - </span>\n    </mat-cell>\n\n  </ng-template>\n\n  <ng-template matHeaderCellDef #myHeader>\n\n    <ng-container *ngIf=\"customCell?.columnDef?.headerCell;else header;\">\n      <ng-container *ngTemplateOutlet=\"customCell.columnDef.headerCell.template; context: {metaData: metaData, styles:  styles.header} \">\n      </ng-container>\n    </ng-container>\n\n    <ng-template #header>\n\n      <mat-header-cell  cdkDrag [styler]='styles.header' [resizeColumn]=\"true\" [key]=\"metaData.key\"   class=\"column-head drag-header\" #headref >\n        <div class=\"header-container\" cdkDragHandle>\n          <div *ngIf=\"!metaData._internalNotUserDefined || !customCell?.columnDef?.cell ; else headerWithoutMenu\" mat-sort-header style=\"width: 100%\">\n            {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\n          </div>\n          <ng-template #headerWithoutMenu >\n            <div *ngIf=\"metaData._internalNotUserDefined;\" style=\"width: 100%\">\n              {{ metaData.displayName ?  metaData.displayName : ( metaData.key | spaceCase ) }}\n            </div>\n          </ng-template>\n          <tb-header-menu\n            *ngIf=\"(!metaData._internalNotUserDefined || !customCell?.columnDef?.cell) && (showfilters$ | async);\" #menu [metaData]='metaData' [filter]='filter' >\n          </tb-header-menu>\n        </div>\n      </mat-header-cell>\n\n    </ng-template>\n\n  </ng-template>\n\n\n  <ng-container *matCellDef=\"let element;\">\n    <ng-container *ngTemplateOutlet=\"outerTemplate; context: {metaData: metaData, element: element , styles: styles.body }\">\n    </ng-container>\n  </ng-container>\n\n  <ng-template matFooterCellDef>\n    <ng-container *ngIf=\"customCell?.columnDef?.footerCell;else footer\">\n      <ng-container\n        *ngTemplateOutlet=\"customCell.columnDef.footerCell.template;context: {metaData: metaData, data: data$, styles : styles.footer }\">\n      </ng-container>\n    </ng-container>\n\n    <ng-template #footer>\n      <mat-footer-cell  [styler]='styles.footer' *ngrxLet=\"data$ as data\">\n        <span *ngIf=\"data?.length && metaData.additional?.footer\" [ngSwitch]=\"metaData.fieldType\" class=\"bold\">\n          <span *ngSwitchCase=\"FieldType.Currency\">\n            {{ data | columnTotal: metaData | currency }}\n          </span>\n          <span *ngSwitchCase=\"FieldType.Number\">\n            {{ data | columnTotal: metaData | number }}\n          </span>\n        </span>\n      </mat-footer-cell>\n    </ng-template>\n  </ng-template>\n</ng-container>\n"]}
|
package/esm2020/table-builder/components/initialization-component/initialization-component.mjs
CHANGED
|
@@ -1,16 +1,12 @@
|
|
|
1
1
|
import { Component, ViewChild } from "@angular/core";
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "
|
|
4
|
-
import * as i2 from "
|
|
3
|
+
import * as i1 from "../array-column.component";
|
|
4
|
+
import * as i2 from "@angular/material/icon";
|
|
5
5
|
import * as i3 from "@angular/common";
|
|
6
6
|
import * as i4 from "@angular/router";
|
|
7
7
|
import * as i5 from "../../../utilities/pipes/function.pipe";
|
|
8
|
-
import * as i6 from "../../../utilities/pipes/space-case.pipes";
|
|
9
8
|
export class InitializationComponent {
|
|
10
9
|
constructor() {
|
|
11
|
-
this.forTrueIcon = (metaData) => metaData.additional?.boolean?.forTrue?.icon || 'check';
|
|
12
|
-
this.forFalseIcon = (metaData) => metaData.additional?.boolean?.showForFalse === true ? 'clear'
|
|
13
|
-
: metaData.additional?.boolean?.showForFalse?.icon || null;
|
|
14
10
|
this.useRouterLink = (metaData) => metaData.additional?.link?.useRouterLink || metaData.additional?.useRouterLink;
|
|
15
11
|
this.target = (metaData) => metaData.additional?.link?.target || metaData.additional?.target || '_blank';
|
|
16
12
|
this.key = (metaData, element) => metaData.additional?.link?.urlKey ? element[metaData.additional?.link?.urlKey] :
|
|
@@ -19,7 +15,8 @@ export class InitializationComponent {
|
|
|
19
15
|
const hasRoute = !!metaData.additional?.link?.interpolatedRoute;
|
|
20
16
|
let link = hasRoute ? this.parseInterpolatedRoute((metaData.additional?.link?.interpolatedRoute), element) : (metaData.additional?.link?.base || metaData.additional?.base);
|
|
21
17
|
if (!hasRoute) {
|
|
22
|
-
|
|
18
|
+
var needsSlash = !link?.endsWith('/');
|
|
19
|
+
link += `${needsSlash ? '/' : ''}${this.key(metaData, element)}`;
|
|
23
20
|
}
|
|
24
21
|
return link;
|
|
25
22
|
};
|
|
@@ -27,14 +24,11 @@ export class InitializationComponent {
|
|
|
27
24
|
}
|
|
28
25
|
}
|
|
29
26
|
InitializationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: InitializationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
-
InitializationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: InitializationComponent, selector: "ng-component", viewQueries: [{ propertyName: "
|
|
27
|
+
InitializationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: InitializationComponent, selector: "ng-component", viewQueries: [{ propertyName: "linkTemplate", first: true, predicate: ["link"], descendants: true, static: true }, { propertyName: "imageUrlTemplate", first: true, predicate: ["imageUrl"], descendants: true, static: true }, { propertyName: "currencyTemplate", first: true, predicate: ["currency"], descendants: true, static: true }, { propertyName: "arrayTemplate", first: true, predicate: ["array"], descendants: true, static: true }, { propertyName: "defaultTemplate", first: true, predicate: ["default"], descendants: true, static: true }], ngImport: i0, template: "<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\" [(getLink | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(getLink | func : metaData : element)}}\">\n {{element[metaData.key]}}\n </a>\n </ng-template>\n</ng-template>\n<ng-template #imageUrl let-element='element' let-metaData='metaData'>\n <span>\n <img src=\"{{element[metaData.key]}}\" height=\"75px\" width=\"75px\" />\n </span>\n</ng-template>\n\n<ng-template #array let-element='element' let-metaData='metaData'>\n <tb-array-column [array]='element[metaData.key]' [metaData]='metaData'></tb-array-column>\n</ng-template>\n\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform' >\n <mat-icon *ngIf=\"metaData.useIcon\" >{{ transform | func : element }}</mat-icon>\n <span *ngIf=\"!metaData.useIcon\" >{{ transform | func : element }}</span>\n</ng-template>\n", components: [{ type: i1.ArrayColumnComponent, selector: "tb-array-column", inputs: ["array", "metaData"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }], pipes: { "func": i5.FunctionPipe } });
|
|
31
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: InitializationComponent, decorators: [{
|
|
32
29
|
type: Component,
|
|
33
|
-
args: [{ template: "<ng-template #
|
|
34
|
-
}], propDecorators: {
|
|
35
|
-
type: ViewChild,
|
|
36
|
-
args: ['boolean', { static: true }]
|
|
37
|
-
}], linkTemplate: [{
|
|
30
|
+
args: [{ template: "<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\" [(getLink | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(getLink | func : metaData : element)}}\">\n {{element[metaData.key]}}\n </a>\n </ng-template>\n</ng-template>\n<ng-template #imageUrl let-element='element' let-metaData='metaData'>\n <span>\n <img src=\"{{element[metaData.key]}}\" height=\"75px\" width=\"75px\" />\n </span>\n</ng-template>\n\n<ng-template #array let-element='element' let-metaData='metaData'>\n <tb-array-column [array]='element[metaData.key]' [metaData]='metaData'></tb-array-column>\n</ng-template>\n\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform' >\n <mat-icon *ngIf=\"metaData.useIcon\" >{{ transform | func : element }}</mat-icon>\n <span *ngIf=\"!metaData.useIcon\" >{{ transform | func : element }}</span>\n</ng-template>\n" }]
|
|
31
|
+
}], propDecorators: { linkTemplate: [{
|
|
38
32
|
type: ViewChild,
|
|
39
33
|
args: ['link', { static: true }]
|
|
40
34
|
}], imageUrlTemplate: [{
|
|
@@ -46,14 +40,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
|
|
|
46
40
|
}], arrayTemplate: [{
|
|
47
41
|
type: ViewChild,
|
|
48
42
|
args: ['array', { static: true }]
|
|
49
|
-
}], expressionTemplate: [{
|
|
50
|
-
type: ViewChild,
|
|
51
|
-
args: ['expression', { static: true }]
|
|
52
43
|
}], defaultTemplate: [{
|
|
53
44
|
type: ViewChild,
|
|
54
45
|
args: ['default', { static: true }]
|
|
55
|
-
}], enumTemplate: [{
|
|
56
|
-
type: ViewChild,
|
|
57
|
-
args: ['enum', { static: true }]
|
|
58
46
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5pdGlhbGl6YXRpb24tY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy9pbml0aWFsaXphdGlvbi1jb21wb25lbnQvaW5pdGlhbGl6YXRpb24tY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy9pbml0aWFsaXphdGlvbi1jb21wb25lbnQvaW5pdGlhbGl6YXRpb24tY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBZSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7QUFNbEUsTUFBTSxPQUFPLHVCQUF1QjtJQUhwQztRQVNFLGtCQUFhLEdBQUcsQ0FBQyxRQUFtQixFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxhQUFhLElBQUksUUFBUSxDQUFDLFVBQVUsRUFBRSxhQUFhLENBQUM7UUFDeEgsV0FBTSxHQUFHLENBQUMsUUFBbUIsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsTUFBTSxJQUFJLFFBQVEsQ0FBQyxVQUFVLEVBQUUsTUFBTSxJQUFJLFFBQVEsQ0FBQztRQUV2RyxRQUFHLEdBQUcsQ0FBQyxRQUFtQixFQUFFLE9BQWEsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztZQUNwSSxRQUFRLENBQUMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDNUYsWUFBTyxHQUFHLENBQUMsUUFBbUIsRUFBRSxPQUFhLEVBQUUsRUFBRTtZQUMvQyxNQUFNLFFBQVEsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsaUJBQWlCLENBQUM7WUFDaEUsSUFBSSxJQUFJLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsc0JBQXNCLENBQUMsQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxpQkFBaUIsQ0FBRSxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBRSxDQUFFLFFBQVEsQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLElBQUksSUFBSSxRQUFRLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO1lBQy9LLElBQUcsQ0FBQyxRQUFRLEVBQUM7Z0JBQ1gsSUFBSSxVQUFVLEdBQUcsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUN0QyxJQUFJLElBQUksR0FBRyxVQUFVLENBQUEsQ0FBQyxDQUFBLEdBQUcsQ0FBQSxDQUFDLENBQUEsRUFBRSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxFQUFFLENBQUM7YUFDOUQ7WUFDRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUMsQ0FBQTtRQUNELDJCQUFzQixHQUFHLENBQUUsS0FBYSxFQUFFLE9BQVksRUFBRyxFQUFFLENBQ3pELEtBQUssQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7S0FFekQ7O29IQXZCWSx1QkFBdUI7d0dBQXZCLHVCQUF1QixvbEJDTnBDLDZtQ0EwQkE7MkZEcEJhLHVCQUF1QjtrQkFIbkMsU0FBUzs7OEJBSTJCLFlBQVk7c0JBQTlDLFNBQVM7dUJBQUMsTUFBTSxFQUFFLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQztnQkFDTSxnQkFBZ0I7c0JBQXRELFNBQVM7dUJBQUMsVUFBVSxFQUFFLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQztnQkFDRSxnQkFBZ0I7c0JBQXRELFNBQVM7dUJBQUMsVUFBVSxFQUFFLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQztnQkFDRCxhQUFhO3NCQUFoRCxTQUFTO3VCQUFDLE9BQU8sRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUM7Z0JBQ0ksZUFBZTtzQkFBcEQsU0FBUzt1QkFBQyxTQUFTLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1ldGFEYXRhIH0gZnJvbSBcIi4uLy4uL2ludGVyZmFjZXMvcmVwb3J0LWRlZlwiO1xuXG5AQ29tcG9uZW50KHtcbiAgdGVtcGxhdGVVcmw6ICcuL2luaXRpYWxpemF0aW9uLWNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBJbml0aWFsaXphdGlvbkNvbXBvbmVudCB7XG4gIEBWaWV3Q2hpbGQoJ2xpbmsnLCB7c3RhdGljOiB0cnVlfSkgbGlua1RlbXBsYXRlISA6IFRlbXBsYXRlUmVmPGFueT47XG4gIEBWaWV3Q2hpbGQoJ2ltYWdlVXJsJywge3N0YXRpYzogdHJ1ZX0pIGltYWdlVXJsVGVtcGxhdGUhIDogVGVtcGxhdGVSZWY8YW55PjtcbiAgQFZpZXdDaGlsZCgnY3VycmVuY3knLCB7c3RhdGljOiB0cnVlfSkgY3VycmVuY3lUZW1wbGF0ZSEgOiBUZW1wbGF0ZVJlZjxhbnk+O1xuICBAVmlld0NoaWxkKCdhcnJheScsIHtzdGF0aWM6IHRydWV9KSBhcnJheVRlbXBsYXRlISA6IFRlbXBsYXRlUmVmPGFueT47XG4gIEBWaWV3Q2hpbGQoJ2RlZmF1bHQnLCB7c3RhdGljOiB0cnVlfSkgZGVmYXVsdFRlbXBsYXRlISA6IFRlbXBsYXRlUmVmPGFueT47XG4gIHVzZVJvdXRlckxpbmsgPSAobWV0YURhdGEgOiBNZXRhRGF0YSkgPT4gbWV0YURhdGEuYWRkaXRpb25hbD8ubGluaz8udXNlUm91dGVyTGluayB8fCBtZXRhRGF0YS5hZGRpdGlvbmFsPy51c2VSb3V0ZXJMaW5rO1xuICB0YXJnZXQgPSAobWV0YURhdGEgOiBNZXRhRGF0YSkgPT4gbWV0YURhdGEuYWRkaXRpb25hbD8ubGluaz8udGFyZ2V0IHx8IG1ldGFEYXRhLmFkZGl0aW9uYWw/LnRhcmdldCB8fCAnX2JsYW5rJztcblxuICBwcml2YXRlIGtleSA9IChtZXRhRGF0YSA6IE1ldGFEYXRhLCBlbGVtZW50IDogYW55KSA9PiBtZXRhRGF0YS5hZGRpdGlvbmFsPy5saW5rPy51cmxLZXkgPyBlbGVtZW50W21ldGFEYXRhLmFkZGl0aW9uYWw/Lmxpbms/LnVybEtleV0gOlxuICAgIG1ldGFEYXRhLmFkZGl0aW9uYWw/LnVybEtleSA/IGVsZW1lbnRbbWV0YURhdGEuYWRkaXRpb25hbC51cmxLZXldIDogZWxlbWVudFttZXRhRGF0YS5rZXldO1xuICBnZXRMaW5rID0gKG1ldGFEYXRhIDogTWV0YURhdGEsIGVsZW1lbnQgOiBhbnkpID0+IHtcbiAgICBjb25zdCBoYXNSb3V0ZSA9ICEhbWV0YURhdGEuYWRkaXRpb25hbD8ubGluaz8uaW50ZXJwb2xhdGVkUm91dGU7XG4gICAgbGV0IGxpbmsgPSBoYXNSb3V0ZSA/IHRoaXMucGFyc2VJbnRlcnBvbGF0ZWRSb3V0ZSgobWV0YURhdGEuYWRkaXRpb25hbD8ubGluaz8uaW50ZXJwb2xhdGVkUm91dGUpISwgZWxlbWVudCkgOiAgKCBtZXRhRGF0YS5hZGRpdGlvbmFsPy5saW5rPy5iYXNlIHx8IG1ldGFEYXRhLmFkZGl0aW9uYWw/LmJhc2UpO1xuICAgIGlmKCFoYXNSb3V0ZSl7XG4gICAgICB2YXIgbmVlZHNTbGFzaCA9ICFsaW5rPy5lbmRzV2l0aCgnLycpO1xuICAgICAgbGluayArPSBgJHtuZWVkc1NsYXNoPycvJzonJ30ke3RoaXMua2V5KG1ldGFEYXRhLCBlbGVtZW50KX1gO1xuICAgIH1cbiAgICByZXR1cm4gbGluaztcbiAgfVxuICBwYXJzZUludGVycG9sYXRlZFJvdXRlID0gKCByb3V0ZTogc3RyaW5nLCBlbGVtZW50OiBhbnkgKSA9PlxuICAgIHJvdXRlLnJlcGxhY2UoL3soW159XSspfS9nLCAoXywga2V5KSA9PiBlbGVtZW50W2tleV0pO1xuXG59XG4iLCI8bmctdGVtcGxhdGUgI2xpbmsgIGxldC1lbGVtZW50PSdlbGVtZW50JyBsZXQtbWV0YURhdGE9J21ldGFEYXRhJz5cbiAgPGEgKm5nSWY9XCJ1c2VSb3V0ZXJMaW5rIHwgZnVuYyA6IG1ldGFEYXRhOyBlbHNlIGhyZWZMaW5rXCIgdGFyZ2V0PVwie3t0YXJnZXQgfCBmdW5jIDogbWV0YURhdGEgfX1cIlxuICAgIFtyb3V0ZXJMaW5rXT1cIiBbKGdldExpbmsgfCBmdW5jIDogbWV0YURhdGEgOiBlbGVtZW50KV1cIj5cbiAgICB7e2VsZW1lbnRbbWV0YURhdGEua2V5XX19XG4gIDwvYT5cbiAgPG5nLXRlbXBsYXRlICNocmVmTGluaz5cbiAgICA8YSB0YXJnZXQ9XCJ7e3RhcmdldCB8IGZ1bmMgOiBtZXRhRGF0YX19XCJcbiAgICAgIGhyZWY9XCJ7eyhnZXRMaW5rIHwgZnVuYyA6IG1ldGFEYXRhIDogZWxlbWVudCl9fVwiPlxuICAgICAge3tlbGVtZW50W21ldGFEYXRhLmtleV19fVxuICAgIDwvYT5cbiAgPC9uZy10ZW1wbGF0ZT5cbjwvbmctdGVtcGxhdGU+XG48bmctdGVtcGxhdGUgI2ltYWdlVXJsICBsZXQtZWxlbWVudD0nZWxlbWVudCcgbGV0LW1ldGFEYXRhPSdtZXRhRGF0YSc+XG4gIDxzcGFuPlxuICAgIDxpbWcgc3JjPVwie3tlbGVtZW50W21ldGFEYXRhLmtleV19fVwiIGhlaWdodD1cIjc1cHhcIiB3aWR0aD1cIjc1cHhcIiAvPlxuICA8L3NwYW4+XG48L25nLXRlbXBsYXRlPlxuXG48bmctdGVtcGxhdGUgI2FycmF5IGxldC1lbGVtZW50PSdlbGVtZW50JyBsZXQtbWV0YURhdGE9J21ldGFEYXRhJz5cbiAgPHRiLWFycmF5LWNvbHVtbiBbYXJyYXldPSdlbGVtZW50W21ldGFEYXRhLmtleV0nIFttZXRhRGF0YV09J21ldGFEYXRhJz48L3RiLWFycmF5LWNvbHVtbj5cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy10ZW1wbGF0ZSAjZGVmYXVsdCBsZXQtZWxlbWVudD0nZWxlbWVudCcgbGV0LW1ldGFEYXRhPSdtZXRhRGF0YScgbGV0LXRyYW5zZm9ybT0ndHJhbnNmb3JtJyA+XG4gIDxtYXQtaWNvbiAqbmdJZj1cIm1ldGFEYXRhLnVzZUljb25cIiA+e3sgdHJhbnNmb3JtIHwgZnVuYyA6IGVsZW1lbnQgfX08L21hdC1pY29uPlxuICA8c3BhbiAgKm5nSWY9XCIhbWV0YURhdGEudXNlSWNvblwiID57eyB0cmFuc2Zvcm0gfCBmdW5jIDogZWxlbWVudCB9fTwvc3Bhbj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|
|
@@ -31,4 +31,4 @@ export var ArrayStyle;
|
|
|
31
31
|
ArrayStyle[ArrayStyle["CommaDelimited"] = 0] = "CommaDelimited";
|
|
32
32
|
ArrayStyle[ArrayStyle["NewLine"] = 1] = "NewLine";
|
|
33
33
|
})(ArrayStyle || (ArrayStyle = {}));
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LWRlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2ludGVyZmFjZXMvcmVwb3J0LWRlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLENBQU4sSUFBWSxTQWNYO0FBZEQsV0FBWSxTQUFTO0lBQ2pCLCtDQUFXLENBQUE7SUFDWCx5Q0FBUSxDQUFBO0lBQ1IseUNBQVEsQ0FBQTtJQUNSLGlEQUFZLENBQUE7SUFDWixpREFBWSxDQUFBO0lBQ1osMkNBQVMsQ0FBQTtJQUNULDZDQUFVLENBQUE7SUFDViw2Q0FBVSxDQUFBO0lBQ1YsNkNBQVUsQ0FBQTtJQUNWLCtDQUFXLENBQUE7SUFDWCx3REFBZ0IsQ0FBQTtJQUNoQixzREFBZSxDQUFBO0lBQ2YsMENBQVMsQ0FBQTtBQUNiLENBQUMsRUFkVyxTQUFTLEtBQVQsU0FBUyxRQWNwQjtBQUVELE1BQU0sQ0FBTixJQUFZLGFBR1g7QUFIRCxXQUFZLGFBQWE7SUFDckIsNEJBQVUsQ0FBQTtJQUNWLDhCQUFZLENBQUE7QUFDaEIsQ0FBQyxFQUhXLGFBQWEsS0FBYixhQUFhLFFBR3hCO0FBRUQsTUFBTSxDQUFOLElBQVksTUFLWDtBQUxELFdBQVksTUFBTTtJQUNoQiwwQkFBZ0IsQ0FBQTtJQUNoQix3QkFBYyxDQUFBO0lBQ2QsNEJBQWtCLENBQUE7SUFDbEIsc0JBQVksQ0FBQTtBQUNkLENBQUMsRUFMVyxNQUFNLEtBQU4sTUFBTSxRQUtqQjtBQW1GRCxNQUFNLENBQU4sSUFBWSxVQUdYO0FBSEQsV0FBWSxVQUFVO0lBQ3BCLCtEQUFjLENBQUE7SUFDZCxpREFBTyxDQUFBO0FBQ1QsQ0FBQyxFQUhXLFVBQVUsS0FBVixVQUFVLFFBR3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGljdGlvbmFyeSB9IGZyb20gJy4vZGljdGlvbmFyeSc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBQcmVkaWNhdGUsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZUJ1aWxkZXJFeHBvcnQgfSBmcm9tICcuLi9jbGFzc2VzL1RhYmxlQnVpbGRlckNvbmZpZyc7XG5cblxuZXhwb3J0IGVudW0gRmllbGRUeXBlIHtcbiAgICBVbmtub3duID0gMCxcbiAgICBEYXRlID0gMSxcbiAgICBMaW5rID0gMixcbiAgICBJbWFnZVVybCA9IDMsXG4gICAgQ3VycmVuY3kgPSA0LFxuICAgIEFycmF5ID0gNSxcbiAgICBIaWRkZW4gPSA2LFxuICAgIE51bWJlciA9IDcsXG4gICAgU3RyaW5nID0gOCxcbiAgICBCb29sZWFuID0gOSxcbiAgICBQaG9uZU51bWJlciA9IDEwLFxuICAgIEV4cHJlc3Npb24gPSAxMSxcbiAgICBFbnVtID0gMTIsXG59XG5cbmV4cG9ydCBlbnVtIFNvcnREaXJlY3Rpb24ge1xuICAgIGFzYz0gJ2FzYycsXG4gICAgZGVzYz0gJ2Rlc2MnXG59XG5cbmV4cG9ydCBlbnVtIFRhcmdldCB7XG4gIEJsYW5rID0gJ19ibGFuaycsXG4gIFNlbGYgPSAnX3NlbGYnLFxuICBQYXJlbnQgPSAnX3BhcmVudCcsXG4gIFRvcCA9ICdfdG9wJ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1ldGFEYXRhPFQgPSBhbnksIEFkZGl0aW9uYWxGaWVsZHMgZXh0ZW5kcyBzdHJpbmdbXSA9IFtdPiB7XG4gIGtleTogKGtleW9mIFQgfCBBZGRpdGlvbmFsRmllbGRzW251bWJlcl0pICYgc3RyaW5nO1xuICBkaXNwbGF5TmFtZT86IHN0cmluZztcbiAgZmllbGRUeXBlOiBGaWVsZFR5cGU7XG4gIGFkZGl0aW9uYWw/OiBBZGRpdGlvbmFsPFQ+O1xuICBvcmRlcj86IG51bWJlcjtcbiAgcHJlU29ydD86IFNvcnREZWY7XG4gIF9pbnRlcm5hbE5vdFVzZXJEZWZpbmVkPzogYm9vbGVhbjtcbiAgd2lkdGg/OiBzdHJpbmc7XG4gIG5vRXhwb3J0PzogYm9vbGVhbjtcbiAgbm9GaWx0ZXI/OiBib29sZWFuO1xuICBjdXN0b21DZWxsPzogYm9vbGVhbjtcbiAgdHJhbnNmb3JtPzogKChvOiBULCAuLi5hcmdzOiBhbnlbXSk9PiBhbnkpIHwgKChvOiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKT0+IGFueSkgfCBQaXBlVHJhbnNmb3JtO1xuICBjbGljaz86IChlbGVtZW50OiBULCBrZXk6IHN0cmluZyApID0+IHZvaWQ7XG4gIHRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcbiAgY2xhc3Nlcz86IERpY3Rpb25hcnk8UHJlZGljYXRlPGFueT4+O1xuICB0b29sVGlwPzogc3RyaW5nO1xuICB1c2VJY29uPzogYm9vbGVhbjtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgIFJlcG9ydERlZjxEYXRhVHlwZSA9IGFueT4ge1xuICAgIGRhdGE6IERhdGFUeXBlW107XG4gICAgbWV0YURhdGE6IE1ldGFEYXRhIFtdO1xuICAgIHRvdGFsUmVjb3Jkcz86IG51bWJlcjtcbiAgICBjb3VudDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNvcnREZWYge1xuICAgIGRpcmVjdGlvbjogU29ydERpcmVjdGlvbjtcbiAgICBwcmVjZWRlbmNlPzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlck9wdGlvbnMge1xuICBmaWx0ZXJhYmxlVmFsdWVzIDogc3RyaW5nW11cbn1cblxuZXhwb3J0IGludGVyZmFjZSBBZGRpdGlvbmFsPFQgPSBhbnk+IHtcbiAgbGluaz8gOiB7XG4gICAgYmFzZT86IHN0cmluZztcbiAgICB1cmxLZXk/OiBzdHJpbmc7XG4gICAgdGFyZ2V0PzogVGFyZ2V0O1xuICAgIHVzZVJvdXRlckxpbms/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIElmIHlvdSB3YW50IHRvIHVzZSBhIHJvdXRlIHdpdGggaW50ZXJwb2xhdGVkIHBhcmFtcywgeW91IGNhbiB1c2UgdGhpcy4gV3JhcCB0aGUgcHJvcGVydHkgbmFtZSBpbiBjdXJseSBicmFjZXMuXG4gICAgICogRm9yIGV4YW1wbGUsIGlmIGludGVycG9sYXRlZFJvdXRlID0gL3VzZXJzL3tpZH0vZWRpdCwge2lkfSB3aWxsIGJlIHJlcGxhY2VkIHdpdGggdGhlIHZhbHVlIG9mIHRoZSBlbGVtZW50J3MgaWQgcHJvcGVydHkuXG4gICAgICovXG4gICAgaW50ZXJwb2xhdGVkUm91dGU/OiBzdHJpbmdcbiAgfVxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgUGxlYXNlIHVzZSBsaW5rLmJhc2VcbiAgICovXG4gIGJhc2U/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBQbGVhc2UgdXNlIGxpbmsudXJsS2V5XG4gICAqL1xuICB1cmxLZXk/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBQbGVhc2UgdXNlIGxpbmsudGFyZ2V0XG4gICAqL1xuICB0YXJnZXQ/OiBUYXJnZXQ7XG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBQbGVhc2UgdXNlIGxpbmsudXNlUm91dGVyTGlua1xuICAgKi9cbiAgdXNlUm91dGVyTGluaz86IGJvb2xlYW47XG4gIGZvb3Rlcj86IHsgdHlwZTogJ3N1bScgfTtcbiAgZ3JvdXBpbmc/OiB7IGdyb3VwQnk/OiBib29sZWFuLCBzdW0/OiBib29sZWFuOyBncm91cFRpdGxlRm4/OiAodmFsOiBhbnkpID0+IHN0cmluZyB9XG4gIGV4cG9ydD86IFRhYmxlQnVpbGRlckV4cG9ydDtcbiAgZGF0ZUZvcm1hdD86IHN0cmluZztcbiAgZmlsdGVyT3B0aW9ucz86IEZpbHRlck9wdGlvbnM7XG4gIHN0eWxlcz86IERpY3Rpb25hcnk8c3RyaW5nPjtcbiAgY29sdW1uUGFydFN0eWxlcz86IHtcbiAgICBoZWFkZXI/OiBEaWN0aW9uYXJ5PHN0cmluZz4sXG4gICAgYm9keT86IERpY3Rpb25hcnk8c3RyaW5nPixcbiAgICBmb290ZXI/OiBEaWN0aW9uYXJ5PHN0cmluZz4sXG4gIH1cbiAgZW51bU1hcD86IHtba2V5Om51bWJlcl06c3RyaW5nfTtcbiAgYm9vbGVhbj8gOiB7XG4gICAgc2hvd0ZvckZhbHNlPyA6IHRydWUgfCB7IGljb24gOiBzdHJpbmcgfSxcbiAgICBmb3JUcnVlPyA6IHsgaWNvbiA6IHN0cmluZyB9XG4gIH1cbn1cblxuZXhwb3J0IGVudW0gQXJyYXlTdHlsZSB7XG4gIENvbW1hRGVsaW1pdGVkLFxuICBOZXdMaW5lXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXJyYXlBZGRpdGlvbmFsIGV4dGVuZHMgQWRkaXRpb25hbCB7XG4gICAgbWV0YURhdGE/OiBNZXRhRGF0YTtcbiAgICBsaW1pdD86IG51bWJlcjtcbiAgICBhcnJheVN0eWxlPzogQXJyYXlTdHlsZTtcbn1cbiJdfQ==
|
|
@@ -12,17 +12,17 @@ export class TableTemplateService {
|
|
|
12
12
|
initTemplates() {
|
|
13
13
|
this.templates = {};
|
|
14
14
|
this.templates[FieldType.Array] = this.instance.arrayTemplate;
|
|
15
|
-
this.templates[FieldType.Boolean] = this.instance.
|
|
16
|
-
this.templates[FieldType.Currency] = this.instance.
|
|
15
|
+
this.templates[FieldType.Boolean] = this.instance.defaultTemplate;
|
|
16
|
+
this.templates[FieldType.Currency] = this.instance.defaultTemplate;
|
|
17
17
|
this.templates[FieldType.Date] = this.instance.defaultTemplate;
|
|
18
|
-
this.templates[FieldType.Expression] = this.instance.
|
|
18
|
+
this.templates[FieldType.Expression] = this.instance.defaultTemplate;
|
|
19
19
|
this.templates[FieldType.ImageUrl] = this.instance.imageUrlTemplate;
|
|
20
20
|
this.templates[FieldType.Link] = this.instance.linkTemplate;
|
|
21
21
|
this.templates[FieldType.Number] = this.instance.defaultTemplate;
|
|
22
22
|
this.templates[FieldType.PhoneNumber] = this.instance.defaultTemplate;
|
|
23
23
|
this.templates[FieldType.String] = this.instance.defaultTemplate;
|
|
24
24
|
this.templates[FieldType.Unknown] = this.instance.defaultTemplate;
|
|
25
|
-
this.templates[FieldType.Enum] = this.instance.
|
|
25
|
+
this.templates[FieldType.Enum] = this.instance.defaultTemplate;
|
|
26
26
|
}
|
|
27
27
|
getTemplate(fieldType) {
|
|
28
28
|
return this.templates[fieldType];
|
|
@@ -34,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
|
|
|
34
34
|
type: Injectable,
|
|
35
35
|
args: [{ providedIn: 'root' }]
|
|
36
36
|
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.Injector }]; } });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdGVtcGxhdGUtc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL3NlcnZpY2VzL3RhYmxlLXRlbXBsYXRlLXNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBZSxNQUFNLGVBQWUsQ0FBQztBQUN4RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxpRUFBaUUsQ0FBQztBQUMxRyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBR3JELE1BQU0sT0FBTyxvQkFBb0I7SUF1Qi9CLFlBQVksUUFBa0MsRUFBRSxDQUFXO1FBQ3JELE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyx1QkFBdUIsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQzFFLE1BQU0sQ0FBQyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDNUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDO1FBQzNCLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBeEJELGFBQWE7UUFDWCxJQUFJLENBQUMsU0FBUyxHQUFHLEVBQUcsQ0FBQztRQUNyQixJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQztRQUM5RCxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUNsRSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUNuRSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUMvRCxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUNyRSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGdCQUFnQixDQUFDO1FBQ3BFLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDO1FBQzVELElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDO1FBQ2pFLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDO1FBQ3RFLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDO1FBQ2pFLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDO1FBQ2xFLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDO0lBQ2pFLENBQUM7SUFDRCxXQUFXLENBQUMsU0FBb0I7UUFDOUIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ25DLENBQUM7O2lIQXJCVSxvQkFBb0I7cUhBQXBCLG9CQUFvQixjQURSLE1BQU07MkZBQ2xCLG9CQUFvQjtrQkFEaEMsVUFBVTttQkFBQyxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIEluamVjdG9yIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEluamVjdGFibGUsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEluaXRpYWxpemF0aW9uQ29tcG9uZW50IH0gZnJvbSBcIi4uL2NvbXBvbmVudHMvaW5pdGlhbGl6YXRpb24tY29tcG9uZW50L2luaXRpYWxpemF0aW9uLWNvbXBvbmVudFwiO1xuaW1wb3J0IHsgRmllbGRUeXBlIH0gZnJvbSBcIi4uL2ludGVyZmFjZXMvcmVwb3J0LWRlZlwiO1xuXG5ASW5qZWN0YWJsZSh7cHJvdmlkZWRJbjogJ3Jvb3QnfSlcbmV4cG9ydCBjbGFzcyBUYWJsZVRlbXBsYXRlU2VydmljZSB7XG4gIGluc3RhbmNlITogSW5pdGlhbGl6YXRpb25Db21wb25lbnQ7XG4gIHRlbXBsYXRlcztcblxuICBpbml0VGVtcGxhdGVzKCkge1xuICAgIHRoaXMudGVtcGxhdGVzID0geyB9O1xuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5BcnJheV0gPSB0aGlzLmluc3RhbmNlLmFycmF5VGVtcGxhdGU7XG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkJvb2xlYW5dID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkN1cnJlbmN5XSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5EYXRlXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5FeHByZXNzaW9uXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5JbWFnZVVybF0gPSB0aGlzLmluc3RhbmNlLmltYWdlVXJsVGVtcGxhdGU7XG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkxpbmtdID0gdGhpcy5pbnN0YW5jZS5saW5rVGVtcGxhdGU7XG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLk51bWJlcl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuUGhvbmVOdW1iZXJdID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLlN0cmluZ10gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuVW5rbm93bl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuRW51bV0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcbiAgfVxuICBnZXRUZW1wbGF0ZShmaWVsZFR5cGU6IEZpZWxkVHlwZSkgOiBUZW1wbGF0ZVJlZjxhbnk+IHtcbiAgICByZXR1cm4gdGhpcy50ZW1wbGF0ZXNbZmllbGRUeXBlXTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHJlc29sdmVyOiBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIGk6IEluamVjdG9yKSB7XG4gICAgICAgIGNvbnN0IGZhY3RvcnkgPSByZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShJbml0aWFsaXphdGlvbkNvbXBvbmVudCk7XG4gICAgICAgIGNvbnN0IGMgPSBmYWN0b3J5LmNyZWF0ZShpKTtcbiAgICAgICAgdGhpcy5pbnN0YW5jZSA9IGMuaW5zdGFuY2U7XG4gICAgICAgIHRoaXMuaW5pdFRlbXBsYXRlcygpO1xuICB9XG59XG4iXX0=
|
|
@@ -4,20 +4,22 @@ import { TableBuilderConfigToken } from '../classes/TableBuilderConfig';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
6
6
|
import * as i2 from "../../utilities/pipes/phone.pipe";
|
|
7
|
+
import * as i3 from "../../utilities";
|
|
7
8
|
export function isPipe(o) {
|
|
8
9
|
return typeof (o.transform) === 'function';
|
|
9
10
|
}
|
|
10
11
|
export class TransformCreator {
|
|
11
|
-
constructor(datePipe, currencyPipe, phonePipe, config) {
|
|
12
|
+
constructor(datePipe, currencyPipe, phonePipe, casePipe, config) {
|
|
12
13
|
this.datePipe = datePipe;
|
|
13
14
|
this.currencyPipe = currencyPipe;
|
|
14
15
|
this.phonePipe = phonePipe;
|
|
16
|
+
this.casePipe = casePipe;
|
|
15
17
|
this.config = config;
|
|
16
18
|
}
|
|
17
19
|
createTransformer(metaData) {
|
|
18
20
|
if (metaData.transform) {
|
|
19
21
|
if (isPipe(metaData.transform)) {
|
|
20
|
-
return metaData.transform.transform;
|
|
22
|
+
return (value) => metaData.transform.transform(value[metaData.key]);
|
|
21
23
|
}
|
|
22
24
|
return metaData.transform;
|
|
23
25
|
}
|
|
@@ -27,24 +29,39 @@ export class TransformCreator {
|
|
|
27
29
|
switch (metaData.fieldType) {
|
|
28
30
|
case FieldType.Date:
|
|
29
31
|
const dateFormat = metaData.additional?.dateFormat ?? this.config.defaultSettings?.dateFormat ?? 'shortDate';
|
|
30
|
-
return (value) => this.datePipe.transform(value, dateFormat);
|
|
32
|
+
return (value) => this.datePipe.transform(value[metaData.key], dateFormat);
|
|
31
33
|
case FieldType.Currency:
|
|
32
|
-
return this.currencyPipe.transform;
|
|
34
|
+
return (value) => this.currencyPipe.transform(value[metaData.key]);
|
|
33
35
|
case FieldType.PhoneNumber:
|
|
34
|
-
return this.phonePipe.transform;
|
|
36
|
+
return (value) => this.phonePipe.transform(value[metaData.key]);
|
|
37
|
+
case FieldType.Enum:
|
|
38
|
+
return (value) => this.casePipe.transform(metaData.additional?.enumMap[value[metaData.key]]);
|
|
39
|
+
case FieldType.Boolean:
|
|
40
|
+
let forTrue = 'check';
|
|
41
|
+
let forFalse = '';
|
|
42
|
+
if (metaData.additional?.boolean?.forTrue) {
|
|
43
|
+
forTrue = metaData?.additional.boolean.forTrue.icon;
|
|
44
|
+
}
|
|
45
|
+
if (metaData.additional?.boolean?.showForFalse === true) {
|
|
46
|
+
forFalse = 'clear';
|
|
47
|
+
}
|
|
48
|
+
else if (metaData.additional?.boolean?.showForFalse?.icon) {
|
|
49
|
+
forFalse = metaData.additional?.boolean?.showForFalse?.icon;
|
|
50
|
+
}
|
|
51
|
+
return (value) => value[metaData.key] ? forTrue : forFalse;
|
|
35
52
|
}
|
|
36
|
-
return (value) => value;
|
|
53
|
+
return (value) => value[metaData.key];
|
|
37
54
|
}
|
|
38
55
|
}
|
|
39
|
-
TransformCreator.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: TransformCreator, deps: [{ token: i1.DatePipe }, { token: i1.CurrencyPipe }, { token: i2.PhoneNumberPipe }, { token: TableBuilderConfigToken }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
56
|
+
TransformCreator.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: TransformCreator, deps: [{ token: i1.DatePipe }, { token: i1.CurrencyPipe }, { token: i2.PhoneNumberPipe }, { token: i3.SpaceCasePipe }, { token: TableBuilderConfigToken }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
40
57
|
TransformCreator.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: TransformCreator, providedIn: 'root' });
|
|
41
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: TransformCreator, decorators: [{
|
|
42
59
|
type: Injectable,
|
|
43
60
|
args: [{
|
|
44
|
-
providedIn: 'root'
|
|
61
|
+
providedIn: 'root',
|
|
45
62
|
}]
|
|
46
|
-
}], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i1.CurrencyPipe }, { type: i2.PhoneNumberPipe }, { type: undefined, decorators: [{
|
|
63
|
+
}], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i1.CurrencyPipe }, { type: i2.PhoneNumberPipe }, { type: i3.SpaceCasePipe }, { type: undefined, decorators: [{
|
|
47
64
|
type: Inject,
|
|
48
65
|
args: [TableBuilderConfigToken]
|
|
49
66
|
}] }]; } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmb3JtLWNyZWF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9zZXJ2aWNlcy90cmFuc2Zvcm0tY3JlYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEUsT0FBTyxFQUFFLFNBQVMsRUFBWSxNQUFNLDBCQUEwQixDQUFDO0FBRy9ELE9BQU8sRUFBRSx1QkFBdUIsRUFBc0IsTUFBTSwrQkFBK0IsQ0FBQzs7Ozs7QUFHNUYsTUFBTSxVQUFVLE1BQU0sQ0FBQyxDQUFPO0lBQzVCLE9BQU8sT0FBTyxDQUFFLENBQW1CLENBQUMsU0FBUyxDQUFFLEtBQUssVUFBVSxDQUFDO0FBQ2pFLENBQUM7QUFLRCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFlBQ1UsUUFBa0IsRUFDbEIsWUFBMEIsRUFDMUIsU0FBMEIsRUFDMUIsUUFBdUIsRUFDVSxNQUEwQjtRQUozRCxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQ2xCLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBQzFCLGNBQVMsR0FBVCxTQUFTLENBQWlCO1FBQzFCLGFBQVEsR0FBUixRQUFRLENBQWU7UUFDVSxXQUFNLEdBQU4sTUFBTSxDQUFvQjtJQUNsRSxDQUFDO0lBQ0osaUJBQWlCLENBQUMsUUFBa0I7UUFDbEMsSUFBRyxRQUFRLENBQUMsU0FBUyxFQUFFO1lBQ3JCLElBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBQztnQkFDNUIsT0FBTyxDQUFDLEtBQVUsRUFBRSxFQUFFLENBQUcsUUFBUyxDQUFDLFNBQTJCLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQzthQUMvRjtZQUNELE9BQU8sUUFBUSxDQUFDLFNBQVMsQ0FBQztTQUMzQjtRQUNELElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQzVFLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBRSxDQUFDO1NBQ3REO1FBQ0QsUUFBTyxRQUFRLENBQUMsU0FBUyxFQUFFO1lBQ3pCLEtBQUssU0FBUyxDQUFDLElBQUk7Z0JBQ2pCLE1BQU0sVUFBVSxHQUFHLFFBQVEsQ0FBQyxVQUFVLEVBQUUsVUFBVSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsZUFBZSxFQUFFLFVBQVUsSUFBSSxXQUFXLENBQUM7Z0JBQzdHLE9BQU8sQ0FBQyxLQUFVLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDbEYsS0FBSyxTQUFTLENBQUMsUUFBUTtnQkFDbkIsT0FBTyxDQUFDLEtBQVUsRUFBRSxFQUFFLENBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1lBQzdFLEtBQUssU0FBUyxDQUFDLFdBQVc7Z0JBQ3hCLE9BQVEsQ0FBQyxLQUFVLEVBQUUsRUFBRSxDQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUN6RSxLQUFLLFNBQVMsQ0FBQyxJQUFJO2dCQUNqQixPQUFPLENBQUMsS0FBVSxFQUFFLEVBQUUsQ0FBRSxJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLE9BQVEsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFXLENBQUMsQ0FBRTtZQUNqSCxLQUFLLFNBQVMsQ0FBQyxPQUFPO2dCQUNwQixJQUFJLE9BQU8sR0FBRyxPQUFPLENBQUE7Z0JBQ3JCLElBQUksUUFBUSxHQUFHLEVBQUUsQ0FBQztnQkFDbEIsSUFBRyxRQUFRLENBQUMsVUFBVSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUU7b0JBQ3hDLE9BQU8sR0FBRyxRQUFRLEVBQUUsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO2lCQUNyRDtnQkFDRCxJQUFHLFFBQVEsQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLFlBQVksS0FBSyxJQUFJLEVBQUU7b0JBQ3RELFFBQVEsR0FBRyxPQUFPLENBQUM7aUJBQ3BCO3FCQUFNLElBQUksUUFBUSxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFLElBQUksRUFBRTtvQkFDM0QsUUFBUSxHQUFHLFFBQVEsQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxJQUFJLENBQUM7aUJBQzdEO2dCQUNELE9BQU8sQ0FBQyxLQUFVLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFFO1NBQ3BFO1FBQ0MsT0FBTyxDQUFDLEtBQVUsRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMvQyxDQUFDOzs2R0ExQ1UsZ0JBQWdCLGtJQU1qQix1QkFBdUI7aUhBTnRCLGdCQUFnQixjQUZkLE1BQU07MkZBRVIsZ0JBQWdCO2tCQUg1QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRyxNQUFNO2lCQUNwQjs7MEJBT0ksTUFBTTsyQkFBQyx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpZWxkVHlwZSwgTWV0YURhdGEgfSBmcm9tICcuLi9pbnRlcmZhY2VzL3JlcG9ydC1kZWYnO1xuaW1wb3J0IHsgRGF0ZVBpcGUsIEN1cnJlbmN5UGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBQaG9uZU51bWJlclBpcGUgfSBmcm9tICcuLi8uLi91dGlsaXRpZXMvcGlwZXMvcGhvbmUucGlwZSc7XG5pbXBvcnQgeyBUYWJsZUJ1aWxkZXJDb25maWdUb2tlbiwgVGFibGVCdWlsZGVyQ29uZmlnIH0gZnJvbSAnLi4vY2xhc3Nlcy9UYWJsZUJ1aWxkZXJDb25maWcnO1xuaW1wb3J0IHsgU3BhY2VDYXNlUGlwZSB9IGZyb20gJy4uLy4uL3V0aWxpdGllcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1BpcGUobyA6IGFueSApOiBvIGlzIFBpcGVUcmFuc2Zvcm0ge1xuICByZXR1cm4gdHlwZW9mICgobyBhcyBQaXBlVHJhbnNmb3JtKS50cmFuc2Zvcm0gKSA9PT0gJ2Z1bmN0aW9uJztcbn1cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAgJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBUcmFuc2Zvcm1DcmVhdG9yIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBkYXRlUGlwZTogRGF0ZVBpcGUsXG4gICAgcHJpdmF0ZSBjdXJyZW5jeVBpcGU6IEN1cnJlbmN5UGlwZSxcbiAgICBwcml2YXRlIHBob25lUGlwZTogUGhvbmVOdW1iZXJQaXBlLFxuICAgIHByaXZhdGUgY2FzZVBpcGU6IFNwYWNlQ2FzZVBpcGUsXG4gICAgQEluamVjdChUYWJsZUJ1aWxkZXJDb25maWdUb2tlbikgcHJpdmF0ZSBjb25maWc6IFRhYmxlQnVpbGRlckNvbmZpZyxcbiAgKSB7fVxuICBjcmVhdGVUcmFuc2Zvcm1lcihtZXRhRGF0YTogTWV0YURhdGEpOiAoKHZhbHVlOiBhbnksIC4uLmFyZ3M6IGFueVtdKSA9PiBhbnkpICB7XG4gICAgaWYobWV0YURhdGEudHJhbnNmb3JtKSB7XG4gICAgICBpZihpc1BpcGUobWV0YURhdGEudHJhbnNmb3JtKSl7XG4gICAgICAgIHJldHVybiAodmFsdWU6IGFueSkgPT4gIChtZXRhRGF0YSEudHJhbnNmb3JtIGFzIFBpcGVUcmFuc2Zvcm0pLnRyYW5zZm9ybSh2YWx1ZVttZXRhRGF0YS5rZXldKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBtZXRhRGF0YS50cmFuc2Zvcm07XG4gICAgfVxuICAgIGlmICh0aGlzLmNvbmZpZy50cmFuc2Zvcm1lcnMgJiYgdGhpcy5jb25maWcudHJhbnNmb3JtZXJzW21ldGFEYXRhLmZpZWxkVHlwZV0pIHtcbiAgICAgIHJldHVybiB0aGlzLmNvbmZpZy50cmFuc2Zvcm1lcnNbbWV0YURhdGEuZmllbGRUeXBlXSE7XG4gICAgfVxuICAgIHN3aXRjaChtZXRhRGF0YS5maWVsZFR5cGUpIHtcbiAgICAgIGNhc2UgRmllbGRUeXBlLkRhdGU6XG4gICAgICAgIGNvbnN0IGRhdGVGb3JtYXQgPSBtZXRhRGF0YS5hZGRpdGlvbmFsPy5kYXRlRm9ybWF0ID8/IHRoaXMuY29uZmlnLmRlZmF1bHRTZXR0aW5ncz8uZGF0ZUZvcm1hdCA/PyAnc2hvcnREYXRlJztcbiAgICAgICAgcmV0dXJuICh2YWx1ZTogYW55KSA9PiB0aGlzLmRhdGVQaXBlLnRyYW5zZm9ybSh2YWx1ZVttZXRhRGF0YS5rZXldLCBkYXRlRm9ybWF0KTtcbiAgICAgIGNhc2UgRmllbGRUeXBlLkN1cnJlbmN5OlxuICAgICAgICAgIHJldHVybiAodmFsdWU6IGFueSkgPT4gIHRoaXMuY3VycmVuY3lQaXBlLnRyYW5zZm9ybSh2YWx1ZVttZXRhRGF0YS5rZXldKTtcbiAgICAgIGNhc2UgRmllbGRUeXBlLlBob25lTnVtYmVyOlxuICAgICAgICByZXR1cm4gICh2YWx1ZTogYW55KSA9PiAgdGhpcy5waG9uZVBpcGUudHJhbnNmb3JtKHZhbHVlW21ldGFEYXRhLmtleV0pO1xuICAgICAgY2FzZSBGaWVsZFR5cGUuRW51bTpcbiAgICAgICAgcmV0dXJuICh2YWx1ZTogYW55KSA9PiAgdGhpcy5jYXNlUGlwZS50cmFuc2Zvcm0obWV0YURhdGEuYWRkaXRpb25hbD8uZW51bU1hcCFbdmFsdWVbbWV0YURhdGEua2V5XV0gYXMgc3RyaW5nKSA7XG4gICAgICBjYXNlIEZpZWxkVHlwZS5Cb29sZWFuOlxuICAgICAgICBsZXQgZm9yVHJ1ZSA9ICdjaGVjaydcbiAgICAgICAgbGV0IGZvckZhbHNlID0gJyc7XG4gICAgICAgIGlmKG1ldGFEYXRhLmFkZGl0aW9uYWw/LmJvb2xlYW4/LmZvclRydWUpIHtcbiAgICAgICAgICBmb3JUcnVlID0gbWV0YURhdGE/LmFkZGl0aW9uYWwuYm9vbGVhbi5mb3JUcnVlLmljb247XG4gICAgICAgIH1cbiAgICAgICAgaWYobWV0YURhdGEuYWRkaXRpb25hbD8uYm9vbGVhbj8uc2hvd0ZvckZhbHNlID09PSB0cnVlKSB7XG4gICAgICAgICAgZm9yRmFsc2UgPSAnY2xlYXInO1xuICAgICAgICB9IGVsc2UgaWYgKG1ldGFEYXRhLmFkZGl0aW9uYWw/LmJvb2xlYW4/LnNob3dGb3JGYWxzZT8uaWNvbikge1xuICAgICAgICAgIGZvckZhbHNlID0gbWV0YURhdGEuYWRkaXRpb25hbD8uYm9vbGVhbj8uc2hvd0ZvckZhbHNlPy5pY29uO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiAodmFsdWU6IGFueSkgPT4gdmFsdWVbbWV0YURhdGEua2V5XSA/IGZvclRydWUgOiBmb3JGYWxzZSA7XG4gICAgfVxuICAgICAgcmV0dXJuICh2YWx1ZTogYW55KSA9PiB2YWx1ZVttZXRhRGF0YS5rZXldO1xuICB9XG5cbn1cbiJdfQ==
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class ConditionalClassesDirective {
|
|
4
|
+
constructor(el, renderer) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
this.renderer = renderer;
|
|
7
|
+
this.classesApplied = [];
|
|
8
|
+
this.el.nativeElement.style.backgroundColor = 'yellow';
|
|
9
|
+
}
|
|
10
|
+
ngOnChanges(changes) {
|
|
11
|
+
let toApply = [];
|
|
12
|
+
if (this.classes) {
|
|
13
|
+
toApply = Object.keys(this.classes)
|
|
14
|
+
.filter(key => this.classes[key](this.element));
|
|
15
|
+
}
|
|
16
|
+
var classesNotYetApplied = toApply.filter(c => !this.classesApplied.includes(c));
|
|
17
|
+
var classesToRemove = this.classesApplied.filter(c => !toApply.includes(c));
|
|
18
|
+
classesToRemove.forEach(c => this.renderer.removeClass(this.el.nativeElement, c));
|
|
19
|
+
classesNotYetApplied.forEach(c => this.renderer.addClass(this.el.nativeElement, c));
|
|
20
|
+
this.classesApplied = toApply;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
ConditionalClassesDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: ConditionalClassesDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
24
|
+
ConditionalClassesDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.5", type: ConditionalClassesDirective, selector: "[conditionalClasses]", inputs: { element: "element", classes: ["conditionalClasses", "classes"] }, usesOnChanges: true, ngImport: i0 });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: ConditionalClassesDirective, decorators: [{
|
|
26
|
+
type: Directive,
|
|
27
|
+
args: [{
|
|
28
|
+
selector: '[conditionalClasses]'
|
|
29
|
+
}]
|
|
30
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { element: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}], classes: [{
|
|
33
|
+
type: Input,
|
|
34
|
+
args: ['conditionalClasses']
|
|
35
|
+
}] } });
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZGl0aW9uYWwtY2xhc3Nlcy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdXRpbGl0aWVzL2RpcmVjdGl2ZXMvY29uZGl0aW9uYWwtY2xhc3Nlcy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQTRCLE1BQU0sZUFBZSxDQUFDOztBQU12RixNQUFNLE9BQU8sMkJBQTJCO0lBRXRDLFlBQW9CLEVBQWMsRUFBVSxRQUFtQjtRQUEzQyxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQU9oRSxtQkFBYyxHQUFhLEVBQUUsQ0FBQztRQU4zQixJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsZUFBZSxHQUFHLFFBQVEsQ0FBQztJQUN6RCxDQUFDO0lBT0YsV0FBVyxDQUFDLE9BQXNCO1FBQ2pDLElBQUksT0FBTyxHQUFjLEVBQUUsQ0FBQztRQUM1QixJQUFHLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDZixPQUFPLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO2lCQUNsQyxNQUFNLENBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBUSxDQUFDLEdBQUcsQ0FBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBRSxDQUFDO1NBQ3JEO1FBRUQsSUFBSSxvQkFBb0IsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBRSxDQUFDO1FBQ25GLElBQUksZUFBZSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFN0UsZUFBZSxDQUFDLE9BQU8sQ0FBRSxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBRSxDQUFFLENBQUM7UUFFdEYsb0JBQW9CLENBQUMsT0FBTyxDQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLEVBQUcsQ0FBQyxDQUFFLENBQUUsQ0FBQztRQUV6RixJQUFJLENBQUMsY0FBYyxHQUFHLE9BQU8sQ0FBQztJQUMvQixDQUFDOzt3SEExQlcsMkJBQTJCOzRHQUEzQiwyQkFBMkI7MkZBQTNCLDJCQUEyQjtrQkFIdkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsc0JBQXNCO2lCQUNqQzt5SEFPUyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ3VCLE9BQU87c0JBQW5DLEtBQUs7dUJBQUMsb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCwgUmVuZGVyZXIyLCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaWN0aW9uYXJ5LCBQcmVkaWNhdGUgfSBmcm9tICdAbmdyeC9lbnRpdHknO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbY29uZGl0aW9uYWxDbGFzc2VzXSdcbn0pXG5leHBvcnQgY2xhc3MgQ29uZGl0aW9uYWxDbGFzc2VzRGlyZWN0aXZlIHtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsOiBFbGVtZW50UmVmLCBwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHtcbiAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuc3R5bGUuYmFja2dyb3VuZENvbG9yID0gJ3llbGxvdyc7XG4gIH1cblxuIEBJbnB1dCgpIGVsZW1lbnQ/OiBhbnk7XG4gQElucHV0KCdjb25kaXRpb25hbENsYXNzZXMnKSBjbGFzc2VzPzogRGljdGlvbmFyeTxQcmVkaWNhdGU8YW55Pj47XG5cbiBjbGFzc2VzQXBwbGllZDogc3RyaW5nW10gPSBbXTtcblxuIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcbiAgbGV0IHRvQXBwbHk6IHN0cmluZyBbXSA9IFtdO1xuICBpZih0aGlzLmNsYXNzZXMpIHtcbiAgICB0b0FwcGx5ID0gT2JqZWN0LmtleXModGhpcy5jbGFzc2VzKVxuICAgIC5maWx0ZXIoIGtleSA9PiB0aGlzLmNsYXNzZXMhW2tleV0hKHRoaXMuZWxlbWVudCkgKTtcbiAgfVxuXG4gIHZhciBjbGFzc2VzTm90WWV0QXBwbGllZCA9IHRvQXBwbHkuZmlsdGVyKCBjID0+ICF0aGlzLmNsYXNzZXNBcHBsaWVkLmluY2x1ZGVzKGMpICk7XG4gIHZhciBjbGFzc2VzVG9SZW1vdmUgPSB0aGlzLmNsYXNzZXNBcHBsaWVkLmZpbHRlciggYyA9PiAhdG9BcHBseS5pbmNsdWRlcyhjKSk7XG5cbiAgY2xhc3Nlc1RvUmVtb3ZlLmZvckVhY2goIGMgPT4gdGhpcy5yZW5kZXJlci5yZW1vdmVDbGFzcyggdGhpcy5lbC5uYXRpdmVFbGVtZW50LCBjICkgKTtcblxuICBjbGFzc2VzTm90WWV0QXBwbGllZC5mb3JFYWNoKCBjID0+IHRoaXMucmVuZGVyZXIuYWRkQ2xhc3MoIHRoaXMuZWwubmF0aXZlRWxlbWVudCAsIGMgKSApO1xuXG4gIHRoaXMuY2xhc3Nlc0FwcGxpZWQgPSB0b0FwcGx5O1xuIH1cblxuXG59XG4iXX0=
|
|
@@ -10,5 +10,6 @@ export * from './pipes/function.pipe';
|
|
|
10
10
|
export * from './pipes/phone.pipe';
|
|
11
11
|
export * from './pipes/space-case.pipes';
|
|
12
12
|
export * from './directives/dialog-service';
|
|
13
|
+
export * from './directives/conditional-classes.directive';
|
|
13
14
|
export * from './module';
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdXRpbGl0aWVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx5Q0FBeUMsQ0FBQztBQUV4RCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYywwQkFBMEIsQ0FBQztBQUV6QyxjQUFjLDZCQUE2QixDQUFDO0FBRTVDLGNBQWMsNENBQTRDLENBQUE7QUFHMUQsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvcHJldmVudC1lbnRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3N0b3AtcHJvcGFnYXRpb24uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9hdXRvLWZvY3VzLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvY2xpY2tTdWJqZWN0JztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9jbGlja0VtaXR0ZXJEaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2RpYWxvZyc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvc3R5bGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9tYXQtdG9nZ2xlLWdyb3VwLWRpcmVjdGl2ZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvZnVuY3Rpb24ucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL3Bob25lLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9zcGFjZS1jYXNlLnBpcGVzJztcblxuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2RpYWxvZy1zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2NvbmRpdGlvbmFsLWNsYXNzZXMuZGlyZWN0aXZlJ1xuXG5cbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlJztcblxuXG4iXX0=
|