UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

131 lines 16 kB
import { IconComponent, TooltipModule } from '@alauda/ui'; import { NgIf, NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, Component, Input } from '@angular/core'; import { FIELD_NOT_AVAILABLE_PLACEHOLDER, formatNumber, PurePipe, } from '../../core/public-api'; import { TranslatePipe, TranslateService } from '../../translate/public-api'; import * as i0 from "@angular/core"; import * as i1 from "../../translate/public-api"; import * as i2 from "@alauda/ui"; const _c0 = a0 => ({ $implicit: a0 }); function ResourceLabelComponent_ng_template_1_aui_icon_0_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelement(0, "aui-icon", 3); i0.ɵɵpipe(1, "translate"); } if (rf & 2) { const info_r1 = i0.ɵɵnextContext().$implicit; const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵclassMap("icon__" + ctx_r1.type); i0.ɵɵproperty("icon", info_r1.icon)("auiTooltip", i0.ɵɵpipeBind1(1, 4, ctx_r1.type)); } } function ResourceLabelComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) { i0.ɵɵtemplate(0, ResourceLabelComponent_ng_template_1_aui_icon_0_Template, 2, 6, "aui-icon", 2); i0.ɵɵtext(1); i0.ɵɵpipe(2, "pure"); } if (rf & 2) { const info_r1 = ctx.$implicit; const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵproperty("ngIf", !ctx_r1.noIcon); i0.ɵɵadvance(); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind3(2, 2, ctx_r1.rawValue, info_r1.formatter, ctx_r1.translate.locale), "\n"); } } export class ResourceLabelComponent { get formattedDefault() { return this.default === FIELD_NOT_AVAILABLE_PLACEHOLDER ? this.default : this.translate.get(this.default); } constructor(translate) { this.translate = translate; this.default = 'unlimited'; this.noIcon = false; this.labelIconMapper = { cpu: { icon: 'prod:cpu', formatter: this.formatCPU.bind(this), }, memory: { icon: 'prod:memory', formatter: this.formatMemory.bind(this), }, }; } formatCPU(rawData) { const cpuUnit = this.getResourceUnit(rawData, this.formatCpuUnit); if (!cpuUnit) { return this.formattedDefault; } return cpuUnit.endsWith('m') ? cpuUnit : cpuUnit + ' ' + this.translate.get('unit_core'); } formatMemory(rawData) { const memoryUnit = this.getResourceUnit(rawData, this.formatMemoryUnit); if (!memoryUnit) { return this.formattedDefault; } return memoryUnit?.match(/[a-z]+/i) ? memoryUnit : memoryUnit + ' Bytes'; } getResourceUnit(rawData, converter) { if (typeof rawData === 'string') { const matched = rawData.match(/([\d.]+)([a-z]+)/i); if (matched) { return matched[1] + ' ' + matched[2]; } return rawData; } return converter(rawData); } formatCpuUnit(cpu) { let cpuUnit = 'm'; if (cpu >= 1000) { cpu /= 1000; cpuUnit = ''; } return isNaN(cpu) ? '' : formatNumber(cpu, [1, 0, 2]) + (cpuUnit ? ' ' + cpuUnit : ''); } formatMemoryUnit(memory) { let memoryUnit = 'Mi'; memory /= 1024 ** 2; if (memory >= 1024) { memory /= 1024; memoryUnit = 'Gi'; } return isNaN(memory) ? '' : formatNumber(memory, [1, 0, 2]) + (memoryUnit ? ' ' + memoryUnit : ''); } static { this.ɵfac = function ResourceLabelComponent_Factory(t) { return new (t || ResourceLabelComponent)(i0.ɵɵdirectiveInject(i1.TranslateService)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceLabelComponent, selectors: [["acl-resource-label"]], inputs: { rawValue: "rawValue", default: "default", type: "type", noIcon: "noIcon" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 3, vars: 4, consts: [["infoTmpl", ""], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], ["size", "16", "auiTooltipType", "info", 3, "icon", "class", "auiTooltip", 4, "ngIf"], ["size", "16", "auiTooltipType", "info", 3, "icon", "auiTooltip"]], template: function ResourceLabelComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementContainer(0, 1); i0.ɵɵtemplate(1, ResourceLabelComponent_ng_template_1_Template, 3, 6, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor); } if (rf & 2) { const infoTmpl_r3 = i0.ɵɵreference(2); i0.ɵɵproperty("ngTemplateOutlet", infoTmpl_r3)("ngTemplateOutletContext", i0.ɵɵpureFunction1(2, _c0, ctx.labelIconMapper[ctx.type])); } }, dependencies: [NgTemplateOutlet, IconComponent, NgIf, TranslatePipe, TooltipModule, i2.TooltipDirective, PurePipe], styles: ["[_nghost-%COMP%]{display:inline-flex;align-items:center}[_nghost-%COMP%] aui-icon[_ngcontent-%COMP%]{margin-right:4px}[_nghost-%COMP%] aui-icon.icon__cpu[_ngcontent-%COMP%]{color:var(--acl-icon-color-cpu)}[_nghost-%COMP%] aui-icon.icon__memory[_ngcontent-%COMP%]{color:var(--acl-icon-color-memory)}"], changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceLabelComponent, [{ type: Component, args: [{ selector: 'acl-resource-label', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ NgTemplateOutlet, IconComponent, NgIf, TranslatePipe, TooltipModule, PurePipe, ], template: "<ng-container\n [ngTemplateOutlet]=\"infoTmpl\"\n [ngTemplateOutletContext]=\"{ $implicit: labelIconMapper[type] }\"\n></ng-container>\n<ng-template\n #infoTmpl\n let-info\n>\n <aui-icon\n size=\"16\"\n *ngIf=\"!noIcon\"\n [icon]=\"info.icon\"\n [class]=\"'icon__' + type\"\n [auiTooltip]=\"type | translate\"\n auiTooltipType=\"info\"\n ></aui-icon>\n {{ rawValue | pure: info.formatter : translate.locale }}\n</ng-template>\n", styles: [":host{display:inline-flex;align-items:center}:host aui-icon{margin-right:4px}:host aui-icon.icon__cpu{color:var(--acl-icon-color-cpu)}:host aui-icon.icon__memory{color:var(--acl-icon-color-memory)}\n"] }] }], () => [{ type: i1.TranslateService }], { rawValue: [{ type: Input }], default: [{ type: Input }], type: [{ type: Input }], noIcon: [{ type: Input }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceLabelComponent, { className: "ResourceLabelComponent" }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/widget/resource-label/component.ts","../../../../../../libs/common/src/widget/resource-label/template.html"],"names":[],"mappings":"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","sourcesContent":["import { IconComponent, TooltipModule } from '@alauda/ui';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Input } from '@angular/core';\n\nimport {\n  FIELD_NOT_AVAILABLE_PLACEHOLDER,\n  formatNumber,\n  PurePipe,\n} from '../../core/public-api';\nimport { TranslatePipe, TranslateService } from '../../translate/public-api';\n\ntype ResourceType = 'cpu' | 'memory';\n\ninterface ResourceInfo {\n  icon: string;\n  formatter: (rawData: number | string, locale?: string) => string;\n}\n\n@Component({\n  selector: 'acl-resource-label',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgTemplateOutlet,\n    IconComponent,\n    NgIf,\n    TranslatePipe,\n    TooltipModule,\n    PurePipe,\n  ],\n})\nexport class ResourceLabelComponent {\n  // 各资源的原始值\n  @Input()\n  rawValue: string | number;\n\n  @Input()\n  default = 'unlimited';\n\n  // 新增类型需要进行扩充\n  @Input()\n  type: ResourceType;\n\n  @Input()\n  noIcon = false;\n\n  get formattedDefault() {\n    return this.default === FIELD_NOT_AVAILABLE_PLACEHOLDER\n      ? this.default\n      : this.translate.get(this.default);\n  }\n\n  labelIconMapper: Record<ResourceType, ResourceInfo> = {\n    cpu: {\n      icon: 'prod:cpu',\n      formatter: this.formatCPU.bind(this),\n    },\n    memory: {\n      icon: 'prod:memory',\n      formatter: this.formatMemory.bind(this),\n    },\n  };\n\n  constructor(public readonly translate: TranslateService) {}\n\n  formatCPU(rawData: number | string) {\n    const cpuUnit = this.getResourceUnit(rawData, this.formatCpuUnit);\n    if (!cpuUnit) {\n      return this.formattedDefault;\n    }\n    return cpuUnit.endsWith('m')\n      ? cpuUnit\n      : cpuUnit + ' ' + this.translate.get('unit_core');\n  }\n\n  formatMemory(rawData: number | string) {\n    const memoryUnit = this.getResourceUnit(rawData, this.formatMemoryUnit);\n\n    if (!memoryUnit) {\n      return this.formattedDefault;\n    }\n    return memoryUnit?.match(/[a-z]+/i) ? memoryUnit : memoryUnit + ' Bytes';\n  }\n\n  private getResourceUnit(\n    rawData: number | string,\n    converter?: (_: number) => string,\n  ) {\n    if (typeof rawData === 'string') {\n      const matched = rawData.match(/([\\d.]+)([a-z]+)/i);\n      if (matched) {\n        return matched[1] + ' ' + matched[2];\n      }\n      return rawData;\n    }\n    return converter(rawData);\n  }\n\n  private formatCpuUnit(cpu: number) {\n    let cpuUnit = 'm';\n    if (cpu >= 1000) {\n      cpu /= 1000;\n      cpuUnit = '';\n    }\n    return isNaN(cpu)\n      ? ''\n      : formatNumber(cpu, [1, 0, 2]) + (cpuUnit ? ' ' + cpuUnit : '');\n  }\n\n  private formatMemoryUnit(memory: number) {\n    let memoryUnit = 'Mi';\n    memory /= 1024 ** 2;\n    if (memory >= 1024) {\n      memory /= 1024;\n      memoryUnit = 'Gi';\n    }\n    return isNaN(memory)\n      ? ''\n      : formatNumber(memory, [1, 0, 2]) + (memoryUnit ? ' ' + memoryUnit : '');\n  }\n}\n","<ng-container\n  [ngTemplateOutlet]=\"infoTmpl\"\n  [ngTemplateOutletContext]=\"{ $implicit: labelIconMapper[type] }\"\n></ng-container>\n<ng-template\n  #infoTmpl\n  let-info\n>\n  <aui-icon\n    size=\"16\"\n    *ngIf=\"!noIcon\"\n    [icon]=\"info.icon\"\n    [class]=\"'icon__' + type\"\n    [auiTooltip]=\"type | translate\"\n    auiTooltipType=\"info\"\n  ></aui-icon>\n  {{ rawValue | pure: info.formatter : translate.locale }}\n</ng-template>\n"]}