@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.
- package/esm2022/lib/common/utils/parse-util.mjs +5 -4
- package/esm2022/lib/components/badge/elder-badge/elder-badge.component.mjs +133 -18
- package/esm2022/lib/components/badge/elder-badge.directive.mjs +72 -19
- package/esm2022/lib/components/badge/elder-badge.module.mjs +28 -10
- package/esm2022/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +1 -1
- package/esm2022/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +22 -12
- package/fesm2022/elderbyte-ngx-starter.mjs +310 -119
- package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/utils/parse-util.d.ts +3 -2
- package/lib/components/badge/elder-badge/elder-badge.component.d.ts +75 -7
- package/lib/components/badge/elder-badge.directive.d.ts +41 -10
- package/lib/components/badge/elder-badge.module.d.ts +3 -1
- package/lib/components/forms/directives/elder-triple-state-checkbox.directive.d.ts +3 -1
- package/package.json +1 -1
- package/src/lib/components/badge/elder-badge/elder-badge.component.scss +21 -1
|
@@ -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
|
|
5
|
+
* @return undefined, if the value is null/undefined/empty
|
|
6
|
+
* @return false, if the value is false, else true.
|
|
6
7
|
*/
|
|
7
|
-
static
|
|
8
|
-
if (bool === undefined || bool
|
|
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,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2UtdXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi91dGlscy9wYXJzZS11dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxTQUFTO0lBRXBCOzs7OztPQUtHO0lBQ0ksTUFBTSxDQUFDLG9CQUFvQixDQUFDLElBQVM7UUFDMUMsSUFBSSxJQUFJLEtBQUssU0FBUyxJQUFJLElBQUksS0FBSyxJQUFJLElBQUksSUFBSSxLQUFLLEVBQUUsRUFBRTtZQUN0RCxPQUFPLFNBQVMsQ0FBQztTQUNsQjthQUFNO1lBQ0wsT0FBTyxDQUFDLENBQUMsSUFBSSxLQUFLLE9BQU8sSUFBSSxJQUFJLEtBQUssS0FBSyxDQUFDLENBQUM7U0FDOUM7SUFDSCxDQUFDO0NBRUYiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgUGFyc2VVdGlsIHtcblxuICAvKipcbiAgICogVHJpZXMgdG8gcGFyc2UgYSBnaXZlbiB2YWx1ZSB0byBhIGJvb2xlYW4uXG4gICAqIEBwYXJhbSBib29sIGEgdmFsdWUgcmVwcmVzZW50aW5nIGEgYm9vbGVhbiBzdGF0ZS5cbiAgICogQHJldHVybiB1bmRlZmluZWQsIGlmIHRoZSB2YWx1ZSBpcyBudWxsL3VuZGVmaW5lZC9lbXB0eVxuICAgKiBAcmV0dXJuIGZhbHNlLCBpZiB0aGUgdmFsdWUgaXMgZmFsc2UsIGVsc2UgdHJ1ZS5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgcGFyc2VCb29sT3JVbmRlZmluZWQoYm9vbDogYW55KTogYm9vbGVhbiB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKGJvb2wgPT09IHVuZGVmaW5lZCB8fCBib29sID09PSBudWxsIHx8IGJvb2wgPT09ICcnKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gIShib29sID09PSAnZmFsc2UnIHx8IGJvb2wgPT09IGZhbHNlKTtcbiAgICB9XG4gIH1cblxufVxuIl19
|
|
@@ -1,39 +1,154 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Input, ViewEncapsulation } from
|
|
2
|
-
import { BehaviorSubject } from
|
|
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
|
-
|
|
9
|
-
|
|
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
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
101
|
+
/***************************************************************************
|
|
102
|
+
* *
|
|
103
|
+
* Templates *
|
|
104
|
+
* *
|
|
105
|
+
**************************************************************************/
|
|
106
|
+
set chipTemplateQuery(template) {
|
|
107
|
+
this.chipTemplate = template;
|
|
19
108
|
}
|
|
20
|
-
|
|
21
|
-
|
|
109
|
+
set chipTemplate(template) {
|
|
110
|
+
this.chipTemplate$.next(template);
|
|
22
111
|
}
|
|
23
|
-
|
|
24
|
-
this.
|
|
25
|
-
|
|
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: {
|
|
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
|
|
33
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
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
|
|
2
|
-
import { ElderBadgeComponent } from
|
|
3
|
-
import { BehaviorSubject
|
|
4
|
-
import {
|
|
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
|
-
|
|
10
|
-
|
|
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.
|
|
15
|
-
|
|
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
|
-
|
|
20
|
-
|
|
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
|
|
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.
|
|
31
|
-
.pipe(
|
|
32
|
-
.subscribe(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
|
-
|
|
35
|
-
|
|
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:
|
|
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,
|
|
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":"AAAA,OAAO,EACL,SAAS,EAGT,KAAK,EAAE,WAAW,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkC,mBAAmB,EAAC,MAAM,qCAAqC,CAAC;AAEzG,OAAO,EAAC,eAAe,EAAC,MAAM,MAAM,CAAC;AAErC,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;;;;AAM9D,MAAM,OAAO,mBAAmB;IAe9B;;;;gFAI4E;IAE5E,YACU,SAAuB,EACvB,gBAAkC,EAClC,QAAkB,EAClB,UAAsB;QAHtB,cAAS,GAAT,SAAS,CAAc;QACvB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,aAAQ,GAAR,QAAQ,CAAU;QAClB,eAAU,GAAV,UAAU,CAAY;QAvBhC;;;;oFAI4E;QAE3D,WAAM,GAAG,IAAI,eAAe,CAAM,SAAS,CAAC,CAAC;QAC7C,eAAU,GAAG,IAAI,eAAe,CAAiB,EAAC,KAAK,EAAE,SAAS,EAAC,CAAC,CAAC;QACrE,gBAAW,GAAG,IAAI,eAAe,CAAkB,SAAS,CAAC,CAAC;QAiB7E,oDAAoD;QACpD,IAAI,CAAC,QAAQ,CAAC,OAAO,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ;QACb,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,qBAAqB,CAAC,CAAC;QAC5E,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC;QAChF,MAAM,mBAAmB,GAAI,YAAY,CAAC,QAAQ,CAAC;QACnD,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,eAAe,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC;QAEvF,oCAAoC;QACpC,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,EAAE,CAAC,aAAa,CAAC;QAC3D,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACxE,IAAI,CAAC,QAAQ,CAAC,eAAe,EAAE,CAAC,MAAM,EAAE,CAAC;QAEzC,IAAI,CAAC,MAAM;aACR,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,mBAAmB,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC;QAEzD,IAAI,CAAC,UAAU;aACZ,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,mBAAmB,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC;QAE3D,IAAI,CAAC,WAAW;aACb,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,mBAAmB,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IAC9D,CAAC;IAED;;;;gFAI4E;IAG5E,IACW,UAAU,CAAC,KAAmB;QACvC,IAAI,CAAC,SAAS,GAAG,EAAC,KAAK,EAAE,KAAK,EAAC,CAAC;IAClC,CAAC;IAED,IACW,SAAS,CAAC,IAAY;QAC/B,IAAI,CAAC,UAAU,GAAG,EAAC,IAAI,EAAE,IAAI,EAAC,CAAC;IACjC,CAAC;IAGD;;;;gFAI4E;IAE5E,IACW,UAAU,CAAC,KAAU;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,IACW,SAAS,CAAC,IAAoB;QACvC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,IACW,UAAU,CAAC,IAAqB;QACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;+GAlGU,mBAAmB;mGAAnB,mBAAmB;;4FAAnB,mBAAmB;kBAH/B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;iBACzB;kLAcC,KAAK;sBADJ,WAAW;uBAAC,OAAO;gBAyDT,UAAU;sBADpB,KAAK;gBAMK,SAAS;sBADnB,KAAK;gBAaK,UAAU;sBADpB,KAAK;gBAMK,SAAS;sBADnB,KAAK;gBAMK,UAAU;sBADpB,KAAK","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
|
|
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
|
|
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
|
|
15
|
+
ElderBadgeComponent,
|
|
16
|
+
ElderBadgeChipDirective,
|
|
17
|
+
ElderBadgeChipAvatarDirective], imports: [MatChipsModule,
|
|
14
18
|
ElderChipsModule,
|
|
15
19
|
AsyncPipe,
|
|
16
|
-
NgIf
|
|
17
|
-
|
|
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,
|
|
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,
|