@ifsworld/granite-components 12.3.3 → 13.0.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/index.mjs +7 -1
- package/esm2022/lib/avatar/avatar-default-status/avatar-default-status.component.mjs +36 -0
- package/esm2022/lib/avatar/avatar.component.mjs +39 -0
- package/esm2022/lib/avatar/avatar.component.public-types.mjs +7 -0
- package/esm2022/lib/avatar/avatar.module.mjs +37 -0
- package/esm2022/lib/avatar/custom-avatar-status.directive.mjs +18 -0
- package/esm2022/lib/avatar/empty-avatar/empty-avatar.component.mjs +47 -0
- package/esm2022/lib/contacts/contacts-profile/contacts-profile.component.mjs +4 -4
- package/esm2022/lib/contacts/contacts.module.mjs +5 -4
- package/esm2022/lib/progress-bar/progress-bar.component.mjs +19 -7
- package/fesm2022/ifsworld-granite-components.mjs +187 -12
- package/fesm2022/ifsworld-granite-components.mjs.map +1 -1
- package/index.d.ts +6 -0
- package/lib/avatar/avatar-default-status/avatar-default-status.component.d.ts +15 -0
- package/lib/avatar/avatar.component.d.ts +16 -0
- package/lib/avatar/avatar.component.public-types.d.ts +7 -0
- package/lib/avatar/avatar.module.d.ts +11 -0
- package/lib/avatar/custom-avatar-status.directive.d.ts +9 -0
- package/lib/avatar/empty-avatar/empty-avatar.component.d.ts +11 -0
- package/lib/contacts/contacts.module.d.ts +3 -2
- package/lib/progress-bar/progress-bar.component.d.ts +3 -1
- package/package.json +1 -1
package/esm2022/index.mjs
CHANGED
|
@@ -51,6 +51,12 @@ export * from './lib/contacts/contacts-trigger/contacts-trigger-for.directive';
|
|
|
51
51
|
export * from './lib/contacts/custom-status.directive';
|
|
52
52
|
export * from './lib/contacts/custom-profile.directive';
|
|
53
53
|
export * from './lib/contacts/contacts-types/contacts.component.public-types';
|
|
54
|
+
export * from './lib/avatar/avatar.module';
|
|
55
|
+
export * from './lib/avatar/avatar.component';
|
|
56
|
+
export * from './lib/avatar/avatar-default-status/avatar-default-status.component';
|
|
57
|
+
export * from './lib/avatar/custom-avatar-status.directive';
|
|
58
|
+
export * from './lib/avatar/empty-avatar/empty-avatar.component';
|
|
59
|
+
export * from './lib/avatar/avatar.component.public-types';
|
|
54
60
|
export * from './lib/progress-bar/progress-bar.module';
|
|
55
61
|
export * from './lib/progress-bar/progress-bar.component';
|
|
56
62
|
export * from './lib/progress-bar/progress-bar.model';
|
|
@@ -83,4 +89,4 @@ export * from './lib/collapsible-group/collapsible-group.module';
|
|
|
83
89
|
export * from './lib/collapsible-group/collapsible-group.component';
|
|
84
90
|
export * from './lib/collapsible-group/collapsible-group-body.directive';
|
|
85
91
|
export * from './lib/collapsible-group/collapsible-group-header.directive';
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/granite-components/src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Public API Surface of ui\n */\n\nexport * from './lib/arrange-grid/arrange-grid.module';\nexport * from './lib/arrange-grid/arrange-grid.component';\nexport * from './lib/arrange-grid/arrange-grid-item.component';\n\nexport * from './lib/grid/grid.module';\nexport * from './lib/grid/grid.component';\n\nexport * from './lib/badge/badge.module';\nexport * from './lib/badge/badge.component';\nexport * from './lib/badge/testing/badge.harness';\n\nexport * from './lib/menu/menu.module';\nexport * from './lib/menu/menu.component';\nexport * from './lib/menu/menu-desktop-animations';\nexport * from './lib/menu/menu-touch-animations';\nexport * from './lib/menu/menu-item.component';\nexport * from './lib/menu/menu-trigger-for.directive';\nexport * from './lib/menu/testing/menu.harness';\nexport * from './lib/menu/divider.directive';\nexport * from './lib/menu/title.directive';\nexport * from './lib/menu/menu-touch-close.component';\nexport * from './lib/menu/menu-touch-title.component';\n\nexport * from './lib/icon/icon.module';\nexport * from './lib/icon/icon.component';\n\nexport * from './lib/toggle-switch/toggle-switch.module';\nexport * from './lib/toggle-switch/toggle-switch.component';\n\nexport * from './lib/radio-button/radio-button.module';\nexport * from './lib/radio-button/radio-button.component';\n\nexport * from './lib/radio-button/radio-group.component';\n\nexport * from './lib/checkbox/checkbox.module';\nexport * from './lib/checkbox/checkbox.component';\n\nexport * from './lib/checkbox/checkbox-group.component';\n\nexport * from './lib/button/button.module';\nexport * from './lib/button/button.component';\n\nexport * from './lib/input-field/input-field.module';\nexport * from './lib/input-field/input-field.component';\n\nexport * from './lib/chips/chips.module';\nexport * from './lib/chips/chip-list.component';\nexport * from './lib/chips/chip.component';\nexport * from './lib/chips/chip-input';\n\nexport * from './lib/label/label.module';\nexport * from './lib/label/label.component';\n\nexport * from './lib/contacts/contacts.module';\nexport * from './lib/contacts/contacts.component';\nexport * from './lib/contacts/contacts-types/contacts.component.public-types';\nexport * from './lib/contacts/contacts-profile/contacts-profile.component';\nexport * from './lib/contacts/contact-item/contact-item.component';\nexport * from './lib/contacts/contact-item-default-status/contact-item-default-status.component';\nexport * from './lib/contacts/contact-item-title/contact-item-title.component';\nexport * from './lib/contacts/contacts-trigger/contacts-trigger-for.directive';\nexport * from './lib/contacts/custom-status.directive';\nexport * from './lib/contacts/custom-profile.directive';\nexport * from './lib/contacts/contacts-types/contacts.component.public-types';\n\nexport * from './lib/avatar/avatar.module';\nexport * from './lib/avatar/avatar.component';\nexport * from './lib/avatar/avatar-default-status/avatar-default-status.component';\nexport * from './lib/avatar/custom-avatar-status.directive';\nexport * from './lib/avatar/empty-avatar/empty-avatar.component';\nexport * from './lib/avatar/avatar.component.public-types';\n\nexport * from './lib/progress-bar/progress-bar.module';\nexport * from './lib/progress-bar/progress-bar.component';\nexport * from './lib/progress-bar/progress-bar.model';\n\n// Temporary\nexport * from './lib/core/client-environment';\nexport * from './lib/core/core.module';\nexport * from './lib/core/devices/client-output-touch.directive';\nexport * from './lib/core/devices/client-output-desktop.directive';\nexport * from './lib/core/devices/client-input-touch.directive';\nexport * from './lib/core/devices/client-input-desktop.directive';\nexport * from './lib/core/common-behaviors/disabled';\nexport * from './lib/core/hide-on-overflow.directive';\n\nexport * from './lib/core/pipes/pure-pipes.module';\nexport * from './lib/core/pipes/title.pipe';\nexport * from './lib/core/types';\n\nexport * from './lib/card-list/card-list.module';\nexport * from './lib/card-list/card-list.component';\nexport * from './lib/card-list/card/card.component';\nexport * from './lib/card-list/card/card-content/card-content.component';\nexport * from './lib/card-list/card/card-content/card-actions.component';\nexport * from './lib/card-list/card/card-content/card-body.component';\nexport * from './lib/card-list/card/card-content/card-header.component';\nexport * from './lib/card-list/card/card-avatar.component';\nexport * from './lib/card-list/card/card-content/card-header-title.component';\nexport * from './lib/card-list/card/card-content/card-header-subtitle.component';\nexport * from './lib/card-list/card/card-content/card-footer.component';\n\nexport * from './lib/file-upload/file-upload.module';\nexport * from './lib/file-upload/file-upload.component';\n\nexport * from './lib/collapsible-group/collapsible-group.module';\nexport * from './lib/collapsible-group/collapsible-group.component';\nexport * from './lib/collapsible-group/collapsible-group-body.directive';\nexport * from './lib/collapsible-group/collapsible-group-header.directive';\n"]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Input, } from '@angular/core';
|
|
2
|
+
import { AVATAR_DEFAULT_STATUS, } from '../avatar.component.public-types';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class GraniteAvatarDefaultStatusComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.AVATAR_STATUS = AVATAR_DEFAULT_STATUS;
|
|
7
|
+
}
|
|
8
|
+
get statusClass() {
|
|
9
|
+
switch (this.status) {
|
|
10
|
+
case this.AVATAR_STATUS.AVAILABLE:
|
|
11
|
+
return 'available';
|
|
12
|
+
case this.AVATAR_STATUS.DO_NOT_DISTURB:
|
|
13
|
+
return 'do-not-disturb';
|
|
14
|
+
case this.AVATAR_STATUS.DISABLED: {
|
|
15
|
+
return 'disabled';
|
|
16
|
+
}
|
|
17
|
+
case this.AVATAR_STATUS.AWAY: {
|
|
18
|
+
return 'away';
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarDefaultStatusComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GraniteAvatarDefaultStatusComponent, selector: "granite-avatar-default-status", inputs: { status: "status" }, host: { properties: { "class": "this.statusClass" }, classAttribute: "granite-avatar-default-status" }, ngImport: i0, template: '', isInline: true, styles: [":host{display:block;width:.5rem;height:.5rem;outline:.125rem solid var(--granite-color-background);border-radius:100%}:host.available{background:var(--granite-color-signal-ok)}:host.do-not-disturb{background:var(--granite-color-signal-failure)}:host.disabled{background:var(--granite-color-signal-neutral)}:host.away{background:var(--granite-color-signal-warning)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
24
|
+
}
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarDefaultStatusComponent, decorators: [{
|
|
26
|
+
type: Component,
|
|
27
|
+
args: [{ selector: 'granite-avatar-default-status', host: {
|
|
28
|
+
class: 'granite-avatar-default-status',
|
|
29
|
+
}, template: '', changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;width:.5rem;height:.5rem;outline:.125rem solid var(--granite-color-background);border-radius:100%}:host.available{background:var(--granite-color-signal-ok)}:host.do-not-disturb{background:var(--granite-color-signal-failure)}:host.disabled{background:var(--granite-color-signal-neutral)}:host.away{background:var(--granite-color-signal-warning)}\n"] }]
|
|
30
|
+
}], propDecorators: { status: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}], statusClass: [{
|
|
33
|
+
type: HostBinding,
|
|
34
|
+
args: ['class']
|
|
35
|
+
}] } });
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLWRlZmF1bHQtc3RhdHVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZ3Jhbml0ZS1jb21wb25lbnRzL3NyYy9saWIvYXZhdGFyL2F2YXRhci1kZWZhdWx0LXN0YXR1cy9hdmF0YXItZGVmYXVsdC1zdGF0dXMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFdBQVcsRUFDWCxLQUFLLEdBQ04sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUNMLHFCQUFxQixHQUV0QixNQUFNLGtDQUFrQyxDQUFDOztBQWlCMUMsTUFBTSxPQUFPLG1DQUFtQztJQVRoRDtRQVlFLGtCQUFhLEdBQUcscUJBQXFCLENBQUM7S0FrQnZDO0lBaEJDLElBQTBCLFdBQVc7UUFDbkMsUUFBUSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDcEIsS0FBSyxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVM7Z0JBQy9CLE9BQU8sV0FBVyxDQUFDO1lBRXJCLEtBQUssSUFBSSxDQUFDLGFBQWEsQ0FBQyxjQUFjO2dCQUNwQyxPQUFPLGdCQUFnQixDQUFDO1lBRTFCLEtBQUssSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO2dCQUNqQyxPQUFPLFVBQVUsQ0FBQztZQUNwQixDQUFDO1lBQ0QsS0FBSyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7Z0JBQzdCLE9BQU8sTUFBTSxDQUFDO1lBQ2hCLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQzs4R0FwQlUsbUNBQW1DO2tHQUFuQyxtQ0FBbUMsMk1BSnBDLEVBQUU7OzJGQUlELG1DQUFtQztrQkFUL0MsU0FBUzsrQkFDRSwrQkFBK0IsUUFDbkM7d0JBQ0osS0FBSyxFQUFFLCtCQUErQjtxQkFDdkMsWUFDUyxFQUFFLG1CQUVLLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLE1BQU07c0JBQWQsS0FBSztnQkFJb0IsV0FBVztzQkFBcEMsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSG9zdEJpbmRpbmcsXG4gIElucHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIEFWQVRBUl9ERUZBVUxUX1NUQVRVUyxcbiAgQXZhdGFyRGVmYXVsdFN0YXR1c2VzLFxufSBmcm9tICcuLi9hdmF0YXIuY29tcG9uZW50LnB1YmxpYy10eXBlcyc7XG5cbmV4cG9ydCB0eXBlIFN0YXR1c0NsYXNzZXMgPVxuICB8ICdhdmFpbGFibGUnXG4gIHwgJ2RvLW5vdC1kaXN0dXJiJ1xuICB8ICdkaXNhYmxlZCdcbiAgfCAnYXdheSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2dyYW5pdGUtYXZhdGFyLWRlZmF1bHQtc3RhdHVzJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZ3Jhbml0ZS1hdmF0YXItZGVmYXVsdC1zdGF0dXMnLFxuICB9LFxuICB0ZW1wbGF0ZTogJycsXG4gIHN0eWxlVXJsczogWycuL2F2YXRhci1kZWZhdWx0LXN0YXR1cy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgR3Jhbml0ZUF2YXRhckRlZmF1bHRTdGF0dXNDb21wb25lbnQge1xuICBASW5wdXQoKSBzdGF0dXM6IEF2YXRhckRlZmF1bHRTdGF0dXNlcztcblxuICBBVkFUQVJfU1RBVFVTID0gQVZBVEFSX0RFRkFVTFRfU1RBVFVTO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKSBnZXQgc3RhdHVzQ2xhc3MoKTogU3RhdHVzQ2xhc3NlcyB7XG4gICAgc3dpdGNoICh0aGlzLnN0YXR1cykge1xuICAgICAgY2FzZSB0aGlzLkFWQVRBUl9TVEFUVVMuQVZBSUxBQkxFOlxuICAgICAgICByZXR1cm4gJ2F2YWlsYWJsZSc7XG5cbiAgICAgIGNhc2UgdGhpcy5BVkFUQVJfU1RBVFVTLkRPX05PVF9ESVNUVVJCOlxuICAgICAgICByZXR1cm4gJ2RvLW5vdC1kaXN0dXJiJztcblxuICAgICAgY2FzZSB0aGlzLkFWQVRBUl9TVEFUVVMuRElTQUJMRUQ6IHtcbiAgICAgICAgcmV0dXJuICdkaXNhYmxlZCc7XG4gICAgICB9XG4gICAgICBjYXNlIHRoaXMuQVZBVEFSX1NUQVRVUy5BV0FZOiB7XG4gICAgICAgIHJldHVybiAnYXdheSc7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, ContentChildren, QueryList, } from '@angular/core';
|
|
2
|
+
import { ContactsTriggerDataComponent } from '../contacts/contacts-trigger/contacts-trigger-data';
|
|
3
|
+
import { GraniteCustomAvatarStatusDirective } from './custom-avatar-status.directive';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "./avatar-default-status/avatar-default-status.component";
|
|
7
|
+
import * as i3 from "./empty-avatar/empty-avatar.component";
|
|
8
|
+
export class GraniteAvatarComponent extends ContactsTriggerDataComponent {
|
|
9
|
+
ngAfterContentChecked() {
|
|
10
|
+
this._customStatusDirectives = this._customStatusesQueryList
|
|
11
|
+
.toArray()
|
|
12
|
+
.reduce((directives, next) => {
|
|
13
|
+
return {
|
|
14
|
+
...directives,
|
|
15
|
+
[next.graniteCustomAvatarStatus]: next.templateRef,
|
|
16
|
+
};
|
|
17
|
+
}, {});
|
|
18
|
+
}
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
20
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.4", type: GraniteAvatarComponent, selector: "granite-avatar", inputs: { name: "name", surname: "surname", avatar: "avatar", status: "status" }, host: { classAttribute: "granite-avatar" }, queries: [{ propertyName: "_customStatusesQueryList", predicate: GraniteCustomAvatarStatusDirective }], exportAs: ["graniteAvatar"], usesInheritance: true, ngImport: i0, template: "<img\n data-fnd=\"profile-avatar\"\n *ngIf=\"avatar; else noProfileAvatar\"\n [src]=\"avatar\"\n alt=\"avatar\"\n class=\"profile-avatar profile-size\"\n/>\n\n<ng-template #noProfileAvatar>\n <granite-empty-avatar\n class=\"profile-size\"\n [name]=\"name\"\n [surname]=\"surname\"\n ></granite-empty-avatar>\n</ng-template>\n\n@if (status && _customStatusDirectives[status]) {\n <ng-container *ngTemplateOutlet=\"customStatus\"></ng-container>\n} @else if (status) {\n <ng-container *ngTemplateOutlet=\"defaultStatus\"></ng-container>\n}\n\n<ng-template #defaultStatus>\n <granite-avatar-default-status\n class=\"profile-default-status\"\n [attr.data-fnd]=\"status + '-status'\"\n [status]=\"status\"\n ></granite-avatar-default-status>\n</ng-template>\n\n<ng-template #customStatus>\n <div\n [attr.data-fnd]=\"'profile-status-custom'\"\n [class]=\"'profile-status-' + status\"\n class=\"profile-custom-status\"\n >\n <ng-container\n *ngTemplateOutlet=\"_customStatusDirectives[status]\"\n ></ng-container>\n </div>\n</ng-template>\n", styles: [":host .profile-default-status,:host .profile-custom-status{position:absolute;inset-inline-end:0;bottom:0}:host{display:block;position:relative;width:1.5rem;height:1.5rem;color:var(--granite-color-signal-info);font-size:var(--granite-font-size-body-small);font-weight:var(--granite-font-weight-regular)}:host .profile{display:flex;align-items:center;margin-bottom:var(--granite-spacing-8);gap:var(--granite-spacing-4)}:host .profile-avatar{width:inherit;height:inherit;border-radius:50%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.GraniteAvatarDefaultStatusComponent, selector: "granite-avatar-default-status", inputs: ["status"] }, { kind: "component", type: i3.GraniteEmptyAvatarComponent, selector: "granite-empty-avatar", inputs: ["name", "surname"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarComponent, decorators: [{
|
|
23
|
+
type: Component,
|
|
24
|
+
args: [{ selector: 'granite-avatar', exportAs: 'graniteAvatar', host: {
|
|
25
|
+
class: 'granite-avatar',
|
|
26
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<img\n data-fnd=\"profile-avatar\"\n *ngIf=\"avatar; else noProfileAvatar\"\n [src]=\"avatar\"\n alt=\"avatar\"\n class=\"profile-avatar profile-size\"\n/>\n\n<ng-template #noProfileAvatar>\n <granite-empty-avatar\n class=\"profile-size\"\n [name]=\"name\"\n [surname]=\"surname\"\n ></granite-empty-avatar>\n</ng-template>\n\n@if (status && _customStatusDirectives[status]) {\n <ng-container *ngTemplateOutlet=\"customStatus\"></ng-container>\n} @else if (status) {\n <ng-container *ngTemplateOutlet=\"defaultStatus\"></ng-container>\n}\n\n<ng-template #defaultStatus>\n <granite-avatar-default-status\n class=\"profile-default-status\"\n [attr.data-fnd]=\"status + '-status'\"\n [status]=\"status\"\n ></granite-avatar-default-status>\n</ng-template>\n\n<ng-template #customStatus>\n <div\n [attr.data-fnd]=\"'profile-status-custom'\"\n [class]=\"'profile-status-' + status\"\n class=\"profile-custom-status\"\n >\n <ng-container\n *ngTemplateOutlet=\"_customStatusDirectives[status]\"\n ></ng-container>\n </div>\n</ng-template>\n", styles: [":host .profile-default-status,:host .profile-custom-status{position:absolute;inset-inline-end:0;bottom:0}:host{display:block;position:relative;width:1.5rem;height:1.5rem;color:var(--granite-color-signal-info);font-size:var(--granite-font-size-body-small);font-weight:var(--granite-font-weight-regular)}:host .profile{display:flex;align-items:center;margin-bottom:var(--granite-spacing-8);gap:var(--granite-spacing-4)}:host .profile-avatar{width:inherit;height:inherit;border-radius:50%}\n"] }]
|
|
27
|
+
}], propDecorators: { name: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], surname: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}], avatar: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], status: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}], _customStatusesQueryList: [{
|
|
36
|
+
type: ContentChildren,
|
|
37
|
+
args: [GraniteCustomAvatarStatusDirective]
|
|
38
|
+
}] } });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZ3Jhbml0ZS1jb21wb25lbnRzL3NyYy9saWIvYXZhdGFyL2F2YXRhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2dyYW5pdGUtY29tcG9uZW50cy9zcmMvbGliL2F2YXRhci9hdmF0YXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsS0FBSyxFQUNMLGVBQWUsRUFDZixTQUFTLEdBR1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDbEcsT0FBTyxFQUFFLGtDQUFrQyxFQUFFLE1BQU0sa0NBQWtDLENBQUM7Ozs7O0FBWXRGLE1BQU0sT0FBTyxzQkFDWCxTQUFRLDRCQUE0QjtJQVlwQyxxQkFBcUI7UUFDbkIsSUFBSSxDQUFDLHVCQUF1QixHQUFHLElBQUksQ0FBQyx3QkFBd0I7YUFDekQsT0FBTyxFQUFFO2FBQ1QsTUFBTSxDQUFDLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxFQUFFO1lBQzNCLE9BQU87Z0JBQ0wsR0FBRyxVQUFVO2dCQUNiLENBQUMsSUFBSSxDQUFDLHlCQUF5QixDQUFDLEVBQUUsSUFBSSxDQUFDLFdBQVc7YUFDbkQsQ0FBQztRQUNKLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNYLENBQUM7OEdBdEJVLHNCQUFzQjtrR0FBdEIsc0JBQXNCLDZOQVNoQixrQ0FBa0MsaUZDL0JyRCwrakNBeUNBOzsyRkRuQmEsc0JBQXNCO2tCQVZsQyxTQUFTOytCQUNFLGdCQUFnQixZQUNoQixlQUFlLFFBQ25CO3dCQUNKLEtBQUssRUFBRSxnQkFBZ0I7cUJBQ3hCLG1CQUdnQix1QkFBdUIsQ0FBQyxNQUFNOzhCQU10QyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBR04sd0JBQXdCO3NCQUR2QixlQUFlO3VCQUFDLGtDQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIElucHV0LFxuICBDb250ZW50Q2hpbGRyZW4sXG4gIFF1ZXJ5TGlzdCxcbiAgQWZ0ZXJDb250ZW50Q2hlY2tlZCxcbiAgVGVtcGxhdGVSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udGFjdHNUcmlnZ2VyRGF0YUNvbXBvbmVudCB9IGZyb20gJy4uL2NvbnRhY3RzL2NvbnRhY3RzLXRyaWdnZXIvY29udGFjdHMtdHJpZ2dlci1kYXRhJztcbmltcG9ydCB7IEdyYW5pdGVDdXN0b21BdmF0YXJTdGF0dXNEaXJlY3RpdmUgfSBmcm9tICcuL2N1c3RvbS1hdmF0YXItc3RhdHVzLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBBdmF0YXJEZWZhdWx0U3RhdHVzZXMgfSBmcm9tICcuL2F2YXRhci5jb21wb25lbnQucHVibGljLXR5cGVzJztcbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2dyYW5pdGUtYXZhdGFyJyxcbiAgZXhwb3J0QXM6ICdncmFuaXRlQXZhdGFyJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZ3Jhbml0ZS1hdmF0YXInLFxuICB9LFxuICB0ZW1wbGF0ZVVybDogJy4vYXZhdGFyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYXZhdGFyLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBHcmFuaXRlQXZhdGFyQ29tcG9uZW50XG4gIGV4dGVuZHMgQ29udGFjdHNUcmlnZ2VyRGF0YUNvbXBvbmVudFxuICBpbXBsZW1lbnRzIEFmdGVyQ29udGVudENoZWNrZWRcbntcbiAgQElucHV0KCkgbmFtZTogc3RyaW5nO1xuICBASW5wdXQoKSBzdXJuYW1lOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGF2YXRhcjogc3RyaW5nO1xuICBASW5wdXQoKSBzdGF0dXM6IEF2YXRhckRlZmF1bHRTdGF0dXNlcztcblxuICBAQ29udGVudENoaWxkcmVuKEdyYW5pdGVDdXN0b21BdmF0YXJTdGF0dXNEaXJlY3RpdmUpXG4gIF9jdXN0b21TdGF0dXNlc1F1ZXJ5TGlzdDogUXVlcnlMaXN0PEdyYW5pdGVDdXN0b21BdmF0YXJTdGF0dXNEaXJlY3RpdmU+O1xuICBfY3VzdG9tU3RhdHVzRGlyZWN0aXZlczogUmVjb3JkPHN0cmluZywgVGVtcGxhdGVSZWY8dW5rbm93bj4+O1xuXG4gIG5nQWZ0ZXJDb250ZW50Q2hlY2tlZCgpOiB2b2lkIHtcbiAgICB0aGlzLl9jdXN0b21TdGF0dXNEaXJlY3RpdmVzID0gdGhpcy5fY3VzdG9tU3RhdHVzZXNRdWVyeUxpc3RcbiAgICAgIC50b0FycmF5KClcbiAgICAgIC5yZWR1Y2UoKGRpcmVjdGl2ZXMsIG5leHQpID0+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5kaXJlY3RpdmVzLFxuICAgICAgICAgIFtuZXh0LmdyYW5pdGVDdXN0b21BdmF0YXJTdGF0dXNdOiBuZXh0LnRlbXBsYXRlUmVmLFxuICAgICAgICB9O1xuICAgICAgfSwge30pO1xuICB9XG59XG4iLCI8aW1nXG4gIGRhdGEtZm5kPVwicHJvZmlsZS1hdmF0YXJcIlxuICAqbmdJZj1cImF2YXRhcjsgZWxzZSBub1Byb2ZpbGVBdmF0YXJcIlxuICBbc3JjXT1cImF2YXRhclwiXG4gIGFsdD1cImF2YXRhclwiXG4gIGNsYXNzPVwicHJvZmlsZS1hdmF0YXIgcHJvZmlsZS1zaXplXCJcbi8+XG5cbjxuZy10ZW1wbGF0ZSAjbm9Qcm9maWxlQXZhdGFyPlxuICA8Z3Jhbml0ZS1lbXB0eS1hdmF0YXJcbiAgICBjbGFzcz1cInByb2ZpbGUtc2l6ZVwiXG4gICAgW25hbWVdPVwibmFtZVwiXG4gICAgW3N1cm5hbWVdPVwic3VybmFtZVwiXG4gID48L2dyYW5pdGUtZW1wdHktYXZhdGFyPlxuPC9uZy10ZW1wbGF0ZT5cblxuQGlmIChzdGF0dXMgJiYgX2N1c3RvbVN0YXR1c0RpcmVjdGl2ZXNbc3RhdHVzXSkge1xuICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY3VzdG9tU3RhdHVzXCI+PC9uZy1jb250YWluZXI+XG59IEBlbHNlIGlmIChzdGF0dXMpIHtcbiAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImRlZmF1bHRTdGF0dXNcIj48L25nLWNvbnRhaW5lcj5cbn1cblxuPG5nLXRlbXBsYXRlICNkZWZhdWx0U3RhdHVzPlxuICA8Z3Jhbml0ZS1hdmF0YXItZGVmYXVsdC1zdGF0dXNcbiAgICBjbGFzcz1cInByb2ZpbGUtZGVmYXVsdC1zdGF0dXNcIlxuICAgIFthdHRyLmRhdGEtZm5kXT1cInN0YXR1cyArICctc3RhdHVzJ1wiXG4gICAgW3N0YXR1c109XCJzdGF0dXNcIlxuICA+PC9ncmFuaXRlLWF2YXRhci1kZWZhdWx0LXN0YXR1cz5cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy10ZW1wbGF0ZSAjY3VzdG9tU3RhdHVzPlxuICA8ZGl2XG4gICAgW2F0dHIuZGF0YS1mbmRdPVwiJ3Byb2ZpbGUtc3RhdHVzLWN1c3RvbSdcIlxuICAgIFtjbGFzc109XCIncHJvZmlsZS1zdGF0dXMtJyArIHN0YXR1c1wiXG4gICAgY2xhc3M9XCJwcm9maWxlLWN1c3RvbS1zdGF0dXNcIlxuICA+XG4gICAgPG5nLWNvbnRhaW5lclxuICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJfY3VzdG9tU3RhdHVzRGlyZWN0aXZlc1tzdGF0dXNdXCJcbiAgICA+PC9uZy1jb250YWluZXI+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export const AVATAR_DEFAULT_STATUS = {
|
|
2
|
+
AVAILABLE: 'Available',
|
|
3
|
+
DO_NOT_DISTURB: 'DoNotDisturb',
|
|
4
|
+
DISABLED: 'Disabled',
|
|
5
|
+
AWAY: 'Away',
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5wdWJsaWMtdHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2dyYW5pdGUtY29tcG9uZW50cy9zcmMvbGliL2F2YXRhci9hdmF0YXIuY29tcG9uZW50LnB1YmxpYy10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRztJQUNuQyxTQUFTLEVBQUUsV0FBVztJQUN0QixjQUFjLEVBQUUsY0FBYztJQUM5QixRQUFRLEVBQUUsVUFBVTtJQUNwQixJQUFJLEVBQUUsTUFBTTtDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBBdmF0YXJEZWZhdWx0U3RhdHVzZXMgPVxuICAodHlwZW9mIEFWQVRBUl9ERUZBVUxUX1NUQVRVUylba2V5b2YgdHlwZW9mIEFWQVRBUl9ERUZBVUxUX1NUQVRVU107XG5cbmV4cG9ydCBjb25zdCBBVkFUQVJfREVGQVVMVF9TVEFUVVMgPSB7XG4gIEFWQUlMQUJMRTogJ0F2YWlsYWJsZScsXG4gIERPX05PVF9ESVNUVVJCOiAnRG9Ob3REaXN0dXJiJyxcbiAgRElTQUJMRUQ6ICdEaXNhYmxlZCcsXG4gIEFXQVk6ICdBd2F5Jyxcbn0gYXMgY29uc3Q7XG4iXX0=
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { GraniteAvatarComponent } from './avatar.component';
|
|
4
|
+
import { GraniteCustomAvatarStatusDirective } from './custom-avatar-status.directive';
|
|
5
|
+
import { GraniteAvatarDefaultStatusComponent } from './avatar-default-status/avatar-default-status.component';
|
|
6
|
+
import { GraniteEmptyAvatarComponent } from './empty-avatar/empty-avatar.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class GraniteAvatarModule {
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarModule, declarations: [GraniteAvatarComponent,
|
|
11
|
+
GraniteAvatarDefaultStatusComponent,
|
|
12
|
+
GraniteCustomAvatarStatusDirective,
|
|
13
|
+
GraniteEmptyAvatarComponent], imports: [CommonModule], exports: [GraniteAvatarComponent,
|
|
14
|
+
GraniteAvatarDefaultStatusComponent,
|
|
15
|
+
GraniteCustomAvatarStatusDirective,
|
|
16
|
+
GraniteEmptyAvatarComponent] }); }
|
|
17
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarModule, imports: [CommonModule] }); }
|
|
18
|
+
}
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteAvatarModule, decorators: [{
|
|
20
|
+
type: NgModule,
|
|
21
|
+
args: [{
|
|
22
|
+
imports: [CommonModule],
|
|
23
|
+
declarations: [
|
|
24
|
+
GraniteAvatarComponent,
|
|
25
|
+
GraniteAvatarDefaultStatusComponent,
|
|
26
|
+
GraniteCustomAvatarStatusDirective,
|
|
27
|
+
GraniteEmptyAvatarComponent,
|
|
28
|
+
],
|
|
29
|
+
exports: [
|
|
30
|
+
GraniteAvatarComponent,
|
|
31
|
+
GraniteAvatarDefaultStatusComponent,
|
|
32
|
+
GraniteCustomAvatarStatusDirective,
|
|
33
|
+
GraniteEmptyAvatarComponent,
|
|
34
|
+
],
|
|
35
|
+
}]
|
|
36
|
+
}] });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZ3Jhbml0ZS1jb21wb25lbnRzL3NyYy9saWIvYXZhdGFyL2F2YXRhci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtDQUFrQyxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDdEYsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0seURBQXlELENBQUM7QUFDOUcsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBaUJwRixNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7K0dBQW5CLG1CQUFtQixpQkFaNUIsc0JBQXNCO1lBQ3RCLG1DQUFtQztZQUNuQyxrQ0FBa0M7WUFDbEMsMkJBQTJCLGFBTG5CLFlBQVksYUFRcEIsc0JBQXNCO1lBQ3RCLG1DQUFtQztZQUNuQyxrQ0FBa0M7WUFDbEMsMkJBQTJCOytHQUdsQixtQkFBbUIsWUFkcEIsWUFBWTs7MkZBY1gsbUJBQW1CO2tCQWYvQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjt3QkFDdEIsbUNBQW1DO3dCQUNuQyxrQ0FBa0M7d0JBQ2xDLDJCQUEyQjtxQkFDNUI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHNCQUFzQjt3QkFDdEIsbUNBQW1DO3dCQUNuQyxrQ0FBa0M7d0JBQ2xDLDJCQUEyQjtxQkFDNUI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEdyYW5pdGVBdmF0YXJDb21wb25lbnQgfSBmcm9tICcuL2F2YXRhci5jb21wb25lbnQnO1xuaW1wb3J0IHsgR3Jhbml0ZUN1c3RvbUF2YXRhclN0YXR1c0RpcmVjdGl2ZSB9IGZyb20gJy4vY3VzdG9tLWF2YXRhci1zdGF0dXMuZGlyZWN0aXZlJztcbmltcG9ydCB7IEdyYW5pdGVBdmF0YXJEZWZhdWx0U3RhdHVzQ29tcG9uZW50IH0gZnJvbSAnLi9hdmF0YXItZGVmYXVsdC1zdGF0dXMvYXZhdGFyLWRlZmF1bHQtc3RhdHVzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBHcmFuaXRlRW1wdHlBdmF0YXJDb21wb25lbnQgfSBmcm9tICcuL2VtcHR5LWF2YXRhci9lbXB0eS1hdmF0YXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEdyYW5pdGVBdmF0YXJDb21wb25lbnQsXG4gICAgR3Jhbml0ZUF2YXRhckRlZmF1bHRTdGF0dXNDb21wb25lbnQsXG4gICAgR3Jhbml0ZUN1c3RvbUF2YXRhclN0YXR1c0RpcmVjdGl2ZSxcbiAgICBHcmFuaXRlRW1wdHlBdmF0YXJDb21wb25lbnQsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBHcmFuaXRlQXZhdGFyQ29tcG9uZW50LFxuICAgIEdyYW5pdGVBdmF0YXJEZWZhdWx0U3RhdHVzQ29tcG9uZW50LFxuICAgIEdyYW5pdGVDdXN0b21BdmF0YXJTdGF0dXNEaXJlY3RpdmUsXG4gICAgR3Jhbml0ZUVtcHR5QXZhdGFyQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBHcmFuaXRlQXZhdGFyTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Directive, Input, TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class GraniteCustomAvatarStatusDirective {
|
|
4
|
+
constructor(templateRef) {
|
|
5
|
+
this.templateRef = templateRef;
|
|
6
|
+
}
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteCustomAvatarStatusDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
8
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.4", type: GraniteCustomAvatarStatusDirective, selector: "[graniteCustomAvatarStatus]", inputs: { graniteCustomAvatarStatus: "graniteCustomAvatarStatus" }, ngImport: i0 }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteCustomAvatarStatusDirective, decorators: [{
|
|
11
|
+
type: Directive,
|
|
12
|
+
args: [{
|
|
13
|
+
selector: '[graniteCustomAvatarStatus]',
|
|
14
|
+
}]
|
|
15
|
+
}], ctorParameters: () => [{ type: i0.TemplateRef }], propDecorators: { graniteCustomAvatarStatus: [{
|
|
16
|
+
type: Input
|
|
17
|
+
}] } });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWF2YXRhci1zdGF0dXMuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9ncmFuaXRlLWNvbXBvbmVudHMvc3JjL2xpYi9hdmF0YXIvY3VzdG9tLWF2YXRhci1zdGF0dXMuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLOUQsTUFBTSxPQUFPLGtDQUFrQztJQUk3QyxZQUFtQixXQUFpQztRQUFqQyxnQkFBVyxHQUFYLFdBQVcsQ0FBc0I7SUFBRyxDQUFDOzhHQUo3QyxrQ0FBa0M7a0dBQWxDLGtDQUFrQzs7MkZBQWxDLGtDQUFrQztrQkFIOUMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsNkJBQTZCO2lCQUN4QztnRkFHQyx5QkFBeUI7c0JBRHhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZ3Jhbml0ZUN1c3RvbUF2YXRhclN0YXR1c10nLFxufSlcbmV4cG9ydCBjbGFzcyBHcmFuaXRlQ3VzdG9tQXZhdGFyU3RhdHVzRGlyZWN0aXZlIHtcbiAgQElucHV0KClcbiAgZ3Jhbml0ZUN1c3RvbUF2YXRhclN0YXR1czogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8dW5rbm93bj4pIHt9XG59XG4iXX0=
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class GraniteEmptyAvatarComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this._firstNameLetter = '';
|
|
6
|
+
this._firstSurnameLetter = '';
|
|
7
|
+
}
|
|
8
|
+
ngOnChanges(changes) {
|
|
9
|
+
if (changes.name) {
|
|
10
|
+
this._firstNameLetter =
|
|
11
|
+
changes.name.currentValue?.charAt(0)?.toUpperCase() || '';
|
|
12
|
+
}
|
|
13
|
+
if (changes.surname) {
|
|
14
|
+
this._firstSurnameLetter =
|
|
15
|
+
changes.surname.currentValue?.charAt(0)?.toUpperCase() || '';
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteEmptyAvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GraniteEmptyAvatarComponent, selector: "granite-empty-avatar", inputs: { name: "name", surname: "surname" }, host: { classAttribute: "granite-empty-avatar" }, usesOnChanges: true, ngImport: i0, template: `
|
|
20
|
+
<div class="no-profile-avatar">
|
|
21
|
+
<span
|
|
22
|
+
data-fnd="no-profile-avatar-initials"
|
|
23
|
+
class="no-profile-avatar-initials"
|
|
24
|
+
>{{ _firstNameLetter }}{{ _firstSurnameLetter }}</span
|
|
25
|
+
>
|
|
26
|
+
</div>
|
|
27
|
+
`, isInline: true, styles: [":host{width:inherit;height:inherit}:host .no-profile-avatar{display:flex;width:inherit;height:inherit;border-radius:100%;background:var(--granite-color-background-info);justify-content:center;align-items:center}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
28
|
+
}
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteEmptyAvatarComponent, decorators: [{
|
|
30
|
+
type: Component,
|
|
31
|
+
args: [{ selector: 'granite-empty-avatar', host: {
|
|
32
|
+
class: 'granite-empty-avatar',
|
|
33
|
+
}, template: `
|
|
34
|
+
<div class="no-profile-avatar">
|
|
35
|
+
<span
|
|
36
|
+
data-fnd="no-profile-avatar-initials"
|
|
37
|
+
class="no-profile-avatar-initials"
|
|
38
|
+
>{{ _firstNameLetter }}{{ _firstSurnameLetter }}</span
|
|
39
|
+
>
|
|
40
|
+
</div>
|
|
41
|
+
`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{width:inherit;height:inherit}:host .no-profile-avatar{display:flex;width:inherit;height:inherit;border-radius:100%;background:var(--granite-color-background-info);justify-content:center;align-items:center}\n"] }]
|
|
42
|
+
}], propDecorators: { name: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}], surname: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}] } });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1wdHktYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZ3Jhbml0ZS1jb21wb25lbnRzL3NyYy9saWIvYXZhdGFyL2VtcHR5LWF2YXRhci9lbXB0eS1hdmF0YXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssR0FHTixNQUFNLGVBQWUsQ0FBQzs7QUFtQnZCLE1BQU0sT0FBTywyQkFBMkI7SUFqQnhDO1FBcUJFLHFCQUFnQixHQUFXLEVBQUUsQ0FBQztRQUM5Qix3QkFBbUIsR0FBVyxFQUFFLENBQUM7S0FZbEM7SUFWQyxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDakIsSUFBSSxDQUFDLGdCQUFnQjtnQkFDbkIsT0FBTyxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsQ0FBQztRQUM5RCxDQUFDO1FBQ0QsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLG1CQUFtQjtnQkFDdEIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsQ0FBQztRQUNqRSxDQUFDO0lBQ0gsQ0FBQzs4R0FoQlUsMkJBQTJCO2tHQUEzQiwyQkFBMkIsaUxBWjVCOzs7Ozs7OztHQVFUOzsyRkFJVSwyQkFBMkI7a0JBakJ2QyxTQUFTOytCQUNFLHNCQUFzQixRQUMxQjt3QkFDSixLQUFLLEVBQUUsc0JBQXNCO3FCQUM5QixZQUNTOzs7Ozs7OztHQVFULG1CQUVnQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgU2ltcGxlQ2hhbmdlcyxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2dyYW5pdGUtZW1wdHktYXZhdGFyJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZ3Jhbml0ZS1lbXB0eS1hdmF0YXInLFxuICB9LFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJuby1wcm9maWxlLWF2YXRhclwiPlxuICAgICAgPHNwYW5cbiAgICAgICAgZGF0YS1mbmQ9XCJuby1wcm9maWxlLWF2YXRhci1pbml0aWFsc1wiXG4gICAgICAgIGNsYXNzPVwibm8tcHJvZmlsZS1hdmF0YXItaW5pdGlhbHNcIlxuICAgICAgICA+e3sgX2ZpcnN0TmFtZUxldHRlciB9fXt7IF9maXJzdFN1cm5hbWVMZXR0ZXIgfX08L3NwYW5cbiAgICAgID5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vZW1wdHktYXZhdGFyLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBHcmFuaXRlRW1wdHlBdmF0YXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBASW5wdXQoKSBuYW1lOiBzdHJpbmc7XG4gIEBJbnB1dCgpIHN1cm5hbWU6IHN0cmluZztcblxuICBfZmlyc3ROYW1lTGV0dGVyOiBzdHJpbmcgPSAnJztcbiAgX2ZpcnN0U3VybmFtZUxldHRlcjogc3RyaW5nID0gJyc7XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmIChjaGFuZ2VzLm5hbWUpIHtcbiAgICAgIHRoaXMuX2ZpcnN0TmFtZUxldHRlciA9XG4gICAgICAgIGNoYW5nZXMubmFtZS5jdXJyZW50VmFsdWU/LmNoYXJBdCgwKT8udG9VcHBlckNhc2UoKSB8fCAnJztcbiAgICB9XG4gICAgaWYgKGNoYW5nZXMuc3VybmFtZSkge1xuICAgICAgdGhpcy5fZmlyc3RTdXJuYW1lTGV0dGVyID1cbiAgICAgICAgY2hhbmdlcy5zdXJuYW1lLmN1cnJlbnRWYWx1ZT8uY2hhckF0KDApPy50b1VwcGVyQ2FzZSgpIHx8ICcnO1xuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "
|
|
3
|
+
import * as i1 from "../../avatar/avatar.component";
|
|
4
4
|
export class GraniteContactsProfileComponent {
|
|
5
5
|
ngOnChanges(changes) {
|
|
6
6
|
const profile = changes.profile?.currentValue;
|
|
@@ -12,16 +12,16 @@ export class GraniteContactsProfileComponent {
|
|
|
12
12
|
this._initials = name[0].toUpperCase() + surname[0].toUpperCase();
|
|
13
13
|
}
|
|
14
14
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteContactsProfileComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
15
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GraniteContactsProfileComponent, selector: "granite-contacts-profile", inputs: { profile: "profile", profileClass: "profileClass" }, host: { classAttribute: "granite-contacts-profile" }, usesOnChanges: true, ngImport: i0, template: "<div [class]=\"profileClass\" data-fnd=\"profile\" class=\"profile\">\n <
|
|
15
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GraniteContactsProfileComponent, selector: "granite-contacts-profile", inputs: { profile: "profile", profileClass: "profileClass" }, host: { classAttribute: "granite-contacts-profile" }, usesOnChanges: true, ngImport: i0, template: "<div [class]=\"profileClass\" data-fnd=\"profile\" class=\"profile\">\n <granite-avatar\n data-fnd=\"profile-avatar\"\n class=\"profile-avatar\"\n [name]=\"profile.name\"\n [surname]=\"profile.surname\"\n [avatar]=\"profile.avatar\"\n ></granite-avatar>\n\n <ng-template #noProfileAvatar>\n <div class=\"no-profile-avatar\">\n <span\n data-fnd=\"no-profile-avatar-initials\"\n class=\"no-profile-avatar-initials\"\n >{{ _initials }}</span\n >\n </div>\n </ng-template>\n\n <div class=\"profile-info\">\n <p data-fnd=\"profile-info-names\" class=\"profile-info-names\">\n {{ profile?.name }} {{ profile?.surname }}\n </p>\n <p data-fnd=\"profile-info-job-title\" class=\"profile-info-job-title\">\n {{ profile?.jobTitle }}\n </p>\n </div>\n</div>\n", styles: [".profile{display:flex;align-items:center;margin-bottom:var(--granite-spacing-8);gap:var(--granite-spacing-4)}.profile-avatar{width:3rem;height:3rem;border-radius:50%;object-fit:cover}.profile-info{display:flex;flex-direction:column;gap:var(--granite-spacing-8)}.profile-info-names{color:var(--granite-color-text);font-size:var(--granite-font-size-body-small);font-weight:var(--granite-font-weight-regular);margin:0}.profile-info-job-title{color:var(--granite-color-text-hint);font-size:var(--granite-font-size-body-small);margin:0}.no-profile-avatar{display:flex;width:3rem;height:3rem;border-radius:360px;background:var(--granite-color-background-info);justify-content:center;align-items:center}.no-profile-avatar-initials{font-size:var(--granite-font-size-micro);color:var(--granite-color-signal-info);font-weight:var(--granite-font-weight-regular)}\n"], dependencies: [{ kind: "component", type: i1.GraniteAvatarComponent, selector: "granite-avatar", inputs: ["name", "surname", "avatar", "status"], exportAs: ["graniteAvatar"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
16
16
|
}
|
|
17
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteContactsProfileComponent, decorators: [{
|
|
18
18
|
type: Component,
|
|
19
19
|
args: [{ selector: 'granite-contacts-profile', host: {
|
|
20
20
|
class: 'granite-contacts-profile',
|
|
21
|
-
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class]=\"profileClass\" data-fnd=\"profile\" class=\"profile\">\n <
|
|
21
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class]=\"profileClass\" data-fnd=\"profile\" class=\"profile\">\n <granite-avatar\n data-fnd=\"profile-avatar\"\n class=\"profile-avatar\"\n [name]=\"profile.name\"\n [surname]=\"profile.surname\"\n [avatar]=\"profile.avatar\"\n ></granite-avatar>\n\n <ng-template #noProfileAvatar>\n <div class=\"no-profile-avatar\">\n <span\n data-fnd=\"no-profile-avatar-initials\"\n class=\"no-profile-avatar-initials\"\n >{{ _initials }}</span\n >\n </div>\n </ng-template>\n\n <div class=\"profile-info\">\n <p data-fnd=\"profile-info-names\" class=\"profile-info-names\">\n {{ profile?.name }} {{ profile?.surname }}\n </p>\n <p data-fnd=\"profile-info-job-title\" class=\"profile-info-job-title\">\n {{ profile?.jobTitle }}\n </p>\n </div>\n</div>\n", styles: [".profile{display:flex;align-items:center;margin-bottom:var(--granite-spacing-8);gap:var(--granite-spacing-4)}.profile-avatar{width:3rem;height:3rem;border-radius:50%;object-fit:cover}.profile-info{display:flex;flex-direction:column;gap:var(--granite-spacing-8)}.profile-info-names{color:var(--granite-color-text);font-size:var(--granite-font-size-body-small);font-weight:var(--granite-font-weight-regular);margin:0}.profile-info-job-title{color:var(--granite-color-text-hint);font-size:var(--granite-font-size-body-small);margin:0}.no-profile-avatar{display:flex;width:3rem;height:3rem;border-radius:360px;background:var(--granite-color-background-info);justify-content:center;align-items:center}.no-profile-avatar-initials{font-size:var(--granite-font-size-micro);color:var(--granite-color-signal-info);font-weight:var(--granite-font-weight-regular)}\n"] }]
|
|
22
22
|
}], propDecorators: { profile: [{
|
|
23
23
|
type: Input
|
|
24
24
|
}], profileClass: [{
|
|
25
25
|
type: Input
|
|
26
26
|
}] } });
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFjdHMtcHJvZmlsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2dyYW5pdGUtY29tcG9uZW50cy9zcmMvbGliL2NvbnRhY3RzL2NvbnRhY3RzLXByb2ZpbGUvY29udGFjdHMtcHJvZmlsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2dyYW5pdGUtY29tcG9uZW50cy9zcmMvbGliL2NvbnRhY3RzL2NvbnRhY3RzLXByb2ZpbGUvY29udGFjdHMtcHJvZmlsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxLQUFLLEdBR04sTUFBTSxlQUFlLENBQUM7OztBQVl2QixNQUFNLE9BQU8sK0JBQStCO0lBTTFDLFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQztRQUM5QyxJQUFJLE9BQU8sSUFBSSxPQUFPLENBQUMsSUFBSSxJQUFJLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUQsQ0FBQztJQUNILENBQUM7SUFFTyxxQkFBcUIsQ0FBQyxJQUFZLEVBQUUsT0FBZTtRQUN6RCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDcEUsQ0FBQzs4R0FmVSwrQkFBK0I7a0dBQS9CLCtCQUErQix5TUNsQjVDLDZ6QkE0QkE7OzJGRFZhLCtCQUErQjtrQkFUM0MsU0FBUzsrQkFDRSwwQkFBMEIsUUFDOUI7d0JBQ0osS0FBSyxFQUFFLDBCQUEwQjtxQkFDbEMsbUJBR2dCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLE9BQU87c0JBQWYsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgU2ltcGxlQ2hhbmdlcyxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQcm9maWxlIH0gZnJvbSAnLi4vY29udGFjdHMtdHlwZXMvY29udGFjdHMuY29tcG9uZW50LnB1YmxpYy10eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2dyYW5pdGUtY29udGFjdHMtcHJvZmlsZScsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2dyYW5pdGUtY29udGFjdHMtcHJvZmlsZScsXG4gIH0sXG4gIHRlbXBsYXRlVXJsOiAnLi9jb250YWN0cy1wcm9maWxlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY29udGFjdHMtcHJvZmlsZS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgR3Jhbml0ZUNvbnRhY3RzUHJvZmlsZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIHByb2ZpbGU6IFByb2ZpbGU7XG4gIEBJbnB1dCgpIHByb2ZpbGVDbGFzcztcblxuICBfaW5pdGlhbHM6IHN0cmluZztcblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgY29uc3QgcHJvZmlsZSA9IGNoYW5nZXMucHJvZmlsZT8uY3VycmVudFZhbHVlO1xuICAgIGlmIChwcm9maWxlICYmIHByb2ZpbGUubmFtZSAmJiBwcm9maWxlLnN1cm5hbWUpIHtcbiAgICAgIHRoaXMuY3JlYXRlUHJvZmlsZUluaXRpYWxzKHByb2ZpbGUubmFtZSwgcHJvZmlsZS5zdXJuYW1lKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZVByb2ZpbGVJbml0aWFscyhuYW1lOiBzdHJpbmcsIHN1cm5hbWU6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuX2luaXRpYWxzID0gbmFtZVswXS50b1VwcGVyQ2FzZSgpICsgc3VybmFtZVswXS50b1VwcGVyQ2FzZSgpO1xuICB9XG59XG4iLCI8ZGl2IFtjbGFzc109XCJwcm9maWxlQ2xhc3NcIiBkYXRhLWZuZD1cInByb2ZpbGVcIiBjbGFzcz1cInByb2ZpbGVcIj5cbiAgPGdyYW5pdGUtYXZhdGFyXG4gICAgZGF0YS1mbmQ9XCJwcm9maWxlLWF2YXRhclwiXG4gICAgY2xhc3M9XCJwcm9maWxlLWF2YXRhclwiXG4gICAgW25hbWVdPVwicHJvZmlsZS5uYW1lXCJcbiAgICBbc3VybmFtZV09XCJwcm9maWxlLnN1cm5hbWVcIlxuICAgIFthdmF0YXJdPVwicHJvZmlsZS5hdmF0YXJcIlxuICA+PC9ncmFuaXRlLWF2YXRhcj5cblxuICA8bmctdGVtcGxhdGUgI25vUHJvZmlsZUF2YXRhcj5cbiAgICA8ZGl2IGNsYXNzPVwibm8tcHJvZmlsZS1hdmF0YXJcIj5cbiAgICAgIDxzcGFuXG4gICAgICAgIGRhdGEtZm5kPVwibm8tcHJvZmlsZS1hdmF0YXItaW5pdGlhbHNcIlxuICAgICAgICBjbGFzcz1cIm5vLXByb2ZpbGUtYXZhdGFyLWluaXRpYWxzXCJcbiAgICAgICAgPnt7IF9pbml0aWFscyB9fTwvc3BhblxuICAgICAgPlxuICAgIDwvZGl2PlxuICA8L25nLXRlbXBsYXRlPlxuXG4gIDxkaXYgY2xhc3M9XCJwcm9maWxlLWluZm9cIj5cbiAgICA8cCBkYXRhLWZuZD1cInByb2ZpbGUtaW5mby1uYW1lc1wiIGNsYXNzPVwicHJvZmlsZS1pbmZvLW5hbWVzXCI+XG4gICAgICB7eyBwcm9maWxlPy5uYW1lIH19IHt7IHByb2ZpbGU/LnN1cm5hbWUgfX1cbiAgICA8L3A+XG4gICAgPHAgZGF0YS1mbmQ9XCJwcm9maWxlLWluZm8tam9iLXRpdGxlXCIgY2xhc3M9XCJwcm9maWxlLWluZm8tam9iLXRpdGxlXCI+XG4gICAgICB7eyBwcm9maWxlPy5qb2JUaXRsZSB9fVxuICAgIDwvcD5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -9,6 +9,7 @@ import { GraniteCustomStatusDirective } from './custom-status.directive';
|
|
|
9
9
|
import { GraniteContactsTriggerForDirective } from './contacts-trigger/contacts-trigger-for.directive';
|
|
10
10
|
import { GraniteContactsProfileComponent } from './contacts-profile/contacts-profile.component';
|
|
11
11
|
import { GraniteCustomProfileDirective } from './custom-profile.directive';
|
|
12
|
+
import { GraniteAvatarModule } from '../avatar/avatar.module';
|
|
12
13
|
import * as i0 from "@angular/core";
|
|
13
14
|
export class GraniteContactsModule {
|
|
14
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteContactsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
@@ -19,17 +20,17 @@ export class GraniteContactsModule {
|
|
|
19
20
|
GraniteContactItemTitleComponent,
|
|
20
21
|
GraniteContactsTriggerForDirective,
|
|
21
22
|
GraniteCustomStatusDirective,
|
|
22
|
-
GraniteCustomProfileDirective], imports: [GraniteIconModule, CommonModule], exports: [GraniteContactsComponent,
|
|
23
|
+
GraniteCustomProfileDirective], imports: [GraniteIconModule, GraniteAvatarModule, CommonModule], exports: [GraniteContactsComponent,
|
|
23
24
|
GraniteContactsTriggerForDirective,
|
|
24
25
|
GraniteContactItemComponent,
|
|
25
26
|
GraniteCustomStatusDirective,
|
|
26
27
|
GraniteCustomProfileDirective] }); }
|
|
27
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteContactsModule, imports: [GraniteIconModule, CommonModule] }); }
|
|
28
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteContactsModule, imports: [GraniteIconModule, GraniteAvatarModule, CommonModule] }); }
|
|
28
29
|
}
|
|
29
30
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteContactsModule, decorators: [{
|
|
30
31
|
type: NgModule,
|
|
31
32
|
args: [{
|
|
32
|
-
imports: [GraniteIconModule, CommonModule],
|
|
33
|
+
imports: [GraniteIconModule, GraniteAvatarModule, CommonModule],
|
|
33
34
|
declarations: [
|
|
34
35
|
GraniteContactsComponent,
|
|
35
36
|
GraniteContactsProfileComponent,
|
|
@@ -49,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
49
50
|
],
|
|
50
51
|
}]
|
|
51
52
|
}] });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFjdHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9ncmFuaXRlLWNvbXBvbmVudHMvc3JjL2xpYi9jb250YWN0cy9jb250YWN0cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHdCQUF3QixJQUFJLHdCQUF3QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDNUYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDeEQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDcEYsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0scUVBQXFFLENBQUM7QUFDeEgsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDckcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDekUsT0FBTyxFQUFFLGtDQUFrQyxFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDdkcsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDaEcsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDM0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBc0I5RCxNQUFNLE9BQU8scUJBQXFCOzhHQUFyQixxQkFBcUI7K0dBQXJCLHFCQUFxQixpQkFqQjlCLHdCQUF3QjtZQUN4QiwrQkFBK0I7WUFDL0IsMkJBQTJCO1lBQzNCLGlDQUFpQztZQUNqQyxnQ0FBZ0M7WUFDaEMsa0NBQWtDO1lBQ2xDLDRCQUE0QjtZQUM1Qiw2QkFBNkIsYUFUckIsaUJBQWlCLEVBQUUsbUJBQW1CLEVBQUUsWUFBWSxhQVk1RCx3QkFBd0I7WUFDeEIsa0NBQWtDO1lBQ2xDLDJCQUEyQjtZQUMzQiw0QkFBNEI7WUFDNUIsNkJBQTZCOytHQUdwQixxQkFBcUIsWUFuQnRCLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLFlBQVk7OzJGQW1CbkQscUJBQXFCO2tCQXBCakMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxtQkFBbUIsRUFBRSxZQUFZLENBQUM7b0JBQy9ELFlBQVksRUFBRTt3QkFDWix3QkFBd0I7d0JBQ3hCLCtCQUErQjt3QkFDL0IsMkJBQTJCO3dCQUMzQixpQ0FBaUM7d0JBQ2pDLGdDQUFnQzt3QkFDaEMsa0NBQWtDO3dCQUNsQyw0QkFBNEI7d0JBQzVCLDZCQUE2QjtxQkFDOUI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHdCQUF3Qjt3QkFDeEIsa0NBQWtDO3dCQUNsQywyQkFBMkI7d0JBQzNCLDRCQUE0Qjt3QkFDNUIsNkJBQTZCO3FCQUM5QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgR3Jhbml0ZUNvbnRhY3RzQ29tcG9uZW50IGFzIEdyYW5pdGVDb250YWN0c0NvbXBvbmVudCB9IGZyb20gJy4vY29udGFjdHMuY29tcG9uZW50JztcbmltcG9ydCB7IEdyYW5pdGVJY29uTW9kdWxlIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZHVsZSc7XG5pbXBvcnQgeyBHcmFuaXRlQ29udGFjdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2NvbnRhY3QtaXRlbS9jb250YWN0LWl0ZW0uY29tcG9uZW50JztcbmltcG9ydCB7IENvbnRhY3RJdGVtRGVmYXVsdFN0YXR1c0NvbXBvbmVudCB9IGZyb20gJy4vY29udGFjdC1pdGVtLWRlZmF1bHQtc3RhdHVzL2NvbnRhY3QtaXRlbS1kZWZhdWx0LXN0YXR1cy5jb21wb25lbnQnO1xuaW1wb3J0IHsgR3Jhbml0ZUNvbnRhY3RJdGVtVGl0bGVDb21wb25lbnQgfSBmcm9tICcuL2NvbnRhY3QtaXRlbS10aXRsZS9jb250YWN0LWl0ZW0tdGl0bGUuY29tcG9uZW50JztcbmltcG9ydCB7IEdyYW5pdGVDdXN0b21TdGF0dXNEaXJlY3RpdmUgfSBmcm9tICcuL2N1c3RvbS1zdGF0dXMuZGlyZWN0aXZlJztcbmltcG9ydCB7IEdyYW5pdGVDb250YWN0c1RyaWdnZXJGb3JEaXJlY3RpdmUgfSBmcm9tICcuL2NvbnRhY3RzLXRyaWdnZXIvY29udGFjdHMtdHJpZ2dlci1mb3IuZGlyZWN0aXZlJztcbmltcG9ydCB7IEdyYW5pdGVDb250YWN0c1Byb2ZpbGVDb21wb25lbnQgfSBmcm9tICcuL2NvbnRhY3RzLXByb2ZpbGUvY29udGFjdHMtcHJvZmlsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgR3Jhbml0ZUN1c3RvbVByb2ZpbGVEaXJlY3RpdmUgfSBmcm9tICcuL2N1c3RvbS1wcm9maWxlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBHcmFuaXRlQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi4vYXZhdGFyL2F2YXRhci5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbR3Jhbml0ZUljb25Nb2R1bGUsIEdyYW5pdGVBdmF0YXJNb2R1bGUsIENvbW1vbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEdyYW5pdGVDb250YWN0c0NvbXBvbmVudCxcbiAgICBHcmFuaXRlQ29udGFjdHNQcm9maWxlQ29tcG9uZW50LFxuICAgIEdyYW5pdGVDb250YWN0SXRlbUNvbXBvbmVudCxcbiAgICBDb250YWN0SXRlbURlZmF1bHRTdGF0dXNDb21wb25lbnQsXG4gICAgR3Jhbml0ZUNvbnRhY3RJdGVtVGl0bGVDb21wb25lbnQsXG4gICAgR3Jhbml0ZUNvbnRhY3RzVHJpZ2dlckZvckRpcmVjdGl2ZSxcbiAgICBHcmFuaXRlQ3VzdG9tU3RhdHVzRGlyZWN0aXZlLFxuICAgIEdyYW5pdGVDdXN0b21Qcm9maWxlRGlyZWN0aXZlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgR3Jhbml0ZUNvbnRhY3RzQ29tcG9uZW50LFxuICAgIEdyYW5pdGVDb250YWN0c1RyaWdnZXJGb3JEaXJlY3RpdmUsXG4gICAgR3Jhbml0ZUNvbnRhY3RJdGVtQ29tcG9uZW50LFxuICAgIEdyYW5pdGVDdXN0b21TdGF0dXNEaXJlY3RpdmUsXG4gICAgR3Jhbml0ZUN1c3RvbVByb2ZpbGVEaXJlY3RpdmUsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEdyYW5pdGVDb250YWN0c01vZHVsZSB7fVxuIl19
|
|
@@ -10,6 +10,7 @@ import * as i7 from "./progress-bar-legend-trigger-for.directive";
|
|
|
10
10
|
export class GraniteProgressBarComponent {
|
|
11
11
|
constructor() {
|
|
12
12
|
this.progressBarData = [];
|
|
13
|
+
this.legendData = [];
|
|
13
14
|
this.showLabel = false;
|
|
14
15
|
this.showLegend = false;
|
|
15
16
|
this.DEFAULT_TOTAL = 100;
|
|
@@ -51,30 +52,41 @@ export class GraniteProgressBarComponent {
|
|
|
51
52
|
return this.progressBarData.reduce((acc, curr) => acc + curr.value, 0);
|
|
52
53
|
}
|
|
53
54
|
setLegendItems() {
|
|
54
|
-
this.legendItems =
|
|
55
|
+
this.legendItems =
|
|
56
|
+
this.legendData.length > 0
|
|
57
|
+
? this.getLegendItems(this.legendData)
|
|
58
|
+
: this.getLegendItems(this.progressBarData);
|
|
59
|
+
}
|
|
60
|
+
getLegendItems(data) {
|
|
61
|
+
return data.map(({ label, backgroundColor, }) => {
|
|
55
62
|
const legendItemColor = this.getStackColor(backgroundColor);
|
|
56
63
|
return { label, backgroundColor: legendItemColor };
|
|
57
64
|
});
|
|
58
65
|
}
|
|
59
66
|
ngOnChanges(changes) {
|
|
60
|
-
if (changes.progressBarData
|
|
61
|
-
JSON.stringify(changes.progressBarData.currentValue) !==
|
|
62
|
-
JSON.stringify(changes.progressBarData.previousValue)) {
|
|
67
|
+
if (changes.progressBarData) {
|
|
63
68
|
this.checkStackTotal();
|
|
64
69
|
this.setLegendItems();
|
|
65
70
|
}
|
|
71
|
+
if (changes.legendData) {
|
|
72
|
+
this.setLegendItems();
|
|
73
|
+
}
|
|
66
74
|
}
|
|
67
75
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteProgressBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
68
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GraniteProgressBarComponent, selector: "granite-progress-bar", inputs: { progressBarData: "progressBarData", showLabel: "showLabel", showLegend: "showLegend" }, exportAs: ["graniteProgressBar"], usesOnChanges: true, ngImport: i0, template: "<div\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n class=\"progress\"\n [style.background-color]=\"getBackgroundColor()\"\n>\n <div\n *ngFor=\"let bar of progressBarData; let i = index\"\n [style.background-color]=\"getStackColor(bar.backgroundColor)\"\n [style.width]=\"getStringOfWidth(getWidth(bar.value))\"\n [style.color]=\"getFontColor(bar.foregroundColor)\"\n [graniteTooltipTriggerFor]=\"tooltip\"\n class=\"progress-bar\"\n >\n <label *ngIf=\"showLabel\" graniteHideOnOverflow>{{ bar.valueLabel }}</label>\n <granite-tooltip #tooltip> {{ bar.valueLabel }} </granite-tooltip>\n </div>\n</div>\n\n<ng-container *ngIf=\"showLegend\">\n <button\n graniteFlatButton\n [graniteProgressBarLegendTriggerFor]=\"legend\"\n class=\"legend-btn\"\n >\n <granite-icon fontIcon=\"icon-caret-down\"></granite-icon>\n </button>\n</ng-container>\n\n<granite-progress-bar-legend\n #legend\n [legendItems]=\"legendItems\"\n></granite-progress-bar-legend>\n", styles: [":host{width:100%;display:flex;align-items:center;
|
|
76
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GraniteProgressBarComponent, selector: "granite-progress-bar", inputs: { progressBarData: "progressBarData", legendData: "legendData", showLabel: "showLabel", showLegend: "showLegend" }, host: { properties: { "class.label-present": "showLabel" } }, exportAs: ["graniteProgressBar"], usesOnChanges: true, ngImport: i0, template: "<div\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n class=\"progress\"\n [style.background-color]=\"getBackgroundColor()\"\n>\n <div\n *ngFor=\"let bar of progressBarData; let i = index\"\n [style.background-color]=\"getStackColor(bar.backgroundColor)\"\n [style.width]=\"getStringOfWidth(getWidth(bar.value))\"\n [style.color]=\"getFontColor(bar.foregroundColor)\"\n [graniteTooltipTriggerFor]=\"tooltip\"\n class=\"progress-bar\"\n >\n <label *ngIf=\"showLabel\" graniteHideOnOverflow>{{ bar.valueLabel }}</label>\n <granite-tooltip #tooltip> {{ bar.valueLabel }} </granite-tooltip>\n </div>\n</div>\n\n<ng-container *ngIf=\"showLegend\">\n <button\n graniteFlatButton\n [graniteProgressBarLegendTriggerFor]=\"legend\"\n class=\"legend-btn\"\n >\n <granite-icon fontIcon=\"icon-caret-down\"></granite-icon>\n </button>\n</ng-container>\n\n<granite-progress-bar-legend\n #legend\n [legendItems]=\"legendItems\"\n></granite-progress-bar-legend>\n", styles: [":host{width:100%;display:flex;align-items:center;box-sizing:border-box;height:.5rem;border-radius:var(--granite-radius-m);font-size:var(--granite-font-size-body-small);line-height:var(--granite-font-size-body-small)}:host(.label-present){height:auto!important}.progress{display:flex;width:inherit;height:inherit;overflow:hidden;border-radius:inherit;background-color:var(--granite-color-background-selected)}.progress-bar{display:flex;align-items:center;box-sizing:border-box;width:inherit;height:inherit;line-height:inherit;font-size:inherit;vertical-align:middle;text-overflow:ellipsis;white-space:nowrap;color:var(--granite-color-text);overflow:hidden;text-align:center;justify-content:center}.progress-bar label{width:100%;padding:var(--granite-spacing-4) 0}.legend-btn{width:16px;height:16px;margin-inline-start:var(--granite-spacing-16)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.GraniteHideOnOverflowDirective, selector: "[graniteHideOnOverflow]", exportAs: ["graniteHideOnOverflow"] }, { kind: "component", type: i3.GraniteTooltipComponent, selector: "granite-tooltip" }, { kind: "directive", type: i3.GraniteTooltipTriggerForDirective, selector: "[graniteTooltipTriggerFor]", inputs: ["graniteTooltipTriggerFor", "hideDelay", "showDelay", "showOnKeyboardFocus", "showOnClick"] }, { kind: "component", type: i4.GraniteIconComponent, selector: "granite-icon", inputs: ["fontIcon"] }, { kind: "component", type: i5.GraniteButtonComponent, selector: "button[graniteButton],\n button[granitePrimaryButton],\n button[graniteFlatButton],\n button[graniteToolbarButton]\n ", inputs: ["disabled", "toggled"], exportAs: ["graniteButton"] }, { kind: "component", type: i6.GraniteProgressBarLegendComponent, selector: "granite-progress-bar-legend", inputs: ["legendItems"] }, { kind: "directive", type: i7.GraniteProgressBarLegendTriggerForDirective, selector: "[graniteProgressBarLegendTriggerFor]", inputs: ["graniteProgressBarLegendTriggerFor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
69
77
|
}
|
|
70
78
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteProgressBarComponent, decorators: [{
|
|
71
79
|
type: Component,
|
|
72
|
-
args: [{ selector: 'granite-progress-bar', exportAs: 'graniteProgressBar',
|
|
80
|
+
args: [{ selector: 'granite-progress-bar', exportAs: 'graniteProgressBar', host: {
|
|
81
|
+
'[class.label-present]': 'showLabel',
|
|
82
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n class=\"progress\"\n [style.background-color]=\"getBackgroundColor()\"\n>\n <div\n *ngFor=\"let bar of progressBarData; let i = index\"\n [style.background-color]=\"getStackColor(bar.backgroundColor)\"\n [style.width]=\"getStringOfWidth(getWidth(bar.value))\"\n [style.color]=\"getFontColor(bar.foregroundColor)\"\n [graniteTooltipTriggerFor]=\"tooltip\"\n class=\"progress-bar\"\n >\n <label *ngIf=\"showLabel\" graniteHideOnOverflow>{{ bar.valueLabel }}</label>\n <granite-tooltip #tooltip> {{ bar.valueLabel }} </granite-tooltip>\n </div>\n</div>\n\n<ng-container *ngIf=\"showLegend\">\n <button\n graniteFlatButton\n [graniteProgressBarLegendTriggerFor]=\"legend\"\n class=\"legend-btn\"\n >\n <granite-icon fontIcon=\"icon-caret-down\"></granite-icon>\n </button>\n</ng-container>\n\n<granite-progress-bar-legend\n #legend\n [legendItems]=\"legendItems\"\n></granite-progress-bar-legend>\n", styles: [":host{width:100%;display:flex;align-items:center;box-sizing:border-box;height:.5rem;border-radius:var(--granite-radius-m);font-size:var(--granite-font-size-body-small);line-height:var(--granite-font-size-body-small)}:host(.label-present){height:auto!important}.progress{display:flex;width:inherit;height:inherit;overflow:hidden;border-radius:inherit;background-color:var(--granite-color-background-selected)}.progress-bar{display:flex;align-items:center;box-sizing:border-box;width:inherit;height:inherit;line-height:inherit;font-size:inherit;vertical-align:middle;text-overflow:ellipsis;white-space:nowrap;color:var(--granite-color-text);overflow:hidden;text-align:center;justify-content:center}.progress-bar label{width:100%;padding:var(--granite-spacing-4) 0}.legend-btn{width:16px;height:16px;margin-inline-start:var(--granite-spacing-16)}\n"] }]
|
|
73
83
|
}], propDecorators: { progressBarData: [{
|
|
74
84
|
type: Input
|
|
85
|
+
}], legendData: [{
|
|
86
|
+
type: Input
|
|
75
87
|
}], showLabel: [{
|
|
76
88
|
type: Input
|
|
77
89
|
}], showLegend: [{
|
|
78
90
|
type: Input
|
|
79
91
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-bar.component.js","sourceRoot":"","sources":["../../../../../../libs/granite-components/src/lib/progress-bar/progress-bar.component.ts","../../../../../../libs/granite-components/src/lib/progress-bar/progress-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core';\nimport {\n  GraniteProgressInterface,\n  GraniteProgressLegendInterface,\n} from './progress-bar.model';\n\n@Component({\n  selector: 'granite-progress-bar',\n  exportAs: 'graniteProgressBar',\n  templateUrl: './progress-bar.component.html',\n  styleUrls: ['./progress-bar.component.scss'],\n  host: {\n    '[class.label-present]': 'showLabel',\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class GraniteProgressBarComponent implements OnChanges {\n  @Input()\n  progressBarData: GraniteProgressInterface[] = [];\n\n  @Input()\n  legendData: GraniteProgressLegendInterface[] = [];\n\n  @Input()\n  showLabel: boolean = false;\n\n  @Input()\n  showLegend: boolean = false;\n\n  DEFAULT_TOTAL = 100;\n  DEFAULT_BACKGROUND = '--granite-color-background-selected';\n  DEFAULT_STACK_COLOR = '--granite-color-categorical-3';\n  DEFAULT_COLOR = '--granite-color-text';\n\n  total: number = this.DEFAULT_TOTAL;\n  legendItems: GraniteProgressLegendInterface[] = [];\n\n  getBackgroundColor(): string {\n    return this.getColorVar(this.DEFAULT_BACKGROUND);\n  }\n\n  getFontColor(color: string): string {\n    return color\n      ? this.getColorVar(color)\n      : this.getColorVar(this.DEFAULT_COLOR);\n  }\n\n  getStackColor(color: string): string {\n    return color\n      ? this.getColorVar(color)\n      : this.getColorVar(this.DEFAULT_STACK_COLOR);\n  }\n\n  getColorVar(color: string): string {\n    return color?.startsWith('--granite') ? `var(${color})` : color;\n  }\n\n  getWidth(value: number): number {\n    return (value / this.total) * 100;\n  }\n\n  getStringOfWidth(width: number): string {\n    return String(width) + '%';\n  }\n\n  checkStackTotal(): void {\n    const totalOfStackedValues = this.getStackTotal();\n    if (totalOfStackedValues > this.total) {\n      this.total = totalOfStackedValues;\n    }\n  }\n\n  getStackTotal(): number {\n    return this.progressBarData.reduce((acc, curr) => acc + curr.value, 0);\n  }\n\n  setLegendItems(): void {\n    this.legendItems =\n      this.legendData.length > 0\n        ? this.getLegendItems(this.legendData)\n        : this.getLegendItems(this.progressBarData);\n  }\n\n  getLegendItems(\n    data: GraniteProgressInterface[] | GraniteProgressLegendInterface[]\n  ): GraniteProgressLegendInterface[] {\n    return data.map(\n      ({\n        label,\n        backgroundColor,\n      }: {\n        label?: string;\n        backgroundColor?: string;\n      }) => {\n        const legendItemColor = this.getStackColor(backgroundColor);\n        return { label, backgroundColor: legendItemColor };\n      }\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.progressBarData) {\n      this.checkStackTotal();\n      this.setLegendItems();\n    }\n\n    if (changes.legendData) {\n      this.setLegendItems();\n    }\n  }\n}\n","<div\n  role=\"progressbar\"\n  aria-valuemin=\"0\"\n  aria-valuemax=\"100\"\n  class=\"progress\"\n  [style.background-color]=\"getBackgroundColor()\"\n>\n  <div\n    *ngFor=\"let bar of progressBarData; let i = index\"\n    [style.background-color]=\"getStackColor(bar.backgroundColor)\"\n    [style.width]=\"getStringOfWidth(getWidth(bar.value))\"\n    [style.color]=\"getFontColor(bar.foregroundColor)\"\n    [graniteTooltipTriggerFor]=\"tooltip\"\n    class=\"progress-bar\"\n  >\n    <label *ngIf=\"showLabel\" graniteHideOnOverflow>{{ bar.valueLabel }}</label>\n    <granite-tooltip #tooltip> {{ bar.valueLabel }} </granite-tooltip>\n  </div>\n</div>\n\n<ng-container *ngIf=\"showLegend\">\n  <button\n    graniteFlatButton\n    [graniteProgressBarLegendTriggerFor]=\"legend\"\n    class=\"legend-btn\"\n  >\n    <granite-icon fontIcon=\"icon-caret-down\"></granite-icon>\n  </button>\n</ng-container>\n\n<granite-progress-bar-legend\n  #legend\n  [legendItems]=\"legendItems\"\n></granite-progress-bar-legend>\n"]}
|