@one-paragon/angular-utilities 0.0.28 → 0.0.31

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.
@@ -13,16 +13,26 @@ export class InitializationComponent {
13
13
  : metaData.additional?.boolean?.showForFalse?.icon || null;
14
14
  this.useRouterLink = (metaData) => metaData.additional?.link?.useRouterLink || metaData.additional?.useRouterLink;
15
15
  this.target = (metaData) => metaData.additional?.link?.target || metaData.additional?.target || '_blank';
16
- this.base = (metaData) => metaData.additional?.link?.base || metaData.additional?.base;
16
+ this.base = (metaData, element) => metaData.additional?.link?.route
17
+ ? this.parseInterpolatedRoute(metaData.additional.link.route, element)
18
+ : (metaData.additional?.link?.base || metaData.additional?.base);
17
19
  this.key = (metaData, element) => metaData.additional?.link?.urlKey ? element[metaData.additional?.link?.urlKey] :
18
- metaData.additional?.urlKey ? element[metaData.additional.urlKey] : element[metaData.key];
20
+ metaData.additional?.urlKey ? element[metaData.additional.urlKey] : metaData.additional?.link?.route ? '' : element[metaData.key];
21
+ this.parseInterpolatedRoute = (route, element) => {
22
+ let interpolated = route?.interpolated || '';
23
+ const dict = route?.params || {};
24
+ Object.keys(dict).forEach(key => {
25
+ interpolated = interpolated.replace(`{${key}}`, element[dict[key]]);
26
+ });
27
+ return interpolated;
28
+ };
19
29
  }
20
30
  }
21
31
  InitializationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: InitializationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
