@dereekb/dbx-web 12.3.3 → 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.
@@ -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", "style", "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":"AAAA,OAAO,EAAU,SAAS,EAA4B,MAAM,EAAE,QAAQ,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACvH,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACnF,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjF,OAAO,EAAE,YAAY,EAAc,MAAM,eAAe,CAAC;AAEzD,OAAO,EAAE,6BAA6B,EAAE,kBAAkB,EAAE,6BAA6B,EAAmC,wBAAwB,EAAE,gCAAgC,EAAE,MAAM,mBAAmB,CAAC;AAClN,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,wBAAwB,EAAE,MAAM,sCAAsC,CAAC;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;;AAEzE;;GAEG;AAOH,MAAM,OAAO,0BAA2B,SAAQ,6BAA6B;IAClE,WAAW,GAAG,MAAM,CAAC,CAAA,cAA0C,CAAA,CAAC,CAAC;IACjE,YAAY,GAAG,MAAM,CAAiC,kBAAkB,CAAC,CAAC;IAElE,gBAAgB,GAAG,IAAI,OAAO,EAAQ,CAAC;IACvC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,SAAS,CAAC;IAEzD,eAAe,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CACjD,WAAW,EAAE,EACb,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,cAAc,CAAC,CAC9B,CAAC;IAEO,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAC5C,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,EAC9B,SAAS,CAAC,KAAK,CAAC,EAChB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAEO,iBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CACpD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,iBAAiB,CAAC,EACrC,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAChC,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAEO,oBAAoB,GAAG,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACtD,cAAc,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,sBAAsB,GAAG,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC1D,yBAAyB,GAAG,QAAQ,CAAC,GAAG,EAAE;QACjD,IAAI,OAAO,GAAG,sBAAsB,CAAC;QACrC,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAEvD,QAAQ,gBAAgB,EAAE,CAAC;YACzB,KAAK,gBAAgB,CAAC,KAAK;gBACzB,OAAO,IAAI,OAAO,CAAC;gBACnB,MAAM;YACR,KAAK,gBAAgB,CAAC,OAAO;gBAC3B,OAAO,IAAI,SAAS,CAAC;gBACrB,MAAM;YACR;gBACE,OAAO,IAAI,MAAM,CAAC;gBAClB,MAAM;QACV,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC,CAAC;IAEM,MAAM,GAAkB,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IACrF,MAAM,GAAyC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IACxE,SAAS,GAAY,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACrD,OAAO,GAAkB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;IACnD,YAAY,GAAyC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAEvF,QAAQ;QACN,0EAA0E;QAC1E,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,gBAAgB;aAC7B,IAAI,CACH,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,EACvC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,gBAAgB,CAAC,IAAI,CAAC,CAC3C;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC,CAAC,CAAC;IACP,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;IAED,eAAe;QACb,qDAAqD;QACrD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,UAAU,CACR,GAAG,EAAE;gBACH,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;YAC/B,CAAC,EACD,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,IAAI,YAAY,GAAG,EAAE,CACxD,CAAC;QACJ,CAAC;IACH,CAAC;IAED,2BAA2B,GAAoC,GAAS,EAAE;QACxE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC;IAEF,OAAO,GAAG,GAAS,EAAE;QACnB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC,CAAC;wGAvFS,0BAA0B;4FAA1B,0BAA0B,+FCtBvC,swBAkBA,4CDCY,OAAO,oFAAE,wBAAwB,2FAAE,gCAAgC,2GAAE,kBAAkB,kOAAE,wBAAwB,gFAAE,kBAAkB,oEAAE,kBAAkB;;4FAGxJ,0BAA0B;kBANtC,SAAS;iCAEI,IAAI,WACP,CAAC,OAAO,EAAE,wBAAwB,EAAE,gCAAgC,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,6BAA6B,CAAC,mBAClL,uBAAuB,CAAC,MAAM","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", "style", "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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNpdGlvbi5zYWZldHkuZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9hY3Rpb24vdHJhbnNpdGlvbi90cmFuc2l0aW9uLnNhZmV0eS5kaWFsb2cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDN0YsT0FBTyxFQUEwQix5QkFBeUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ3RILE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ25FLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOztBQUloRjs7R0FFRztBQWVILE1BQU0sT0FBTyxnREFBaUQsU0FBUSx1QkFBdUI7SUFDbEYsTUFBTSxHQUEyQjtRQUN4QyxLQUFLLEVBQUUsaUJBQWlCO1FBQ3hCLE1BQU0sRUFBRSx3Q0FBd0M7UUFDaEQsV0FBVyxFQUFFLE1BQU07UUFDbkIsVUFBVSxFQUFFLGlCQUFpQjtLQUM5QixDQUFDO0lBRUYsT0FBTztRQUNMLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDbEMsQ0FBQzt3R0FkVSxnREFBZ0Q7NEZBQWhELGdEQUFnRCwrRkFiakQ7Ozs7Ozs7O0dBUVQsNERBRVMseUJBQXlCLG1IQUFFLGlCQUFpQixpSEFBRSx1QkFBdUIsNkRBQUUsa0JBQWtCLGtPQUFFLHdCQUF3Qjs7NEZBR2xILGdEQUFnRDtrQkFkNUQsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUU7Ozs7Ozs7O0dBUVQ7b0JBQ0QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixFQUFFLGlCQUFpQixFQUFFLHVCQUF1QixFQUFFLGtCQUFrQixFQUFFLHdCQUF3QixDQUFDO29CQUM5SCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vaW50ZXJhY3Rpb24vZGlhbG9nL2Fic3RyYWN0LmRpYWxvZy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4UHJvbXB0Q29uZmlybUNvbmZpZywgRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2ludGVyYWN0aW9uL3Byb21wdC9wcm9tcHQuY29uZmlybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4RXJyb3JDb21wb25lbnQgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4QWN0aW9uRXJyb3JEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5hY3Rpb24uZGlyZWN0aXZlJztcbmltcG9ydCB7IERieEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uc3BhY2VyLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCB0eXBlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlEaWFsb2dSZXN1bHQgPSAnc3VjY2VzcycgfCAnc3RheScgfCAnZGlzY2FyZCcgfCAnbm9uZSc7XG5cbi8qKlxuICogRGlhbG9nIHRoYXQgaXMgc2hvd24vdHJpZ2dlcmVkIGFzIHBhcnQgb2YgdGhlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlcbiAqL1xuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1wcm9tcHQtY29uZmlybSBbY29uZmlnXT1cImNvbmZpZ1wiIChjb25maXJtKT1cImNvbmZpcm0oKVwiIChjYW5jZWwpPVwiY2FuY2VsKClcIj5cbiAgICAgIDxuZy1jb250YWluZXI+XG4gICAgICAgIDxkYngtZXJyb3IgZGJ4QWN0aW9uRXJyb3I+PC9kYngtZXJyb3I+XG4gICAgICAgIDxkYngtYnV0dG9uIHRleHQ9XCJTYXZlIENoYW5nZXNcIiBkYnhBY3Rpb25CdXR0b24+PC9kYngtYnV0dG9uPlxuICAgICAgICA8ZGJ4LWJ1dHRvbi1zcGFjZXI+PC9kYngtYnV0dG9uLXNwYWNlcj5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvZGJ4LXByb21wdC1jb25maXJtPlxuICBgLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCwgRGJ4RXJyb3JDb21wb25lbnQsIERieEFjdGlvbkVycm9yRGlyZWN0aXZlLCBEYnhCdXR0b25Db21wb25lbnQsIERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZV0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieEFjdGlvblVJUm91dGVyVHJhbnNpdGlvblNhZmV0eURpYWxvZ0NvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcmVhZG9ubHkgY29uZmlnOiBEYnhQcm9tcHRDb25maXJtQ29uZmlnID0ge1xuICAgIHRpdGxlOiAnVW5zYXZlZCBDaGFuZ2VzJyxcbiAgICBwcm9tcHQ6ICdZb3UgaGF2ZSB1bnNhdmVkIGNoYW5nZXMgb24gdGhpcyBwYWdlLicsXG4gICAgY29uZmlybVRleHQ6ICdTdGF5JyxcbiAgICBjYW5jZWxUZXh0OiAnRGlzY2FyZCBDaGFuZ2VzJ1xuICB9O1xuXG4gIGNvbmZpcm0oKTogdm9pZCB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoJ3N0YXknKTtcbiAgfVxuXG4gIGNhbmNlbCgpOiB2b2lkIHtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgnZGlzY2FyZCcpO1xuICB9XG59XG4iXX0=
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNpdGlvbi5zYWZldHkuZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9hY3Rpb24vdHJhbnNpdGlvbi90cmFuc2l0aW9uLnNhZmV0eS5kaWFsb2cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDN0YsT0FBTyxFQUEwQix5QkFBeUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ3RILE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ25FLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOztBQUloRjs7R0FFRztBQWVILE1BQU0sT0FBTyxnREFBaUQsU0FBUSx1QkFBdUI7SUFDbEYsTUFBTSxHQUEyQjtRQUN4QyxLQUFLLEVBQUUsaUJBQWlCO1FBQ3hCLE1BQU0sRUFBRSx3Q0FBd0M7UUFDaEQsV0FBVyxFQUFFLE1BQU07UUFDbkIsVUFBVSxFQUFFLGlCQUFpQjtLQUM5QixDQUFDO0lBRUYsT0FBTztRQUNMLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDbEMsQ0FBQzt3R0FkVSxnREFBZ0Q7NEZBQWhELGdEQUFnRCwrRkFiakQ7Ozs7Ozs7O0dBUVQsNERBRVMseUJBQXlCLG1IQUFFLGlCQUFpQixpSEFBRSx1QkFBdUIsNkRBQUUsa0JBQWtCLHdPQUFFLHdCQUF3Qjs7NEZBR2xILGdEQUFnRDtrQkFkNUQsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUU7Ozs7Ozs7O0dBUVQ7b0JBQ0QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixFQUFFLGlCQUFpQixFQUFFLHVCQUF1QixFQUFFLGtCQUFrQixFQUFFLHdCQUF3QixDQUFDO29CQUM5SCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vaW50ZXJhY3Rpb24vZGlhbG9nL2Fic3RyYWN0LmRpYWxvZy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4UHJvbXB0Q29uZmlybUNvbmZpZywgRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2ludGVyYWN0aW9uL3Byb21wdC9wcm9tcHQuY29uZmlybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4RXJyb3JDb21wb25lbnQgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4QWN0aW9uRXJyb3JEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9lcnJvci9lcnJvci5hY3Rpb24uZGlyZWN0aXZlJztcbmltcG9ydCB7IERieEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2J1dHRvbi9idXR0b24uc3BhY2VyLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCB0eXBlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlEaWFsb2dSZXN1bHQgPSAnc3VjY2VzcycgfCAnc3RheScgfCAnZGlzY2FyZCcgfCAnbm9uZSc7XG5cbi8qKlxuICogRGlhbG9nIHRoYXQgaXMgc2hvd24vdHJpZ2dlcmVkIGFzIHBhcnQgb2YgdGhlIERieEFjdGlvblRyYW5zaXRpb25TYWZldHlcbiAqL1xuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1wcm9tcHQtY29uZmlybSBbY29uZmlnXT1cImNvbmZpZ1wiIChjb25maXJtKT1cImNvbmZpcm0oKVwiIChjYW5jZWwpPVwiY2FuY2VsKClcIj5cbiAgICAgIDxuZy1jb250YWluZXI+XG4gICAgICAgIDxkYngtZXJyb3IgZGJ4QWN0aW9uRXJyb3I+PC9kYngtZXJyb3I+XG4gICAgICAgIDxkYngtYnV0dG9uIHRleHQ9XCJTYXZlIENoYW5nZXNcIiBkYnhBY3Rpb25CdXR0b24+PC9kYngtYnV0dG9uPlxuICAgICAgICA8ZGJ4LWJ1dHRvbi1zcGFjZXI+PC9kYngtYnV0dG9uLXNwYWNlcj5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvZGJ4LXByb21wdC1jb25maXJtPlxuICBgLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4UHJvbXB0Q29uZmlybUNvbXBvbmVudCwgRGJ4RXJyb3JDb21wb25lbnQsIERieEFjdGlvbkVycm9yRGlyZWN0aXZlLCBEYnhCdXR0b25Db21wb25lbnQsIERieEJ1dHRvblNwYWNlckRpcmVjdGl2ZV0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieEFjdGlvblVJUm91dGVyVHJhbnNpdGlvblNhZmV0eURpYWxvZ0NvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcmVhZG9ubHkgY29uZmlnOiBEYnhQcm9tcHRDb25maXJtQ29uZmlnID0ge1xuICAgIHRpdGxlOiAnVW5zYXZlZCBDaGFuZ2VzJyxcbiAgICBwcm9tcHQ6ICdZb3UgaGF2ZSB1bnNhdmVkIGNoYW5nZXMgb24gdGhpcyBwYWdlLicsXG4gICAgY29uZmlybVRleHQ6ICdTdGF5JyxcbiAgICBjYW5jZWxUZXh0OiAnRGlzY2FyZCBDaGFuZ2VzJ1xuICB9O1xuXG4gIGNvbmZpcm0oKTogdm9pZCB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoJ3N0YXknKTtcbiAgfVxuXG4gIGNhbmNlbCgpOiB2b2lkIHtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgnZGlzY2FyZCcpO1xuICB9XG59XG4iXX0=
@@ -18,7 +18,7 @@ export var DbxButtonDisplayType;
18
18
  */
