UNPKG

@y3krulez/angular-archwizard

Version:

The port of angular-archwizard, supporting IVY and thus being compatible with Angular16+

133 lines 14.3 kB
import { Directive, EventEmitter, HostListener, Inject, Input, Optional, Output } from '@angular/core'; import { isStepId } from '../util/step-id.interface'; import { isStepIndex } from '../util/step-index.interface'; import { isStepOffset } from '../util/step-offset.interface'; import { WizardStep } from '../util/wizard-step.interface'; import { WIZARD_TOKEN } from '../navigation/wizard.interface'; import * as i0 from "@angular/core"; import * as i1 from "../util/wizard-step.interface"; /** * The `awGoToStep` directive can be used to navigate to a given step. * This step can be defined in one of multiple formats * * ### Syntax * * With absolute step index: * * ```html * <button [awGoToStep]="{ stepIndex: absolute step index }" (finalize)="finalize method">...</button> * ``` * * With unique step id: * * ```html * <button [awGoToStep]="{ stepId: 'step id of destination step' }" (finalize)="finalize method">...</button> * ``` * * With a wizard step object: * * ```html * <button [awGoToStep]="wizard step object" (finalize)="finalize method">...</button> * ``` * * With an offset to the defining step: * * ```html * <button [awGoToStep]="{ stepOffset: offset }" (finalize)="finalize method">...</button> * ``` * * @author Marc Arndt */ export class GoToStepDirective { /** * Constructor * * @param wizard The wizard component * @param wizardStep The wizard step, which contains this [[GoToStepDirective]] */ constructor(wizard, wizardStep) { this.wizard = wizard; this.wizardStep = wizardStep; /** * This [[EventEmitter]] is called directly before the current step is exited during a transition through a component with this directive. */ this.preFinalize = new EventEmitter(); /** * This [[EventEmitter]] is called directly after the current step is exited during a transition through a component with this directive. */ this.postFinalize = new EventEmitter(); } /** * A convenience field for `preFinalize` */ get finalize() { return this.preFinalize; } /** * A convenience name for `preFinalize` * * @param emitter The [[EventEmitter]] to be set */ set finalize(emitter) { /* istanbul ignore next */ this.preFinalize = emitter; } /** * Returns the destination step of this directive as an absolute step index inside the wizard * * @returns The index of the destination step * @throws If `targetStep` is of an unknown type an `Error` is thrown */ get destinationStep() { let destinationStep; if (isStepIndex(this.targetStep)) { destinationStep = this.targetStep.stepIndex; } else if (isStepId(this.targetStep)) { destinationStep = this.wizard.getIndexOfStepWithId(this.targetStep.stepId); } else if (isStepOffset(this.targetStep) && this.wizardStep !== null) { destinationStep = this.wizard.getIndexOfStep(this.wizardStep) + this.targetStep.stepOffset; } else if (this.targetStep instanceof WizardStep) { destinationStep = this.wizard.getIndexOfStep(this.targetStep); } else { throw new Error(`Input 'targetStep' is neither a WizardStep, StepOffset, StepIndex or StepId`); } return destinationStep; } /** * Listener method for `click` events on the component with this directive. * After this method is called the wizard will try to transition to the `destinationStep` */ onClick() { this.wizard.goToStep(this.destinationStep, this.preFinalize, this.postFinalize); } } GoToStepDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GoToStepDirective, deps: [{ token: WIZARD_TOKEN }, { token: i1.WizardStep, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); GoToStepDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: GoToStepDirective, selector: "[awGoToStep]", inputs: { targetStep: ["awGoToStep", "targetStep"] }, outputs: { preFinalize: "preFinalize", postFinalize: "postFinalize", finalize: "finalize" }, host: { listeners: { "click": "onClick()" } }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GoToStepDirective, decorators: [{ type: Directive, args: [{ selector: '[awGoToStep]' }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [WIZARD_TOKEN] }] }, { type: i1.WizardStep, decorators: [{ type: Optional }] }]; }, propDecorators: { preFinalize: [{ type: Output }], postFinalize: [{ type: Output }], targetStep: [{ type: Input, args: ['awGoToStep'] }], finalize: [{ type: Output }], onClick: [{ type: HostListener, args: ['click'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"go-to-step.directive.js","sourceRoot":"","sources":["../../../../src/lib/directives/go-to-step.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvG,OAAO,EAAE,QAAQ,EAAU,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAa,MAAM,8BAA8B,CAAC;AACtE,OAAO,EAAE,YAAY,EAAc,MAAM,+BAA+B,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAU,MAAM,gCAAgC,CAAC;;;AAGtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AAIH,MAAM,OAAO,iBAAiB;IAuB5B;;;;;OAKG;IACH,YAAyC,MAAc,EAAsB,UAAsB;QAA1D,WAAM,GAAN,MAAM,CAAQ;QAAsB,eAAU,GAAV,UAAU,CAAY;QA5BnG;;WAEG;QAEI,gBAAW,GAAuB,IAAI,YAAY,EAAE,CAAC;QAE5D;;WAEG;QAEI,iBAAY,GAAuB,IAAI,YAAY,EAAE,CAAC;IAmB7D,CAAC;IAED;;OAEG;IACH,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;;OAIG;IACH,IACW,QAAQ,CAAC,OAA2B;QAC7C,0BAA0B;QAC1B,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC;IAC7B,CAAC;IAED;;;;;OAKG;IACH,IAAW,eAAe;QACxB,IAAI,eAAuB,CAAC;QAE5B,IAAI,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YAChC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC;SAC7C;aAAM,IAAI,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;SAC5E;aAAM,IAAI,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,EAAE;YACpE,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;SAC5F;aAAM,IAAI,IAAI,CAAC,UAAU,YAAY,UAAU,EAAE;YAChD,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAC/D;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;SAChG;QAED,OAAO,eAAe,CAAC;IACzB,CAAC;IAED;;;OAGG;IAEI,OAAO;QACZ,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAClF,CAAC;;+GAjFU,iBAAiB,kBA6BR,YAAY;mGA7BrB,iBAAiB;4FAAjB,iBAAiB;kBAH7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;iBACzB;;0BA8Bc,MAAM;2BAAC,YAAY;;0BAA0B,QAAQ;4CAxB3D,WAAW;sBADjB,MAAM;gBAOA,YAAY;sBADlB,MAAM;gBAWA,UAAU;sBADhB,KAAK;uBAAC,YAAY;gBAyBR,QAAQ;sBADlB,MAAM;gBAmCA,OAAO;sBADb,YAAY;uBAAC,OAAO","sourcesContent":["import { Directive, EventEmitter, HostListener, Inject, Input, Optional, Output } from '@angular/core';\r\nimport { isStepId, StepId } from '../util/step-id.interface';\r\nimport { isStepIndex, StepIndex } from '../util/step-index.interface';\r\nimport { isStepOffset, StepOffset } from '../util/step-offset.interface';\r\nimport { WizardStep } from '../util/wizard-step.interface';\r\nimport { WIZARD_TOKEN, Wizard } from '../navigation/wizard.interface';\r\n\r\n\r\n/**\r\n * The `awGoToStep` directive can be used to navigate to a given step.\r\n * This step can be defined in one of multiple formats\r\n *\r\n * ### Syntax\r\n *\r\n * With absolute step index:\r\n *\r\n * ```html\r\n * <button [awGoToStep]=\"{ stepIndex: absolute step index }\" (finalize)=\"finalize method\">...</button>\r\n * ```\r\n *\r\n * With unique step id:\r\n *\r\n * ```html\r\n * <button [awGoToStep]=\"{ stepId: 'step id of destination step' }\" (finalize)=\"finalize method\">...</button>\r\n * ```\r\n *\r\n * With a wizard step object:\r\n *\r\n * ```html\r\n * <button [awGoToStep]=\"wizard step object\" (finalize)=\"finalize method\">...</button>\r\n * ```\r\n *\r\n * With an offset to the defining step:\r\n *\r\n * ```html\r\n * <button [awGoToStep]=\"{ stepOffset: offset }\" (finalize)=\"finalize method\">...</button>\r\n * ```\r\n *\r\n * @author Marc Arndt\r\n */\r\n@Directive({\r\n  selector: '[awGoToStep]'\r\n})\r\nexport class GoToStepDirective {\r\n  /**\r\n   * This [[EventEmitter]] is called directly before the current step is exited during a transition through a component with this directive.\r\n   */\r\n  @Output()\r\n  public preFinalize: EventEmitter<void> = new EventEmitter();\r\n\r\n  /**\r\n   * This [[EventEmitter]] is called directly after the current step is exited during a transition through a component with this directive.\r\n   */\r\n  @Output()\r\n  public postFinalize: EventEmitter<void> = new EventEmitter();\r\n\r\n  /**\r\n   * The destination step, to which the wizard should navigate, after the component, having this directive has been activated.\r\n   * This destination step can be given either as a [[WizardStep]] containing the step directly,\r\n   * a [[StepOffset]] between the current step and the `wizardStep`, in which this directive has been used,\r\n   * or a step index as a number or string\r\n   */\r\n  // tslint:disable-next-line:no-input-rename\r\n  @Input('awGoToStep')\r\n  public targetStep: WizardStep | StepOffset | StepIndex | StepId;\r\n\r\n  /**\r\n   * Constructor\r\n   *\r\n   * @param wizard The wizard component\r\n   * @param wizardStep The wizard step, which contains this [[GoToStepDirective]]\r\n   */\r\n  constructor(@Inject(WIZARD_TOKEN) public wizard: Wizard, @Optional() private wizardStep: WizardStep) {\r\n  }\r\n\r\n  /**\r\n   * A convenience field for `preFinalize`\r\n   */\r\n  public get finalize(): EventEmitter<void> {\r\n    return this.preFinalize;\r\n  }\r\n\r\n  /**\r\n   * A convenience name for `preFinalize`\r\n   *\r\n   * @param emitter The [[EventEmitter]] to be set\r\n   */\r\n  @Output()\r\n  public set finalize(emitter: EventEmitter<void>) {\r\n    /* istanbul ignore next */\r\n    this.preFinalize = emitter;\r\n  }\r\n\r\n  /**\r\n   * Returns the destination step of this directive as an absolute step index inside the wizard\r\n   *\r\n   * @returns The index of the destination step\r\n   * @throws If `targetStep` is of an unknown type an `Error` is thrown\r\n   */\r\n  public get destinationStep(): number {\r\n    let destinationStep: number;\r\n\r\n    if (isStepIndex(this.targetStep)) {\r\n      destinationStep = this.targetStep.stepIndex;\r\n    } else if (isStepId(this.targetStep)) {\r\n      destinationStep = this.wizard.getIndexOfStepWithId(this.targetStep.stepId);\r\n    } else if (isStepOffset(this.targetStep) && this.wizardStep !== null) {\r\n      destinationStep = this.wizard.getIndexOfStep(this.wizardStep) + this.targetStep.stepOffset;\r\n    } else if (this.targetStep instanceof WizardStep) {\r\n      destinationStep = this.wizard.getIndexOfStep(this.targetStep);\r\n    } else {\r\n      throw new Error(`Input 'targetStep' is neither a WizardStep, StepOffset, StepIndex or StepId`);\r\n    }\r\n\r\n    return destinationStep;\r\n  }\r\n\r\n  /**\r\n   * Listener method for `click` events on the component with this directive.\r\n   * After this method is called the wizard will try to transition to the `destinationStep`\r\n   */\r\n  @HostListener('click')\r\n  public onClick(): void {\r\n    this.wizard.goToStep(this.destinationStep, this.preFinalize, this.postFinalize);\r\n  }\r\n}\r\n"]}