@spartacus/storefront
Version:
Spartacus Storefront is a package that you can include in your application, which allows you to add default storefront features.
110 lines • 13.9 kB
JavaScript
import { Injectable } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "../../../cms-structure/outlet/outlet.service";
import * as i2 from "./config/table.config";
/**
* The table renderer service adds a component for each table cells (th and td)
* based on a fine grained configuration. Each table type can configure both global
* components for headers and cells as well as individual components for field
* specific cells.
*
* The components are added to the outlet slots for the corresponding cells. The table
* structure and data is added to the outlet context.
*/
export class TableRendererService {
constructor(outletService, componentFactoryResolver, config) {
this.outletService = outletService;
this.componentFactoryResolver = componentFactoryResolver;
this.config = config;
// keep a list of outletRefs to avoid recreation
this.outletRefs = new Map();
}
/**
* Adds the configured table component for the header and data.
*/
add(structure) {
var _a;
(_a = structure === null || structure === void 0 ? void 0 : structure.cells) === null || _a === void 0 ? void 0 : _a.forEach((field) => {
const thRenderer = this.getHeaderRenderer(structure, field);
if (thRenderer) {
const ref = this.getHeaderOutletRef(structure.type, field);
this.render(ref, thRenderer);
}
const tdRenderer = this.getDataRenderer(structure, field);
if (tdRenderer) {
const ref = this.getDataOutletRef(structure.type, field);
this.render(ref, tdRenderer);
}
});
}
render(outletRef, renderer) {
if (this.outletRefs.has(outletRef)) {
return;
}
this.outletRefs.set(outletRef, true);
const template = this.componentFactoryResolver.resolveComponentFactory(renderer);
this.outletService.add(outletRef, template);
}
/**
* Returns the header render component for the given field.
*/
getHeaderRenderer(structure, field) {
var _a, _b, _c, _d, _e;
return (((_c = (_b = (_a = structure.options) === null || _a === void 0 ? void 0 : _a.cells) === null || _b === void 0 ? void 0 : _b[field]) === null || _c === void 0 ? void 0 : _c.headerComponent) ||
((_d = structure.options) === null || _d === void 0 ? void 0 : _d.headerComponent) ||
((_e = this.config.tableOptions) === null || _e === void 0 ? void 0 : _e.headerComponent));
}
/**
* Returns the data render component for the given field.
*/
getDataRenderer(structure, field) {
var _a, _b, _c, _d, _e;
return (((_c = (_b = (_a = structure.options) === null || _a === void 0 ? void 0 : _a.cells) === null || _b === void 0 ? void 0 : _b[field]) === null || _c === void 0 ? void 0 : _c.dataComponent) ||
((_d = structure.options) === null || _d === void 0 ? void 0 : _d.dataComponent) ||
((_e = this.config.tableOptions) === null || _e === void 0 ? void 0 : _e.dataComponent));
}
/**
* Returns the header (th) outlet reference for the given field.
*
* The outlet reference is generated as:
* `table.[tableType].header.[field]`
*/
getHeaderOutletRef(type, field) {
return `table.${type}.header.${field}`;
}
/**
* Returns the header (th) outlet context for the given field.
*/
getHeaderOutletContext(type, options, i18nRoot, field) {
return {
_type: type,
_options: options,
_field: field,
_i18nRoot: i18nRoot,
};
}
/**
* Returns the data (td) outlet reference for the given field.
*
* The field is generated as:
* `table.[tableType].data.[tableField]`
*/
getDataOutletRef(type, field) {
return `table.${type}.data.${field}`;
}
/**
* Returns the data (td) outlet context for the given field.
*/
getDataOutletContext(type, options, i18nRoot, field, data) {
return Object.assign(Object.assign({}, data), { _type: type, _options: options, _field: field, _i18nRoot: i18nRoot });
}
}
TableRendererService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: TableRendererService, deps: [{ token: i1.OutletService }, { token: i0.ComponentFactoryResolver }, { token: i2.TableConfig }], target: i0.ɵɵFactoryTarget.Injectable });
TableRendererService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: TableRendererService, providedIn: 'root' });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: TableRendererService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root',
}]
}], ctorParameters: function () { return [{ type: i1.OutletService }, { type: i0.ComponentFactoryResolver }, { type: i2.TableConfig }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-renderer.service.js","sourceRoot":"","sources":["../../../../../../projects/storefrontlib/shared/components/table/table-renderer.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, Injectable, Type } from '@angular/core';\nimport { OutletService } from '../../../cms-structure/outlet/outlet.service';\nimport { TableConfig } from './config/table.config';\nimport {\n  TableDataOutletContext,\n  TableHeaderOutletContext,\n  TableOptions,\n  TableStructure,\n} from './table.model';\n\n/**\n * The table renderer service adds a component for each table cells (th and td)\n * based on a fine grained configuration. Each table type can configure both global\n * components for headers and cells as well as individual components for field\n * specific cells.\n *\n * The components are added to the outlet slots for the corresponding cells. The table\n * structure and data is added to the outlet context.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class TableRendererService {\n  // keep a list of outletRefs to avoid recreation\n  protected outletRefs = new Map();\n\n  constructor(\n    protected outletService: OutletService,\n    protected componentFactoryResolver: ComponentFactoryResolver,\n    protected config: TableConfig\n  ) {}\n\n  /**\n   * Adds the configured table component for the header and data.\n   */\n  add(structure: TableStructure): void {\n    structure?.cells?.forEach((field) => {\n      const thRenderer = this.getHeaderRenderer(structure, field);\n      if (thRenderer) {\n        const ref = this.getHeaderOutletRef(structure.type, field);\n        this.render(ref, thRenderer);\n      }\n      const tdRenderer = this.getDataRenderer(structure, field);\n      if (tdRenderer) {\n        const ref = this.getDataOutletRef(structure.type, field);\n        this.render(ref, tdRenderer);\n      }\n    });\n  }\n\n  protected render(outletRef: string, renderer: Type<any>) {\n    if (this.outletRefs.has(outletRef)) {\n      return;\n    }\n    this.outletRefs.set(outletRef, true);\n    const template =\n      this.componentFactoryResolver.resolveComponentFactory(renderer);\n    this.outletService.add(outletRef, <any>template);\n  }\n\n  /**\n   * Returns the header render component for the given field.\n   */\n  protected getHeaderRenderer(\n    structure: TableStructure,\n    field: string\n  ): Type<any> {\n    return (\n      structure.options?.cells?.[field]?.headerComponent ||\n      structure.options?.headerComponent ||\n      this.config.tableOptions?.headerComponent\n    );\n  }\n\n  /**\n   * Returns the data render component for the given field.\n   */\n  protected getDataRenderer(\n    structure: TableStructure,\n    field: string\n  ): Type<any> {\n    return (\n      structure.options?.cells?.[field]?.dataComponent ||\n      structure.options?.dataComponent ||\n      this.config.tableOptions?.dataComponent\n    );\n  }\n\n  /**\n   * Returns the header (th) outlet reference for the given field.\n   *\n   * The outlet reference is generated as:\n   * `table.[tableType].header.[field]`\n   */\n  getHeaderOutletRef(type: string, field: string): string {\n    return `table.${type}.header.${field}`;\n  }\n\n  /**\n   * Returns the header (th) outlet context for the given field.\n   */\n  getHeaderOutletContext(\n    type: string,\n    options: TableOptions,\n    i18nRoot: string,\n    field: string\n  ): TableHeaderOutletContext {\n    return {\n      _type: type,\n      _options: options,\n      _field: field,\n      _i18nRoot: i18nRoot,\n    };\n  }\n\n  /**\n   * Returns the data (td) outlet reference for the given field.\n   *\n   * The field is generated as:\n   * `table.[tableType].data.[tableField]`\n   */\n  getDataOutletRef(type: string, field: string): string {\n    return `table.${type}.data.${field}`;\n  }\n\n  /**\n   * Returns the data (td) outlet context for the given field.\n   */\n  getDataOutletContext(\n    type: string,\n    options: TableOptions,\n    i18nRoot: string,\n    field: string,\n    data: any\n  ): TableDataOutletContext {\n    return {\n      ...data,\n      _type: type,\n      _options: options,\n      _field: field,\n      _i18nRoot: i18nRoot,\n    };\n  }\n}\n"]}