@delon/abc
Version:
Common business components of ng-alain.
289 lines • 29.2 kB
JavaScript
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>
(safeOpt.type) {
('checkbox') {
<label nz-checkbox [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)">
{{ safeOpt.checkbox?.label }}
</label>
}
('radio') {
<label nz-radio [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)">
{{ safeOpt.radio?.label }}
</label>
}
('link') {
<a (click)="_link($event)" [attr.target]="safeOpt.link?.target" [attr.title]="value" [innerHTML]="_text"></a>
}
('tag') {
<nz-tag [nzColor]="res?.result?.color">
<span [innerHTML]="_text"></span>
</nz-tag>
}
('badge') {
<nz-badge [nzStatus]="res?.result?.color" nzText="{{ _text }}" />
}
('widget') {
(res) {
<ng-template cell-widget-host [data]="res" />
}
}
('img') {
(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"
/>
}
}
{
(isText) {
<span [innerText]="_text" [attr.title]="value"></span>
} {
<span [innerHTML]="_text" [attr.title]="value"></span>
}
(_unit) {
<span class="unit">{{ _unit }}</span>
}
}
}
</ng-template>
<ng-template #textWrap>
(showDefault) {
{{ safeOpt.default?.text }}
} {
(safeOpt.tooltip) {
<span [nz-tooltip]="safeOpt.tooltip">
<ng-template [ngTemplateOutlet]="text" />
</span>
} {
<ng-template [ngTemplateOutlet]="text" />
}
}
</ng-template>
(loading) {
<span nz-icon nzType="loading"></span>
} {
<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>
(safeOpt.type) {
('checkbox') {
<label nz-checkbox [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)">
{{ safeOpt.checkbox?.label }}
</label>
}
('radio') {
<label nz-radio [nzDisabled]="disabled" [ngModel]="value" (ngModelChange)="change($event)">
{{ safeOpt.radio?.label }}
</label>
}
('link') {
<a (click)="_link($event)" [attr.target]="safeOpt.link?.target" [attr.title]="value" [innerHTML]="_text"></a>
}
('tag') {
<nz-tag [nzColor]="res?.result?.color">
<span [innerHTML]="_text"></span>
</nz-tag>
}
('badge') {
<nz-badge [nzStatus]="res?.result?.color" nzText="{{ _text }}" />
}
('widget') {
(res) {
<ng-template cell-widget-host [data]="res" />
}
}
('img') {
(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"
/>
}
}
{
(isText) {
<span [innerText]="_text" [attr.title]="value"></span>
} {
<span [innerHTML]="_text" [attr.title]="value"></span>
}
(_unit) {
<span class="unit">{{ _unit }}</span>
}
}
}
</ng-template>
<ng-template #textWrap>
(showDefault) {
{{ safeOpt.default?.text }}
} {
(safeOpt.tooltip) {
<span [nz-tooltip]="safeOpt.tooltip">
<ng-template [ngTemplateOutlet]="text" />
</span>
} {
<ng-template [ngTemplateOutlet]="text" />
}
}
</ng-template>
(loading) {
<span nz-icon nzType="loading"></span>
} {
<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"]}