19
19
  export class DbxButtonComponent extends AbstractDbxButtonDirective {
20
20
  type = input();
21
- style = input();
21
+ buttonStyle = input();
22
22
  color = input(undefined);
23
23
  spinnerColor = input(undefined);
24
24
  customButtonColor = input();
@@ -31,7 +31,7 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
31
31
  iconOnly = input(false, { transform: isDefinedAndNotFalse });
32
32
  fab = input(false, { transform: isDefinedAndNotFalse });
33
33
  typeSignal = computed(() => {
34
- const style = this.style();
34
+ const style = this.buttonStyle();
35
35
  let type = this.type() ?? style?.type;
36
36
  if (!type) {
37
37
  type = 'basic';
@@ -53,7 +53,7 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
53
53
  configSignal = computed(() => {
54
54
  // configure custom style
55
55
  const customStyle = {};
56
- const style = this.style();
56
+ const style = this.buttonStyle();
57
57
  const customButtonColorValue = this.customButtonColor() ?? style?.customButtonColor;
58
58
  if (customButtonColorValue) {
59
59
  customStyle['background'] = customButtonColorValue;
@@ -91,7 +91,7 @@ export class DbxButtonComponent extends AbstractDbxButtonDirective {
91
91
  return config;
92
92
  });
93
93
  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.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 }, style: { classPropertyName: "style", publicName: "style", 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: `
95
95
  <dbx-progress-spinner-button (btnClick)="clickButton()" [config]="configSignal()">
96
96
  <ng-content></ng-content>
97
97
  </dbx-progress-spinner-button>
@@ -112,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
112
112
  standalone: true
113
113
  }]
114
114
  }] });
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 style = 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.style();\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.style();\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"]}
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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEpF,OAAO,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAC;AACjF,OAAO,EAAgB,oBAAoB,EAAc,MAAM,eAAe,CAAC;AAG/E,OAAO,EAAE,iCAAiC,EAAE,MAAM,YAAY,CAAC;;AAiB/D;;GAEG;AACH,MAAM,CAAN,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,yCAAiB,CAAA;IACjB,2CAAmB,CAAA;IACnB,qCAAa,CAAA;IACb,0CAAkB,CAAA;AACpB,CAAC,EALW,oBAAoB,KAApB,oBAAoB,QAK/B;AAED;;GAEG;AAaH,MAAM,OAAO,kBAAmB,SAAQ,0BAA0B;IACvD,IAAI,GAAG,KAAK,EAAwB,CAAC;IACrC,WAAW,GAAG,KAAK,EAAyB,CAAC;IAE7C,KAAK,GAAG,KAAK,CAA+B,SAAS,CAAC,CAAC;IACvD,YAAY,GAAG,KAAK,CAA+B,SAAS,CAAC,CAAC;IAC9D,iBAAiB,GAAG,KAAK,EAAiB,CAAC;IAC3C,eAAe,GAAG,KAAK,EAAiB,CAAC;IACzC,kBAAkB,GAAG,KAAK,EAAiB,CAAC;IAE5C,KAAK,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,oBAAoB,EAAE,CAAC,CAAC;IACxF,MAAM,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,oBAAoB,EAAE,CAAC,CAAC;IACzF,OAAO,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,oBAAoB,EAAE,CAAC,CAAC;IAC1F,IAAI,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,oBAAoB,EAAE,CAAC,CAAC;IACvF,QAAQ,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,oBAAoB,EAAE,CAAC,CAAC;IAC3F,GAAG,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,oBAAoB,EAAE,CAAC,CAAC;IAEtF,UAAU,GAAG,QAAQ,CAAC,GAAG,EAAE;QAClC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACjC,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,IAAI,KAAK,EAAE,IAAI,CAAC;QAEtC,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,IAAI,GAAG,OAAO,CAAC;YAEf,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC;gBAClB,IAAI,GAAG,QAAQ,CAAC;YAClB,CAAC;iBAAM,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;gBAC1B,IAAI,GAAG,SAAS,CAAC;YACnB,CAAC;iBAAM,IAAI,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;gBACvB,IAAI,GAAG,MAAM,CAAC;YAChB,CAAC;iBAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBAC3B,IAAI,GAAG,MAAM,CAAC;YAChB,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC,CAAC;IAEM,YAAY,GAAG,QAAQ,CAA0B,GAAG,EAAE;QAC7D,yBAAyB;QACzB,MAAM,WAAW,GAAG,EAEnB,CAAC;QAEF,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACjC,MAAM,sBAAsB,GAAG,IAAI,CAAC,iBAAiB,EAAE,IAAI,KAAK,EAAE,iBAAiB,CAAC;QAEpF,IAAI,sBAAsB,EAAE,CAAC;YAC3B,WAAW,CAAC,YAAY,CAAC,GAAG,sBAAsB,CAAC;QACrD,CAAC;QAED,MAAM,oBAAoB,GAAG,IAAI,CAAC,eAAe,EAAE,IAAI,KAAK,EAAE,eAAe,CAAC;QAE9E,IAAI,oBAAoB,EAAE,CAAC;YACzB,WAAW,CAAC,OAAO,CAAC,GAAG,oBAAoB,CAAC;QAC9C,CAAC;QAED,MAAM,uBAAuB,GAAG,IAAI,CAAC,kBAAkB,EAAE,IAAI,KAAK,EAAE,kBAAkB,CAAC;QACvF,MAAM,kBAAkB,GAAkB,uBAAuB,IAAI,oBAAoB,CAAC;QAE1F,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,KAAK,EAAE,KAAK,CAAC;QACjD,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,KAAK,EAAE,YAAY,IAAI,WAAW,CAAC;QAE/E,MAAM,mBAAmB,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAClD,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,mBAAmB,CAAC,CAAC,sEAAsE;QAErI,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACpC,MAAM,UAAU,GAAG,SAAS,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;QAEnE,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACpC,MAAM,gBAAgB,GAAG,UAAU,IAAI,CAAC,SAAS,CAAC;QAClD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,KAAK,EAAE,GAAG,CAAC;QAErC,MAAM,MAAM,GAA0C;YACpD,GAAG;YACH,OAAO,EAAE,IAAI,CAAC,aAAa,EAAE;YAC7B,UAAU;YACV,WAAW;YACX,WAAW,EAAE,aAAa,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3E,IAAI,EAAE,SAAS,IAAI,EAAE;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE;YAC7B,WAAW;YACX,QAAQ,EAAE,QAAQ;YAClB,IAAI,EAAE,eAAe;YACrB,YAAY;YACZ,kBAAkB;YAClB,QAAQ;SACT,CAAC;QAEF,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;wGA1FQ,kBAAkB;4FAAlB,kBAAkB,mvDALlB,gBAAgB,CAAC,kBAAkB,CAAC,iDALrC;;;;GAIT,4DAES,iCAAiC;;4FAIhC,kBAAkB;kBAZ9B,SAAS;mBAAC;oBACT,QAAQ,EAAE,YAAY;oBACtB,QAAQ,EAAE;;;;GAIT;oBACD,SAAS,EAAE,gBAAgB,oBAAoB;oBAC/C,OAAO,EAAE,CAAC,iCAAiC,CAAC;oBAC5C,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,UAAU,EAAE,IAAI;iBACjB","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", "style", "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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnH,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAAqC,mBAAmB,EAAE,aAAa,EAAE,6BAA6B,EAA0B,+BAA+B,EAAE,MAAM,eAAe,CAAC;AAC9L,OAAO,EAAE,YAAY,EAAc,MAAM,eAAe,CAAC;AACzD,OAAO,EAAc,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,OAAO,EAAE,YAAY,EAAmB,MAAM,2BAA2B,CAAC;AAC1E,OAAO,EAAE,6BAA6B,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;AAC5F,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,wBAAwB,EAAE,MAAM,yCAAyC,CAAC;;;AAEnF;;GAEG;AAQH,MAAM,OAAO,4BAA6B,SAAQ,6BAA6B;IAC5D,UAAU,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IAC/B,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IACnC,UAAU,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;IAE1C,cAAc,GAAG,SAAS,CAA4B,gBAAgB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IAE9F,WAAW,GAAG,KAAK,CAAgB,SAAS,CAAC,CAAC;IAC9C,MAAM,GAAG,KAAK,CAAiB,SAAS,CAAC,CAAC;IAC1C,SAAS,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;IACjC,WAAW,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;IAEnC,OAAO,GAAG,KAAK,CAA6B,SAAS,CAAC,CAAC;IACvD,YAAY,GAAG,KAAK,CAA4D,SAAS,CAAC,CAAC;IAE3F,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,+BAA+B,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IAExG,kBAAkB,GAAG,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAElD,yBAAyB,GAAG,QAAQ,CAAC,GAAG,EAAE;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC/B,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE/C,IAAI,MAAgD,CAAC;QAErD,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,GAAG,YAAY,CAAC;QACxB,CAAC;aAAM,IAAI,OAAO,EAAE,CAAC;YACnB,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;QAClC,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;IAEM,oBAAoB,GAAG,YAAY,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IACpE,QAAQ,GAA2C,IAAI,CAAC,oBAAoB,CAAC,IAAI,CACxF,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;QACd,IAAI,CAAC,EAAE,CAAC;YACN,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,6BAA6B,EAAE,CAAC,CAAC;QACrD,CAAC;aAAM,CAAC;YACN,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC;QACvB,CAAC;IACH,CAAC,CAAC,CACH,CAAC;IAEO,aAAa,GAAG,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAExC,iBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,OAAO,CAAC,CAAC;IAElE,aAAa,GAAG,QAAQ,CAAC,GAAG,EAAE;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QAErC,IAAI,OAAO,GAA2B,SAAS,CAAC;QAEhD,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,QAAQ,IAAI,0BAA0B,EAAE,CAAC,CAAC;YACnG,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,CAAC,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;QAC7F,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC,CAAC;IAEM,cAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,IAAI,MAAM,CAAC,CAAC;IAEtE,mBAAmB,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC3C,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAC7C,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACvC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACrC,OAAO,OAAO,CAAC,cAAc,IAAI,QAAQ,IAAI,OAAO,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEM,OAAO,GAAG,mBAAmB,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;IAElE,qBAAqB,GAAwB,GAAG,EAAE;QACzD,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CACvB,KAAK,EAAE,EACP,SAAS,CAAC,CAAC,mBAA+C,EAAE,EAAE;YAC5D,IAAI,mBAAmB,EAAE,CAAC;gBACxB,OAAO,IAAI,OAAO,CAAU,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;oBAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;oBAEvE,IAAI,uBAAuB,GAAG,EAAE,CAAC,CAAC,uCAAuC;oBAEzE,MAAM,OAAO,GAAG,GAAG,EAAE;wBACnB,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;wBAEtC,IAAI,CAAC,cAAc,IAAI,EAAE,uBAAuB,EAAE,CAAC;4BACjD,UAAU,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;wBACpC,CAAC;6BAAM,CAAC;4BACN,wCAAwC;4BACxC,OAAO,CAAC,OAAO,EAAE,CAAC;4BAElB,IAAI,cAAc,EAAE,CAAC;gCACnB,OAAO,CAAC,IAAI,CAAC,CAAC;4BAChB,CAAC;iCAAM,CAAC;gCACN,MAAM,CAAC,KAAK,CAAC,CAAC;4BAChB,CAAC;wBACH,CAAC;oBACH,CAAC,CAAC;oBAEF,OAAO,EAAE,CAAC;gBACZ,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;YACnB,CAAC;QACH,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,IAAI,OAAO,EAAE,CAAC;gBACZ,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,qBAAqB,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,CAAC;YAC3F,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,2BAA2B,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,CAAC;YACjG,CAAC;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC,CAAC;wGAlHS,4BAA4B;4FAA5B,4BAA4B,y9BAKkD,UAAU,oEC/BrG,2rCAsBA,4CDCY,gBAAgB,oJAAE,mBAAmB,kKAAE,eAAe,ohBAA4B,kBAAkB,kOAAE,wBAAwB;;4FAG7H,4BAA4B;kBAPxC,SAAS;+BAEE,wBAAwB,cACtB,IAAI,WACP,CAAC,gBAAgB,EAAE,mBAAmB,EAAE,eAAe,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,wBAAwB,CAAC,mBACxH,uBAAuB,CAAC,MAAM","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", "style", "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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLndyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2ludGVyYWN0aW9uL2ZpbHRlci9maWx0ZXIud3JhcHBlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvaW50ZXJhY3Rpb24vZmlsdGVyL2ZpbHRlci53cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRixPQUFPLEVBQUUsaUNBQWlDLEVBQUUscUJBQXFCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN2SCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7Ozs7OztBQUd6RDs7OztHQUlHO0FBU0gsTUFBTSxPQUFPLHlCQUF1QyxTQUFRLGlDQUFvQztJQUNyRixxQkFBcUIsR0FBRyxNQUFNLENBQUMsQ0FBQSxxQkFBd0IsQ0FBQSxDQUFDLENBQUM7SUFFekQsV0FBVyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxQixXQUFXLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLFNBQVMsR0FBRyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDakMsU0FBUyxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUVyQztRQUNFLEtBQUssRUFBRSxDQUFDO1FBRVIsNkJBQTZCO1FBQzdCLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLE1BQVMsRUFBRSxRQUFrQyxFQUFFLEVBQUU7WUFDbEcsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM3QyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLDBCQUEwQjtRQUMzRCxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzNDLENBQUM7d0dBekJVLHlCQUF5Qjs0RkFBekIseUJBQXlCLHltQkFMekIsQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxpRENoQjdDLHdkQWNBLDJDRElZLGVBQWUsOFdBQUUsZUFBZSwySUFBRSxhQUFhLG1MQUFFLGdCQUFnQjs7NEZBR2hFLHlCQUF5QjtrQkFSckMsU0FBUzsrQkFDRSxvQkFBb0IsYUFFbkIsQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxjQUMvQixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsQ0FBQyxtQkFDM0QsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0RGJ4QWN0aW9uSGFuZGxlckRpcmVjdGl2ZSwgRmlsdGVyU291cmNlRGlyZWN0aXZlLCBwcm92aWRlQWN0aW9uU3RvcmVTb3VyY2UgfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgRGJ4QnV0dG9uTW9kdWxlIH0gZnJvbSAnLi4vLi4vYnV0dG9uL2J1dHRvbi5tb2R1bGUnO1xuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dCc7XG5pbXBvcnQgeyBXb3JrSW5zdGFuY2UgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcblxuLyoqXG4gKiBBY3Rpb24gY29tcG9uZW50IHVzZWQgdG8gc2ltcGxpZnkgY3JlYXRpbmcgYSBmaWx0ZXIgZm9ybS5cbiAqXG4gKiBQcm92aWRlcyBhIERieEFjdGlvbiBhbmQgY29uZmlndXJlcyB0aGUgYWN0aW9uIHRvIHNldCB0aGUgZmlsdGVyIG9uIGEgRmlsdGVyU291cmNlRGlyZWN0aXZlIHdoZW4gdHJpZ2dlcmVkLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtZmlsdGVyLXdyYXBwZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLndyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtwcm92aWRlQWN0aW9uU3RvcmVTb3VyY2UobnVsbCldLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRGJ4QnV0dG9uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUsIEZsZXhMYXlvdXRNb2R1bGVdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBEYnhGaWx0ZXJXcmFwcGVyQ29tcG9uZW50PEYgPSB1bmtub3duPiBleHRlbmRzIEFic3RyYWN0RGJ4QWN0aW9uSGFuZGxlckRpcmVjdGl2ZTxGPiB7XG4gIHJlYWRvbmx5IGZpbHRlclNvdXJjZURpcmVjdGl2ZSA9IGluamVjdChGaWx0ZXJTb3VyY2VEaXJlY3RpdmU8Rj4pO1xuXG4gIHJlYWRvbmx5IHNob3dCdXR0b25zID0gaW5wdXQodHJ1ZSk7XG4gIHJlYWRvbmx5IGFwcGx5UmFpc2VkID0gaW5wdXQodHJ1ZSk7XG4gIHJlYWRvbmx5IGFwcGx5SWNvbiA9IGlucHV0KCdmaWx0ZXJfbGlzdCcpO1xuICByZWFkb25seSBhcHBseVRleHQgPSBpbnB1dCgnRmlsdGVyJyk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIC8vIGNvbmZpZ3VyZSBoYW5kbGVyIGZ1bmN0aW9uXG4gICAgdGhpcy5fZGJ4QWN0aW9uSGFuZGxlckluc3RhbmNlLnNldEhhbmRsZXJGdW5jdGlvbigoZmlsdGVyOiBGLCBpbnN0YW5jZTogV29ya0luc3RhbmNlPEYsIHVua25vd24+KSA9PiB7XG4gICAgICB0aGlzLmZpbHRlclNvdXJjZURpcmVjdGl2ZS5zZXRGaWx0ZXIoZmlsdGVyKTtcbiAgICAgIGluc3RhbmNlLnN1Y2Nlc3ModHJ1ZSk7XG4gICAgfSk7XG4gIH1cblxuICBhcHBseUZpbHRlcigpOiB2b2lkIHtcbiAgICB0aGlzLnNvdXJjZS5zZXRJc01vZGlmaWVkKHRydWUpOyAvLyBGb3JjZSBzZXR0aW5nIG1vZGlmaWVkLlxuICAgIHRoaXMuc291cmNlLnRyaWdnZXIoKTtcbiAgfVxuXG4gIHJlc2V0RmlsdGVyKCk6IHZvaWQge1xuICAgIHRoaXMuZmlsdGVyU291cmNlRGlyZWN0aXZlLnJlc2V0RmlsdGVyKCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJkYngtZmlsdGVyLXdyYXBwZXJcIj5cbiAgPGRpdiBjbGFzcz1cImRieC1maWx0ZXItd3JhcHBlci1jb250ZW50XCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbiAgQGlmIChzaG93QnV0dG9ucygpKSB7XG4gICAgPGRpdiBmeExheW91dD1cInJvd1wiPlxuICAgICAgPGRieC1idXR0b24gZGJ4QWN0aW9uQnV0dG9uIFtyYWlzZWRdPVwiYXBwbHlSYWlzZWQoKVwiIFt0ZXh0XT1cImFwcGx5VGV4dCgpXCIgW2ljb25dPVwiYXBwbHlJY29uKClcIj48L2RieC1idXR0b24+XG4gICAgICA8ZGl2IGNsYXNzPVwic3BhY2VyXCI+PC9kaXY+XG4gICAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwicmVzZXRGaWx0ZXIoKVwiPlxuICAgICAgICA8bWF0LWljb24+Y2xlYXI8L21hdC1pY29uPlxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuIl19
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", "style", "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,
@@ -79,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
79
79
  changeDetection: ChangeDetectionStrategy.OnPush
80
80
  }]
81
81
  }] });
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmxpbWl0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sYXlvdXQvdGV4dC9udW1iZXIubGltaXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUE4Q25FLE1BQU0sT0FBTywyQkFBMkI7SUFDN0IsTUFBTSxHQUFHLEtBQUssRUFBc0IsQ0FBQztJQUNyQyxPQUFPLEdBQUcsS0FBSyxFQUFXLENBQUM7SUFFM0IsV0FBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzdCLE9BQU8sTUFBTSxFQUFFLFlBQVksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUM7SUFDbEYsQ0FBQyxDQUFDLENBQUM7SUFFTSxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUNuQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDN0IsT0FBTyxNQUFNLEVBQUUsS0FBSyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsWUFBWSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDeEgsQ0FBQyxDQUFDLENBQUM7SUFFTSxjQUFjLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUN0QyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxLQUFLLElBQUksSUFBSSxDQUFDO0lBQ3RDLENBQUMsQ0FBQyxDQUFDO0lBRU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDcEMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsTUFBTSxDQUFDO0lBQy9CLENBQUMsQ0FBQyxDQUFDO0lBRU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDcEMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsTUFBTSxDQUFDO0lBQy9CLENBQUMsQ0FBQyxDQUFDO0lBRU0sV0FBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzdCLElBQUksS0FBMkIsQ0FBQztRQUVoQyxJQUFJLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNuQixNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLE1BQU0sQ0FBQztZQUVoQyxJQUFJLEtBQUssSUFBSSxJQUFJLEVBQUUsQ0FBQztnQkFDbEIsSUFBSSxLQUFLLEdBQUcsS0FBSyxFQUFFLENBQUM7b0JBQ2xCLEtBQUssR0FBRyxNQUFNLENBQUM7Z0JBQ2pCLENBQUM7cUJBQU0sSUFBSSxLQUFLLEtBQUssS0FBSyxFQUFFLENBQUM7b0JBQzNCLEtBQUssR0FBRyxRQUFRLENBQUM7Z0JBQ25CLENBQUM7cUJBQU0sQ0FBQztvQkFDTixNQUFNLEtBQUssR0FBRyxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7b0JBRTlDLElBQUksS0FBSyxHQUFHLEdBQUcsRUFBRSxDQUFDO3dCQUNoQixLQUFLLEdBQUcsUUFBUSxDQUFDO29CQUNuQixDQUFDO3lCQUFNLENBQUM7d0JBQ04sS0FBSyxHQUFHLElBQUksQ0FBQztvQkFDZixDQUFDO2dCQUNILENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQyxDQUFDLENBQUM7d0dBbkRRLDJCQUEyQjs0RkFBM0IsMkJBQTJCLHNWQWY1Qjs7Ozs7Ozs7OztHQVVULDREQUNTLGlCQUFpQjs7NEZBSWhCLDJCQUEyQjtrQkFqQnZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsUUFBUSxFQUFFOzs7Ozs7Ozs7O0dBVVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhDb2xvckRpcmVjdGl2ZSB9IGZyb20gJy4uL3N0eWxlL3N0eWxlLmNvbG9yLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYnhUaGVtZUNvbG9yIH0gZnJvbSAnLi4vc3R5bGUvc3R5bGUnO1xuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIHRoZSBEYnhOdW1iZXJXaXRoTGltaXRDb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTnVtYmVyV2l0aExpbWl0PFQgZXh0ZW5kcyBudW1iZXI+IHtcbiAgLyoqXG4gICAqIE51bWJlciB0byBkaXNwbGF5LCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgdmFsdWU6IFQ7XG4gIC8qKlxuICAgKiBMaW1pdCB0byBkaXNwbGF5LCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgbGltaXQ/OiBNYXliZTxUPjtcbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHRvIGZvcm1hdCB0aGUgaW5wdXQgbnVtYmVyKHMpIHRvIGEgc3RyaW5nIGJlZm9yZSBiZWluZyBkaXNwbGF5ZWQsIGlmIGFwcGxpY2FibGUuXG4gICAqL1xuICByZWFkb25seSBmb3JtYXROdW1iZXI/OiBNYXliZTwobnVtYmVyOiBUKSA9PiBzdHJpbmc+O1xuICAvKipcbiAgICogUHJlZml4IHRvIGFkZCBiZWZvcmUgdGhlIHZhbHVlXG4gICAqL1xuICByZWFkb25seSBwcmVmaXg/OiBNYXliZTxzdHJpbmc+O1xuICAvKipcbiAgICogU3VmZml4IHRvIGFkZCBhZnRlciB0aGUgdmFsdWVcbiAgICovXG4gIHJlYWRvbmx5IHN1ZmZpeD86IE1heWJlPHN0cmluZz47XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1udW1iZXItd2l0aC1saW1pdCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPHNwYW4gY2xhc3M9XCJkYngtbnVtYmVyLXdpdGgtbGltaXRcIiBbY2xhc3NdPVwieyAnZGJ4LW51bWJlci13aXRoLWxpbWl0LXJvdW5kZWQnOiByb3VuZGVkKCkgfVwiIFtkYnhDb2xvcl09XCJjb2xvclNpZ25hbCgpXCI+XG4gICAgICA8c3Bhbj57eyBwcmVmaXhTaWduYWwoKSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuPnt7IHZhbHVlU2lnbmFsKCkgfX08L3NwYW4+XG4gICAgICBAaWYgKGhhc0xpbWl0U2lnbmFsKCkpIHtcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJkYngtbnVtYmVyLXdpdGgtbGltaXQtZGl2aWRlclwiPi88L3NwYW4+XG4gICAgICAgIDxzcGFuPnt7IGxpbWl0U2lnbmFsKCkgfX08L3NwYW4+XG4gICAgICB9XG4gICAgICA8c3Bhbj57eyBzdWZmaXhTaWduYWwoKSB9fTwvc3Bhbj5cbiAgICA8L3NwYW4+XG4gIGAsXG4gIGltcG9ydHM6IFtEYnhDb2xvckRpcmVjdGl2ZV0sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieE51bWJlcldpdGhMaW1pdENvbXBvbmVudDxUIGV4dGVuZHMgbnVtYmVyPiB7XG4gIHJlYWRvbmx5IG51bWJlciA9IGlucHV0PE51bWJlcldpdGhMaW1pdDxUPj4oKTtcbiAgcmVhZG9ubHkgcm91bmRlZCA9IGlucHV0PGJvb2xlYW4+KCk7XG5cbiAgcmVhZG9ubHkgdmFsdWVTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgbnVtYmVyID0gdGhpcy5udW1iZXIoKTtcbiAgICByZXR1cm4gbnVtYmVyPy5mb3JtYXROdW1iZXIgPyBudW1iZXIuZm9ybWF0TnVtYmVyKG51bWJlci52YWx1ZSkgOiBudW1iZXI/LnZhbHVlO1xuICB9KTtcblxuICByZWFkb25seSBsaW1pdFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBudW1iZXIgPSB0aGlzLm51bWJlcigpO1xuICAgIHJldHVybiBudW1iZXI/LmxpbWl0ICE9IG51bGwgPyAobnVtYmVyPy5mb3JtYXROdW1iZXIgPyBudW1iZXIuZm9ybWF0TnVtYmVyKG51bWJlci5saW1pdCkgOiBudW1iZXI/LmxpbWl0KSA6IHVuZGVmaW5lZDtcbiAgfSk7XG5cbiAgcmVhZG9ubHkgaGFzTGltaXRTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMubnVtYmVyKCk/LmxpbWl0ICE9IG51bGw7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IHByZWZpeFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICByZXR1cm4gdGhpcy5udW1iZXIoKT8ucHJlZml4O1xuICB9KTtcblxuICByZWFkb25seSBzdWZmaXhTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMubnVtYmVyKCk/LnN1ZmZpeDtcbiAgfSk7XG5cbiAgcmVhZG9ubHkgY29sb3JTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgbnVtYmVyID0gdGhpcy5udW1iZXIoKTtcbiAgICBsZXQgY29sb3I6IE1heWJlPERieFRoZW1lQ29sb3I+O1xuXG4gICAgaWYgKG51bWJlciAhPSBudWxsKSB7XG4gICAgICBjb25zdCB7IHZhbHVlLCBsaW1pdCB9ID0gbnVtYmVyO1xuXG4gICAgICBpZiAobGltaXQgIT0gbnVsbCkge1xuICAgICAgICBpZiAodmFsdWUgPiBsaW1pdCkge1xuICAgICAgICAgIGNvbG9yID0gJ3dhcm4nO1xuICAgICAgICB9IGVsc2UgaWYgKHZhbHVlID09PSBsaW1pdCkge1xuICAgICAgICAgIGNvbG9yID0gJ25vdGljZSc7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgY29uc3QgcmF0aW8gPSBsaW1pdCA9PT0gMCA/IDEgOiB2YWx1ZSAvIGxpbWl0O1xuXG4gICAgICAgICAgaWYgKHJhdGlvID4gMC44KSB7XG4gICAgICAgICAgICBjb2xvciA9ICdub3RpY2UnO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb2xvciA9ICdvayc7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbG9yO1xuICB9KTtcbn1cbiJdfQ==
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmxpbWl0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9sYXlvdXQvdGV4dC9udW1iZXIubGltaXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUE4Q25FLE1BQU0sT0FBTywyQkFBMkI7SUFDN0IsTUFBTSxHQUFHLEtBQUssRUFBc0IsQ0FBQztJQUNyQyxPQUFPLEdBQUcsS0FBSyxFQUFXLENBQUM7SUFFM0IsV0FBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzdCLE9BQU8sTUFBTSxFQUFFLFlBQVksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUM7SUFDbEYsQ0FBQyxDQUFDLENBQUM7SUFFTSxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUNuQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDN0IsT0FBTyxNQUFNLEVBQUUsS0FBSyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsWUFBWSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDeEgsQ0FBQyxDQUFDLENBQUM7SUFFTSxjQUFjLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUN0QyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxLQUFLLElBQUksSUFBSSxDQUFDO0lBQ3RDLENBQUMsQ0FBQyxDQUFDO0lBRU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDcEMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsTUFBTSxDQUFDO0lBQy9CLENBQUMsQ0FBQyxDQUFDO0lBRU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDcEMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsTUFBTSxDQUFDO0lBQy9CLENBQUMsQ0FBQyxDQUFDO0lBRU0sV0FBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7UUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzdCLElBQUksS0FBMkIsQ0FBQztRQUVoQyxJQUFJLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNuQixNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLE1BQU0sQ0FBQztZQUVoQyxJQUFJLEtBQUssSUFBSSxJQUFJLEVBQUUsQ0FBQztnQkFDbEIsSUFBSSxLQUFLLEdBQUcsS0FBSyxFQUFFLENBQUM7b0JBQ2xCLEtBQUssR0FBRyxNQUFNLENBQUM7Z0JBQ2pCLENBQUM7cUJBQU0sSUFBSSxLQUFLLEtBQUssS0FBSyxFQUFFLENBQUM7b0JBQzNCLEtBQUssR0FBRyxRQUFRLENBQUM7Z0JBQ25CLENBQUM7cUJBQU0sQ0FBQztvQkFDTixNQUFNLEtBQUssR0FBRyxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7b0JBRTlDLElBQUksS0FBSyxHQUFHLEdBQUcsRUFBRSxDQUFDO3dCQUNoQixLQUFLLEdBQUcsUUFBUSxDQUFDO29CQUNuQixDQUFDO3lCQUFNLENBQUM7d0JBQ04sS0FBSyxHQUFHLElBQUksQ0FBQztvQkFDZixDQUFDO2dCQUNILENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQyxDQUFDLENBQUM7d0dBbkRRLDJCQUEyQjs0RkFBM0IsMkJBQTJCLHNWQWY1Qjs7Ozs7Ozs7OztHQVVULDREQUNTLGlCQUFpQjs7NEZBSWhCLDJCQUEyQjtrQkFqQnZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsUUFBUSxFQUFFOzs7Ozs7Ozs7O0dBVVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhDb2xvckRpcmVjdGl2ZSB9IGZyb20gJy4uL3N0eWxlL3N0eWxlLmNvbG9yLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYnhUaGVtZUNvbG9yIH0gZnJvbSAnLi4vc3R5bGUvc3R5bGUnO1xuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIHRoZSBEYnhOdW1iZXJXaXRoTGltaXRDb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTnVtYmVyV2l0aExpbWl0PFQgZXh0ZW5kcyBudW1iZXIgPSBudW1iZXI+IHtcbiAgLyoqXG4gICAqIE51bWJlciB0byBkaXNwbGF5LCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgdmFsdWU6IFQ7XG4gIC8qKlxuICAgKiBMaW1pdCB0byBkaXNwbGF5LCBpZiBhcHBsaWNhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgbGltaXQ/OiBNYXliZTxUPjtcbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHRvIGZvcm1hdCB0aGUgaW5wdXQgbnVtYmVyKHMpIHRvIGEgc3RyaW5nIGJlZm9yZSBiZWluZyBkaXNwbGF5ZWQsIGlmIGFwcGxpY2FibGUuXG4gICAqL1xuICByZWFkb25seSBmb3JtYXROdW1iZXI/OiBNYXliZTwobnVtYmVyOiBUKSA9PiBzdHJpbmc+O1xuICAvKipcbiAgICogUHJlZml4IHRvIGFkZCBiZWZvcmUgdGhlIHZhbHVlXG4gICAqL1xuICByZWFkb25seSBwcmVmaXg/OiBNYXliZTxzdHJpbmc+O1xuICAvKipcbiAgICogU3VmZml4IHRvIGFkZCBhZnRlciB0aGUgdmFsdWVcbiAgICovXG4gIHJlYWRvbmx5IHN1ZmZpeD86IE1heWJlPHN0cmluZz47XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RieC1udW1iZXItd2l0aC1saW1pdCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPHNwYW4gY2xhc3M9XCJkYngtbnVtYmVyLXdpdGgtbGltaXRcIiBbY2xhc3NdPVwieyAnZGJ4LW51bWJlci13aXRoLWxpbWl0LXJvdW5kZWQnOiByb3VuZGVkKCkgfVwiIFtkYnhDb2xvcl09XCJjb2xvclNpZ25hbCgpXCI+XG4gICAgICA8c3Bhbj57eyBwcmVmaXhTaWduYWwoKSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuPnt7IHZhbHVlU2lnbmFsKCkgfX08L3NwYW4+XG4gICAgICBAaWYgKGhhc0xpbWl0U2lnbmFsKCkpIHtcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJkYngtbnVtYmVyLXdpdGgtbGltaXQtZGl2aWRlclwiPi88L3NwYW4+XG4gICAgICAgIDxzcGFuPnt7IGxpbWl0U2lnbmFsKCkgfX08L3NwYW4+XG4gICAgICB9XG4gICAgICA8c3Bhbj57eyBzdWZmaXhTaWduYWwoKSB9fTwvc3Bhbj5cbiAgICA8L3NwYW4+XG4gIGAsXG4gIGltcG9ydHM6IFtEYnhDb2xvckRpcmVjdGl2ZV0sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIERieE51bWJlcldpdGhMaW1pdENvbXBvbmVudDxUIGV4dGVuZHMgbnVtYmVyID0gbnVtYmVyPiB7XG4gIHJlYWRvbmx5IG51bWJlciA9IGlucHV0PE51bWJlcldpdGhMaW1pdDxUPj4oKTtcbiAgcmVhZG9ubHkgcm91bmRlZCA9IGlucHV0PGJvb2xlYW4+KCk7XG5cbiAgcmVhZG9ubHkgdmFsdWVTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgbnVtYmVyID0gdGhpcy5udW1iZXIoKTtcbiAgICByZXR1cm4gbnVtYmVyPy5mb3JtYXROdW1iZXIgPyBudW1iZXIuZm9ybWF0TnVtYmVyKG51bWJlci52YWx1ZSkgOiBudW1iZXI/LnZhbHVlO1xuICB9KTtcblxuICByZWFkb25seSBsaW1pdFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBudW1iZXIgPSB0aGlzLm51bWJlcigpO1xuICAgIHJldHVybiBudW1iZXI/LmxpbWl0ICE9IG51bGwgPyAobnVtYmVyPy5mb3JtYXROdW1iZXIgPyBudW1iZXIuZm9ybWF0TnVtYmVyKG51bWJlci5saW1pdCkgOiBudW1iZXI/LmxpbWl0KSA6IHVuZGVmaW5lZDtcbiAgfSk7XG5cbiAgcmVhZG9ubHkgaGFzTGltaXRTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMubnVtYmVyKCk/LmxpbWl0ICE9IG51bGw7XG4gIH0pO1xuXG4gIHJlYWRvbmx5IHByZWZpeFNpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICByZXR1cm4gdGhpcy5udW1iZXIoKT8ucHJlZml4O1xuICB9KTtcblxuICByZWFkb25seSBzdWZmaXhTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMubnVtYmVyKCk/LnN1ZmZpeDtcbiAgfSk7XG5cbiAgcmVhZG9ubHkgY29sb3JTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgbnVtYmVyID0gdGhpcy5udW1iZXIoKTtcbiAgICBsZXQgY29sb3I6IE1heWJlPERieFRoZW1lQ29sb3I+O1xuXG4gICAgaWYgKG51bWJlciAhPSBudWxsKSB7XG4gICAgICBjb25zdCB7IHZhbHVlLCBsaW1pdCB9ID0gbnVtYmVyO1xuXG4gICAgICBpZiAobGltaXQgIT0gbnVsbCkge1xuICAgICAgICBpZiAodmFsdWUgPiBsaW1pdCkge1xuICAgICAgICAgIGNvbG9yID0gJ3dhcm4nO1xuICAgICAgICB9IGVsc2UgaWYgKHZhbHVlID09PSBsaW1pdCkge1xuICAgICAgICAgIGNvbG9yID0gJ25vdGljZSc7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgY29uc3QgcmF0aW8gPSBsaW1pdCA9PT0gMCA/IDEgOiB2YWx1ZSAvIGxpbWl0O1xuXG4gICAgICAgICAgaWYgKHJhdGlvID4gMC44KSB7XG4gICAgICAgICAgICBjb2xvciA9ICdub3RpY2UnO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb2xvciA9ICdvayc7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbG9yO1xuICB9KTtcbn1cbiJdfQ==
@@ -1675,7 +1675,7 @@ var DbxButtonDisplayType;
1675
1675
  */
1676
1676
  class DbxButtonComponent extends AbstractDbxButtonDirective {
1677
1677
  type = input();
1678
- style = input();
1678
+ buttonStyle = input();
1679
1679
  color = input(undefined);
1680
1680
  spinnerColor = input(undefined);
1681
1681
  customButtonColor = input();
@@ -1688,7 +1688,7 @@ class DbxButtonComponent extends AbstractDbxButtonDirective {
1688
1688
  iconOnly = input(false, { transform: isDefinedAndNotFalse });
1689
1689
  fab = input(false, { transform: isDefinedAndNotFalse });
1690
1690
  typeSignal = computed(() => {
1691
- const style = this.style();
1691
+ const style = this.buttonStyle();
1692
1692
  let type = this.type() ?? style?.type;
1693
1693
  if (!type) {
1694
1694
  type = 'basic';
@@ -1710,7 +1710,7 @@ class DbxButtonComponent extends AbstractDbxButtonDirective {
1710
1710
  configSignal = computed(() => {
1711
1711
  // configure custom style
1712
1712
  const customStyle = {};
1713
- const style = this.style();
1713
+ const style = this.buttonStyle();
1714
1714
  const customButtonColorValue = this.customButtonColor() ?? style?.customButtonColor;
1715
1715
  if (customButtonColorValue) {
1716
1716
  customStyle['background'] = customButtonColorValue;
@@ -1748,7 +1748,7 @@ class DbxButtonComponent extends AbstractDbxButtonDirective {
1748
1748
  return config;
1749
1749
  });
1750
1750
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
1751
- 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 }, style: { classPropertyName: "style", publicName: "style", 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: `
1751
+ 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: `
1752
1752
  <dbx-progress-spinner-button (btnClick)="clickButton()" [config]="configSignal()">
1753
1753
  <ng-content></ng-content>
1754
1754
  </dbx-progress-spinner-button>
@@ -1860,7 +1860,7 @@ class DbxFilterWrapperComponent extends AbstractDbxActionHandlerDirective {
1860
1860
  this.filterSourceDirective.resetFilter();
1861
1861
  }
1862
1862
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFilterWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1863
- 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$2.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "style", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1$1.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i1.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 });
1863
+ 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$2.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: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1$1.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i1.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 });
1864
1864
  }
1865
1865
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFilterWrapperComponent, decorators: [{
1866
1866
  type: Component,
@@ -2626,7 +2626,7 @@ class DbxPopupControlButtonsComponent {
2626
2626
  }
2627
2627
  <dbx-button-spacer></dbx-button-spacer>
2628
2628
  <dbx-button [flat]="true" icon="close" color="warn" (buttonClick)="closeClicked()"></dbx-button>
2629
- `, isInline: true, dependencies: [{ kind: "ngmodule", type: DbxButtonModule }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "style", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2629
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: DbxButtonModule }, { 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 });
2630
2630
  }
2631
2631
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxPopupControlButtonsComponent, decorators: [{
2632
2632
  type: Component,
@@ -4001,7 +4001,7 @@ class DbxActionSnackbarComponent extends AbstractSubscriptionDirective {
4001
4001
  this.snackbarRef.dismiss();
4002
4002
  };
4003
4003
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxActionSnackbarComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
4004
- 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", "style", "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 });
4004
+ 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 });
4005
4005
  }
4006
4006
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxActionSnackbarComponent, decorators: [{
4007
4007
  type: Component,
@@ -4328,7 +4328,7 @@ class DbxActionUIRouterTransitionSafetyDialogComponent extends AbstractDialogDir
4328
4328
  <dbx-button-spacer></dbx-button-spacer>
4329
4329
  </ng-container>
4330
4330
  </dbx-prompt-confirm>
4331
- `, 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", "style", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
4331
+ `, 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 });
4332
4332
  }
