@dereekb/dbx-web 12.4.5 → 12.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/action/action.confirm.directive.mjs +4 -4
- package/esm2022/lib/action/snackbar/action.snackbar.component.mjs +2 -2
- package/esm2022/lib/action/transition/transition.safety.dialog.component.mjs +2 -2
- package/esm2022/lib/button/button.component.mjs +46 -20
- package/esm2022/lib/button/progress/abstract.progress.button.directive.mjs +53 -7
- package/esm2022/lib/button/progress/bar.button.component.mjs +3 -3
- package/esm2022/lib/button/progress/button.progress.config.mjs +1 -1
- package/esm2022/lib/button/progress/spinner.button.component.mjs +3 -3
- package/esm2022/lib/extension/download/text/download.text.component.mjs +2 -2
- package/esm2022/lib/interaction/filter/filter.wrapper.component.mjs +2 -2
- package/esm2022/lib/interaction/index.mjs +2 -1
- package/esm2022/lib/interaction/popup/popup.controls.buttons.component.mjs +1 -1
- package/esm2022/lib/interaction/upload/abstract.upload.component.mjs +85 -0
- package/esm2022/lib/interaction/upload/index.mjs +8 -0
- package/esm2022/lib/interaction/upload/upload.accept.mjs +72 -0
- package/esm2022/lib/interaction/upload/upload.action.directive.mjs +36 -0
- package/esm2022/lib/interaction/upload/upload.action.mjs +18 -0
- package/esm2022/lib/interaction/upload/upload.area.component.mjs +138 -0
- package/esm2022/lib/interaction/upload/upload.button.component.mjs +81 -0
- package/esm2022/lib/interaction/upload/upload.component.mjs +116 -0
- package/esm2022/lib/layout/avatar/avatar.component.mjs +76 -0
- package/esm2022/lib/layout/avatar/avatar.mjs +7 -0
- package/esm2022/lib/layout/avatar/avatar.service.mjs +78 -0
- package/esm2022/lib/layout/avatar/avatar.view.component.mjs +89 -0
- package/esm2022/lib/layout/avatar/index.mjs +4 -0
- package/esm2022/lib/layout/content/content.pit.directive.mjs +34 -4
- package/esm2022/lib/layout/index.mjs +2 -1
- package/esm2022/lib/loading/basic-loading.component.mjs +32 -5
- package/esm2022/lib/loading/index.mjs +2 -1
- package/esm2022/lib/loading/loading.component.mjs +11 -4
- package/esm2022/lib/loading/loading.mjs +2 -0
- package/fesm2022/dereekb-dbx-web.mjs +930 -47
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/action/action.confirm.directive.d.ts +1 -1
- package/lib/button/_button.scss +2 -1
- package/lib/button/button.component.d.ts +5 -1
- package/lib/button/progress/abstract.progress.button.directive.d.ts +9 -5
- package/lib/button/progress/button.progress.config.d.ts +6 -2
- package/lib/interaction/_interaction.scss +4 -0
- package/lib/interaction/index.d.ts +1 -0
- package/lib/interaction/upload/_upload.scss +100 -0
- package/lib/interaction/upload/abstract.upload.component.d.ts +54 -0
- package/lib/interaction/upload/index.d.ts +7 -0
- package/lib/interaction/upload/upload.accept.d.ts +87 -0
- package/lib/interaction/upload/upload.action.d.ts +17 -0
- package/lib/interaction/upload/upload.action.directive.d.ts +17 -0
- package/lib/interaction/upload/upload.area.component.d.ts +22 -0
- package/lib/interaction/upload/upload.button.component.d.ts +24 -0
- package/lib/interaction/upload/upload.component.d.ts +58 -0
- package/lib/layout/_layout.scss +4 -0
- package/lib/layout/avatar/_avatar.scss +102 -0
- package/lib/layout/avatar/avatar.component.d.ts +32 -0
- package/lib/layout/avatar/avatar.d.ts +54 -0
- package/lib/layout/avatar/avatar.service.d.ts +66 -0
- package/lib/layout/avatar/avatar.view.component.d.ts +24 -0
- package/lib/layout/avatar/index.d.ts +3 -0
- package/lib/layout/content/content.pit.directive.d.ts +6 -2
- package/lib/layout/index.d.ts +1 -0
- package/lib/loading/basic-loading.component.d.ts +13 -8
- package/lib/loading/index.d.ts +1 -0
- package/lib/loading/loading.component.d.ts +4 -3
- package/lib/loading/loading.d.ts +10 -0
- package/lib/style/_config.scss +17 -1
- package/lib/style/_root-variables.scss +4 -0
- package/lib/style/_variables.scss +8 -0
- package/package.json +1 -1
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, HostListener, input, output, signal } from '@angular/core';
|
|
2
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
3
|
+
import { fileArrayAcceptMatchFunction } from './upload.accept';
|
|
4
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
5
|
+
import { AbstractDbxFileUploadComponent } from './abstract.upload.component';
|
|
6
|
+
import { provideDbxFileUploadActionCompatable } from './upload.action';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/material/icon";
|
|
9
|
+
export class DbxFileUploadAreaComponent extends AbstractDbxFileUploadComponent {
|
|
10
|
+
icon = input();
|
|
11
|
+
text = input();
|
|
12
|
+
hint = input();
|
|
13
|
+
show = input(true);
|
|
14
|
+
hintSignal = computed(() => {
|
|
15
|
+
const hint = this.hint();
|
|
16
|
+
return typeof hint === 'string' ? hint : hint === true ? 'Drag to upload' : null;
|
|
17
|
+
});
|
|
18
|
+
filesChanged = output();
|
|
19
|
+
areaClicked = output();
|
|
20
|
+
areaDragActiveChanged = output();
|
|
21
|
+
dragOverStateSignal = signal(false);
|
|
22
|
+
filesAcceptedFunctionSignal = computed(() => fileArrayAcceptMatchFunction({ multiple: this.multipleSignal() ?? false, accept: this.acceptSignal() }));
|
|
23
|
+
onClick(evt) {
|
|
24
|
+
evt.stopPropagation();
|
|
25
|
+
if (!this.disabled()) {
|
|
26
|
+
this.areaClicked.emit();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
onDragOver(evt) {
|
|
30
|
+
evt.preventDefault();
|
|
31
|
+
evt.stopPropagation();
|
|
32
|
+
this.dragOverStateSignal.set(true);
|
|
33
|
+
this.areaDragActiveChanged.emit(true);
|
|
34
|
+
}
|
|
35
|
+
onDragLeave(evt) {
|
|
36
|
+
evt.preventDefault();
|
|
37
|
+
evt.stopPropagation();
|
|
38
|
+
this.dragOverStateSignal.set(false);
|
|
39
|
+
this.areaDragActiveChanged.emit(false);
|
|
40
|
+
}
|
|
41
|
+
onDrop(evt) {
|
|
42
|
+
evt.preventDefault();
|
|
43
|
+
evt.stopPropagation();
|
|
44
|
+
this.dragOverStateSignal.set(false);
|
|
45
|
+
if (!this.disabled()) {
|
|
46
|
+
const allFiles = evt.dataTransfer?.files;
|
|
47
|
+
if (allFiles) {
|
|
48
|
+
const matchResult = this.filesAcceptedFunctionSignal()(Array.from(allFiles));
|
|
49
|
+
this.filesChanged.emit({ allFiles: matchResult.input, matchResult });
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFileUploadAreaComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
54
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxFileUploadAreaComponent, isStandalone: true, selector: "dbx-file-upload-area", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null }, hint: { classPropertyName: "hint", publicName: "hint", isSignal: true, isRequired: false, transformFunction: null }, show: { classPropertyName: "show", publicName: "show", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filesChanged: "filesChanged", areaClicked: "areaClicked", areaDragActiveChanged: "areaDragActiveChanged" }, host: { listeners: { "click": "onClick($event)", "dragover": "onDragOver($event)", "dragleave": "onDragLeave($event)", "drop": "onDrop($event)" }, properties: { "class.dbx-file-upload-area-with-hint": "hintSignal()", "class.dbx-file-upload-area-disabled": "disabledSignal()", "class.dbx-file-upload-area-working": "isWorkingSignal()", "class.dbx-file-upload-area-drag-over": "!disabledSignal() && dragOverStateSignal()" }, classAttribute: "dbx-file-upload-area dbx-block" }, providers: provideDbxFileUploadActionCompatable(DbxFileUploadAreaComponent), usesInheritance: true, ngImport: i0, template: `
|
|
55
|
+
@if (show()) {
|
|
56
|
+
<div class="dbx-file-upload-area-content">
|
|
57
|
+
<div class="dbx-file-upload-area-content-text">
|
|
58
|
+
@if (icon() != null) {
|
|
59
|
+
<mat-icon>{{ icon() }}</mat-icon>
|
|
60
|
+
}
|
|
61
|
+
@if (text() != null) {
|
|
62
|
+
<span>{{ text() }}</span>
|
|
63
|
+
}
|
|
64
|
+
</div>
|
|
65
|
+
<div class="dbx-file-upload-area-content-wrapped">
|
|
66
|
+
<ng-template [ngTemplateOutlet]="contentTemplate"></ng-template>
|
|
67
|
+
</div>
|
|
68
|
+
</div>
|
|
69
|
+
@if (hintSignal()) {
|
|
70
|
+
<div class="dbx-file-upload-area-content-hint dbx-hint dbx-small">{{ hintSignal() }}</div>
|
|
71
|
+
}
|
|
72
|
+
} @else {
|
|
73
|
+
<ng-template [ngTemplateOutlet]="contentTemplate"></ng-template>
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
<!-- Content Template -->
|
|
77
|
+
<ng-template #contentTemplate>
|
|
78
|
+
<ng-content></ng-content>
|
|
79
|
+
</ng-template>
|
|
80
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
81
|
+
}
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFileUploadAreaComponent, decorators: [{
|
|
83
|
+
type: Component,
|
|
84
|
+
args: [{
|
|
85
|
+
selector: 'dbx-file-upload-area',
|
|
86
|
+
template: `
|
|
87
|
+
@if (show()) {
|
|
88
|
+
<div class="dbx-file-upload-area-content">
|
|
89
|
+
<div class="dbx-file-upload-area-content-text">
|
|
90
|
+
@if (icon() != null) {
|
|
91
|
+
<mat-icon>{{ icon() }}</mat-icon>
|
|
92
|
+
}
|
|
93
|
+
@if (text() != null) {
|
|
94
|
+
<span>{{ text() }}</span>
|
|
95
|
+
}
|
|
96
|
+
</div>
|
|
97
|
+
<div class="dbx-file-upload-area-content-wrapped">
|
|
98
|
+
<ng-template [ngTemplateOutlet]="contentTemplate"></ng-template>
|
|
99
|
+
</div>
|
|
100
|
+
</div>
|
|
101
|
+
@if (hintSignal()) {
|
|
102
|
+
<div class="dbx-file-upload-area-content-hint dbx-hint dbx-small">{{ hintSignal() }}</div>
|
|
103
|
+
}
|
|
104
|
+
} @else {
|
|
105
|
+
<ng-template [ngTemplateOutlet]="contentTemplate"></ng-template>
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
<!-- Content Template -->
|
|
109
|
+
<ng-template #contentTemplate>
|
|
110
|
+
<ng-content></ng-content>
|
|
111
|
+
</ng-template>
|
|
112
|
+
`,
|
|
113
|
+
host: {
|
|
114
|
+
class: 'dbx-file-upload-area dbx-block',
|
|
115
|
+
'[class.dbx-file-upload-area-with-hint]': 'hintSignal()',
|
|
116
|
+
'[class.dbx-file-upload-area-disabled]': 'disabledSignal()',
|
|
117
|
+
'[class.dbx-file-upload-area-working]': 'isWorkingSignal()',
|
|
118
|
+
'[class.dbx-file-upload-area-drag-over]': '!disabledSignal() && dragOverStateSignal()'
|
|
119
|
+
},
|
|
120
|
+
providers: provideDbxFileUploadActionCompatable(DbxFileUploadAreaComponent),
|
|
121
|
+
imports: [MatIconModule, NgTemplateOutlet],
|
|
122
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
123
|
+
standalone: true
|
|
124
|
+
}]
|
|
125
|
+
}], propDecorators: { onClick: [{
|
|
126
|
+
type: HostListener,
|
|
127
|
+
args: ['click', ['$event']]
|
|
128
|
+
}], onDragOver: [{
|
|
129
|
+
type: HostListener,
|
|
130
|
+
args: ['dragover', ['$event']]
|
|
131
|
+
}], onDragLeave: [{
|
|
132
|
+
type: HostListener,
|
|
133
|
+
args: ['dragleave', ['$event']]
|
|
134
|
+
}], onDrop: [{
|
|
135
|
+
type: HostListener,
|
|
136
|
+
args: ['drop', ['$event']]
|
|
137
|
+
}] } });
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.area.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/upload/upload.area.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, HostListener, input, output, signal } from '@angular/core';\nimport { MatIconModule } from '@angular/material/icon';\nimport { Maybe } from '@dereekb/util';\nimport { fileArrayAcceptMatchFunction } from './upload.accept';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { AbstractDbxFileUploadComponent, DbxFileUploadFilesChangedEvent } from './abstract.upload.component';\nimport { provideDbxFileUploadActionCompatable } from './upload.action';\n\nexport type DbxFileUploadAreaFilesChangedEvent = DbxFileUploadFilesChangedEvent;\n\n@Component({\n  selector: 'dbx-file-upload-area',\n  template: `\n    @if (show()) {\n      <div class=\"dbx-file-upload-area-content\">\n        <div class=\"dbx-file-upload-area-content-text\">\n          @if (icon() != null) {\n            <mat-icon>{{ icon() }}</mat-icon>\n          }\n          @if (text() != null) {\n            <span>{{ text() }}</span>\n          }\n        </div>\n        <div class=\"dbx-file-upload-area-content-wrapped\">\n          <ng-template [ngTemplateOutlet]=\"contentTemplate\"></ng-template>\n        </div>\n      </div>\n      @if (hintSignal()) {\n        <div class=\"dbx-file-upload-area-content-hint dbx-hint dbx-small\">{{ hintSignal() }}</div>\n      }\n    } @else {\n      <ng-template [ngTemplateOutlet]=\"contentTemplate\"></ng-template>\n    }\n\n    <!-- Content Template -->\n    <ng-template #contentTemplate>\n      <ng-content></ng-content>\n    </ng-template>\n  `,\n  host: {\n    class: 'dbx-file-upload-area dbx-block',\n    '[class.dbx-file-upload-area-with-hint]': 'hintSignal()',\n    '[class.dbx-file-upload-area-disabled]': 'disabledSignal()',\n    '[class.dbx-file-upload-area-working]': 'isWorkingSignal()',\n    '[class.dbx-file-upload-area-drag-over]': '!disabledSignal() && dragOverStateSignal()'\n  },\n  providers: provideDbxFileUploadActionCompatable(DbxFileUploadAreaComponent),\n  imports: [MatIconModule, NgTemplateOutlet],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxFileUploadAreaComponent extends AbstractDbxFileUploadComponent {\n  readonly icon = input<Maybe<string>>();\n  readonly text = input<Maybe<string>>();\n  readonly hint = input<Maybe<string | boolean>>();\n  readonly show = input<boolean>(true);\n\n  readonly hintSignal = computed(() => {\n    const hint = this.hint();\n    return typeof hint === 'string' ? hint : hint === true ? 'Drag to upload' : null;\n  });\n\n  readonly filesChanged = output<DbxFileUploadAreaFilesChangedEvent>();\n  readonly areaClicked = output<void>();\n  readonly areaDragActiveChanged = output<boolean>();\n\n  readonly dragOverStateSignal = signal<boolean>(false);\n  readonly filesAcceptedFunctionSignal = computed(() => fileArrayAcceptMatchFunction({ multiple: this.multipleSignal() ?? false, accept: this.acceptSignal() }));\n\n  @HostListener('click', ['$event'])\n  onClick(evt: MouseEvent) {\n    evt.stopPropagation();\n\n    if (!this.disabled()) {\n      this.areaClicked.emit();\n    }\n  }\n\n  @HostListener('dragover', ['$event'])\n  onDragOver(evt: DragEvent) {\n    evt.preventDefault();\n    evt.stopPropagation();\n    this.dragOverStateSignal.set(true);\n    this.areaDragActiveChanged.emit(true);\n  }\n\n  @HostListener('dragleave', ['$event'])\n  onDragLeave(evt: DragEvent) {\n    evt.preventDefault();\n    evt.stopPropagation();\n    this.dragOverStateSignal.set(false);\n    this.areaDragActiveChanged.emit(false);\n  }\n\n  @HostListener('drop', ['$event'])\n  onDrop(evt: DragEvent) {\n    evt.preventDefault();\n    evt.stopPropagation();\n    this.dragOverStateSignal.set(false);\n\n    if (!this.disabled()) {\n      const allFiles = evt.dataTransfer?.files;\n\n      if (allFiles) {\n        const matchResult = this.filesAcceptedFunctionSignal()(Array.from(allFiles));\n        this.filesChanged.emit({ allFiles: matchResult.input, matchResult });\n      }\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, ElementRef, input, output, viewChild } from '@angular/core';
|
|
2
|
+
import { fileAcceptString, fileArrayAcceptMatchFunction } from './upload.accept';
|
|
3
|
+
import { DbxButtonComponent } from '../../button/button.component';
|
|
4
|
+
import { AbstractDbxFileUploadComponent } from './abstract.upload.component';
|
|
5
|
+
import { provideDbxFileUploadActionCompatable } from './upload.action';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class DbxFileUploadButtonComponent extends AbstractDbxFileUploadComponent {
|
|
8
|
+
fileInput = viewChild.required('fileInput', { read: ElementRef });
|
|
9
|
+
text = input();
|
|
10
|
+
icon = input();
|
|
11
|
+
buttonStyle = input();
|
|
12
|
+
filesChanged = output();
|
|
13
|
+
buttonAcceptSignal = computed(() => {
|
|
14
|
+
const accept = this.acceptSignal();
|
|
15
|
+
return typeof accept === 'function' ? undefined : fileAcceptString(accept);
|
|
16
|
+
});
|
|
17
|
+
buttonMultipleSignal = computed(() => this.multipleSignal() ?? false);
|
|
18
|
+
filesAcceptedFunctionSignal = computed(() => {
|
|
19
|
+
const accept = this.acceptSignal();
|
|
20
|
+
const multiple = this.buttonMultipleSignal();
|
|
21
|
+
return typeof accept === 'function' ? fileArrayAcceptMatchFunction({ multiple, accept }) : undefined;
|
|
22
|
+
});
|
|
23
|
+
/**
|
|
24
|
+
* The HTML attribute should not be added if it is false, so we return null.
|
|
25
|
+
*/
|
|
26
|
+
multipleAttributeSignal = computed(() => (this.buttonMultipleSignal() ? '' : null));
|
|
27
|
+
openInput() {
|
|
28
|
+
const inputRef = this.fileInput();
|
|
29
|
+
const input = inputRef.nativeElement;
|
|
30
|
+
const isDisabled = this.disabledSignal();
|
|
31
|
+
if (!isDisabled) {
|
|
32
|
+
input.click();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
fileInputChanged() {
|
|
36
|
+
const inputRef = this.fileInput();
|
|
37
|
+
const input = inputRef.nativeElement;
|
|
38
|
+
const isDisabled = this.disabledSignal();
|
|
39
|
+
if (!isDisabled) {
|
|
40
|
+
const allFiles = input.files ? Array.from(input.files) : [];
|
|
41
|
+
const fileAcceptFunction = this.filesAcceptedFunctionSignal();
|
|
42
|
+
if (fileAcceptFunction) {
|
|
43
|
+
const matchResult = fileAcceptFunction(allFiles);
|
|
44
|
+
this.filesChanged.emit({ allFiles, matchResult });
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
// if not using a filesAcceptedFunction, then accept all files as the input should have filtered them
|
|
48
|
+
const multiple = this.buttonMultipleSignal();
|
|
49
|
+
this.filesChanged.emit({ allFiles, matchResult: { multiple, input: allFiles, accepted: allFiles, rejected: [], acceptedType: allFiles, rejectedType: [] } });
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
// reset the input value
|
|
53
|
+
if (input.value) {
|
|
54
|
+
input.value = '';
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFileUploadButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
58
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxFileUploadButtonComponent, isStandalone: true, selector: "dbx-file-upload-button", inputs: { text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, buttonStyle: { classPropertyName: "buttonStyle", publicName: "buttonStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filesChanged: "filesChanged" }, providers: provideDbxFileUploadActionCompatable(DbxFileUploadButtonComponent), viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, read: ElementRef, isSignal: true }], usesInheritance: true, ngImport: i0, template: `
|
|
59
|
+
<dbx-button [buttonStyle]="buttonStyle()" [text]="text()" [icon]="icon()" (buttonClick)="openInput()" [disabled]="disabledSignal()" [working]="workingSignal()">
|
|
60
|
+
<ng-content></ng-content>
|
|
61
|
+
</dbx-button>
|
|
62
|
+
<input #fileInput hidden type="file" [attr.accept]="buttonAcceptSignal() ?? null" [attr.multiple]="multipleAttributeSignal() ? '' : null" (change)="fileInputChanged()" />
|
|
63
|
+
`, isInline: true, dependencies: [{ kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["bar", "type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab", "mode"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
64
|
+
}
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFileUploadButtonComponent, decorators: [{
|
|
66
|
+
type: Component,
|
|
67
|
+
args: [{
|
|
68
|
+
selector: 'dbx-file-upload-button',
|
|
69
|
+
template: `
|
|
70
|
+
<dbx-button [buttonStyle]="buttonStyle()" [text]="text()" [icon]="icon()" (buttonClick)="openInput()" [disabled]="disabledSignal()" [working]="workingSignal()">
|
|
71
|
+
<ng-content></ng-content>
|
|
72
|
+
</dbx-button>
|
|
73
|
+
<input #fileInput hidden type="file" [attr.accept]="buttonAcceptSignal() ?? null" [attr.multiple]="multipleAttributeSignal() ? '' : null" (change)="fileInputChanged()" />
|
|
74
|
+
`,
|
|
75
|
+
providers: provideDbxFileUploadActionCompatable(DbxFileUploadButtonComponent),
|
|
76
|
+
imports: [DbxButtonComponent],
|
|
77
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
78
|
+
standalone: true
|
|
79
|
+
}]
|
|
80
|
+
}] });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.button.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/upload/upload.button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, ElementRef, input, output, viewChild } from '@angular/core';\nimport { fileAcceptString, fileArrayAcceptMatchFunction } from './upload.accept';\nimport { DbxButtonComponent, DbxButtonStyle } from '../../button/button.component';\nimport { Maybe } from '@dereekb/util';\nimport { AbstractDbxFileUploadComponent, DbxFileUploadFilesChangedEvent } from './abstract.upload.component';\nimport { provideDbxFileUploadActionCompatable } from './upload.action';\n\nexport type DbxFileUploadButtonFilesChangedEvent = DbxFileUploadFilesChangedEvent;\n\n@Component({\n  selector: 'dbx-file-upload-button',\n  template: `\n    <dbx-button [buttonStyle]=\"buttonStyle()\" [text]=\"text()\" [icon]=\"icon()\" (buttonClick)=\"openInput()\" [disabled]=\"disabledSignal()\" [working]=\"workingSignal()\">\n      <ng-content></ng-content>\n    </dbx-button>\n    <input #fileInput hidden type=\"file\" [attr.accept]=\"buttonAcceptSignal() ?? null\" [attr.multiple]=\"multipleAttributeSignal() ? '' : null\" (change)=\"fileInputChanged()\" />\n  `,\n  providers: provideDbxFileUploadActionCompatable(DbxFileUploadButtonComponent),\n  imports: [DbxButtonComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxFileUploadButtonComponent extends AbstractDbxFileUploadComponent {\n  readonly fileInput = viewChild.required<string, ElementRef<HTMLInputElement>>('fileInput', { read: ElementRef });\n\n  readonly text = input<Maybe<string>>();\n  readonly icon = input<Maybe<string>>();\n  readonly buttonStyle = input<Maybe<DbxButtonStyle>>();\n\n  readonly filesChanged = output<DbxFileUploadButtonFilesChangedEvent>();\n\n  readonly buttonAcceptSignal = computed(() => {\n    const accept = this.acceptSignal();\n    return typeof accept === 'function' ? undefined : fileAcceptString(accept);\n  });\n\n  readonly buttonMultipleSignal = computed(() => this.multipleSignal() ?? false);\n\n  readonly filesAcceptedFunctionSignal = computed(() => {\n    const accept = this.acceptSignal();\n    const multiple = this.buttonMultipleSignal();\n    return typeof accept === 'function' ? fileArrayAcceptMatchFunction({ multiple, accept }) : undefined;\n  });\n\n  /**\n   * The HTML attribute should not be added if it is false, so we return null.\n   */\n  readonly multipleAttributeSignal = computed(() => (this.buttonMultipleSignal() ? '' : null));\n\n  openInput() {\n    const inputRef = this.fileInput();\n    const input = inputRef.nativeElement;\n\n    const isDisabled = this.disabledSignal();\n\n    if (!isDisabled) {\n      input.click();\n    }\n  }\n\n  fileInputChanged() {\n    const inputRef = this.fileInput();\n    const input = inputRef.nativeElement;\n    const isDisabled = this.disabledSignal();\n\n    if (!isDisabled) {\n      const allFiles = input.files ? Array.from(input.files) : [];\n      const fileAcceptFunction = this.filesAcceptedFunctionSignal();\n\n      if (fileAcceptFunction) {\n        const matchResult = fileAcceptFunction(allFiles);\n        this.filesChanged.emit({ allFiles, matchResult });\n      } else {\n        // if not using a filesAcceptedFunction, then accept all files as the input should have filtered them\n        const multiple = this.buttonMultipleSignal();\n        this.filesChanged.emit({ allFiles, matchResult: { multiple, input: allFiles, accepted: allFiles, rejected: [], acceptedType: allFiles, rejectedType: [] } });\n      }\n    }\n\n    // reset the input value\n    if (input.value) {\n      input.value = '';\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output, viewChild } from '@angular/core';
|
|
2
|
+
import { DbxFileUploadButtonComponent } from './upload.button.component';
|
|
3
|
+
import { DbxFileUploadAreaComponent } from './upload.area.component';
|
|
4
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
5
|
+
import { AbstractDbxFileUploadComponent } from './abstract.upload.component';
|
|
6
|
+
import { provideDbxFileUploadActionCompatable } from './upload.action';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
/**
|
|
9
|
+
* Combines both the file upload area and button into a single component.
|
|
10
|
+
*/
|
|
11
|
+
export class DbxFileUploadComponent extends AbstractDbxFileUploadComponent {
|
|
12
|
+
config = input();
|
|
13
|
+
area = viewChild.required('area', { read: DbxFileUploadAreaComponent });
|
|
14
|
+
button = viewChild.required('button', { read: DbxFileUploadButtonComponent });
|
|
15
|
+
buttonStyle = input();
|
|
16
|
+
mode = input();
|
|
17
|
+
text = input(); // button text
|
|
18
|
+
icon = input(); // button icon
|
|
19
|
+
hint = input(); // area hint
|
|
20
|
+
modeSignal = computed(() => {
|
|
21
|
+
const config = this.config();
|
|
22
|
+
const mode = this.mode();
|
|
23
|
+
return config?.mode ?? mode ?? 'default';
|
|
24
|
+
});
|
|
25
|
+
showButtonSignal = computed(() => {
|
|
26
|
+
const mode = this.modeSignal();
|
|
27
|
+
return mode === 'button' || mode === 'default';
|
|
28
|
+
});
|
|
29
|
+
showAreaSignal = computed(() => {
|
|
30
|
+
const mode = this.modeSignal();
|
|
31
|
+
return mode === 'area' || mode === 'default';
|
|
32
|
+
});
|
|
33
|
+
clickAreaToUpload = input();
|
|
34
|
+
clickAreaToUploadSignal = computed(() => {
|
|
35
|
+
const config = this.config();
|
|
36
|
+
const clickAreaToUpload = this.clickAreaToUpload();
|
|
37
|
+
return config?.clickAreaToUpload ?? clickAreaToUpload;
|
|
38
|
+
});
|
|
39
|
+
buttonTextSignal = computed(() => {
|
|
40
|
+
const config = this.config();
|
|
41
|
+
const text = this.text();
|
|
42
|
+
return config?.button?.text ?? text;
|
|
43
|
+
});
|
|
44
|
+
buttonIconSignal = computed(() => {
|
|
45
|
+
const config = this.config();
|
|
46
|
+
const icon = this.icon();
|
|
47
|
+
return config?.button?.icon ?? icon;
|
|
48
|
+
});
|
|
49
|
+
areaTextSignal = computed(() => this.config()?.area?.text);
|
|
50
|
+
areaIconSignal = computed(() => this.config()?.area?.icon);
|
|
51
|
+
areaHintSignal = computed(() => {
|
|
52
|
+
const config = this.config();
|
|
53
|
+
const hint = this.hint();
|
|
54
|
+
return config?.area?.hint ?? hint;
|
|
55
|
+
});
|
|
56
|
+
uploadMultipleSignal = computed(() => {
|
|
57
|
+
const config = this.config();
|
|
58
|
+
const multiple = this.multipleSignal();
|
|
59
|
+
return multiple ?? config?.multiple;
|
|
60
|
+
});
|
|
61
|
+
uploadAcceptSignal = computed(() => {
|
|
62
|
+
const config = this.config();
|
|
63
|
+
const accept = this.acceptSignal();
|
|
64
|
+
return accept ?? config?.accept;
|
|
65
|
+
});
|
|
66
|
+
filesChanged = output();
|
|
67
|
+
areaClicked() {
|
|
68
|
+
const clickAreaToUpload = this.clickAreaToUploadSignal();
|
|
69
|
+
if (clickAreaToUpload) {
|
|
70
|
+
const button = this.button();
|
|
71
|
+
button.openInput();
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
areaFilesChanged(event) {
|
|
75
|
+
this.filesChanged.emit(event);
|
|
76
|
+
}
|
|
77
|
+
buttonFilesChanged(event) {
|
|
78
|
+
this.filesChanged.emit(event);
|
|
79
|
+
}
|
|
80
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFileUploadComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxFileUploadComponent, isStandalone: true, selector: "dbx-file-upload", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null }, buttonStyle: { classPropertyName: "buttonStyle", publicName: "buttonStyle", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, hint: { classPropertyName: "hint", publicName: "hint", isSignal: true, isRequired: false, transformFunction: null }, clickAreaToUpload: { classPropertyName: "clickAreaToUpload", publicName: "clickAreaToUpload", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filesChanged: "filesChanged" }, providers: provideDbxFileUploadActionCompatable(DbxFileUploadComponent), viewQueries: [{ propertyName: "area", first: true, predicate: ["area"], descendants: true, read: DbxFileUploadAreaComponent, isSignal: true }, { propertyName: "button", first: true, predicate: ["button"], descendants: true, read: DbxFileUploadButtonComponent, isSignal: true }], usesInheritance: true, ngImport: i0, template: `
|
|
82
|
+
<dbx-file-upload-area #area [show]="showAreaSignal()" [hint]="areaHintSignal()" [text]="areaTextSignal()" [icon]="areaIconSignal()" [accept]="acceptSignal()" [multiple]="multipleSignal()" (filesChanged)="areaFilesChanged($event)" (areaClicked)="areaClicked()" [disabled]="disabledSignal()" [working]="workingSignal()">
|
|
83
|
+
<ng-content></ng-content>
|
|
84
|
+
@if (showButtonSignal()) {
|
|
85
|
+
<ng-template [ngTemplateOutlet]="buttonTemplate"></ng-template>
|
|
86
|
+
}
|
|
87
|
+
</dbx-file-upload-area>
|
|
88
|
+
<!-- Button Template -->
|
|
89
|
+
<ng-template #buttonTemplate>
|
|
90
|
+
<dbx-file-upload-button #button [text]="buttonTextSignal()" [icon]="buttonIconSignal()" [accept]="acceptSignal()" [multiple]="multipleSignal()" (filesChanged)="buttonFilesChanged($event)" [disabled]="disabledSignal()" [working]="workingSignal()" [buttonStyle]="buttonStyle()"></dbx-file-upload-button>
|
|
91
|
+
</ng-template>
|
|
92
|
+
`, isInline: true, dependencies: [{ kind: "component", type: DbxFileUploadAreaComponent, selector: "dbx-file-upload-area", inputs: ["icon", "text", "hint", "show"], outputs: ["filesChanged", "areaClicked", "areaDragActiveChanged"] }, { kind: "component", type: DbxFileUploadButtonComponent, selector: "dbx-file-upload-button", inputs: ["text", "icon", "buttonStyle"], outputs: ["filesChanged"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
93
|
+
}
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFileUploadComponent, decorators: [{
|
|
95
|
+
type: Component,
|
|
96
|
+
args: [{
|
|
97
|
+
selector: 'dbx-file-upload',
|
|
98
|
+
template: `
|
|
99
|
+
<dbx-file-upload-area #area [show]="showAreaSignal()" [hint]="areaHintSignal()" [text]="areaTextSignal()" [icon]="areaIconSignal()" [accept]="acceptSignal()" [multiple]="multipleSignal()" (filesChanged)="areaFilesChanged($event)" (areaClicked)="areaClicked()" [disabled]="disabledSignal()" [working]="workingSignal()">
|
|
100
|
+
<ng-content></ng-content>
|
|
101
|
+
@if (showButtonSignal()) {
|
|
102
|
+
<ng-template [ngTemplateOutlet]="buttonTemplate"></ng-template>
|
|
103
|
+
}
|
|
104
|
+
</dbx-file-upload-area>
|
|
105
|
+
<!-- Button Template -->
|
|
106
|
+
<ng-template #buttonTemplate>
|
|
107
|
+
<dbx-file-upload-button #button [text]="buttonTextSignal()" [icon]="buttonIconSignal()" [accept]="acceptSignal()" [multiple]="multipleSignal()" (filesChanged)="buttonFilesChanged($event)" [disabled]="disabledSignal()" [working]="workingSignal()" [buttonStyle]="buttonStyle()"></dbx-file-upload-button>
|
|
108
|
+
</ng-template>
|
|
109
|
+
`,
|
|
110
|
+
providers: provideDbxFileUploadActionCompatable(DbxFileUploadComponent),
|
|
111
|
+
imports: [DbxFileUploadAreaComponent, DbxFileUploadButtonComponent, NgTemplateOutlet],
|
|
112
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
113
|
+
standalone: true
|
|
114
|
+
}]
|
|
115
|
+
}] });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/upload/upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output, viewChild } from '@angular/core';\nimport { FileArrayAcceptMatchConfig } from './upload.accept';\nimport { DbxButtonStyle } from '../../button/button.component';\nimport { Maybe } from '@dereekb/util';\nimport { DbxFileUploadButtonComponent, DbxFileUploadButtonFilesChangedEvent } from './upload.button.component';\nimport { DbxFileUploadAreaComponent, DbxFileUploadAreaFilesChangedEvent } from './upload.area.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { AbstractDbxFileUploadComponent, DbxFileUploadFilesChangedEvent } from './abstract.upload.component';\nimport { provideDbxFileUploadActionCompatable } from './upload.action';\n\nexport type DbxFileUploadMode = 'area' | 'button' | 'default';\n\nexport interface DbxFileUploadComponentConfig {\n  readonly mode?: DbxFileUploadMode;\n  readonly accept?: Maybe<FileArrayAcceptMatchConfig['accept']>;\n  readonly multiple?: Maybe<boolean>;\n\n  /**\n   * If true, the area will be clickable to open the file picker.\n   */\n  readonly clickAreaToUpload?: Maybe<boolean>;\n\n  readonly area?: Maybe<{\n    readonly icon?: Maybe<string>;\n    readonly text?: Maybe<string>;\n    readonly hint?: Maybe<string | boolean>;\n  }>;\n\n  readonly button?: Maybe<{\n    readonly icon?: Maybe<string>;\n    readonly text?: Maybe<string>;\n    readonly style?: DbxButtonStyle;\n  }>;\n}\n\n/**\n * Combines both the file upload area and button into a single component.\n */\n@Component({\n  selector: 'dbx-file-upload',\n  template: `\n    <dbx-file-upload-area #area [show]=\"showAreaSignal()\" [hint]=\"areaHintSignal()\" [text]=\"areaTextSignal()\" [icon]=\"areaIconSignal()\" [accept]=\"acceptSignal()\" [multiple]=\"multipleSignal()\" (filesChanged)=\"areaFilesChanged($event)\" (areaClicked)=\"areaClicked()\" [disabled]=\"disabledSignal()\" [working]=\"workingSignal()\">\n      <ng-content></ng-content>\n      @if (showButtonSignal()) {\n        <ng-template [ngTemplateOutlet]=\"buttonTemplate\"></ng-template>\n      }\n    </dbx-file-upload-area>\n    <!-- Button Template -->\n    <ng-template #buttonTemplate>\n      <dbx-file-upload-button #button [text]=\"buttonTextSignal()\" [icon]=\"buttonIconSignal()\" [accept]=\"acceptSignal()\" [multiple]=\"multipleSignal()\" (filesChanged)=\"buttonFilesChanged($event)\" [disabled]=\"disabledSignal()\" [working]=\"workingSignal()\" [buttonStyle]=\"buttonStyle()\"></dbx-file-upload-button>\n    </ng-template>\n  `,\n  providers: provideDbxFileUploadActionCompatable(DbxFileUploadComponent),\n  imports: [DbxFileUploadAreaComponent, DbxFileUploadButtonComponent, NgTemplateOutlet],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxFileUploadComponent extends AbstractDbxFileUploadComponent {\n  readonly config = input<Maybe<DbxFileUploadComponentConfig>>();\n\n  readonly area = viewChild.required<string, DbxFileUploadAreaComponent>('area', { read: DbxFileUploadAreaComponent });\n  readonly button = viewChild.required<string, DbxFileUploadButtonComponent>('button', { read: DbxFileUploadButtonComponent });\n  readonly buttonStyle = input<Maybe<DbxButtonStyle>>();\n\n  readonly mode = input<Maybe<DbxFileUploadMode>>();\n  readonly text = input<Maybe<string>>(); // button text\n  readonly icon = input<Maybe<string>>(); // button icon\n  readonly hint = input<Maybe<string | boolean>>(); // area hint\n\n  readonly modeSignal = computed(() => {\n    const config = this.config();\n    const mode = this.mode();\n    return config?.mode ?? mode ?? 'default';\n  });\n\n  readonly showButtonSignal = computed(() => {\n    const mode = this.modeSignal();\n    return mode === 'button' || mode === 'default';\n  });\n\n  readonly showAreaSignal = computed(() => {\n    const mode = this.modeSignal();\n    return mode === 'area' || mode === 'default';\n  });\n\n  readonly clickAreaToUpload = input<Maybe<boolean>>();\n  readonly clickAreaToUploadSignal = computed(() => {\n    const config = this.config();\n    const clickAreaToUpload = this.clickAreaToUpload();\n    return config?.clickAreaToUpload ?? clickAreaToUpload;\n  });\n\n  readonly buttonTextSignal = computed(() => {\n    const config = this.config();\n    const text = this.text();\n    return config?.button?.text ?? text;\n  });\n\n  readonly buttonIconSignal = computed(() => {\n    const config = this.config();\n    const icon = this.icon();\n    return config?.button?.icon ?? icon;\n  });\n\n  readonly areaTextSignal = computed(() => this.config()?.area?.text);\n  readonly areaIconSignal = computed(() => this.config()?.area?.icon);\n  readonly areaHintSignal = computed(() => {\n    const config = this.config();\n    const hint = this.hint();\n    return config?.area?.hint ?? hint;\n  });\n\n  readonly uploadMultipleSignal = computed(() => {\n    const config = this.config();\n    const multiple = this.multipleSignal();\n    return multiple ?? config?.multiple;\n  });\n\n  readonly uploadAcceptSignal = computed(() => {\n    const config = this.config();\n    const accept = this.acceptSignal();\n    return accept ?? config?.accept;\n  });\n\n  readonly filesChanged = output<DbxFileUploadFilesChangedEvent>();\n\n  areaClicked() {\n    const clickAreaToUpload = this.clickAreaToUploadSignal();\n\n    if (clickAreaToUpload) {\n      const button = this.button();\n      button.openInput();\n    }\n  }\n\n  areaFilesChanged(event: DbxFileUploadAreaFilesChangedEvent) {\n    this.filesChanged.emit(event);\n  }\n\n  buttonFilesChanged(event: DbxFileUploadButtonFilesChangedEvent) {\n    this.filesChanged.emit(event);\n  }\n}\n"]}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, inject, Injector, input } from '@angular/core';
|
|
2
|
+
import { DBX_AVATAR_CONTEXT_DATA_TOKEN } from './avatar';
|
|
3
|
+
import { DbxAvatarViewService } from './avatar.service';
|
|
4
|
+
import { DbxInjectionComponent, mergeStaticProviders } from '@dereekb/dbx-core';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* Component that displays an avatar based on the input context.
|
|
8
|
+
*/
|
|
9
|
+
export class DbxAvatarComponent {
|
|
10
|
+
injector = inject(Injector);
|
|
11
|
+
avatarService = inject(DbxAvatarViewService);
|
|
12
|
+
context = input();
|
|
13
|
+
avatarSelector = input();
|
|
14
|
+
avatarUid = input();
|
|
15
|
+
avatarUrl = input();
|
|
16
|
+
avatarKey = input();
|
|
17
|
+
avatarIcon = input();
|
|
18
|
+
avatarStyle = input();
|
|
19
|
+
avatarSize = input(undefined);
|
|
20
|
+
contextSignal = computed(() => {
|
|
21
|
+
const inputContext = this.context();
|
|
22
|
+
const selector = this.avatarSelector() ?? inputContext?.selector;
|
|
23
|
+
const uid = this.avatarUid() ?? inputContext?.uid;
|
|
24
|
+
const url = this.avatarUrl() ?? inputContext?.url;
|
|
25
|
+
const key = this.avatarKey() ?? inputContext?.key;
|
|
26
|
+
const icon = this.avatarIcon() ?? inputContext?.icon;
|
|
27
|
+
const style = this.avatarStyle() ?? inputContext?.style;
|
|
28
|
+
const context = {
|
|
29
|
+
selector,
|
|
30
|
+
uid,
|
|
31
|
+
url,
|
|
32
|
+
key,
|
|
33
|
+
icon,
|
|
34
|
+
style
|
|
35
|
+
};
|
|
36
|
+
return context;
|
|
37
|
+
});
|
|
38
|
+
configSignal = computed(() => {
|
|
39
|
+
const context = this.contextSignal();
|
|
40
|
+
const returnedConfig = this.avatarService.avatarComponentForContext(context);
|
|
41
|
+
const dataProvider = {
|
|
42
|
+
provide: DBX_AVATAR_CONTEXT_DATA_TOKEN,
|
|
43
|
+
useValue: context
|
|
44
|
+
};
|
|
45
|
+
const injector = Injector.create({
|
|
46
|
+
parent: this.injector,
|
|
47
|
+
providers: mergeStaticProviders(dataProvider, returnedConfig.providers)
|
|
48
|
+
});
|
|
49
|
+
const config = {
|
|
50
|
+
...returnedConfig,
|
|
51
|
+
injector
|
|
52
|
+
};
|
|
53
|
+
return config;
|
|
54
|
+
});
|
|
55
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
56
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DbxAvatarComponent, isStandalone: true, selector: "dbx-avatar", inputs: { context: { classPropertyName: "context", publicName: "context", isSignal: true, isRequired: false, transformFunction: null }, avatarSelector: { classPropertyName: "avatarSelector", publicName: "avatarSelector", isSignal: true, isRequired: false, transformFunction: null }, avatarUid: { classPropertyName: "avatarUid", publicName: "avatarUid", isSignal: true, isRequired: false, transformFunction: null }, avatarUrl: { classPropertyName: "avatarUrl", publicName: "avatarUrl", isSignal: true, isRequired: false, transformFunction: null }, avatarKey: { classPropertyName: "avatarKey", publicName: "avatarKey", isSignal: true, isRequired: false, transformFunction: null }, avatarIcon: { classPropertyName: "avatarIcon", publicName: "avatarIcon", isSignal: true, isRequired: false, transformFunction: null }, avatarStyle: { classPropertyName: "avatarStyle", publicName: "avatarStyle", isSignal: true, isRequired: false, transformFunction: null }, avatarSize: { classPropertyName: "avatarSize", publicName: "avatarSize", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.dbx-avatar-small": "avatarSize() === 'small'", "class.dbx-avatar-large": "avatarSize() === 'large'" } }, ngImport: i0, template: `
|
|
57
|
+
<dbx-injection [config]="configSignal()"></dbx-injection>
|
|
58
|
+
`, isInline: true, dependencies: [{ kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
59
|
+
}
|
|
60
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAvatarComponent, decorators: [{
|
|
61
|
+
type: Component,
|
|
62
|
+
args: [{
|
|
63
|
+
selector: 'dbx-avatar',
|
|
64
|
+
template: `
|
|
65
|
+
<dbx-injection [config]="configSignal()"></dbx-injection>
|
|
66
|
+
`,
|
|
67
|
+
imports: [DbxInjectionComponent],
|
|
68
|
+
host: {
|
|
69
|
+
'[class.dbx-avatar-small]': `avatarSize() === 'small'`,
|
|
70
|
+
'[class.dbx-avatar-large]': `avatarSize() === 'large'`
|
|
71
|
+
},
|
|
72
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
73
|
+
standalone: true
|
|
74
|
+
}]
|
|
75
|
+
}] });
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sYXlvdXQvYXZhdGFyL2F2YXRhci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdEcsT0FBTyxFQUFFLDZCQUE2QixFQUFvRixNQUFNLFVBQVUsQ0FBQztBQUMzSSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUN4RCxPQUFPLEVBQXNCLHFCQUFxQixFQUErQixvQkFBb0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUdqSTs7R0FFRztBQWNILE1BQU0sT0FBTyxrQkFBa0I7SUFDcEIsUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUM1QixhQUFhLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFFN0MsT0FBTyxHQUFHLEtBQUssRUFBb0IsQ0FBQztJQUVwQyxjQUFjLEdBQUcsS0FBSyxFQUE0QixDQUFDO0lBQ25ELFNBQVMsR0FBRyxLQUFLLEVBQTZCLENBQUM7SUFDL0MsU0FBUyxHQUFHLEtBQUssRUFBK0IsQ0FBQztJQUNqRCxTQUFTLEdBQUcsS0FBSyxFQUF1QixDQUFDO0lBQ3pDLFVBQVUsR0FBRyxLQUFLLEVBQWlCLENBQUM7SUFDcEMsV0FBVyxHQUFHLEtBQUssRUFBeUIsQ0FBQztJQUM3QyxVQUFVLEdBQUcsS0FBSyxDQUF1QixTQUFTLENBQUMsQ0FBQztJQUVwRCxhQUFhLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUNyQyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFFcEMsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxJQUFJLFlBQVksRUFBRSxRQUFRLENBQUM7UUFDakUsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLFlBQVksRUFBRSxHQUFHLENBQUM7UUFDbEQsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLFlBQVksRUFBRSxHQUFHLENBQUM7UUFDbEQsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLFlBQVksRUFBRSxHQUFHLENBQUM7UUFDbEQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxJQUFJLFlBQVksRUFBRSxJQUFJLENBQUM7UUFDckQsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLFlBQVksRUFBRSxLQUFLLENBQUM7UUFFeEQsTUFBTSxPQUFPLEdBQUc7WUFDZCxRQUFRO1lBQ1IsR0FBRztZQUNILEdBQUc7WUFDSCxHQUFHO1lBQ0gsSUFBSTtZQUNKLEtBQUs7U0FDTixDQUFDO1FBRUYsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQyxDQUFDLENBQUM7SUFFTSxZQUFZLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUNwQyxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDckMsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyx5QkFBeUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUU3RSxNQUFNLFlBQVksR0FBRztZQUNuQixPQUFPLEVBQUUsNkJBQTZCO1lBQ3RDLFFBQVEsRUFBRSxPQUFPO1NBQ2xCLENBQUM7UUFFRixNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQy9CLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUTtZQUNyQixTQUFTLEVBQUUsb0JBQW9CLENBQUMsWUFBWSxFQUFFLGNBQWMsQ0FBQyxTQUFTLENBQUM7U0FDeEUsQ0FBQyxDQUFDO1FBRUgsTUFBTSxNQUFNLEdBQWdDO1lBQzFDLEdBQUcsY0FBYztZQUNqQixRQUFRO1NBQ1QsQ0FBQztRQUVGLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUMsQ0FBQyxDQUFDO3dHQXhEUSxrQkFBa0I7NEZBQWxCLGtCQUFrQiw2d0NBWG5COztHQUVULDREQUNTLHFCQUFxQjs7NEZBUXBCLGtCQUFrQjtrQkFiOUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsWUFBWTtvQkFDdEIsUUFBUSxFQUFFOztHQUVUO29CQUNELE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNoQyxJQUFJLEVBQUU7d0JBQ0osMEJBQTBCLEVBQUUsMEJBQTBCO3dCQUN0RCwwQkFBMEIsRUFBRSwwQkFBMEI7cUJBQ3ZEO29CQUNELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0LCBJbmplY3RvciwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERCWF9BVkFUQVJfQ09OVEVYVF9EQVRBX1RPS0VOLCBEYnhBdmF0YXJDb250ZXh0LCBEYnhBdmF0YXJLZXksIERieEF2YXRhclNlbGVjdG9yLCBEYnhBdmF0YXJTaXplLCBEYnhBdmF0YXJTdHlsZSB9IGZyb20gJy4vYXZhdGFyJztcbmltcG9ydCB7IERieEF2YXRhclZpZXdTZXJ2aWNlIH0gZnJvbSAnLi9hdmF0YXIuc2VydmljZSc7XG5pbXBvcnQgeyBBdXRoVXNlcklkZW50aWZpZXIsIERieEluamVjdGlvbkNvbXBvbmVudCwgRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnLCBtZXJnZVN0YXRpY1Byb3ZpZGVycyB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IE1heWJlLCBXZWJzaXRlVXJsV2l0aFByZWZpeCB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG4vKipcbiAqIENvbXBvbmVudCB0aGF0IGRpc3BsYXlzIGFuIGF2YXRhciBiYXNlZCBvbiB0aGUgaW5wdXQgY29udGV4dC5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWF2YXRhcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1pbmplY3Rpb24gW2NvbmZpZ109XCJjb25maWdTaWduYWwoKVwiPjwvZGJ4LWluamVjdGlvbj5cbiAgYCxcbiAgaW1wb3J0czogW0RieEluamVjdGlvbkNvbXBvbmVudF0sXG4gIGhvc3Q6IHtcbiAgICAnW2NsYXNzLmRieC1hdmF0YXItc21hbGxdJzogYGF2YXRhclNpemUoKSA9PT0gJ3NtYWxsJ2AsXG4gICAgJ1tjbGFzcy5kYngtYXZhdGFyLWxhcmdlXSc6IGBhdmF0YXJTaXplKCkgPT09ICdsYXJnZSdgXG4gIH0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieEF2YXRhckNvbXBvbmVudCB7XG4gIHJlYWRvbmx5IGluamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcbiAgcmVhZG9ubHkgYXZhdGFyU2VydmljZSA9IGluamVjdChEYnhBdmF0YXJWaWV3U2VydmljZSk7XG5cbiAgcmVhZG9ubHkgY29udGV4dCA9IGlucHV0PERieEF2YXRhckNvbnRleHQ+KCk7XG5cbiAgcmVhZG9ubHkgYXZhdGFyU2VsZWN0b3IgPSBpbnB1dDxNYXliZTxEYnhBdmF0YXJTZWxlY3Rvcj4+KCk7XG4gIHJlYWRvbmx5IGF2YXRhclVpZCA9IGlucHV0PE1heWJlPEF1dGhVc2VySWRlbnRpZmllcj4+KCk7XG4gIHJlYWRvbmx5IGF2YXRhclVybCA9IGlucHV0PE1heWJlPFdlYnNpdGVVcmxXaXRoUHJlZml4Pj4oKTtcbiAgcmVhZG9ubHkgYXZhdGFyS2V5ID0gaW5wdXQ8TWF5YmU8RGJ4QXZhdGFyS2V5Pj4oKTtcbiAgcmVhZG9ubHkgYXZhdGFySWNvbiA9IGlucHV0PE1heWJlPHN0cmluZz4+KCk7XG4gIHJlYWRvbmx5IGF2YXRhclN0eWxlID0gaW5wdXQ8TWF5YmU8RGJ4QXZhdGFyU3R5bGU+PigpO1xuICByZWFkb25seSBhdmF0YXJTaXplID0gaW5wdXQ8TWF5YmU8RGJ4QXZhdGFyU2l6ZT4+KHVuZGVmaW5lZCk7XG5cbiAgcmVhZG9ubHkgY29udGV4dFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBpbnB1dENvbnRleHQgPSB0aGlzLmNvbnRleHQoKTtcblxuICAgIGNvbnN0IHNlbGVjdG9yID0gdGhpcy5hdmF0YXJTZWxlY3RvcigpID8/IGlucHV0Q29udGV4dD8uc2VsZWN0b3I7XG4gICAgY29uc3QgdWlkID0gdGhpcy5hdmF0YXJVaWQoKSA/PyBpbnB1dENvbnRleHQ/LnVpZDtcbiAgICBjb25zdCB1cmwgPSB0aGlzLmF2YXRhclVybCgpID8/IGlucHV0Q29udGV4dD8udXJsO1xuICAgIGNvbnN0IGtleSA9IHRoaXMuYXZhdGFyS2V5KCkgPz8gaW5wdXRDb250ZXh0Py5rZXk7XG4gICAgY29uc3QgaWNvbiA9IHRoaXMuYXZhdGFySWNvbigpID8/IGlucHV0Q29udGV4dD8uaWNvbjtcbiAgICBjb25zdCBzdHlsZSA9IHRoaXMuYXZhdGFyU3R5bGUoKSA/PyBpbnB1dENvbnRleHQ/LnN0eWxlO1xuXG4gICAgY29uc3QgY29udGV4dCA9IHtcbiAgICAgIHNlbGVjdG9yLFxuICAgICAgdWlkLFxuICAgICAgdXJsLFxuICAgICAga2V5LFxuICAgICAgaWNvbixcbiAgICAgIHN0eWxlXG4gICAgfTtcblxuICAgIHJldHVybiBjb250ZXh0O1xuICB9KTtcblxuICByZWFkb25seSBjb25maWdTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgY29udGV4dCA9IHRoaXMuY29udGV4dFNpZ25hbCgpO1xuICAgIGNvbnN0IHJldHVybmVkQ29uZmlnID0gdGhpcy5hdmF0YXJTZXJ2aWNlLmF2YXRhckNvbXBvbmVudEZvckNvbnRleHQoY29udGV4dCk7XG5cbiAgICBjb25zdCBkYXRhUHJvdmlkZXIgPSB7XG4gICAgICBwcm92aWRlOiBEQlhfQVZBVEFSX0NPTlRFWFRfREFUQV9UT0tFTixcbiAgICAgIHVzZVZhbHVlOiBjb250ZXh0XG4gICAgfTtcblxuICAgIGNvbnN0IGluamVjdG9yID0gSW5qZWN0b3IuY3JlYXRlKHtcbiAgICAgIHBhcmVudDogdGhpcy5pbmplY3RvcixcbiAgICAgIHByb3ZpZGVyczogbWVyZ2VTdGF0aWNQcm92aWRlcnMoZGF0YVByb3ZpZGVyLCByZXR1cm5lZENvbmZpZy5wcm92aWRlcnMpXG4gICAgfSk7XG5cbiAgICBjb25zdCBjb25maWc6IERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZyA9IHtcbiAgICAgIC4uLnJldHVybmVkQ29uZmlnLFxuICAgICAgaW5qZWN0b3JcbiAgICB9O1xuXG4gICAgcmV0dXJuIGNvbmZpZztcbiAgfSk7XG59XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
// MARK: Injection Token
|
|
3
|
+
/**
|
|
4
|
+
* Injection token for the avatar context data.
|
|
5
|
+
*/
|
|
6
|
+
export const DBX_AVATAR_CONTEXT_DATA_TOKEN = new InjectionToken('DbxAvatarContextData');
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9hdmF0YXIvYXZhdGFyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUF3RC9DLHdCQUF3QjtBQUN4Qjs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLElBQUksY0FBYyxDQUFtQixzQkFBc0IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEF1dGhVc2VySWRlbnRpZmllciB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IE1heWJlLCBXZWJzaXRlVXJsV2l0aFByZWZpeCB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG4vKipcbiAqIEFyYml0cmFyeSBzdHJpbmcgc2VsZWN0b3IgdXNlZCB0byBkaWZmZXJlbnRpYXRlIGF2YXRhcnMuXG4gKi9cbmV4cG9ydCB0eXBlIERieEF2YXRhclNlbGVjdG9yID0gc3RyaW5nO1xuXG4vKipcbiAqIEFyYml0cmFyeSBrZXkgdGhhdCBpcyB1c2VkIHRvIGNvbmZpZ3VyZSBhbiBhdmF0YXIgcGF0aC5cbiAqL1xuZXhwb3J0IHR5cGUgRGJ4QXZhdGFyS2V5ID0gc3RyaW5nO1xuXG4vKipcbiAqIFRoZSBhdmF0YXIgc3R5bGUuXG4gKi9cbmV4cG9ydCB0eXBlIERieEF2YXRhclN0eWxlID0gJ2NpcmNsZScgfCAnc3F1YXJlJztcblxuLyoqXG4gKiBUaGUgYXZhdGFyIHNpemUuXG4gKi9cbmV4cG9ydCB0eXBlIERieEF2YXRhclNpemUgPSAnc21hbGwnIHwgJ25vcm1hbCcgfCAnbGFyZ2UnO1xuXG4vKipcbiAqIFByb3ZpZGVzIGNvbnRleHR1YWwgaW5mb3JtYXRpb24gZm9yIGRpc3BsYXlpbmcgYW4gYXZhdGFyLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERieEF2YXRhckNvbnRleHQge1xuICAvKipcbiAgICogQW4gYXJiaXRyYXJ5IGRpc2NyaW1pbmF0b3IgdXNlZCB0byBkaWZmZXJlbnRpYXRlIGF2YXRhcnMuXG4gICAqL1xuICByZWFkb25seSBzZWxlY3Rvcj86IE1heWJlPERieEF2YXRhclNlbGVjdG9yPjtcbiAgLyoqXG4gICAqIFVzZXIgaWRlbnRpZmllci5cbiAgICpcbiAgICogTWF5IGJlIHVzZWQgaW4gc29tZSBjYXNlcyB0byBkaXNwbGF5IGEgdXNlci1zcGVjaWZpYyBhdmF0YXIuXG4gICAqL1xuICByZWFkb25seSB1aWQ/OiBNYXliZTxBdXRoVXNlcklkZW50aWZpZXI+O1xuICAvKipcbiAgICogQSBmdWxsIHdlYnNpdGUgVVJMIHRvIGFuIGF2YXRhciBpbWFnZS5cbiAgICovXG4gIHJlYWRvbmx5IHVybD86IE1heWJlPFdlYnNpdGVVcmxXaXRoUHJlZml4PjtcbiAgLyoqXG4gICAqIEFyYml0cmFyeSBrZXkgdGhhdCBpcyB1c2VkIHRvIGNvbmZpZ3VyZSBhbiBhdmF0YXIuXG4gICAqL1xuICByZWFkb25seSBrZXk/OiBNYXliZTxEYnhBdmF0YXJLZXk+O1xuICAvKipcbiAgICogVGhlIGF2YXRhciBzdHlsZS5cbiAgICovXG4gIHJlYWRvbmx5IHN0eWxlPzogRGJ4QXZhdGFyU3R5bGU7XG4gIC8qKlxuICAgKiBJY29uIG5hbWUgdG8gdXNlIGZvciB0aGUgZmFsbGJhY2sgYXZhdGFyIHdoZW4gbm8gaW1hZ2UgaXMgcHJvdmlkZWQuXG4gICAqL1xuICByZWFkb25seSBpY29uPzogTWF5YmU8c3RyaW5nPjtcbn1cblxuLy8gTUFSSzogSW5qZWN0aW9uIFRva2VuXG4vKipcbiAqIEluamVjdGlvbiB0b2tlbiBmb3IgdGhlIGF2YXRhciBjb250ZXh0IGRhdGEuXG4gKi9cbmV4cG9ydCBjb25zdCBEQlhfQVZBVEFSX0NPTlRFWFRfREFUQV9UT0tFTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxEYnhBdmF0YXJDb250ZXh0PignRGJ4QXZhdGFyQ29udGV4dERhdGEnKTtcbiJdfQ==
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
|
+
import { DbxAvatarViewComponent } from './avatar.view.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* Configuration for a DbxAvatarViewService.
|
|
6
|
+
*/
|
|
7
|
+
export class DbxAvatarViewServiceConfig {
|
|
8
|
+
/**
|
|
9
|
+
* The default avatar URL to use in DbxAvatarViewComponent if no other url is available
|
|
10
|
+
*/
|
|
11
|
+
defaultAvatarUrl;
|
|
12
|
+
/**
|
|
13
|
+
* The default fallback icon to use when no avatar image is provided.
|
|
14
|
+
*/
|
|
15
|
+
defaultAvatarIcon;
|
|
16
|
+
/**
|
|
17
|
+
* The default fallback icon to use when an avatar image is provided but fails to load.
|
|
18
|
+
*/
|
|
19
|
+
defaultAvatarErrorIcon;
|
|
20
|
+
/**
|
|
21
|
+
* Overrides the default avatar component.
|
|
22
|
+
*/
|
|
23
|
+
defaultAvatarComponentConfig;
|
|
24
|
+
/**
|
|
25
|
+
* Custom function that returns a DbxInjectionComponentConfig for the given context.
|
|
26
|
+
*/
|
|
27
|
+
avatarComponentForContext;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Service for registering avatars.
|
|
31
|
+
*/
|
|
32
|
+
export class DbxAvatarViewService {
|
|
33
|
+
_serviceConfig = inject(DbxAvatarViewServiceConfig, { optional: true });
|
|
34
|
+
_defaultAvatarUrl = this._serviceConfig?.defaultAvatarUrl;
|
|
35
|
+
_defaultAvatarIcon = this._serviceConfig?.defaultAvatarIcon ?? 'person';
|
|
36
|
+
_defaultAvatarErrorIcon;
|
|
37
|
+
_defaultAvatarComponentConfig = this._serviceConfig?.defaultAvatarComponentConfig ?? {
|
|
38
|
+
componentClass: DbxAvatarViewComponent
|
|
39
|
+
};
|
|
40
|
+
_avatarComponentForContext = this._serviceConfig?.avatarComponentForContext;
|
|
41
|
+
avatarComponentForContext(context) {
|
|
42
|
+
let config = this._defaultAvatarComponentConfig;
|
|
43
|
+
if (this._avatarComponentForContext) {
|
|
44
|
+
config = this._avatarComponentForContext(context) ?? config;
|
|
45
|
+
}
|
|
46
|
+
return config;
|
|
47
|
+
}
|
|
48
|
+
get defaultAvatarUrl() {
|
|
49
|
+
return this._defaultAvatarUrl;
|
|
50
|
+
}
|
|
51
|
+
get defaultAvatarIcon() {
|
|
52
|
+
return this._defaultAvatarIcon;
|
|
53
|
+
}
|
|
54
|
+
get defaultAvatarErrorIcon() {
|
|
55
|
+
return this._defaultAvatarErrorIcon;
|
|
56
|
+
}
|
|
57
|
+
setDefaultAvatarUrl(url) {
|
|
58
|
+
this._defaultAvatarUrl = url;
|
|
59
|
+
}
|
|
60
|
+
setDefaultAvatarIcon(icon) {
|
|
61
|
+
this._defaultAvatarIcon = icon;
|
|
62
|
+
}
|
|
63
|
+
setDefaultAvatarErrorIcon(icon) {
|
|
64
|
+
this._defaultAvatarErrorIcon = icon;
|
|
65
|
+
}
|
|
66
|
+
setDefaultAvatarComponentConfig(config) {
|
|
67
|
+
this._defaultAvatarComponentConfig = config;
|
|
68
|
+
}
|
|
69
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAvatarViewService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
70
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAvatarViewService, providedIn: 'root' });
|
|
71
|
+
}
|
|
72
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAvatarViewService, decorators: [{
|
|
73
|
+
type: Injectable,
|
|
74
|
+
args: [{
|
|
75
|
+
providedIn: 'root'
|
|
76
|
+
}]
|
|
77
|
+
}] });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2F2YXRhci9hdmF0YXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVuRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFzQmpFOztHQUVHO0FBQ0gsTUFBTSxPQUFnQiwwQkFBMEI7SUFDOUM7O09BRUc7SUFDTSxnQkFBZ0IsQ0FBNkM7SUFDdEU7O09BRUc7SUFDTSxpQkFBaUIsQ0FBaUI7SUFDM0M7O09BRUc7SUFDTSxzQkFBc0IsQ0FBaUI7SUFDaEQ7O09BRUc7SUFDTSw0QkFBNEIsQ0FBNEM7SUFDakY7O09BRUc7SUFDTSx5QkFBeUIsQ0FBd0M7Q0FDM0U7QUFFRDs7R0FFRztBQUlILE1BQU0sT0FBTyxvQkFBb0I7SUFDZCxjQUFjLEdBQUcsTUFBTSxDQUFDLDBCQUEwQixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFFakYsaUJBQWlCLEdBQThDLElBQUksQ0FBQyxjQUFjLEVBQUUsZ0JBQWdCLENBQUM7SUFDckcsa0JBQWtCLEdBQWtCLElBQUksQ0FBQyxjQUFjLEVBQUUsaUJBQWlCLElBQUksUUFBUSxDQUFDO0lBQ3ZGLHVCQUF1QixDQUFnQjtJQUV2Qyw2QkFBNkIsR0FBc0MsSUFBSSxDQUFDLGNBQWMsRUFBRSw0QkFBNEIsSUFBSTtRQUM5SCxjQUFjLEVBQUUsc0JBQXNCO0tBQ3ZDLENBQUM7SUFFTSwwQkFBMEIsR0FBMEMsSUFBSSxDQUFDLGNBQWMsRUFBRSx5QkFBeUIsQ0FBQztJQUUzSCx5QkFBeUIsQ0FBQyxPQUF5QjtRQUNqRCxJQUFJLE1BQU0sR0FBc0MsSUFBSSxDQUFDLDZCQUE2QixDQUFDO1FBRW5GLElBQUksSUFBSSxDQUFDLDBCQUEwQixFQUFFLENBQUM7WUFDcEMsTUFBTSxHQUFHLElBQUksQ0FBQywwQkFBMEIsQ0FBQyxPQUFPLENBQUMsSUFBSSxNQUFNLENBQUM7UUFDOUQsQ0FBQztRQUVELE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFFRCxJQUFJLGdCQUFnQjtRQUNsQixPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQztJQUNoQyxDQUFDO0lBRUQsSUFBSSxpQkFBaUI7UUFDbkIsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUM7SUFDakMsQ0FBQztJQUVELElBQUksc0JBQXNCO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLHVCQUF1QixDQUFDO0lBQ3RDLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxHQUE4QztRQUNoRSxJQUFJLENBQUMsaUJBQWlCLEdBQUcsR0FBRyxDQUFDO0lBQy9CLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxJQUFtQjtRQUN0QyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDO0lBQ2pDLENBQUM7SUFFRCx5QkFBeUIsQ0FBQyxJQUFtQjtRQUMzQyxJQUFJLENBQUMsdUJBQXVCLEdBQUcsSUFBSSxDQUFDO0lBQ3RDLENBQUM7SUFFRCwrQkFBK0IsQ0FBQyxNQUF5QztRQUN2RSxJQUFJLENBQUMsNkJBQTZCLEdBQUcsTUFBTSxDQUFDO0lBQzlDLENBQUM7d0dBakRVLG9CQUFvQjs0R0FBcEIsb0JBQW9CLGNBRm5CLE1BQU07OzRGQUVQLG9CQUFvQjtrQkFIaEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZyB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieEF2YXRhclZpZXdDb21wb25lbnQgfSBmcm9tICcuL2F2YXRhci52aWV3LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhBdmF0YXJDb250ZXh0IH0gZnJvbSAnLi9hdmF0YXInO1xuaW1wb3J0IHsgTWF5YmUsIFdlYnNpdGVQYXRoLCBXZWJzaXRlVXJsV2l0aFByZWZpeCB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG4vKipcbiAqIFRoZSBpbmplY3Rpb24gY29uZmlndXJhdGlvbiBmb3IgYSBEYnhBdmF0YXIgY29tcG9uZW50LlxuICpcbiAqIE5vdCBhbGxvd2VkIHRvIG92ZXJyaWRlIHRoZSBpbmplY3Rvci5cbiAqXG4gKiBUaGUgZmluYWwgaW5qZWN0b3IgdGhhdCB3aWxsIGJlIHBhc3NlZCB3aWxsIHByb3ZpZGUgREJYX0FWQVRBUl9DT05URVhUX0RBVEFfVE9LRU4uXG4gKi9cbmV4cG9ydCB0eXBlIERieEF2YXRhckluamVjdGlvbkNvbXBvbmVudENvbmZpZyA9IE9taXQ8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnLCAnaW5qZWN0b3InPjtcblxuLyoqXG4gKiBGdW5jdGlvbiB0aGF0IHJldHVybnMgYSBEYnhJbmplY3Rpb25Db21wb25lbnRDb25maWcgZm9yIHRoZSBnaXZlbiBjb250ZXh0LlxuICpcbiAqIENhbiByZXR1cm4gbnVsbC91bmRlZmluZWQgaWYgdGhlIGRlZmF1bHQgYXZhdGFyIGNvbXBvbmVudCBzaG91bGQgYmUgdXNlZC5cbiAqXG4gKiBAcGFyYW0gY29udGV4dCBUaGUgY3VycmVudCBjb250ZXh0IGlucHV0LlxuICovXG5leHBvcnQgdHlwZSBEYnhBdmF0YXJDb21wb25lbnRGb3JDb250ZXh0RnVuY3Rpb24gPSAoY29udGV4dDogRGJ4QXZhdGFyQ29udGV4dCkgPT4gTWF5YmU8RGJ4QXZhdGFySW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPjtcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGZvciBhIERieEF2YXRhclZpZXdTZXJ2aWNlLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgRGJ4QXZhdGFyVmlld1NlcnZpY2VDb25maWcge1xuICAvKipcbiAgICogVGhlIGRlZmF1bHQgYXZhdGFyIFVSTCB0byB1c2UgaW4gRGJ4QXZhdGFyVmlld0NvbXBvbmVudCBpZiBubyBvdGhlciB1cmwgaXMgYXZhaWxhYmxlXG4gICAqL1xuICByZWFkb25seSBkZWZhdWx0QXZhdGFyVXJsPzogTWF5YmU8V2Vic2l0ZVBhdGggfCBXZWJzaXRlVXJsV2l0aFByZWZpeD47XG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBmYWxsYmFjayBpY29uIHRvIHVzZSB3aGVuIG5vIGF2YXRhciBpbWFnZSBpcyBwcm92aWRlZC5cbiAgICovXG4gIHJlYWRvbmx5IGRlZmF1bHRBdmF0YXJJY29uPzogTWF5YmU8c3RyaW5nPjtcbiAgLyoqXG4gICAqIFRoZSBkZWZhdWx0IGZhbGxiYWNrIGljb24gdG8gdXNlIHdoZW4gYW4gYXZhdGFyIGltYWdlIGlzIHByb3ZpZGVkIGJ1dCBmYWlscyB0byBsb2FkLlxuICAgKi9cbiAgcmVhZG9ubHkgZGVmYXVsdEF2YXRhckVycm9ySWNvbj86IE1heWJlPHN0cmluZz47XG4gIC8qKlxuICAgKiBPdmVycmlkZXMgdGhlIGRlZmF1bHQgYXZhdGFyIGNvbXBvbmVudC5cbiAgICovXG4gIHJlYWRvbmx5IGRlZmF1bHRBdmF0YXJDb21wb25lbnRDb25maWc/OiBNYXliZTxEYnhBdmF0YXJJbmplY3Rpb25Db21wb25lbnRDb25maWc+O1xuICAvKipcbiAgICogQ3VzdG9tIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBhIERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZyBmb3IgdGhlIGdpdmVuIGNvbnRleHQuXG4gICAqL1xuICByZWFkb25seSBhdmF0YXJDb21wb25lbnRGb3JDb250ZXh0PzogRGJ4QXZhdGFyQ29tcG9uZW50Rm9yQ29udGV4dEZ1bmN0aW9uO1xufVxuXG4vKipcbiAqIFNlcnZpY2UgZm9yIHJlZ2lzdGVyaW5nIGF2YXRhcnMuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIERieEF2YXRhclZpZXdTZXJ2aWNlIHtcbiAgcHJpdmF0ZSByZWFkb25seSBfc2VydmljZUNvbmZpZyA9IGluamVjdChEYnhBdmF0YXJWaWV3U2VydmljZUNvbmZpZywgeyBvcHRpb25hbDogdHJ1ZSB9KTtcblxuICBwcml2YXRlIF9kZWZhdWx0QXZhdGFyVXJsOiBNYXliZTxXZWJzaXRlUGF0aCB8IFdlYnNpdGVVcmxXaXRoUHJlZml4PiA9IHRoaXMuX3NlcnZpY2VDb25maWc/LmRlZmF1bHRBdmF0YXJVcmw7XG4gIHByaXZhdGUgX2RlZmF1bHRBdmF0YXJJY29uOiBNYXliZTxzdHJpbmc+ID0gdGhpcy5fc2VydmljZUNvbmZpZz8uZGVmYXVsdEF2YXRhckljb24gPz8gJ3BlcnNvbic7XG4gIHByaXZhdGUgX2RlZmF1bHRBdmF0YXJFcnJvckljb246IE1heWJlPHN0cmluZz47XG5cbiAgcHJpdmF0ZSBfZGVmYXVsdEF2YXRhckNvbXBvbmVudENvbmZpZzogRGJ4QXZhdGFySW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnID0gdGhpcy5fc2VydmljZUNvbmZpZz8uZGVmYXVsdEF2YXRhckNvbXBvbmVudENvbmZpZyA/PyB7XG4gICAgY29tcG9uZW50Q2xhc3M6IERieEF2YXRhclZpZXdDb21wb25lbnRcbiAgfTtcblxuICBwcml2YXRlIF9hdmF0YXJDb21wb25lbnRGb3JDb250ZXh0PzogRGJ4QXZhdGFyQ29tcG9uZW50Rm9yQ29udGV4dEZ1bmN0aW9uID0gdGhpcy5fc2VydmljZUNvbmZpZz8uYXZhdGFyQ29tcG9uZW50Rm9yQ29udGV4dDtcblxuICBhdmF0YXJDb21wb25lbnRGb3JDb250ZXh0KGNvbnRleHQ6IERieEF2YXRhckNvbnRleHQpOiBEYnhBdmF0YXJJbmplY3Rpb25Db21wb25lbnRDb25maWcge1xuICAgIGxldCBjb25maWc6IERieEF2YXRhckluamVjdGlvbkNvbXBvbmVudENvbmZpZyA9IHRoaXMuX2RlZmF1bHRBdmF0YXJDb21wb25lbnRDb25maWc7XG5cbiAgICBpZiAodGhpcy5fYXZhdGFyQ29tcG9uZW50Rm9yQ29udGV4dCkge1xuICAgICAgY29uZmlnID0gdGhpcy5fYXZhdGFyQ29tcG9uZW50Rm9yQ29udGV4dChjb250ZXh0KSA/PyBjb25maWc7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbmZpZztcbiAgfVxuXG4gIGdldCBkZWZhdWx0QXZhdGFyVXJsKCkge1xuICAgIHJldHVybiB0aGlzLl9kZWZhdWx0QXZhdGFyVXJsO1xuICB9XG5cbiAgZ2V0IGRlZmF1bHRBdmF0YXJJY29uKCkge1xuICAgIHJldHVybiB0aGlzLl9kZWZhdWx0QXZhdGFySWNvbjtcbiAgfVxuXG4gIGdldCBkZWZhdWx0QXZhdGFyRXJyb3JJY29uKCkge1xuICAgIHJldHVybiB0aGlzLl9kZWZhdWx0QXZhdGFyRXJyb3JJY29uO1xuICB9XG5cbiAgc2V0RGVmYXVsdEF2YXRhclVybCh1cmw6IE1heWJlPFdlYnNpdGVQYXRoIHwgV2Vic2l0ZVVybFdpdGhQcmVmaXg+KSB7XG4gICAgdGhpcy5fZGVmYXVsdEF2YXRhclVybCA9IHVybDtcbiAgfVxuXG4gIHNldERlZmF1bHRBdmF0YXJJY29uKGljb246IE1heWJlPHN0cmluZz4pIHtcbiAgICB0aGlzLl9kZWZhdWx0QXZhdGFySWNvbiA9IGljb247XG4gIH1cblxuICBzZXREZWZhdWx0QXZhdGFyRXJyb3JJY29uKGljb246IE1heWJlPHN0cmluZz4pIHtcbiAgICB0aGlzLl9kZWZhdWx0QXZhdGFyRXJyb3JJY29uID0gaWNvbjtcbiAgfVxuXG4gIHNldERlZmF1bHRBdmF0YXJDb21wb25lbnRDb25maWcoY29uZmlnOiBEYnhBdmF0YXJJbmplY3Rpb25Db21wb25lbnRDb25maWcpIHtcbiAgICB0aGlzLl9kZWZhdWx0QXZhdGFyQ29tcG9uZW50Q29uZmlnID0gY29uZmlnO1xuICB9XG59XG4iXX0=
|