@elderbyte/ngx-starter 16.4.7 → 16.5.0

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.
@@ -2,10 +2,11 @@ export class ParseUtil {
2
2
  /**
3
3
  * Tries to parse a given value to a boolean.
4
4
  * @param bool a value representing a boolean state.
5
- * @return undefined, if the value is null or undefined, false, if the value is false, else true.
5
+ * @return undefined, if the value is null/undefined/empty
6
+ * @return false, if the value is false, else true.
6
7
  */
7
- static parseBoolean(bool) {
8
- if (bool === undefined || bool == null) {
8
+ static parseBoolOrUndefined(bool) {
9
+ if (bool === undefined || bool === null || bool === '') {
9
10
  return undefined;
10
11
  }
11
12
  else {
@@ -13,4 +14,4 @@ export class ParseUtil {
13
14
  }
14
15
  }
15
16
  }
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2UtdXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi91dGlscy9wYXJzZS11dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxTQUFTO0lBRXBCOzs7O09BSUc7SUFDSSxNQUFNLENBQUMsWUFBWSxDQUFDLElBQVM7UUFFaEMsSUFBSSxJQUFJLEtBQUssU0FBUyxJQUFJLElBQUksSUFBSSxJQUFJLEVBQUU7WUFDdEMsT0FBTyxTQUFTLENBQUM7U0FDbEI7YUFBTTtZQUNMLE9BQU8sQ0FBQyxDQUFDLElBQUksS0FBSyxPQUFPLElBQUksSUFBSSxLQUFLLEtBQUssQ0FBQyxDQUFDO1NBQzlDO0lBQ0gsQ0FBQztDQUVKIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIFBhcnNlVXRpbCB7XG5cbiAgLyoqXG4gICAqIFRyaWVzIHRvIHBhcnNlIGEgZ2l2ZW4gdmFsdWUgdG8gYSBib29sZWFuLlxuICAgKiBAcGFyYW0gYm9vbCBhIHZhbHVlIHJlcHJlc2VudGluZyBhIGJvb2xlYW4gc3RhdGUuXG4gICAqIEByZXR1cm4gdW5kZWZpbmVkLCBpZiB0aGUgdmFsdWUgaXMgbnVsbCBvciB1bmRlZmluZWQsIGZhbHNlLCBpZiB0aGUgdmFsdWUgaXMgZmFsc2UsIGVsc2UgdHJ1ZS5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgcGFyc2VCb29sZWFuKGJvb2w6IGFueSk6IGJvb2xlYW4ge1xuXG4gICAgICBpZiAoYm9vbCA9PT0gdW5kZWZpbmVkIHx8IGJvb2wgPT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuICEoYm9vbCA9PT0gJ2ZhbHNlJyB8fCBib29sID09PSBmYWxzZSk7XG4gICAgICB9XG4gICAgfVxuXG59XG4iXX0=
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2UtdXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi91dGlscy9wYXJzZS11dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxTQUFTO0lBRXBCOzs7OztPQUtHO0lBQ0ksTUFBTSxDQUFDLG9CQUFvQixDQUFDLElBQVM7UUFDMUMsSUFBSSxJQUFJLEtBQUssU0FBUyxJQUFJLElBQUksS0FBSyxJQUFJLElBQUksSUFBSSxLQUFLLEVBQUUsRUFBRTtZQUN0RCxPQUFPLFNBQVMsQ0FBQztTQUNsQjthQUFNO1lBQ0wsT0FBTyxDQUFDLENBQUMsSUFBSSxLQUFLLE9BQU8sSUFBSSxJQUFJLEtBQUssS0FBSyxDQUFDLENBQUM7U0FDOUM7SUFDSCxDQUFDO0NBRUYiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgUGFyc2VVdGlsIHtcblxuICAvKipcbiAgICogVHJpZXMgdG8gcGFyc2UgYSBnaXZlbiB2YWx1ZSB0byBhIGJvb2xlYW4uXG4gICAqIEBwYXJhbSBib29sIGEgdmFsdWUgcmVwcmVzZW50aW5nIGEgYm9vbGVhbiBzdGF0ZS5cbiAgICogQHJldHVybiB1bmRlZmluZWQsIGlmIHRoZSB2YWx1ZSBpcyBudWxsL3VuZGVmaW5lZC9lbXB0eVxuICAgKiBAcmV0dXJuIGZhbHNlLCBpZiB0aGUgdmFsdWUgaXMgZmFsc2UsIGVsc2UgdHJ1ZS5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgcGFyc2VCb29sT3JVbmRlZmluZWQoYm9vbDogYW55KTogYm9vbGVhbiB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKGJvb2wgPT09IHVuZGVmaW5lZCB8fCBib29sID09PSBudWxsIHx8IGJvb2wgPT09ICcnKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gIShib29sID09PSAnZmFsc2UnIHx8IGJvb2wgPT09IGZhbHNlKTtcbiAgICB9XG4gIH1cblxufVxuIl19
@@ -1,39 +1,154 @@
1
- import { ChangeDetectionStrategy, Component, Input, ViewEncapsulation } from "@angular/core";
2
- import { BehaviorSubject } from "rxjs";
1
+ import { ChangeDetectionStrategy, Component, ContentChild, Directive, Input, TemplateRef, ViewEncapsulation } from '@angular/core';
2
+ import { BehaviorSubject, combineLatest } from 'rxjs';
3
+ import { map } from 'rxjs/operators';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/material/chips";
5
6
  import * as i2 from "../../chips/elder-chip-label.directive";
6
7
  import * as i3 from "@angular/common";
8
+ import * as i4 from "@angular/material/icon";
9
+ import * as i5 from "../../../pipes/elder-truncate.pipe";
10
+ export class ElderBadgeChipDirective {
11
+ constructor(templateRef, viewContainer) {
12
+ this.templateRef = templateRef;
13
+ this.viewContainer = viewContainer;
14
+ }
15
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeChipDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
16
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: ElderBadgeChipDirective, selector: "[elderBadgeChip]", ngImport: i0 }); }
17
+ }
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeChipDirective, decorators: [{
19
+ type: Directive,
20
+ args: [{
21
+ selector: '[elderBadgeChip]'
22
+ }]
23
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
24
+ export class ElderBadgeChipAvatarDirective {
25
+ constructor(templateRef, viewContainer) {
26
+ this.templateRef = templateRef;
27
+ this.viewContainer = viewContainer;
28
+ }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeChipAvatarDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
30
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: ElderBadgeChipAvatarDirective, selector: "[elderBadgeChipAvatar]", ngImport: i0 }); }
31
+ }
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeChipAvatarDirective, decorators: [{
33
+ type: Directive,
34
+ args: [{
35
+ selector: '[elderBadgeChipAvatar]'
36
+ }]
37
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
38
+ class ElderBadgeModel {
39
+ static standard() {
40
+ return new ElderBadgeModel('', { theme: 'primary' }, {});
41
+ }
42
+ constructor(value, colorSpec, avatarSpec) {
43
+ this.value = value;
44
+ this.colorSpec = colorSpec;
45
+ this.avatarSpec = avatarSpec;
46
+ }
47
+ get showAvatar() {
48
+ return !!this.avatarSpec?.icon;
49
+ }
50
+ }
7
51
  export class ElderBadgeComponent {
8
- set content(count) {
9
- this.content$.next(count);
52
+ /***************************************************************************
53
+ * *
54
+ * Constructor *
55
+ * *
56
+ **************************************************************************/
57
+ constructor() {
58
+ /***************************************************************************
59
+ * *
60
+ * Fields *
61
+ * *
62
+ **************************************************************************/
63
+ this.badgeModel$ = new BehaviorSubject(ElderBadgeModel.standard());
64
+ this.elementClass = [];
65
+ this.chipTemplate$ = new BehaviorSubject(null);
66
+ this.chipAvatarTemplate$ = new BehaviorSubject(null);
67
+ this.appearance = 'legacy';
68
+ this.templates$ = combineLatest([
69
+ this.chipTemplate$,
70
+ this.chipAvatarTemplate$
71
+ ]).pipe(map(([chip, avatar]) => {
72
+ return {
73
+ chip,
74
+ avatar
75
+ };
76
+ }));
77
+ }
78
+ /***************************************************************************
79
+ * *
80
+ * Properties *
81
+ * *
82
+ **************************************************************************/
83
+ set value(value) {
84
+ const current = this.badgeModel$.getValue();
85
+ this.badgeModel$.next(new ElderBadgeModel(value, current.colorSpec, current.avatarSpec));
86
+ }
87
+ set colorSpec(spec) {
88
+ const current = this.badgeModel$.getValue();
89
+ this.badgeModel$.next(new ElderBadgeModel(current.value, spec, current.avatarSpec));
90
+ }
91
+ set badgeColor(color) {
92
+ this.colorSpec = { theme: color };
93
+ }
94
+ set avatarSpec(spec) {
95
+ const current = this.badgeModel$.getValue();
96
+ this.badgeModel$.next(new ElderBadgeModel(current.value, current.colorSpec, spec));
10
97
  }
11
98
  setCssClass(val) {
12
99
  this.elementClass = val.split(' ');
13
100
  }
14
- getColor() {
15
- if (this.isContentANumberAndBiggerThanZero()) {
16
- return 'primary';
17
- }
18
- return null;
101
+ /***************************************************************************
102
+ * *
103
+ * Templates *
104
+ * *
105
+ **************************************************************************/
106
+ set chipTemplateQuery(template) {
107
+ this.chipTemplate = template;
19
108
  }
20
- isContentANumberAndBiggerThanZero() {
21
- return !isNaN(+this.content$.getValue()) && +this.content$.getValue() > 0;
109
+ set chipTemplate(template) {
110
+ this.chipTemplate$.next(template);
22
111
  }
23
- constructor() {
24
- this.content$ = new BehaviorSubject('');
25
- this.elementClass = [];
112
+ get chipTemplate() {
113
+ return this.chipTemplate$.getValue();
114
+ }
115
+ set chipAvatarTemplateQuery(template) {
116
+ this.chipAvatarTemplate = template;
117
+ }
118
+ set chipAvatarTemplate(template) {
119
+ this.chipAvatarTemplate$.next(template);
120
+ }
121
+ get chipAvatarTemplate() {
122
+ return this.chipAvatarTemplate$.getValue();
26
123
  }
27
124
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
28
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ElderBadgeComponent, selector: "elder-badge", inputs: { content: "content", setCssClass: ["cssClass", "setCssClass"] }, ngImport: i0, template: "<mat-chip elderChipLabel\n [color]=\"getColor()\"\n [class]=\"'elder-badge ' + elementClass\"\n *ngIf=\"content$ | async as count\">\n {{count}}\n</mat-chip>\n", styles: [".elder-badge{position:absolute!important;width:unset!important;max-width:unset!important;box-sizing:border-box;font-weight:600}.elder-badge .mdc-evolution-chip,.elder-badge .mdc-evolution-chip__cell,.elder-badge .mdc-evolution-chip__action{justify-content:center}.mat-badge-small .elder-badge.mat-badge-content{border-radius:16px;min-width:16px}.mat-badge-small.mat-badge-above .elder-badge.mat-badge-content{top:-7px!important}.mat-badge-small.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-small.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-small .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 3px!important}.mat-badge-small .elder-badge.mat-badge-content{line-height:14px!important}.mat-badge-medium .elder-badge.mat-badge-content{border-radius:22px;min-width:22px}.mat-badge-medium.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-medium.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-medium .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-medium .elder-badge.mat-badge-content{line-height:20px!important}.mat-badge-large .elder-badge.mat-badge-content{border-radius:28px;min-width:28px}.mat-badge-large.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-large.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-large .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-large .elder-badge.mat-badge-content{line-height:26px!important}.elder-badge.mat-badge-content{transform:unset!important}\n"], dependencies: [{ kind: "component", type: i1.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disabled", "disableRipple", "tabIndex", "role", "id", "aria-label", "aria-description", "value", "removable", "highlighted"], outputs: ["removed", "destroyed"], exportAs: ["matChip"] }, { kind: "directive", type: i2.ElderChipLabelDirective, selector: "[elderChipLabel]", inputs: ["appearance", "color", "stateColor", "levelColor"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
125
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ElderBadgeComponent, selector: "elder-badge", inputs: { appearance: "appearance", value: "value", colorSpec: "colorSpec", badgeColor: "badgeColor", avatarSpec: "avatarSpec", setCssClass: ["cssClass", "setCssClass"], chipTemplate: "chipTemplate", chipAvatarTemplate: "chipAvatarTemplate" }, queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderBadgeChipDirective, descendants: true, read: TemplateRef }, { propertyName: "chipAvatarTemplateQuery", first: true, predicate: ElderBadgeChipAvatarDirective, descendants: true, read: TemplateRef }], ngImport: i0, template: "<ng-container *ngIf=\"templates$ | async as templates\">\n <ng-container *ngIf=\"badgeModel$ | async as badgeModel\">\n <mat-chip elderChipLabel [appearance]=\"appearance\"\n [color]=\"badgeModel.colorSpec?.theme\"\n [stateColor]=\"badgeModel.colorSpec?.state\"\n [levelColor]=\"badgeModel.colorSpec?.level\"\n [class]=\"'elder-badge fill ' + elementClass\">\n <mat-chip-avatar clasS=\"elder-badge-avatar\"\n *ngIf=\"templates.avatar || badgeModel.showAvatar\"\n >\n <ng-container\n *ngTemplateOutlet=\"templates.avatar || simpleAvatarTemplate; context: {$implicit: badgeModel}\">\n </ng-container>\n </mat-chip-avatar>\n\n <ng-container\n *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: badgeModel}\">\n </ng-container>\n\n <ng-content></ng-content>\n\n </mat-chip>\n </ng-container>\n</ng-container>\n\n<ng-template #simpleChipTemplate let-badgeModel>\n <!--\n <span class=\"elder-chip-text\">{{badgeModel.value | elderTruncate:20}}</span>\n -->\n {{badgeModel.value | elderTruncate:20}}\n</ng-template>\n\n<ng-template #simpleAvatarTemplate let-badgeModel>\n <mat-icon>{{badgeModel.avatarSpec?.icon}}</mat-icon>\n</ng-template>\n", styles: [".elder-badge{position:absolute!important;width:unset!important;max-width:unset!important;box-sizing:border-box}.elder-badge.mat-mdc-standard-chip{height:var(--mat-badge-text-size, 12px)4}.elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__text-label{font-size:var(--mat-badge-text-size, 12px);font-weight:var(--mat-badge-text-weight, 600)}.elder-badge .mdc-evolution-chip,.elder-badge .mdc-evolution-chip__cell,.elder-badge .mdc-evolution-chip__action{justify-content:center}.elder-badge.mdc-evolution-chip--with-avatar.mdc-evolution-chip--with-primary-graphic .mdc-evolution-chip__graphic{padding-left:0;padding-right:0}.mat-badge-small .elder-badge.mat-badge-content{border-radius:16px;min-width:16px}.mat-badge-small.mat-badge-above .elder-badge.mat-badge-content{top:-7px!important}.mat-badge-small.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-small.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-small .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 3px!important}.mat-badge-small .elder-badge.mat-badge-content{line-height:14px!important}.mat-badge-medium .elder-badge.mat-badge-content{border-radius:22px;min-width:22px}.mat-badge-medium.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-medium.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-medium .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-medium .elder-badge.mat-badge-content{line-height:20px!important}.mat-badge-large .elder-badge.mat-badge-content{border-radius:28px;min-width:28px}.mat-badge-large.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-large.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-large .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-large .elder-badge.mat-badge-content{line-height:26px!important}.elder-badge.mat-badge-content{transform:unset!important}\n"], dependencies: [{ kind: "component", type: i1.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disabled", "disableRipple", "tabIndex", "role", "id", "aria-label", "aria-description", "value", "removable", "highlighted"], outputs: ["removed", "destroyed"], exportAs: ["matChip"] }, { kind: "directive", type: i1.MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]" }, { kind: "directive", type: i2.ElderChipLabelDirective, selector: "[elderChipLabel]", inputs: ["appearance", "color", "stateColor", "levelColor"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.ElderTruncatePipe, name: "elderTruncate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
29
126
  }
30
127
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeComponent, decorators: [{
31
128
  type: Component,
32
- args: [{ selector: 'elder-badge', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<mat-chip elderChipLabel\n [color]=\"getColor()\"\n [class]=\"'elder-badge ' + elementClass\"\n *ngIf=\"content$ | async as count\">\n {{count}}\n</mat-chip>\n", styles: [".elder-badge{position:absolute!important;width:unset!important;max-width:unset!important;box-sizing:border-box;font-weight:600}.elder-badge .mdc-evolution-chip,.elder-badge .mdc-evolution-chip__cell,.elder-badge .mdc-evolution-chip__action{justify-content:center}.mat-badge-small .elder-badge.mat-badge-content{border-radius:16px;min-width:16px}.mat-badge-small.mat-badge-above .elder-badge.mat-badge-content{top:-7px!important}.mat-badge-small.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-small.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-small .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 3px!important}.mat-badge-small .elder-badge.mat-badge-content{line-height:14px!important}.mat-badge-medium .elder-badge.mat-badge-content{border-radius:22px;min-width:22px}.mat-badge-medium.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-medium.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-medium .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-medium .elder-badge.mat-badge-content{line-height:20px!important}.mat-badge-large .elder-badge.mat-badge-content{border-radius:28px;min-width:28px}.mat-badge-large.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-large.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-large .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-large .elder-badge.mat-badge-content{line-height:26px!important}.elder-badge.mat-badge-content{transform:unset!important}\n"] }]
33
- }], ctorParameters: function () { return []; }, propDecorators: { content: [{
129
+ args: [{ selector: 'elder-badge', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ng-container *ngIf=\"templates$ | async as templates\">\n <ng-container *ngIf=\"badgeModel$ | async as badgeModel\">\n <mat-chip elderChipLabel [appearance]=\"appearance\"\n [color]=\"badgeModel.colorSpec?.theme\"\n [stateColor]=\"badgeModel.colorSpec?.state\"\n [levelColor]=\"badgeModel.colorSpec?.level\"\n [class]=\"'elder-badge fill ' + elementClass\">\n <mat-chip-avatar clasS=\"elder-badge-avatar\"\n *ngIf=\"templates.avatar || badgeModel.showAvatar\"\n >\n <ng-container\n *ngTemplateOutlet=\"templates.avatar || simpleAvatarTemplate; context: {$implicit: badgeModel}\">\n </ng-container>\n </mat-chip-avatar>\n\n <ng-container\n *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: badgeModel}\">\n </ng-container>\n\n <ng-content></ng-content>\n\n </mat-chip>\n </ng-container>\n</ng-container>\n\n<ng-template #simpleChipTemplate let-badgeModel>\n <!--\n <span class=\"elder-chip-text\">{{badgeModel.value | elderTruncate:20}}</span>\n -->\n {{badgeModel.value | elderTruncate:20}}\n</ng-template>\n\n<ng-template #simpleAvatarTemplate let-badgeModel>\n <mat-icon>{{badgeModel.avatarSpec?.icon}}</mat-icon>\n</ng-template>\n", styles: [".elder-badge{position:absolute!important;width:unset!important;max-width:unset!important;box-sizing:border-box}.elder-badge.mat-mdc-standard-chip{height:var(--mat-badge-text-size, 12px)4}.elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__text-label{font-size:var(--mat-badge-text-size, 12px);font-weight:var(--mat-badge-text-weight, 600)}.elder-badge .mdc-evolution-chip,.elder-badge .mdc-evolution-chip__cell,.elder-badge .mdc-evolution-chip__action{justify-content:center}.elder-badge.mdc-evolution-chip--with-avatar.mdc-evolution-chip--with-primary-graphic .mdc-evolution-chip__graphic{padding-left:0;padding-right:0}.mat-badge-small .elder-badge.mat-badge-content{border-radius:16px;min-width:16px}.mat-badge-small.mat-badge-above .elder-badge.mat-badge-content{top:-7px!important}.mat-badge-small.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-small.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-small .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 3px!important}.mat-badge-small .elder-badge.mat-badge-content{line-height:14px!important}.mat-badge-medium .elder-badge.mat-badge-content{border-radius:22px;min-width:22px}.mat-badge-medium.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-medium.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-medium .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-medium .elder-badge.mat-badge-content{line-height:20px!important}.mat-badge-large .elder-badge.mat-badge-content{border-radius:28px;min-width:28px}.mat-badge-large.mat-badge-overlap.mat-badge-after .elder-badge.mat-badge-content{right:-5px;transform:translate(100%)!important}.mat-badge-large.mat-badge-overlap.mat-badge-before .elder-badge.mat-badge-content{left:-5px;transform:translate(-100%)!important}.mat-badge-large .elder-badge.mat-mdc-standard-chip .mdc-evolution-chip__action--primary{padding:0 6px!important}.mat-badge-large .elder-badge.mat-badge-content{line-height:26px!important}.elder-badge.mat-badge-content{transform:unset!important}\n"] }]
130
+ }], ctorParameters: function () { return []; }, propDecorators: { appearance: [{
131
+ type: Input
132
+ }], value: [{
133
+ type: Input
134
+ }], colorSpec: [{
135
+ type: Input
136
+ }], badgeColor: [{
137
+ type: Input
138
+ }], avatarSpec: [{
34
139
  type: Input
35
140
  }], setCssClass: [{
36
141
  type: Input,
37
142
  args: ['cssClass']
143
+ }], chipTemplateQuery: [{
144
+ type: ContentChild,
145
+ args: [ElderBadgeChipDirective, { read: TemplateRef, static: false }]
146
+ }], chipTemplate: [{
147
+ type: Input
148
+ }], chipAvatarTemplateQuery: [{
149
+ type: ContentChild,
150
+ args: [ElderBadgeChipAvatarDirective, { read: TemplateRef, static: false }]
151
+ }], chipAvatarTemplate: [{
152
+ type: Input
38
153
  }] } });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9iYWRnZS9lbGRlci1iYWRnZS9lbGRlci1iYWRnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2JhZGdlL2VsZGVyLWJhZGdlL2VsZGVyLWJhZGdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBV3ZDLE1BQU0sT0FBTyxtQkFBbUI7SUFJOUIsSUFDVyxPQUFPLENBQUMsS0FBYTtRQUM5QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBS00sV0FBVyxDQUFDLEdBQVc7UUFDNUIsSUFBSSxDQUFDLFlBQVksR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFTSxRQUFRO1FBQ2IsSUFBRyxJQUFJLENBQUMsaUNBQWlDLEVBQUUsRUFBRTtZQUMzQyxPQUFPLFNBQVMsQ0FBQTtTQUNqQjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVPLGlDQUFpQztRQUN2QyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLENBQUE7SUFDM0UsQ0FBQztJQUVEO1FBekJnQixhQUFRLEdBQUcsSUFBSSxlQUFlLENBQVMsRUFBRSxDQUFDLENBQUM7UUFPcEQsaUJBQVksR0FBYSxFQUFFLENBQUM7SUFtQm5DLENBQUM7K0dBNUJVLG1CQUFtQjttR0FBbkIsbUJBQW1CLDZIQ1poQyw2TEFNQTs7NEZETWEsbUJBQW1CO2tCQVIvQixTQUFTOytCQUNFLGFBQWEsbUJBR04sdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSTswRUFRMUIsT0FBTztzQkFEakIsS0FBSztnQkFRQyxXQUFXO3NCQURqQixLQUFLO3VCQUFDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IFRoZW1lUGFsZXR0ZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9jb3JlXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLWJhZGdlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2VsZGVyLWJhZGdlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZWxkZXItYmFkZ2UuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcblxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckJhZGdlQ29tcG9uZW50IHtcblxuICBwdWJsaWMgcmVhZG9ubHkgY29udGVudCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4oJycpO1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzZXQgY29udGVudChjb3VudDogc3RyaW5nKSB7XG4gICAgdGhpcy5jb250ZW50JC5uZXh0KGNvdW50KTtcbiAgfVxuXG4gIHB1YmxpYyBlbGVtZW50Q2xhc3M6IHN0cmluZ1tdID0gW107XG5cbiAgQElucHV0KCdjc3NDbGFzcycpXG4gIHB1YmxpYyBzZXRDc3NDbGFzcyh2YWw6IHN0cmluZykge1xuICAgIHRoaXMuZWxlbWVudENsYXNzID0gdmFsLnNwbGl0KCcgJyk7XG4gIH1cblxuICBwdWJsaWMgZ2V0Q29sb3IoKTogVGhlbWVQYWxldHRlIHtcbiAgICBpZih0aGlzLmlzQ29udGVudEFOdW1iZXJBbmRCaWdnZXJUaGFuWmVybygpKSB7XG4gICAgICByZXR1cm4gJ3ByaW1hcnknXG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgcHJpdmF0ZSBpc0NvbnRlbnRBTnVtYmVyQW5kQmlnZ2VyVGhhblplcm8oKSB7XG4gICAgcmV0dXJuICFpc05hTigrdGhpcy5jb250ZW50JC5nZXRWYWx1ZSgpKSAmJiArdGhpcy5jb250ZW50JC5nZXRWYWx1ZSgpID4gMFxuICB9XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIH1cblxufVxuIiwiPG1hdC1jaGlwIGVsZGVyQ2hpcExhYmVsXG4gICAgICAgICAgW2NvbG9yXT1cImdldENvbG9yKClcIlxuICAgICAgICAgIFtjbGFzc109XCInZWxkZXItYmFkZ2UgJyArIGVsZW1lbnRDbGFzc1wiXG4gICAgICAgICAgKm5nSWY9XCJjb250ZW50JCB8IGFzeW5jIGFzIGNvdW50XCI+XG4gIHt7Y291bnR9fVxuPC9tYXQtY2hpcD5cbiJdfQ==
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-badge.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/badge/elder-badge/elder-badge.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/badge/elder-badge/elder-badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Directive,\n  Input,\n  TemplateRef,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport { ThemePalette } from \"@angular/material/core\";\nimport {ElderChipAppearance, ElderLevelColor, ElderStateColor} from '../../chips/elder-chip-label.directive';\nimport {map} from 'rxjs/operators';\n\n\n@Directive({\n  selector: '[elderBadgeChip]'\n})\nexport class ElderBadgeChipDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef\n  ) { }\n}\n\n@Directive({\n  selector: '[elderBadgeChipAvatar]'\n})\nexport class ElderBadgeChipAvatarDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef\n  ) { }\n}\n\nexport interface BadgeColorSpec {\n  readonly theme?: ThemePalette;\n  readonly state?: ElderStateColor;\n  readonly level?: ElderLevelColor;\n}\n\nexport interface BadgeAvatarSpec {\n  readonly icon?: string;\n}\n\nclass ElderBadgeModel {\n\n  public static standard(): ElderBadgeModel {\n    return new ElderBadgeModel('', {theme: 'primary'}, {});\n  }\n\n  constructor(\n    public readonly value: any,\n    public readonly colorSpec: BadgeColorSpec,\n    public readonly avatarSpec: BadgeAvatarSpec,\n  ) {\n  }\n\n  public get showAvatar(): boolean {\n    return !!this.avatarSpec?.icon;\n  }\n\n}\n\ninterface TemplateWrapper {\n  chip: TemplateRef<any>;\n  avatar: TemplateRef<any>;\n}\n\n@Component({\n  selector: 'elder-badge',\n  templateUrl: './elder-badge.component.html',\n  styleUrls: ['./elder-badge.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n\n})\nexport class ElderBadgeComponent {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  public readonly badgeModel$ = new BehaviorSubject<ElderBadgeModel>(ElderBadgeModel.standard());\n  public elementClass: string[] = [];\n  readonly templates$: Observable<TemplateWrapper>;\n\n  private readonly chipTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n  private readonly chipAvatarTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n\n  @Input()\n  public appearance: ElderChipAppearance = 'legacy';\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    this.templates$ = combineLatest([\n      this.chipTemplate$,\n      this.chipAvatarTemplate$\n    ]).pipe(\n      map(([chip, avatar]) => {\n        return <TemplateWrapper>{\n          chip,\n          avatar\n        };\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set value(value: any) {\n    const current = this.badgeModel$.getValue();\n    this.badgeModel$.next(\n      new ElderBadgeModel(\n        value,\n        current.colorSpec,\n        current.avatarSpec\n      )\n    );\n  }\n\n  @Input()\n  public set colorSpec(spec: BadgeColorSpec) {\n    const current = this.badgeModel$.getValue();\n    this.badgeModel$.next(\n      new ElderBadgeModel(\n        current.value,\n        spec,\n        current.avatarSpec\n      )\n    );\n  }\n\n  @Input()\n  public set badgeColor(color: ThemePalette) {\n    this.colorSpec = {theme: color};\n  }\n\n  @Input()\n  public set avatarSpec(spec: BadgeAvatarSpec) {\n    const current = this.badgeModel$.getValue();\n    this.badgeModel$.next(\n      new ElderBadgeModel(\n        current.value,\n        current.colorSpec,\n        spec\n      )\n    );\n  }\n\n  @Input('cssClass')\n  public setCssClass(val: string) {\n    this.elementClass = val.split(' ');\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Templates                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  @ContentChild(ElderBadgeChipDirective, {read: TemplateRef, static: false})\n  public set chipTemplateQuery(template: TemplateRef<any>) {\n    this.chipTemplate = template;\n  }\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this.chipTemplate$.next(template);\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this.chipTemplate$.getValue();\n  }\n\n  @ContentChild(ElderBadgeChipAvatarDirective, {read: TemplateRef, static: false})\n  public set chipAvatarTemplateQuery(template: TemplateRef<any>) {\n    this.chipAvatarTemplate = template;\n  }\n\n  @Input()\n  public set chipAvatarTemplate(template: TemplateRef<any>) {\n    this.chipAvatarTemplate$.next(template);\n  }\n\n  public get chipAvatarTemplate(): TemplateRef<any> {\n    return this.chipAvatarTemplate$.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n}\n","<ng-container *ngIf=\"templates$ | async as templates\">\n  <ng-container *ngIf=\"badgeModel$ | async as badgeModel\">\n    <mat-chip elderChipLabel [appearance]=\"appearance\"\n              [color]=\"badgeModel.colorSpec?.theme\"\n              [stateColor]=\"badgeModel.colorSpec?.state\"\n              [levelColor]=\"badgeModel.colorSpec?.level\"\n              [class]=\"'elder-badge fill ' + elementClass\">\n      <mat-chip-avatar clasS=\"elder-badge-avatar\"\n        *ngIf=\"templates.avatar || badgeModel.showAvatar\"\n      >\n        <ng-container\n          *ngTemplateOutlet=\"templates.avatar || simpleAvatarTemplate; context: {$implicit: badgeModel}\">\n        </ng-container>\n      </mat-chip-avatar>\n\n      <ng-container\n        *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: badgeModel}\">\n      </ng-container>\n\n      <ng-content></ng-content>\n\n    </mat-chip>\n  </ng-container>\n</ng-container>\n\n<ng-template #simpleChipTemplate let-badgeModel>\n  <!--\n  <span class=\"elder-chip-text\">{{badgeModel.value | elderTruncate:20}}</span>\n  -->\n  {{badgeModel.value | elderTruncate:20}}\n</ng-template>\n\n<ng-template #simpleAvatarTemplate let-badgeModel>\n  <mat-icon>{{badgeModel.avatarSpec?.icon}}</mat-icon>\n</ng-template>\n"]}
@@ -1,48 +1,101 @@
1
- import { Directive, Input, HostBinding } from "@angular/core";
2
- import { ElderBadgeComponent } from "./elder-badge/elder-badge.component";
3
- import { BehaviorSubject, Subject } from "rxjs";
4
- import { takeUntil } from "rxjs/operators";
1
+ import { Directive, Input, HostBinding } from '@angular/core';
2
+ import { ElderBadgeComponent } from './elder-badge/elder-badge.component';
3
+ import { BehaviorSubject } from 'rxjs';
4
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@angular/platform-browser";
7
7
  import * as i2 from "@angular/material/badge";
8
8
  export class ElderBadgeDirective {
9
- constructor(element, sanitizer, viewContainerRef, matBadge) {
10
- this.element = element;
9
+ /***************************************************************************
10
+ * *
11
+ * Constructor *
12
+ * *
13
+ **************************************************************************/
14
+ constructor(sanitizer, viewContainerRef, matBadge, destroyRef) {
11
15
  this.sanitizer = sanitizer;
12
16
  this.viewContainerRef = viewContainerRef;
13
17
  this.matBadge = matBadge;
14
- this.elderBadge$ = new BehaviorSubject('');
15
- this.unsubscribe$ = new Subject();
18
+ this.destroyRef = destroyRef;
19
+ /***************************************************************************
20
+ * *
21
+ * Fields *
22
+ * *
23
+ **************************************************************************/
24
+ this.value$ = new BehaviorSubject(undefined);
25
+ this.colorSpec$ = new BehaviorSubject({ theme: 'primary' });
26
+ this.avatarSpec$ = new BehaviorSubject(undefined);
16
27
  // Necessary for the directive to load the component
17
28
  this.matBadge.content = 0;
18
29
  }
19
- set elderBadge(elderBadge) {
20
- this.elderBadge$.next(elderBadge);
21
- }
30
+ /***************************************************************************
31
+ * *
32
+ * Life Cycle *
33
+ * *
34
+ **************************************************************************/
22
35
  ngOnInit() {
23
36
  this.style = this.sanitizer.bypassSecurityTrustStyle('position: relative;');
24
37
  const componentRef = this.viewContainerRef.createComponent(ElderBadgeComponent);
25
- componentRef.instance.setCssClass(this.matBadge.getBadgeElement().getAttribute('class'));
38
+ const elderBadgeComponent = componentRef.instance;
39
+ elderBadgeComponent.setCssClass(this.matBadge.getBadgeElement().getAttribute('class'));
26
40
  //Replace mat-badge with elder-badge
27
41
  const host = this.matBadge.getBadgeElement().parentElement;
28
42
  host.insertBefore(componentRef.location.nativeElement, host.firstChild);
29
43
  this.matBadge.getBadgeElement().remove();
30
- this.elderBadge$
31
- .pipe(takeUntil(this.unsubscribe$))
32
- .subscribe(value => componentRef.setInput('content', value));
44
+ this.value$
45
+ .pipe(takeUntilDestroyed(this.destroyRef))
46
+ .subscribe(value => elderBadgeComponent.value = value);
47
+ this.colorSpec$
48
+ .pipe(takeUntilDestroyed(this.destroyRef))
49
+ .subscribe(spec => elderBadgeComponent.colorSpec = spec);
50
+ this.avatarSpec$
51
+ .pipe(takeUntilDestroyed(this.destroyRef))
52
+ .subscribe(spec => elderBadgeComponent.avatarSpec = spec);
53
+ }
54
+ /***************************************************************************
55
+ * *
56
+ * Properties *
57
+ * *
58
+ **************************************************************************/
59
+ set badgeColor(theme) {
60
+ this.colorSpec = { theme: theme };
61
+ }
62
+ set badgeIcon(icon) {
63
+ this.avatarSpec = { icon: icon };
64
+ }
65
+ /***************************************************************************
66
+ * *
67
+ * Properties *
68
+ * *
69
+ **************************************************************************/
70
+ set elderBadge(value) {
71
+ this.value$.next(value);
72
+ }
73
+ set colorSpec(spec) {
74
+ this.colorSpec$.next(spec);
33
75
  }
34
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeDirective, deps: [{ token: i0.ElementRef }, { token: i1.DomSanitizer }, { token: i0.ViewContainerRef }, { token: i2.MatBadge }], target: i0.ɵɵFactoryTarget.Directive }); }
35
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: ElderBadgeDirective, selector: "[elderBadge]", inputs: { elderBadge: "elderBadge" }, host: { properties: { "style": "this.style" } }, ngImport: i0 }); }
76
+ set avatarSpec(spec) {
77
+ this.avatarSpec$.next(spec);
78
+ }
79
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeDirective, deps: [{ token: i1.DomSanitizer }, { token: i0.ViewContainerRef }, { token: i2.MatBadge }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive }); }
80
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: ElderBadgeDirective, selector: "[elderBadge]", inputs: { badgeColor: "badgeColor", badgeIcon: "badgeIcon", elderBadge: "elderBadge", colorSpec: "colorSpec", avatarSpec: "avatarSpec" }, host: { properties: { "style": "this.style" } }, ngImport: i0 }); }
36
81
  }
