@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
JavaScript
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":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAEL,MAAM,GAIP,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,WAAW,GAIZ,MAAM,WAAW,CAAC;AAEnB,IAAsB,oBAAoB,GAA1C,MAAsB,oBAAoB;IAqCxC,YAC8B,QAAa,EAC/B,eAAiC;QADf,aAAQ,GAAR,QAAQ,CAAK;QAC/B,oBAAe,GAAf,eAAe,CAAkB;QAtC7C,6DAA6D;QACnD,oBAAe,GAIpB,EAAE,CAAC;QAER;;WAEG;QACO,kBAAa,GAAG,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QAC/D;;WAEG;QACO,mBAAc,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACjD;;WAEG;QACO,yBAAoB,GAAG,CAAC,0BAA0B,CAAC,CAAC;QAC9D;;WAEG;QACO,iCAA4B,GAAG;YACvC,mCAAmC;SACpC,CAAC;QACF;;WAEG;QACO,sBAAiB,GAAG,CAAC,gBAAgB,CAAC,CAAC;QACjD;;WAEG;QACO,wBAAmB,GAAG,CAAC,kBAAkB,CAAC,CAAC;QAQnD,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC7D,CAAC;IAoBD;;;;;OAKG;IACO,YAAY,CACpB,MAA8B,EAC9B,MAAoB;QAEpB,OAAO,CACL,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC;YACzB,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,KAAK,MAAM,CAAC;gBACtD,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK;gBAChB,CAAC,CAAC,IAAI,CAAC,CACV,CAAC;IACJ,CAAC;IAES,YAAY,CACpB,SAA4B,EAC5B,UAAuB;QAEvB,IAAI,OAAO,GAAG,EAAE,CAAC;QAEjB,kCAAkC;QAClC,QAAQ,UAAU,EAAE;YAClB,KAAK,WAAW,CAAC,MAAM;gBACrB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC;gBAC7B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;gBACzD,MAAM;YACR,KAAK,WAAW,CAAC,OAAO;gBACtB,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC;gBAC9B,MAAM;YACR,KAAK,WAAW,CAAC,cAAc;gBAC7B,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC;gBACpC,MAAM;YACR,KAAK,WAAW,CAAC,uBAAuB;gBACtC,OAAO,GAAG,IAAI,CAAC,4BAA4B,CAAC;gBAC5C,MAAM;YACR,KAAK,WAAW,CAAC,WAAW;gBAC1B,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC;gBACjC,MAAM;YACR,KAAK,WAAW,CAAC,aAAa;gBAC5B,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC;gBACnC,MAAM;SACT;QAED,KAAK,MAAM,QAAQ,IAAI,OAAO,EAAE;YAC9B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;SACpE;IACH,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,MAA8B,EAAE,MAAqB;;QACjE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAChD,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,KAAK,MAAM,CAC7B,CAAC;QAEF,IAAI,CAAA,MAAC,MAAuB,0CAAE,UAAU,MAAK,WAAW,CAAC,MAAM,EAAE;YAC/D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;SAC7D;IACH,CAAC;IAED,WAAW;QACT,qBAAoB,CAAC,iCAAiC;IACxD,CAAC;CACF,CAAA;AAtIqB,oBAAoB;IAsCrC,WAAA,MAAM,CAAC,QAAQ,CAAC,CAAA;GAtCC,oBAAoB,CAsIzC;SAtIqB,oBAAoB","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"]}