UNPKG

@spartacus/storefront

Version:

Spartacus Storefront is a package that you can include in your application, which allows you to add default storefront features.

101 lines 12.8 kB
import { __decorate, __param } from "tslib"; import { DOCUMENT } from '@angular/common'; import { Inject, } from '@angular/core'; import { DIALOG_TYPE, } from '../config'; let LaunchRenderStrategy = class LaunchRenderStrategy { constructor(document, rendererFactory) { this.document = document; this.rendererFactory = rendererFactory; // List of called references; only used for rendered elements this.renderedCallers = []; /** * Classes to apply to the component when the dialog is a DIALOG */ this.dialogClasses = ['d-block', 'fade', 'modal', 'show']; /** * Classes to apply to the component when the dialog is a POPOVER */ this.popoverClasses = ['cx-dialog-popover']; /** * Classes to apply to the component when the dialog is a POPOVER_CENTER */ this.popoverCenterClasses = ['cx-dialog-popover-center']; /** * Classes to apply to the component when the dialog is a POPOVER_CENTER with a backdrop */ this.popoverCenterBackdropClasses = [ 'cx-dialog-popover-center-backdrop', ]; /** * Classes to apply to the component when the dialog is a SIDEBAR_END */ this.sidebarEndClasses = ['cx-sidebar-end']; /** * Classes to apply to the component when the dialog is a SIDEBAR_START */ this.sidebarStartClasses = ['cx-sidebar-start']; this.renderer = rendererFactory.createRenderer(null, null); } /** * Determines if element should render * * @param caller * @param config */ shouldRender(caller, config) { return (Boolean(config.component) && (this.renderedCallers.some((el) => el.caller === caller) ? !!config.multi : true)); } applyClasses(component, dialogType) { let classes = []; // TODO: make classes configurable switch (dialogType) { case DIALOG_TYPE.DIALOG: classes = this.dialogClasses; this.renderer.addClass(this.document.body, 'modal-open'); break; case DIALOG_TYPE.POPOVER: classes = this.popoverClasses; break; case DIALOG_TYPE.POPOVER_CENTER: classes = this.popoverCenterClasses; break; case DIALOG_TYPE.POPOVER_CENTER_BACKDROP: classes = this.popoverCenterBackdropClasses; break; case DIALOG_TYPE.SIDEBAR_END: classes = this.sidebarEndClasses; break; case DIALOG_TYPE.SIDEBAR_START: classes = this.sidebarStartClasses; break; } for (const newClass of classes) { this.renderer.addClass(component.location.nativeElement, newClass); } } /** * Method to call when rendered element is destroyed * The element will be removed from the list of rendered elements * * @param caller * @param _config optional parameters used in children strategies */ remove(caller, config) { var _a; this.renderedCallers = this.renderedCallers.filter((el) => el.caller !== caller); if (((_a = config) === null || _a === void 0 ? void 0 : _a.dialogType) === DIALOG_TYPE.DIALOG) { this.renderer.removeClass(this.document.body, 'modal-open'); } } getPriority() { return -10 /* LOW */; // low, as it's a default matcher } }; LaunchRenderStrategy = __decorate([ __param(0, Inject(DOCUMENT)) ], LaunchRenderStrategy); export { LaunchRenderStrategy }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"launch-render.strategy.js","sourceRoot":"","sources":["../../../../../../projects/storefrontlib/layout/launch-dialog/services/launch-render.strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  ComponentRef,\n  Inject,\n  Renderer2,\n  RendererFactory2,\n  ViewContainerRef,\n} from '@angular/core';\nimport { Applicable, Priority } from '@spartacus/core';\nimport { Observable } from 'rxjs';\nimport {\n  DIALOG_TYPE,\n  LaunchDialog,\n  LaunchOptions,\n  LAUNCH_CALLER,\n} from '../config';\n\nexport abstract class LaunchRenderStrategy implements Applicable {\n  // List of called references; only used for rendered elements\n  protected renderedCallers: Array<{\n    caller: LAUNCH_CALLER | string;\n    element?: any;\n    component?: ComponentRef<any>;\n  }> = [];\n\n  /**\n   * Classes to apply to the component when the dialog is a DIALOG\n   */\n  protected dialogClasses = ['d-block', 'fade', 'modal', 'show'];\n  /**\n   * Classes to apply to the component when the dialog is a POPOVER\n   */\n  protected popoverClasses = ['cx-dialog-popover'];\n  /**\n   * Classes to apply to the component when the dialog is a POPOVER_CENTER\n   */\n  protected popoverCenterClasses = ['cx-dialog-popover-center'];\n  /**\n   * Classes to apply to the component when the dialog is a POPOVER_CENTER with a backdrop\n   */\n  protected popoverCenterBackdropClasses = [\n    'cx-dialog-popover-center-backdrop',\n  ];\n  /**\n   * Classes to apply to the component when the dialog is a SIDEBAR_END\n   */\n  protected sidebarEndClasses = ['cx-sidebar-end'];\n  /**\n   * Classes to apply to the component when the dialog is a SIDEBAR_START\n   */\n  protected sidebarStartClasses = ['cx-sidebar-start'];\n\n  protected renderer: Renderer2;\n\n  constructor(\n    @Inject(DOCUMENT) protected document: any,\n    protected rendererFactory: RendererFactory2\n  ) {\n    this.renderer = rendererFactory.createRenderer(null, null);\n  }\n\n  /**\n   * Render method to implement based on the strategy\n   *\n   * @param config Launch configuration\n   */\n  abstract render(\n    config: LaunchOptions,\n    caller: LAUNCH_CALLER | string,\n    vcr?: ViewContainerRef\n  ): Observable<ComponentRef<any> | undefined> | void;\n\n  /**\n   * Determines if the strategy is the right one for the provided configuration\n   *\n   * @param config\n   */\n  abstract hasMatch(config: LaunchOptions): boolean;\n\n  /**\n   * Determines if element should render\n   *\n   * @param caller\n   * @param config\n   */\n  protected shouldRender(\n    caller: LAUNCH_CALLER | string,\n    config: LaunchDialog\n  ): boolean {\n    return (\n      Boolean(config.component) &&\n      (this.renderedCallers.some((el) => el.caller === caller)\n        ? !!config.multi\n        : true)\n    );\n  }\n\n  protected applyClasses(\n    component: ComponentRef<any>,\n    dialogType: DIALOG_TYPE\n  ): void {\n    let classes = [];\n\n    // TODO: make classes configurable\n    switch (dialogType) {\n      case DIALOG_TYPE.DIALOG:\n        classes = this.dialogClasses;\n        this.renderer.addClass(this.document.body, 'modal-open');\n        break;\n      case DIALOG_TYPE.POPOVER:\n        classes = this.popoverClasses;\n        break;\n      case DIALOG_TYPE.POPOVER_CENTER:\n        classes = this.popoverCenterClasses;\n        break;\n      case DIALOG_TYPE.POPOVER_CENTER_BACKDROP:\n        classes = this.popoverCenterBackdropClasses;\n        break;\n      case DIALOG_TYPE.SIDEBAR_END:\n        classes = this.sidebarEndClasses;\n        break;\n      case DIALOG_TYPE.SIDEBAR_START:\n        classes = this.sidebarStartClasses;\n        break;\n    }\n\n    for (const newClass of classes) {\n      this.renderer.addClass(component.location.nativeElement, newClass);\n    }\n  }\n\n  /**\n   * Method to call when rendered element is destroyed\n   * The element will be removed from the list of rendered elements\n   *\n   * @param caller\n   * @param _config optional parameters used in children strategies\n   */\n  public remove(caller: LAUNCH_CALLER | string, config: LaunchOptions): void {\n    this.renderedCallers = this.renderedCallers.filter(\n      (el) => el.caller !== caller\n    );\n\n    if ((config as LaunchDialog)?.dialogType === DIALOG_TYPE.DIALOG) {\n      this.renderer.removeClass(this.document.body, 'modal-open');\n    }\n  }\n\n  getPriority(): Priority {\n    return Priority.LOW; // low, as it's a default matcher\n  }\n}\n"]}