4333
4333
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxActionUIRouterTransitionSafetyDialogComponent, decorators: [{
4334
4334
  type: Component,
@@ -5256,7 +5256,7 @@ class DbxDownloadTextViewComponent extends AbstractSubscriptionDirective {
5256
5256
  }));
5257
5257
  };
5258
5258
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDownloadTextViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
5259
- 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$2.DbxActionDirective, selector: "dbx-action,[dbxAction],dbx-action-context,[dbxActionContext]", exportAs: ["action", "dbxAction"] }, { kind: "directive", type: i1$2.DbxActionHandlerDirective, selector: "[dbxActionHandler]", inputs: ["dbxActionHandler"] }, { kind: "directive", type: i1$2.DbxActionValueDirective, selector: "dbxActionValue,[dbxActionValue]", inputs: ["dbxActionValue"] }, { kind: "directive", type: i1$2.DbxActionButtonDirective, selector: "[dbxActionButton]" }, { kind: "component", type: DbxButtonComponent, selector: "dbx-button", inputs: ["type", "style", "color", "spinnerColor", "customButtonColor", "customTextColor", "customSpinnerColor", "basic", "raised", "stroked", "flat", "iconOnly", "fab"] }, { kind: "directive", type: DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
5259
+ 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$2.DbxActionDirective, selector: "dbx-action,[dbxAction],dbx-action-context,[dbxActionContext]", exportAs: ["action", "dbxAction"] }, { kind: "directive", type: i1$2.DbxActionHandlerDirective, selector: "[dbxActionHandler]", inputs: ["dbxActionHandler"] }, { kind: "directive", type: i1$2.DbxActionValueDirective, selector: "dbxActionValue,[dbxActionValue]", inputs: ["dbxActionValue"] }, { kind: "directive", type: i1$2.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 });
5260
5260
  }
5261
5261
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxDownloadTextViewComponent, decorators: [{
5262
5262
  type: Component,