UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

130 lines 18.9 kB
import { Component, Input } from '@angular/core'; import { find, keys, get, isEmpty } from 'lodash-es'; import { OptionsService } from '../common/options.service'; import { IconDirective } from '../common'; import { NgClass, NgIf, NgStyle } from '@angular/common'; import * as i0 from "@angular/core"; import * as i1 from "../common/options.service"; export class AppIconComponent { constructor(options) { this.options = options; /** Application name. */ this.name = ''; this.model = this.emptyModel(); this.c8yAppIconsList = { analyticsbuilder: 'analytics-builder', 'analytics-builder': 'analytics-builder', cockpit: 'cockpit', devicemanagement: 'device-management', administration: 'administration', apamaepl: 'apama-epl' }; this.white = false; this.defaultIconStyle = { 'background-repeat': 'no-repeat', 'background-size': 'contain', 'background-position': 'center', 'aspect-ratio': '1' }; this.faIconMatch = /fa-/; this.c8yMatch = /^c8y-/; this.dltC8yMatch = /^dlt-c8y-/; } ngOnInit() { this.loadSetup(); } ngOnChanges() { this.loadSetup(); } emptyModel() { return { appIcon: '', configIcon: '', showIcon: true, iconClass: ['c8y-icon'], appNameAbbr: '', iconStyle: {} }; } isC8y(icon) { return this.c8yMatch.test(icon); } isFaIcon(icon) { return this.faIconMatch.test(icon); } isDltC8y(icon) { return this.dltC8yMatch.test(icon); } loadSetup() { this.model = this.emptyModel(); this.model.configIcon = this.getPropertyFromAppOrOptions(['config', 'icon']); if (!this.model.configIcon) { this.model.appIcon = this.iconFromAppDefinition(); const iconUrl = this.iconUrlFromAppDefinition(); if (iconUrl) { this.model.iconStyle = Object.assign({ 'background-image': iconUrl }, this.defaultIconStyle); } else if (!this.model.appIcon) { // only set static icon if no icon is set in the app definition this.model.appIcon = this.findStaticIcon(); } } this.model.showIcon = !!this.model.appIcon || !isEmpty(this.model.iconStyle) || !!this.model.configIcon; this.model.iconClass = [ 'c8y-icon', this.mapFontAwesomeToDelightIcons(this.model.appIcon), this.white ? 'c8y-icon-white' : 'c8y-icon-duocolor', !isEmpty(this.model.iconStyle) ? 'app-img-icon' : '' ].filter(c => !!c); const name = this.name || this.app?.name || ''; this.model.appNameAbbr = name.substring(0, 2); } iconFromAppDefinition() { return (this.getPropertyFromAppOrOptions(['icon', 'class']) || this.getPropertyFromAppOrOptions(['manifest', 'icon', 'class'])); } iconUrlFromAppDefinition() { return this.getPropertyFromAppOrOptions(['icon', 'url']); } getPropertyFromAppOrOptions(path) { const app = this.app || this.options; return get(app, ['manifest', ...path]) || get(app, path); } findStaticIcon() { const contextPath = this.contextPath || this.name || this.app?.contextPath || this.app?.name; if (!contextPath) { return undefined; } const appContextPathNormalized = find(keys(this.c8yAppIconsList), cp => { return contextPath.indexOf(cp) > -1; }); const appIcon = this.c8yAppIconsList[appContextPathNormalized]; return appIcon ? `c8y-icon-${appIcon}` : undefined; } mapFontAwesomeToDelightIcons(iconClasses) { if (!iconClasses) { return; } if (this.isFaIcon(iconClasses)) { const regex = /fa-/gi; return iconClasses.replace(regex, 'dlt-c8y-icon-'); } return this.isC8y(iconClasses) || this.isDltC8y(iconClasses) ? iconClasses : `dlt-c8y-icon-${iconClasses}`; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AppIconComponent, deps: [{ token: i1.OptionsService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AppIconComponent, isStandalone: true, selector: "c8y-app-icon", inputs: { contextPath: "contextPath", name: "name", app: "app" }, host: { classAttribute: "c8y-app-icon" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"model.showIcon; else noIcon\">\n <i\n [ngStyle]=\"model.iconStyle\"\n *ngIf=\"!model.configIcon\"\n [ngClass]=\"model.iconClass\"\n ></i>\n <i\n [c8yIcon]=\"model.configIcon\"\n *ngIf=\"model.configIcon\"\n ></i>\n</ng-container>\n\n<ng-template #noIcon>\n <span class=\"app-noicon\">{{ model.appNameAbbr }}</span>\n</ng-template>\n", dependencies: [{ kind: "directive", type: IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AppIconComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-app-icon', host: { class: 'c8y-app-icon' }, standalone: true, imports: [IconDirective, NgStyle, NgIf, NgClass], template: "<ng-container *ngIf=\"model.showIcon; else noIcon\">\n <i\n [ngStyle]=\"model.iconStyle\"\n *ngIf=\"!model.configIcon\"\n [ngClass]=\"model.iconClass\"\n ></i>\n <i\n [c8yIcon]=\"model.configIcon\"\n *ngIf=\"model.configIcon\"\n ></i>\n</ng-container>\n\n<ng-template #noIcon>\n <span class=\"app-noicon\">{{ model.appNameAbbr }}</span>\n</ng-template>\n" }] }], ctorParameters: () => [{ type: i1.OptionsService }], propDecorators: { contextPath: [{ type: Input }], name: [{ type: Input }], app: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-icon.component.js","sourceRoot":"","sources":["../../../../core/application/app-icon.component.ts","../../../../core/application/app-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnChanges } from '@angular/core';\nimport { find, keys, get, isEmpty } from 'lodash-es';\nimport { OptionsService } from '../common/options.service';\nimport { IApplication } from '@c8y/client';\nimport { IconDirective } from '../common';\nimport { NgClass, NgIf, NgStyle } from '@angular/common';\n\n@Component({\n  selector: 'c8y-app-icon',\n  templateUrl: './app-icon.component.html',\n  host: { class: 'c8y-app-icon' },\n  standalone: true,\n  imports: [IconDirective, NgStyle, NgIf, NgClass]\n})\nexport class AppIconComponent implements OnInit, OnChanges {\n  /** Application context path. */\n  @Input() contextPath: string;\n  /** Application name. */\n  @Input() name = '';\n  /** Application managed object. */\n  @Input() app: IApplication;\n\n  model = this.emptyModel();\n\n  private c8yAppIconsList = {\n    analyticsbuilder: 'analytics-builder',\n    'analytics-builder': 'analytics-builder',\n    cockpit: 'cockpit',\n    devicemanagement: 'device-management',\n    administration: 'administration',\n    apamaepl: 'apama-epl'\n  } as const;\n\n  private white = false;\n\n  private defaultIconStyle = {\n    'background-repeat': 'no-repeat',\n    'background-size': 'contain',\n    'background-position': 'center',\n    'aspect-ratio': '1'\n  };\n\n  private faIconMatch = /fa-/;\n  private c8yMatch = /^c8y-/;\n  private dltC8yMatch = /^dlt-c8y-/;\n\n  constructor(private options: OptionsService) {}\n\n  ngOnInit() {\n    this.loadSetup();\n  }\n\n  ngOnChanges(): void {\n    this.loadSetup();\n  }\n\n  private emptyModel() {\n    return {\n      appIcon: '',\n      configIcon: '',\n      showIcon: true,\n      iconClass: ['c8y-icon'],\n      appNameAbbr: '',\n      iconStyle: {}\n    };\n  }\n\n  private isC8y(icon) {\n    return this.c8yMatch.test(icon);\n  }\n\n  private isFaIcon(icon) {\n    return this.faIconMatch.test(icon);\n  }\n\n  private isDltC8y(icon) {\n    return this.dltC8yMatch.test(icon);\n  }\n\n  private loadSetup() {\n    this.model = this.emptyModel();\n    this.model.configIcon = this.getPropertyFromAppOrOptions(['config', 'icon']);\n    if (!this.model.configIcon) {\n      this.model.appIcon = this.iconFromAppDefinition();\n      const iconUrl = this.iconUrlFromAppDefinition();\n      if (iconUrl) {\n        this.model.iconStyle = Object.assign(\n          { 'background-image': iconUrl },\n          this.defaultIconStyle\n        );\n      } else if (!this.model.appIcon) {\n        // only set static icon if no icon is set in the app definition\n        this.model.appIcon = this.findStaticIcon();\n      }\n    }\n    this.model.showIcon =\n      !!this.model.appIcon || !isEmpty(this.model.iconStyle) || !!this.model.configIcon;\n    this.model.iconClass = [\n      'c8y-icon',\n      this.mapFontAwesomeToDelightIcons(this.model.appIcon),\n      this.white ? 'c8y-icon-white' : 'c8y-icon-duocolor',\n      !isEmpty(this.model.iconStyle) ? 'app-img-icon' : ''\n    ].filter(c => !!c);\n    const name = this.name || this.app?.name || '';\n    this.model.appNameAbbr = name.substring(0, 2);\n  }\n\n  private iconFromAppDefinition() {\n    return (\n      this.getPropertyFromAppOrOptions(['icon', 'class']) ||\n      this.getPropertyFromAppOrOptions(['manifest', 'icon', 'class'])\n    );\n  }\n\n  private iconUrlFromAppDefinition() {\n    return this.getPropertyFromAppOrOptions(['icon', 'url']);\n  }\n\n  private getPropertyFromAppOrOptions(path: string[]) {\n    const app = this.app || this.options;\n    return get(app, ['manifest', ...path]) || get(app, path);\n  }\n\n  private findStaticIcon() {\n    const contextPath = this.contextPath || this.name || this.app?.contextPath || this.app?.name;\n    if (!contextPath) {\n      return undefined;\n    }\n    const appContextPathNormalized = find(keys(this.c8yAppIconsList), cp => {\n      return contextPath.indexOf(cp) > -1;\n    });\n    const appIcon: string = this.c8yAppIconsList[appContextPathNormalized];\n    return appIcon ? (`c8y-icon-${appIcon}` as const) : undefined;\n  }\n\n  private mapFontAwesomeToDelightIcons(iconClasses: string) {\n    if (!iconClasses) {\n      return;\n    }\n    if (this.isFaIcon(iconClasses)) {\n      const regex = /fa-/gi;\n      return iconClasses.replace(regex, 'dlt-c8y-icon-');\n    }\n    return this.isC8y(iconClasses) || this.isDltC8y(iconClasses)\n      ? iconClasses\n      : `dlt-c8y-icon-${iconClasses}`;\n  }\n}\n","<ng-container *ngIf=\"model.showIcon; else noIcon\">\n  <i\n    [ngStyle]=\"model.iconStyle\"\n    *ngIf=\"!model.configIcon\"\n    [ngClass]=\"model.iconClass\"\n  ></i>\n  <i\n    [c8yIcon]=\"model.configIcon\"\n    *ngIf=\"model.configIcon\"\n  ></i>\n</ng-container>\n\n<ng-template #noIcon>\n  <span class=\"app-noicon\">{{ model.appNameAbbr }}</span>\n</ng-template>\n"]}