UNPKG

@delon/abc

Version:

Common business components of ng-alain.

289 lines 29.2 kB
import { NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, Renderer2, ViewEncapsulation, booleanAttribute, inject } from '@angular/core'; import { FormsModule } from '@angular/forms'; import { Router } from '@angular/router'; import { updateHostClass } from '@delon/util/browser'; import { WINDOW } from '@delon/util/token'; import { NzBadgeComponent } from 'ng-zorro-antd/badge'; import { NzCheckboxComponent } from 'ng-zorro-antd/checkbox'; import { NzIconDirective } from 'ng-zorro-antd/icon'; import { NzImageModule, NzImageService } from 'ng-zorro-antd/image'; import { NzRadioComponent } from 'ng-zorro-antd/radio'; import { NzTagComponent } from 'ng-zorro-antd/tag'; import { NzTooltipDirective } from 'ng-zorro-antd/tooltip'; import { CellHostDirective } from './cell-host.directive'; import { CellService } from './cell.service'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; export class CellComponent { constructor() { this.srv = inject(CellService); this.router = inject(Router); this.cdr = inject(ChangeDetectorRef); this.renderer = inject(Renderer2); this.imgSrv = inject(NzImageService); this.win = inject(WINDOW); this.el = inject(ElementRef).nativeElement; this.showDefault = false; this.valueChange = new EventEmitter(); this.loading = false; this.disabled = false; } get safeOpt() { return this.res?.options ?? {}; } get isText() { return this.res?.safeHtml === 'text'; } updateValue() { this.destroy$?.unsubscribe(); this.destroy$ = this.srv.get(this.value, this.options).subscribe(res => { this.res = res; this.showDefault = this.value == this.safeOpt.default.condition; this._text = res.result?.text ?? ''; this._unit = res.result?.unit ?? this.safeOpt?.unit; this.cdr.detectChanges(); this.setClass(); }); } setClass() { const { el, renderer } = this; const { renderType, size, type } = this.safeOpt; updateHostClass(el, renderer, { [`cell`]: true, [`cell__${renderType}`]: renderType != null, [`cell__${size}`]: size != null, [`cell__has-unit`]: this._unit, [`cell__has-default`]: this.showDefault, [`cell__disabled`]: this.disabled }); el.setAttribute('data-type', `${type}`); } ngOnChanges(changes) { // Do not call updateValue when only updating loading, disabled if (Object.keys(changes).every(k => ['loading', 'disabled'].includes(k))) { this.setClass(); } else { this.updateValue(); } } change(value) { this.value = value; this.valueChange.emit(value); } _link(e) { e.preventDefault(); e.stopPropagation(); if (this.disabled) return; const link = this.safeOpt.link; const url = link?.url; if (url == null) return; if (/https?:\/\//g.test(url)) { this.win.open(url, link?.target); } else { this.router.navigateByUrl(url); } } _showImg(img) { const config = this.safeOpt.img; if (config == null || config.big == null) return; let idx = -1; const list = this._text.map((p, index) => { if (idx === -1 && p === img) idx = index; return typeof config.big === 'function' ? config.big(p) : p; }); this.imgSrv .preview(list.map(p => ({ src: p })), config.previewOptions) .switchTo(idx); } ngOnDestroy() { this.destroy$?.unsubscribe(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: CellComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: CellComponent, isStandalone: true, selector: "cell, [cell]", inputs: { value: "value", options: "options", loading: ["loading", "loading", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute] }, outputs: { valueChange: "valueChange" }, exportAs: ["cell"], usesOnChanges: true, ngImport: i0, template: ` <ng-template #text> @switch (safeOpt.type) { @case ('checkbox') { <label nz-checkbox [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)"> {{ safeOpt.checkbox?.label }} </label> } @case ('radio') { <label nz-radio [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)"> {{ safeOpt.radio?.label }} </label> } @case ('link') { <a (click)="_link($event)" [attr.target]="safeOpt.link?.target" [attr.title]="value" [innerHTML]="_text"></a> } @case ('tag') { <nz-tag [nzColor]="res?.result?.color"> <span [innerHTML]="_text"></span> </nz-tag> } @case ('badge') { <nz-badge [nzStatus]="res?.result?.color" nzText="{{ _text }}" /> } @case ('widget') { @if (res) { <ng-template cell-widget-host [data]="res" /> } } @case ('img') { @for (i of $any(_text); track $index) { <img [attr.src]="i" [attr.height]="safeOpt.img?.size" [attr.width]="safeOpt.img?.size" (click)="_showImg(i)" class="img" [class.point]="safeOpt.img?.big" /> } } @default { @if (isText) { <span [innerText]="_text" [attr.title]="value"></span> } @else { <span [innerHTML]="_text" [attr.title]="value"></span> } @if (_unit) { <span class="unit">{{ _unit }}</span> } } } </ng-template> <ng-template #textWrap> @if (showDefault) { {{ safeOpt.default?.text }} } @else { @if (safeOpt.tooltip) { <span [nz-tooltip]="safeOpt.tooltip"> <ng-template [ngTemplateOutlet]="text" /> </span> } @else { <ng-template [ngTemplateOutlet]="text" /> } } </ng-template> @if (loading) { <span nz-icon nzType="loading"></span> } @else { <ng-template [ngTemplateOutlet]="textWrap" /> } `, isInline: true, dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: NzCheckboxComponent, selector: "[nz-checkbox]", inputs: ["nzValue", "nzAutoFocus", "nzDisabled", "nzIndeterminate", "nzChecked", "nzId"], outputs: ["nzCheckedChange"], exportAs: ["nzCheckbox"] }, { kind: "component", type: NzRadioComponent, selector: "[nz-radio],[nz-radio-button]", inputs: ["nzValue", "nzDisabled", "nzAutoFocus", "nz-radio-button"], exportAs: ["nzRadio"] }, { kind: "directive", type: NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "component", type: NzTagComponent, selector: "nz-tag", inputs: ["nzMode", "nzColor", "nzChecked", "nzBordered"], outputs: ["nzOnClose", "nzCheckedChange"], exportAs: ["nzTag"] }, { kind: "component", type: NzBadgeComponent, selector: "nz-badge", inputs: ["nzShowZero", "nzShowDot", "nzStandalone", "nzDot", "nzOverflowCount", "nzColor", "nzStyle", "nzText", "nzTitle", "nzStatus", "nzCount", "nzOffset", "nzSize"], exportAs: ["nzBadge"] }, { kind: "directive", type: NzTooltipDirective, selector: "[nz-tooltip]", inputs: ["nzTooltipTitle", "nzTooltipTitleContext", "nz-tooltip", "nzTooltipTrigger", "nzTooltipPlacement", "nzTooltipOrigin", "nzTooltipVisible", "nzTooltipMouseEnterDelay", "nzTooltipMouseLeaveDelay", "nzTooltipOverlayClassName", "nzTooltipOverlayStyle", "nzTooltipArrowPointAtCenter", "cdkConnectedOverlayPush", "nzTooltipColor"], outputs: ["nzTooltipVisibleChange"], exportAs: ["nzTooltip"] }, { kind: "ngmodule", type: NzImageModule }, { kind: "directive", type: CellHostDirective, selector: "[cell-widget-host]", inputs: ["data"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: CellComponent, decorators: [{ type: Component, args: [{ selector: 'cell, [cell]', template: ` <ng-template #text> @switch (safeOpt.type) { @case ('checkbox') { <label nz-checkbox [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)"> {{ safeOpt.checkbox?.label }} </label> } @case ('radio') { <label nz-radio [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)"> {{ safeOpt.radio?.label }} </label> } @case ('link') { <a (click)="_link($event)" [attr.target]="safeOpt.link?.target" [attr.title]="value" [innerHTML]="_text"></a> } @case ('tag') { <nz-tag [nzColor]="res?.result?.color"> <span [innerHTML]="_text"></span> </nz-tag> } @case ('badge') { <nz-badge [nzStatus]="res?.result?.color" nzText="{{ _text }}" /> } @case ('widget') { @if (res) { <ng-template cell-widget-host [data]="res" /> } } @case ('img') { @for (i of $any(_text); track $index) { <img [attr.src]="i" [attr.height]="safeOpt.img?.size" [attr.width]="safeOpt.img?.size" (click)="_showImg(i)" class="img" [class.point]="safeOpt.img?.big" /> } } @default { @if (isText) { <span [innerText]="_text" [attr.title]="value"></span> } @else { <span [innerHTML]="_text" [attr.title]="value"></span> } @if (_unit) { <span class="unit">{{ _unit }}</span> } } } </ng-template> <ng-template #textWrap> @if (showDefault) { {{ safeOpt.default?.text }} } @else { @if (safeOpt.tooltip) { <span [nz-tooltip]="safeOpt.tooltip"> <ng-template [ngTemplateOutlet]="text" /> </span> } @else { <ng-template [ngTemplateOutlet]="text" /> } } </ng-template> @if (loading) { <span nz-icon nzType="loading"></span> } @else { <ng-template [ngTemplateOutlet]="textWrap" /> } `, exportAs: 'cell', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [ FormsModule, NgTemplateOutlet, NzCheckboxComponent, NzRadioComponent, NzIconDirective, NzTagComponent, NzBadgeComponent, NzTooltipDirective, NzImageModule, CellHostDirective ] }] }], propDecorators: { value: [{ type: Input }], valueChange: [{ type: Output }], options: [{ type: Input }], loading: [{ type: Input, args: [{ transform: booleanAttribute }] }], disabled: [{ type: Input, args: [{ transform: booleanAttribute }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.component.js","sourceRoot":"","sources":["../../../../../packages/abc/cell/cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChange,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport type { SafeValue } from '@angular/platform-browser';\nimport { Router } from '@angular/router';\nimport { Subscription } from 'rxjs';\n\nimport { updateHostClass } from '@delon/util/browser';\nimport { WINDOW } from '@delon/util/token';\nimport { NzBadgeComponent } from 'ng-zorro-antd/badge';\nimport { NzCheckboxComponent } from 'ng-zorro-antd/checkbox';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzIconDirective } from 'ng-zorro-antd/icon';\nimport { NzImage, NzImageModule, NzImageService } from 'ng-zorro-antd/image';\nimport { NzRadioComponent } from 'ng-zorro-antd/radio';\nimport { NzTagComponent } from 'ng-zorro-antd/tag';\nimport { NzTooltipDirective } from 'ng-zorro-antd/tooltip';\n\nimport { CellHostDirective } from './cell-host.directive';\nimport { CellService } from './cell.service';\nimport type { CellDefaultText, CellOptions, CellTextResult, CellValue } from './cell.types';\n\n@Component({\n  selector: 'cell, [cell]',\n  template: `\n    <ng-template #text>\n      @switch (safeOpt.type) {\n        @case ('checkbox') {\n          <label nz-checkbox [nzDisabled]=\"disabled\" [ngModel]=\"value\" (ngModelChange)=\"change($event)\">\n            {{ safeOpt.checkbox?.label }}\n          </label>\n        }\n        @case ('radio') {\n          <label nz-radio [nzDisabled]=\"disabled\" [ngModel]=\"value\" (ngModelChange)=\"change($event)\">\n            {{ safeOpt.radio?.label }}\n          </label>\n        }\n        @case ('link') {\n          <a (click)=\"_link($event)\" [attr.target]=\"safeOpt.link?.target\" [attr.title]=\"value\" [innerHTML]=\"_text\"></a>\n        }\n        @case ('tag') {\n          <nz-tag [nzColor]=\"res?.result?.color\">\n            <span [innerHTML]=\"_text\"></span>\n          </nz-tag>\n        }\n        @case ('badge') {\n          <nz-badge [nzStatus]=\"res?.result?.color\" nzText=\"{{ _text }}\" />\n        }\n        @case ('widget') {\n          @if (res) {\n            <ng-template cell-widget-host [data]=\"res\" />\n          }\n        }\n        @case ('img') {\n          @for (i of $any(_text); track $index) {\n            <img\n              [attr.src]=\"i\"\n              [attr.height]=\"safeOpt.img?.size\"\n              [attr.width]=\"safeOpt.img?.size\"\n              (click)=\"_showImg(i)\"\n              class=\"img\"\n              [class.point]=\"safeOpt.img?.big\"\n            />\n          }\n        }\n        @default {\n          @if (isText) {\n            <span [innerText]=\"_text\" [attr.title]=\"value\"></span>\n          } @else {\n            <span [innerHTML]=\"_text\" [attr.title]=\"value\"></span>\n          }\n          @if (_unit) {\n            <span class=\"unit\">{{ _unit }}</span>\n          }\n        }\n      }\n    </ng-template>\n    <ng-template #textWrap>\n      @if (showDefault) {\n        {{ safeOpt.default?.text }}\n      } @else {\n        @if (safeOpt.tooltip) {\n          <span [nz-tooltip]=\"safeOpt.tooltip\">\n            <ng-template [ngTemplateOutlet]=\"text\" />\n          </span>\n        } @else {\n          <ng-template [ngTemplateOutlet]=\"text\" />\n        }\n      }\n    </ng-template>\n    @if (loading) {\n      <span nz-icon nzType=\"loading\"></span>\n    } @else {\n      <ng-template [ngTemplateOutlet]=\"textWrap\" />\n    }\n  `,\n  exportAs: 'cell',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    FormsModule,\n    NgTemplateOutlet,\n    NzCheckboxComponent,\n    NzRadioComponent,\n    NzIconDirective,\n    NzTagComponent,\n    NzBadgeComponent,\n    NzTooltipDirective,\n    NzImageModule,\n    CellHostDirective\n  ]\n})\nexport class CellComponent implements OnChanges, OnDestroy {\n  private readonly srv = inject(CellService);\n  private readonly router = inject(Router);\n  private readonly cdr = inject(ChangeDetectorRef);\n  private readonly renderer = inject(Renderer2);\n  private readonly imgSrv = inject(NzImageService);\n  private readonly win = inject(WINDOW);\n  private readonly el: HTMLElement = inject(ElementRef).nativeElement;\n\n  private destroy$?: Subscription;\n\n  _text!: string | SafeValue | string[] | number;\n  _unit?: string;\n  res?: CellTextResult;\n  showDefault = false;\n\n  @Input() value?: CellValue;\n  @Output() readonly valueChange = new EventEmitter<NzSafeAny>();\n  @Input() options?: CellOptions;\n  @Input({ transform: booleanAttribute }) loading = false;\n  @Input({ transform: booleanAttribute }) disabled = false;\n\n  get safeOpt(): CellOptions {\n    return this.res?.options ?? {};\n  }\n\n  get isText(): boolean {\n    return this.res?.safeHtml === 'text';\n  }\n\n  private updateValue(): void {\n    this.destroy$?.unsubscribe();\n    this.destroy$ = this.srv.get(this.value, this.options).subscribe(res => {\n      this.res = res;\n      this.showDefault = this.value == (this.safeOpt.default as CellDefaultText).condition;\n      this._text = res.result?.text ?? '';\n      this._unit = res.result?.unit ?? this.safeOpt?.unit;\n      this.cdr.detectChanges();\n      this.setClass();\n    });\n  }\n\n  private setClass(): void {\n    const { el, renderer } = this;\n    const { renderType, size, type } = this.safeOpt;\n    updateHostClass(el, renderer, {\n      [`cell`]: true,\n      [`cell__${renderType}`]: renderType != null,\n      [`cell__${size}`]: size != null,\n      [`cell__has-unit`]: this._unit,\n      [`cell__has-default`]: this.showDefault,\n      [`cell__disabled`]: this.disabled\n    });\n    el.setAttribute('data-type', `${type}`);\n  }\n\n  ngOnChanges(changes: { [p in keyof CellComponent]?: SimpleChange }): void {\n    // Do not call updateValue when only updating loading, disabled\n    if (Object.keys(changes).every(k => ['loading', 'disabled'].includes(k))) {\n      this.setClass();\n    } else {\n      this.updateValue();\n    }\n  }\n\n  change(value: NzSafeAny): void {\n    this.value = value;\n    this.valueChange.emit(value);\n  }\n\n  _link(e: Event): void {\n    e.preventDefault();\n    e.stopPropagation();\n\n    if (this.disabled) return;\n\n    const link = this.safeOpt.link;\n    const url = link?.url;\n    if (url == null) return;\n\n    if (/https?:\\/\\//g.test(url)) {\n      this.win.open(url, link?.target);\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n  _showImg(img: string): void {\n    const config = this.safeOpt.img;\n    if (config == null || config.big == null) return;\n\n    let idx = -1;\n    const list = (this._text as string[]).map((p, index) => {\n      if (idx === -1 && p === img) idx = index;\n      return typeof config.big === 'function' ? config.big(p) : p;\n    });\n    this.imgSrv\n      .preview(\n        list.map(p => ({ src: p }) as NzImage),\n        config.previewOptions\n      )\n      .switchTo(idx);\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$?.unsubscribe();\n  }\n}\n"]}