37
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeDirective, decorators: [{
38
83
  type: Directive,
39
84
  args: [{
40
85
  selector: '[elderBadge]'
41
86
  }]
42
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.DomSanitizer }, { type: i0.ViewContainerRef }, { type: i2.MatBadge }]; }, propDecorators: { style: [{
87
+ }], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i0.ViewContainerRef }, { type: i2.MatBadge }, { type: i0.DestroyRef }]; }, propDecorators: { style: [{
43
88
  type: HostBinding,
44
89
  args: ['style']
90
+ }], badgeColor: [{
91
+ type: Input
92
+ }], badgeIcon: [{
93
+ type: Input
45
94
  }], elderBadge: [{
46
95
  type: Input
96
+ }], colorSpec: [{
97
+ type: Input
98
+ }], avatarSpec: [{
99
+ type: Input
47
100
  }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYmFkZ2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9iYWRnZS9lbGRlci1iYWRnZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFNVCxLQUFLLEVBQUUsV0FBVyxFQUNuQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUUxRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNoRCxPQUFPLEVBQVEsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFPakQsTUFBTSxPQUFPLG1CQUFtQjtJQUs5QixZQUFvQixPQUFtQixFQUNuQixTQUF1QixFQUN2QixnQkFBa0MsRUFDbEMsUUFBa0I7UUFIbEIsWUFBTyxHQUFQLE9BQU8sQ0FBWTtRQUNuQixjQUFTLEdBQVQsU0FBUyxDQUFjO1FBQ3ZCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFDbEMsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQU5yQixnQkFBVyxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQy9DLGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQU9qRCxvREFBb0Q7UUFDcEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFLRCxJQUNXLFVBQVUsQ0FBQyxVQUFrQjtRQUN0QyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyx3QkFBd0IsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQzVFLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUNoRixZQUFZLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsRUFBRSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBRXpGLG9DQUFvQztRQUNwQyxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUMzRCxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUN2RSxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBRXpDLElBQUksQ0FBQyxXQUFXO2FBQ2IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7YUFDbEMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNqRSxDQUFDOytHQW5DVSxtQkFBbUI7bUdBQW5CLG1CQUFtQjs7NEZBQW5CLG1CQUFtQjtrQkFIL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsY0FBYztpQkFDekI7a0xBZ0JDLEtBQUs7c0JBREosV0FBVzt1QkFBQyxPQUFPO2dCQUlULFVBQVU7c0JBRHBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIFZpZXdDb250YWluZXJSZWYsXG4gIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcbiAgQ29tcG9uZW50UmVmLFxuICBPbkluaXQsXG4gIElucHV0LCBIb3N0QmluZGluZywgSG9zdExpc3RlbmVyLCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXNcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEVsZGVyQmFkZ2VDb21wb25lbnQgfSBmcm9tIFwiLi9lbGRlci1iYWRnZS9lbGRlci1iYWRnZS5jb21wb25lbnRcIjtcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZVN0eWxlIH0gZnJvbSBcIkBhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXJcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyB0YWtlLCB0YWtlVW50aWwgfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIjtcbmltcG9ydCB7IE1hdExhYmVsIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGRcIjtcbmltcG9ydCB7IE1hdEJhZGdlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2JhZGdlXCI7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tlbGRlckJhZGdlXSdcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJCYWRnZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBlbGRlckJhZGdlJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignJyk7XG4gIHB1YmxpYyByZWFkb25seSB1bnN1YnNjcmliZSQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudDogRWxlbWVudFJlZixcbiAgICAgICAgICAgICAgcHJpdmF0ZSBzYW5pdGl6ZXI6IERvbVNhbml0aXplcixcbiAgICAgICAgICAgICAgcHJpdmF0ZSB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgICAgICAgICAgICBwcml2YXRlIG1hdEJhZGdlOiBNYXRCYWRnZVxuICApIHtcbiAgICAvLyBOZWNlc3NhcnkgZm9yIHRoZSBkaXJlY3RpdmUgdG8gbG9hZCB0aGUgY29tcG9uZW50XG4gICAgdGhpcy5tYXRCYWRnZS5jb250ZW50ID0gMDtcbiAgfVxuXG4gIEBIb3N0QmluZGluZygnc3R5bGUnKVxuICBzdHlsZTogU2FmZVN0eWxlO1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzZXQgZWxkZXJCYWRnZShlbGRlckJhZGdlOiBzdHJpbmcpIHtcbiAgICB0aGlzLmVsZGVyQmFkZ2UkLm5leHQoZWxkZXJCYWRnZSk7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLnN0eWxlID0gdGhpcy5zYW5pdGl6ZXIuYnlwYXNzU2VjdXJpdHlUcnVzdFN0eWxlKCdwb3NpdGlvbjogcmVsYXRpdmU7Jyk7XG4gICAgY29uc3QgY29tcG9uZW50UmVmID0gdGhpcy52aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUNvbXBvbmVudChFbGRlckJhZGdlQ29tcG9uZW50KTtcbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2Uuc2V0Q3NzQ2xhc3ModGhpcy5tYXRCYWRnZS5nZXRCYWRnZUVsZW1lbnQoKS5nZXRBdHRyaWJ1dGUoJ2NsYXNzJykpO1xuXG4gICAgLy9SZXBsYWNlIG1hdC1iYWRnZSB3aXRoIGVsZGVyLWJhZGdlXG4gICAgY29uc3QgaG9zdCA9IHRoaXMubWF0QmFkZ2UuZ2V0QmFkZ2VFbGVtZW50KCkucGFyZW50RWxlbWVudDtcbiAgICBob3N0Lmluc2VydEJlZm9yZShjb21wb25lbnRSZWYubG9jYXRpb24ubmF0aXZlRWxlbWVudCwgaG9zdC5maXJzdENoaWxkKVxuICAgIHRoaXMubWF0QmFkZ2UuZ2V0QmFkZ2VFbGVtZW50KCkucmVtb3ZlKCk7XG5cbiAgICB0aGlzLmVsZGVyQmFkZ2UkXG4gICAgICAucGlwZSh0YWtlVW50aWwodGhpcy51bnN1YnNjcmliZSQpKVxuICAgICAgLnN1YnNjcmliZSh2YWx1ZSA9PiBjb21wb25lbnRSZWYuc2V0SW5wdXQoJ2NvbnRlbnQnLCB2YWx1ZSkpO1xuICB9XG59XG4iXX0=
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-badge.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/badge/elder-badge.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ViewContainerRef,\n  OnInit,\n  Input, HostBinding,DestroyRef\n} from '@angular/core';\nimport {BadgeAvatarSpec, BadgeColorSpec, ElderBadgeComponent} from './elder-badge/elder-badge.component';\nimport {DomSanitizer, SafeStyle} from '@angular/platform-browser';\nimport {BehaviorSubject} from 'rxjs';\nimport {MatBadge} from '@angular/material/badge';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {ThemePalette} from '@angular/material/core';\n\n@Directive({\n  selector: '[elderBadge]'\n})\nexport class ElderBadgeDirective implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly value$ = new BehaviorSubject<any>(undefined);\n  private readonly colorSpec$ = new BehaviorSubject<BadgeColorSpec>({theme: 'primary'});\n  private readonly avatarSpec$ = new BehaviorSubject<BadgeAvatarSpec>(undefined);\n\n  @HostBinding('style')\n  style: SafeStyle;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private sanitizer: DomSanitizer,\n    private viewContainerRef: ViewContainerRef,\n    private matBadge: MatBadge,\n    private destroyRef: DestroyRef\n  ) {\n    // Necessary for the directive to load the component\n    this.matBadge.content = 0;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.style = this.sanitizer.bypassSecurityTrustStyle('position: relative;');\n    const componentRef = this.viewContainerRef.createComponent(ElderBadgeComponent);\n    const elderBadgeComponent  = componentRef.instance;\n    elderBadgeComponent.setCssClass(this.matBadge.getBadgeElement().getAttribute('class'));\n\n    //Replace mat-badge with elder-badge\n    const host = this.matBadge.getBadgeElement().parentElement;\n    host.insertBefore(componentRef.location.nativeElement, host.firstChild);\n    this.matBadge.getBadgeElement().remove();\n\n    this.value$\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(value => elderBadgeComponent.value = value);\n\n    this.colorSpec$\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(spec => elderBadgeComponent.colorSpec = spec);\n\n    this.avatarSpec$\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(spec => elderBadgeComponent.avatarSpec = spec);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n\n  @Input()\n  public set badgeColor(theme: ThemePalette) {\n    this.colorSpec = {theme: theme};\n  }\n\n  @Input()\n  public set badgeIcon(icon: string) {\n    this.avatarSpec = {icon: icon};\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set elderBadge(value: any) {\n    this.value$.next(value);\n  }\n\n  @Input()\n  public set colorSpec(spec: BadgeColorSpec) {\n    this.colorSpec$.next(spec);\n  }\n\n  @Input()\n  public set avatarSpec(spec: BadgeAvatarSpec) {\n    this.avatarSpec$.next(spec);\n  }\n\n}\n"]}
@@ -1,40 +1,58 @@
1
1
  import { NgModule } from '@angular/core';
2
- import { ElderBadgeComponent } from "./elder-badge/elder-badge.component";
2
+ import { ElderBadgeChipAvatarDirective, ElderBadgeChipDirective, ElderBadgeComponent } from './elder-badge/elder-badge.component';
3
3
  import { ElderBadgeDirective } from "./elder-badge.directive";
4
4
  import { MatChipsModule } from "@angular/material/chips";
5
5
  import { ElderChipsModule } from "../chips/elder-chips.module";
6
- import { AsyncPipe, NgIf } from "@angular/common";
6
+ import { AsyncPipe, NgIf, NgTemplateOutlet } from '@angular/common';
7
+ import { ElderPipesModule } from '../../pipes/elder-pipes.module';
8
+ import { MatIconModule } from '@angular/material/icon';
7
9
  import * as i0 from "@angular/core";
8
10
  export * from './elder-badge/elder-badge.component';
9
11
  export * from './elder-badge.directive';
10
12
  export class ElderBadgeModule {
11
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
12
14
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeModule, declarations: [ElderBadgeDirective,
13
- ElderBadgeComponent], imports: [MatChipsModule,
15
+ ElderBadgeComponent,
16
+ ElderBadgeChipDirective,
17
+ ElderBadgeChipAvatarDirective], imports: [MatChipsModule,
14
18
  ElderChipsModule,
15
19
  AsyncPipe,
16
- NgIf], exports: [ElderBadgeDirective,
17
- ElderBadgeComponent] }); }
20
+ NgIf,
21
+ NgTemplateOutlet,
22
+ ElderPipesModule,
23
+ MatIconModule], exports: [ElderBadgeDirective,
24
+ ElderBadgeComponent,
25
+ ElderBadgeChipDirective,
26
+ ElderBadgeChipAvatarDirective] }); }
18
27
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeModule, imports: [MatChipsModule,
19
- ElderChipsModule] }); }
28
+ ElderChipsModule,
29
+ ElderPipesModule,
30
+ MatIconModule] }); }
20
31
  }
