UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

76 lines 15.1 kB
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core'; import { uniq } from 'lodash-es'; import { startWith, switchMap, takeUntil } from 'rxjs'; import { K8sUtilService, publishRef, } from '../../../../core/public-api'; import { CommonLayoutContextService } from '../../../../page-scaffold/public-api'; import { ResourceListBase } from '../../base-list'; import { ResourceSelectContextService } from '../../context.service'; import * as i0 from "@angular/core"; import * as i1 from "../../../../page-scaffold/public-api"; import * as i2 from "../../context.service"; import * as i3 from "../../../../core/public-api"; export class ProjectListComponent extends ResourceListBase { constructor(commonLayoutService, contextService, cdr, k8sUtil) { super(cdr, k8sUtil, contextService); this.commonLayoutService = commonLayoutService; this.type = 'project'; this.projects = []; this.projects$ = this.reload$$.pipe(startWith(null), switchMap(() => this.commonLayoutService.getProjects()), takeUntil(this.destroy$$), publishRef()); this.mapResource = (list) => list.map(item => { const cachedItem = this.projects.find(project => project.name === this.k8sUtil.getName(item)); return { name: this.k8sUtil.getName(item), displayName: this.k8sUtil.getDisplayName(item), status: item.status?.phase === 'Active' ? 'normal' : 'abnormal', admin: cachedItem?.admin || '', timestamp: item.metadata.creationTimestamp, __origin: item, }; }); } ngOnInit() { this.projects = this.contextService.cachedProjects; this.setSelected(); this.projects$.subscribe({ next: projects => { this.load.emit({ project: projects.length, cluster: uniq(projects.reduce((acc, cur) => [ ...acc, ...(cur.spec.clusters || []).map(c => c.name), ], [])).length, }); this.projects = this.mapResource(projects); this.contextService.cachedProjects = this.projects; this.setSelected(); this.loading = false; this.forceLoading = false; this.cdr.markForCheck(); }, error: () => { this.loading = false; this.forceLoading = false; this.cdr.markForCheck(); }, }); } setSelected() { this.selectedProject = this.projects.find(p => p.name === this.value); } static { this.ɵfac = function ProjectListComponent_Factory(t) { return new (t || ProjectListComponent)(i0.ɵɵdirectiveInject(i1.CommonLayoutContextService), i0.ɵɵdirectiveInject(i2.ResourceSelectContextService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i3.K8sUtilService)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ProjectListComponent, selectors: [["acl-project-list"]], inputs: { value: "value" }, features: [i0.ɵɵInheritDefinitionFeature], decls: 1, vars: 7, consts: [[3, "selectItem", "reload", "data", "fields", "context", "popupLite", "type", "selectedUid", "loading"]], template: function ProjectListComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "acl-resource-data-grid", 0); i0.ɵɵlistener("selectItem", function ProjectListComponent_Template_acl_resource_data_grid_selectItem_0_listener($event) { return ctx.onSelect($event); })("reload", function ProjectListComponent_Template_acl_resource_data_grid_reload_0_listener() { return ctx.reload(); }); i0.ɵɵelementEnd(); } if (rf & 2) { i0.ɵɵproperty("data", ctx.projects)("fields", ctx.fields)("context", ctx.context)("popupLite", ctx.popupLite)("type", ctx.type)("selectedUid", ctx.selectedProject == null ? null : ctx.selectedProject.__origin.metadata.uid)("loading", ctx.forceLoading || !ctx.projects.length && ctx.loading); } }, styles: ["[_nghost-%COMP%]{display:flex;flex-direction:column}.filter[_ngcontent-%COMP%]{display:flex;border-bottom:1px solid rgb(var(--aui-color-n-8));padding-bottom:8px}.filter[_ngcontent-%COMP%] aui-form-item[_ngcontent-%COMP%] .aui-form-item{margin-bottom:0}.filter__project[_ngcontent-%COMP%]{margin-right:50px;padding-bottom:8px}.filter__project[_ngcontent-%COMP%] aui-select[_ngcontent-%COMP%]{width:240px}.filter__cluster[_ngcontent-%COMP%]{flex:1}.cluster-tags[_ngcontent-%COMP%] aui-check-tag[_ngcontent-%COMP%]{margin-bottom:8px;display:inline-flex}.cluster-tags[_ngcontent-%COMP%] aui-check-tag[_ngcontent-%COMP%] .aui-tag{border:none}.cluster-tags[_ngcontent-%COMP%] aui-check-tag[_ngcontent-%COMP%] .aui-tag--info{background-color:rgb(var(--aui-color-n-8))}"], changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProjectListComponent, [{ type: Component, args: [{ selector: 'acl-project-list', changeDetection: ChangeDetectionStrategy.OnPush, template: "<acl-resource-data-grid\n [data]=\"projects\"\n [fields]=\"fields\"\n [context]=\"context\"\n [popupLite]=\"popupLite\"\n (selectItem)=\"onSelect($event)\"\n [type]=\"type\"\n [selectedUid]=\"selectedProject?.__origin.metadata.uid\"\n [loading]=\"forceLoading || (!projects.length && loading)\"\n (reload)=\"reload()\"\n></acl-resource-data-grid>\n", styles: [":host{display:flex;flex-direction:column}.filter{display:flex;border-bottom:1px solid rgb(var(--aui-color-n-8));padding-bottom:8px}.filter aui-form-item ::ng-deep .aui-form-item{margin-bottom:0}.filter__project{margin-right:50px;padding-bottom:8px}.filter__project aui-select{width:240px}.filter__cluster{flex:1}.cluster-tags aui-check-tag{margin-bottom:8px;display:inline-flex}.cluster-tags aui-check-tag::ng-deep .aui-tag{border:none}.cluster-tags aui-check-tag::ng-deep .aui-tag--info{background-color:rgb(var(--aui-color-n-8))}\n"] }] }], () => [{ type: i1.CommonLayoutContextService }, { type: i2.ResourceSelectContextService }, { type: i0.ChangeDetectorRef }, { type: i3.K8sUtilService }], { value: [{ type: Input }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ProjectListComponent, { className: "ProjectListComponent" }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../libs/common/src/business/resource-select/exports/project-list/component.ts","../../../../../../../../libs/common/src/business/resource-select/exports/project-list/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport { uniq } from 'lodash-es';\nimport { startWith, switchMap, takeUntil } from 'rxjs';\n\nimport {\n  K8sUtilService,\n  Project,\n  publishRef,\n} from '../../../../core/public-api';\nimport { CommonLayoutContextService } from '../../../../page-scaffold/public-api';\nimport { ResourceListBase } from '../../base-list';\nimport { ResourceSelectContextService } from '../../context.service';\n\nimport { ProjectDataItem } from './../../types';\n\n@Component({\n  selector: 'acl-project-list',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ProjectListComponent\n  extends ResourceListBase\n  implements OnInit, OnDestroy\n{\n  @Input()\n  value: string;\n\n  selectedProject: ProjectDataItem;\n\n  type = 'project' as const;\n\n  selectedUid: string;\n\n  projects: ProjectDataItem[] = [];\n\n  projects$ = this.reload$$.pipe(\n    startWith(null as void),\n    switchMap(() => this.commonLayoutService.getProjects()),\n    takeUntil(this.destroy$$),\n    publishRef(),\n  );\n\n  constructor(\n    private readonly commonLayoutService: CommonLayoutContextService,\n    contextService: ResourceSelectContextService,\n    cdr: ChangeDetectorRef,\n    k8sUtil: K8sUtilService,\n  ) {\n    super(cdr, k8sUtil, contextService);\n  }\n\n  ngOnInit() {\n    this.projects = this.contextService.cachedProjects;\n    this.setSelected();\n    this.projects$.subscribe({\n      next: projects => {\n        this.load.emit({\n          project: projects.length,\n          cluster: uniq(\n            projects.reduce(\n              (acc, cur) => [\n                ...acc,\n                ...(cur.spec.clusters || []).map(c => c.name),\n              ],\n              [],\n            ),\n          ).length,\n        });\n        this.projects = this.mapResource(projects);\n        this.contextService.cachedProjects = this.projects;\n        this.setSelected();\n        this.loading = false;\n        this.forceLoading = false;\n        this.cdr.markForCheck();\n      },\n      error: () => {\n        this.loading = false;\n        this.forceLoading = false;\n        this.cdr.markForCheck();\n      },\n    });\n  }\n\n  setSelected() {\n    this.selectedProject = this.projects.find(p => p.name === this.value);\n  }\n\n  mapResource = (list: Project[]): ProjectDataItem[] =>\n    list.map(item => {\n      const cachedItem = this.projects.find(\n        project => project.name === this.k8sUtil.getName(item),\n      );\n      return {\n        name: this.k8sUtil.getName(item),\n        displayName: this.k8sUtil.getDisplayName(item),\n        status: item.status?.phase === 'Active' ? 'normal' : 'abnormal',\n        admin: cachedItem?.admin || '',\n        timestamp: item.metadata.creationTimestamp,\n        __origin: item,\n      };\n    });\n}\n","<acl-resource-data-grid\n  [data]=\"projects\"\n  [fields]=\"fields\"\n  [context]=\"context\"\n  [popupLite]=\"popupLite\"\n  (selectItem)=\"onSelect($event)\"\n  [type]=\"type\"\n  [selectedUid]=\"selectedProject?.__origin.metadata.uid\"\n  [loading]=\"forceLoading || (!projects.length && loading)\"\n  (reload)=\"reload()\"\n></acl-resource-data-grid>\n"]}