22
- InitializationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", type: InitializationComponent, selector: "ng-component", viewQueries: [{ propertyName: "booleanTemplate", first: true, predicate: ["boolean"], descendants: true, static: true }, { 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: "expressionTemplate", first: true, predicate: ["expression"], descendants: true, static: true }, { propertyName: "defaultTemplate", first: true, predicate: ["default"], descendants: true, static: true }, { propertyName: "enumTemplate", first: true, predicate: ["enum"], descendants: true, static: true }], ngImport: i0, template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.ArrayColumnComponent, selector: "tb-array-column", inputs: ["array", "metaData"] }], 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, "currency": i3.CurrencyPipe, "spaceCase": i6.SpaceCasePipe } });
32
+ InitializationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", type: InitializationComponent, selector: "ng-component", viewQueries: [{ propertyName: "booleanTemplate", first: true, predicate: ["boolean"], descendants: true, static: true }, { 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: "expressionTemplate", first: true, predicate: ["expression"], descendants: true, static: true }, { propertyName: "defaultTemplate", first: true, predicate: ["default"], descendants: true, static: true }, { propertyName: "enumTemplate", first: true, predicate: ["enum"], descendants: true, static: true }], ngImport: i0, template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData : element), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData : element)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.ArrayColumnComponent, selector: "tb-array-column", inputs: ["array", "metaData"] }], 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, "currency": i3.CurrencyPipe, "spaceCase": i6.SpaceCasePipe } });
23
33
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: InitializationComponent, decorators: [{
24
34
  type: Component,
25
- args: [{ template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n" }]
35
+ args: [{ template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData : element), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData : element)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n" }]
26
36
  }], propDecorators: { booleanTemplate: [{
27
37
  type: ViewChild,
28
38
  args: ['boolean', { static: true }]
@@ -48,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
48
58
  type: ViewChild,
49
59
  args: ['enum', { static: true }]
50
60
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5pdGlhbGl6YXRpb24tY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy9pbml0aWFsaXphdGlvbi1jb21wb25lbnQvaW5pdGlhbGl6YXRpb24tY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvY29tcG9uZW50cy9pbml0aWFsaXphdGlvbi1jb21wb25lbnQvaW5pdGlhbGl6YXRpb24tY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBZSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7O0FBTWxFLE1BQU0sT0FBTyx1QkFBdUI7SUFIcEM7UUFZRSxnQkFBVyxHQUFHLENBQUMsUUFBbUIsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLElBQUksSUFBSyxPQUFPLENBQUM7UUFDL0YsaUJBQVksR0FBRyxDQUFDLFFBQW1CLEVBQWtCLEVBQUUsQ0FDckQsUUFBUSxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsWUFBWSxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTztZQUM3RCxDQUFDLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFLElBQUksSUFBSSxJQUFJLENBQUM7UUFDN0Qsa0JBQWEsR0FBRyxDQUFDLFFBQW1CLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLGFBQWEsSUFBSSxRQUFRLENBQUMsVUFBVSxFQUFFLGFBQWEsQ0FBQztRQUN4SCxXQUFNLEdBQUcsQ0FBQyxRQUFtQixFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxNQUFNLElBQUksUUFBUSxDQUFDLFVBQVUsRUFBRSxNQUFNLElBQUksUUFBUSxDQUFDO1FBQy9HLFNBQUksR0FBRyxDQUFDLFFBQW1CLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLElBQUksSUFBSSxRQUFRLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQztRQUM3RixRQUFHLEdBQUcsQ0FBQyxRQUFtQixFQUFFLE9BQWEsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztZQUM1SCxRQUFRLENBQUMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUE7S0FFNUY7O29IQW5CWSx1QkFBdUI7d0dBQXZCLHVCQUF1QixxNUJDTnBDLHk4REE4Q0E7MkZEeENhLHVCQUF1QjtrQkFIbkMsU0FBUzs7OEJBSThCLGVBQWU7c0JBQXBELFNBQVM7dUJBQUMsU0FBUyxFQUFFLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQztnQkFDRCxZQUFZO3NCQUE5QyxTQUFTO3VCQUFDLE1BQU0sRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUM7Z0JBQ00sZ0JBQWdCO3NCQUF0RCxTQUFTO3VCQUFDLFVBQVUsRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUM7Z0JBQ0UsZ0JBQWdCO3NCQUF0RCxTQUFTO3VCQUFDLFVBQVUsRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUM7Z0JBQ0QsYUFBYTtzQkFBaEQsU0FBUzt1QkFBQyxPQUFPLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDO2dCQUNPLGtCQUFrQjtzQkFBMUQsU0FBUzt1QkFBQyxZQUFZLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDO2dCQUNELGVBQWU7c0JBQXBELFNBQVM7dUJBQUMsU0FBUyxFQUFFLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQztnQkFDRCxZQUFZO3NCQUE5QyxTQUFTO3VCQUFDLE1BQU0sRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIFRlbXBsYXRlUmVmLCBWaWV3Q2hpbGQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgTWV0YURhdGEgfSBmcm9tIFwiLi4vLi4vaW50ZXJmYWNlcy9yZXBvcnQtZGVmXCI7XG5cbkBDb21wb25lbnQoe1xuICB0ZW1wbGF0ZVVybDogJy4vaW5pdGlhbGl6YXRpb24tY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEluaXRpYWxpemF0aW9uQ29tcG9uZW50IHtcbiAgQFZpZXdDaGlsZCgnYm9vbGVhbicsIHtzdGF0aWM6IHRydWV9KSBib29sZWFuVGVtcGxhdGUhIDogVGVtcGxhdGVSZWY8YW55PjtcbiAgQFZpZXdDaGlsZCgnbGluaycsIHtzdGF0aWM6IHRydWV9KSBsaW5rVGVtcGxhdGUhIDogVGVtcGxhdGVSZWY8YW55PjtcbiAgQFZpZXdDaGlsZCgnaW1hZ2VVcmwnLCB7c3RhdGljOiB0cnVlfSkgaW1hZ2VVcmxUZW1wbGF0ZSEgOiBUZW1wbGF0ZVJlZjxhbnk+O1xuICBAVmlld0NoaWxkKCdjdXJyZW5jeScsIHtzdGF0aWM6IHRydWV9KSBjdXJyZW5jeVRlbXBsYXRlISA6IFRlbXBsYXRlUmVmPGFueT47XG4gIEBWaWV3Q2hpbGQoJ2FycmF5Jywge3N0YXRpYzogdHJ1ZX0pIGFycmF5VGVtcGxhdGUhIDogVGVtcGxhdGVSZWY8YW55PjtcbiAgQFZpZXdDaGlsZCgnZXhwcmVzc2lvbicsIHtzdGF0aWM6IHRydWV9KSBleHByZXNzaW9uVGVtcGxhdGUhIDogVGVtcGxhdGVSZWY8YW55PjtcbiAgQFZpZXdDaGlsZCgnZGVmYXVsdCcsIHtzdGF0aWM6IHRydWV9KSBkZWZhdWx0VGVtcGxhdGUhIDogVGVtcGxhdGVSZWY8YW55PjtcbiAgQFZpZXdDaGlsZCgnZW51bScsIHtzdGF0aWM6IHRydWV9KSBlbnVtVGVtcGxhdGUhIDogVGVtcGxhdGVSZWY8YW55PjtcbiAgZm9yVHJ1ZUljb24gPSAobWV0YURhdGEgOiBNZXRhRGF0YSkgPT4gbWV0YURhdGEuYWRkaXRpb25hbD8uYm9vbGVhbj8uZm9yVHJ1ZT8uaWNvbiB8fCAgJ2NoZWNrJztcbiAgZm9yRmFsc2VJY29uID0gKG1ldGFEYXRhIDogTWV0YURhdGEpIDogc3RyaW5nIHwgbnVsbCA9PiBcbiAgICBtZXRhRGF0YS5hZGRpdGlvbmFsPy5ib29sZWFuPy5zaG93Rm9yRmFsc2UgPT09IHRydWUgPyAnY2xlYXInXG4gICAgOiBtZXRhRGF0YS5hZGRpdGlvbmFsPy5ib29sZWFuPy5zaG93Rm9yRmFsc2U/Lmljb24gfHwgbnVsbDtcbiAgdXNlUm91dGVyTGluayA9IChtZXRhRGF0YSA6IE1ldGFEYXRhKSA9PiBtZXRhRGF0YS5hZGRpdGlvbmFsPy5saW5rPy51c2VSb3V0ZXJMaW5rIHx8IG1ldGFEYXRhLmFkZGl0aW9uYWw/LnVzZVJvdXRlckxpbms7XG4gIHRhcmdldCA9IChtZXRhRGF0YSA6IE1ldGFEYXRhKSA9PiBtZXRhRGF0YS5hZGRpdGlvbmFsPy5saW5rPy50YXJnZXQgfHwgbWV0YURhdGEuYWRkaXRpb25hbD8udGFyZ2V0IHx8ICdfYmxhbmsnO1xuICBiYXNlID0gKG1ldGFEYXRhIDogTWV0YURhdGEpID0+IG1ldGFEYXRhLmFkZGl0aW9uYWw/Lmxpbms/LmJhc2UgfHwgbWV0YURhdGEuYWRkaXRpb25hbD8uYmFzZTtcbiAga2V5ID0gKG1ldGFEYXRhIDogTWV0YURhdGEsIGVsZW1lbnQgOiBhbnkpID0+IG1ldGFEYXRhLmFkZGl0aW9uYWw/Lmxpbms/LnVybEtleSA/IGVsZW1lbnRbbWV0YURhdGEuYWRkaXRpb25hbD8ubGluaz8udXJsS2V5XSA6XG4gICAgbWV0YURhdGEuYWRkaXRpb25hbD8udXJsS2V5ID8gZWxlbWVudFttZXRhRGF0YS5hZGRpdGlvbmFsLnVybEtleV0gOiBlbGVtZW50W21ldGFEYXRhLmtleV1cblxufSIsIjxuZy10ZW1wbGF0ZSAjYm9vbGVhbiAgbGV0LWVsZW1lbnQ9J2VsZW1lbnQnIGxldC1tZXRhRGF0YT0nbWV0YURhdGEnPlxuICA8c3Bhbj5cbiAgICA8bWF0LWljb24gKm5nSWY9XCJlbGVtZW50W21ldGFEYXRhLmtleV1cIj5cbiAgICAgIHt7Zm9yVHJ1ZUljb24gfCBmdW5jICA6IG1ldGFEYXRhfX1cbiAgICA8L21hdC1pY29uPlxuICAgIDxtYXQtaWNvbiAqbmdJZj1cIiFlbGVtZW50W21ldGFEYXRhLmtleV1cIj5cbiAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIoZm9yRmFsc2VJY29uIHwgZnVuYyA6IG1ldGFEYXRhKSBhcyBpY29uXCI+XG4gICAgICAgIHt7aWNvbn19XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L21hdC1pY29uPlxuICA8L3NwYW4+XG48L25nLXRlbXBsYXRlPlxuPG5nLXRlbXBsYXRlICNsaW5rICBsZXQtZWxlbWVudD0nZWxlbWVudCcgbGV0LW1ldGFEYXRhPSdtZXRhRGF0YSc+XG4gIDxhICpuZ0lmPVwidXNlUm91dGVyTGluayB8IGZ1bmMgOiBtZXRhRGF0YTsgZWxzZSBocmVmTGlua1wiIHRhcmdldD1cInt7dGFyZ2V0IHwgZnVuYyA6IG1ldGFEYXRhIH19XCJcbiAgICBbcm91dGVyTGlua109XCJbKGJhc2UgfCBmdW5jIDogbWV0YURhdGEpLCAoa2V5IHwgZnVuYyA6IG1ldGFEYXRhIDogZWxlbWVudCldXCI+XG4gICAge3tlbGVtZW50W21ldGFEYXRhLmtleV19fVxuICA8L2E+XG4gIDxuZy10ZW1wbGF0ZSAjaHJlZkxpbms+XG4gICAgPGEgdGFyZ2V0PVwie3t0YXJnZXQgfCBmdW5jIDogbWV0YURhdGF9fVwiXG4gICAgICBocmVmPVwie3soYmFzZSB8IGZ1bmMgOiBtZXRhRGF0YSl9fXt7KGtleSB8IGZ1bmMgOiBtZXRhRGF0YSA6IGVsZW1lbnQpfX1cIj5cbiAgICAgIHt7ZWxlbWVudFttZXRhRGF0YS5rZXldfX1cbiAgICA8L2E+XG4gIDwvbmctdGVtcGxhdGU+XG48L25nLXRlbXBsYXRlPlxuPG5nLXRlbXBsYXRlICNpbWFnZVVybCAgbGV0LWVsZW1lbnQ9J2VsZW1lbnQnIGxldC1tZXRhRGF0YT0nbWV0YURhdGEnPlxuICA8c3Bhbj5cbiAgICA8aW1nIHNyYz1cInt7ZWxlbWVudFttZXRhRGF0YS5rZXldfX1cIiBoZWlnaHQ9XCI3NXB4XCIgd2lkdGg9XCI3NXB4XCIgLz5cbiAgPC9zcGFuPlxuPC9uZy10ZW1wbGF0ZT5cbjxuZy10ZW1wbGF0ZSAjY3VycmVuY3kgIGxldC1lbGVtZW50PSdlbGVtZW50JyBsZXQtbWV0YURhdGE9J21ldGFEYXRhJyA+XG4gIDxzcGFuIFtjbGFzcy5uZWdhdGl2ZS1jdXJyZW5jeV09XCJlbGVtZW50W21ldGFEYXRhLmtleV0gPCAwXCI+XG4gICAge3sgZWxlbWVudFttZXRhRGF0YS5rZXldIHwgY3VycmVuY3kgfX1cbiAgPC9zcGFuPlxuPC9uZy10ZW1wbGF0ZT5cbjxuZy10ZW1wbGF0ZSAjYXJyYXkgbGV0LWVsZW1lbnQ9J2VsZW1lbnQnIGxldC1tZXRhRGF0YT0nbWV0YURhdGEnPlxuICA8dGItYXJyYXktY29sdW1uIFthcnJheV09J2VsZW1lbnRbbWV0YURhdGEua2V5XScgW21ldGFEYXRhXT0nbWV0YURhdGEnPjwvdGItYXJyYXktY29sdW1uPlxuPC9uZy10ZW1wbGF0ZT5cbjxuZy10ZW1wbGF0ZSAjZXhwcmVzc2lvbiBsZXQtZWxlbWVudD0nZWxlbWVudCcgbGV0LW1ldGFEYXRhPSdtZXRhRGF0YSc+XG4gIDxzcGFuPnt7IG1ldGFEYXRhLnRyYW5zZm9ybSB8IGZ1bmMgOiBlbGVtZW50IH19PC9zcGFuPlxuPC9uZy10ZW1wbGF0ZT5cbjxuZy10ZW1wbGF0ZSAjZW51bSBsZXQtZWxlbWVudD0nZWxlbWVudCcgbGV0LW1ldGFEYXRhPSdtZXRhRGF0YScgPlxuICA8c3Bhbj57eyBtZXRhRGF0YS5hZGRpdGlvbmFsLmVudW1NYXBbZWxlbWVudFttZXRhRGF0YS5rZXldXSB8IHNwYWNlQ2FzZSB9fTwvc3Bhbj5cbjwvbmctdGVtcGxhdGU+XG48bmctdGVtcGxhdGUgI2RlZmF1bHQgbGV0LWVsZW1lbnQ9J2VsZW1lbnQnIGxldC1tZXRhRGF0YT0nbWV0YURhdGEnIGxldC10cmFuc2Zvcm09J3RyYW5zZm9ybSc+XG4gIDxzcGFuPnt7IHRyYW5zZm9ybSB8IGZ1bmMgOiBlbGVtZW50W21ldGFEYXRhLmtleV0gfX08L3NwYW4+XG48L25nLXRlbXBsYXRlPlxuIl19
61
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"initialization-component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/initialization-component/initialization-component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/initialization-component/initialization-component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, TemplateRef, ViewChild } from \"@angular/core\";\nimport { MetaData, Route } from \"../../interfaces/report-def\";\n\n@Component({\n  templateUrl: './initialization-component.html'\n})\nexport class InitializationComponent {\n  @ViewChild('boolean', {static: true}) booleanTemplate! : TemplateRef<any>;\n  @ViewChild('link', {static: true}) linkTemplate! : TemplateRef<any>;\n  @ViewChild('imageUrl', {static: true}) imageUrlTemplate! : TemplateRef<any>;\n  @ViewChild('currency', {static: true}) currencyTemplate! : TemplateRef<any>;\n  @ViewChild('array', {static: true}) arrayTemplate! : TemplateRef<any>;\n  @ViewChild('expression', {static: true}) expressionTemplate! : TemplateRef<any>;\n  @ViewChild('default', {static: true}) defaultTemplate! : TemplateRef<any>;\n  @ViewChild('enum', {static: true}) enumTemplate! : TemplateRef<any>;\n  forTrueIcon = (metaData : MetaData) => metaData.additional?.boolean?.forTrue?.icon ||  'check';\n  forFalseIcon = (metaData : MetaData) : string | null => \n    metaData.additional?.boolean?.showForFalse === true ? 'clear'\n    : metaData.additional?.boolean?.showForFalse?.icon || null;\n  useRouterLink = (metaData : MetaData) => metaData.additional?.link?.useRouterLink || metaData.additional?.useRouterLink;\n  target = (metaData : MetaData) => metaData.additional?.link?.target || metaData.additional?.target || '_blank';\n  base = (metaData : MetaData, element : any) => metaData.additional?.link?.route\n    ? this.parseInterpolatedRoute(metaData.additional.link.route, element)\n    : ( metaData.additional?.link?.base || metaData.additional?.base);\n  key = (metaData : MetaData, element : any) => metaData.additional?.link?.urlKey ? element[metaData.additional?.link?.urlKey] :\n    metaData.additional?.urlKey ? element[metaData.additional.urlKey] : metaData.additional?.link?.route ? '' : element[metaData.key];\n\n  parseInterpolatedRoute = ( route: Route, element: any ) => {\n    let interpolated = route?.interpolated || '';\n    const dict = route?.params || {};\n    Object.keys(dict).forEach(key => {\n      interpolated = interpolated.replace(`{${key}}`, element[dict[key]]);\n    });\n    return interpolated;\n  }\n\n}","<ng-template #boolean  let-element='element' let-metaData='metaData'>\n  <span>\n    <mat-icon *ngIf=\"element[metaData.key]\">\n      {{forTrueIcon | func  : metaData}}\n    </mat-icon>\n    <mat-icon *ngIf=\"!element[metaData.key]\">\n      <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n        {{icon}}\n      </ng-container>\n    </mat-icon>\n  </span>\n</ng-template>\n<ng-template #link  let-element='element' let-metaData='metaData'>\n  <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n    [routerLink]=\"[(base | func : metaData : element), (key | func : metaData : element)]\">\n    {{element[metaData.key]}}\n  </a>\n  <ng-template #hrefLink>\n    <a target=\"{{target | func : metaData}}\"\n      href=\"{{(base | func : metaData : element)}}{{(key | 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<ng-template #currency  let-element='element' let-metaData='metaData' >\n  <span [class.negative-currency]=\"element[metaData.key] < 0\">\n    {{ element[metaData.key] | currency }}\n  </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n  <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n  <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n  <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n"]}
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LWRlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2ludGVyZmFjZXMvcmVwb3J0LWRlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLENBQU4sSUFBWSxTQWNYO0FBZEQsV0FBWSxTQUFTO0lBQ2pCLCtDQUFXLENBQUE7SUFDWCx5Q0FBUSxDQUFBO0lBQ1IseUNBQVEsQ0FBQTtJQUNSLGlEQUFZLENBQUE7SUFDWixpREFBWSxDQUFBO0lBQ1osMkNBQVMsQ0FBQTtJQUNULDZDQUFVLENBQUE7SUFDViw2Q0FBVSxDQUFBO0lBQ1YsNkNBQVUsQ0FBQTtJQUNWLCtDQUFXLENBQUE7SUFDWCx3REFBZ0IsQ0FBQTtJQUNoQixzREFBZSxDQUFBO0lBQ2YsMENBQVMsQ0FBQTtBQUNiLENBQUMsRUFkVyxTQUFTLEtBQVQsU0FBUyxRQWNwQjtBQUVELE1BQU0sQ0FBTixJQUFZLGFBR1g7QUFIRCxXQUFZLGFBQWE7SUFDckIsNEJBQVUsQ0FBQTtJQUNWLDhCQUFZLENBQUE7QUFDaEIsQ0FBQyxFQUhXLGFBQWEsS0FBYixhQUFhLFFBR3hCO0FBRUQsTUFBTSxDQUFOLElBQVksTUFLWDtBQUxELFdBQVksTUFBTTtJQUNoQiwwQkFBZ0IsQ0FBQTtJQUNoQix3QkFBYyxDQUFBO0lBQ2QsNEJBQWtCLENBQUE7SUFDbEIsc0JBQVksQ0FBQTtBQUNkLENBQUMsRUFMVyxNQUFNLEtBQU4sTUFBTSxRQUtqQjtBQTJFRCxNQUFNLENBQU4sSUFBWSxVQUdYO0FBSEQsV0FBWSxVQUFVO0lBQ3BCLCtEQUFjLENBQUE7SUFDZCxpREFBTyxDQUFBO0FBQ1QsQ0FBQyxFQUhXLFVBQVUsS0FBVixVQUFVLFFBR3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGljdGlvbmFyeSB9IGZyb20gJy4vZGljdGlvbmFyeSc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGFibGVCdWlsZGVyRXhwb3J0IH0gZnJvbSAnLi4vY2xhc3Nlcy9UYWJsZUJ1aWxkZXJDb25maWcnO1xuXG5cbmV4cG9ydCBlbnVtIEZpZWxkVHlwZSB7XG4gICAgVW5rbm93biA9IDAsXG4gICAgRGF0ZSA9IDEsXG4gICAgTGluayA9IDIsXG4gICAgSW1hZ2VVcmwgPSAzLFxuICAgIEN1cnJlbmN5ID0gNCxcbiAgICBBcnJheSA9IDUsXG4gICAgSGlkZGVuID0gNixcbiAgICBOdW1iZXIgPSA3LFxuICAgIFN0cmluZyA9IDgsXG4gICAgQm9vbGVhbiA9IDksXG4gICAgUGhvbmVOdW1iZXIgPSAxMCxcbiAgICBFeHByZXNzaW9uID0gMTEsXG4gICAgRW51bSA9IDEyLFxufVxuXG5leHBvcnQgZW51bSBTb3J0RGlyZWN0aW9uIHtcbiAgICBhc2M9ICdhc2MnLFxuICAgIGRlc2M9ICdkZXNjJ1xufVxuXG5leHBvcnQgZW51bSBUYXJnZXQge1xuICBCbGFuayA9ICdfYmxhbmsnLFxuICBTZWxmID0gJ19zZWxmJyxcbiAgUGFyZW50ID0gJ19wYXJlbnQnLFxuICBUb3AgPSAnX3RvcCdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXRhRGF0YTxUID0gYW55LCBBZGRpdGlvbmFsRmllbGRzIGV4dGVuZHMgc3RyaW5nW10gPSBbXT4ge1xuICBrZXk6IChrZXlvZiBUIHwgQWRkaXRpb25hbEZpZWxkc1tudW1iZXJdKSAmIHN0cmluZztcbiAgZGlzcGxheU5hbWU/OiBzdHJpbmc7XG4gIGZpZWxkVHlwZTogRmllbGRUeXBlO1xuICBhZGRpdGlvbmFsPzogQWRkaXRpb25hbDtcbiAgb3JkZXI/OiBudW1iZXI7XG4gIHByZVNvcnQ/OiBTb3J0RGVmO1xuICBfaW50ZXJuYWxOb3RVc2VyRGVmaW5lZD86IGJvb2xlYW47XG4gIHdpZHRoPzogc3RyaW5nO1xuICBub0V4cG9ydD86IGJvb2xlYW47XG4gIG5vRmlsdGVyPzogYm9vbGVhbjtcbiAgY3VzdG9tQ2VsbD86IGJvb2xlYW47XG4gIHRyYW5zZm9ybT86ICgobzogVCwgLi4uYXJnczogYW55W10pPT4gYW55KSB8ICgobzogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk9PiBhbnkpIHwgUGlwZVRyYW5zZm9ybTtcbiAgY2xpY2s/OiAoZWxlbWVudDogVCwga2V5OiBzdHJpbmcgKSA9PiB2b2lkO1xuICB0ZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XG59XG5leHBvcnQgaW50ZXJmYWNlICBSZXBvcnREZWY8RGF0YVR5cGUgPSBhbnk+IHtcbiAgICBkYXRhOiBEYXRhVHlwZVtdO1xuICAgIG1ldGFEYXRhOiBNZXRhRGF0YSBbXTtcbiAgICB0b3RhbFJlY29yZHM/OiBudW1iZXI7XG4gICAgY291bnQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTb3J0RGVmIHtcbiAgICBkaXJlY3Rpb246IFNvcnREaXJlY3Rpb247XG4gICAgcHJlY2VkZW5jZT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGaWx0ZXJPcHRpb25zIHtcbiAgZmlsdGVyYWJsZVZhbHVlcyA6IHN0cmluZ1tdXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWRkaXRpb25hbCAgIHtcbiAgbGluaz8gOiB7XG4gICAgYmFzZT86IHN0cmluZztcbiAgICB1cmxLZXk/OiBzdHJpbmc7XG4gICAgdGFyZ2V0PzogVGFyZ2V0O1xuICAgIHVzZVJvdXRlckxpbms/OiBib29sZWFuO1xuICB9XG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBQbGVhc2UgdXNlIGxpbmsuYmFzZVxuICAgKi9cbiAgYmFzZT86IHN0cmluZztcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIFBsZWFzZSB1c2UgbGluay51cmxLZXlcbiAgICovXG4gIHVybEtleT86IHN0cmluZztcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIFBsZWFzZSB1c2UgbGluay50YXJnZXRcbiAgICovXG4gIHRhcmdldD86IFRhcmdldDtcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIFBsZWFzZSB1c2UgbGluay51c2VSb3V0ZXJMaW5rXG4gICAqL1xuICB1c2VSb3V0ZXJMaW5rPzogYm9vbGVhbjtcbiAgZm9vdGVyPzogeyB0eXBlOiAnc3VtJyB9O1xuICBncm91cGluZz86IHsgZ3JvdXBCeT86IGJvb2xlYW4sIHN1bT86IGJvb2xlYW47IGdyb3VwVGl0bGVGbj86ICh2YWw6IGFueSkgPT4gc3RyaW5nIH1cbiAgZXhwb3J0PzogVGFibGVCdWlsZGVyRXhwb3J0O1xuICBkYXRlRm9ybWF0Pzogc3RyaW5nO1xuICBmaWx0ZXJPcHRpb25zPzogRmlsdGVyT3B0aW9ucztcbiAgc3R5bGVzPzogRGljdGlvbmFyeTxzdHJpbmc+O1xuICBjb2x1bW5QYXJ0U3R5bGVzPzoge1xuICAgIGhlYWRlcj86IERpY3Rpb25hcnk8c3RyaW5nPixcbiAgICBib2R5PzogRGljdGlvbmFyeTxzdHJpbmc+LFxuICAgIGZvb3Rlcj86IERpY3Rpb25hcnk8c3RyaW5nPixcbiAgfVxuICBlbnVtTWFwPzoge1trZXk6bnVtYmVyXTpzdHJpbmd9O1xuICBib29sZWFuPyA6IHtcbiAgICBzaG93Rm9yRmFsc2U/IDogdHJ1ZSB8IHsgaWNvbiA6IHN0cmluZyB9LFxuICAgIGZvclRydWU/IDogeyBpY29uIDogc3RyaW5nIH1cbiAgfVxufVxuXG5leHBvcnQgZW51bSBBcnJheVN0eWxlIHtcbiAgQ29tbWFEZWxpbWl0ZWQsXG4gIE5ld0xpbmVcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBcnJheUFkZGl0aW9uYWwgZXh0ZW5kcyBBZGRpdGlvbmFsIHtcbiAgICBtZXRhRGF0YT86IE1ldGFEYXRhO1xuICAgIGxpbWl0PzogbnVtYmVyO1xuICAgIGFycmF5U3R5bGU/OiBBcnJheVN0eWxlO1xufVxuIl19
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LWRlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2ludGVyZmFjZXMvcmVwb3J0LWRlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLENBQU4sSUFBWSxTQWNYO0FBZEQsV0FBWSxTQUFTO0lBQ2pCLCtDQUFXLENBQUE7SUFDWCx5Q0FBUSxDQUFBO0lBQ1IseUNBQVEsQ0FBQTtJQUNSLGlEQUFZLENBQUE7SUFDWixpREFBWSxDQUFBO0lBQ1osMkNBQVMsQ0FBQTtJQUNULDZDQUFVLENBQUE7SUFDViw2Q0FBVSxDQUFBO0lBQ1YsNkNBQVUsQ0FBQTtJQUNWLCtDQUFXLENBQUE7SUFDWCx3REFBZ0IsQ0FBQTtJQUNoQixzREFBZSxDQUFBO0lBQ2YsMENBQVMsQ0FBQTtBQUNiLENBQUMsRUFkVyxTQUFTLEtBQVQsU0FBUyxRQWNwQjtBQUVELE1BQU0sQ0FBTixJQUFZLGFBR1g7QUFIRCxXQUFZLGFBQWE7SUFDckIsNEJBQVUsQ0FBQTtJQUNWLDhCQUFZLENBQUE7QUFDaEIsQ0FBQyxFQUhXLGFBQWEsS0FBYixhQUFhLFFBR3hCO0FBRUQsTUFBTSxDQUFOLElBQVksTUFLWDtBQUxELFdBQVksTUFBTTtJQUNoQiwwQkFBZ0IsQ0FBQTtJQUNoQix3QkFBYyxDQUFBO0lBQ2QsNEJBQWtCLENBQUE7SUFDbEIsc0JBQVksQ0FBQTtBQUNkLENBQUMsRUFMVyxNQUFNLEtBQU4sTUFBTSxRQUtqQjtBQTRFRCxNQUFNLENBQU4sSUFBWSxVQUdYO0FBSEQsV0FBWSxVQUFVO0lBQ3BCLCtEQUFjLENBQUE7SUFDZCxpREFBTyxDQUFBO0FBQ1QsQ0FBQyxFQUhXLFVBQVUsS0FBVixVQUFVLFFBR3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGljdGlvbmFyeSB9IGZyb20gJy4vZGljdGlvbmFyeSc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGFibGVCdWlsZGVyRXhwb3J0IH0gZnJvbSAnLi4vY2xhc3Nlcy9UYWJsZUJ1aWxkZXJDb25maWcnO1xuXG5cbmV4cG9ydCBlbnVtIEZpZWxkVHlwZSB7XG4gICAgVW5rbm93biA9IDAsXG4gICAgRGF0ZSA9IDEsXG4gICAgTGluayA9IDIsXG4gICAgSW1hZ2VVcmwgPSAzLFxuICAgIEN1cnJlbmN5ID0gNCxcbiAgICBBcnJheSA9IDUsXG4gICAgSGlkZGVuID0gNixcbiAgICBOdW1iZXIgPSA3LFxuICAgIFN0cmluZyA9IDgsXG4gICAgQm9vbGVhbiA9IDksXG4gICAgUGhvbmVOdW1iZXIgPSAxMCxcbiAgICBFeHByZXNzaW9uID0gMTEsXG4gICAgRW51bSA9IDEyLFxufVxuXG5leHBvcnQgZW51bSBTb3J0RGlyZWN0aW9uIHtcbiAgICBhc2M9ICdhc2MnLFxuICAgIGRlc2M9ICdkZXNjJ1xufVxuXG5leHBvcnQgZW51bSBUYXJnZXQge1xuICBCbGFuayA9ICdfYmxhbmsnLFxuICBTZWxmID0gJ19zZWxmJyxcbiAgUGFyZW50ID0gJ19wYXJlbnQnLFxuICBUb3AgPSAnX3RvcCdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXRhRGF0YTxUID0gYW55LCBBZGRpdGlvbmFsRmllbGRzIGV4dGVuZHMgc3RyaW5nW10gPSBbXT4ge1xuICBrZXk6IChrZXlvZiBUIHwgQWRkaXRpb25hbEZpZWxkc1tudW1iZXJdKSAmIHN0cmluZztcbiAgZGlzcGxheU5hbWU/OiBzdHJpbmc7XG4gIGZpZWxkVHlwZTogRmllbGRUeXBlO1xuICBhZGRpdGlvbmFsPzogQWRkaXRpb25hbDxUPjtcbiAgb3JkZXI/OiBudW1iZXI7XG4gIHByZVNvcnQ/OiBTb3J0RGVmO1xuICBfaW50ZXJuYWxOb3RVc2VyRGVmaW5lZD86IGJvb2xlYW47XG4gIHdpZHRoPzogc3RyaW5nO1xuICBub0V4cG9ydD86IGJvb2xlYW47XG4gIG5vRmlsdGVyPzogYm9vbGVhbjtcbiAgY3VzdG9tQ2VsbD86IGJvb2xlYW47XG4gIHRyYW5zZm9ybT86ICgobzogVCwgLi4uYXJnczogYW55W10pPT4gYW55KSB8ICgobzogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk9PiBhbnkpIHwgUGlwZVRyYW5zZm9ybTtcbiAgY2xpY2s/OiAoZWxlbWVudDogVCwga2V5OiBzdHJpbmcgKSA9PiB2b2lkO1xuICB0ZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XG59XG5leHBvcnQgaW50ZXJmYWNlICBSZXBvcnREZWY8RGF0YVR5cGUgPSBhbnk+IHtcbiAgICBkYXRhOiBEYXRhVHlwZVtdO1xuICAgIG1ldGFEYXRhOiBNZXRhRGF0YSBbXTtcbiAgICB0b3RhbFJlY29yZHM/OiBudW1iZXI7XG4gICAgY291bnQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTb3J0RGVmIHtcbiAgICBkaXJlY3Rpb246IFNvcnREaXJlY3Rpb247XG4gICAgcHJlY2VkZW5jZT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGaWx0ZXJPcHRpb25zIHtcbiAgZmlsdGVyYWJsZVZhbHVlcyA6IHN0cmluZ1tdXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWRkaXRpb25hbDxUID0gYW55PiB7XG4gIGxpbms/IDoge1xuICAgIGJhc2U/OiBzdHJpbmc7XG4gICAgdXJsS2V5Pzogc3RyaW5nO1xuICAgIHRhcmdldD86IFRhcmdldDtcbiAgICB1c2VSb3V0ZXJMaW5rPzogYm9vbGVhbjtcbiAgICByb3V0ZT86IFJvdXRlPFQ+XG4gIH1cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIFBsZWFzZSB1c2UgbGluay5iYXNlXG4gICAqL1xuICBiYXNlPzogc3RyaW5nO1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgUGxlYXNlIHVzZSBsaW5rLnVybEtleVxuICAgKi9cbiAgdXJsS2V5Pzogc3RyaW5nO1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgUGxlYXNlIHVzZSBsaW5rLnRhcmdldFxuICAgKi9cbiAgdGFyZ2V0PzogVGFyZ2V0O1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgUGxlYXNlIHVzZSBsaW5rLnVzZVJvdXRlckxpbmtcbiAgICovXG4gIHVzZVJvdXRlckxpbms/OiBib29sZWFuO1xuICBmb290ZXI/OiB7IHR5cGU6ICdzdW0nIH07XG4gIGdyb3VwaW5nPzogeyBncm91cEJ5PzogYm9vbGVhbiwgc3VtPzogYm9vbGVhbjsgZ3JvdXBUaXRsZUZuPzogKHZhbDogYW55KSA9PiBzdHJpbmcgfVxuICBleHBvcnQ/OiBUYWJsZUJ1aWxkZXJFeHBvcnQ7XG4gIGRhdGVGb3JtYXQ/OiBzdHJpbmc7XG4gIGZpbHRlck9wdGlvbnM/OiBGaWx0ZXJPcHRpb25zO1xuICBzdHlsZXM/OiBEaWN0aW9uYXJ5PHN0cmluZz47XG4gIGNvbHVtblBhcnRTdHlsZXM/OiB7XG4gICAgaGVhZGVyPzogRGljdGlvbmFyeTxzdHJpbmc+LFxuICAgIGJvZHk/OiBEaWN0aW9uYXJ5PHN0cmluZz4sXG4gICAgZm9vdGVyPzogRGljdGlvbmFyeTxzdHJpbmc+LFxuICB9XG4gIGVudW1NYXA/OiB7W2tleTpudW1iZXJdOnN0cmluZ307XG4gIGJvb2xlYW4/IDoge1xuICAgIHNob3dGb3JGYWxzZT8gOiB0cnVlIHwgeyBpY29uIDogc3RyaW5nIH0sXG4gICAgZm9yVHJ1ZT8gOiB7IGljb24gOiBzdHJpbmcgfVxuICB9XG59XG5cbmV4cG9ydCBlbnVtIEFycmF5U3R5bGUge1xuICBDb21tYURlbGltaXRlZCxcbiAgTmV3TGluZVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFycmF5QWRkaXRpb25hbCBleHRlbmRzIEFkZGl0aW9uYWwge1xuICAgIG1ldGFEYXRhPzogTWV0YURhdGE7XG4gICAgbGltaXQ/OiBudW1iZXI7XG4gICAgYXJyYXlTdHlsZT86IEFycmF5U3R5bGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUm91dGU8VCA9IGFueT57XG4gIGludGVycG9sYXRlZDogc3RyaW5nO1xuICBwYXJhbXM6IERpY3Rpb25hcnk8a2V5b2YgVD47XG59Il19
@@ -1339,19 +1339,32 @@ class InitializationComponent {
1339
1339
  };
1340
1340
  this.useRouterLink = (metaData) => { var _a, _b, _c; return ((_b = (_a = metaData.additional) === null || _a === void 0 ? void 0 : _a.link) === null || _b === void 0 ? void 0 : _b.useRouterLink) || ((_c = metaData.additional) === null || _c === void 0 ? void 0 : _c.useRouterLink); };
1341
1341
  this.target = (metaData) => { var _a, _b, _c; return ((_b = (_a = metaData.additional) === null || _a === void 0 ? void 0 : _a.link) === null || _b === void 0 ? void 0 : _b.target) || ((_c = metaData.additional) === null || _c === void 0 ? void 0 : _c.target) || '_blank'; };
1342
- this.base = (metaData) => { var _a, _b, _c; return ((_b = (_a = metaData.additional) === null || _a === void 0 ? void 0 : _a.link) === null || _b === void 0 ? void 0 : _b.base) || ((_c = metaData.additional) === null || _c === void 0 ? void 0 : _c.base); };
1343
- this.key = (metaData, element) => {
1342
+ this.base = (metaData, element) => {
1344
1343
  var _a, _b, _c, _d, _e;
1344
+ return ((_b = (_a = metaData.additional) === null || _a === void 0 ? void 0 : _a.link) === null || _b === void 0 ? void 0 : _b.route)
1345
+ ? this.parseInterpolatedRoute(metaData.additional.link.route, element)
1346
+ : (((_d = (_c = metaData.additional) === null || _c === void 0 ? void 0 : _c.link) === null || _d === void 0 ? void 0 : _d.base) || ((_e = metaData.additional) === null || _e === void 0 ? void 0 : _e.base));
1347
+ };
1348
+ this.key = (metaData, element) => {
1349
+ var _a, _b, _c, _d, _e, _f, _g;
1345
1350
  return ((_b = (_a = metaData.additional) === null || _a === void 0 ? void 0 : _a.link) === null || _b === void 0 ? void 0 : _b.urlKey) ? element[(_d = (_c = metaData.additional) === null || _c === void 0 ? void 0 : _c.link) === null || _d === void 0 ? void 0 : _d.urlKey] :
1346
- ((_e = metaData.additional) === null || _e === void 0 ? void 0 : _e.urlKey) ? element[metaData.additional.urlKey] : element[metaData.key];
1351
+ ((_e = metaData.additional) === null || _e === void 0 ? void 0 : _e.urlKey) ? element[metaData.additional.urlKey] : ((_g = (_f = metaData.additional) === null || _f === void 0 ? void 0 : _f.link) === null || _g === void 0 ? void 0 : _g.route) ? '' : element[metaData.key];
1352
+ };
1353
+ this.parseInterpolatedRoute = (route, element) => {
1354
+ let interpolated = (route === null || route === void 0 ? void 0 : route.interpolated) || '';
1355
+ const dict = (route === null || route === void 0 ? void 0 : route.params) || {};
1356
+ Object.keys(dict).forEach(key => {
1357
+ interpolated = interpolated.replace(`{${key}}`, element[dict[key]]);
1358
+ });
1359
+ return interpolated;
1347
1360
  };
1348
1361
  }
1349
1362
  }
1350
1363
  InitializationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: InitializationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1351
- InitializationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", type: InitializationComponent, selector: "ng-component", viewQueries: [{ propertyName: "booleanTemplate", first: true, predicate: ["boolean"], descendants: true, static: true }, { 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: "expressionTemplate", first: true, predicate: ["expression"], descendants: true, static: true }, { propertyName: "defaultTemplate", first: true, predicate: ["default"], descendants: true, static: true }, { propertyName: "enumTemplate", first: true, predicate: ["enum"], descendants: true, static: true }], ngImport: i0, template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n", components: [{ type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: ArrayColumnComponent, selector: "tb-array-column", inputs: ["array", "metaData"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4$1.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }], pipes: { "func": FunctionPipe, "currency": i1.CurrencyPipe, "spaceCase": SpaceCasePipe } });
1364
+ InitializationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", type: InitializationComponent, selector: "ng-component", viewQueries: [{ propertyName: "booleanTemplate", first: true, predicate: ["boolean"], descendants: true, static: true }, { 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: "expressionTemplate", first: true, predicate: ["expression"], descendants: true, static: true }, { propertyName: "defaultTemplate", first: true, predicate: ["default"], descendants: true, static: true }, { propertyName: "enumTemplate", first: true, predicate: ["enum"], descendants: true, static: true }], ngImport: i0, template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData : element), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData : element)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n", components: [{ type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: ArrayColumnComponent, selector: "tb-array-column", inputs: ["array", "metaData"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4$1.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }], pipes: { "func": FunctionPipe, "currency": i1.CurrencyPipe, "spaceCase": SpaceCasePipe } });
1352
1365
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: InitializationComponent, decorators: [{
1353
1366
  type: Component,
1354
- args: [{ template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n" }]
1367
+ args: [{ template: "<ng-template #boolean let-element='element' let-metaData='metaData'>\n <span>\n <mat-icon *ngIf=\"element[metaData.key]\">\n {{forTrueIcon | func : metaData}}\n </mat-icon>\n <mat-icon *ngIf=\"!element[metaData.key]\">\n <ng-container *ngIf=\"(forFalseIcon | func : metaData) as icon\">\n {{icon}}\n </ng-container>\n </mat-icon>\n </span>\n</ng-template>\n<ng-template #link let-element='element' let-metaData='metaData'>\n <a *ngIf=\"useRouterLink | func : metaData; else hrefLink\" target=\"{{target | func : metaData }}\"\n [routerLink]=\"[(base | func : metaData : element), (key | func : metaData : element)]\">\n {{element[metaData.key]}}\n </a>\n <ng-template #hrefLink>\n <a target=\"{{target | func : metaData}}\"\n href=\"{{(base | func : metaData : element)}}{{(key | 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<ng-template #currency let-element='element' let-metaData='metaData' >\n <span [class.negative-currency]=\"element[metaData.key] < 0\">\n {{ element[metaData.key] | currency }}\n </span>\n</ng-template>\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<ng-template #expression let-element='element' let-metaData='metaData'>\n <span>{{ metaData.transform | func : element }}</span>\n</ng-template>\n<ng-template #enum let-element='element' let-metaData='metaData' >\n <span>{{ metaData.additional.enumMap[element[metaData.key]] | spaceCase }}</span>\n</ng-template>\n<ng-template #default let-element='element' let-metaData='metaData' let-transform='transform'>\n <span>{{ transform | func : element[metaData.key] }}</span>\n</ng-template>\n" }]
1355
1368
  }], propDecorators: { booleanTemplate: [{
1356
1369
  type: ViewChild,
1357
1370
  args: ['boolean', { static: true }]