@dereekb/dbx-web 12.4.5 → 12.5.1
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,89 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, inject, input, signal } from '@angular/core';
|
|
2
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
3
|
+
import { DbxAvatarViewService } from './avatar.service';
|
|
4
|
+
import { DBX_AVATAR_CONTEXT_DATA_TOKEN } from './avatar';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/material/icon";
|
|
7
|
+
/**
|
|
8
|
+
* Component that displays an avatar image. It has a configurable default avatar.
|
|
9
|
+
*/
|
|
10
|
+
export class DbxAvatarViewComponent {
|
|
11
|
+
defaultContext = inject(DBX_AVATAR_CONTEXT_DATA_TOKEN, { optional: true });
|
|
12
|
+
avatarService = inject(DbxAvatarViewService);
|
|
13
|
+
defaultAvatarUrl = this.avatarService.defaultAvatarUrl;
|
|
14
|
+
avatarUrl = input();
|
|
15
|
+
avatarErrorUrlSignal = signal(null);
|
|
16
|
+
avatarStyle = input();
|
|
17
|
+
avatarIcon = input();
|
|
18
|
+
avatarUrlSignal = computed(() => {
|
|
19
|
+
const directUrl = this.avatarUrl();
|
|
20
|
+
const contextUrl = this.defaultContext?.url;
|
|
21
|
+
let url = directUrl ?? contextUrl ?? this.defaultAvatarUrl ?? null;
|
|
22
|
+
// if the error url is true or matches the url, then the url is invalid.
|
|
23
|
+
const errorUrl = this.avatarErrorUrlSignal();
|
|
24
|
+
if (errorUrl === true || errorUrl === url) {
|
|
25
|
+
url = null;
|
|
26
|
+
}
|
|
27
|
+
return url;
|
|
28
|
+
});
|
|
29
|
+
hasAvatarSignal = computed(() => !!this.avatarUrlSignal());
|
|
30
|
+
missingAvatarSignal = computed(() => !this.hasAvatarSignal());
|
|
31
|
+
avatarStyleClassSignal = computed(() => {
|
|
32
|
+
return this.avatarStyle() ?? this.defaultContext?.style ?? 'circle';
|
|
33
|
+
});
|
|
34
|
+
avatarIconSignal = computed(() => {
|
|
35
|
+
let icon = this.avatarIcon() ?? this.defaultContext?.icon;
|
|
36
|
+
if (!icon && this.avatarErrorUrlSignal()) {
|
|
37
|
+
icon = this.avatarService.defaultAvatarErrorIcon;
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
icon = icon ?? this.avatarService.defaultAvatarIcon;
|
|
41
|
+
}
|
|
42
|
+
return icon ?? 'person';
|
|
43
|
+
});
|
|
44
|
+
onAvatarImageError(event) {
|
|
45
|
+
if (event.target) {
|
|
46
|
+
const target = event.target;
|
|
47
|
+
this.avatarErrorUrlSignal.set(target.src);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
this.avatarErrorUrlSignal.set(true);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAvatarViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
54
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxAvatarViewComponent, isStandalone: true, selector: "dbx-avatar-view", inputs: { avatarUrl: { classPropertyName: "avatarUrl", publicName: "avatarUrl", isSignal: true, isRequired: false, transformFunction: null }, avatarStyle: { classPropertyName: "avatarStyle", publicName: "avatarStyle", isSignal: true, isRequired: false, transformFunction: null }, avatarIcon: { classPropertyName: "avatarIcon", publicName: "avatarIcon", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.dbx-avatar-view-circle": "avatarStyleClassSignal() === \"circle\"", "class.dbx-avatar-view-square": "avatarStyleClassSignal() === \"square\"", "class.dbx-avatar-view-with-avatar": "hasAvatarSignal()", "class.dbx-avatar-view-no-avatar": "missingAvatarSignal()" }, classAttribute: "dbx-avatar-view" }, ngImport: i0, template: `
|
|
55
|
+
@if (avatarUrlSignal()) {
|
|
56
|
+
<img (error)="onAvatarImageError($event)" class="dbx-avatar-view-img" [src]="avatarUrlSignal()!" alt="." loading="lazy" decoding="async" />
|
|
57
|
+
} @else {
|
|
58
|
+
<div class="dbx-avatar-view-fallback" aria-hidden="true">
|
|
59
|
+
<mat-icon>{{ avatarIconSignal() }}</mat-icon>
|
|
60
|
+
</div>
|
|
61
|
+
}
|
|
62
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
63
|
+
}
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxAvatarViewComponent, decorators: [{
|
|
65
|
+
type: Component,
|
|
66
|
+
args: [{
|
|
67
|
+
selector: 'dbx-avatar-view',
|
|
68
|
+
template: `
|
|
69
|
+
@if (avatarUrlSignal()) {
|
|
70
|
+
<img (error)="onAvatarImageError($event)" class="dbx-avatar-view-img" [src]="avatarUrlSignal()!" alt="." loading="lazy" decoding="async" />
|
|
71
|
+
} @else {
|
|
72
|
+
<div class="dbx-avatar-view-fallback" aria-hidden="true">
|
|
73
|
+
<mat-icon>{{ avatarIconSignal() }}</mat-icon>
|
|
74
|
+
</div>
|
|
75
|
+
}
|
|
76
|
+
`,
|
|
77
|
+
host: {
|
|
78
|
+
class: 'dbx-avatar-view',
|
|
79
|
+
'[class.dbx-avatar-view-circle]': 'avatarStyleClassSignal() === "circle"',
|
|
80
|
+
'[class.dbx-avatar-view-square]': 'avatarStyleClassSignal() === "square"',
|
|
81
|
+
'[class.dbx-avatar-view-with-avatar]': 'hasAvatarSignal()',
|
|
82
|
+
'[class.dbx-avatar-view-no-avatar]': 'missingAvatarSignal()'
|
|
83
|
+
},
|
|
84
|
+
imports: [MatIconModule],
|
|
85
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
86
|
+
standalone: true
|
|
87
|
+
}]
|
|
88
|
+
}] });
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLnZpZXcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9hdmF0YXIvYXZhdGFyLnZpZXcuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV2RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUN4RCxPQUFPLEVBQW9CLDZCQUE2QixFQUFrQixNQUFNLFVBQVUsQ0FBQzs7O0FBRTNGOztHQUVHO0FBdUJILE1BQU0sT0FBTyxzQkFBc0I7SUFDeEIsY0FBYyxHQUE0QixNQUFNLENBQUMsNkJBQTZCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUVwRyxhQUFhLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFFN0MsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQztJQUV2RCxTQUFTLEdBQUcsS0FBSyxFQUErQixDQUFDO0lBQ2pELG9CQUFvQixHQUFHLE1BQU0sQ0FBd0MsSUFBSSxDQUFDLENBQUM7SUFFM0UsV0FBVyxHQUFHLEtBQUssRUFBeUIsQ0FBQztJQUM3QyxVQUFVLEdBQUcsS0FBSyxFQUFpQixDQUFDO0lBRXBDLGVBQWUsR0FBRyxRQUFRLENBQTRDLEdBQUcsRUFBRTtRQUNsRixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDbkMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxHQUFHLENBQUM7UUFFNUMsSUFBSSxHQUFHLEdBQUcsU0FBUyxJQUFJLFVBQVUsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLElBQUksSUFBSSxDQUFDO1FBRW5FLHdFQUF3RTtRQUN4RSxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztRQUU3QyxJQUFJLFFBQVEsS0FBSyxJQUFJLElBQUksUUFBUSxLQUFLLEdBQUcsRUFBRSxDQUFDO1lBQzFDLEdBQUcsR0FBRyxJQUFJLENBQUM7UUFDYixDQUFDO1FBRUQsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDLENBQUMsQ0FBQztJQUVNLGVBQWUsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDO0lBRTNELG1CQUFtQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDO0lBRTlELHNCQUFzQixHQUFHLFFBQVEsQ0FBc0IsR0FBRyxFQUFFO1FBQ25FLE9BQU8sSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLElBQUksQ0FBQyxjQUFjLEVBQUUsS0FBSyxJQUFJLFFBQVEsQ0FBQztJQUN0RSxDQUFDLENBQUMsQ0FBQztJQUVNLGdCQUFnQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDeEMsSUFBSSxJQUFJLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxJQUFJLElBQUksQ0FBQyxjQUFjLEVBQUUsSUFBSSxDQUFDO1FBRTFELElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLG9CQUFvQixFQUFFLEVBQUUsQ0FBQztZQUN6QyxJQUFJLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQztRQUNuRCxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksR0FBRyxJQUFJLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxpQkFBaUIsQ0FBQztRQUN0RCxDQUFDO1FBRUQsT0FBTyxJQUFJLElBQUksUUFBUSxDQUFDO0lBQzFCLENBQUMsQ0FBQyxDQUFDO0lBRUgsa0JBQWtCLENBQUMsS0FBWTtRQUM3QixJQUFJLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNqQixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBMEIsQ0FBQztZQUNoRCxJQUFJLENBQUMsb0JBQW9CLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM1QyxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdEMsQ0FBQztJQUNILENBQUM7d0dBeERVLHNCQUFzQjs0RkFBdEIsc0JBQXNCLHF6QkFwQnZCOzs7Ozs7OztHQVFULDJEQVFTLGFBQWE7OzRGQUlaLHNCQUFzQjtrQkF0QmxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsUUFBUSxFQUFFOzs7Ozs7OztHQVFUO29CQUNELElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsaUJBQWlCO3dCQUN4QixnQ0FBZ0MsRUFBRSx1Q0FBdUM7d0JBQ3pFLGdDQUFnQyxFQUFFLHVDQUF1Qzt3QkFDekUscUNBQXFDLEVBQUUsbUJBQW1CO3dCQUMxRCxtQ0FBbUMsRUFBRSx1QkFBdUI7cUJBQzdEO29CQUNELE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQztvQkFDeEIsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGNvbXB1dGVkLCBpbmplY3QsIGlucHV0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE1heWJlLCBXZWJzaXRlUGF0aCwgV2Vic2l0ZVVybFdpdGhQcmVmaXggfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IERieEF2YXRhclZpZXdTZXJ2aWNlIH0gZnJvbSAnLi9hdmF0YXIuc2VydmljZSc7XG5pbXBvcnQgeyBEYnhBdmF0YXJDb250ZXh0LCBEQlhfQVZBVEFSX0NPTlRFWFRfREFUQV9UT0tFTiwgRGJ4QXZhdGFyU3R5bGUgfSBmcm9tICcuL2F2YXRhcic7XG5cbi8qKlxuICogQ29tcG9uZW50IHRoYXQgZGlzcGxheXMgYW4gYXZhdGFyIGltYWdlLiBJdCBoYXMgYSBjb25maWd1cmFibGUgZGVmYXVsdCBhdmF0YXIuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1hdmF0YXItdmlldycsXG4gIHRlbXBsYXRlOiBgXG4gICAgQGlmIChhdmF0YXJVcmxTaWduYWwoKSkge1xuICAgICAgPGltZyAoZXJyb3IpPVwib25BdmF0YXJJbWFnZUVycm9yKCRldmVudClcIiBjbGFzcz1cImRieC1hdmF0YXItdmlldy1pbWdcIiBbc3JjXT1cImF2YXRhclVybFNpZ25hbCgpIVwiIGFsdD1cIi5cIiBsb2FkaW5nPVwibGF6eVwiIGRlY29kaW5nPVwiYXN5bmNcIiAvPlxuICAgIH0gQGVsc2Uge1xuICAgICAgPGRpdiBjbGFzcz1cImRieC1hdmF0YXItdmlldy1mYWxsYmFja1wiIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPlxuICAgICAgICA8bWF0LWljb24+e3sgYXZhdGFySWNvblNpZ25hbCgpIH19PC9tYXQtaWNvbj5cbiAgICAgIDwvZGl2PlxuICAgIH1cbiAgYCxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZGJ4LWF2YXRhci12aWV3JyxcbiAgICAnW2NsYXNzLmRieC1hdmF0YXItdmlldy1jaXJjbGVdJzogJ2F2YXRhclN0eWxlQ2xhc3NTaWduYWwoKSA9PT0gXCJjaXJjbGVcIicsXG4gICAgJ1tjbGFzcy5kYngtYXZhdGFyLXZpZXctc3F1YXJlXSc6ICdhdmF0YXJTdHlsZUNsYXNzU2lnbmFsKCkgPT09IFwic3F1YXJlXCInLFxuICAgICdbY2xhc3MuZGJ4LWF2YXRhci12aWV3LXdpdGgtYXZhdGFyXSc6ICdoYXNBdmF0YXJTaWduYWwoKScsXG4gICAgJ1tjbGFzcy5kYngtYXZhdGFyLXZpZXctbm8tYXZhdGFyXSc6ICdtaXNzaW5nQXZhdGFyU2lnbmFsKCknXG4gIH0sXG4gIGltcG9ydHM6IFtNYXRJY29uTW9kdWxlXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4QXZhdGFyVmlld0NvbXBvbmVudCB7XG4gIHJlYWRvbmx5IGRlZmF1bHRDb250ZXh0OiBNYXliZTxEYnhBdmF0YXJDb250ZXh0PiA9IGluamVjdChEQlhfQVZBVEFSX0NPTlRFWFRfREFUQV9UT0tFTiwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcblxuICByZWFkb25seSBhdmF0YXJTZXJ2aWNlID0gaW5qZWN0KERieEF2YXRhclZpZXdTZXJ2aWNlKTtcblxuICByZWFkb25seSBkZWZhdWx0QXZhdGFyVXJsID0gdGhpcy5hdmF0YXJTZXJ2aWNlLmRlZmF1bHRBdmF0YXJVcmw7XG5cbiAgcmVhZG9ubHkgYXZhdGFyVXJsID0gaW5wdXQ8TWF5YmU8V2Vic2l0ZVVybFdpdGhQcmVmaXg+PigpO1xuICByZWFkb25seSBhdmF0YXJFcnJvclVybFNpZ25hbCA9IHNpZ25hbDxNYXliZTxib29sZWFuIHwgV2Vic2l0ZVVybFdpdGhQcmVmaXg+PihudWxsKTtcblxuICByZWFkb25seSBhdmF0YXJTdHlsZSA9IGlucHV0PE1heWJlPERieEF2YXRhclN0eWxlPj4oKTtcbiAgcmVhZG9ubHkgYXZhdGFySWNvbiA9IGlucHV0PE1heWJlPHN0cmluZz4+KCk7XG5cbiAgcmVhZG9ubHkgYXZhdGFyVXJsU2lnbmFsID0gY29tcHV0ZWQ8TWF5YmU8V2Vic2l0ZVVybFdpdGhQcmVmaXggfCBXZWJzaXRlUGF0aD4+KCgpID0+IHtcbiAgICBjb25zdCBkaXJlY3RVcmwgPSB0aGlzLmF2YXRhclVybCgpO1xuICAgIGNvbnN0IGNvbnRleHRVcmwgPSB0aGlzLmRlZmF1bHRDb250ZXh0Py51cmw7XG5cbiAgICBsZXQgdXJsID0gZGlyZWN0VXJsID8/IGNvbnRleHRVcmwgPz8gdGhpcy5kZWZhdWx0QXZhdGFyVXJsID8/IG51bGw7XG5cbiAgICAvLyBpZiB0aGUgZXJyb3IgdXJsIGlzIHRydWUgb3IgbWF0Y2hlcyB0aGUgdXJsLCB0aGVuIHRoZSB1cmwgaXMgaW52YWxpZC5cbiAgICBjb25zdCBlcnJvclVybCA9IHRoaXMuYXZhdGFyRXJyb3JVcmxTaWduYWwoKTtcblxuICAgIGlmIChlcnJvclVybCA9PT0gdHJ1ZSB8fCBlcnJvclVybCA9PT0gdXJsKSB7XG4gICAgICB1cmwgPSBudWxsO1xuICAgIH1cblxuICAgIHJldHVybiB1cmw7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IGhhc0F2YXRhclNpZ25hbCA9IGNvbXB1dGVkKCgpID0+ICEhdGhpcy5hdmF0YXJVcmxTaWduYWwoKSk7XG5cbiAgcmVhZG9ubHkgbWlzc2luZ0F2YXRhclNpZ25hbCA9IGNvbXB1dGVkKCgpID0+ICF0aGlzLmhhc0F2YXRhclNpZ25hbCgpKTtcblxuICByZWFkb25seSBhdmF0YXJTdHlsZUNsYXNzU2lnbmFsID0gY29tcHV0ZWQ8J2NpcmNsZScgfCAnc3F1YXJlJz4oKCkgPT4ge1xuICAgIHJldHVybiB0aGlzLmF2YXRhclN0eWxlKCkgPz8gdGhpcy5kZWZhdWx0Q29udGV4dD8uc3R5bGUgPz8gJ2NpcmNsZSc7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IGF2YXRhckljb25TaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgbGV0IGljb24gPSB0aGlzLmF2YXRhckljb24oKSA/PyB0aGlzLmRlZmF1bHRDb250ZXh0Py5pY29uO1xuXG4gICAgaWYgKCFpY29uICYmIHRoaXMuYXZhdGFyRXJyb3JVcmxTaWduYWwoKSkge1xuICAgICAgaWNvbiA9IHRoaXMuYXZhdGFyU2VydmljZS5kZWZhdWx0QXZhdGFyRXJyb3JJY29uO1xuICAgIH0gZWxzZSB7XG4gICAgICBpY29uID0gaWNvbiA/PyB0aGlzLmF2YXRhclNlcnZpY2UuZGVmYXVsdEF2YXRhckljb247XG4gICAgfVxuXG4gICAgcmV0dXJuIGljb24gPz8gJ3BlcnNvbic7XG4gIH0pO1xuXG4gIG9uQXZhdGFySW1hZ2VFcnJvcihldmVudDogRXZlbnQpIHtcbiAgICBpZiAoZXZlbnQudGFyZ2V0KSB7XG4gICAgICBjb25zdCB0YXJnZXQgPSBldmVudC50YXJnZXQgYXMgSFRNTEltYWdlRWxlbWVudDtcbiAgICAgIHRoaXMuYXZhdGFyRXJyb3JVcmxTaWduYWwuc2V0KHRhcmdldC5zcmMpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmF2YXRhckVycm9yVXJsU2lnbmFsLnNldCh0cnVlKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './avatar';
|
|
2
|
+
export * from './avatar.component';
|
|
3
|
+
export * from './avatar.service';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2F2YXRhci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2F2YXRhcic7XG5leHBvcnQgKiBmcm9tICcuL2F2YXRhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hdmF0YXIuc2VydmljZSc7XG4iXX0=
|
|
@@ -1,12 +1,41 @@
|
|
|
1
|
-
import { Directive, input } from '@angular/core';
|
|
1
|
+
import { computed, Directive, input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
/**
|
|
4
4
|
* Component used to wrap content in a pit with a label.
|
|
5
5
|
*/
|
|
6
6
|
export class DbxContentPitDirective {
|
|
7
7
|
scrollable = input();
|
|
8
|
+
scrollableHeightSignal = computed(() => {
|
|
9
|
+
let scrollable = this.scrollable();
|
|
10
|
+
let scrollableHeight;
|
|
11
|
+
if (typeof scrollable === 'boolean') {
|
|
12
|
+
scrollable = scrollable ? 'medium' : undefined; // defaults to medium
|
|
13
|
+
}
|
|
14
|
+
if (scrollable) {
|
|
15
|
+
if (typeof scrollable === 'string') {
|
|
16
|
+
switch (scrollable) {
|
|
17
|
+
case 'small':
|
|
18
|
+
scrollable = 120;
|
|
19
|
+
break;
|
|
20
|
+
case 'medium':
|
|
21
|
+
scrollable = 320;
|
|
22
|
+
break;
|
|
23
|
+
case 'large':
|
|
24
|
+
scrollable = 460;
|
|
25
|
+
break;
|
|
26
|
+
default:
|
|
27
|
+
scrollableHeight = scrollable; // use as-is
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (typeof scrollable === 'number') {
|
|
32
|
+
scrollableHeight = `${scrollable}px`;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return scrollableHeight ?? null;
|
|
36
|
+
});
|
|
8
37
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxContentPitDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxContentPitDirective, isStandalone: true, selector: "dbx-content-pit, [dbxContentPit]", inputs: { scrollable: { classPropertyName: "scrollable", publicName: "scrollable", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.dbx-content-pit-scrollable": "
|
|
38
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxContentPitDirective, isStandalone: true, selector: "dbx-content-pit, [dbxContentPit]", inputs: { scrollable: { classPropertyName: "scrollable", publicName: "scrollable", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.dbx-content-pit-scrollable": "scrollableHeightSignal() != null", "style.max-height": "scrollableHeightSignal()" }, classAttribute: "d-block dbx-content-pit" }, ngImport: i0 });
|
|
10
39
|
}
|
|
11
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxContentPitDirective, decorators: [{
|
|
12
41
|
type: Directive,
|
|
@@ -14,9 +43,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
14
43
|
selector: 'dbx-content-pit, [dbxContentPit]',
|
|
15
44
|
host: {
|
|
16
45
|
class: 'd-block dbx-content-pit',
|
|
17
|
-
'[class.dbx-content-pit-scrollable]': '
|
|
46
|
+
'[class.dbx-content-pit-scrollable]': 'scrollableHeightSignal() != null',
|
|
47
|
+
'[style.max-height]': 'scrollableHeightSignal()'
|
|
18
48
|
},
|
|
19
49
|
standalone: true
|
|
20
50
|
}]
|
|
21
51
|
}] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5waXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9jb250ZW50L2NvbnRlbnQucGl0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzNEOztHQUVHO0FBVUgsTUFBTSxPQUFPLHNCQUFzQjtJQUN4QixVQUFVLEdBQUcsS0FBSyxFQUF1QyxDQUFDO0lBRTFELHNCQUFzQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDOUMsSUFBSSxVQUFVLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ25DLElBQUksZ0JBQTBDLENBQUM7UUFFL0MsSUFBSSxPQUFPLFVBQVUsS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNwQyxVQUFVLEdBQUcsVUFBVSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLHFCQUFxQjtRQUN2RSxDQUFDO1FBRUQsSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNmLElBQUksT0FBTyxVQUFVLEtBQUssUUFBUSxFQUFFLENBQUM7Z0JBQ25DLFFBQVEsVUFBVSxFQUFFLENBQUM7b0JBQ25CLEtBQUssT0FBTzt3QkFDVixVQUFVLEdBQUcsR0FBRyxDQUFDO3dCQUNqQixNQUFNO29CQUNSLEtBQUssUUFBUTt3QkFDWCxVQUFVLEdBQUcsR0FBRyxDQUFDO3dCQUNqQixNQUFNO29CQUNSLEtBQUssT0FBTzt3QkFDVixVQUFVLEdBQUcsR0FBRyxDQUFDO3dCQUNqQixNQUFNO29CQUNSO3dCQUNFLGdCQUFnQixHQUFHLFVBQVUsQ0FBQyxDQUFDLFlBQVk7d0JBQzNDLE1BQU07Z0JBQ1YsQ0FBQztZQUNILENBQUM7WUFFRCxJQUFJLE9BQU8sVUFBVSxLQUFLLFFBQVEsRUFBRSxDQUFDO2dCQUNuQyxnQkFBZ0IsR0FBRyxHQUFHLFVBQVUsSUFBSSxDQUFDO1lBQ3ZDLENBQUM7UUFDSCxDQUFDO1FBRUQsT0FBTyxnQkFBZ0IsSUFBSSxJQUFJLENBQUM7SUFDbEMsQ0FBQyxDQUFDLENBQUM7d0dBbkNRLHNCQUFzQjs0RkFBdEIsc0JBQXNCOzs0RkFBdEIsc0JBQXNCO2tCQVRsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQ0FBa0M7b0JBQzVDLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUseUJBQXlCO3dCQUNoQyxvQ0FBb0MsRUFBRSxrQ0FBa0M7d0JBQ3hFLG9CQUFvQixFQUFFLDBCQUEwQjtxQkFDakQ7b0JBQ0QsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29tcHV0ZWQsIERpcmVjdGl2ZSwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFBpeGVscywgUGl4ZWxzU3RyaW5nLCB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbmV4cG9ydCB0eXBlIERieENvbnRlbnRQaXRTY3JvbGxhYmxlSW5wdXQgPSBib29sZWFuIHwgRGJ4Q29udGVudFBpdFNjcm9sbGFibGVIZWlnaHQ7XG5leHBvcnQgdHlwZSBEYnhDb250ZW50UGl0U2Nyb2xsYWJsZUhlaWdodCA9IFBpeGVscyB8IFBpeGVsc1N0cmluZyB8IERieENvbnRlbnRQaXRTY3JvbGxhYmxlSGVpZ2h0U2V0dGluZztcbmV4cG9ydCB0eXBlIERieENvbnRlbnRQaXRTY3JvbGxhYmxlSGVpZ2h0U2V0dGluZyA9ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZSc7XG5cbi8qKlxuICogQ29tcG9uZW50IHVzZWQgdG8gd3JhcCBjb250ZW50IGluIGEgcGl0IHdpdGggYSBsYWJlbC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnZGJ4LWNvbnRlbnQtcGl0LCBbZGJ4Q29udGVudFBpdF0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdkLWJsb2NrIGRieC1jb250ZW50LXBpdCcsXG4gICAgJ1tjbGFzcy5kYngtY29udGVudC1waXQtc2Nyb2xsYWJsZV0nOiAnc2Nyb2xsYWJsZUhlaWdodFNpZ25hbCgpICE9IG51bGwnLFxuICAgICdbc3R5bGUubWF4LWhlaWdodF0nOiAnc2Nyb2xsYWJsZUhlaWdodFNpZ25hbCgpJ1xuICB9LFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieENvbnRlbnRQaXREaXJlY3RpdmUge1xuICByZWFkb25seSBzY3JvbGxhYmxlID0gaW5wdXQ8TWF5YmU8RGJ4Q29udGVudFBpdFNjcm9sbGFibGVJbnB1dD4+KCk7XG5cbiAgcmVhZG9ubHkgc2Nyb2xsYWJsZUhlaWdodFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBsZXQgc2Nyb2xsYWJsZSA9IHRoaXMuc2Nyb2xsYWJsZSgpO1xuICAgIGxldCBzY3JvbGxhYmxlSGVpZ2h0OiBQaXhlbHNTdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgICBpZiAodHlwZW9mIHNjcm9sbGFibGUgPT09ICdib29sZWFuJykge1xuICAgICAgc2Nyb2xsYWJsZSA9IHNjcm9sbGFibGUgPyAnbWVkaXVtJyA6IHVuZGVmaW5lZDsgLy8gZGVmYXVsdHMgdG8gbWVkaXVtXG4gICAgfVxuXG4gICAgaWYgKHNjcm9sbGFibGUpIHtcbiAgICAgIGlmICh0eXBlb2Ygc2Nyb2xsYWJsZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgc3dpdGNoIChzY3JvbGxhYmxlKSB7XG4gICAgICAgICAgY2FzZSAnc21hbGwnOlxuICAgICAgICAgICAgc2Nyb2xsYWJsZSA9IDEyMDtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgIGNhc2UgJ21lZGl1bSc6XG4gICAgICAgICAgICBzY3JvbGxhYmxlID0gMzIwO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgY2FzZSAnbGFyZ2UnOlxuICAgICAgICAgICAgc2Nyb2xsYWJsZSA9IDQ2MDtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICBzY3JvbGxhYmxlSGVpZ2h0ID0gc2Nyb2xsYWJsZTsgLy8gdXNlIGFzLWlzXG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAodHlwZW9mIHNjcm9sbGFibGUgPT09ICdudW1iZXInKSB7XG4gICAgICAgIHNjcm9sbGFibGVIZWlnaHQgPSBgJHtzY3JvbGxhYmxlfXB4YDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gc2Nyb2xsYWJsZUhlaWdodCA/PyBudWxsO1xuICB9KTtcbn1cbiJdfQ==
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export * from './avatar';
|
|
1
2
|
export * from './bar';
|
|
2
3
|
export * from './block';
|
|
3
4
|
export * from './card';
|
|
@@ -13,4 +14,4 @@ export * from './step';
|
|
|
13
14
|
export * from './style';
|
|
14
15
|
export * from './text';
|
|
15
16
|
export * from './layout.module';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2F2YXRhcic7XG5leHBvcnQgKiBmcm9tICcuL2Jhcic7XG5leHBvcnQgKiBmcm9tICcuL2Jsb2NrJztcbmV4cG9ydCAqIGZyb20gJy4vY2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbHVtbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBhY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmxhZyc7XG5leHBvcnQgKiBmcm9tICcuL2ZsZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9pdGVtJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdCc7XG5leHBvcnQgKiBmcm9tICcuL3NlY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9zdGVwJztcbmV4cG9ydCAqIGZyb20gJy4vc3R5bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vbGF5b3V0Lm1vZHVsZSc7XG4iXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Component, ElementRef, input, computed, ChangeDetectionStrategy, viewChild } from '@angular/core';
|
|
2
|
+
import { isDefinedAndNotFalse } from '@dereekb/util';
|
|
2
3
|
import { checkNgContentWrapperHasContent } from '@dereekb/dbx-core';
|
|
3
4
|
import { DbxErrorComponent } from '../error/error.component';
|
|
4
5
|
import { DbxLoadingProgressComponent } from './loading-progress.component';
|
|
@@ -11,15 +12,41 @@ export class DbxBasicLoadingComponent {
|
|
|
11
12
|
customError = viewChild('customError', { read: ElementRef });
|
|
12
13
|
customLoading = viewChild('customLoading', { read: ElementRef });
|
|
13
14
|
diameter = input();
|
|
14
|
-
mode = input(
|
|
15
|
+
mode = input();
|
|
15
16
|
color = input('primary');
|
|
16
17
|
text = input();
|
|
17
18
|
linear = input(false);
|
|
18
19
|
show = input(true);
|
|
19
20
|
loading = input();
|
|
20
21
|
error = input();
|
|
21
|
-
|
|
22
|
+
loadingProgressSignal = computed(() => {
|
|
22
23
|
const loading = this.loading();
|
|
24
|
+
let result;
|
|
25
|
+
if (typeof loading === 'number') {
|
|
26
|
+
result = loading;
|
|
27
|
+
}
|
|
28
|
+
return result;
|
|
29
|
+
});
|
|
30
|
+
modeSignal = computed(() => {
|
|
31
|
+
const mode = this.mode();
|
|
32
|
+
const loadingProgress = this.loadingProgressSignal();
|
|
33
|
+
let result;
|
|
34
|
+
if (!mode) {
|
|
35
|
+
if (loadingProgress != null) {
|
|
36
|
+
result = 'determinate';
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
result = 'indeterminate';
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
result = mode;
|
|
44
|
+
}
|
|
45
|
+
return result;
|
|
46
|
+
});
|
|
47
|
+
isLoadingSignal = computed(() => isDefinedAndNotFalse(this.loading()));
|
|
48
|
+
stateSignal = computed(() => {
|
|
49
|
+
const loading = this.isLoadingSignal();
|
|
23
50
|
const error = this.error();
|
|
24
51
|
const show = this.show() ?? true; // default to true if not defined
|
|
25
52
|
let state;
|
|
@@ -41,10 +68,10 @@ export class DbxBasicLoadingComponent {
|
|
|
41
68
|
hasNoCustomErrorSignal = computed(() => !checkNgContentWrapperHasContent(this.customError()));
|
|
42
69
|
hasNoCustomLoadingSignal = computed(() => !checkNgContentWrapperHasContent(this.customLoading()));
|
|
43
70
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxBasicLoadingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
44
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxBasicLoadingComponent, isStandalone: true, selector: "dbx-basic-loading", inputs: { diameter: { classPropertyName: "diameter", publicName: "diameter", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null }, linear: { classPropertyName: "linear", publicName: "linear", isSignal: true, isRequired: false, transformFunction: null }, show: { classPropertyName: "show", publicName: "show", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, error: { classPropertyName: "error", publicName: "error", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "customError", first: true, predicate: ["customError"], descendants: true, read: ElementRef, isSignal: true }, { propertyName: "customLoading", first: true, predicate: ["customLoading"], descendants: true, read: ElementRef, isSignal: true }], ngImport: i0, template: "@switch (stateSignal()) {\n @case ('none') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('loading') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('content') {\n <!-- Content -->\n <ng-content></ng-content>\n }\n @case ('error') {\n <!-- Error -->\n <ng-container *ngTemplateOutlet=\"errorTemplate\"></ng-container>\n }\n}\n\n<ng-template #loadingTemplate>\n @if (hasNoCustomLoadingSignal()) {\n <dbx-loading-progress [mode]=\"
|
|
71
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxBasicLoadingComponent, isStandalone: true, selector: "dbx-basic-loading", inputs: { diameter: { classPropertyName: "diameter", publicName: "diameter", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null }, linear: { classPropertyName: "linear", publicName: "linear", isSignal: true, isRequired: false, transformFunction: null }, show: { classPropertyName: "show", publicName: "show", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, error: { classPropertyName: "error", publicName: "error", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "customError", first: true, predicate: ["customError"], descendants: true, read: ElementRef, isSignal: true }, { propertyName: "customLoading", first: true, predicate: ["customLoading"], descendants: true, read: ElementRef, isSignal: true }], ngImport: i0, template: "@switch (stateSignal()) {\n @case ('none') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('loading') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('content') {\n <!-- Content -->\n <ng-content></ng-content>\n }\n @case ('error') {\n <!-- Error -->\n <ng-container *ngTemplateOutlet=\"errorTemplate\"></ng-container>\n }\n}\n\n<ng-template #loadingTemplate>\n @if (hasNoCustomLoadingSignal()) {\n <dbx-loading-progress [mode]=\"modeSignal()\" [value]=\"loadingProgressSignal()\" [color]=\"color()\" [text]=\"text()\" [linear]=\"linear()\" [diameter]=\"diameter()\"></dbx-loading-progress>\n }\n <div #customLoading>\n <ng-content select=\"[loading]\"></ng-content>\n </div>\n</ng-template>\n\n<ng-template #errorTemplate>\n @if (hasNoCustomErrorSignal()) {\n <dbx-error [error]=\"error()\"></dbx-error>\n }\n <div #customError>\n <ng-content select=\"[error]\"></ng-content>\n </div>\n <ng-content select=\"[errorAction]\"></ng-content>\n</ng-template>\n", dependencies: [{ kind: "component", type: DbxErrorComponent, selector: "dbx-error", inputs: ["error", "iconOnly"], outputs: ["popoverOpened"] }, { kind: "component", type: DbxLoadingProgressComponent, selector: "dbx-loading-progress", inputs: ["diameter", "text", "linear", "mode", "color", "value", "bufferValue"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
45
72
|
}
|
|
46
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxBasicLoadingComponent, decorators: [{
|
|
47
74
|
type: Component,
|
|
48
|
-
args: [{ selector: 'dbx-basic-loading', imports: [DbxErrorComponent, DbxLoadingProgressComponent, NgTemplateOutlet], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "@switch (stateSignal()) {\n @case ('none') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('loading') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('content') {\n <!-- Content -->\n <ng-content></ng-content>\n }\n @case ('error') {\n <!-- Error -->\n <ng-container *ngTemplateOutlet=\"errorTemplate\"></ng-container>\n }\n}\n\n<ng-template #loadingTemplate>\n @if (hasNoCustomLoadingSignal()) {\n <dbx-loading-progress [mode]=\"
|
|
75
|
+
args: [{ selector: 'dbx-basic-loading', imports: [DbxErrorComponent, DbxLoadingProgressComponent, NgTemplateOutlet], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "@switch (stateSignal()) {\n @case ('none') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('loading') {\n <!-- Loading -->\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n }\n @case ('content') {\n <!-- Content -->\n <ng-content></ng-content>\n }\n @case ('error') {\n <!-- Error -->\n <ng-container *ngTemplateOutlet=\"errorTemplate\"></ng-container>\n }\n}\n\n<ng-template #loadingTemplate>\n @if (hasNoCustomLoadingSignal()) {\n <dbx-loading-progress [mode]=\"modeSignal()\" [value]=\"loadingProgressSignal()\" [color]=\"color()\" [text]=\"text()\" [linear]=\"linear()\" [diameter]=\"diameter()\"></dbx-loading-progress>\n }\n <div #customLoading>\n <ng-content select=\"[loading]\"></ng-content>\n </div>\n</ng-template>\n\n<ng-template #errorTemplate>\n @if (hasNoCustomErrorSignal()) {\n <dbx-error [error]=\"error()\"></dbx-error>\n }\n <div #customError>\n <ng-content select=\"[error]\"></ng-content>\n </div>\n <ng-content select=\"[errorAction]\"></ng-content>\n</ng-template>\n" }]
|
|
49
76
|
}] });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic-loading.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/src/lib/loading/basic-loading.component.ts","../../../../../../packages/dbx-web/src/lib/loading/basic-loading.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, input, computed, ChangeDetectionStrategy, viewChild, Signal } from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { ProgressBarMode } from '@angular/material/progress-bar';\nimport { ErrorInput, isDefinedAndNotFalse, type Maybe } from '@dereekb/util';\nimport { checkNgContentWrapperHasContent } from '@dereekb/dbx-core';\nimport { ProgressSpinnerMode } from '@angular/material/progress-spinner';\nimport { DbxErrorComponent } from '../error/error.component';\nimport { type DbxThemeColor } from '../layout/style/style';\nimport { DbxLoadingProgressComponent } from './loading-progress.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { DbxLoadingIsLoadingOrProgress, DbxLoadingProgress } from './loading';\n\n/**\n * DbxBasicLoadingComponent loading state.\n */\nexport type LoadingComponentState = 'none' | 'loading' | 'content' | 'error';\n\n/**\n * Basic loading component.\n */\n@Component({\n  selector: 'dbx-basic-loading',\n  templateUrl: './basic-loading.component.html',\n  imports: [DbxErrorComponent, DbxLoadingProgressComponent, NgTemplateOutlet],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxBasicLoadingComponent {\n  readonly customError = viewChild<string, Maybe<ElementRef>>('customError', { read: ElementRef });\n  readonly customLoading = viewChild<string, Maybe<ElementRef>>('customLoading', { read: ElementRef });\n\n  readonly diameter = input<Maybe<number>>();\n  readonly mode = input<Maybe<ProgressBarMode | ProgressSpinnerMode>>();\n  readonly color = input<ThemePalette | DbxThemeColor>('primary');\n  readonly text = input<Maybe<string>>();\n  readonly linear = input<Maybe<boolean>>(false);\n\n  readonly show = input<Maybe<boolean>>(true);\n  readonly loading = input<Maybe<DbxLoadingIsLoadingOrProgress>>();\n  readonly error = input<Maybe<ErrorInput>>();\n\n  readonly loadingProgressSignal = computed(() => {\n    const loading = this.loading();\n    let result: Maybe<DbxLoadingProgress>;\n\n    if (typeof loading === 'number') {\n      result = loading;\n    }\n\n    return result;\n  });\n\n  readonly modeSignal: Signal<ProgressBarMode | ProgressSpinnerMode> = computed(() => {\n    const mode = this.mode();\n    const loadingProgress = this.loadingProgressSignal();\n\n    let result: ProgressBarMode | ProgressSpinnerMode;\n\n    if (!mode) {\n      if (loadingProgress != null) {\n        result = 'determinate';\n      } else {\n        result = 'indeterminate';\n      }\n    } else {\n      result = mode;\n    }\n\n    return result;\n  });\n\n  readonly isLoadingSignal = computed(() => isDefinedAndNotFalse(this.loading()));\n\n  readonly stateSignal = computed<LoadingComponentState>(() => {\n    const loading = this.isLoadingSignal();\n    const error = this.error();\n    const show = this.show() ?? true; // default to true if not defined\n\n    let state: LoadingComponentState;\n\n    if (error) {\n      state = 'error';\n    } else if (loading == null) {\n      // If loading has not yet been defined and no error has occured, we're waiting for some input on loading or error.\n      state = 'none';\n    } else if (loading || !show) {\n      state = 'loading';\n    } else {\n      state = 'content';\n    }\n\n    return state;\n  });\n\n  readonly hasNoCustomErrorSignal = computed(() => !checkNgContentWrapperHasContent(this.customError()));\n  readonly hasNoCustomLoadingSignal = computed(() => !checkNgContentWrapperHasContent(this.customLoading()));\n}\n","@switch (stateSignal()) {\n  @case ('none') {\n    <!-- Loading -->\n    <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n  }\n  @case ('loading') {\n    <!-- Loading -->\n    <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\n  }\n  @case ('content') {\n    <!-- Content -->\n    <ng-content></ng-content>\n  }\n  @case ('error') {\n    <!-- Error -->\n    <ng-container *ngTemplateOutlet=\"errorTemplate\"></ng-container>\n  }\n}\n\n<ng-template #loadingTemplate>\n  @if (hasNoCustomLoadingSignal()) {\n    <dbx-loading-progress [mode]=\"modeSignal()\" [value]=\"loadingProgressSignal()\" [color]=\"color()\" [text]=\"text()\" [linear]=\"linear()\" [diameter]=\"diameter()\"></dbx-loading-progress>\n  }\n  <div #customLoading>\n    <ng-content select=\"[loading]\"></ng-content>\n  </div>\n</ng-template>\n\n<ng-template #errorTemplate>\n  @if (hasNoCustomErrorSignal()) {\n    <dbx-error [error]=\"error()\"></dbx-error>\n  }\n  <div #customError>\n    <ng-content select=\"[error]\"></ng-content>\n  </div>\n  <ng-content select=\"[errorAction]\"></ng-content>\n</ng-template>\n"]}
|
|
@@ -3,4 +3,5 @@ export * from './loading-progress.component';
|
|
|
3
3
|
export * from './loading.action.directive';
|
|
4
4
|
export * from './loading.component';
|
|
5
5
|
export * from './loading.module';
|
|
6
|
-
|
|
6
|
+
export * from './loading';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbG9hZGluZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Jhc2ljLWxvYWRpbmcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZy1wcm9ncmVzcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2FkaW5nLmFjdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2FkaW5nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xvYWRpbmcubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZyc7XG4iXX0=
|
|
@@ -15,7 +15,7 @@ export class DbxLoadingComponent {
|
|
|
15
15
|
padding = input(false);
|
|
16
16
|
show = input();
|
|
17
17
|
text = input();
|
|
18
|
-
mode = input(
|
|
18
|
+
mode = input();
|
|
19
19
|
color = input('primary');
|
|
20
20
|
diameter = input();
|
|
21
21
|
linear = input();
|
|
@@ -28,8 +28,15 @@ export class DbxLoadingComponent {
|
|
|
28
28
|
stateSignal = computed(() => {
|
|
29
29
|
const loading = this.loading();
|
|
30
30
|
const error = this.error();
|
|
31
|
-
|
|
32
|
-
|
|
31
|
+
const contextStreamEvent = this.contextStreamSignal();
|
|
32
|
+
let loadingState;
|
|
33
|
+
if (contextStreamEvent) {
|
|
34
|
+
loadingState = {
|
|
35
|
+
loading: contextStreamEvent.loading === true ? (contextStreamEvent.loadingProgress ?? true) : false,
|
|
36
|
+
error: contextStreamEvent.error
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
33
40
|
loadingState = {
|
|
34
41
|
loading: loading ?? false,
|
|
35
42
|
error: error
|
|
@@ -84,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
84
91
|
standalone: true
|
|
85
92
|
}]
|
|
86
93
|
}] });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/src/lib/loading/loading.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,WAAW,EAAE,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAGpG,OAAO,EAA+D,+BAA+B,EAAE,kCAAkC,EAAE,MAAM,eAAe,CAAC;AAGjK,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;;AAWrE;;GAEG;AAkBH,MAAM,OAAO,mBAAmB;IACb,sBAAsB,GAAG,MAAM,CAAyC,SAAS,CAAC,CAAC;IAEpG;;OAEG;IACM,OAAO,GAAG,KAAK,CAAiB,KAAK,CAAC,CAAC;IACvC,IAAI,GAAG,KAAK,EAAkB,CAAC;IAC/B,IAAI,GAAG,KAAK,EAAiB,CAAC;IAC9B,IAAI,GAAG,KAAK,EAA0B,CAAC;IACvC,KAAK,GAAG,KAAK,CAA+B,SAAS,CAAC,CAAC;IACvD,QAAQ,GAAG,KAAK,EAAiB,CAAC;IAClC,MAAM,GAAG,KAAK,EAAkB,CAAC;IACjC,OAAO,GAAG,KAAK,EAAwC,CAAC;IACxD,KAAK,GAAG,KAAK,EAAqB,CAAC;IAEnC,OAAO,GAAG,KAAK,EAA0C,CAAC;IAE1D,aAAa,GAAmD,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,sBAAsB,EAAE,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IAEhI,cAAc,GAA2C,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,+BAA+B,EAAE,EAAE,kCAAkC,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACxL,mBAAmB,GAAG,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAEpD,WAAW,GAAG,QAAQ,CAA2B,GAAG,EAAE;QAC7D,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC/B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAC3B,MAAM,kBAAkB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAEtD,IAAI,YAAsC,CAAC;QAE3C,IAAI,kBAAkB,EAAE,CAAC;YACvB,YAAY,GAAG;gBACb,OAAO,EAAE,kBAAkB,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;gBACnG,KAAK,EAAE,kBAAkB,CAAC,KAAK;aAChC,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,YAAY,GAAG;gBACb,OAAO,EAAE,OAAO,IAAI,KAAK;gBACzB,KAAK,EAAE,KAAK;aACb,CAAC;QACJ,CAAC;QAED,OAAO,YAAY,CAAC;IACtB,CAAC,CAAC,CAAC;IAEM,iBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE;QACzC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,EAAE,OAAO,CAAC;QAC5C,OAAO,MAAM,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH;;;;OAIG;IACH,UAAU,CAAC,OAA+C;QACxD,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC3C,CAAC;wGA3DU,mBAAmB;4FAAnB,mBAAmB,wxCAfpB;;;;;;;;;;GAUT,4DACS,wBAAwB;;4FAIvB,mBAAmB;kBAjB/B,SAAS;mBAAC;oBACT,QAAQ,EAAE,aAAa;oBACvB,QAAQ,EAAE;;;;;;;;;;GAUT;oBACD,OAAO,EAAE,CAAC,wBAAwB,CAAC;oBACnC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,UAAU,EAAE,IAAI;iBACjB","sourcesContent":["import { Observable, shareReplay } from 'rxjs';\nimport { Component, ChangeDetectionStrategy, input, computed, signal, Signal } from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { ProgressBarMode } from '@angular/material/progress-bar';\nimport { LoadingContext, LoadingContextEvent, MaybeObservableOrValue, maybeValueFromObservableOrValue, switchMapMaybeLoadingContextStream } from '@dereekb/rxjs';\nimport { ErrorInput, type Maybe } from '@dereekb/util';\nimport { type DbxThemeColor } from '../layout/style/style';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { DbxBasicLoadingComponent } from './basic-loading.component';\nimport { DbxLoadingIsLoadingOrProgress } from './loading';\n\n/**\n * State of a DbxLoadingComponent.\n */\nexport interface DbxLoadingComponentState {\n  readonly loading: DbxLoadingIsLoadingOrProgress;\n  readonly error: Maybe<ErrorInput>;\n}\n\n/**\n * Loading View component that provides content sections for loading, error, and an error action.\n */\n@Component({\n  selector: 'dbx-loading',\n  template: `\n    <dbx-basic-loading [show]=\"show()\" [color]=\"color()\" [text]=\"text()\" [mode]=\"mode()\" [linear]=\"linear()\" [diameter]=\"diameter()\" [error]=\"stateSignal().error\" [loading]=\"stateSignal().loading\">\n      <ng-content loading select=\"[loading]\"></ng-content>\n      @if (showPaddingSignal()) {\n        <div class=\"dbx-loading-linear-done-padding\"></div>\n      }\n      <ng-content></ng-content>\n      <ng-content error select=\"[error]\"></ng-content>\n      <ng-content errorAction select=\"[errorAction]\"></ng-content>\n    </dbx-basic-loading>\n  `,\n  imports: [DbxBasicLoadingComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxLoadingComponent {\n  private readonly _contextOverrideSignal = signal<MaybeObservableOrValue<LoadingContext>>(undefined);\n\n  /**\n   * Whether or not to add padding to the linear presentation when linear is complete. This prevents the linear bar from pushing content around.\n   */\n  readonly padding = input<Maybe<boolean>>(false);\n  readonly show = input<Maybe<boolean>>();\n  readonly text = input<Maybe<string>>();\n  readonly mode = input<Maybe<ProgressBarMode>>();\n  readonly color = input<ThemePalette | DbxThemeColor>('primary');\n  readonly diameter = input<Maybe<number>>();\n  readonly linear = input<Maybe<boolean>>();\n  readonly loading = input<Maybe<DbxLoadingIsLoadingOrProgress>>();\n  readonly error = input<Maybe<ErrorInput>>();\n\n  readonly context = input<MaybeObservableOrValue<LoadingContext>>();\n\n  readonly contextSignal: Signal<MaybeObservableOrValue<LoadingContext>> = computed(() => this._contextOverrideSignal() ?? this.context());\n\n  readonly contextStream$: Observable<Maybe<LoadingContextEvent>> = toObservable(this.contextSignal).pipe(maybeValueFromObservableOrValue(), switchMapMaybeLoadingContextStream(), shareReplay(1));\n  readonly contextStreamSignal = toSignal(this.contextStream$);\n\n  readonly stateSignal = computed<DbxLoadingComponentState>(() => {\n    const loading = this.loading();\n    const error = this.error();\n    const contextStreamEvent = this.contextStreamSignal();\n\n    let loadingState: DbxLoadingComponentState;\n\n    if (contextStreamEvent) {\n      loadingState = {\n        loading: contextStreamEvent.loading === true ? (contextStreamEvent.loadingProgress ?? true) : false,\n        error: contextStreamEvent.error\n      };\n    } else {\n      loadingState = {\n        loading: loading ?? false,\n        error: error\n      };\n    }\n\n    return loadingState;\n  });\n\n  readonly showPaddingSignal = computed(() => {\n    const linear = this.linear();\n    const padding = this.padding();\n    const loading = this.stateSignal()?.loading;\n    return linear && padding && !loading;\n  });\n\n  /**\n   * Sets/overrides the context directly.\n   *\n   * @param context Context source to use as an override.\n   */\n  setContext(context: MaybeObservableOrValue<LoadingContext>) {\n    this._contextOverrideSignal.set(context);\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sb2FkaW5nL2xvYWRpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERieEFjdGlvbldvcmtPcldvcmtQcm9ncmVzcywgRGJ4QWN0aW9uV29ya1Byb2dyZXNzIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuXG5leHBvcnQgdHlwZSBEYnhMb2FkaW5nUHJvZ3Jlc3MgPSBEYnhBY3Rpb25Xb3JrUHJvZ3Jlc3M7XG5cbi8qKlxuICogTG9hZGluZyBwcm9ncmVzcyBmb3IgYSBsb2FkaW5nIGNvbXBvbmVudC5cbiAqXG4gKiBDYW4gYmUgYSBib29sZWFuIG9yIGEgbnVtYmVyLlxuICpcbiAqIFRydWUgaXMgdHJlYXRlZCBhcyBhbiBpbmRldGVybWluYXRlIGxvYWRpbmcgc3RhdGUuXG4gKi9cbmV4cG9ydCB0eXBlIERieExvYWRpbmdJc0xvYWRpbmdPclByb2dyZXNzID0gRGJ4QWN0aW9uV29ya09yV29ya1Byb2dyZXNzO1xuIl19
|