@dereekb/dbx-web 12.4.4 → 12.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/action/action.confirm.directive.mjs +4 -4
- package/esm2022/lib/action/snackbar/action.snackbar.component.mjs +2 -2
- package/esm2022/lib/action/transition/transition.safety.dialog.component.mjs +2 -2
- package/esm2022/lib/button/button.component.mjs +46 -20
- package/esm2022/lib/button/progress/abstract.progress.button.directive.mjs +53 -7
- package/esm2022/lib/button/progress/bar.button.component.mjs +3 -3
- package/esm2022/lib/button/progress/button.progress.config.mjs +1 -1
- package/esm2022/lib/button/progress/spinner.button.component.mjs +3 -3
- package/esm2022/lib/extension/download/text/download.text.component.mjs +2 -2
- package/esm2022/lib/interaction/filter/filter.wrapper.component.mjs +2 -2
- package/esm2022/lib/interaction/index.mjs +2 -1
- package/esm2022/lib/interaction/popup/popup.controls.buttons.component.mjs +1 -1
- package/esm2022/lib/interaction/upload/abstract.upload.component.mjs +85 -0
- package/esm2022/lib/interaction/upload/index.mjs +8 -0
- package/esm2022/lib/interaction/upload/upload.accept.mjs +72 -0
- package/esm2022/lib/interaction/upload/upload.action.directive.mjs +36 -0
- package/esm2022/lib/interaction/upload/upload.action.mjs +18 -0
- package/esm2022/lib/interaction/upload/upload.area.component.mjs +138 -0
- package/esm2022/lib/interaction/upload/upload.button.component.mjs +81 -0
- package/esm2022/lib/interaction/upload/upload.component.mjs +116 -0
- package/esm2022/lib/layout/avatar/avatar.component.mjs +76 -0
- package/esm2022/lib/layout/avatar/avatar.mjs +7 -0
- package/esm2022/lib/layout/avatar/avatar.service.mjs +78 -0
- package/esm2022/lib/layout/avatar/avatar.view.component.mjs +89 -0
- package/esm2022/lib/layout/avatar/index.mjs +4 -0
- package/esm2022/lib/layout/content/content.pit.directive.mjs +34 -4
- package/esm2022/lib/layout/index.mjs +2 -1
- package/esm2022/lib/loading/basic-loading.component.mjs +32 -5
- package/esm2022/lib/loading/index.mjs +2 -1
- package/esm2022/lib/loading/loading.component.mjs +11 -4
- package/esm2022/lib/loading/loading.mjs +2 -0
- package/fesm2022/dereekb-dbx-web.mjs +930 -47
- package/fesm2022/dereekb-dbx-web.mjs.map +1 -1
- package/lib/action/action.confirm.directive.d.ts +1 -1
- package/lib/button/_button.scss +2 -1
- package/lib/button/button.component.d.ts +5 -1
- package/lib/button/progress/abstract.progress.button.directive.d.ts +9 -5
- package/lib/button/progress/button.progress.config.d.ts +6 -2
- package/lib/interaction/_interaction.scss +4 -0
- package/lib/interaction/index.d.ts +1 -0
- package/lib/interaction/upload/_upload.scss +100 -0
- package/lib/interaction/upload/abstract.upload.component.d.ts +54 -0
- package/lib/interaction/upload/index.d.ts +7 -0
- package/lib/interaction/upload/upload.accept.d.ts +87 -0
- package/lib/interaction/upload/upload.action.d.ts +17 -0
- package/lib/interaction/upload/upload.action.directive.d.ts +17 -0
- package/lib/interaction/upload/upload.area.component.d.ts +22 -0
- package/lib/interaction/upload/upload.button.component.d.ts +24 -0
- package/lib/interaction/upload/upload.component.d.ts +58 -0
- package/lib/layout/_layout.scss +4 -0
- package/lib/layout/avatar/_avatar.scss +102 -0
- package/lib/layout/avatar/avatar.component.d.ts +32 -0
- package/lib/layout/avatar/avatar.d.ts +54 -0
- package/lib/layout/avatar/avatar.service.d.ts +66 -0
- package/lib/layout/avatar/avatar.view.component.d.ts +24 -0
- package/lib/layout/avatar/index.d.ts +3 -0
- package/lib/layout/content/content.pit.directive.d.ts +6 -2
- package/lib/layout/index.d.ts +1 -0
- package/lib/loading/basic-loading.component.d.ts +13 -8
- package/lib/loading/index.d.ts +1 -0
- package/lib/loading/loading.component.d.ts +4 -3
- package/lib/loading/loading.d.ts +10 -0
- package/lib/style/_config.scss +17 -1
- package/lib/style/_root-variables.scss +4 -0
- package/lib/style/_variables.scss +8 -0
- package/package.json +1 -1
|
@@ -12,14 +12,14 @@ import * as i0 from "@angular/core";
|
|
|
12
12
|
export class DbxActionConfirmDirective extends AbstractPromptConfirmDirective {
|
|
13
13
|
source = inject((DbxActionContextStoreSourceInstance), { host: true });
|
|
14
14
|
dbxActionConfirm = input(undefined, { transform: transformEmptyStringInputToUndefined });
|
|
15
|
-
|
|
15
|
+
_sourceSub = new SubscriptionObject();
|
|
16
16
|
ngOnInit() {
|
|
17
|
-
this.
|
|
17
|
+
this._sourceSub.subscription = this.source.triggered$.subscribe(() => {
|
|
18
18
|
this.showDialog();
|
|
19
19
|
});
|
|
20
20
|
}
|
|
21
21
|
ngOnDestroy() {
|
|
22
|
-
this.
|
|
22
|
+
this._sourceSub.destroy();
|
|
23
23
|
}
|
|
24
24
|
getDefaultDialogConfig() {
|
|
25
25
|
return this.dbxActionConfirm();
|
|
@@ -43,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
43
43
|
standalone: true
|
|
44
44
|
}]
|
|
45
45
|
}] });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmNvbmZpcm0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2FjdGlvbi9hY3Rpb24uY29uZmlybS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBcUIsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RSxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUVoRyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLG9DQUFvQyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBYTlHOzs7OztHQUtHO0FBS0gsTUFBTSxPQUFPLHlCQUFvRCxTQUFRLDhCQUE4QjtJQUM1RixNQUFNLEdBQUcsTUFBTSxDQUFDLENBQUEsbUNBQXlDLENBQUEsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBRTNFLGdCQUFnQixHQUFHLEtBQUssQ0FBMEUsU0FBUyxFQUFFLEVBQUUsU0FBUyxFQUFFLG9DQUFvQyxFQUFFLENBQUMsQ0FBQztJQUUxSixVQUFVLEdBQUcsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO0lBRXZELFFBQVE7UUFDTixJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ25FLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNwQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRVMsc0JBQXNCO1FBQzlCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVrQixtQkFBbUIsQ0FBQyxNQUFlO1FBQ3BELElBQUksTUFBTSxFQUFFLENBQUM7WUFDWCxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxVQUEwQixDQUFDLENBQUM7UUFDOUUsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNoQyxDQUFDO1FBRUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQzt3R0E3QlUseUJBQXlCOzRGQUF6Qix5QkFBeUI7OzRGQUF6Qix5QkFBeUI7a0JBSnJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBPbkRlc3Ryb3ksIE9uSW5pdCwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RQcm9tcHRDb25maXJtRGlyZWN0aXZlIH0gZnJvbSAnLi4vaW50ZXJhY3Rpb24vcHJvbXB0L3Byb21wdC5jb25maXJtLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYnhQcm9tcHRDb25maXJtQ29uZmlnIH0gZnJvbSAnLi4vaW50ZXJhY3Rpb24vcHJvbXB0L3Byb21wdC5jb25maXJtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTdWJzY3JpcHRpb25PYmplY3QgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IERieEFjdGlvbkNvbnRleHRTdG9yZVNvdXJjZUluc3RhbmNlLCB0cmFuc2Zvcm1FbXB0eVN0cmluZ0lucHV0VG9VbmRlZmluZWQgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG4vKipcbiAqIERieEFjdGlvbkNvbmZpcm1EaXJlY3RpdmUgY29uZmlndXJhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEYnhBY3Rpb25Db25maXJtQ29uZmlnPFQgPSB1bmtub3duPiBleHRlbmRzIERieFByb21wdENvbmZpcm1Db25maWcge1xuICAvKipcbiAgICogT3B0aW9uYWxseSBzZXQgdGhlIHJlYWR5VmFsdWUgcGFzc2VkIHRvIHRoZSBpbnN0YW5jZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlYWR5VmFsdWU/OiBUO1xufVxuXG4vKipcbiAqIERpcmVjdGl2ZSB0aGF0IHdoZW4gdHJpZ2dlcmVkIHNob3dzIGEgZGlhbG9nIHRvIGFjY2VwdCBvciByZWplY3QuXG4gKlxuICogVGhpcyBvbmx5IHdvcmtzIHRvIHBhc3MgYSByZWFkeSB2YWx1ZSBvciByZWplY3QgdGhyb3VnaCwgbm90IHRvIHdvcmsgd2l0aCBhIGJ1dHRvbi5cbiAqIEZvciBidXR0b24gdXNhZ2UsIHVzZSBhbiBhcHBQcm9tcHRDb25maXJtQnV0dG9uIGRpcmVjdGl2ZS5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2RieEFjdGlvbkNvbmZpcm1dJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhBY3Rpb25Db25maXJtRGlyZWN0aXZlPFQgPSB1bmtub3duLCBPID0gdW5rbm93bj4gZXh0ZW5kcyBBYnN0cmFjdFByb21wdENvbmZpcm1EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHJlYWRvbmx5IHNvdXJjZSA9IGluamVjdChEYnhBY3Rpb25Db250ZXh0U3RvcmVTb3VyY2VJbnN0YW5jZTxULCBPPiwgeyBob3N0OiB0cnVlIH0pO1xuXG4gIHJlYWRvbmx5IGRieEFjdGlvbkNvbmZpcm0gPSBpbnB1dDxNYXliZTxEYnhBY3Rpb25Db25maXJtQ29uZmlnPFQ+PiwgTWF5YmU8RGJ4QWN0aW9uQ29uZmlybUNvbmZpZzxUPiB8ICcnPj4odW5kZWZpbmVkLCB7IHRyYW5zZm9ybTogdHJhbnNmb3JtRW1wdHlTdHJpbmdJbnB1dFRvVW5kZWZpbmVkIH0pO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgX3NvdXJjZVN1YiA9IG5ldyBTdWJzY3JpcHRpb25PYmplY3QoKTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLl9zb3VyY2VTdWIuc3Vic2NyaXB0aW9uID0gdGhpcy5zb3VyY2UudHJpZ2dlcmVkJC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5zaG93RGlhbG9nKCk7XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLl9zb3VyY2VTdWIuZGVzdHJveSgpO1xuICB9XG5cbiAgcHJvdGVjdGVkIGdldERlZmF1bHREaWFsb2dDb25maWcoKTogTWF5YmU8RGJ4UHJvbXB0Q29uZmlybUNvbmZpZz4ge1xuICAgIHJldHVybiB0aGlzLmRieEFjdGlvbkNvbmZpcm0oKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBfaGFuZGxlRGlhbG9nUmVzdWx0KHJlc3VsdDogYm9vbGVhbik6IGJvb2xlYW4ge1xuICAgIGlmIChyZXN1bHQpIHtcbiAgICAgIHRoaXMuc291cmNlLnJlYWR5VmFsdWUodGhpcy5kYnhBY3Rpb25Db25maXJtKCk/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", "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 });
|
|
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: ["bar", "type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab", "mode"] }, { 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", "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 });
|
|
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: ["bar", "type", "buttonStyle", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab", "mode"] }, { 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNpdGlvbi5zYWZldHkuZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9hY3Rpb24vdHJhbnNpdGlvbi90cmFuc2l0aW9uLnNhZmV0eS5kaWFsb2cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDN0YsT0FBTyxFQUEwQix5QkFBeUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ3RILE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ25FLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOztBQUloRjs7R0FFRztBQWVILE1BQU0sT0FBTyxnREFBaUQsU0FBUSx1QkFBdUI7SUFDbEYsTUFBTSxHQUEyQjtRQUN4QyxLQUFLLEVBQUUsaUJBQWlCO1FBQ3hCLE1BQU0sRUFBRSx3Q0FBd0M7UUFDaEQsV0FBVyxFQUFFLE1BQU07UUFDbkIsVUFBVSxFQUFFLGlCQUFpQjtLQUM5QixDQUFDO0lBRUYsT0FBTztRQUNMLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDbEMsQ0FBQzt3R0FkVSxnREFBZ0Q7NEZBQWhELGdEQUFnRCwrRkFiakQ7Ozs7Ozs7O0dBUVQsNERBRVMseUJBQXlCLG1IQUFFLGlCQUFpQixpSEFBRSx1QkFBdUIsNkRBQUUsa0JBQWtCLHVQQUFFLHdCQUF3Qjs7NEZBR2xILGdEQUFnRDtrQkFkNUQsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUU7Ozs7Ozs7O0dBUVQ7b0JBQ0QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixFQUFFLGlCQUFpQixFQUFFLHVCQUF1QixFQUFFLGtCQUFrQixFQUFFLHdCQUF3QixDQUFDO29CQUM5SCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vaW50ZXJhY3Rpb24vZGlhbG9nL2Fic3RyYWN0LmRpYWxvZy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4UHJvbXB0Q29uZmlybUNvbmZpZywgRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2ludGVyYWN0aW9uL3Byb21wdC9wcm9tcHQuY29uZmlybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4RXJyb3JDb21wb25lbnQgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4QWN0aW9uRXJyb3JEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5hY3Rpb24uZGlyZWN0aXZlJztcbmltcG9ydCB7IERieEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uc3BhY2VyLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCB0eXBlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlEaWFsb2dSZXN1bHQgPSAnc3VjY2VzcycgfCAnc3RheScgfCAnZGlzY2FyZCcgfCAnbm9uZSc7XG5cbi8qKlxuICogRGlhbG9nIHRoYXQgaXMgc2hvd24vdHJpZ2dlcmVkIGFzIHBhcnQgb2YgdGhlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlcbiAqL1xuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1wcm9tcHQtY29uZmlybSBbY29uZmlnXT1cImNvbmZpZ1wiIChjb25maXJtKT1cImNvbmZpcm0oKVwiIChjYW5jZWwpPVwiY2FuY2VsKClcIj5cbiAgICAgIDxuZy1jb250YWluZXI+XG4gICAgICAgIDxkYngtZXJyb3IgZGJ4QWN0aW9uRXJyb3I+PC9kYngtZXJyb3I+XG4gICAgICAgIDxkYngtYnV0dG9uIHRleHQ9XCJTYXZlIENoYW5nZXNcIiBkYnhBY3Rpb25CdXR0b24+PC9kYngtYnV0dG9uPlxuICAgICAgICA8ZGJ4LWJ1dHRvbi1zcGFjZXI+PC9kYngtYnV0dG9uLXNwYWNlcj5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvZGJ4LXByb21wdC1jb25maXJtPlxuICBgLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCwgRGJ4RXJyb3JDb21wb25lbnQsIERieEFjdGlvbkVycm9yRGlyZWN0aXZlLCBEYnhCdXR0b25Db21wb25lbnQsIERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZV0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieEFjdGlvblVJUm91dGVyVHJhbnNpdGlvblNhZmV0eURpYWxvZ0NvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcmVhZG9ubHkgY29uZmlnOiBEYnhQcm9tcHRDb25maXJtQ29uZmlnID0ge1xuICAgIHRpdGxlOiAnVW5zYXZlZCBDaGFuZ2VzJyxcbiAgICBwcm9tcHQ6ICdZb3UgaGF2ZSB1bnNhdmVkIGNoYW5nZXMgb24gdGhpcyBwYWdlLicsXG4gICAgY29uZmlybVRleHQ6ICdTdGF5JyxcbiAgICBjYW5jZWxUZXh0OiAnRGlzY2FyZCBDaGFuZ2VzJ1xuICB9O1xuXG4gIGNvbmZpcm0oKTogdm9pZCB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoJ3N0YXknKTtcbiAgfVxuXG4gIGNhbmNlbCgpOiB2b2lkIHtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgnZGlzY2FyZCcpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
|
2
2
|
import { provideDbxButton, AbstractDbxButtonDirective } from '@dereekb/dbx-core';
|
|
3
3
|
import { isDefinedAndNotFalse } from '@dereekb/util';
|
|
4
|
-
import { DbxProgressSpinnerButtonComponent } from './progress';
|
|
4
|
+
import { DbxProgressSpinnerButtonComponent, DbxProgressBarButtonComponent } from './progress';
|
|
5
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
/**
|
|
7
8
|
* @deprecated use DbxButtonType instead.
|
|
@@ -17,6 +18,7 @@ export var DbxButtonDisplayType;
|
|
|
17
18
|
* Complex button that supports loading states.
|
|
18
19
|
*/
|
|
19
20
|
export class DbxButtonComponent extends AbstractDbxButtonDirective {
|
|
21
|
+
bar = input(false, { transform: isDefinedAndNotFalse });
|
|
20
22
|
type = input();
|
|
21
23
|
buttonStyle = input();
|
|
22
24
|
color = input(undefined);
|
|
@@ -30,6 +32,7 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
|
|
|
30
32
|
flat = input(false, { transform: isDefinedAndNotFalse });
|
|
31
33
|
iconOnly = input(false, { transform: isDefinedAndNotFalse });
|
|
32
34
|
fab = input(false, { transform: isDefinedAndNotFalse });
|
|
35
|
+
mode = input();
|
|
33
36
|
typeSignal = computed(() => {
|
|
34
37
|
const style = this.buttonStyle();
|
|
35
38
|
let type = this.type() ?? style?.type;
|
|
@@ -53,37 +56,40 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
|
|
|
53
56
|
configSignal = computed(() => {
|
|
54
57
|
// configure custom style
|
|
55
58
|
const customStyle = {};
|
|
56
|
-
const
|
|
57
|
-
const customButtonColorValue = this.customButtonColor() ??
|
|
59
|
+
const buttonStyle = this.buttonStyle();
|
|
60
|
+
const customButtonColorValue = this.customButtonColor() ?? buttonStyle?.customButtonColor;
|
|
58
61
|
if (customButtonColorValue) {
|
|
59
62
|
customStyle['background'] = customButtonColorValue;
|
|
60
63
|
}
|
|
61
|
-
const customTextColorValue = this.customTextColor() ??
|
|
64
|
+
const customTextColorValue = this.customTextColor() ?? buttonStyle?.customTextColor;
|
|
62
65
|
if (customTextColorValue) {
|
|
63
66
|
customStyle['color'] = customTextColorValue;
|
|
64
67
|
}
|
|
65
|
-
const customSpinnerColorValue = this.customSpinnerColor() ??
|
|
68
|
+
const customSpinnerColorValue = this.customSpinnerColor() ?? buttonStyle?.customSpinnerColor;
|
|
66
69
|
const customSpinnerColor = customSpinnerColorValue ?? customTextColorValue;
|
|
67
|
-
const buttonColor = this.color() ??
|
|
68
|
-
const spinnerColor = this.spinnerColor() ??
|
|
70
|
+
const buttonColor = this.color() ?? buttonStyle?.color;
|
|
71
|
+
const spinnerColor = this.spinnerColor() ?? buttonStyle?.spinnerColor ?? buttonColor;
|
|
69
72
|
const disabledSignalValue = this.disabledSignal();
|
|
70
|
-
const disabled = !this.
|
|
73
|
+
const disabled = !this.isWorkingSignal() && disabledSignalValue; // Only disabled if we're not working, in order to show the animation.
|
|
71
74
|
const iconValue = this.iconSignal();
|
|
72
75
|
const buttonIcon = iconValue ? { fontIcon: iconValue } : undefined;
|
|
73
76
|
const textValue = this.textSignal();
|
|
74
77
|
const isIconOnlyButton = buttonIcon && !textValue;
|
|
75
|
-
const fab = this.fab() ||
|
|
78
|
+
const fab = this.fab() || buttonStyle?.fab;
|
|
79
|
+
const mode = this.mode() ?? buttonStyle?.mode;
|
|
80
|
+
const working = this.workingSignal();
|
|
81
|
+
const buttonType = this.typeSignal();
|
|
76
82
|
const config = {
|
|
77
83
|
fab,
|
|
78
|
-
working
|
|
84
|
+
working,
|
|
79
85
|
buttonIcon,
|
|
80
86
|
customStyle,
|
|
81
87
|
customClass: 'dbx-button ' + (isIconOnlyButton ? 'dbx-button-no-text' : ''),
|
|
82
88
|
text: textValue ?? '',
|
|
83
|
-
buttonType
|
|
89
|
+
buttonType,
|
|
84
90
|
buttonColor,
|
|
85
91
|
barColor: 'accent',
|
|
86
|
-
mode
|
|
92
|
+
mode,
|
|
87
93
|
spinnerColor,
|
|
88
94
|
customSpinnerColor,
|
|
89
95
|
disabled
|
|
@@ -91,25 +97,45 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
|
|
|
91
97
|
return config;
|
|
92
98
|
});
|
|
93
99
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.
|
|
95
|
-
|
|
100
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxButtonComponent, isStandalone: true, selector: "dbx-button", inputs: { bar: { classPropertyName: "bar", publicName: "bar", isSignal: true, isRequired: false, transformFunction: null }, 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 }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null } }, providers: provideDbxButton(DbxButtonComponent), usesInheritance: true, ngImport: i0, template: `
|
|
101
|
+
@if (bar()) {
|
|
102
|
+
<dbx-progress-bar-button (btnClick)="clickButton()" [config]="configSignal()">
|
|
103
|
+
<ng-template [ngTemplateOutlet]="content"></ng-template>
|
|
104
|
+
</dbx-progress-bar-button>
|
|
105
|
+
} @else {
|
|
106
|
+
<dbx-progress-spinner-button (btnClick)="clickButton()" [config]="configSignal()">
|
|
107
|
+
<ng-template [ngTemplateOutlet]="content"></ng-template>
|
|
108
|
+
</dbx-progress-spinner-button>
|
|
109
|
+
}
|
|
110
|
+
<!-- Content -->
|
|
111
|
+
<ng-template #content>
|
|
96
112
|
<ng-content></ng-content>
|
|
97
|
-
</
|
|
98
|
-
`, isInline: true, dependencies: [{ kind: "component", type: DbxProgressSpinnerButtonComponent, selector: "dbx-progress-spinner-button,dbx-spinner-button" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
113
|
+
</ng-template>
|
|
114
|
+
`, isInline: true, dependencies: [{ kind: "component", type: DbxProgressSpinnerButtonComponent, selector: "dbx-progress-spinner-button,dbx-spinner-button" }, { kind: "component", type: DbxProgressBarButtonComponent, selector: "dbx-progress-bar-button,dbx-bar-button" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
99
115
|
}
|
|
100
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxButtonComponent, decorators: [{
|
|
101
117
|
type: Component,
|
|
102
118
|
args: [{
|
|
103
119
|
selector: 'dbx-button',
|
|
104
120
|
template: `
|
|
105
|
-
|
|
121
|
+
@if (bar()) {
|
|
122
|
+
<dbx-progress-bar-button (btnClick)="clickButton()" [config]="configSignal()">
|
|
123
|
+
<ng-template [ngTemplateOutlet]="content"></ng-template>
|
|
124
|
+
</dbx-progress-bar-button>
|
|
125
|
+
} @else {
|
|
126
|
+
<dbx-progress-spinner-button (btnClick)="clickButton()" [config]="configSignal()">
|
|
127
|
+
<ng-template [ngTemplateOutlet]="content"></ng-template>
|
|
128
|
+
</dbx-progress-spinner-button>
|
|
129
|
+
}
|
|
130
|
+
<!-- Content -->
|
|
131
|
+
<ng-template #content>
|
|
106
132
|
<ng-content></ng-content>
|
|
107
|
-
</
|
|
133
|
+
</ng-template>
|
|
108
134
|
`,
|
|
109
135
|
providers: provideDbxButton(DbxButtonComponent),
|
|
110
|
-
imports: [DbxProgressSpinnerButtonComponent],
|
|
136
|
+
imports: [DbxProgressSpinnerButtonComponent, DbxProgressBarButtonComponent, NgTemplateOutlet],
|
|
111
137
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
112
138
|
standalone: true
|
|
113
139
|
}]
|
|
114
140
|
}] });
|
|
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"]}
|
|
141
|
+
//# 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, DbxProgressBarButtonComponent } from './progress';\nimport { ProgressSpinnerMode } from '@angular/material/progress-spinner';\nimport { NgTemplateOutlet } from '@angular/common';\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 mode?: ProgressSpinnerMode;\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    @if (bar()) {\n      <dbx-progress-bar-button (btnClick)=\"clickButton()\" [config]=\"configSignal()\">\n        <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n      </dbx-progress-bar-button>\n    } @else {\n      <dbx-progress-spinner-button (btnClick)=\"clickButton()\" [config]=\"configSignal()\">\n        <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n      </dbx-progress-spinner-button>\n    }\n    <!-- Content -->\n    <ng-template #content>\n      <ng-content></ng-content>\n    </ng-template>\n  `,\n  providers: provideDbxButton(DbxButtonComponent),\n  imports: [DbxProgressSpinnerButtonComponent, DbxProgressBarButtonComponent, NgTemplateOutlet],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxButtonComponent extends AbstractDbxButtonDirective {\n  readonly bar = input<boolean, Maybe<boolean | ''>>(false, { transform: isDefinedAndNotFalse });\n\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 mode = input<Maybe<ProgressSpinnerMode>>();\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 buttonStyle = this.buttonStyle();\n    const customButtonColorValue = this.customButtonColor() ?? buttonStyle?.customButtonColor;\n\n    if (customButtonColorValue) {\n      customStyle['background'] = customButtonColorValue;\n    }\n\n    const customTextColorValue = this.customTextColor() ?? buttonStyle?.customTextColor;\n\n    if (customTextColorValue) {\n      customStyle['color'] = customTextColorValue;\n    }\n\n    const customSpinnerColorValue = this.customSpinnerColor() ?? buttonStyle?.customSpinnerColor;\n    const customSpinnerColor: Maybe<string> = customSpinnerColorValue ?? customTextColorValue;\n\n    const buttonColor = this.color() ?? buttonStyle?.color;\n    const spinnerColor = this.spinnerColor() ?? buttonStyle?.spinnerColor ?? buttonColor;\n\n    const disabledSignalValue = this.disabledSignal();\n    const disabled = !this.isWorkingSignal() && 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() || buttonStyle?.fab;\n\n    const mode = this.mode() ?? buttonStyle?.mode;\n    const working = this.workingSignal();\n    const buttonType = this.typeSignal();\n\n    const config: Configurable<DbxProgressButtonConfig> = {\n      fab,\n      working,\n      buttonIcon,\n      customStyle,\n      customClass: 'dbx-button ' + (isIconOnlyButton ? 'dbx-button-no-text' : ''),\n      text: textValue ?? '',\n      buttonType,\n      buttonColor,\n      barColor: 'accent',\n      mode,\n      spinnerColor,\n      customSpinnerColor,\n      disabled\n    };\n\n    return config;\n  });\n}\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Directive, HostListener, inject, computed, input, output } from '@angular/core';
|
|
2
|
-
import { AbstractSubscriptionDirective } from '@dereekb/dbx-core';
|
|
2
|
+
import { AbstractSubscriptionDirective, dbxActionWorkProgress } from '@dereekb/dbx-core';
|
|
3
|
+
import { isDefinedAndNotFalse } from '@dereekb/util';
|
|
3
4
|
import { DBX_PROGRESS_BUTTON_GLOBAL_CONFIG } from './button.progress.config';
|
|
4
5
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
@@ -75,16 +76,61 @@ export class AbstractProgressButtonDirective extends AbstractSubscriptionDirecti
|
|
|
75
76
|
return classes;
|
|
76
77
|
});
|
|
77
78
|
baseCssClasses$ = toObservable(this.baseCssClassSignal);
|
|
78
|
-
|
|
79
|
-
|
|
79
|
+
workingProgressSignal = computed(() => {
|
|
80
|
+
const working = this.working();
|
|
81
|
+
const config = this.configSignal();
|
|
82
|
+
const configWorking = config?.working;
|
|
83
|
+
const workingProgress = dbxActionWorkProgress([working, configWorking], config?.value);
|
|
84
|
+
return workingProgress;
|
|
85
|
+
});
|
|
86
|
+
isWorkingSignal = computed(() => isDefinedAndNotFalse(this.workingProgressSignal()));
|
|
87
|
+
workingValueSignal = computed(() => {
|
|
88
|
+
const working = this.workingProgressSignal();
|
|
89
|
+
let result;
|
|
90
|
+
if (typeof working === 'number') {
|
|
91
|
+
result = working;
|
|
92
|
+
}
|
|
93
|
+
return result;
|
|
94
|
+
});
|
|
95
|
+
modeSignal = computed(() => {
|
|
96
|
+
const config = this.configSignal();
|
|
97
|
+
const workingValue = this.workingValueSignal();
|
|
98
|
+
const mode = config?.mode;
|
|
99
|
+
let result;
|
|
100
|
+
if (!mode) {
|
|
101
|
+
if (workingValue != null) {
|
|
102
|
+
result = 'determinate';
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
result = 'indeterminate';
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
result = mode;
|
|
110
|
+
}
|
|
111
|
+
return result;
|
|
112
|
+
});
|
|
113
|
+
disabledSignal = computed(() => {
|
|
114
|
+
const disabled = this.disabled();
|
|
115
|
+
const configDisabled = this.configSignal()?.disabled;
|
|
116
|
+
return disabled || configDisabled;
|
|
117
|
+
});
|
|
80
118
|
buttonTypeAttributeSignal = computed(() => {
|
|
81
119
|
const options = this.configSignal();
|
|
82
120
|
return options?.buttonTypeAttribute ?? options?.type;
|
|
83
121
|
});
|
|
84
|
-
buttonDisabledSignal = computed(() =>
|
|
85
|
-
|
|
122
|
+
buttonDisabledSignal = computed(() => {
|
|
123
|
+
const working = this.isWorkingSignal();
|
|
124
|
+
const disabled = this.disabledSignal();
|
|
125
|
+
return working || disabled;
|
|
126
|
+
});
|
|
127
|
+
showProgressSignal = computed(() => {
|
|
128
|
+
const working = this.isWorkingSignal();
|
|
129
|
+
const disabled = this.disabledSignal();
|
|
130
|
+
return working && !disabled;
|
|
131
|
+
});
|
|
86
132
|
handleClick(event) {
|
|
87
|
-
const working = this.
|
|
133
|
+
const working = this.isWorkingSignal();
|
|
88
134
|
const disabled = this.disabledSignal();
|
|
89
135
|
if (!working && !disabled) {
|
|
90
136
|
this.btnClick.emit(event);
|
|
@@ -100,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
100
146
|
type: HostListener,
|
|
101
147
|
args: ['click', ['$event']]
|
|
102
148
|
}] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract.progress.button.directive.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/button/progress/abstract.progress.button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnDestroy, Directive, HostListener, inject, computed, input, Signal, output } from '@angular/core';\nimport { AbstractSubscriptionDirective } from '@dereekb/dbx-core';\nimport { Configurable, CssClass, type Maybe } from '@dereekb/util';\nimport { DbxProgressButtonGlobalConfig, DbxProgressButtonConfig, DbxProgressButtonTargetedConfig, DBX_PROGRESS_BUTTON_GLOBAL_CONFIG } from './button.progress.config';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { DbxButtonType } from '../button.component';\n\n@Directive()\nexport abstract class AbstractProgressButtonDirective extends AbstractSubscriptionDirective implements OnDestroy {\n  private readonly globalConfig = inject<DbxProgressButtonGlobalConfig>(DBX_PROGRESS_BUTTON_GLOBAL_CONFIG, { optional: true }) ?? [];\n\n  readonly btnClick = output<MouseEvent>();\n\n  readonly config = input.required<Maybe<DbxProgressButtonConfig>>();\n  readonly buttonId = input<Maybe<string>>();\n  readonly working = input<Maybe<boolean>>();\n  readonly disabled = input<Maybe<boolean>>();\n\n  readonly globalOptionsSignal: Signal<Maybe<DbxProgressButtonConfig>> = computed(() => {\n    const buttonId = this.buttonId();\n    return buttonId ? this.globalConfig.find((config: DbxProgressButtonTargetedConfig) => config.id === buttonId) : undefined;\n  });\n\n  readonly configSignal = computed<Maybe<DbxProgressButtonConfig>>(() => {\n    const config = this.config();\n    const globalConfig = this.globalOptionsSignal();\n\n    let completeConfig: Maybe<Configurable<DbxProgressButtonConfig>>;\n\n    if (config || globalConfig) {\n      completeConfig = {\n        ...globalConfig,\n        ...config\n      };\n\n      // set the iconOnly property if the buttonType is icon\n      if (completeConfig.buttonType === 'icon') {\n        completeConfig.iconOnly = true;\n      } else if (completeConfig.iconOnly) {\n        completeConfig.buttonType = 'icon';\n      }\n    }\n\n    return completeConfig;\n  });\n\n  readonly baseCssClassSignal = computed(() => {\n    const config = this.configSignal();\n    const classes: CssClass[] = [config?.customClass ?? ''];\n\n    if (config?.fullWidth) {\n      classes.push('fullWidth');\n    }\n\n    if (config?.disabled) {\n      classes.push('disabled');\n    }\n\n    let buttonType: DbxButtonType = 'basic';\n\n    if (config?.buttonType) {\n      buttonType = config.buttonType;\n    } else if (config?.raised) {\n      buttonType = 'raised';\n    } else if (config?.stroked) {\n      buttonType = 'stroked';\n    } else if (config?.flat) {\n      buttonType = 'flat';\n    } else if (config?.iconOnly) {\n      buttonType = 'icon';\n    }\n\n    switch (buttonType) {\n      case 'raised':\n        classes.push('mat-mdc-raised-button mdc-button--raised');\n        break;\n      case 'stroked':\n        classes.push('mat-mdc-outlined-button mdc-button--outlined');\n        break;\n      case 'flat':\n        classes.push('mat-mdc-unelevated-button mdc-button--unelevated');\n        break;\n      default:\n        classes.push('mat-unthemed');\n        break;\n    }\n\n    return classes;\n  });\n\n  readonly baseCssClasses$ = toObservable(this.baseCssClassSignal);\n\n  readonly workingSignal = computed(() => (this.working() || this.configSignal()?.working) ?? false);\n  readonly disabledSignal = computed(() => (this.disabled() || this.configSignal()?.disabled) ?? false);\n\n  readonly buttonTypeAttributeSignal = computed(() => {\n    const options = this.configSignal();\n    return options?.buttonTypeAttribute ?? options?.type;\n  });\n\n  readonly buttonDisabledSignal = computed(() => this.workingSignal() || this.disabledSignal());\n  readonly showProgressSignal = computed(() => this.workingSignal() && !this.disabledSignal());\n\n  @HostListener('click', ['$event'])\n  public handleClick(event: MouseEvent): void {\n    const working = this.workingSignal();\n    const disabled = this.disabledSignal();\n\n    if (!working && !disabled) {\n      this.btnClick.emit(event);\n      event.stopImmediatePropagation();\n    }\n  }\n}\n"]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract.progress.button.directive.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/button/progress/abstract.progress.button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnDestroy, Directive, HostListener, inject, computed, input, Signal, output } from '@angular/core';\nimport { AbstractSubscriptionDirective, dbxActionWorkProgress, type DbxActionWorkProgress, type DbxButtonWorking } from '@dereekb/dbx-core';\nimport { Configurable, CssClass, isDefinedAndNotFalse, type Maybe } from '@dereekb/util';\nimport { DbxProgressButtonGlobalConfig, DbxProgressButtonConfig, DbxProgressButtonTargetedConfig, DBX_PROGRESS_BUTTON_GLOBAL_CONFIG } from './button.progress.config';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { DbxButtonType } from '../button.component';\nimport { type ProgressSpinnerMode } from '@angular/material/progress-spinner';\n\n@Directive()\nexport abstract class AbstractProgressButtonDirective extends AbstractSubscriptionDirective implements OnDestroy {\n  private readonly globalConfig = inject<DbxProgressButtonGlobalConfig>(DBX_PROGRESS_BUTTON_GLOBAL_CONFIG, { optional: true }) ?? [];\n\n  readonly btnClick = output<MouseEvent>();\n\n  readonly config = input.required<Maybe<DbxProgressButtonConfig>>();\n\n  readonly buttonId = input<Maybe<string>>();\n  readonly working = input<Maybe<DbxButtonWorking>>();\n  readonly disabled = input<Maybe<boolean>>();\n\n  readonly globalOptionsSignal: Signal<Maybe<DbxProgressButtonConfig>> = computed(() => {\n    const buttonId = this.buttonId();\n    return buttonId ? this.globalConfig.find((config: DbxProgressButtonTargetedConfig) => config.id === buttonId) : undefined;\n  });\n\n  readonly configSignal = computed<Maybe<DbxProgressButtonConfig>>(() => {\n    const config = this.config();\n    const globalConfig = this.globalOptionsSignal();\n\n    let completeConfig: Maybe<Configurable<DbxProgressButtonConfig>>;\n\n    if (config || globalConfig) {\n      completeConfig = {\n        ...globalConfig,\n        ...config\n      };\n\n      // set the iconOnly property if the buttonType is icon\n      if (completeConfig.buttonType === 'icon') {\n        completeConfig.iconOnly = true;\n      } else if (completeConfig.iconOnly) {\n        completeConfig.buttonType = 'icon';\n      }\n    }\n\n    return completeConfig;\n  });\n\n  readonly baseCssClassSignal = computed(() => {\n    const config = this.configSignal();\n    const classes: CssClass[] = [config?.customClass ?? ''];\n\n    if (config?.fullWidth) {\n      classes.push('fullWidth');\n    }\n\n    if (config?.disabled) {\n      classes.push('disabled');\n    }\n\n    let buttonType: DbxButtonType = 'basic';\n\n    if (config?.buttonType) {\n      buttonType = config.buttonType;\n    } else if (config?.raised) {\n      buttonType = 'raised';\n    } else if (config?.stroked) {\n      buttonType = 'stroked';\n    } else if (config?.flat) {\n      buttonType = 'flat';\n    } else if (config?.iconOnly) {\n      buttonType = 'icon';\n    }\n\n    switch (buttonType) {\n      case 'raised':\n        classes.push('mat-mdc-raised-button mdc-button--raised');\n        break;\n      case 'stroked':\n        classes.push('mat-mdc-outlined-button mdc-button--outlined');\n        break;\n      case 'flat':\n        classes.push('mat-mdc-unelevated-button mdc-button--unelevated');\n        break;\n      default:\n        classes.push('mat-unthemed');\n        break;\n    }\n\n    return classes;\n  });\n\n  readonly baseCssClasses$ = toObservable(this.baseCssClassSignal);\n\n  readonly workingProgressSignal: Signal<DbxButtonWorking> = computed(() => {\n    const working = this.working();\n    const config = this.configSignal();\n    const configWorking = config?.working;\n\n    const workingProgress = dbxActionWorkProgress([working, configWorking], config?.value);\n    return workingProgress;\n  });\n\n  readonly isWorkingSignal = computed(() => isDefinedAndNotFalse(this.workingProgressSignal()));\n\n  readonly workingValueSignal: Signal<Maybe<DbxActionWorkProgress>> = computed(() => {\n    const working = this.workingProgressSignal();\n    let result: Maybe<DbxActionWorkProgress>;\n\n    if (typeof working === 'number') {\n      result = working;\n    }\n\n    return result;\n  });\n\n  readonly modeSignal: Signal<ProgressSpinnerMode> = computed(() => {\n    const config = this.configSignal();\n    const workingValue = this.workingValueSignal();\n\n    const mode = config?.mode;\n    let result: ProgressSpinnerMode;\n\n    if (!mode) {\n      if (workingValue != null) {\n        result = 'determinate';\n      } else {\n        result = 'indeterminate';\n      }\n    } else {\n      result = mode;\n    }\n\n    return result;\n  });\n\n  readonly disabledSignal = computed(() => {\n    const disabled = this.disabled();\n    const configDisabled = this.configSignal()?.disabled;\n    return disabled || configDisabled;\n  });\n\n  readonly buttonTypeAttributeSignal = computed(() => {\n    const options = this.configSignal();\n    return options?.buttonTypeAttribute ?? options?.type;\n  });\n\n  readonly buttonDisabledSignal = computed(() => {\n    const working = this.isWorkingSignal();\n    const disabled = this.disabledSignal();\n    return working || disabled;\n  });\n\n  readonly showProgressSignal = computed(() => {\n    const working = this.isWorkingSignal();\n    const disabled = this.disabledSignal();\n    return working && !disabled;\n  });\n\n  @HostListener('click', ['$event'])\n  public handleClick(event: MouseEvent): void {\n    const working = this.isWorkingSignal();\n    const disabled = this.disabledSignal();\n\n    if (!working && !disabled) {\n      this.btnClick.emit(event);\n      event.stopImmediatePropagation();\n    }\n  }\n}\n"]}
|
|
@@ -15,10 +15,10 @@ export class DbxProgressBarButtonComponent extends AbstractProgressButtonDirecti
|
|
|
15
15
|
buttonCss$ = this.baseCssClasses$.pipe(distinctUntilItemsHaveDifferentValues((x) => x[1]), map((x) => spaceSeparatedCssClasses(x[1])), shareReplay(1));
|
|
16
16
|
buttonCssSignal = toSignal(this.buttonCss$);
|
|
17
17
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxProgressBarButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxProgressBarButtonComponent, isStandalone: true, selector: "dbx-progress-bar-button,dbx-bar-button", usesInheritance: true, ngImport: i0, template: "<button class=\"dbx-base-button dbx-progress-bar-button\" mat-button [type]=\"buttonTypeAttributeSignal()\" [color]=\"configSignal()?.buttonColor\" [ngClass]=\"buttonCssSignal()\" [ngStyle]=\"configSignal()?.customStyle\" [disabled]=\"buttonDisabledSignal()\">\n @if (configSignal()?.buttonIcon) {\n <mat-icon class=\"mat-button-icon\" [class.is-mat-icon]=\"!configSignal()?.buttonIcon?.fontSet!\" [ngClass]=\"configSignal()?.buttonIcon?.customClass!\" [fontSet]=\"configSignal()?.buttonIcon?.fontSet!\" [fontIcon]=\"configSignal()?.buttonIcon?.fontIcon!\" [color]=\"configSignal()?.buttonIcon?.color!\" [svgIcon]=\"configSignal()?.buttonIcon?.svgIcon!\" [inline]=\"configSignal()?.buttonIcon?.inline!\">\n {{ configSignal()?.buttonIcon?.fontSet! ? '' : configSignal()?.buttonIcon?.fontIcon! }}\n </mat-icon>\n }\n <span>\n {{ configSignal()?.text }}\n <ng-content></ng-content>\n </span>\n @if (showProgressSignal()) {\n <mat-progress-bar class=\"bar\" [color]=\"configSignal()?.barColor!\" [mode]=\"
|
|
18
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DbxProgressBarButtonComponent, isStandalone: true, selector: "dbx-progress-bar-button,dbx-bar-button", usesInheritance: true, ngImport: i0, template: "<button class=\"dbx-base-button dbx-progress-bar-button\" mat-button [type]=\"buttonTypeAttributeSignal()\" [color]=\"configSignal()?.buttonColor\" [ngClass]=\"buttonCssSignal()\" [ngStyle]=\"configSignal()?.customStyle\" [disabled]=\"buttonDisabledSignal()\">\n @if (configSignal()?.buttonIcon) {\n <mat-icon class=\"mat-button-icon\" [class.is-mat-icon]=\"!configSignal()?.buttonIcon?.fontSet!\" [ngClass]=\"configSignal()?.buttonIcon?.customClass!\" [fontSet]=\"configSignal()?.buttonIcon?.fontSet!\" [fontIcon]=\"configSignal()?.buttonIcon?.fontIcon!\" [color]=\"configSignal()?.buttonIcon?.color!\" [svgIcon]=\"configSignal()?.buttonIcon?.svgIcon!\" [inline]=\"configSignal()?.buttonIcon?.inline!\">\n {{ configSignal()?.buttonIcon?.fontSet! ? '' : configSignal()?.buttonIcon?.fontIcon! }}\n </mat-icon>\n }\n <span>\n {{ configSignal()?.text }}\n <ng-content></ng-content>\n </span>\n @if (showProgressSignal()) {\n <mat-progress-bar class=\"bar\" [color]=\"configSignal()?.barColor!\" [mode]=\"modeSignal()\" [value]=\"workingValueSignal()\"></mat-progress-bar>\n }\n</button>\n", styles: [":host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button.working{cursor:not-allowed}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button.fullWidth{width:100%}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label{position:unset;display:flex;align-items:center}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label .bar{position:absolute;top:0;left:0}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label mat-icon{padding-right:5px}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label mat-icon.is-mat-icon{font-size:18px;position:relative;top:3px}\n", ":host button.mat-mdc-button .button-text{display:flex;align-items:center}:host button.mat-mdc-button mat-icon.mat-button-icon.mat-icon.mat-ligature-font[fontIcon]:before,:host button.mat-mdc-button mat-icon.mat-fab-icon.mat-icon.mat-ligature-font[fontIcon]:before{content:unset}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
19
19
|
}
|
|
20
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxProgressBarButtonComponent, decorators: [{
|
|
21
21
|
type: Component,
|
|
22
|
-
args: [{ selector: 'dbx-progress-bar-button,dbx-bar-button', imports: [MatButtonModule, MatIconModule, MatProgressBar, NgClass, NgStyle], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<button class=\"dbx-base-button dbx-progress-bar-button\" mat-button [type]=\"buttonTypeAttributeSignal()\" [color]=\"configSignal()?.buttonColor\" [ngClass]=\"buttonCssSignal()\" [ngStyle]=\"configSignal()?.customStyle\" [disabled]=\"buttonDisabledSignal()\">\n @if (configSignal()?.buttonIcon) {\n <mat-icon class=\"mat-button-icon\" [class.is-mat-icon]=\"!configSignal()?.buttonIcon?.fontSet!\" [ngClass]=\"configSignal()?.buttonIcon?.customClass!\" [fontSet]=\"configSignal()?.buttonIcon?.fontSet!\" [fontIcon]=\"configSignal()?.buttonIcon?.fontIcon!\" [color]=\"configSignal()?.buttonIcon?.color!\" [svgIcon]=\"configSignal()?.buttonIcon?.svgIcon!\" [inline]=\"configSignal()?.buttonIcon?.inline!\">\n {{ configSignal()?.buttonIcon?.fontSet! ? '' : configSignal()?.buttonIcon?.fontIcon! }}\n </mat-icon>\n }\n <span>\n {{ configSignal()?.text }}\n <ng-content></ng-content>\n </span>\n @if (showProgressSignal()) {\n <mat-progress-bar class=\"bar\" [color]=\"configSignal()?.barColor!\" [mode]=\"
|
|
22
|
+
args: [{ selector: 'dbx-progress-bar-button,dbx-bar-button', imports: [MatButtonModule, MatIconModule, MatProgressBar, NgClass, NgStyle], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<button class=\"dbx-base-button dbx-progress-bar-button\" mat-button [type]=\"buttonTypeAttributeSignal()\" [color]=\"configSignal()?.buttonColor\" [ngClass]=\"buttonCssSignal()\" [ngStyle]=\"configSignal()?.customStyle\" [disabled]=\"buttonDisabledSignal()\">\n @if (configSignal()?.buttonIcon) {\n <mat-icon class=\"mat-button-icon\" [class.is-mat-icon]=\"!configSignal()?.buttonIcon?.fontSet!\" [ngClass]=\"configSignal()?.buttonIcon?.customClass!\" [fontSet]=\"configSignal()?.buttonIcon?.fontSet!\" [fontIcon]=\"configSignal()?.buttonIcon?.fontIcon!\" [color]=\"configSignal()?.buttonIcon?.color!\" [svgIcon]=\"configSignal()?.buttonIcon?.svgIcon!\" [inline]=\"configSignal()?.buttonIcon?.inline!\">\n {{ configSignal()?.buttonIcon?.fontSet! ? '' : configSignal()?.buttonIcon?.fontIcon! }}\n </mat-icon>\n }\n <span>\n {{ configSignal()?.text }}\n <ng-content></ng-content>\n </span>\n @if (showProgressSignal()) {\n <mat-progress-bar class=\"bar\" [color]=\"configSignal()?.barColor!\" [mode]=\"modeSignal()\" [value]=\"workingValueSignal()\"></mat-progress-bar>\n }\n</button>\n", styles: [":host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button.working{cursor:not-allowed}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button.fullWidth{width:100%}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label{position:unset;display:flex;align-items:center}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label .bar{position:absolute;top:0;left:0}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label mat-icon{padding-right:5px}:host>button.dbx-progress-bar-button.mdc-button.mat-mdc-button>::ng-deep .mdc-button__label mat-icon.is-mat-icon{font-size:18px;position:relative;top:3px}\n", ":host button.mat-mdc-button .button-text{display:flex;align-items:center}:host button.mat-mdc-button mat-icon.mat-button-icon.mat-icon.mat-ligature-font[fontIcon]:before,:host button.mat-mdc-button mat-icon.mat-fab-icon.mat-icon.mat-ligature-font[fontIcon]:before{content:unset}\n"] }]
|
|
23
23
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLmJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvYnV0dG9uL3Byb2dyZXNzL2Jhci5idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2J1dHRvbi9wcm9ncmVzcy9iYXIuYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkYsT0FBTyxFQUFFLEdBQUcsRUFBRSxXQUFXLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDeEMsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxxQ0FBcUMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7OztBQVVuRCxNQUFNLE9BQU8sNkJBQThCLFNBQVEsK0JBQStCO0lBQ3ZFLFVBQVUsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FDN0MscUNBQXFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUNsRCxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLHdCQUF3QixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQzFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FDZixDQUFDO0lBRU8sZUFBZSxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7d0dBUDFDLDZCQUE2Qjs0RkFBN0IsNkJBQTZCLHlIQ25CMUMseWxDQWNBLGlpQ0RDWSxlQUFlLDJOQUFFLGFBQWEsb0xBQUUsY0FBYyx5S0FBRSxPQUFPLG9GQUFFLE9BQU87OzRGQUkvRCw2QkFBNkI7a0JBUnpDLFNBQVM7K0JBQ0Usd0NBQXdDLFdBR3pDLENBQUMsZUFBZSxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsT0FBTyxFQUFFLE9BQU8sQ0FBQyxtQkFDMUQsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RQcm9ncmVzc0J1dHRvbkRpcmVjdGl2ZSB9IGZyb20gJy4vYWJzdHJhY3QucHJvZ3Jlc3MuYnV0dG9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBtYXAsIHNoYXJlUmVwbGF5IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBzcGFjZVNlcGFyYXRlZENzc0NsYXNzZXMgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IGRpc3RpbmN0VW50aWxJdGVtc0hhdmVEaWZmZXJlbnRWYWx1ZXMgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRQcm9ncmVzc0JhciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLWJhcic7XG5pbXBvcnQgeyB0b1NpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcbmltcG9ydCB7IE5nQ2xhc3MsIE5nU3R5bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtcHJvZ3Jlc3MtYmFyLWJ1dHRvbixkYngtYmFyLWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9iYXIuYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmFyLmJ1dHRvbi5jb21wb25lbnQuc2NzcycsICcuL3NoYXJlZC5idXR0b24uY29tcG9uZW50LnNjc3MnXSxcbiAgaW1wb3J0czogW01hdEJ1dHRvbk1vZHVsZSwgTWF0SWNvbk1vZHVsZSwgTWF0UHJvZ3Jlc3NCYXIsIE5nQ2xhc3MsIE5nU3R5bGVdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhQcm9ncmVzc0JhckJ1dHRvbkNvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0UHJvZ3Jlc3NCdXR0b25EaXJlY3RpdmUge1xuICByZWFkb25seSBidXR0b25Dc3MkID0gdGhpcy5iYXNlQ3NzQ2xhc3NlcyQucGlwZShcbiAgICBkaXN0aW5jdFVudGlsSXRlbXNIYXZlRGlmZmVyZW50VmFsdWVzKCh4KSA9PiB4WzFdKSxcbiAgICBtYXAoKHgpID0+IHNwYWNlU2VwYXJhdGVkQ3NzQ2xhc3Nlcyh4WzFdKSksXG4gICAgc2hhcmVSZXBsYXkoMSlcbiAgKTtcblxuICByZWFkb25seSBidXR0b25Dc3NTaWduYWwgPSB0b1NpZ25hbCh0aGlzLmJ1dHRvbkNzcyQpO1xufVxuIiwiPGJ1dHRvbiBjbGFzcz1cImRieC1iYXNlLWJ1dHRvbiBkYngtcHJvZ3Jlc3MtYmFyLWJ1dHRvblwiIG1hdC1idXR0b24gW3R5cGVdPVwiYnV0dG9uVHlwZUF0dHJpYnV0ZVNpZ25hbCgpXCIgW2NvbG9yXT1cImNvbmZpZ1NpZ25hbCgpPy5idXR0b25Db2xvclwiIFtuZ0NsYXNzXT1cImJ1dHRvbkNzc1NpZ25hbCgpXCIgW25nU3R5bGVdPVwiY29uZmlnU2lnbmFsKCk/LmN1c3RvbVN0eWxlXCIgW2Rpc2FibGVkXT1cImJ1dHRvbkRpc2FibGVkU2lnbmFsKClcIj5cbiAgQGlmIChjb25maWdTaWduYWwoKT8uYnV0dG9uSWNvbikge1xuICAgIDxtYXQtaWNvbiBjbGFzcz1cIm1hdC1idXR0b24taWNvblwiIFtjbGFzcy5pcy1tYXQtaWNvbl09XCIhY29uZmlnU2lnbmFsKCk/LmJ1dHRvbkljb24/LmZvbnRTZXQhXCIgW25nQ2xhc3NdPVwiY29uZmlnU2lnbmFsKCk/LmJ1dHRvbkljb24/LmN1c3RvbUNsYXNzIVwiIFtmb250U2V0XT1cImNvbmZpZ1NpZ25hbCgpPy5idXR0b25JY29uPy5mb250U2V0IVwiIFtmb250SWNvbl09XCJjb25maWdTaWduYWwoKT8uYnV0dG9uSWNvbj8uZm9udEljb24hXCIgW2NvbG9yXT1cImNvbmZpZ1NpZ25hbCgpPy5idXR0b25JY29uPy5jb2xvciFcIiBbc3ZnSWNvbl09XCJjb25maWdTaWduYWwoKT8uYnV0dG9uSWNvbj8uc3ZnSWNvbiFcIiBbaW5saW5lXT1cImNvbmZpZ1NpZ25hbCgpPy5idXR0b25JY29uPy5pbmxpbmUhXCI+XG4gICAgICB7eyBjb25maWdTaWduYWwoKT8uYnV0dG9uSWNvbj8uZm9udFNldCEgPyAnJyA6IGNvbmZpZ1NpZ25hbCgpPy5idXR0b25JY29uPy5mb250SWNvbiEgfX1cbiAgICA8L21hdC1pY29uPlxuICB9XG4gIDxzcGFuPlxuICAgIHt7IGNvbmZpZ1NpZ25hbCgpPy50ZXh0IH19XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L3NwYW4+XG4gIEBpZiAoc2hvd1Byb2dyZXNzU2lnbmFsKCkpIHtcbiAgICA8bWF0LXByb2dyZXNzLWJhciBjbGFzcz1cImJhclwiIFtjb2xvcl09XCJjb25maWdTaWduYWwoKT8uYmFyQ29sb3IhXCIgW21vZGVdPVwibW9kZVNpZ25hbCgpXCIgW3ZhbHVlXT1cIndvcmtpbmdWYWx1ZVNpZ25hbCgpXCI+PC9tYXQtcHJvZ3Jlc3MtYmFyPlxuICB9XG48L2J1dHRvbj5cbiJdfQ==
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { InjectionToken } from '@angular/core';
|
|
2
2
|
export const DBX_PROGRESS_BUTTON_GLOBAL_CONFIG = new InjectionToken('DbxProgressButtonGlobalConfig');
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLnByb2dyZXNzLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9idXR0b24vcHJvZ3Jlc3MvYnV0dG9uLnByb2dyZXNzLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBcUYvQyxNQUFNLENBQUMsTUFBTSxpQ0FBaUMsR0FBRyxJQUFJLGNBQWMsQ0FBZ0MsK0JBQStCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVtZVBhbGV0dGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IFByb2dyZXNzU3Bpbm5lck1vZGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1zcGlubmVyJztcbmltcG9ydCB7IHR5cGUgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IERieFRoZW1lQ29sb3IgfSBmcm9tICcuLi8uLi9sYXlvdXQvc3R5bGUvc3R5bGUnO1xuaW1wb3J0IHsgRGJ4QnV0dG9uVHlwZSB9IGZyb20gJy4uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4QnV0dG9uV29ya2luZywgRGJ4QnV0dG9uV29ya2luZ1Byb2dyZXNzIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERieFByb2dyZXNzQnV0dG9uQ29uZmlnIHtcbiAgcmVhZG9ubHkgd29ya2luZz86IE1heWJlPERieEJ1dHRvbldvcmtpbmc+O1xuICByZWFkb25seSB0ZXh0PzogTWF5YmU8c3RyaW5nPjtcbiAgcmVhZG9ubHkgc3Bpbm5lclRleHQ/OiBNYXliZTxzdHJpbmc+O1xuICByZWFkb25seSBidXR0b25Db2xvcj86IE1heWJlPFRoZW1lUGFsZXR0ZSB8IERieFRoZW1lQ29sb3I+O1xuICByZWFkb25seSBzcGlubmVyQ29sb3I/OiBNYXliZTxUaGVtZVBhbGV0dGUgfCBEYnhUaGVtZUNvbG9yPjtcbiAgcmVhZG9ubHkgYmFyQ29sb3I/OiBNYXliZTxUaGVtZVBhbGV0dGUgfCBEYnhUaGVtZUNvbG9yPjtcbiAgLyoqXG4gICAqIFdoZXRoZXIgb3Igbm90IHRvIHJlbmRlciBhcyBhbiBpY29uIGJ1dHRvbi5cbiAgICovXG4gIHJlYWRvbmx5IGljb25Pbmx5PzogTWF5YmU8Ym9vbGVhbj47XG4gIHJlYWRvbmx5IHNwaW5uZXJTaXplPzogTWF5YmU8bnVtYmVyPjtcbiAgcmVhZG9ubHkgc3Bpbm5lclJhdGlvPzogTWF5YmU8bnVtYmVyPjtcbiAgcmVhZG9ubHkgbW9kZT86IE1heWJlPFByb2dyZXNzU3Bpbm5lck1vZGU+O1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgdXNlIHdvcmtpbmcgaW5zdGVhZFxuICAgKi9cbiAgcmVhZG9ubHkgdmFsdWU/OiBNYXliZTxEYnhCdXR0b25Xb3JraW5nUHJvZ3Jlc3M+O1xuICByZWFkb25seSBmdWxsV2lkdGg/OiBNYXliZTxib29sZWFuPjtcbiAgcmVhZG9ubHkgZGlzYWJsZWQ/OiBNYXliZTxib29sZWFuPjtcbiAgcmVhZG9ubHkgY3VzdG9tU3R5bGU/OiBNYXliZTx7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9PjtcbiAgcmVhZG9ubHkgY3VzdG9tQ2xhc3M/OiBNYXliZTxzdHJpbmc+O1xuICAvKipcbiAgICogQ3VzdG9tIHNwaW5uZXIgY29sb3IuIE92ZXJyaWRlcyB0aGUgbm9ybWFsIHNwaW5uZXIgY29sb3IgaWYgcHJvdmlkZWQuXG4gICAqL1xuICByZWFkb25seSBjdXN0b21TcGlubmVyQ29sb3I/OiBNYXliZTxzdHJpbmc+O1xuICByZWFkb25seSBidXR0b25JY29uPzogTWF5YmU8RGJ4UHJvZ3Jlc3NCdXR0b25JY29uPjtcbiAgcmVhZG9ubHkgaWQ/OiBNYXliZTxzdHJpbmc+O1xuICAvKipcbiAgICogVGhlIHR5cGUgb2YgYnV0dG9uIHRvIHJlbmRlci5cbiAgICovXG4gIHJlYWRvbmx5IGJ1dHRvblR5cGU/OiBNYXliZTxEYnhCdXR0b25UeXBlPjtcblxuICAvKipcbiAgICogVGhlIEhUTUwgYXR0cmlidXRlIFwidHlwZVwiIHRvIGFkZCB0byB0aGUgYnV0dG9uLlxuICAgKi9cbiAgcmVhZG9ubHkgYnV0dG9uVHlwZUF0dHJpYnV0ZT86IE1heWJlPHN0cmluZz47XG5cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHVzZSBidXR0b25UeXBlPXJhaXNlZCBpbnN0ZWFkXG4gICAqL1xuICByZWFkb25seSByYWlzZWQ/OiBNYXliZTxib29sZWFuPjtcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHVzZSBidXR0b25UeXBlPXN0cm9rZWQgaW5zdGVhZFxuICAgKi9cbiAgcmVhZG9ubHkgc3Ryb2tlZD86IE1heWJlPGJvb2xlYW4+O1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgdXNlIGJ1dHRvblR5cGU9ZmxhdCBpbnN0ZWFkXG4gICAqL1xuICByZWFkb25seSBmbGF0PzogTWF5YmU8Ym9vbGVhbj47XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgb3Igbm90IHRoaXMgaXMgYSBmbG9hdGluZyBhY3Rpb24gYnV0dG9uLlxuICAgKi9cbiAgcmVhZG9ubHkgZmFiPzogTWF5YmU8Ym9vbGVhbj47XG5cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHVzZSBidXR0b25UeXBlQXR0cmlidXRlIGluc3RlYWRcbiAgICovXG4gIHJlYWRvbmx5IHR5cGU/OiBNYXliZTxzdHJpbmc+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERieFByb2dyZXNzQnV0dG9uSWNvbiB7XG4gIHJlYWRvbmx5IGNvbG9yPzogTWF5YmU8VGhlbWVQYWxldHRlIHwgRGJ4VGhlbWVDb2xvcj47XG4gIHJlYWRvbmx5IGZvbnRJY29uPzogTWF5YmU8c3RyaW5nPjtcbiAgcmVhZG9ubHkgZm9udFNldD86IE1heWJlPHN0cmluZz47XG4gIHJlYWRvbmx5IGlubGluZT86IE1heWJlPGJvb2xlYW4+O1xuICByZWFkb25seSBzdmdJY29uPzogTWF5YmU8c3RyaW5nPjtcbiAgcmVhZG9ubHkgY3VzdG9tQ2xhc3M/OiBNYXliZTxzdHJpbmc+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERieFByb2dyZXNzQnV0dG9uVGFyZ2V0ZWRDb25maWcgZXh0ZW5kcyBEYnhQcm9ncmVzc0J1dHRvbkNvbmZpZyB7XG4gIHJlYWRvbmx5IGlkPzogTWF5YmU8c3RyaW5nPjtcbn1cblxuZXhwb3J0IHR5cGUgRGJ4UHJvZ3Jlc3NCdXR0b25HbG9iYWxDb25maWcgPSBEYnhQcm9ncmVzc0J1dHRvblRhcmdldGVkQ29uZmlnW107XG5cbmV4cG9ydCBjb25zdCBEQlhfUFJPR1JFU1NfQlVUVE9OX0dMT0JBTF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48RGJ4UHJvZ3Jlc3NCdXR0b25HbG9iYWxDb25maWc+KCdEYnhQcm9ncmVzc0J1dHRvbkdsb2JhbENvbmZpZycpO1xuXG4vLyBNQVJLOiBDb21wYXRcbi8qKlxuICogQGRlcHJlY2F0ZWQgdXNlIERieFByb2dyZXNzQnV0dG9uQ29uZmlnIGluc3RlYWQuXG4gKi9cbmV4cG9ydCB0eXBlIERieFByb2dyZXNzQnV0dG9uT3B0aW9ucyA9IERieFByb2dyZXNzQnV0dG9uQ29uZmlnO1xuIl19
|