@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.
Files changed (66) hide show
  1. package/esm2022/lib/action/action.confirm.directive.mjs +4 -4
  2. package/esm2022/lib/action/snackbar/action.snackbar.component.mjs +2 -2
  3. package/esm2022/lib/action/transition/transition.safety.dialog.component.mjs +2 -2
  4. package/esm2022/lib/button/button.component.mjs +46 -20
  5. package/esm2022/lib/button/progress/abstract.progress.button.directive.mjs +53 -7
  6. package/esm2022/lib/button/progress/bar.button.component.mjs +3 -3
  7. package/esm2022/lib/button/progress/button.progress.config.mjs +1 -1
  8. package/esm2022/lib/button/progress/spinner.button.component.mjs +3 -3
  9. package/esm2022/lib/extension/download/text/download.text.component.mjs +2 -2
  10. package/esm2022/lib/interaction/filter/filter.wrapper.component.mjs +2 -2
  11. package/esm2022/lib/interaction/index.mjs +2 -1
  12. package/esm2022/lib/interaction/popup/popup.controls.buttons.component.mjs +1 -1
  13. package/esm2022/lib/interaction/upload/abstract.upload.component.mjs +85 -0
  14. package/esm2022/lib/interaction/upload/index.mjs +8 -0
  15. package/esm2022/lib/interaction/upload/upload.accept.mjs +72 -0
  16. package/esm2022/lib/interaction/upload/upload.action.directive.mjs +36 -0
  17. package/esm2022/lib/interaction/upload/upload.action.mjs +18 -0
  18. package/esm2022/lib/interaction/upload/upload.area.component.mjs +138 -0
  19. package/esm2022/lib/interaction/upload/upload.button.component.mjs +81 -0
  20. package/esm2022/lib/interaction/upload/upload.component.mjs +116 -0
  21. package/esm2022/lib/layout/avatar/avatar.component.mjs +76 -0
  22. package/esm2022/lib/layout/avatar/avatar.mjs +7 -0
  23. package/esm2022/lib/layout/avatar/avatar.service.mjs +78 -0
  24. package/esm2022/lib/layout/avatar/avatar.view.component.mjs +89 -0
  25. package/esm2022/lib/layout/avatar/index.mjs +4 -0
  26. package/esm2022/lib/layout/content/content.pit.directive.mjs +34 -4
  27. package/esm2022/lib/layout/index.mjs +2 -1
  28. package/esm2022/lib/loading/basic-loading.component.mjs +32 -5
  29. package/esm2022/lib/loading/index.mjs +2 -1
  30. package/esm2022/lib/loading/loading.component.mjs +11 -4
  31. package/esm2022/lib/loading/loading.mjs +2 -0
  32. package/fesm2022/dereekb-dbx-web.mjs +930 -47
  33. package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
  34. package/lib/action/action.confirm.directive.d.ts +1 -1
  35. package/lib/button/_button.scss +2 -1
  36. package/lib/button/button.component.d.ts +5 -1
  37. package/lib/button/progress/abstract.progress.button.directive.d.ts +9 -5
  38. package/lib/button/progress/button.progress.config.d.ts +6 -2
  39. package/lib/interaction/_interaction.scss +4 -0
  40. package/lib/interaction/index.d.ts +1 -0
  41. package/lib/interaction/upload/_upload.scss +100 -0
  42. package/lib/interaction/upload/abstract.upload.component.d.ts +54 -0
  43. package/lib/interaction/upload/index.d.ts +7 -0
  44. package/lib/interaction/upload/upload.accept.d.ts +87 -0
  45. package/lib/interaction/upload/upload.action.d.ts +17 -0
  46. package/lib/interaction/upload/upload.action.directive.d.ts +17 -0
  47. package/lib/interaction/upload/upload.area.component.d.ts +22 -0
  48. package/lib/interaction/upload/upload.button.component.d.ts +24 -0
  49. package/lib/interaction/upload/upload.component.d.ts +58 -0
  50. package/lib/layout/_layout.scss +4 -0
  51. package/lib/layout/avatar/_avatar.scss +102 -0
  52. package/lib/layout/avatar/avatar.component.d.ts +32 -0
  53. package/lib/layout/avatar/avatar.d.ts +54 -0
  54. package/lib/layout/avatar/avatar.service.d.ts +66 -0
  55. package/lib/layout/avatar/avatar.view.component.d.ts +24 -0
  56. package/lib/layout/avatar/index.d.ts +3 -0
  57. package/lib/layout/content/content.pit.directive.d.ts +6 -2
  58. package/lib/layout/index.d.ts +1 -0
  59. package/lib/loading/basic-loading.component.d.ts +13 -8
  60. package/lib/loading/index.d.ts +1 -0
  61. package/lib/loading/loading.component.d.ts +4 -3
  62. package/lib/loading/loading.d.ts +10 -0
  63. package/lib/style/_config.scss +17 -1
  64. package/lib/style/_root-variables.scss +4 -0
  65. package/lib/style/_variables.scss +8 -0
  66. 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": "scrollable()" }, classAttribute: "d-block dbx-content-pit" }, ngImport: i0 });
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]': '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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5waXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9jb250ZW50L2NvbnRlbnQucGl0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHakQ7O0dBRUc7QUFTSCxNQUFNLE9BQU8sc0JBQXNCO0lBQ3hCLFVBQVUsR0FBRyxLQUFLLEVBQWtCLENBQUM7d0dBRG5DLHNCQUFzQjs0RkFBdEIsc0JBQXNCOzs0RkFBdEIsc0JBQXNCO2tCQVJsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQ0FBa0M7b0JBQzVDLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUseUJBQXlCO3dCQUNoQyxvQ0FBb0MsRUFBRSxjQUFjO3FCQUNyRDtvQkFDRCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbi8qKlxuICogQ29tcG9uZW50IHVzZWQgdG8gd3JhcCBjb250ZW50IGluIGEgcGl0IHdpdGggYSBsYWJlbC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnZGJ4LWNvbnRlbnQtcGl0LCBbZGJ4Q29udGVudFBpdF0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdkLWJsb2NrIGRieC1jb250ZW50LXBpdCcsXG4gICAgJ1tjbGFzcy5kYngtY29udGVudC1waXQtc2Nyb2xsYWJsZV0nOiAnc2Nyb2xsYWJsZSgpJ1xuICB9LFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieENvbnRlbnRQaXREaXJlY3RpdmUge1xuICByZWFkb25seSBzY3JvbGxhYmxlID0gaW5wdXQ8TWF5YmU8Ym9vbGVhbj4+KCk7XG59XG4iXX0=
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Jhcic7XG5leHBvcnQgKiBmcm9tICcuL2Jsb2NrJztcbmV4cG9ydCAqIGZyb20gJy4vY2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbHVtbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBhY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmxhZyc7XG5leHBvcnQgKiBmcm9tICcuL2ZsZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9pdGVtJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdCc7XG5leHBvcnQgKiBmcm9tICcuL3NlY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9zdGVwJztcbmV4cG9ydCAqIGZyb20gJy4vc3R5bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vbGF5b3V0Lm1vZHVsZSc7XG4iXX0=
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('indeterminate');
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
- stateSignal = computed(() => {
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]=\"mode()\" [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 });
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]=\"mode()\" [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" }]
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzaWMtbG9hZGluZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbG9hZGluZy9iYXNpYy1sb2FkaW5nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sb2FkaW5nL2Jhc2ljLWxvYWRpbmcuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJM0csT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFN0QsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBT25EOztHQUVHO0FBUUgsTUFBTSxPQUFPLHdCQUF3QjtJQUMxQixXQUFXLEdBQUcsU0FBUyxDQUE0QixhQUFhLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUN4RixhQUFhLEdBQUcsU0FBUyxDQUE0QixlQUFlLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUU1RixRQUFRLEdBQUcsS0FBSyxFQUFpQixDQUFDO0lBQ2xDLElBQUksR0FBRyxLQUFLLENBQXdDLGVBQWUsQ0FBQyxDQUFDO0lBQ3JFLEtBQUssR0FBRyxLQUFLLENBQStCLFNBQVMsQ0FBQyxDQUFDO0lBQ3ZELElBQUksR0FBRyxLQUFLLEVBQWlCLENBQUM7SUFDOUIsTUFBTSxHQUFHLEtBQUssQ0FBaUIsS0FBSyxDQUFDLENBQUM7SUFFdEMsSUFBSSxHQUFHLEtBQUssQ0FBaUIsSUFBSSxDQUFDLENBQUM7SUFDbkMsT0FBTyxHQUFHLEtBQUssRUFBa0IsQ0FBQztJQUNsQyxLQUFLLEdBQUcsS0FBSyxFQUFxQixDQUFDO0lBRW5DLFdBQVcsR0FBRyxRQUFRLENBQXdCLEdBQUcsRUFBRTtRQUMxRCxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDL0IsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzNCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsQ0FBQyxpQ0FBaUM7UUFFbkUsSUFBSSxLQUE0QixDQUFDO1FBRWpDLElBQUksS0FBSyxFQUFFLENBQUM7WUFDVixLQUFLLEdBQUcsT0FBTyxDQUFDO1FBQ2xCLENBQUM7YUFBTSxJQUFJLE9BQU8sSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUMzQixrSEFBa0g7WUFDbEgsS0FBSyxHQUFHLE1BQU0sQ0FBQztRQUNqQixDQUFDO2FBQU0sSUFBSSxPQUFPLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUM1QixLQUFLLEdBQUcsU0FBUyxDQUFDO1FBQ3BCLENBQUM7YUFBTSxDQUFDO1lBQ04sS0FBSyxHQUFHLFNBQVMsQ0FBQztRQUNwQixDQUFDO1FBRUQsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDLENBQUMsQ0FBQztJQUVNLHNCQUFzQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLCtCQUErQixDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDOUYsd0JBQXdCLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsK0JBQStCLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUMsQ0FBQzt3R0FwQ2hHLHdCQUF3Qjs0RkFBeEIsd0JBQXdCLHluQ0FDZ0QsVUFBVSx5SEFDTixVQUFVLDZDQzVCbkcseWpDQXFDQSw0Q0RmWSxpQkFBaUIsaUhBQUUsMkJBQTJCLGtKQUFFLGdCQUFnQjs7NEZBSS9ELHdCQUF3QjtrQkFQcEMsU0FBUzsrQkFDRSxtQkFBbUIsV0FFcEIsQ0FBQyxpQkFBaUIsRUFBRSwyQkFBMkIsRUFBRSxnQkFBZ0IsQ0FBQyxtQkFDMUQsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBpbnB1dCwgY29tcHV0ZWQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCB2aWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoZW1lUGFsZXR0ZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgUHJvZ3Jlc3NCYXJNb2RlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3MtYmFyJztcbmltcG9ydCB7IEVycm9ySW5wdXQsIHR5cGUgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IGNoZWNrTmdDb250ZW50V3JhcHBlckhhc0NvbnRlbnQgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBQcm9ncmVzc1NwaW5uZXJNb2RlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3Mtc3Bpbm5lcic7XG5pbXBvcnQgeyBEYnhFcnJvckNvbXBvbmVudCB9IGZyb20gJy4uL2Vycm9yL2Vycm9yLmNvbXBvbmVudCc7XG5pbXBvcnQgeyB0eXBlIERieFRoZW1lQ29sb3IgfSBmcm9tICcuLi9sYXlvdXQvc3R5bGUvc3R5bGUnO1xuaW1wb3J0IHsgRGJ4TG9hZGluZ1Byb2dyZXNzQ29tcG9uZW50IH0gZnJvbSAnLi9sb2FkaW5nLXByb2dyZXNzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOZ1RlbXBsYXRlT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuLyoqXG4gKiBEYnhCYXNpY0xvYWRpbmdDb21wb25lbnQgbG9hZGluZyBzdGF0ZS5cbiAqL1xuZXhwb3J0IHR5cGUgTG9hZGluZ0NvbXBvbmVudFN0YXRlID0gJ25vbmUnIHwgJ2xvYWRpbmcnIHwgJ2NvbnRlbnQnIHwgJ2Vycm9yJztcblxuLyoqXG4gKiBCYXNpYyBsb2FkaW5nIGNvbXBvbmVudC5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWJhc2ljLWxvYWRpbmcnLFxuICB0ZW1wbGF0ZVVybDogJy4vYmFzaWMtbG9hZGluZy5jb21wb25lbnQuaHRtbCcsXG4gIGltcG9ydHM6IFtEYnhFcnJvckNvbXBvbmVudCwgRGJ4TG9hZGluZ1Byb2dyZXNzQ29tcG9uZW50LCBOZ1RlbXBsYXRlT3V0bGV0XSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4QmFzaWNMb2FkaW5nQ29tcG9uZW50IHtcbiAgcmVhZG9ubHkgY3VzdG9tRXJyb3IgPSB2aWV3Q2hpbGQ8c3RyaW5nLCBNYXliZTxFbGVtZW50UmVmPj4oJ2N1c3RvbUVycm9yJywgeyByZWFkOiBFbGVtZW50UmVmIH0pO1xuICByZWFkb25seSBjdXN0b21Mb2FkaW5nID0gdmlld0NoaWxkPHN0cmluZywgTWF5YmU8RWxlbWVudFJlZj4+KCdjdXN0b21Mb2FkaW5nJywgeyByZWFkOiBFbGVtZW50UmVmIH0pO1xuXG4gIHJlYWRvbmx5IGRpYW1ldGVyID0gaW5wdXQ8TWF5YmU8bnVtYmVyPj4oKTtcbiAgcmVhZG9ubHkgbW9kZSA9IGlucHV0PFByb2dyZXNzQmFyTW9kZSB8IFByb2dyZXNzU3Bpbm5lck1vZGU+KCdpbmRldGVybWluYXRlJyk7XG4gIHJlYWRvbmx5IGNvbG9yID0gaW5wdXQ8VGhlbWVQYWxldHRlIHwgRGJ4VGhlbWVDb2xvcj4oJ3ByaW1hcnknKTtcbiAgcmVhZG9ubHkgdGV4dCA9IGlucHV0PE1heWJlPHN0cmluZz4+KCk7XG4gIHJlYWRvbmx5IGxpbmVhciA9IGlucHV0PE1heWJlPGJvb2xlYW4+PihmYWxzZSk7XG5cbiAgcmVhZG9ubHkgc2hvdyA9IGlucHV0PE1heWJlPGJvb2xlYW4+Pih0cnVlKTtcbiAgcmVhZG9ubHkgbG9hZGluZyA9IGlucHV0PE1heWJlPGJvb2xlYW4+PigpO1xuICByZWFkb25seSBlcnJvciA9IGlucHV0PE1heWJlPEVycm9ySW5wdXQ+PigpO1xuXG4gIHJlYWRvbmx5IHN0YXRlU2lnbmFsID0gY29tcHV0ZWQ8TG9hZGluZ0NvbXBvbmVudFN0YXRlPigoKSA9PiB7XG4gICAgY29uc3QgbG9hZGluZyA9IHRoaXMubG9hZGluZygpO1xuICAgIGNvbnN0IGVycm9yID0gdGhpcy5lcnJvcigpO1xuICAgIGNvbnN0IHNob3cgPSB0aGlzLnNob3coKSA/PyB0cnVlOyAvLyBkZWZhdWx0IHRvIHRydWUgaWYgbm90IGRlZmluZWRcblxuICAgIGxldCBzdGF0ZTogTG9hZGluZ0NvbXBvbmVudFN0YXRlO1xuXG4gICAgaWYgKGVycm9yKSB7XG4gICAgICBzdGF0ZSA9ICdlcnJvcic7XG4gICAgfSBlbHNlIGlmIChsb2FkaW5nID09IG51bGwpIHtcbiAgICAgIC8vIElmIGxvYWRpbmcgaGFzIG5vdCB5ZXQgYmVlbiBkZWZpbmVkIGFuZCBubyBlcnJvciBoYXMgb2NjdXJlZCwgd2UncmUgd2FpdGluZyBmb3Igc29tZSBpbnB1dCBvbiBsb2FkaW5nIG9yIGVycm9yLlxuICAgICAgc3RhdGUgPSAnbm9uZSc7XG4gICAgfSBlbHNlIGlmIChsb2FkaW5nIHx8ICFzaG93KSB7XG4gICAgICBzdGF0ZSA9ICdsb2FkaW5nJztcbiAgICB9IGVsc2Uge1xuICAgICAgc3RhdGUgPSAnY29udGVudCc7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlO1xuICB9KTtcblxuICByZWFkb25seSBoYXNOb0N1c3RvbUVycm9yU2lnbmFsID0gY29tcHV0ZWQoKCkgPT4gIWNoZWNrTmdDb250ZW50V3JhcHBlckhhc0NvbnRlbnQodGhpcy5jdXN0b21FcnJvcigpKSk7XG4gIHJlYWRvbmx5IGhhc05vQ3VzdG9tTG9hZGluZ1NpZ25hbCA9IGNvbXB1dGVkKCgpID0+ICFjaGVja05nQ29udGVudFdyYXBwZXJIYXNDb250ZW50KHRoaXMuY3VzdG9tTG9hZGluZygpKSk7XG59XG4iLCJAc3dpdGNoIChzdGF0ZVNpZ25hbCgpKSB7XG4gIEBjYXNlICgnbm9uZScpIHtcbiAgICA8IS0tIExvYWRpbmcgLS0+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImxvYWRpbmdUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxuICB9XG4gIEBjYXNlICgnbG9hZGluZycpIHtcbiAgICA8IS0tIExvYWRpbmcgLS0+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImxvYWRpbmdUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxuICB9XG4gIEBjYXNlICgnY29udGVudCcpIHtcbiAgICA8IS0tIENvbnRlbnQgLS0+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICB9XG4gIEBjYXNlICgnZXJyb3InKSB7XG4gICAgPCEtLSBFcnJvciAtLT5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiZXJyb3JUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxuICB9XG59XG5cbjxuZy10ZW1wbGF0ZSAjbG9hZGluZ1RlbXBsYXRlPlxuICBAaWYgKGhhc05vQ3VzdG9tTG9hZGluZ1NpZ25hbCgpKSB7XG4gICAgPGRieC1sb2FkaW5nLXByb2dyZXNzIFttb2RlXT1cIm1vZGUoKVwiIFtjb2xvcl09XCJjb2xvcigpXCIgW3RleHRdPVwidGV4dCgpXCIgW2xpbmVhcl09XCJsaW5lYXIoKVwiIFtkaWFtZXRlcl09XCJkaWFtZXRlcigpXCI+PC9kYngtbG9hZGluZy1wcm9ncmVzcz5cbiAgfVxuICA8ZGl2ICNjdXN0b21Mb2FkaW5nPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltsb2FkaW5nXVwiPjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuXG48bmctdGVtcGxhdGUgI2Vycm9yVGVtcGxhdGU+XG4gIEBpZiAoaGFzTm9DdXN0b21FcnJvclNpZ25hbCgpKSB7XG4gICAgPGRieC1lcnJvciBbZXJyb3JdPVwiZXJyb3IoKVwiPjwvZGJ4LWVycm9yPlxuICB9XG4gIDxkaXYgI2N1c3RvbUVycm9yPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltlcnJvcl1cIj48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuICA8bmctY29udGVudCBzZWxlY3Q9XCJbZXJyb3JBY3Rpb25dXCI+PC9uZy1jb250ZW50PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbG9hZGluZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Jhc2ljLWxvYWRpbmcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZy1wcm9ncmVzcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2FkaW5nLmFjdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2FkaW5nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xvYWRpbmcubW9kdWxlJztcbiJdfQ==
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('indeterminate');
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
- let loadingState = this.contextStreamSignal();
32
- if (loadingState == null) {
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbG9hZGluZy9sb2FkaW5nLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsV0FBVyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFHcEcsT0FBTyxFQUErRCwrQkFBK0IsRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdqSyxPQUFPLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQVVyRTs7R0FFRztBQWtCSCxNQUFNLE9BQU8sbUJBQW1CO0lBQ2Isc0JBQXNCLEdBQUcsTUFBTSxDQUF5QyxTQUFTLENBQUMsQ0FBQztJQUVwRzs7T0FFRztJQUNNLE9BQU8sR0FBRyxLQUFLLENBQWlCLEtBQUssQ0FBQyxDQUFDO0lBQ3ZDLElBQUksR0FBRyxLQUFLLEVBQWtCLENBQUM7SUFDL0IsSUFBSSxHQUFHLEtBQUssRUFBaUIsQ0FBQztJQUM5QixJQUFJLEdBQUcsS0FBSyxDQUFrQixlQUFlLENBQUMsQ0FBQztJQUMvQyxLQUFLLEdBQUcsS0FBSyxDQUErQixTQUFTLENBQUMsQ0FBQztJQUN2RCxRQUFRLEdBQUcsS0FBSyxFQUFpQixDQUFDO0lBQ2xDLE1BQU0sR0FBRyxLQUFLLEVBQWtCLENBQUM7SUFDakMsT0FBTyxHQUFHLEtBQUssRUFBa0IsQ0FBQztJQUNsQyxLQUFLLEdBQUcsS0FBSyxFQUFxQixDQUFDO0lBRW5DLE9BQU8sR0FBRyxLQUFLLEVBQTBDLENBQUM7SUFFMUQsYUFBYSxHQUFtRCxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLHNCQUFzQixFQUFFLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFFaEksY0FBYyxHQUEyQyxZQUFZLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQywrQkFBK0IsRUFBRSxFQUFFLGtDQUFrQyxFQUFFLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDeEwsbUJBQW1CLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUVwRCxXQUFXLEdBQUcsUUFBUSxDQUEyQixHQUFHLEVBQUU7UUFDN0QsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQy9CLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUMzQixJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsbUJBQW1CLEVBQThCLENBQUM7UUFFMUUsSUFBSSxZQUFZLElBQUksSUFBSSxFQUFFLENBQUM7WUFDekIsWUFBWSxHQUFHO2dCQUNiLE9BQU8sRUFBRSxPQUFPLElBQUksS0FBSztnQkFDekIsS0FBSyxFQUFFLEtBQUs7YUFDYixDQUFDO1FBQ0osQ0FBQztRQUVELE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUMsQ0FBQyxDQUFDO0lBRU0saUJBQWlCLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUN6QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDN0IsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQy9CLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRSxPQUFPLENBQUM7UUFDNUMsT0FBTyxNQUFNLElBQUksT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3ZDLENBQUMsQ0FBQyxDQUFDO0lBRUg7Ozs7T0FJRztJQUNILFVBQVUsQ0FBQyxPQUErQztRQUN4RCxJQUFJLENBQUMsc0JBQXNCLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzNDLENBQUM7d0dBcERVLG1CQUFtQjs0RkFBbkIsbUJBQW1CLHd4Q0FmcEI7Ozs7Ozs7Ozs7R0FVVCw0REFDUyx3QkFBd0I7OzRGQUl2QixtQkFBbUI7a0JBakIvQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxhQUFhO29CQUN2QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7R0FVVDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQztvQkFDbkMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIHNoYXJlUmVwbGF5IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBpbnB1dCwgY29tcHV0ZWQsIHNpZ25hbCwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVtZVBhbGV0dGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IFByb2dyZXNzQmFyTW9kZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLWJhcic7XG5pbXBvcnQgeyBMb2FkaW5nQ29udGV4dCwgTG9hZGluZ0NvbnRleHRFdmVudCwgTWF5YmVPYnNlcnZhYmxlT3JWYWx1ZSwgbWF5YmVWYWx1ZUZyb21PYnNlcnZhYmxlT3JWYWx1ZSwgc3dpdGNoTWFwTWF5YmVMb2FkaW5nQ29udGV4dFN0cmVhbSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgRXJyb3JJbnB1dCwgdHlwZSBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgdHlwZSBEYnhUaGVtZUNvbG9yIH0gZnJvbSAnLi4vbGF5b3V0L3N0eWxlL3N0eWxlJztcbmltcG9ydCB7IHRvT2JzZXJ2YWJsZSwgdG9TaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBEYnhCYXNpY0xvYWRpbmdDb21wb25lbnQgfSBmcm9tICcuL2Jhc2ljLWxvYWRpbmcuY29tcG9uZW50JztcblxuLyoqXG4gKiBTdGF0ZSBvZiBhIERieExvYWRpbmdDb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4TG9hZGluZ0NvbXBvbmVudFN0YXRlIHtcbiAgcmVhZG9ubHkgbG9hZGluZzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgZXJyb3I6IE1heWJlPEVycm9ySW5wdXQ+O1xufVxuXG4vKipcbiAqIExvYWRpbmcgVmlldyBjb21wb25lbnQgdGhhdCBwcm92aWRlcyBjb250ZW50IHNlY3Rpb25zIGZvciBsb2FkaW5nLCBlcnJvciwgYW5kIGFuIGVycm9yIGFjdGlvbi5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LWxvYWRpbmcnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkYngtYmFzaWMtbG9hZGluZyBbc2hvd109XCJzaG93KClcIiBbY29sb3JdPVwiY29sb3IoKVwiIFt0ZXh0XT1cInRleHQoKVwiIFttb2RlXT1cIm1vZGUoKVwiIFtsaW5lYXJdPVwibGluZWFyKClcIiBbZGlhbWV0ZXJdPVwiZGlhbWV0ZXIoKVwiIFtlcnJvcl09XCJzdGF0ZVNpZ25hbCgpLmVycm9yXCIgW2xvYWRpbmddPVwic3RhdGVTaWduYWwoKS5sb2FkaW5nXCI+XG4gICAgICA8bmctY29udGVudCBsb2FkaW5nIHNlbGVjdD1cIltsb2FkaW5nXVwiPjwvbmctY29udGVudD5cbiAgICAgIEBpZiAoc2hvd1BhZGRpbmdTaWduYWwoKSkge1xuICAgICAgICA8ZGl2IGNsYXNzPVwiZGJ4LWxvYWRpbmctbGluZWFyLWRvbmUtcGFkZGluZ1wiPjwvZGl2PlxuICAgICAgfVxuICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgICAgPG5nLWNvbnRlbnQgZXJyb3Igc2VsZWN0PVwiW2Vycm9yXVwiPjwvbmctY29udGVudD5cbiAgICAgIDxuZy1jb250ZW50IGVycm9yQWN0aW9uIHNlbGVjdD1cIltlcnJvckFjdGlvbl1cIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kYngtYmFzaWMtbG9hZGluZz5cbiAgYCxcbiAgaW1wb3J0czogW0RieEJhc2ljTG9hZGluZ0NvbXBvbmVudF0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieExvYWRpbmdDb21wb25lbnQge1xuICBwcml2YXRlIHJlYWRvbmx5IF9jb250ZXh0T3ZlcnJpZGVTaWduYWwgPSBzaWduYWw8TWF5YmVPYnNlcnZhYmxlT3JWYWx1ZTxMb2FkaW5nQ29udGV4dD4+KHVuZGVmaW5lZCk7XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgb3Igbm90IHRvIGFkZCBwYWRkaW5nIHRvIHRoZSBsaW5lYXIgcHJlc2VudGF0aW9uIHdoZW4gbGluZWFyIGlzIGNvbXBsZXRlLiBUaGlzIHByZXZlbnRzIHRoZSBsaW5lYXIgYmFyIGZyb20gcHVzaGluZyBjb250ZW50IGFyb3VuZC5cbiAgICovXG4gIHJlYWRvbmx5IHBhZGRpbmcgPSBpbnB1dDxNYXliZTxib29sZWFuPj4oZmFsc2UpO1xuICByZWFkb25seSBzaG93ID0gaW5wdXQ8TWF5YmU8Ym9vbGVhbj4+KCk7XG4gIHJlYWRvbmx5IHRleHQgPSBpbnB1dDxNYXliZTxzdHJpbmc+PigpO1xuICByZWFkb25seSBtb2RlID0gaW5wdXQ8UHJvZ3Jlc3NCYXJNb2RlPignaW5kZXRlcm1pbmF0ZScpO1xuICByZWFkb25seSBjb2xvciA9IGlucHV0PFRoZW1lUGFsZXR0ZSB8IERieFRoZW1lQ29sb3I+KCdwcmltYXJ5Jyk7XG4gIHJlYWRvbmx5IGRpYW1ldGVyID0gaW5wdXQ8TWF5YmU8bnVtYmVyPj4oKTtcbiAgcmVhZG9ubHkgbGluZWFyID0gaW5wdXQ8TWF5YmU8Ym9vbGVhbj4+KCk7XG4gIHJlYWRvbmx5IGxvYWRpbmcgPSBpbnB1dDxNYXliZTxib29sZWFuPj4oKTtcbiAgcmVhZG9ubHkgZXJyb3IgPSBpbnB1dDxNYXliZTxFcnJvcklucHV0Pj4oKTtcblxuICByZWFkb25seSBjb250ZXh0ID0gaW5wdXQ8TWF5YmVPYnNlcnZhYmxlT3JWYWx1ZTxMb2FkaW5nQ29udGV4dD4+KCk7XG5cbiAgcmVhZG9ubHkgY29udGV4dFNpZ25hbDogU2lnbmFsPE1heWJlT2JzZXJ2YWJsZU9yVmFsdWU8TG9hZGluZ0NvbnRleHQ+PiA9IGNvbXB1dGVkKCgpID0+IHRoaXMuX2NvbnRleHRPdmVycmlkZVNpZ25hbCgpID8/IHRoaXMuY29udGV4dCgpKTtcblxuICByZWFkb25seSBjb250ZXh0U3RyZWFtJDogT2JzZXJ2YWJsZTxNYXliZTxMb2FkaW5nQ29udGV4dEV2ZW50Pj4gPSB0b09ic2VydmFibGUodGhpcy5jb250ZXh0U2lnbmFsKS5waXBlKG1heWJlVmFsdWVGcm9tT2JzZXJ2YWJsZU9yVmFsdWUoKSwgc3dpdGNoTWFwTWF5YmVMb2FkaW5nQ29udGV4dFN0cmVhbSgpLCBzaGFyZVJlcGxheSgxKSk7XG4gIHJlYWRvbmx5IGNvbnRleHRTdHJlYW1TaWduYWwgPSB0b1NpZ25hbCh0aGlzLmNvbnRleHRTdHJlYW0kKTtcblxuICByZWFkb25seSBzdGF0ZVNpZ25hbCA9IGNvbXB1dGVkPERieExvYWRpbmdDb21wb25lbnRTdGF0ZT4oKCkgPT4ge1xuICAgIGNvbnN0IGxvYWRpbmcgPSB0aGlzLmxvYWRpbmcoKTtcbiAgICBjb25zdCBlcnJvciA9IHRoaXMuZXJyb3IoKTtcbiAgICBsZXQgbG9hZGluZ1N0YXRlID0gdGhpcy5jb250ZXh0U3RyZWFtU2lnbmFsKCkgYXMgRGJ4TG9hZGluZ0NvbXBvbmVudFN0YXRlO1xuXG4gICAgaWYgKGxvYWRpbmdTdGF0ZSA9PSBudWxsKSB7XG4gICAgICBsb2FkaW5nU3RhdGUgPSB7XG4gICAgICAgIGxvYWRpbmc6IGxvYWRpbmcgPz8gZmFsc2UsXG4gICAgICAgIGVycm9yOiBlcnJvclxuICAgICAgfTtcbiAgICB9XG5cbiAgICByZXR1cm4gbG9hZGluZ1N0YXRlO1xuICB9KTtcblxuICByZWFkb25seSBzaG93UGFkZGluZ1NpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBsaW5lYXIgPSB0aGlzLmxpbmVhcigpO1xuICAgIGNvbnN0IHBhZGRpbmcgPSB0aGlzLnBhZGRpbmcoKTtcbiAgICBjb25zdCBsb2FkaW5nID0gdGhpcy5zdGF0ZVNpZ25hbCgpPy5sb2FkaW5nO1xuICAgIHJldHVybiBsaW5lYXIgJiYgcGFkZGluZyAmJiAhbG9hZGluZztcbiAgfSk7XG5cbiAgLyoqXG4gICAqIFNldHMvb3ZlcnJpZGVzIHRoZSBjb250ZXh0IGRpcmVjdGx5LlxuICAgKlxuICAgKiBAcGFyYW0gY29udGV4dCBDb250ZXh0IHNvdXJjZSB0byB1c2UgYXMgYW4gb3ZlcnJpZGUuXG4gICAqL1xuICBzZXRDb250ZXh0KGNvbnRleHQ6IE1heWJlT2JzZXJ2YWJsZU9yVmFsdWU8TG9hZGluZ0NvbnRleHQ+KSB7XG4gICAgdGhpcy5fY29udGV4dE92ZXJyaWRlU2lnbmFsLnNldChjb250ZXh0KTtcbiAgfVxufVxuIl19
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":"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","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