21
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderBadgeModule, decorators: [{
22
33
  type: NgModule,
23
34
  args: [{
24
35
  declarations: [
25
36
  ElderBadgeDirective,
26
- ElderBadgeComponent
37
+ ElderBadgeComponent,
38
+ ElderBadgeChipDirective,
39
+ ElderBadgeChipAvatarDirective,
27
40
  ],
28
41
  imports: [
29
42
  MatChipsModule,
30
43
  ElderChipsModule,
31
44
  AsyncPipe,
32
- NgIf
45
+ NgIf,
46
+ NgTemplateOutlet,
47
+ ElderPipesModule,
48
+ MatIconModule
33
49
  ],
34
50
  exports: [
35
51
  ElderBadgeDirective,
36
- ElderBadgeComponent
52
+ ElderBadgeComponent,
53
+ ElderBadgeChipDirective,
54
+ ElderBadgeChipAvatarDirective,
37
55
  ]
38
56
  }]
39
57
  }] });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYmFkZ2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9iYWRnZS9lbGRlci1iYWRnZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV2QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFFbEQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHlCQUF5QixDQUFDO0FBa0J4QyxNQUFNLE9BQU8sZ0JBQWdCOytHQUFoQixnQkFBZ0I7Z0hBQWhCLGdCQUFnQixpQkFkekIsbUJBQW1CO1lBQ25CLG1CQUFtQixhQUduQixjQUFjO1lBQ2QsZ0JBQWdCO1lBQ2hCLFNBQVM7WUFDVCxJQUFJLGFBR0osbUJBQW1CO1lBQ25CLG1CQUFtQjtnSEFHVixnQkFBZ0IsWUFWekIsY0FBYztZQUNkLGdCQUFnQjs7NEZBU1AsZ0JBQWdCO2tCQWhCNUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osbUJBQW1CO3dCQUNuQixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsU0FBUzt3QkFDVCxJQUFJO3FCQUNMO29CQUNELE9BQU8sRUFBRTt3QkFDUCxtQkFBbUI7d0JBQ25CLG1CQUFtQjtxQkFDcEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRWxkZXJCYWRnZUNvbXBvbmVudCB9IGZyb20gXCIuL2VsZGVyLWJhZGdlL2VsZGVyLWJhZGdlLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgRWxkZXJCYWRnZURpcmVjdGl2ZSB9IGZyb20gXCIuL2VsZGVyLWJhZGdlLmRpcmVjdGl2ZVwiO1xuaW1wb3J0IHsgTWF0Q2hpcHNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY2hpcHNcIjtcbmltcG9ydCB7IEVsZGVyQ2hpcHNNb2R1bGUgfSBmcm9tIFwiLi4vY2hpcHMvZWxkZXItY2hpcHMubW9kdWxlXCI7XG5pbXBvcnQgeyBBc3luY1BpcGUsIE5nSWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5cbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItYmFkZ2UvZWxkZXItYmFkZ2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItYmFkZ2UuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWxkZXJCYWRnZURpcmVjdGl2ZSxcbiAgICBFbGRlckJhZGdlQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBNYXRDaGlwc01vZHVsZSxcbiAgICBFbGRlckNoaXBzTW9kdWxlLFxuICAgIEFzeW5jUGlwZSxcbiAgICBOZ0lmXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBFbGRlckJhZGdlRGlyZWN0aXZlLFxuICAgIEVsZGVyQmFkZ2VDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckJhZGdlTW9kdWxlIHtcbn1cbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYmFkZ2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9iYWRnZS9lbGRlci1iYWRnZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV2QyxPQUFPLEVBQUMsNkJBQTZCLEVBQUUsdUJBQXVCLEVBQUUsbUJBQW1CLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNoSSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFDLFNBQVMsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUNsRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7O0FBRXJELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx5QkFBeUIsQ0FBQztBQXlCeEMsTUFBTSxPQUFPLGdCQUFnQjsrR0FBaEIsZ0JBQWdCO2dIQUFoQixnQkFBZ0IsaUJBckJ6QixtQkFBbUI7WUFDbkIsbUJBQW1CO1lBQ25CLHVCQUF1QjtZQUN2Qiw2QkFBNkIsYUFHN0IsY0FBYztZQUNkLGdCQUFnQjtZQUNoQixTQUFTO1lBQ1QsSUFBSTtZQUNKLGdCQUFnQjtZQUNoQixnQkFBZ0I7WUFDaEIsYUFBYSxhQUdiLG1CQUFtQjtZQUNuQixtQkFBbUI7WUFDbkIsdUJBQXVCO1lBQ3ZCLDZCQUE2QjtnSEFHcEIsZ0JBQWdCLFlBZnpCLGNBQWM7WUFDZCxnQkFBZ0I7WUFJaEIsZ0JBQWdCO1lBQ2hCLGFBQWE7OzRGQVNKLGdCQUFnQjtrQkF2QjVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLG1CQUFtQjt3QkFDbkIsbUJBQW1CO3dCQUNuQix1QkFBdUI7d0JBQ3ZCLDZCQUE2QjtxQkFDOUI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixTQUFTO3dCQUNULElBQUk7d0JBQ0osZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLGFBQWE7cUJBQ2Q7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG1CQUFtQjt3QkFDbkIsbUJBQW1CO3dCQUNuQix1QkFBdUI7d0JBQ3ZCLDZCQUE2QjtxQkFDOUI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtFbGRlckJhZGdlQ2hpcEF2YXRhckRpcmVjdGl2ZSwgRWxkZXJCYWRnZUNoaXBEaXJlY3RpdmUsIEVsZGVyQmFkZ2VDb21wb25lbnR9IGZyb20gJy4vZWxkZXItYmFkZ2UvZWxkZXItYmFkZ2UuY29tcG9uZW50JztcbmltcG9ydCB7IEVsZGVyQmFkZ2VEaXJlY3RpdmUgfSBmcm9tIFwiLi9lbGRlci1iYWRnZS5kaXJlY3RpdmVcIjtcbmltcG9ydCB7IE1hdENoaXBzTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2NoaXBzXCI7XG5pbXBvcnQgeyBFbGRlckNoaXBzTW9kdWxlIH0gZnJvbSBcIi4uL2NoaXBzL2VsZGVyLWNoaXBzLm1vZHVsZVwiO1xuaW1wb3J0IHtBc3luY1BpcGUsIE5nSWYsIE5nVGVtcGxhdGVPdXRsZXR9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0VsZGVyUGlwZXNNb2R1bGV9IGZyb20gJy4uLy4uL3BpcGVzL2VsZGVyLXBpcGVzLm1vZHVsZSc7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5leHBvcnQgKiBmcm9tICcuL2VsZGVyLWJhZGdlL2VsZGVyLWJhZGdlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2VsZGVyLWJhZGdlLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEVsZGVyQmFkZ2VEaXJlY3RpdmUsXG4gICAgRWxkZXJCYWRnZUNvbXBvbmVudCxcbiAgICBFbGRlckJhZGdlQ2hpcERpcmVjdGl2ZSxcbiAgICBFbGRlckJhZGdlQ2hpcEF2YXRhckRpcmVjdGl2ZSxcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIE1hdENoaXBzTW9kdWxlLFxuICAgIEVsZGVyQ2hpcHNNb2R1bGUsXG4gICAgQXN5bmNQaXBlLFxuICAgIE5nSWYsXG4gICAgTmdUZW1wbGF0ZU91dGxldCxcbiAgICBFbGRlclBpcGVzTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyQmFkZ2VEaXJlY3RpdmUsXG4gICAgRWxkZXJCYWRnZUNvbXBvbmVudCxcbiAgICBFbGRlckJhZGdlQ2hpcERpcmVjdGl2ZSxcbiAgICBFbGRlckJhZGdlQ2hpcEF2YXRhckRpcmVjdGl2ZSxcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckJhZGdlTW9kdWxlIHtcbn1cbiJdfQ==
