@dereekb/dbx-web 12.3.2 → 12.3.4
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 -1
- 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 +15 -9
- 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/popup/popup.controls.buttons.component.mjs +1 -1
- package/esm2022/lib/interaction/prompt/prompt.confirm.dialog.component.mjs +2 -2
- package/esm2022/lib/interaction/prompt/prompt.confirm.directive.mjs +9 -10
- package/esm2022/lib/layout/text/detail.block.component.mjs +6 -5
- package/esm2022/lib/layout/text/detail.block.header.component.mjs +29 -7
- package/esm2022/lib/layout/text/index.mjs +2 -1
- package/esm2022/lib/layout/text/number.limit.component.mjs +82 -0
- package/esm2022/lib/layout/text/text.module.mjs +4 -3
- package/fesm2022/dereekb-dbx-web.mjs +144 -35
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/action/action.confirm.directive.d.ts +1 -0
- package/lib/button/_button.scss +12 -0
- package/lib/button/button.component.d.ts +17 -2
- package/lib/interaction/dialog/_dialog.scss +29 -0
- package/lib/interaction/prompt/prompt.confirm.directive.d.ts +3 -5
- package/lib/layout/text/_text.scss +23 -1
- package/lib/layout/text/detail.block.component.d.ts +2 -1
- package/lib/layout/text/detail.block.header.component.d.ts +2 -1
- package/lib/layout/text/index.d.ts +1 -0
- package/lib/layout/text/number.limit.component.d.ts +40 -0
- package/lib/layout/text/text.module.d.ts +9 -8
- package/package.json +1 -1
|
@@ -21,6 +21,9 @@ export class DbxActionConfirmDirective extends AbstractPromptConfirmDirective {
|
|
|
21
21
|
ngOnDestroy() {
|
|
22
22
|
this._sourceSubscription.destroy();
|
|
23
23
|
}
|
|
24
|
+
getDefaultDialogConfig() {
|
|
25
|
+
return this.dbxActionConfirm();
|
|
26
|
+
}
|
|
24
27
|
_handleDialogResult(result) {
|
|
25
28
|
if (result) {
|
|
26
29
|
this.source.readyValue(this.dbxActionConfirm()?.readyValue);
|
|
@@ -40,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
40
43
|
standalone: true
|
|
41
44
|
}]
|
|
42
45
|
}] });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmNvbmZpcm0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2FjdGlvbi9hY3Rpb24uY29uZmlybS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBcUIsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RSxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUVoRyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLG9DQUFvQyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBYTlHOzs7OztHQUtHO0FBS0gsTUFBTSxPQUFPLHlCQUFvRCxTQUFRLDhCQUE4QjtJQUM1RixNQUFNLEdBQUcsTUFBTSxDQUFDLENBQUEsbUNBQXlDLENBQUEsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBRTNFLGdCQUFnQixHQUFHLEtBQUssQ0FBMEUsU0FBUyxFQUFFLEVBQUUsU0FBUyxFQUFFLG9DQUFvQyxFQUFFLENBQUMsQ0FBQztJQUUxSixtQkFBbUIsR0FBRyxJQUFJLGtCQUFrQixFQUFFLENBQUM7SUFFaEUsUUFBUTtRQUNOLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUM1RSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDcEIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNyQyxDQUFDO0lBRVMsc0JBQXNCO1FBQzlCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVrQixtQkFBbUIsQ0FBQyxNQUFlO1FBQ3BELElBQUksTUFBTSxFQUFFLENBQUM7WUFDWCxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxVQUEwQixDQUFDLENBQUM7UUFDOUUsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNoQyxDQUFDO1FBRUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQzt3R0E3QlUseUJBQXlCOzRGQUF6Qix5QkFBeUI7OzRGQUF6Qix5QkFBeUI7a0JBSnJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBPbkRlc3Ryb3ksIE9uSW5pdCwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RQcm9tcHRDb25maXJtRGlyZWN0aXZlIH0gZnJvbSAnLi4vaW50ZXJhY3Rpb24vcHJvbXB0L3Byb21wdC5jb25maXJtLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYnhQcm9tcHRDb25maXJtQ29uZmlnIH0gZnJvbSAnLi4vaW50ZXJhY3Rpb24vcHJvbXB0L3Byb21wdC5jb25maXJtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTdWJzY3JpcHRpb25PYmplY3QgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IERieEFjdGlvbkNvbnRleHRTdG9yZVNvdXJjZUluc3RhbmNlLCB0cmFuc2Zvcm1FbXB0eVN0cmluZ0lucHV0VG9VbmRlZmluZWQgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG4vKipcbiAqIERieEFjdGlvbkNvbmZpcm1EaXJlY3RpdmUgY29uZmlndXJhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEYnhBY3Rpb25Db25maXJtQ29uZmlnPFQgPSB1bmtub3duPiBleHRlbmRzIERieFByb21wdENvbmZpcm1Db25maWcge1xuICAvKipcbiAgICogT3B0aW9uYWxseSBzZXQgdGhlIHJlYWR5VmFsdWUgcGFzc2VkIHRvIHRoZSBpbnN0YW5jZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlYWR5VmFsdWU/OiBUO1xufVxuXG4vKipcbiAqIERpcmVjdGl2ZSB0aGF0IHdoZW4gdHJpZ2dlcmVkIHNob3dzIGEgZGlhbG9nIHRvIGFjY2VwdCBvciByZWplY3QuXG4gKlxuICogVGhpcyBvbmx5IHdvcmtzIHRvIHBhc3MgYSByZWFkeSB2YWx1ZSBvciByZWplY3QgdGhyb3VnaCwgbm90IHRvIHdvcmsgd2l0aCBhIGJ1dHRvbi5cbiAqIEZvciBidXR0b24gdXNhZ2UsIHVzZSBhbiBhcHBQcm9tcHRDb25maXJtQnV0dG9uIGRpcmVjdGl2ZS5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2RieEFjdGlvbkNvbmZpcm1dJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhBY3Rpb25Db25maXJtRGlyZWN0aXZlPFQgPSB1bmtub3duLCBPID0gdW5rbm93bj4gZXh0ZW5kcyBBYnN0cmFjdFByb21wdENvbmZpcm1EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHJlYWRvbmx5IHNvdXJjZSA9IGluamVjdChEYnhBY3Rpb25Db250ZXh0U3RvcmVTb3VyY2VJbnN0YW5jZTxULCBPPiwgeyBob3N0OiB0cnVlIH0pO1xuXG4gIHJlYWRvbmx5IGRieEFjdGlvbkNvbmZpcm0gPSBpbnB1dDxNYXliZTxEYnhBY3Rpb25Db25maXJtQ29uZmlnPFQ+PiwgTWF5YmU8RGJ4QWN0aW9uQ29uZmlybUNvbmZpZzxUPiB8ICcnPj4odW5kZWZpbmVkLCB7IHRyYW5zZm9ybTogdHJhbnNmb3JtRW1wdHlTdHJpbmdJbnB1dFRvVW5kZWZpbmVkIH0pO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgX3NvdXJjZVN1YnNjcmlwdGlvbiA9IG5ldyBTdWJzY3JpcHRpb25PYmplY3QoKTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLl9zb3VyY2VTdWJzY3JpcHRpb24uc3Vic2NyaXB0aW9uID0gdGhpcy5zb3VyY2UudHJpZ2dlcmVkJC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5zaG93RGlhbG9nKCk7XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLl9zb3VyY2VTdWJzY3JpcHRpb24uZGVzdHJveSgpO1xuICB9XG5cbiAgcHJvdGVjdGVkIGdldERlZmF1bHREaWFsb2dDb25maWcoKTogTWF5YmU8RGJ4UHJvbXB0Q29uZmlybUNvbmZpZz4ge1xuICAgIHJldHVybiB0aGlzLmRieEFjdGlvbkNvbmZpcm0oKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBfaGFuZGxlRGlhbG9nUmVzdWx0KHJlc3VsdDogYm9vbGVhbik6IGJvb2xlYW4ge1xuICAgIGlmIChyZXN1bHQpIHtcbiAgICAgIHRoaXMuc291cmNlLnJlYWR5VmFsdWUodGhpcy5kYnhBY3Rpb25Db25maXJtKCk/LnJlYWR5VmFsdWUgYXMgdW5rbm93biBhcyBUKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zb3VyY2UucmVqZWN0KHVuZGVmaW5lZCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxufVxuIl19
|
|
@@ -72,10 +72,10 @@ export class DbxActionSnackbarComponent extends AbstractSubscriptionDirective {
|
|
|
72
72
|
this.snackbarRef.dismiss();
|
|
73
73
|
};
|
|
74
74
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxActionSnackbarComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
75
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxActionSnackbarComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-action-snackbar\" [ngClass]=\"snackbarStatusClassSignal()\">\n <span>{{ message }}</span>\n <dbx-spacer></dbx-spacer>\n @switch (completeSignal()) {\n @case (true) {\n <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"done\" text=\"Success\"></dbx-button>\n }\n @case (false) {\n @if (hasAction) {\n <dbx-action dbxActionValue [dbxActionSource]=\"sourceInstanceSignal()\" [dbxActionSuccessHandler]=\"dismissAfterActionCompletes\">\n <dbx-button dbxActionButton color=\"warn\" [text]=\"button\"></dbx-button>\n </dbx-action>\n <dbx-button-spacer></dbx-button-spacer>\n }\n <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"close\"></dbx-button>\n }\n }\n</div>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: DbxActionSourceDirective, selector: "[dbxActionSource]", inputs: ["dbxActionSource"] }, { kind: "directive", type: DbxActionSuccessHandlerDirective, selector: "[dbxActionSuccessHandler]", inputs: ["dbxActionSuccessHandler"] }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "directive", type: DbxSpacerDirective, selector: "dbx-spacer, [dbxSpacer]" }, { kind: "directive", type: DbxActionDirective, selector: "dbx-action,[dbxAction],dbx-action-context,[dbxActionContext]", exportAs: ["action", "dbxAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
75
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxActionSnackbarComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-action-snackbar\" [ngClass]=\"snackbarStatusClassSignal()\">\n <span>{{ message }}</span>\n <dbx-spacer></dbx-spacer>\n @switch (completeSignal()) {\n @case (true) {\n <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"done\" text=\"Success\"></dbx-button>\n }\n @case (false) {\n @if (hasAction) {\n <dbx-action dbxActionValue [dbxActionSource]=\"sourceInstanceSignal()\" [dbxActionSuccessHandler]=\"dismissAfterActionCompletes\">\n <dbx-button dbxActionButton color=\"warn\" [text]=\"button\"></dbx-button>\n </dbx-action>\n <dbx-button-spacer></dbx-button-spacer>\n }\n <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"close\"></dbx-button>\n }\n }\n</div>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: DbxActionSourceDirective, selector: "[dbxActionSource]", inputs: ["dbxActionSource"] }, { kind: "directive", type: DbxActionSuccessHandlerDirective, selector: "[dbxActionSuccessHandler]", inputs: ["dbxActionSuccessHandler"] }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "directive", type: DbxSpacerDirective, selector: "dbx-spacer, [dbxSpacer]" }, { kind: "directive", type: DbxActionDirective, selector: "dbx-action,[dbxAction],dbx-action-context,[dbxActionContext]", exportAs: ["action", "dbxAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
76
76
|
}
|
|
77
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxActionSnackbarComponent, decorators: [{
|
|
78
78
|
type: Component,
|
|
79
79
|
args: [{ standalone: true, imports: [NgClass, DbxActionSourceDirective, DbxActionSuccessHandlerDirective, DbxButtonComponent, DbxButtonSpacerDirective, DbxSpacerDirective, DbxActionDirective, DbxActionValueStreamDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dbx-action-snackbar\" [ngClass]=\"snackbarStatusClassSignal()\">\n <span>{{ message }}</span>\n <dbx-spacer></dbx-spacer>\n @switch (completeSignal()) {\n @case (true) {\n <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"done\" text=\"Success\"></dbx-button>\n }\n @case (false) {\n @if (hasAction) {\n <dbx-action dbxActionValue [dbxActionSource]=\"sourceInstanceSignal()\" [dbxActionSuccessHandler]=\"dismissAfterActionCompletes\">\n <dbx-button dbxActionButton color=\"warn\" [text]=\"button\"></dbx-button>\n </dbx-action>\n <dbx-button-spacer></dbx-button-spacer>\n }\n <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"close\"></dbx-button>\n }\n }\n</div>\n" }]
|
|
80
80
|
}] });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.snackbar.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/action/snackbar/action.snackbar.component.ts","../../../../../../../packages/dbx-web/src/lib/action/snackbar/action.snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, Component, OnDestroy, AfterViewInit, inject, computed, ChangeDetectionStrategy } from '@angular/core';\nimport { filterMaybe, LoadingStateType } from '@dereekb/rxjs';\nimport { shareReplay, switchMap, startWith, Subject, of, filter, map } from 'rxjs';\nimport { MatSnackBarRef, MAT_SNACK_BAR_DATA } from '@angular/material/snack-bar';\nimport { MS_IN_SECOND, type Maybe } from '@dereekb/util';\nimport { DbxActionSnackbarDisplayConfig, DbxActionSnackbarActionConfig } from './action.snackbar';\nimport { AbstractSubscriptionDirective, DbxActionDirective, DbxActionValueStreamDirective, DbxActionSuccessHandlerFunction, DbxActionSourceDirective, DbxActionSuccessHandlerDirective } from '@dereekb/dbx-core';\nimport { NgClass } from '@angular/common';\nimport { DbxButtonComponent } from '../../button/button.component';\nimport { DbxButtonSpacerDirective } from '../../button/button.spacer.directive';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { DbxSpacerDirective } from '../../layout/style/spacer.directive';\n\n/**\n * Component for a snackbar that contains an action.\n */\n@Component({\n  templateUrl: './action.snackbar.component.html',\n  standalone: true,\n  imports: [NgClass, DbxActionSourceDirective, DbxActionSuccessHandlerDirective, DbxButtonComponent, DbxButtonSpacerDirective, DbxSpacerDirective, DbxActionDirective, DbxActionValueStreamDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxActionSnackbarComponent extends AbstractSubscriptionDirective implements OnInit, AfterViewInit, OnDestroy {\n  readonly snackbarRef = inject(MatSnackBarRef<DbxActionSnackbarComponent>);\n  readonly snackbarData = inject<DbxActionSnackbarDisplayConfig>(MAT_SNACK_BAR_DATA);\n\n  private readonly _durationTimeout = new Subject<void>();\n  private readonly _actionRef = this.snackbarData.action?.reference;\n\n  readonly sourceInstance$ = of(this._actionRef).pipe(\n    filterMaybe(),\n    map((x) => x?.sourceInstance)\n  );\n\n  readonly complete$ = this.sourceInstance$.pipe(\n    switchMap((x) => x.isSuccess$),\n    startWith(false),\n    shareReplay(1)\n  );\n\n  readonly loadingStateType$ = this.sourceInstance$.pipe(\n    switchMap((x) => x.loadingStateType$),\n    startWith(LoadingStateType.IDLE),\n    shareReplay(1)\n  );\n\n  readonly sourceInstanceSignal = toSignal(this.sourceInstance$);\n  readonly completeSignal = toSignal(this.complete$);\n  readonly loadingStateTypeSignal = toSignal(this.loadingStateType$);\n  readonly snackbarStatusClassSignal = computed(() => {\n    let classes = 'dbx-action-snackbar-';\n    const loadingStateType = this.loadingStateTypeSignal();\n\n    switch (loadingStateType) {\n      case LoadingStateType.ERROR:\n        classes += 'error';\n        break;\n      case LoadingStateType.SUCCESS:\n        classes += 'success';\n        break;\n      default:\n        classes += 'idle';\n        break;\n    }\n\n    return classes;\n  });\n\n  readonly button: Maybe<string> = this.snackbarData.action?.button ?? this.snackbarData.button;\n  readonly action: Maybe<DbxActionSnackbarActionConfig> = this.snackbarData.action;\n  readonly hasAction: boolean = Boolean(this.action?.reference);\n  readonly message: Maybe<string> = this.snackbarData.message;\n  readonly actionConfig: Maybe<DbxActionSnackbarActionConfig> = this.snackbarData.action;\n\n  ngOnInit(): void {\n    // Subscribe and close if the duration is up and the action state is idle.\n    this.sub = this._durationTimeout\n      .pipe(\n        switchMap(() => this.loadingStateType$),\n        filter((x) => x === LoadingStateType.IDLE)\n      )\n      .subscribe(() => {\n        this.dismiss();\n      });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._durationTimeout.complete();\n  }\n\n  ngAfterViewInit(): void {\n    // Responsible for hiding itself if it has an action.\n    if (this.hasAction) {\n      setTimeout(\n        () => {\n          this._durationTimeout.next();\n        },\n        this.snackbarData.action?.duration ?? MS_IN_SECOND * 10\n      );\n    }\n  }\n\n  dismissAfterActionCompletes: DbxActionSuccessHandlerFunction = (): void => {\n    this.snackbarRef._dismissAfter(MS_IN_SECOND * 3);\n  };\n\n  dismiss = (): void => {\n    this.snackbarRef.dismiss();\n  };\n}\n","<div class=\"dbx-action-snackbar\" [ngClass]=\"snackbarStatusClassSignal()\">\n  <span>{{ message }}</span>\n  <dbx-spacer></dbx-spacer>\n  @switch (completeSignal()) {\n    @case (true) {\n      <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"done\" text=\"Success\"></dbx-button>\n    }\n    @case (false) {\n      @if (hasAction) {\n        <dbx-action dbxActionValue [dbxActionSource]=\"sourceInstanceSignal()\" [dbxActionSuccessHandler]=\"dismissAfterActionCompletes\">\n          <dbx-button dbxActionButton color=\"warn\" [text]=\"button\"></dbx-button>\n        </dbx-action>\n        <dbx-button-spacer></dbx-button-spacer>\n      }\n      <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"close\"></dbx-button>\n    }\n  }\n</div>\n"]}
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.snackbar.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/action/snackbar/action.snackbar.component.ts","../../../../../../../packages/dbx-web/src/lib/action/snackbar/action.snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, Component, OnDestroy, AfterViewInit, inject, computed, ChangeDetectionStrategy } from '@angular/core';\nimport { filterMaybe, LoadingStateType } from '@dereekb/rxjs';\nimport { shareReplay, switchMap, startWith, Subject, of, filter, map } from 'rxjs';\nimport { MatSnackBarRef, MAT_SNACK_BAR_DATA } from '@angular/material/snack-bar';\nimport { MS_IN_SECOND, type Maybe } from '@dereekb/util';\nimport { DbxActionSnackbarDisplayConfig, DbxActionSnackbarActionConfig } from './action.snackbar';\nimport { AbstractSubscriptionDirective, DbxActionDirective, DbxActionValueStreamDirective, DbxActionSuccessHandlerFunction, DbxActionSourceDirective, DbxActionSuccessHandlerDirective } from '@dereekb/dbx-core';\nimport { NgClass } from '@angular/common';\nimport { DbxButtonComponent } from '../../button/button.component';\nimport { DbxButtonSpacerDirective } from '../../button/button.spacer.directive';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { DbxSpacerDirective } from '../../layout/style/spacer.directive';\n\n/**\n * Component for a snackbar that contains an action.\n */\n@Component({\n  templateUrl: './action.snackbar.component.html',\n  standalone: true,\n  imports: [NgClass, DbxActionSourceDirective, DbxActionSuccessHandlerDirective, DbxButtonComponent, DbxButtonSpacerDirective, DbxSpacerDirective, DbxActionDirective, DbxActionValueStreamDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxActionSnackbarComponent extends AbstractSubscriptionDirective implements OnInit, AfterViewInit, OnDestroy {\n  readonly snackbarRef = inject(MatSnackBarRef<DbxActionSnackbarComponent>);\n  readonly snackbarData = inject<DbxActionSnackbarDisplayConfig>(MAT_SNACK_BAR_DATA);\n\n  private readonly _durationTimeout = new Subject<void>();\n  private readonly _actionRef = this.snackbarData.action?.reference;\n\n  readonly sourceInstance$ = of(this._actionRef).pipe(\n    filterMaybe(),\n    map((x) => x?.sourceInstance)\n  );\n\n  readonly complete$ = this.sourceInstance$.pipe(\n    switchMap((x) => x.isSuccess$),\n    startWith(false),\n    shareReplay(1)\n  );\n\n  readonly loadingStateType$ = this.sourceInstance$.pipe(\n    switchMap((x) => x.loadingStateType$),\n    startWith(LoadingStateType.IDLE),\n    shareReplay(1)\n  );\n\n  readonly sourceInstanceSignal = toSignal(this.sourceInstance$);\n  readonly completeSignal = toSignal(this.complete$);\n  readonly loadingStateTypeSignal = toSignal(this.loadingStateType$);\n  readonly snackbarStatusClassSignal = computed(() => {\n    let classes = 'dbx-action-snackbar-';\n    const loadingStateType = this.loadingStateTypeSignal();\n\n    switch (loadingStateType) {\n      case LoadingStateType.ERROR:\n        classes += 'error';\n        break;\n      case LoadingStateType.SUCCESS:\n        classes += 'success';\n        break;\n      default:\n        classes += 'idle';\n        break;\n    }\n\n    return classes;\n  });\n\n  readonly button: Maybe<string> = this.snackbarData.action?.button ?? this.snackbarData.button;\n  readonly action: Maybe<DbxActionSnackbarActionConfig> = this.snackbarData.action;\n  readonly hasAction: boolean = Boolean(this.action?.reference);\n  readonly message: Maybe<string> = this.snackbarData.message;\n  readonly actionConfig: Maybe<DbxActionSnackbarActionConfig> = this.snackbarData.action;\n\n  ngOnInit(): void {\n    // Subscribe and close if the duration is up and the action state is idle.\n    this.sub = this._durationTimeout\n      .pipe(\n        switchMap(() => this.loadingStateType$),\n        filter((x) => x === LoadingStateType.IDLE)\n      )\n      .subscribe(() => {\n        this.dismiss();\n      });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._durationTimeout.complete();\n  }\n\n  ngAfterViewInit(): void {\n    // Responsible for hiding itself if it has an action.\n    if (this.hasAction) {\n      setTimeout(\n        () => {\n          this._durationTimeout.next();\n        },\n        this.snackbarData.action?.duration ?? MS_IN_SECOND * 10\n      );\n    }\n  }\n\n  dismissAfterActionCompletes: DbxActionSuccessHandlerFunction = (): void => {\n    this.snackbarRef._dismissAfter(MS_IN_SECOND * 3);\n  };\n\n  dismiss = (): void => {\n    this.snackbarRef.dismiss();\n  };\n}\n","<div class=\"dbx-action-snackbar\" [ngClass]=\"snackbarStatusClassSignal()\">\n  <span>{{ message }}</span>\n  <dbx-spacer></dbx-spacer>\n  @switch (completeSignal()) {\n    @case (true) {\n      <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"done\" text=\"Success\"></dbx-button>\n    }\n    @case (false) {\n      @if (hasAction) {\n        <dbx-action dbxActionValue [dbxActionSource]=\"sourceInstanceSignal()\" [dbxActionSuccessHandler]=\"dismissAfterActionCompletes\">\n          <dbx-button dbxActionButton color=\"warn\" [text]=\"button\"></dbx-button>\n        </dbx-action>\n        <dbx-button-spacer></dbx-button-spacer>\n      }\n      <dbx-button (buttonClick)=\"dismiss()\" color=\"accent\" icon=\"close\"></dbx-button>\n    }\n  }\n</div>\n"]}
|
|
@@ -31,7 +31,7 @@ export class DbxActionUIRouterTransitionSafetyDialogComponent extends AbstractDi
|
|
|
31
31
|
<dbx-button-spacer></dbx-button-spacer>
|
|
32
32
|
</ng-container>
|
|
33
33
|
</dbx-prompt-confirm>
|
|
34
|
-
`, isInline: true, dependencies: [{ kind: "component", type: DbxPromptConfirmComponent, selector: "dbx-prompt-confirm", inputs: ["config"], outputs: ["confirm", "cancel"] }, { kind: "component", type: DbxErrorComponent, selector: "dbx-error", inputs: ["error", "iconOnly"], outputs: ["popoverOpened"] }, { kind: "directive", type: DbxActionErrorDirective, selector: "[dbxActionError]" }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
34
|
+
`, isInline: true, dependencies: [{ kind: "component", type: DbxPromptConfirmComponent, selector: "dbx-prompt-confirm", inputs: ["config"], outputs: ["confirm", "cancel"] }, { kind: "component", type: DbxErrorComponent, selector: "dbx-error", inputs: ["error", "iconOnly"], outputs: ["popoverOpened"] }, { kind: "directive", type: DbxActionErrorDirective, selector: "[dbxActionError]" }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
35
35
|
}
|
|
36
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxActionUIRouterTransitionSafetyDialogComponent, decorators: [{
|
|
37
37
|
type: Component,
|
|
@@ -50,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
50
50
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
51
51
|
}]
|
|
52
52
|
}] });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNpdGlvbi5zYWZldHkuZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9hY3Rpb24vdHJhbnNpdGlvbi90cmFuc2l0aW9uLnNhZmV0eS5kaWFsb2cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDN0YsT0FBTyxFQUEwQix5QkFBeUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ3RILE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ25FLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOztBQUloRjs7R0FFRztBQWVILE1BQU0sT0FBTyxnREFBaUQsU0FBUSx1QkFBdUI7SUFDbEYsTUFBTSxHQUEyQjtRQUN4QyxLQUFLLEVBQUUsaUJBQWlCO1FBQ3hCLE1BQU0sRUFBRSx3Q0FBd0M7UUFDaEQsV0FBVyxFQUFFLE1BQU07UUFDbkIsVUFBVSxFQUFFLGlCQUFpQjtLQUM5QixDQUFDO0lBRUYsT0FBTztRQUNMLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDbEMsQ0FBQzt3R0FkVSxnREFBZ0Q7NEZBQWhELGdEQUFnRCwrRkFiakQ7Ozs7Ozs7O0dBUVQsNERBRVMseUJBQXlCLG1IQUFFLGlCQUFpQixpSEFBRSx1QkFBdUIsNkRBQUUsa0JBQWtCLHdPQUFFLHdCQUF3Qjs7NEZBR2xILGdEQUFnRDtrQkFkNUQsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUU7Ozs7Ozs7O0dBUVQ7b0JBQ0QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixFQUFFLGlCQUFpQixFQUFFLHVCQUF1QixFQUFFLGtCQUFrQixFQUFFLHdCQUF3QixDQUFDO29CQUM5SCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vaW50ZXJhY3Rpb24vZGlhbG9nL2Fic3RyYWN0LmRpYWxvZy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4UHJvbXB0Q29uZmlybUNvbmZpZywgRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2ludGVyYWN0aW9uL3Byb21wdC9wcm9tcHQuY29uZmlybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4RXJyb3JDb21wb25lbnQgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4QWN0aW9uRXJyb3JEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5hY3Rpb24uZGlyZWN0aXZlJztcbmltcG9ydCB7IERieEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uc3BhY2VyLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCB0eXBlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlEaWFsb2dSZXN1bHQgPSAnc3VjY2VzcycgfCAnc3RheScgfCAnZGlzY2FyZCcgfCAnbm9uZSc7XG5cbi8qKlxuICogRGlhbG9nIHRoYXQgaXMgc2hvd24vdHJpZ2dlcmVkIGFzIHBhcnQgb2YgdGhlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlcbiAqL1xuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1wcm9tcHQtY29uZmlybSBbY29uZmlnXT1cImNvbmZpZ1wiIChjb25maXJtKT1cImNvbmZpcm0oKVwiIChjYW5jZWwpPVwiY2FuY2VsKClcIj5cbiAgICAgIDxuZy1jb250YWluZXI+XG4gICAgICAgIDxkYngtZXJyb3IgZGJ4QWN0aW9uRXJyb3I+PC9kYngtZXJyb3I+XG4gICAgICAgIDxkYngtYnV0dG9uIHRleHQ9XCJTYXZlIENoYW5nZXNcIiBkYnhBY3Rpb25CdXR0b24+PC9kYngtYnV0dG9uPlxuICAgICAgICA8ZGJ4LWJ1dHRvbi1zcGFjZXI+PC9kYngtYnV0dG9uLXNwYWNlcj5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvZGJ4LXByb21wdC1jb25maXJtPlxuICBgLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCwgRGJ4RXJyb3JDb21wb25lbnQsIERieEFjdGlvbkVycm9yRGlyZWN0aXZlLCBEYnhCdXR0b25Db21wb25lbnQsIERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZV0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieEFjdGlvblVJUm91dGVyVHJhbnNpdGlvblNhZmV0eURpYWxvZ0NvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcmVhZG9ubHkgY29uZmlnOiBEYnhQcm9tcHRDb25maXJtQ29uZmlnID0ge1xuICAgIHRpdGxlOiAnVW5zYXZlZCBDaGFuZ2VzJyxcbiAgICBwcm9tcHQ6ICdZb3UgaGF2ZSB1bnNhdmVkIGNoYW5nZXMgb24gdGhpcyBwYWdlLicsXG4gICAgY29uZmlybVRleHQ6ICdTdGF5JyxcbiAgICBjYW5jZWxUZXh0OiAnRGlzY2FyZCBDaGFuZ2VzJ1xuICB9O1xuXG4gIGNvbmZpcm0oKTogdm9pZCB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoJ3N0YXknKTtcbiAgfVxuXG4gIGNhbmNlbCgpOiB2b2lkIHtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgnZGlzY2FyZCcpO1xuICB9XG59XG4iXX0=
|
|
@@ -18,6 +18,7 @@ export var DbxButtonDisplayType;
|
|
|
18
18
|
*/
|
|
19
19
|
export class DbxButtonComponent extends AbstractDbxButtonDirective {
|
|
20
20
|
type = input();
|
|
21
|
+
buttonStyle = input();
|
|
21
22
|
color = input(undefined);
|
|
22
23
|
spinnerColor = input(undefined);
|
|
23
24
|
customButtonColor = input();
|
|
@@ -30,7 +31,8 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
|
|
|
30
31
|
iconOnly = input(false, { transform: isDefinedAndNotFalse });
|
|
31
32
|
fab = input(false, { transform: isDefinedAndNotFalse });
|
|
32
33
|
typeSignal = computed(() => {
|
|
33
|
-
|
|
34
|
+
const style = this.buttonStyle();
|
|
35
|
+
let type = this.type() ?? style?.type;
|
|
34
36
|
if (!type) {
|
|
35
37
|
type = 'basic';
|
|
36
38
|
if (this.raised()) {
|
|
@@ -51,41 +53,45 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
|
|
|
51
53
|
configSignal = computed(() => {
|
|
52
54
|
// configure custom style
|
|
53
55
|
const customStyle = {};
|
|
54
|
-
const
|
|
56
|
+
const style = this.buttonStyle();
|
|
57
|
+
const customButtonColorValue = this.customButtonColor() ?? style?.customButtonColor;
|
|
55
58
|
if (customButtonColorValue) {
|
|
56
59
|
customStyle['background'] = customButtonColorValue;
|
|
57
60
|
}
|
|
58
|
-
const customTextColorValue = this.customTextColor();
|
|
61
|
+
const customTextColorValue = this.customTextColor() ?? style?.customTextColor;
|
|
59
62
|
if (customTextColorValue) {
|
|
60
63
|
customStyle['color'] = customTextColorValue;
|
|
61
64
|
}
|
|
62
|
-
const customSpinnerColorValue = this.customSpinnerColor();
|
|
65
|
+
const customSpinnerColorValue = this.customSpinnerColor() ?? style?.customSpinnerColor;
|
|
63
66
|
const customSpinnerColor = customSpinnerColorValue ?? customTextColorValue;
|
|
67
|
+
const buttonColor = this.color() ?? style?.color;
|
|
68
|
+
const spinnerColor = this.spinnerColor() ?? style?.spinnerColor ?? buttonColor;
|
|
64
69
|
const disabledSignalValue = this.disabledSignal();
|
|
65
70
|
const disabled = !this.workingSignal() && disabledSignalValue; // Only disabled if we're not working, in order to show the animation.
|
|
66
71
|
const iconValue = this.iconSignal();
|
|
67
72
|
const buttonIcon = iconValue ? { fontIcon: iconValue } : undefined;
|
|
68
73
|
const textValue = this.textSignal();
|
|
69
74
|
const isIconOnlyButton = buttonIcon && !textValue;
|
|
75
|
+
const fab = this.fab() || style?.fab;
|
|
70
76
|
const config = {
|
|
71
|
-
fab
|
|
77
|
+
fab,
|
|
72
78
|
working: this.workingSignal(),
|
|
73
79
|
buttonIcon,
|
|
74
80
|
customStyle,
|
|
75
81
|
customClass: 'dbx-button ' + (isIconOnlyButton ? 'dbx-button-no-text' : ''),
|
|
76
82
|
text: textValue ?? '',
|
|
77
83
|
buttonType: this.typeSignal(),
|
|
78
|
-
buttonColor
|
|
84
|
+
buttonColor,
|
|
79
85
|
barColor: 'accent',
|
|
80
86
|
mode: 'indeterminate',
|
|
81
|
-
spinnerColor
|
|
87
|
+
spinnerColor,
|
|
82
88
|
customSpinnerColor,
|
|
83
89
|
disabled
|
|
84
90
|
};
|
|
85
91
|
return config;
|
|
86
92
|
});
|
|
87
93
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DbxButtonComponent, isStandalone: true, selector: "dbx-button", inputs: { type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, spinnerColor: { classPropertyName: "spinnerColor", publicName: "spinnerColor", isSignal: true, isRequired: false, transformFunction: null }, customButtonColor: { classPropertyName: "customButtonColor", publicName: "customButtonColor", isSignal: true, isRequired: false, transformFunction: null }, customTextColor: { classPropertyName: "customTextColor", publicName: "customTextColor", isSignal: true, isRequired: false, transformFunction: null }, customSpinnerColor: { classPropertyName: "customSpinnerColor", publicName: "customSpinnerColor", isSignal: true, isRequired: false, transformFunction: null }, basic: { classPropertyName: "basic", publicName: "basic", isSignal: true, isRequired: false, transformFunction: null }, raised: { classPropertyName: "raised", publicName: "raised", isSignal: true, isRequired: false, transformFunction: null }, stroked: { classPropertyName: "stroked", publicName: "stroked", isSignal: true, isRequired: false, transformFunction: null }, flat: { classPropertyName: "flat", publicName: "flat", isSignal: true, isRequired: false, transformFunction: null }, iconOnly: { classPropertyName: "iconOnly", publicName: "iconOnly", isSignal: true, isRequired: false, transformFunction: null }, fab: { classPropertyName: "fab", publicName: "fab", isSignal: true, isRequired: false, transformFunction: null } }, providers: provideDbxButton(DbxButtonComponent), usesInheritance: true, ngImport: i0, template: `
|
|
94
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DbxButtonComponent, isStandalone: true, selector: "dbx-button", inputs: { type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, buttonStyle: { classPropertyName: "buttonStyle", publicName: "buttonStyle", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, spinnerColor: { classPropertyName: "spinnerColor", publicName: "spinnerColor", isSignal: true, isRequired: false, transformFunction: null }, customButtonColor: { classPropertyName: "customButtonColor", publicName: "customButtonColor", isSignal: true, isRequired: false, transformFunction: null }, customTextColor: { classPropertyName: "customTextColor", publicName: "customTextColor", isSignal: true, isRequired: false, transformFunction: null }, customSpinnerColor: { classPropertyName: "customSpinnerColor", publicName: "customSpinnerColor", isSignal: true, isRequired: false, transformFunction: null }, basic: { classPropertyName: "basic", publicName: "basic", isSignal: true, isRequired: false, transformFunction: null }, raised: { classPropertyName: "raised", publicName: "raised", isSignal: true, isRequired: false, transformFunction: null }, stroked: { classPropertyName: "stroked", publicName: "stroked", isSignal: true, isRequired: false, transformFunction: null }, flat: { classPropertyName: "flat", publicName: "flat", isSignal: true, isRequired: false, transformFunction: null }, iconOnly: { classPropertyName: "iconOnly", publicName: "iconOnly", isSignal: true, isRequired: false, transformFunction: null }, fab: { classPropertyName: "fab", publicName: "fab", isSignal: true, isRequired: false, transformFunction: null } }, providers: provideDbxButton(DbxButtonComponent), usesInheritance: true, ngImport: i0, template: `
|
|
89
95
|
<dbx-progress-spinner-button (btnClick)="clickButton()" [config]="configSignal()">
|
|
90
96
|
<ng-content></ng-content>
|
|
91
97
|
</dbx-progress-spinner-button>
|
|
@@ -106,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
106
112
|
standalone: true
|
|
107
113
|
}]
|
|
108
114
|
}] });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/src/lib/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { provideDbxButton, AbstractDbxButtonDirective } from '@dereekb/dbx-core';\nimport { Configurable, isDefinedAndNotFalse, type Maybe } from '@dereekb/util';\nimport { DbxProgressButtonConfig } from './progress/button.progress.config';\nimport { type DbxThemeColor } from '../layout/style/style';\nimport { DbxProgressSpinnerButtonComponent } from './progress';\n\nexport type DbxButtonType = 'basic' | 'raised' | 'stroked' | 'flat' | 'icon';\n\n/**\n * @deprecated use DbxButtonType instead.\n */\nexport enum DbxButtonDisplayType {\n  RAISED = 'raised',\n  STROKED = 'stroked',\n  FLAT = 'flag',\n  ICON_ONLY = 'icon'\n}\n\n/**\n * Complex button that supports loading states.\n */\n@Component({\n  selector: 'dbx-button',\n  template: `\n    <dbx-progress-spinner-button (btnClick)=\"clickButton()\" [config]=\"configSignal()\">\n      <ng-content></ng-content>\n    </dbx-progress-spinner-button>\n  `,\n  providers: provideDbxButton(DbxButtonComponent),\n  imports: [DbxProgressSpinnerButtonComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxButtonComponent extends AbstractDbxButtonDirective {\n  readonly type = input<Maybe<DbxButtonType>>();\n\n  readonly color = input<ThemePalette | DbxThemeColor>(undefined);\n  readonly spinnerColor = input<ThemePalette | DbxThemeColor>(undefined);\n  readonly customButtonColor = input<Maybe<string>>();\n  readonly customTextColor = input<Maybe<string>>();\n  readonly customSpinnerColor = input<Maybe<string>>();\n\n  readonly basic = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly raised = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly stroked = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly flat = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly iconOnly = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly fab = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n\n  readonly typeSignal = computed(() => {\n    let type = this.type();\n\n    if (!type) {\n      type = 'basic';\n\n      if (this.raised()) {\n        type = 'raised';\n      } else if (this.stroked()) {\n        type = 'stroked';\n      } else if (this.flat()) {\n        type = 'flat';\n      } else if (this.iconOnly()) {\n        type = 'icon';\n      }\n    }\n\n    return type;\n  });\n\n  readonly configSignal = computed<DbxProgressButtonConfig>(() => {\n    // configure custom style\n    const customStyle = {} as {\n      [key: string]: string;\n    };\n\n    const customButtonColorValue = this.customButtonColor();\n\n    if (customButtonColorValue) {\n      customStyle['background'] = customButtonColorValue;\n    }\n\n    const customTextColorValue = this.customTextColor();\n\n    if (customTextColorValue) {\n      customStyle['color'] = customTextColorValue;\n    }\n\n    const customSpinnerColorValue = this.customSpinnerColor();\n    const customSpinnerColor: Maybe<string> = customSpinnerColorValue ?? customTextColorValue;\n\n    const disabledSignalValue = this.disabledSignal();\n    const disabled = !this.workingSignal() && disabledSignalValue; // Only disabled if we're not working, in order to show the animation.\n\n    const iconValue = this.iconSignal();\n    const buttonIcon = iconValue ? { fontIcon: iconValue } : undefined;\n\n    const textValue = this.textSignal();\n    const isIconOnlyButton = buttonIcon && !textValue;\n\n    const config: Configurable<DbxProgressButtonConfig> = {\n      fab: this.fab(),\n      working: this.workingSignal(),\n      buttonIcon,\n      customStyle,\n      customClass: 'dbx-button ' + (isIconOnlyButton ? 'dbx-button-no-text' : ''),\n      text: textValue ?? '',\n      buttonType: this.typeSignal(),\n      buttonColor: this.color(),\n      barColor: 'accent',\n      mode: 'indeterminate',\n      spinnerColor: this.spinnerColor() ?? this.color(),\n      customSpinnerColor,\n      disabled\n    };\n\n    return config;\n  });\n}\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/src/lib/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { provideDbxButton, AbstractDbxButtonDirective } from '@dereekb/dbx-core';\nimport { Configurable, isDefinedAndNotFalse, type Maybe } from '@dereekb/util';\nimport { DbxProgressButtonConfig } from './progress/button.progress.config';\nimport { type DbxThemeColor } from '../layout/style/style';\nimport { DbxProgressSpinnerButtonComponent } from './progress';\n\nexport type DbxButtonType = 'basic' | 'raised' | 'stroked' | 'flat' | 'icon';\n\n/**\n * Style details for the button\n */\nexport interface DbxButtonStyle {\n  readonly type?: DbxButtonType;\n  readonly color?: ThemePalette | DbxThemeColor;\n  readonly spinnerColor?: ThemePalette | DbxThemeColor;\n  readonly customButtonColor?: string;\n  readonly customTextColor?: string;\n  readonly customSpinnerColor?: string;\n  readonly fab?: boolean;\n}\n\n/**\n * @deprecated use DbxButtonType instead.\n */\nexport enum DbxButtonDisplayType {\n  RAISED = 'raised',\n  STROKED = 'stroked',\n  FLAT = 'flag',\n  ICON_ONLY = 'icon'\n}\n\n/**\n * Complex button that supports loading states.\n */\n@Component({\n  selector: 'dbx-button',\n  template: `\n    <dbx-progress-spinner-button (btnClick)=\"clickButton()\" [config]=\"configSignal()\">\n      <ng-content></ng-content>\n    </dbx-progress-spinner-button>\n  `,\n  providers: provideDbxButton(DbxButtonComponent),\n  imports: [DbxProgressSpinnerButtonComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxButtonComponent extends AbstractDbxButtonDirective {\n  readonly type = input<Maybe<DbxButtonType>>();\n  readonly buttonStyle = input<Maybe<DbxButtonStyle>>();\n\n  readonly color = input<ThemePalette | DbxThemeColor>(undefined);\n  readonly spinnerColor = input<ThemePalette | DbxThemeColor>(undefined);\n  readonly customButtonColor = input<Maybe<string>>();\n  readonly customTextColor = input<Maybe<string>>();\n  readonly customSpinnerColor = input<Maybe<string>>();\n\n  readonly basic = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly raised = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly stroked = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly flat = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly iconOnly = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n  readonly fab = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n\n  readonly typeSignal = computed(() => {\n    const style = this.buttonStyle();\n    let type = this.type() ?? style?.type;\n\n    if (!type) {\n      type = 'basic';\n\n      if (this.raised()) {\n        type = 'raised';\n      } else if (this.stroked()) {\n        type = 'stroked';\n      } else if (this.flat()) {\n        type = 'flat';\n      } else if (this.iconOnly()) {\n        type = 'icon';\n      }\n    }\n\n    return type;\n  });\n\n  readonly configSignal = computed<DbxProgressButtonConfig>(() => {\n    // configure custom style\n    const customStyle = {} as {\n      [key: string]: string;\n    };\n\n    const style = this.buttonStyle();\n    const customButtonColorValue = this.customButtonColor() ?? style?.customButtonColor;\n\n    if (customButtonColorValue) {\n      customStyle['background'] = customButtonColorValue;\n    }\n\n    const customTextColorValue = this.customTextColor() ?? style?.customTextColor;\n\n    if (customTextColorValue) {\n      customStyle['color'] = customTextColorValue;\n    }\n\n    const customSpinnerColorValue = this.customSpinnerColor() ?? style?.customSpinnerColor;\n    const customSpinnerColor: Maybe<string> = customSpinnerColorValue ?? customTextColorValue;\n\n    const buttonColor = this.color() ?? style?.color;\n    const spinnerColor = this.spinnerColor() ?? style?.spinnerColor ?? buttonColor;\n\n    const disabledSignalValue = this.disabledSignal();\n    const disabled = !this.workingSignal() && disabledSignalValue; // Only disabled if we're not working, in order to show the animation.\n\n    const iconValue = this.iconSignal();\n    const buttonIcon = iconValue ? { fontIcon: iconValue } : undefined;\n\n    const textValue = this.textSignal();\n    const isIconOnlyButton = buttonIcon && !textValue;\n    const fab = this.fab() || style?.fab;\n\n    const config: Configurable<DbxProgressButtonConfig> = {\n      fab,\n      working: this.workingSignal(),\n      buttonIcon,\n      customStyle,\n      customClass: 'dbx-button ' + (isIconOnlyButton ? 'dbx-button-no-text' : ''),\n      text: textValue ?? '',\n      buttonType: this.typeSignal(),\n      buttonColor,\n      barColor: 'accent',\n      mode: 'indeterminate',\n      spinnerColor,\n      customSpinnerColor,\n      disabled\n    };\n\n    return config;\n  });\n}\n"]}
|
|
@@ -108,10 +108,10 @@ export class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective
|
|
|
108
108
|
}));
|
|
109
109
|
};
|
|
110
110
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDownloadTextViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
111
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxDownloadTextViewComponent, isStandalone: true, selector: "dbx-download-text-view", inputs: { loadingText: { classPropertyName: "loadingText", publicName: "loadingText", isSignal: true, isRequired: false, transformFunction: null }, linear: { classPropertyName: "linear", publicName: "linear", isSignal: true, isRequired: false, transformFunction: null }, showTitle: { classPropertyName: "showTitle", publicName: "showTitle", isSignal: true, isRequired: false, transformFunction: null }, showPreview: { classPropertyName: "showPreview", publicName: "showPreview", isSignal: true, isRequired: false, transformFunction: null }, content: { classPropertyName: "content", publicName: "content", isSignal: true, isRequired: false, transformFunction: null }, contentState: { classPropertyName: "contentState", publicName: "contentState", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "downloadButton", first: true, predicate: ["downloadButton"], descendants: true, read: ElementRef, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-download-text-view\">\n <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n <div class=\"dbx-download-text-view-content\">\n @if (showTitle()) {\n <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n }\n @if (showPreview()) {\n <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n }\n <div class=\"dbx-download-text-view-actions\">\n <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n <dbx-button-spacer></dbx-button-spacer>\n <a #downloadButton [href]=\"fileUrlSignal()\" [attr.download]=\"fileNameSignal()\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!downloadReadySignal()\" [disabled]=\"!downloadReadySignal()\"></dbx-button></a>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: DbxLoadingComponent, selector: "dbx-loading", inputs: ["padding", "show", "text", "mode", "color", "diameter", "linear", "loading", "error", "context"] }, { kind: "ngmodule", type: DbxActionModule }, { kind: "directive", type: i1.DbxActionDirective, selector: "dbx-action,[dbxAction],dbx-action-context,[dbxActionContext]", exportAs: ["action", "dbxAction"] }, { kind: "directive", type: i1.DbxActionHandlerDirective, selector: "[dbxActionHandler]", inputs: ["dbxActionHandler"] }, { kind: "directive", type: i1.DbxActionValueDirective, selector: "dbxActionValue,[dbxActionValue]", inputs: ["dbxActionValue"] }, { kind: "directive", type: i1.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
111
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxDownloadTextViewComponent, isStandalone: true, selector: "dbx-download-text-view", inputs: { loadingText: { classPropertyName: "loadingText", publicName: "loadingText", isSignal: true, isRequired: false, transformFunction: null }, linear: { classPropertyName: "linear", publicName: "linear", isSignal: true, isRequired: false, transformFunction: null }, showTitle: { classPropertyName: "showTitle", publicName: "showTitle", isSignal: true, isRequired: false, transformFunction: null }, showPreview: { classPropertyName: "showPreview", publicName: "showPreview", isSignal: true, isRequired: false, transformFunction: null }, content: { classPropertyName: "content", publicName: "content", isSignal: true, isRequired: false, transformFunction: null }, contentState: { classPropertyName: "contentState", publicName: "contentState", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "downloadButton", first: true, predicate: ["downloadButton"], descendants: true, read: ElementRef, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-download-text-view\">\n <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n <div class=\"dbx-download-text-view-content\">\n @if (showTitle()) {\n <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n }\n @if (showPreview()) {\n <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n }\n <div class=\"dbx-download-text-view-actions\">\n <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n <dbx-button-spacer></dbx-button-spacer>\n <a #downloadButton [href]=\"fileUrlSignal()\" [attr.download]=\"fileNameSignal()\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!downloadReadySignal()\" [disabled]=\"!downloadReadySignal()\"></dbx-button></a>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: DbxLoadingComponent, selector: "dbx-loading", inputs: ["padding", "show", "text", "mode", "color", "diameter", "linear", "loading", "error", "context"] }, { kind: "ngmodule", type: DbxActionModule }, { kind: "directive", type: i1.DbxActionDirective, selector: "dbx-action,[dbxAction],dbx-action-context,[dbxActionContext]", exportAs: ["action", "dbxAction"] }, { kind: "directive", type: i1.DbxActionHandlerDirective, selector: "[dbxActionHandler]", inputs: ["dbxActionHandler"] }, { kind: "directive", type: i1.DbxActionValueDirective, selector: "dbxActionValue,[dbxActionValue]", inputs: ["dbxActionValue"] }, { kind: "directive", type: i1.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
112
112
|
}
|
|
113
113
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDownloadTextViewComponent, decorators: [{
|
|
114
114
|
type: Component,
|
|
115
115
|
args: [{ selector: 'dbx-download-text-view', standalone: true, imports: [NgTemplateOutlet, DbxLoadingComponent, DbxActionModule, DbxActionButtonDirective, DbxButtonComponent, DbxButtonSpacerDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dbx-download-text-view\">\n <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n <div class=\"dbx-download-text-view-content\">\n @if (showTitle()) {\n <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n }\n @if (showPreview()) {\n <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n }\n <div class=\"dbx-download-text-view-actions\">\n <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n <dbx-button-spacer></dbx-button-spacer>\n <a #downloadButton [href]=\"fileUrlSignal()\" [attr.download]=\"fileNameSignal()\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!downloadReadySignal()\" [disabled]=\"!downloadReadySignal()\"></dbx-button></a>\n </div>\n </div>\n</ng-template>\n" }]
|
|
116
116
|
}] });
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"download.text.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.ts","../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, computed, inject, input, viewChild } from '@angular/core';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { WorkUsingObservable, LoadingState, loadingStateContext, successResult, valueFromFinishedLoadingState, MaybeObservableOrValue, maybeValueFromObservableOrValue } from '@dereekb/rxjs';\nimport { MS_IN_SECOND, type Maybe } from '@dereekb/util';\nimport { Observable, first, of, shareReplay, switchMap, tap } from 'rxjs';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { DownloadTextContent } from './download.text';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { AbstractSubscriptionDirective, DbxActionButtonDirective } from '@dereekb/dbx-core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { DbxLoadingComponent } from '../../../loading/loading.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { DbxButtonComponent } from '../../../button/button.component';\nimport { DbxActionModule } from '../../../action/action.module';\nimport { DbxButtonSpacerDirective } from '../../../button/button.spacer.directive';\n\n/**\n * DbxStructureDirective used specifically on the body of the app.\n */\n@Component({\n  templateUrl: './download.text.component.html',\n  selector: 'dbx-download-text-view',\n  standalone: true,\n  imports: [NgTemplateOutlet, DbxLoadingComponent, DbxActionModule, DbxActionButtonDirective, DbxButtonComponent, DbxButtonSpacerDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective {\n  private readonly _clipboard = inject(Clipboard);\n  private readonly _matSnackbar = inject(MatSnackBar);\n  private readonly _sanitizer = inject(DomSanitizer);\n\n  readonly downloadButton = viewChild<string, Maybe<ElementRef>>('downloadButton', { read: ElementRef });\n\n  readonly loadingText = input<Maybe<string>>(undefined);\n  readonly linear = input<Maybe<boolean>>(undefined);\n  readonly showTitle = input<boolean>(true);\n  readonly showPreview = input<boolean>(true);\n\n  readonly content = input<Maybe<DownloadTextContent>>(undefined);\n  readonly contentState = input<MaybeObservableOrValue<LoadingState<DownloadTextContent>>>(undefined);\n\n  readonly contentState$ = toObservable(this.contentState).pipe(maybeValueFromObservableOrValue(), shareReplay(1));\n\n  readonly contentStateSignal = toSignal(this.contentState$);\n\n  readonly contentLoadingStateSignal = computed(() => {\n    const content = this.content();\n    const contentState = this.contentStateSignal();\n\n    let result: Maybe<LoadingState<DownloadTextContent>>;\n\n    if (contentState) {\n      result = contentState;\n    } else if (content) {\n      result = successResult(content);\n    }\n\n    return result;\n  });\n\n  readonly contentLoadingState$ = toObservable(this.contentLoadingStateSignal);\n  readonly content$: Observable<Maybe<DownloadTextContent>> = this.contentLoadingState$.pipe(\n    switchMap((x) => {\n      if (x) {\n        return of(x).pipe(valueFromFinishedLoadingState());\n      } else {\n        return of(undefined);\n      }\n    })\n  );\n\n  readonly contentSignal = toSignal(this.content$);\n\n  readonly contentDataSignal = computed(() => this.contentSignal()?.content);\n\n  readonly fileUrlSignal = computed(() => {\n    const content = this.contentSignal();\n\n    let fileUrl: Maybe<SafeResourceUrl> = undefined;\n\n    if (content) {\n      const blob = new Blob([content.content], { type: content.mimeType ?? 'application/octet-stream' });\n      fileUrl = this._sanitizer.bypassSecurityTrustResourceUrl(window.URL.createObjectURL(blob));\n    }\n\n    return fileUrl;\n  });\n\n  readonly fileNameSignal = computed(() => this.contentSignal()?.name ?? 'File');\n\n  readonly downloadReadySignal = computed(() => {\n    const downloadButton = this.downloadButton();\n    const fileName = this.fileNameSignal();\n    const fileUrl = this.fileUrlSignal();\n    return Boolean(downloadButton && fileName && fileUrl);\n  });\n\n  readonly context = loadingStateContext({ obs: this.contentLoadingState$ });\n\n  readonly handleCopyToClipboard: WorkUsingObservable = () => {\n    return this.content$.pipe(\n      first(),\n      switchMap((downloadTextContent: Maybe<DownloadTextContent>) => {\n        if (downloadTextContent) {\n          return new Promise<boolean>((resolve, reject) => {\n            const pending = this._clipboard.beginCopy(downloadTextContent.content);\n\n            let secondsRemainingForCopy = 20; // attempt to copy for up to 20 seconds\n\n            const attempt = () => {\n              const copyIsFinished = pending.copy();\n\n              if (!copyIsFinished && --secondsRemainingForCopy) {\n                setTimeout(attempt, MS_IN_SECOND);\n              } else {\n                // Remember to destroy when you're done!\n                pending.destroy();\n\n                if (copyIsFinished) {\n                  resolve(true);\n                } else {\n                  reject(false);\n                }\n              }\n            };\n\n            attempt();\n          });\n        } else {\n          return of(false);\n        }\n      }),\n      tap((success) => {\n        if (success) {\n          this._matSnackbar.open('Copied to clipboard', undefined, { duration: 3 * MS_IN_SECOND });\n        } else {\n          this._matSnackbar.open('Content failed to copy...', undefined, { duration: 3 * MS_IN_SECOND });\n        }\n      })\n    );\n  };\n}\n","<div class=\"dbx-download-text-view\">\n  <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n    <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n  </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n  <div class=\"dbx-download-text-view-content\">\n    @if (showTitle()) {\n      <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n    }\n    @if (showPreview()) {\n      <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n    }\n    <div class=\"dbx-download-text-view-actions\">\n      <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n      <dbx-button-spacer></dbx-button-spacer>\n      <a #downloadButton [href]=\"fileUrlSignal()\" [attr.download]=\"fileNameSignal()\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!downloadReadySignal()\" [disabled]=\"!downloadReadySignal()\"></dbx-button></a>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"download.text.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.ts","../../../../../../../../packages/dbx-web/src/lib/extension/download/text/download.text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, computed, inject, input, viewChild } from '@angular/core';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { WorkUsingObservable, LoadingState, loadingStateContext, successResult, valueFromFinishedLoadingState, MaybeObservableOrValue, maybeValueFromObservableOrValue } from '@dereekb/rxjs';\nimport { MS_IN_SECOND, type Maybe } from '@dereekb/util';\nimport { Observable, first, of, shareReplay, switchMap, tap } from 'rxjs';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { DownloadTextContent } from './download.text';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { AbstractSubscriptionDirective, DbxActionButtonDirective } from '@dereekb/dbx-core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { DbxLoadingComponent } from '../../../loading/loading.component';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { DbxButtonComponent } from '../../../button/button.component';\nimport { DbxActionModule } from '../../../action/action.module';\nimport { DbxButtonSpacerDirective } from '../../../button/button.spacer.directive';\n\n/**\n * DbxStructureDirective used specifically on the body of the app.\n */\n@Component({\n  templateUrl: './download.text.component.html',\n  selector: 'dbx-download-text-view',\n  standalone: true,\n  imports: [NgTemplateOutlet, DbxLoadingComponent, DbxActionModule, DbxActionButtonDirective, DbxButtonComponent, DbxButtonSpacerDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective {\n  private readonly _clipboard = inject(Clipboard);\n  private readonly _matSnackbar = inject(MatSnackBar);\n  private readonly _sanitizer = inject(DomSanitizer);\n\n  readonly downloadButton = viewChild<string, Maybe<ElementRef>>('downloadButton', { read: ElementRef });\n\n  readonly loadingText = input<Maybe<string>>(undefined);\n  readonly linear = input<Maybe<boolean>>(undefined);\n  readonly showTitle = input<boolean>(true);\n  readonly showPreview = input<boolean>(true);\n\n  readonly content = input<Maybe<DownloadTextContent>>(undefined);\n  readonly contentState = input<MaybeObservableOrValue<LoadingState<DownloadTextContent>>>(undefined);\n\n  readonly contentState$ = toObservable(this.contentState).pipe(maybeValueFromObservableOrValue(), shareReplay(1));\n\n  readonly contentStateSignal = toSignal(this.contentState$);\n\n  readonly contentLoadingStateSignal = computed(() => {\n    const content = this.content();\n    const contentState = this.contentStateSignal();\n\n    let result: Maybe<LoadingState<DownloadTextContent>>;\n\n    if (contentState) {\n      result = contentState;\n    } else if (content) {\n      result = successResult(content);\n    }\n\n    return result;\n  });\n\n  readonly contentLoadingState$ = toObservable(this.contentLoadingStateSignal);\n  readonly content$: Observable<Maybe<DownloadTextContent>> = this.contentLoadingState$.pipe(\n    switchMap((x) => {\n      if (x) {\n        return of(x).pipe(valueFromFinishedLoadingState());\n      } else {\n        return of(undefined);\n      }\n    })\n  );\n\n  readonly contentSignal = toSignal(this.content$);\n\n  readonly contentDataSignal = computed(() => this.contentSignal()?.content);\n\n  readonly fileUrlSignal = computed(() => {\n    const content = this.contentSignal();\n\n    let fileUrl: Maybe<SafeResourceUrl> = undefined;\n\n    if (content) {\n      const blob = new Blob([content.content], { type: content.mimeType ?? 'application/octet-stream' });\n      fileUrl = this._sanitizer.bypassSecurityTrustResourceUrl(window.URL.createObjectURL(blob));\n    }\n\n    return fileUrl;\n  });\n\n  readonly fileNameSignal = computed(() => this.contentSignal()?.name ?? 'File');\n\n  readonly downloadReadySignal = computed(() => {\n    const downloadButton = this.downloadButton();\n    const fileName = this.fileNameSignal();\n    const fileUrl = this.fileUrlSignal();\n    return Boolean(downloadButton && fileName && fileUrl);\n  });\n\n  readonly context = loadingStateContext({ obs: this.contentLoadingState$ });\n\n  readonly handleCopyToClipboard: WorkUsingObservable = () => {\n    return this.content$.pipe(\n      first(),\n      switchMap((downloadTextContent: Maybe<DownloadTextContent>) => {\n        if (downloadTextContent) {\n          return new Promise<boolean>((resolve, reject) => {\n            const pending = this._clipboard.beginCopy(downloadTextContent.content);\n\n            let secondsRemainingForCopy = 20; // attempt to copy for up to 20 seconds\n\n            const attempt = () => {\n              const copyIsFinished = pending.copy();\n\n              if (!copyIsFinished && --secondsRemainingForCopy) {\n                setTimeout(attempt, MS_IN_SECOND);\n              } else {\n                // Remember to destroy when you're done!\n                pending.destroy();\n\n                if (copyIsFinished) {\n                  resolve(true);\n                } else {\n                  reject(false);\n                }\n              }\n            };\n\n            attempt();\n          });\n        } else {\n          return of(false);\n        }\n      }),\n      tap((success) => {\n        if (success) {\n          this._matSnackbar.open('Copied to clipboard', undefined, { duration: 3 * MS_IN_SECOND });\n        } else {\n          this._matSnackbar.open('Content failed to copy...', undefined, { duration: 3 * MS_IN_SECOND });\n        }\n      })\n    );\n  };\n}\n","<div class=\"dbx-download-text-view\">\n  <dbx-loading [context]=\"context\" [linear]=\"linear()\" [text]=\"loadingText()\">\n    <ng-container *ngTemplateOutlet=\"contentView\"></ng-container>\n  </dbx-loading>\n</div>\n\n<!-- Template -->\n<ng-template #contentView>\n  <div class=\"dbx-download-text-view-content\">\n    @if (showTitle()) {\n      <div class=\"dbx-download-text-view-content-title dbx-mb2 mat-subtitle-2\">{{ fileNameSignal() }}</div>\n    }\n    @if (showPreview()) {\n      <div class=\"dbx-download-text-preview dbx-json dbx-content-pit dbx-content-pit-scrollable dbx-mb3\">{{ contentDataSignal() }}</div>\n    }\n    <div class=\"dbx-download-text-view-actions\">\n      <dbx-button dbxAction dbxActionValue [raised]=\"true\" [dbxActionHandler]=\"handleCopyToClipboard\" icon=\"content_copy\" dbxActionButton text=\"Copy To Clipboard\"></dbx-button>\n      <dbx-button-spacer></dbx-button-spacer>\n      <a #downloadButton [href]=\"fileUrlSignal()\" [attr.download]=\"fileNameSignal()\"><dbx-button icon=\"download\" text=\"Download\" [raised]=\"true\" [working]=\"!downloadReadySignal()\" [disabled]=\"!downloadReadySignal()\"></dbx-button></a>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -37,10 +37,10 @@ export class DbxFilterWrapperComponent extends AbstractDbxActionHandlerDirective
|
|
|
37
37
|
this.filterSourceDirective.resetFilter();
|
|
38
38
|
}
|
|
39
39
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFilterWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
40
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxFilterWrapperComponent, isStandalone: true, selector: "dbx-filter-wrapper", inputs: { showButtons: { classPropertyName: "showButtons", publicName: "showButtons", isSignal: true, isRequired: false, transformFunction: null }, applyRaised: { classPropertyName: "applyRaised", publicName: "applyRaised", isSignal: true, isRequired: false, transformFunction: null }, applyIcon: { classPropertyName: "applyIcon", publicName: "applyIcon", isSignal: true, isRequired: false, transformFunction: null }, applyText: { classPropertyName: "applyText", publicName: "applyText", isSignal: true, isRequired: false, transformFunction: null } }, providers: [provideActionStoreSource(null)], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n @if (showButtons()) {\n <div fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised()\" [text]=\"applyText()\" [icon]=\"applyIcon()\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n }\n</div>\n", dependencies: [{ kind: "ngmodule", type: DbxButtonModule }, { kind: "directive", type: i1.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: i2.DbxButtonComponent, selector: "dbx-button", inputs: ["type", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FlexLayoutModule }, { kind: "directive", type: i5.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
40
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxFilterWrapperComponent, isStandalone: true, selector: "dbx-filter-wrapper", inputs: { showButtons: { classPropertyName: "showButtons", publicName: "showButtons", isSignal: true, isRequired: false, transformFunction: null }, applyRaised: { classPropertyName: "applyRaised", publicName: "applyRaised", isSignal: true, isRequired: false, transformFunction: null }, applyIcon: { classPropertyName: "applyIcon", publicName: "applyIcon", isSignal: true, isRequired: false, transformFunction: null }, applyText: { classPropertyName: "applyText", publicName: "applyText", isSignal: true, isRequired: false, transformFunction: null } }, providers: [provideActionStoreSource(null)], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n @if (showButtons()) {\n <div fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised()\" [text]=\"applyText()\" [icon]=\"applyIcon()\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n }\n</div>\n", dependencies: [{ kind: "ngmodule", type: DbxButtonModule }, { kind: "directive", type: i1.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: i2.DbxButtonComponent, selector: "dbx-button", inputs: ["type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FlexLayoutModule }, { kind: "directive", type: i5.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
41
41
|
}
|
|
42
42
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFilterWrapperComponent, decorators: [{
|
|
43
43
|
type: Component,
|
|
44
44
|
args: [{ selector: 'dbx-filter-wrapper', providers: [provideActionStoreSource(null)], standalone: true, imports: [DbxButtonModule, MatButtonModule, MatIconModule, FlexLayoutModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dbx-filter-wrapper\">\n <div class=\"dbx-filter-wrapper-content\">\n <ng-content></ng-content>\n </div>\n @if (showButtons()) {\n <div fxLayout=\"row\">\n <dbx-button dbxActionButton [raised]=\"applyRaised()\" [text]=\"applyText()\" [icon]=\"applyIcon()\"></dbx-button>\n <div class=\"spacer\"></div>\n <button mat-icon-button (click)=\"resetFilter()\">\n <mat-icon>clear</mat-icon>\n </button>\n </div>\n }\n</div>\n" }]
|
|
45
45
|
}], ctorParameters: () => [] });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLndyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL2ZpbHRlci9maWx0ZXIud3JhcHBlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvaW50ZXJhY3Rpb24vZmlsdGVyL2ZpbHRlci53cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRixPQUFPLEVBQUUsaUNBQWlDLEVBQUUscUJBQXFCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN2SCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7Ozs7OztBQUd6RDs7OztHQUlHO0FBU0gsTUFBTSxPQUFPLHlCQUF1QyxTQUFRLGlDQUFvQztJQUNyRixxQkFBcUIsR0FBRyxNQUFNLENBQUMsQ0FBQSxxQkFBd0IsQ0FBQSxDQUFDLENBQUM7SUFFekQsV0FBVyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixXQUFXLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLFNBQVMsR0FBRyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDakMsU0FBUyxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUVyQztRQUNFLEtBQUssRUFBRSxDQUFDO1FBRVIsNkJBQTZCO1FBQzdCLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLE1BQVMsRUFBRSxRQUFrQyxFQUFFLEVBQUU7WUFDbEcsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM3QyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLDBCQUEwQjtRQUMzRCxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzNDLENBQUM7d0dBekJVLHlCQUF5Qjs0RkFBekIseUJBQXlCLHltQkFMekIsQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxpRENoQjdDLHdkQWNBLDJDRElZLGVBQWUsb1hBQUUsZUFBZSwySUFBRSxhQUFhLG1MQUFFLGdCQUFnQjs7NEZBR2hFLHlCQUF5QjtrQkFSckMsU0FBUzsrQkFDRSxvQkFBb0IsYUFFbkIsQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxjQUMvQixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsQ0FBQyxtQkFDM0QsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGJ4QWN0aW9uSGFuZGxlckRpcmVjdGl2ZSwgRmlsdGVyU291cmNlRGlyZWN0aXZlLCBwcm92aWRlQWN0aW9uU3RvcmVTb3VyY2UgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgRGJ4QnV0dG9uTW9kdWxlIH0gZnJvbSAnLi4vLi4vYnV0dG9uL2J1dHRvbi5tb2R1bGUnO1xuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dCc7XG5pbXBvcnQgeyBXb3JrSW5zdGFuY2UgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcblxuLyoqXG4gKiBBY3Rpb24gY29tcG9uZW50IHVzZWQgdG8gc2ltcGxpZnkgY3JlYXRpbmcgYSBmaWx0ZXIgZm9ybS5cbiAqXG4gKiBQcm92aWRlcyBhIERieEFjdGlvbiBhbmQgY29uZmlndXJlcyB0aGUgYWN0aW9uIHRvIHNldCB0aGUgZmlsdGVyIG9uIGEgRmlsdGVyU291cmNlRGlyZWN0aXZlIHdoZW4gdHJpZ2dlcmVkLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtZmlsdGVyLXdyYXBwZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLndyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtwcm92aWRlQWN0aW9uU3RvcmVTb3VyY2UobnVsbCldLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4QnV0dG9uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUsIEZsZXhMYXlvdXRNb2R1bGVdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBEYnhGaWx0ZXJXcmFwcGVyQ29tcG9uZW50PEYgPSB1bmtub3duPiBleHRlbmRzIEFic3RyYWN0RGJ4QWN0aW9uSGFuZGxlckRpcmVjdGl2ZTxGPiB7XG4gIHJlYWRvbmx5IGZpbHRlclNvdXJjZURpcmVjdGl2ZSA9IGluamVjdChGaWx0ZXJTb3VyY2VEaXJlY3RpdmU8Rj4pO1xuXG4gIHJlYWRvbmx5IHNob3dCdXR0b25zID0gaW5wdXQodHJ1ZSk7XG4gIHJlYWRvbmx5IGFwcGx5UmFpc2VkID0gaW5wdXQodHJ1ZSk7XG4gIHJlYWRvbmx5IGFwcGx5SWNvbiA9IGlucHV0KCdmaWx0ZXJfbGlzdCcpO1xuICByZWFkb25seSBhcHBseVRleHQgPSBpbnB1dCgnRmlsdGVyJyk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIC8vIGNvbmZpZ3VyZSBoYW5kbGVyIGZ1bmN0aW9uXG4gICAgdGhpcy5fZGJ4QWN0aW9uSGFuZGxlckluc3RhbmNlLnNldEhhbmRsZXJGdW5jdGlvbigoZmlsdGVyOiBGLCBpbnN0YW5jZTogV29ya0luc3RhbmNlPEYsIHVua25vd24+KSA9PiB7XG4gICAgICB0aGlzLmZpbHRlclNvdXJjZURpcmVjdGl2ZS5zZXRGaWx0ZXIoZmlsdGVyKTtcbiAgICAgIGluc3RhbmNlLnN1Y2Nlc3ModHJ1ZSk7XG4gICAgfSk7XG4gIH1cblxuICBhcHBseUZpbHRlcigpOiB2b2lkIHtcbiAgICB0aGlzLnNvdXJjZS5zZXRJc01vZGlmaWVkKHRydWUpOyAvLyBGb3JjZSBzZXR0aW5nIG1vZGlmaWVkLlxuICAgIHRoaXMuc291cmNlLnRyaWdnZXIoKTtcbiAgfVxuXG4gIHJlc2V0RmlsdGVyKCk6IHZvaWQge1xuICAgIHRoaXMuZmlsdGVyU291cmNlRGlyZWN0aXZlLnJlc2V0RmlsdGVyKCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJkYngtZmlsdGVyLXdyYXBwZXJcIj5cbiAgPGRpdiBjbGFzcz1cImRieC1maWx0ZXItd3JhcHBlci1jb250ZW50XCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbiAgQGlmIChzaG93QnV0dG9ucygpKSB7XG4gICAgPGRpdiBmeExheW91dD1cInJvd1wiPlxuICAgICAgPGRieC1idXR0b24gZGJ4QWN0aW9uQnV0dG9uIFtyYWlzZWRdPVwiYXBwbHlSYWlzZWQoKVwiIFt0ZXh0XT1cImFwcGx5VGV4dCgpXCIgW2ljb25dPVwiYXBwbHlJY29uKClcIj48L2RieC1idXR0b24+XG4gICAgICA8ZGl2IGNsYXNzPVwic3BhY2VyXCI+PC9kaXY+XG4gICAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwicmVzZXRGaWx0ZXIoKVwiPlxuICAgICAgICA8bWF0LWljb24+Y2xlYXI8L21hdC1pY29uPlxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuIl19
|
|
@@ -52,7 +52,7 @@ export class DbxPopupControlButtonsComponent {
|
|
|
52
52
|
}
|
|
53
53
|
<dbx-button-spacer></dbx-button-spacer>
|
|
54
54
|
<dbx-button [flat]="true" icon="close" color="warn" (buttonClick)="closeClicked()"></dbx-button>
|
|
55
|
-
`, isInline: true, dependencies: [{ kind: "ngmodule", type: DbxButtonModule }, { kind: "component", type: i1.DbxButtonComponent, selector: "dbx-button", inputs: ["type", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: i2.DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
55
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: DbxButtonModule }, { kind: "component", type: i1.DbxButtonComponent, selector: "dbx-button", inputs: ["type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: i2.DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
56
56
|
}
|
|
57
57
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxPopupControlButtonsComponent, decorators: [{
|
|
58
58
|
type: Component,
|
|
@@ -16,7 +16,7 @@ export class DbxPromptConfirmDialogComponent extends AbstractDialogDirective {
|
|
|
16
16
|
}
|
|
17
17
|
static openDialog(matDialog, config) {
|
|
18
18
|
const dialogRef = matDialog.open(DbxPromptConfirmDialogComponent, {
|
|
19
|
-
data: config
|
|
19
|
+
data: config ?? DEFAULT_DBX_PROMPT_CONFIRM_DIALOG_CONFIG
|
|
20
20
|
});
|
|
21
21
|
return dialogRef;
|
|
22
22
|
}
|
|
@@ -50,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
50
50
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
51
51
|
}]
|
|
52
52
|
}] });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvbXB0LmNvbmZpcm0uZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9wcm9tcHQvcHJvbXB0LmNvbmZpcm0uZGlhbG9nLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUscUJBQXFCLEVBQStCLE1BQU0sbUJBQW1CLENBQUM7QUFDdkYsT0FBTyxFQUFFLFNBQVMsRUFBRSx1QkFBdUIsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUM5RSxPQUFPLEVBQUUseUJBQXlCLEVBQTBCLE1BQU0sNEJBQTRCLENBQUM7QUFFL0YsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7O0FBRS9FLE1BQU0sQ0FBQyxNQUFNLHdDQUF3QyxHQUFHO0lBQ3RELEtBQUssRUFBRSxVQUFVO0NBQ2xCLENBQUM7QUFrQkYsTUFBTSxPQUFPLCtCQUFnQyxTQUFRLHVCQUE4RDtJQUNqSCxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUVELElBQUksZUFBZTtRQUNqQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzdCLENBQUM7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLFNBQW9CLEVBQUUsTUFBNEM7UUFDbEYsTUFBTSxTQUFTLEdBQUcsU0FBUyxDQUFDLElBQUksQ0FBQywrQkFBK0IsRUFBRTtZQUNoRSxJQUFJLEVBQUUsTUFBTSxJQUFJLHdDQUF3QztTQUN6RCxDQUFDLENBQUM7UUFFSCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkIsQ0FBQztJQUVELE1BQU07UUFDSixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BCLENBQUM7d0dBdkJVLCtCQUErQjs0RkFBL0IsK0JBQStCLCtGQVhoQzs7Ozs7O0dBTVQsNERBRVMseUJBQXlCLHlIQUFFLHlCQUF5QixtSEFBRSxxQkFBcUI7OzRGQUcxRSwrQkFBK0I7a0JBWjNDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFOzs7Ozs7R0FNVDtvQkFDRCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMseUJBQXlCLEVBQUUseUJBQXlCLEVBQUUscUJBQXFCLENBQUM7b0JBQ3RGLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hdERpYWxvZywgTWF0RGlhbG9nUmVmIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudCwgRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBYnN0cmFjdERpYWxvZ0RpcmVjdGl2ZSB9IGZyb20gJy4uL2RpYWxvZy9hYnN0cmFjdC5kaWFsb2cuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieFByb21wdENvbmZpcm1Db21wb25lbnQsIERieFByb21wdENvbmZpcm1Db25maWcgfSBmcm9tICcuL3Byb21wdC5jb25maXJtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhEaWFsb2dDb250ZW50RGlyZWN0aXZlIH0gZnJvbSAnLi4vZGlhbG9nL2RpYWxvZy5jb250ZW50LmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0RCWF9QUk9NUFRfQ09ORklSTV9ESUFMT0dfQ09ORklHID0ge1xuICB0aXRsZTogJ0NvbmZpcm0/J1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBEYnhQcm9tcHRDb25maXJtRGlhbG9nQ29uZmlnIGV4dGVuZHMgRGJ4UHJvbXB0Q29uZmlybUNvbmZpZyB7XG4gIGNvbXBvbmVudD86IERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZztcbn1cblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1kaWFsb2ctY29udGVudD5cbiAgICAgIDxkYngtcHJvbXB0LWNvbmZpcm0gW2NvbmZpZ109XCJjb25maWdcIiAoY29uZmlybSk9XCJjb25maXJtKClcIiAoY2FuY2VsKT1cImNhbmNlbCgpXCI+XG4gICAgICAgIDxkYngtaW5qZWN0aW9uIFtjb25maWddPVwiaW5qZWN0aW9uQ29uZmlnXCI+PC9kYngtaW5qZWN0aW9uPlxuICAgICAgPC9kYngtcHJvbXB0LWNvbmZpcm0+XG4gICAgPC9kYngtZGlhbG9nLWNvbnRlbnQ+XG4gIGAsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtEYnhEaWFsb2dDb250ZW50RGlyZWN0aXZlLCBEYnhQcm9tcHRDb25maXJtQ29tcG9uZW50LCBEYnhJbmplY3Rpb25Db21wb25lbnRdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBEYnhQcm9tcHRDb25maXJtRGlhbG9nQ29tcG9uZW50IGV4dGVuZHMgQWJzdHJhY3REaWFsb2dEaXJlY3RpdmU8Ym9vbGVhbiwgRGJ4UHJvbXB0Q29uZmlybURpYWxvZ0NvbmZpZz4gaW1wbGVtZW50cyBPbkluaXQge1xuICBnZXQgY29uZmlnKCk6IERieFByb21wdENvbmZpcm1EaWFsb2dDb25maWcge1xuICAgIHJldHVybiB0aGlzLmRhdGE7XG4gIH1cblxuICBnZXQgaW5qZWN0aW9uQ29uZmlnKCk6IE1heWJlPERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZz4ge1xuICAgIHJldHVybiB0aGlzLmRhdGEuY29tcG9uZW50O1xuICB9XG5cbiAgc3RhdGljIG9wZW5EaWFsb2cobWF0RGlhbG9nOiBNYXREaWFsb2csIGNvbmZpZz86IE1heWJlPERieFByb21wdENvbmZpcm1EaWFsb2dDb25maWc+KTogTWF0RGlhbG9nUmVmPERieFByb21wdENvbmZpcm1EaWFsb2dDb21wb25lbnQsIGJvb2xlYW4+IHtcbiAgICBjb25zdCBkaWFsb2dSZWYgPSBtYXREaWFsb2cub3BlbihEYnhQcm9tcHRDb25maXJtRGlhbG9nQ29tcG9uZW50LCB7XG4gICAgICBkYXRhOiBjb25maWcgPz8gREVGQVVMVF9EQlhfUFJPTVBUX0NPTkZJUk1fRElBTE9HX0NPTkZJR1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIGRpYWxvZ1JlZjtcbiAgfVxuXG4gIGNvbmZpcm0oKTogdm9pZCB7XG4gICAgdGhpcy5jbG9zZSh0cnVlKTtcbiAgfVxuXG4gIGNhbmNlbCgpOiB2b2lkIHtcbiAgICB0aGlzLmNsb3NlKGZhbHNlKTtcbiAgfVxufVxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive,
|
|
1
|
+
import { Directive, inject, input } from '@angular/core';
|
|
2
2
|
import { MatDialog } from '@angular/material/dialog';
|
|
3
3
|
import { from } from 'rxjs';
|
|
4
4
|
import { provideDbxPromptConfirm } from './prompt.confirm';
|
|
@@ -12,14 +12,13 @@ export class AbstractPromptConfirmDirective {
|
|
|
12
12
|
matDialog = inject(MatDialog);
|
|
13
13
|
_currentDialogRef;
|
|
14
14
|
_currentDialogPromise;
|
|
15
|
-
/**
|
|
16
|
-
* Config used when showDialog() is called.
|
|
17
|
-
*/
|
|
18
|
-
config;
|
|
19
15
|
showDialog() {
|
|
16
|
+
return this.showDialogWithConfig(this.getDefaultDialogConfig());
|
|
17
|
+
}
|
|
18
|
+
showDialogWithConfig(config) {
|
|
20
19
|
if (!this._currentDialogPromise) {
|
|
21
20
|
this._currentDialogPromise = new Promise((resolve) => {
|
|
22
|
-
this._currentDialogRef = DbxPromptConfirmDialogComponent.openDialog(this.matDialog,
|
|
21
|
+
this._currentDialogRef = DbxPromptConfirmDialogComponent.openDialog(this.matDialog, config);
|
|
23
22
|
this._currentDialogRef.afterClosed().subscribe((result) => {
|
|
24
23
|
this._currentDialogRef = undefined;
|
|
25
24
|
this._currentDialogPromise = undefined;
|
|
@@ -44,9 +43,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
44
43
|
*/
|
|
45
44
|
export class DbxPromptConfirmDirective extends AbstractPromptConfirmDirective {
|
|
46
45
|
dbxPromptConfirm = input();
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
}
|
|
46
|
+
getDefaultDialogConfig() {
|
|
47
|
+
return this.dbxPromptConfirm();
|
|
48
|
+
}
|
|
50
49
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxPromptConfirmDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
51
50
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxPromptConfirmDirective, isStandalone: true, selector: "[dbxPromptConfirm]", inputs: { dbxPromptConfirm: { classPropertyName: "dbxPromptConfirm", publicName: "dbxPromptConfirm", isSignal: true, isRequired: false, transformFunction: null } }, providers: provideDbxPromptConfirm(DbxPromptConfirmDirective), usesInheritance: true, ngImport: i0 });
|
|
52
51
|
}
|
|
@@ -58,4 +57,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
58
57
|
standalone: true
|
|
59
58
|
}]
|
|
60
59
|
}] });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvbXB0LmNvbmZpcm0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL3Byb21wdC9wcm9tcHQuY29uZmlybS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxTQUFTLEVBQWdCLE1BQU0sMEJBQTBCLENBQUM7QUFFbkUsT0FBTyxFQUFjLElBQUksRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN4QyxPQUFPLEVBQW9CLHVCQUF1QixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFN0UsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBRXBGLGlCQUFpQjtBQUNqQjs7R0FFRztBQUVILE1BQU0sT0FBZ0IsOEJBQThCO0lBQy9CLFNBQVMsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7SUFFekMsaUJBQWlCLENBQTBEO0lBQzNFLHFCQUFxQixDQUFvQjtJQUlqRCxVQUFVO1FBQ1IsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUMsQ0FBQztJQUNsRSxDQUFDO0lBRVMsb0JBQW9CLENBQUMsTUFBcUM7UUFDbEUsSUFBSSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1lBQ2hDLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxJQUFJLE9BQU8sQ0FBVSxDQUFDLE9BQU8sRUFBRSxFQUFFO2dCQUM1RCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsK0JBQStCLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUM7Z0JBQzVGLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFzQixFQUFFLEVBQUU7b0JBQ3hFLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxTQUFTLENBQUM7b0JBQ25DLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxTQUFTLENBQUM7b0JBQ3ZDLE9BQU8sQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDckQsQ0FBQyxDQUFDLENBQUM7WUFDTCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRVMsbUJBQW1CLENBQUMsTUFBZTtRQUMzQyxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO3dHQTdCbUIsOEJBQThCOzRGQUE5Qiw4QkFBOEI7OzRGQUE5Qiw4QkFBOEI7a0JBRG5ELFNBQVM7O0FBaUNWLGtCQUFrQjtBQUNsQjs7R0FFRztBQU1ILE1BQU0sT0FBTyx5QkFBMEIsU0FBUSw4QkFBOEI7SUFDbEUsZ0JBQWdCLEdBQUcsS0FBSyxFQUFpQyxDQUFDO0lBRWhELHNCQUFzQjtRQUN2QyxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO0lBQ2pDLENBQUM7d0dBTFUseUJBQXlCOzRGQUF6Qix5QkFBeUIsc09BSHpCLHVCQUF1QixDQUFDLHlCQUF5QixDQUFDOzs0RkFHbEQseUJBQXlCO2tCQUxyQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFNBQVMsRUFBRSx1QkFBdUIsMkJBQTJCO29CQUM3RCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdERpYWxvZywgTWF0RGlhbG9nUmVmIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IHR5cGUgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IE9ic2VydmFibGUsIGZyb20gfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IERieFByb21wdENvbmZpcm0sIHByb3ZpZGVEYnhQcm9tcHRDb25maXJtIH0gZnJvbSAnLi9wcm9tcHQuY29uZmlybSc7XG5pbXBvcnQgeyBEYnhQcm9tcHRDb25maXJtQ29uZmlnIH0gZnJvbSAnLi9wcm9tcHQuY29uZmlybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4UHJvbXB0Q29uZmlybURpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vcHJvbXB0LmNvbmZpcm0uZGlhbG9nLmNvbXBvbmVudCc7XG5cbi8vIE1BUks6IEFic3RyYWN0XG4vKipcbiAqIERpcmVjdGl2ZSB0aGF0IHdoZW4gdHJpZ2dlcmVkIHNob3dzIGEgZGlhbG9nIHRvIGFjY2VwdCBvciByZWplY3QuXG4gKi9cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0UHJvbXB0Q29uZmlybURpcmVjdGl2ZSBpbXBsZW1lbnRzIERieFByb21wdENvbmZpcm0ge1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgbWF0RGlhbG9nID0gaW5qZWN0KE1hdERpYWxvZyk7XG5cbiAgcHJpdmF0ZSBfY3VycmVudERpYWxvZ1JlZj86IE1hdERpYWxvZ1JlZjxEYnhQcm9tcHRDb25maXJtRGlhbG9nQ29tcG9uZW50LCBib29sZWFuPjtcbiAgcHJpdmF0ZSBfY3VycmVudERpYWxvZ1Byb21pc2U/OiBQcm9taXNlPGJvb2xlYW4+O1xuXG4gIHByb3RlY3RlZCBhYnN0cmFjdCBnZXREZWZhdWx0RGlhbG9nQ29uZmlnKCk6IE1heWJlPERieFByb21wdENvbmZpcm1Db25maWc+O1xuXG4gIHNob3dEaWFsb2coKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuc2hvd0RpYWxvZ1dpdGhDb25maWcodGhpcy5nZXREZWZhdWx0RGlhbG9nQ29uZmlnKCkpO1xuICB9XG5cbiAgcHJvdGVjdGVkIHNob3dEaWFsb2dXaXRoQ29uZmlnKGNvbmZpZzogTWF5YmU8RGJ4UHJvbXB0Q29uZmlybUNvbmZpZz4pOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICBpZiAoIXRoaXMuX2N1cnJlbnREaWFsb2dQcm9taXNlKSB7XG4gICAgICB0aGlzLl9jdXJyZW50RGlhbG9nUHJvbWlzZSA9IG5ldyBQcm9taXNlPGJvb2xlYW4+KChyZXNvbHZlKSA9PiB7XG4gICAgICAgIHRoaXMuX2N1cnJlbnREaWFsb2dSZWYgPSBEYnhQcm9tcHRDb25maXJtRGlhbG9nQ29tcG9uZW50Lm9wZW5EaWFsb2codGhpcy5tYXREaWFsb2csIGNvbmZpZyk7XG4gICAgICAgIHRoaXMuX2N1cnJlbnREaWFsb2dSZWYuYWZ0ZXJDbG9zZWQoKS5zdWJzY3JpYmUoKHJlc3VsdDogTWF5YmU8Ym9vbGVhbj4pID0+IHtcbiAgICAgICAgICB0aGlzLl9jdXJyZW50RGlhbG9nUmVmID0gdW5kZWZpbmVkO1xuICAgICAgICAgIHRoaXMuX2N1cnJlbnREaWFsb2dQcm9taXNlID0gdW5kZWZpbmVkO1xuICAgICAgICAgIHJlc29sdmUodGhpcy5faGFuZGxlRGlhbG9nUmVzdWx0KEJvb2xlYW4ocmVzdWx0KSkpO1xuICAgICAgICB9KTtcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiBmcm9tKHRoaXMuX2N1cnJlbnREaWFsb2dQcm9taXNlKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBfaGFuZGxlRGlhbG9nUmVzdWx0KHJlc3VsdDogYm9vbGVhbik6IGJvb2xlYW4ge1xuICAgIHJldHVybiByZXN1bHQ7XG4gIH1cbn1cblxuLy8gTUFSSzogRGlyZWN0aXZlXG4vKipcbiAqIERpcmVjdGl2ZSB0aGF0IHNob3dzIGEgY29uZmlybWF0aW9uIHNjcmVlbi5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2RieFByb21wdENvbmZpcm1dJyxcbiAgcHJvdmlkZXJzOiBwcm92aWRlRGJ4UHJvbXB0Q29uZmlybShEYnhQcm9tcHRDb25maXJtRGlyZWN0aXZlKSxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhQcm9tcHRDb25maXJtRGlyZWN0aXZlIGV4dGVuZHMgQWJzdHJhY3RQcm9tcHRDb25maXJtRGlyZWN0aXZlIHtcbiAgcmVhZG9ubHkgZGJ4UHJvbXB0Q29uZmlybSA9IGlucHV0PE1heWJlPERieFByb21wdENvbmZpcm1Db25maWc+PigpO1xuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBnZXREZWZhdWx0RGlhbG9nQ29uZmlnKCk6IE1heWJlPERieFByb21wdENvbmZpcm1Db25maWc+IHtcbiAgICByZXR1cm4gdGhpcy5kYnhQcm9tcHRDb25maXJtKCk7XG4gIH1cbn1cbiJdfQ==
|