@c8y/ngx-components 1021.25.1 → 1021.25.5

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.
@@ -1 +1 @@
1
- {"version":3,"file":"stepper-buttons.component.d.ts","sourceRoot":"","sources":["../../../core/stepper/stepper-buttons.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAa,YAAY,EAAS,SAAS,EAAU,MAAM,eAAe,CAAC;AAEpG,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAE3E,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;;AAE3D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkDG;AACH,qBAIa,iBAAkB,YAAW,gBAAgB,EAAE,SAAS;IAuDjE,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,gBAAgB;IAxD1B;;;OAGG;IACM,MAAM,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACrF;;;;OAIG;IACM,OAAO,CAAC,EAAE,OAAO,CAAS;IAEnC;;OAEG;IACM,QAAQ,CAAC,EAAE,OAAO,CAAS;IAEpC;;OAEG;IACO,QAAQ,oBAAsB;IACxC;;OAEG;IACO,MAAM;iBAA+B,UAAU;cAAQ,OAAO;OAAM;IAE9E;;OAEG;IACO,MAAM;iBAA+B,UAAU;cAAQ,OAAO;OAAM;IAE9E;;OAEG;IACO,QAAQ,oBAAsB;IAExC;;;;OAIG;IACH,QAAQ,EAAE,wBAAwB,CAKhC;IACF;;OAEG;IACH,aAAa,UAAS;IAEtB,OAAO,CAAC,wBAAwB,CAAe;gBAErC,OAAO,EAAE,UAAU,EACnB,IAAI,EAAE,OAAO,EACb,gBAAgB,EAAE,gBAAgB;IAG5C;;;;;;;;;;;;OAYG;IACH,IAAa,WAAW,CAAC,IAAI,EAAE,wBAAwB,EAKtD;IAED;;OAEG;IACH,kBAAkB;IAoBlB,WAAW;IAMX;;;OAGG;IACH,MAAM;IAKN;;;;OAIG;IACH,IAAI;IASJ;;;;OAIG;IACH,IAAI;IAUJ;;;OAGG;IACH,MAAM;IAKN,OAAO,CAAC,YAAY;yCA5JT,iBAAiB;2CAAjB,iBAAiB;CAqK7B"}
1
+ {"version":3,"file":"stepper-buttons.component.d.ts","sourceRoot":"","sources":["../../../core/stepper/stepper-buttons.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAa,YAAY,EAAS,SAAS,EAAU,MAAM,eAAe,CAAC;AAEpG,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAE3E,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;;AAE3D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkDG;AACH,qBAIa,iBAAkB,YAAW,gBAAgB,EAAE,SAAS;IAuDjE,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,gBAAgB;IAxD1B;;;OAGG;IACM,MAAM,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACrF;;;;OAIG;IACM,OAAO,CAAC,EAAE,OAAO,CAAS;IAEnC;;OAEG;IACM,QAAQ,CAAC,EAAE,OAAO,CAAS;IAEpC;;OAEG;IACO,QAAQ,oBAAsB;IACxC;;OAEG;IACO,MAAM;iBAA+B,UAAU;cAAQ,OAAO;OAAM;IAE9E;;OAEG;IACO,MAAM;iBAA+B,UAAU;cAAQ,OAAO;OAAM;IAE9E;;OAEG;IACO,QAAQ,oBAAsB;IAExC;;;;OAIG;IACH,QAAQ,EAAE,wBAAwB,CAKhC;IACF;;OAEG;IACH,aAAa,UAAS;IAEtB,OAAO,CAAC,wBAAwB,CAAe;gBAErC,OAAO,EAAE,UAAU,EACnB,IAAI,EAAE,OAAO,EACb,gBAAgB,EAAE,gBAAgB;IAG5C;;;;;;;;;;;;OAYG;IACH,IAAa,WAAW,CAAC,IAAI,EAAE,wBAAwB,EAKtD;IAED;;OAEG;IACH,kBAAkB;IAoBlB,WAAW;IAMX;;;OAGG;IACH,MAAM;IAKN;;;;OAIG;IACH,IAAI;IAUJ;;;;OAIG;IACH,IAAI;IAUJ;;;OAGG;IACH,MAAM;IAKN,OAAO,CAAC,YAAY;yCA7JT,iBAAiB;2CAAjB,iBAAiB;CAsK7B"}
@@ -1 +1 @@
1
- {"version":3,"file":"application-plugins.guard.d.ts","sourceRoot":"","sources":["../../../ecosystem/application-plugins/application-plugins.guard.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAEzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;;AAExE,qBACa,uBAAuB;IACtB,OAAO,CAAC,gBAAgB;gBAAhB,gBAAgB,EAAE,gBAAgB;IAEtD,WAAW,CAAC,KAAK,EAAE,sBAAsB;yCAH9B,uBAAuB;6CAAvB,uBAAuB;CAcnC"}
1
+ {"version":3,"file":"application-plugins.guard.d.ts","sourceRoot":"","sources":["../../../ecosystem/application-plugins/application-plugins.guard.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAEzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;;AAExE,qBACa,uBAAuB;IACtB,OAAO,CAAC,gBAAgB;gBAAhB,gBAAgB,EAAE,gBAAgB;IAEtD,WAAW,CAAC,KAAK,EAAE,sBAAsB;yCAH9B,uBAAuB;6CAAvB,uBAAuB;CAoBnC"}
@@ -164,6 +164,7 @@ export class C8yStepperButtons {
164
164
  * Otherwise it will call stepper.next() as default.
165
165
  */
166
166
  next() {
167
+ this.stepper.selected.completed = true;
167
168
  if (this.onNext.observers.length > 0) {
168
169
  this.onNext.emit({ stepper: this.stepper, step: this.step });
169
170
  }
@@ -227,4 +228,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
227
228
  }], showButtons: [{
228
229
  type: Input
229
230
  }] } });
230
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper-buttons.component.js","sourceRoot":"","sources":["../../../../core/stepper/stepper-buttons.component.ts","../../../../core/stepper/stepper-buttons.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkStep } from '@angular/cdk/stepper';\nimport { AfterContentInit, Component, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { GainsightService } from '../product-experience/gainsight.service';\nimport { ACTIONS_STEPPER } from './stepper-px.constants';\nimport { C8yStepper } from './stepper.component';\nimport { StepperButtonsVisibility } from './stepper.model';\n\n/**\n * `C8yStepperButtons` provides a convenient way to have, according to\n * the `C8yStepper` and each `cdk-step`, buttons to navigate between steps or to cancel the whole\n * step-process. Buttons rendered with the help of this component will use the branding css.\n *\n * By default all steps with this component in use will render a next button, expect the last step.\n * The other way around, every step using this component will render a back button, expect the first step.\n * To get a cancel button rendered you need to handle the onCancel event.\n * For next and back button you don't need to handle the available events `onNext` and `onBack` because default behavior\n * is implemented. The default will just call, according to the button, the `stepper.next()` or `stepper.previous()`\n * methods and moves the stepper forth or back. Using the `EventEmitter` `onNext` and `onBack` will emit for you the following\n * object: `{stepper: C8yStepper, step: CdkStep}`. This is useful if you need to implement custom logic before moving\n * to the next step or sending data to a backend. In this case you need to tell the stepper to move forward or back\n * on your own.\n *\n * With the component input `[labels]` you can change the label of each button in each step. It takes an object like this:\n * `{next?: string, back?: string, cancel?: string}`\n *\n * The `[pending]` input is of type boolean and will enable css animation for the next button when true.\n *\n * If the `cdk-step` provides a `stepControl` the component will set the next button disabled when the formGroup\n * behind it is invalid. As long as the `[pending]` input is true the back and next button is also disabled.\n * This will prevent multiple clicks while running a request or stepping back while a request is ongoing.\n *\n * ```html\n * <c8y-stepper>\n *  <cdk-step>\n *    <!--\n *      your html code\n *          ...\n *          ...    -->\n *    <c8y-stepper-buttons\n *     (onNext)=\"save()\"\n *     [labels]=\"{ next: 'Save' }\"\n *     [pending]=\"pendingStatus\"\n *     ></c8y-stepper-buttons>\n *  </cdk-step>\n * </c8y-stepper>\n * ```\n *\n * ```js\n * // in your component:\n * async save() {\n *   this.pendingStatus = true;\n *   // your async request goes here ...\n *   // await something();\n *   this.pendingStatus = false;\n *   this.stepper.next();\n * }\n * ```\n */\n@Component({\n  selector: 'c8y-stepper-buttons',\n  templateUrl: './stepper-buttons.component.html'\n})\nexport class C8yStepperButtons implements AfterContentInit, OnDestroy {\n  /**\n   * Optional\n   * Specify custom labels for each button (cancel, back or next)\n   */\n  @Input() labels?: { cancel?: string; back?: string; next?: string; custom?: string };\n  /**\n   * Optional\n   * Indicates if a request is pending and sets the next button\n   * to disabled when true\n   */\n  @Input() pending?: boolean = false;\n\n  /**\n   * Disabled state of a button\n   */\n  @Input() disabled?: boolean = false;\n\n  /**\n   * EventEmitter which emits when cancel button is clicked\n   */\n  @Output() onCancel = new EventEmitter();\n  /**\n   * EventEmitter which emits {stepper: C8yStepper; step: CdkStep} when next button is clicked.\n   */\n  @Output() onNext = new EventEmitter<{ stepper: C8yStepper; step: CdkStep }>();\n\n  /**\n   * EventEmitter which emits {stepper: C8yStepper; step: CdkStep} when back button is clicked.\n   */\n  @Output() onBack = new EventEmitter<{ stepper: C8yStepper; step: CdkStep }>();\n\n  /**\n   * EventEmitter which emits when the optional custom button is clicked\n   */\n  @Output() onCustom = new EventEmitter();\n\n  /**\n   * Indicator which button should be shown.\n   * Based on the cdk-steps within the c8y-stepper\n   * next and back buttons are rendered.\n   */\n  showBtns: StepperButtonsVisibility = {\n    cancel: false,\n    back: false,\n    next: false,\n    custom: false\n  };\n  /**\n   * Flag that indicates that the default settings defined in the showBtns have been overwritten.\n   */\n  forceShowBtns = false;\n\n  private statusChangeSubscription: Subscription;\n  constructor(\n    private stepper: C8yStepper,\n    private step: CdkStep,\n    private gainsightService: GainsightService\n  ) {}\n\n  /**\n   * This option forces the display of the buttons passed by the input.\n   * It will override the default settings and take precedence over the standard settings.\n   *\n   * ```html\n   * <c8y-stepper-buttons\n   *   [labels]=\"{ custom: 'Custom btn', cancel: 'Cancel btn' }\"\n   *   [showButtons]=\"{ custom: true, cancel: true }\"\n   * ></c8y-stepper-buttons>\n   * ```\n   *\n   * @param btns An object that contains options for displaying buttons.\n   */\n  @Input() set showButtons(btns: StepperButtonsVisibility) {\n    if (btns) {\n      this.showBtns = btns;\n      this.forceShowBtns = true;\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  ngAfterContentInit() {\n    if (!this.forceShowBtns) {\n      this.showBtns.cancel = this.onCancel.observers.length > 0;\n      this.showBtns.custom = this.onCustom.observers.length > 0;\n    }\n\n    if (this.stepper && this.stepper._steps && this.step && !this.forceShowBtns) {\n      this.showBtns.back = this.stepper._steps.first !== this.step;\n      this.showBtns.next = this.stepper._steps.last !== this.step;\n    }\n\n    if (this.step && this.step.stepControl) {\n      this.disabled = this.step.stepControl.invalid;\n\n      this.statusChangeSubscription = this.step.stepControl.statusChanges.subscribe(() => {\n        this.disabled = this.step.stepControl.invalid;\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.statusChangeSubscription && !this.statusChangeSubscription.closed) {\n      this.statusChangeSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * Gets called when cancel button is clicked.\n   * It will emit immediate.\n   */\n  cancel() {\n    this.onCancel.emit();\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_CANCEL_BTN);\n  }\n\n  /**\n   * Gets called when next button is clicked. When onNext EventEmitter has an observer registered\n   * it will emit the following object {stepper: C8yStepper; step: CdkStep}.\n   * Otherwise it will call stepper.next() as default.\n   */\n  next() {\n    if (this.onNext.observers.length > 0) {\n      this.onNext.emit({ stepper: this.stepper, step: this.step });\n    } else {\n      this.stepper.next();\n    }\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_NEXT_BTN);\n  }\n\n  /**\n   * Gets called when back button is clicked. When onBack EventEmitter has an observer registered\n   * it will emit the following object {stepper: C8yStepper; step: CdkStep}.\n   * Otherwise it will call stepper.previous() as default.\n   */\n  back() {\n    this.stepper.selected.completed = false;\n    if (this.onBack.observers.length > 0) {\n      this.onBack.emit({ stepper: this.stepper, step: this.step });\n    } else {\n      this.stepper.previous();\n    }\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_BACK_BTN);\n  }\n\n  /**\n   * Gets called when the custom button is clicked.\n   * It will emit immediately.\n   */\n  custom() {\n    this.onCustom.emit();\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_CUSTOM_BTN);\n  }\n\n  private triggerEvent(action: string): void {\n    const eventData = {\n      ...this.stepper.productExperienceEvent?.data,\n      action,\n      step: this.gainsightService.translateToEnglish(this.step.label)\n    };\n    const eventName = this.stepper.productExperienceEvent?.eventName || 'c8yStepper';\n    this.gainsightService.triggerEvent(eventName, eventData);\n  }\n}\n","<div class=\"text-center\">\n  <button\n    class=\"btn btn-default\"\n    title=\"{{ labels?.cancel || 'Cancel' | translate }}\"\n    data-cy=\"cancel\"\n    type=\"button\"\n    *ngIf=\"showBtns.cancel\"\n    (click)=\"cancel()\"\n  >\n    <span\n      title=\"{{ labels?.cancel | translate }}\"\n      *ngIf=\"labels?.cancel; else cancelLabel\"\n    >\n      {{ labels?.cancel | translate }}\n    </span>\n    <ng-template #cancelLabel>\n      <span title=\"{{ 'Cancel' | translate }}\">{{ 'Cancel' | translate }}</span>\n    </ng-template>\n  </button>\n  <button\n    class=\"btn btn-default\"\n    title=\"{{ labels?.back || 'Back' | translate }}\"\n    type=\"button\"\n    *ngIf=\"showBtns.back\"\n    (click)=\"back()\"\n    [disabled]=\"pending\"\n    data-cy=\"back\"\n  >\n    <span\n      title=\"{{ labels?.back | translate }}\"\n      *ngIf=\"labels?.back; else backLabel\"\n    >\n      {{ labels?.back | translate }}\n    </span>\n    <ng-template #backLabel>\n      <span title=\"{{ 'Back' | translate }}\">{{ 'Back' | translate }}</span>\n    </ng-template>\n  </button>\n  <button\n    class=\"btn\"\n    title=\"{{ labels?.custom || 'Complete' | translate }}\"\n    type=\"button\"\n    *ngIf=\"showBtns.custom\"\n    (click)=\"custom()\"\n    [ngClass]=\"{\n      'btn-default': showBtns.next,\n      'btn-primary': !showBtns.next,\n      'btn-pending': pending\n    }\"\n    [disabled]=\"disabled\"\n    data-cy=\"custom\"\n  >\n    <span\n      title=\"{{ labels?.custom | translate }}\"\n      *ngIf=\"labels?.custom; else customLabel\"\n    >\n      {{ labels?.custom | translate }}\n    </span>\n    <ng-template #customLabel>\n      <span title=\"{{ 'Complete' | translate }}\">{{ 'Complete' | translate }}</span>\n    </ng-template>\n  </button>\n  <button\n    class=\"btn btn-primary\"\n    title=\"{{ labels?.next || 'Next' | translate }}\"\n    type=\"button\"\n    (click)=\"next()\"\n    *ngIf=\"showBtns.next\"\n    [ngClass]=\"{ 'btn-pending': pending }\"\n    [disabled]=\"disabled\"\n    data-cy=\"next\"\n  >\n    <span\n      title=\"{{ labels?.next | translate }}\"\n      *ngIf=\"labels?.next; else nextLabel\"\n    >\n      {{ labels?.next | translate }}\n    </span>\n    <ng-template #nextLabel>\n      <span title=\"{{ 'Next' | translate }}\">{{ 'Next' | translate }}</span>\n    </ng-template>\n  </button>\n  <ng-content select=\"button\"></ng-content>\n</div>\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper-buttons.component.js","sourceRoot":"","sources":["../../../../core/stepper/stepper-buttons.component.ts","../../../../core/stepper/stepper-buttons.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkStep } from '@angular/cdk/stepper';\nimport { AfterContentInit, Component, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { GainsightService } from '../product-experience/gainsight.service';\nimport { ACTIONS_STEPPER } from './stepper-px.constants';\nimport { C8yStepper } from './stepper.component';\nimport { StepperButtonsVisibility } from './stepper.model';\n\n/**\n * `C8yStepperButtons` provides a convenient way to have, according to\n * the `C8yStepper` and each `cdk-step`, buttons to navigate between steps or to cancel the whole\n * step-process. Buttons rendered with the help of this component will use the branding css.\n *\n * By default all steps with this component in use will render a next button, expect the last step.\n * The other way around, every step using this component will render a back button, expect the first step.\n * To get a cancel button rendered you need to handle the onCancel event.\n * For next and back button you don't need to handle the available events `onNext` and `onBack` because default behavior\n * is implemented. The default will just call, according to the button, the `stepper.next()` or `stepper.previous()`\n * methods and moves the stepper forth or back. Using the `EventEmitter` `onNext` and `onBack` will emit for you the following\n * object: `{stepper: C8yStepper, step: CdkStep}`. This is useful if you need to implement custom logic before moving\n * to the next step or sending data to a backend. In this case you need to tell the stepper to move forward or back\n * on your own.\n *\n * With the component input `[labels]` you can change the label of each button in each step. It takes an object like this:\n * `{next?: string, back?: string, cancel?: string}`\n *\n * The `[pending]` input is of type boolean and will enable css animation for the next button when true.\n *\n * If the `cdk-step` provides a `stepControl` the component will set the next button disabled when the formGroup\n * behind it is invalid. As long as the `[pending]` input is true the back and next button is also disabled.\n * This will prevent multiple clicks while running a request or stepping back while a request is ongoing.\n *\n * ```html\n * <c8y-stepper>\n *  <cdk-step>\n *    <!--\n *      your html code\n *          ...\n *          ...    -->\n *    <c8y-stepper-buttons\n *     (onNext)=\"save()\"\n *     [labels]=\"{ next: 'Save' }\"\n *     [pending]=\"pendingStatus\"\n *     ></c8y-stepper-buttons>\n *  </cdk-step>\n * </c8y-stepper>\n * ```\n *\n * ```js\n * // in your component:\n * async save() {\n *   this.pendingStatus = true;\n *   // your async request goes here ...\n *   // await something();\n *   this.pendingStatus = false;\n *   this.stepper.next();\n * }\n * ```\n */\n@Component({\n  selector: 'c8y-stepper-buttons',\n  templateUrl: './stepper-buttons.component.html'\n})\nexport class C8yStepperButtons implements AfterContentInit, OnDestroy {\n  /**\n   * Optional\n   * Specify custom labels for each button (cancel, back or next)\n   */\n  @Input() labels?: { cancel?: string; back?: string; next?: string; custom?: string };\n  /**\n   * Optional\n   * Indicates if a request is pending and sets the next button\n   * to disabled when true\n   */\n  @Input() pending?: boolean = false;\n\n  /**\n   * Disabled state of a button\n   */\n  @Input() disabled?: boolean = false;\n\n  /**\n   * EventEmitter which emits when cancel button is clicked\n   */\n  @Output() onCancel = new EventEmitter();\n  /**\n   * EventEmitter which emits {stepper: C8yStepper; step: CdkStep} when next button is clicked.\n   */\n  @Output() onNext = new EventEmitter<{ stepper: C8yStepper; step: CdkStep }>();\n\n  /**\n   * EventEmitter which emits {stepper: C8yStepper; step: CdkStep} when back button is clicked.\n   */\n  @Output() onBack = new EventEmitter<{ stepper: C8yStepper; step: CdkStep }>();\n\n  /**\n   * EventEmitter which emits when the optional custom button is clicked\n   */\n  @Output() onCustom = new EventEmitter();\n\n  /**\n   * Indicator which button should be shown.\n   * Based on the cdk-steps within the c8y-stepper\n   * next and back buttons are rendered.\n   */\n  showBtns: StepperButtonsVisibility = {\n    cancel: false,\n    back: false,\n    next: false,\n    custom: false\n  };\n  /**\n   * Flag that indicates that the default settings defined in the showBtns have been overwritten.\n   */\n  forceShowBtns = false;\n\n  private statusChangeSubscription: Subscription;\n  constructor(\n    private stepper: C8yStepper,\n    private step: CdkStep,\n    private gainsightService: GainsightService\n  ) {}\n\n  /**\n   * This option forces the display of the buttons passed by the input.\n   * It will override the default settings and take precedence over the standard settings.\n   *\n   * ```html\n   * <c8y-stepper-buttons\n   *   [labels]=\"{ custom: 'Custom btn', cancel: 'Cancel btn' }\"\n   *   [showButtons]=\"{ custom: true, cancel: true }\"\n   * ></c8y-stepper-buttons>\n   * ```\n   *\n   * @param btns An object that contains options for displaying buttons.\n   */\n  @Input() set showButtons(btns: StepperButtonsVisibility) {\n    if (btns) {\n      this.showBtns = btns;\n      this.forceShowBtns = true;\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  ngAfterContentInit() {\n    if (!this.forceShowBtns) {\n      this.showBtns.cancel = this.onCancel.observers.length > 0;\n      this.showBtns.custom = this.onCustom.observers.length > 0;\n    }\n\n    if (this.stepper && this.stepper._steps && this.step && !this.forceShowBtns) {\n      this.showBtns.back = this.stepper._steps.first !== this.step;\n      this.showBtns.next = this.stepper._steps.last !== this.step;\n    }\n\n    if (this.step && this.step.stepControl) {\n      this.disabled = this.step.stepControl.invalid;\n\n      this.statusChangeSubscription = this.step.stepControl.statusChanges.subscribe(() => {\n        this.disabled = this.step.stepControl.invalid;\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.statusChangeSubscription && !this.statusChangeSubscription.closed) {\n      this.statusChangeSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * Gets called when cancel button is clicked.\n   * It will emit immediate.\n   */\n  cancel() {\n    this.onCancel.emit();\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_CANCEL_BTN);\n  }\n\n  /**\n   * Gets called when next button is clicked. When onNext EventEmitter has an observer registered\n   * it will emit the following object {stepper: C8yStepper; step: CdkStep}.\n   * Otherwise it will call stepper.next() as default.\n   */\n  next() {\n    this.stepper.selected.completed = true;\n    if (this.onNext.observers.length > 0) {\n      this.onNext.emit({ stepper: this.stepper, step: this.step });\n    } else {\n      this.stepper.next();\n    }\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_NEXT_BTN);\n  }\n\n  /**\n   * Gets called when back button is clicked. When onBack EventEmitter has an observer registered\n   * it will emit the following object {stepper: C8yStepper; step: CdkStep}.\n   * Otherwise it will call stepper.previous() as default.\n   */\n  back() {\n    this.stepper.selected.completed = false;\n    if (this.onBack.observers.length > 0) {\n      this.onBack.emit({ stepper: this.stepper, step: this.step });\n    } else {\n      this.stepper.previous();\n    }\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_BACK_BTN);\n  }\n\n  /**\n   * Gets called when the custom button is clicked.\n   * It will emit immediately.\n   */\n  custom() {\n    this.onCustom.emit();\n    this.triggerEvent(ACTIONS_STEPPER.CLICK_STEPPER_CUSTOM_BTN);\n  }\n\n  private triggerEvent(action: string): void {\n    const eventData = {\n      ...this.stepper.productExperienceEvent?.data,\n      action,\n      step: this.gainsightService.translateToEnglish(this.step.label)\n    };\n    const eventName = this.stepper.productExperienceEvent?.eventName || 'c8yStepper';\n    this.gainsightService.triggerEvent(eventName, eventData);\n  }\n}\n","<div class=\"text-center\">\n  <button\n    class=\"btn btn-default\"\n    title=\"{{ labels?.cancel || 'Cancel' | translate }}\"\n    data-cy=\"cancel\"\n    type=\"button\"\n    *ngIf=\"showBtns.cancel\"\n    (click)=\"cancel()\"\n  >\n    <span\n      title=\"{{ labels?.cancel | translate }}\"\n      *ngIf=\"labels?.cancel; else cancelLabel\"\n    >\n      {{ labels?.cancel | translate }}\n    </span>\n    <ng-template #cancelLabel>\n      <span title=\"{{ 'Cancel' | translate }}\">{{ 'Cancel' | translate }}</span>\n    </ng-template>\n  </button>\n  <button\n    class=\"btn btn-default\"\n    title=\"{{ labels?.back || 'Back' | translate }}\"\n    type=\"button\"\n    *ngIf=\"showBtns.back\"\n    (click)=\"back()\"\n    [disabled]=\"pending\"\n    data-cy=\"back\"\n  >\n    <span\n      title=\"{{ labels?.back | translate }}\"\n      *ngIf=\"labels?.back; else backLabel\"\n    >\n      {{ labels?.back | translate }}\n    </span>\n    <ng-template #backLabel>\n      <span title=\"{{ 'Back' | translate }}\">{{ 'Back' | translate }}</span>\n    </ng-template>\n  </button>\n  <button\n    class=\"btn\"\n    title=\"{{ labels?.custom || 'Complete' | translate }}\"\n    type=\"button\"\n    *ngIf=\"showBtns.custom\"\n    (click)=\"custom()\"\n    [ngClass]=\"{\n      'btn-default': showBtns.next,\n      'btn-primary': !showBtns.next,\n      'btn-pending': pending\n    }\"\n    [disabled]=\"disabled\"\n    data-cy=\"custom\"\n  >\n    <span\n      title=\"{{ labels?.custom | translate }}\"\n      *ngIf=\"labels?.custom; else customLabel\"\n    >\n      {{ labels?.custom | translate }}\n    </span>\n    <ng-template #customLabel>\n      <span title=\"{{ 'Complete' | translate }}\">{{ 'Complete' | translate }}</span>\n    </ng-template>\n  </button>\n  <button\n    class=\"btn btn-primary\"\n    title=\"{{ labels?.next || 'Next' | translate }}\"\n    type=\"button\"\n    (click)=\"next()\"\n    *ngIf=\"showBtns.next\"\n    [ngClass]=\"{ 'btn-pending': pending }\"\n    [disabled]=\"disabled\"\n    data-cy=\"next\"\n  >\n    <span\n      title=\"{{ labels?.next | translate }}\"\n      *ngIf=\"labels?.next; else nextLabel\"\n    >\n      {{ labels?.next | translate }}\n    </span>\n    <ng-template #nextLabel>\n      <span title=\"{{ 'Next' | translate }}\">{{ 'Next' | translate }}</span>\n    </ng-template>\n  </button>\n  <ng-content select=\"button\"></ng-content>\n</div>\n"]}
@@ -12,9 +12,15 @@ export class ApplicationPluginsGuard {
12
12
  if (!app) {
13
13
  return false;
14
14
  }
15
+ const manifest = app.manifest;
16
+ if (!manifest) {
17
+ return false;
18
+ }
15
19
  return (app.type === ApplicationType.HOSTED &&
16
20
  this.ecosystemService.isOwner(app) &&
17
- !this.ecosystemService.isPackage(app));
21
+ !this.ecosystemService.isPackage(app) &&
22
+ // apps like e.g. the public-options should not have the plugins tab
23
+ !manifest.noAppSwitcher);
18
24
  }
19
25
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ApplicationPluginsGuard, deps: [{ token: i1.EcosystemService }], target: i0.ɵɵFactoryTarget.Injectable }); }
20
26
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ApplicationPluginsGuard }); }
@@ -22,4 +28,4 @@ export class ApplicationPluginsGuard {
22
28
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ApplicationPluginsGuard, decorators: [{
23
29
  type: Injectable
24
30
  }], ctorParameters: () => [{ type: i1.EcosystemService }] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24tcGx1Z2lucy5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2Vjb3N5c3RlbS9hcHBsaWNhdGlvbi1wbHVnaW5zL2FwcGxpY2F0aW9uLXBsdWdpbnMuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOzs7QUFHeEUsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxZQUFvQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUFHLENBQUM7SUFFMUQsV0FBVyxDQUFDLEtBQTZCO1FBQ3ZDLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsV0FBVyxJQUFJLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQztRQUNwRSxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDVCxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7UUFDRCxPQUFPLENBQ0wsR0FBRyxDQUFDLElBQUksS0FBSyxlQUFlLENBQUMsTUFBTTtZQUNuQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQztZQUNsQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQ3RDLENBQUM7SUFDSixDQUFDOzhHQWJVLHVCQUF1QjtrSEFBdkIsdUJBQXVCOzsyRkFBdkIsdUJBQXVCO2tCQURuQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBBcHBsaWNhdGlvblR5cGUgfSBmcm9tICdAYzh5L2NsaWVudCc7XG5pbXBvcnQgeyBFY29zeXN0ZW1TZXJ2aWNlIH0gZnJvbSAnQGM4eS9uZ3gtY29tcG9uZW50cy9lY29zeXN0ZW0vc2hhcmVkJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEFwcGxpY2F0aW9uUGx1Z2luc0d1YXJkIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlY29zeXN0ZW1TZXJ2aWNlOiBFY29zeXN0ZW1TZXJ2aWNlKSB7fVxuXG4gIGNhbkFjdGl2YXRlKHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90KSB7XG4gICAgY29uc3QgYXBwID0gcm91dGUuZGF0YS5jb250ZXh0RGF0YSB8fCByb3V0ZS5wYXJlbnQuZGF0YS5jb250ZXh0RGF0YTtcbiAgICBpZiAoIWFwcCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgYXBwLnR5cGUgPT09IEFwcGxpY2F0aW9uVHlwZS5IT1NURUQgJiZcbiAgICAgIHRoaXMuZWNvc3lzdGVtU2VydmljZS5pc093bmVyKGFwcCkgJiZcbiAgICAgICF0aGlzLmVjb3N5c3RlbVNlcnZpY2UuaXNQYWNrYWdlKGFwcClcbiAgICApO1xuICB9XG59XG4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24tcGx1Z2lucy5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2Vjb3N5c3RlbS9hcHBsaWNhdGlvbi1wbHVnaW5zL2FwcGxpY2F0aW9uLXBsdWdpbnMuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsZUFBZSxFQUFnQixNQUFNLGFBQWEsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7O0FBR3hFLE1BQU0sT0FBTyx1QkFBdUI7SUFDbEMsWUFBb0IsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDO0lBRTFELFdBQVcsQ0FBQyxLQUE2QjtRQUN2QyxNQUFNLEdBQUcsR0FBaUIsS0FBSyxDQUFDLElBQUksQ0FBQyxXQUFXLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQ2xGLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNULE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUNELE1BQU0sUUFBUSxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUM7UUFDOUIsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ2QsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO1FBQ0QsT0FBTyxDQUNMLEdBQUcsQ0FBQyxJQUFJLEtBQUssZUFBZSxDQUFDLE1BQU07WUFDbkMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUM7WUFDbEMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQztZQUNyQyxvRUFBb0U7WUFDcEUsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUN4QixDQUFDO0lBQ0osQ0FBQzs4R0FuQlUsdUJBQXVCO2tIQUF2Qix1QkFBdUI7OzJGQUF2Qix1QkFBdUI7a0JBRG5DLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90IH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IEFwcGxpY2F0aW9uVHlwZSwgSUFwcGxpY2F0aW9uIH0gZnJvbSAnQGM4eS9jbGllbnQnO1xuaW1wb3J0IHsgRWNvc3lzdGVtU2VydmljZSB9IGZyb20gJ0BjOHkvbmd4LWNvbXBvbmVudHMvZWNvc3lzdGVtL3NoYXJlZCc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBBcHBsaWNhdGlvblBsdWdpbnNHdWFyZCB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWNvc3lzdGVtU2VydmljZTogRWNvc3lzdGVtU2VydmljZSkge31cblxuICBjYW5BY3RpdmF0ZShyb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCkge1xuICAgIGNvbnN0IGFwcDogSUFwcGxpY2F0aW9uID0gcm91dGUuZGF0YS5jb250ZXh0RGF0YSB8fCByb3V0ZS5wYXJlbnQuZGF0YS5jb250ZXh0RGF0YTtcbiAgICBpZiAoIWFwcCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBjb25zdCBtYW5pZmVzdCA9IGFwcC5tYW5pZmVzdDtcbiAgICBpZiAoIW1hbmlmZXN0KSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIHJldHVybiAoXG4gICAgICBhcHAudHlwZSA9PT0gQXBwbGljYXRpb25UeXBlLkhPU1RFRCAmJlxuICAgICAgdGhpcy5lY29zeXN0ZW1TZXJ2aWNlLmlzT3duZXIoYXBwKSAmJlxuICAgICAgIXRoaXMuZWNvc3lzdGVtU2VydmljZS5pc1BhY2thZ2UoYXBwKSAmJlxuICAgICAgLy8gYXBwcyBsaWtlIGUuZy4gdGhlIHB1YmxpYy1vcHRpb25zIHNob3VsZCBub3QgaGF2ZSB0aGUgcGx1Z2lucyB0YWJcbiAgICAgICFtYW5pZmVzdC5ub0FwcFN3aXRjaGVyXG4gICAgKTtcbiAgfVxufVxuIl19
@@ -1000,9 +1000,15 @@ class ApplicationPluginsGuard {
1000
1000
  if (!app) {
1001
1001
  return false;
1002
1002
  }
1003
+ const manifest = app.manifest;
1004
+ if (!manifest) {
1005
+ return false;
1006
+ }
1003
1007
  return (app.type === ApplicationType.HOSTED &&
1004
1008
  this.ecosystemService.isOwner(app) &&
1005
- !this.ecosystemService.isPackage(app));
1009
+ !this.ecosystemService.isPackage(app) &&
1010
+ // apps like e.g. the public-options should not have the plugins tab
1011
+ !manifest.noAppSwitcher);
1006
1012
  }
1007
1013
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ApplicationPluginsGuard, deps: [{ token: i3.EcosystemService }], target: i0.ɵɵFactoryTarget.Injectable }); }
1008
1014
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ApplicationPluginsGuard }); }