@@ -29,7 +29,7 @@ export class ElderSelectionMasterCheckboxComponent {
29
29
  ngOnInit() {
30
30
  }
31
31
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderSelectionMasterCheckboxComponent, deps: [{ token: i1.DataContextSelectionDirective }], target: i0.ɵɵFactoryTarget.Component }); }
32
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox", ngImport: i0, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div class=\"layout-row place-start-center\"\n *ngIf=\"selectionState.isMultiSelection\"\n [matBadgeHidden]=\"selectionState.count === 0\"\n [elderBadge]=\"selectionState.count + ''\"\n [matBadge]=\"selectionState.count + ''\"\n [matBadgePosition]=\"'above before'\"\n [matBadgeOverlap]=\"false\"\n [matBadgeSize]=\"'small'\"\n >\n <mat-checkbox (change)=\"$event ? dataContextSelection.masterToggle() : null\"\n [checked]=\"selectionState.allSelected\"\n [indeterminate]=\"selectionState.someSelected\"\n >\n </mat-checkbox>\n </div>\n</ng-container>\n", styles: [".mat-badge-small.mat-badge-above .mat-badge-content{top:-6px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i4.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "directive", type: i5.ElderBadgeDirective, selector: "[elderBadge]", inputs: ["elderBadge"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
32
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox", ngImport: i0, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div class=\"layout-row place-start-center\"\n *ngIf=\"selectionState.isMultiSelection\"\n [matBadgeHidden]=\"selectionState.count === 0\"\n [elderBadge]=\"selectionState.count + ''\"\n [matBadge]=\"selectionState.count + ''\"\n [matBadgePosition]=\"'above before'\"\n [matBadgeOverlap]=\"false\"\n [matBadgeSize]=\"'small'\"\n >\n <mat-checkbox (change)=\"$event ? dataContextSelection.masterToggle() : null\"\n [checked]=\"selectionState.allSelected\"\n [indeterminate]=\"selectionState.someSelected\"\n >\n </mat-checkbox>\n </div>\n</ng-container>\n", styles: [".mat-badge-small.mat-badge-above .mat-badge-content{top:-6px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i4.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "directive", type: i5.ElderBadgeDirective, selector: "[elderBadge]", inputs: ["badgeColor", "badgeIcon", "elderBadge", "colorSpec", "avatarSpec"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
33
33
  }
34
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderSelectionMasterCheckboxComponent, decorators: [{
35
35
  type: Component,