ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
189 lines (187 loc) • 18 kB
JavaScript
import { ChangeDetectionStrategy, Component, Input, Optional, ViewEncapsulation } from '@angular/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { NzOutletModule } from 'ng-zorro-antd/core/outlet';
import { NzIconModule } from 'ng-zorro-antd/icon';
import { NzResultNotFoundComponent } from './partial/not-found';
import { NzResultServerErrorComponent } from './partial/server-error.component';
import { NzResultUnauthorizedComponent } from './partial/unauthorized';
import * as i0 from "@angular/core";
import * as i1 from "@angular/cdk/bidi";
import * as i2 from "ng-zorro-antd/core/outlet";
import * as i3 from "ng-zorro-antd/icon";
const IconMap = {
success: 'check-circle',
error: 'close-circle',
info: 'exclamation-circle',
warning: 'warning'
};
const ExceptionStatus = ['404', '500', '403'];
export class NzResultComponent {
constructor(cdr, directionality) {
this.cdr = cdr;
this.directionality = directionality;
this.nzStatus = 'info';
this.isException = false;
this.dir = 'ltr';
this.destroy$ = new Subject();
}
ngOnInit() {
this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction) => {
this.dir = direction;
this.cdr.detectChanges();
});
this.dir = this.directionality.value;
}
ngOnChanges() {
this.setStatusIcon();
}
ngOnDestroy() {
this.destroy$.next();
this.destroy$.complete();
}
setStatusIcon() {
const icon = this.nzIcon;
this.isException = ExceptionStatus.indexOf(this.nzStatus) !== -1;
this.icon = icon
? typeof icon === 'string'
? IconMap[icon] || icon
: icon
: this.isException
? undefined
: IconMap[this.nzStatus];
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: NzResultComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.4", type: NzResultComponent, isStandalone: true, selector: "nz-result", inputs: { nzIcon: "nzIcon", nzTitle: "nzTitle", nzStatus: "nzStatus", nzSubTitle: "nzSubTitle", nzExtra: "nzExtra" }, host: { properties: { "class.ant-result-success": "nzStatus === 'success'", "class.ant-result-error": "nzStatus === 'error'", "class.ant-result-info": "nzStatus === 'info'", "class.ant-result-warning": "nzStatus === 'warning'", "class.ant-result-rtl": "dir === 'rtl'" }, classAttribute: "ant-result" }, exportAs: ["nzResult"], usesOnChanges: true, ngImport: i0, template: `
<div class="ant-result-icon">
(!isException) {
(icon) {
<ng-container *nzStringTemplateOutlet="icon; let icon">
<span nz-icon [nzType]="icon" nzTheme="fill"></span>
</ng-container>
} {
<ng-content select="[nz-result-icon]"></ng-content>
}
} {
(nzStatus) {
('404') {
<nz-result-not-found />
}
('500') {
<nz-result-server-error />
}
('403') {
<nz-result-unauthorized />
}
}
}
</div>
(nzTitle) {
<div class="ant-result-title" *nzStringTemplateOutlet="nzTitle">
{{ nzTitle }}
</div>
} {
<ng-content select="div[nz-result-title]"></ng-content>
}
(nzSubTitle) {
<div class="ant-result-subtitle" *nzStringTemplateOutlet="nzSubTitle">
{{ nzSubTitle }}
</div>
} {
<ng-content select="div[nz-result-subtitle]"></ng-content>
}
<ng-content select="nz-result-content, [nz-result-content]"></ng-content>
(nzExtra) {
<div class="ant-result-extra" *nzStringTemplateOutlet="nzExtra">
{{ nzExtra }}
</div>
} {
<ng-content select="div[nz-result-extra]"></ng-content>
}
`, isInline: true, dependencies: [{ kind: "ngmodule", type: NzOutletModule }, { kind: "directive", type: i2.NzStringTemplateOutletDirective, selector: "[nzStringTemplateOutlet]", inputs: ["nzStringTemplateOutletContext", "nzStringTemplateOutlet"], exportAs: ["nzStringTemplateOutlet"] }, { kind: "ngmodule", type: NzIconModule }, { kind: "directive", type: i3.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "component", type: NzResultNotFoundComponent, selector: "nz-result-not-found", exportAs: ["nzResultNotFound"] }, { kind: "component", type: NzResultServerErrorComponent, selector: "nz-result-server-error", exportAs: ["nzResultServerError"] }, { kind: "component", type: NzResultUnauthorizedComponent, selector: "nz-result-unauthorized", exportAs: ["nzResultUnauthorized"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: NzResultComponent, decorators: [{
type: Component,
args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
selector: 'nz-result',
exportAs: 'nzResult',
template: `
<div class="ant-result-icon">
(!isException) {
(icon) {
<ng-container *nzStringTemplateOutlet="icon; let icon">
<span nz-icon [nzType]="icon" nzTheme="fill"></span>
</ng-container>
} {
<ng-content select="[nz-result-icon]"></ng-content>
}
} {
(nzStatus) {
('404') {
<nz-result-not-found />
}
('500') {
<nz-result-server-error />
}
('403') {
<nz-result-unauthorized />
}
}
}
</div>
(nzTitle) {
<div class="ant-result-title" *nzStringTemplateOutlet="nzTitle">
{{ nzTitle }}
</div>
} {
<ng-content select="div[nz-result-title]"></ng-content>
}
(nzSubTitle) {
<div class="ant-result-subtitle" *nzStringTemplateOutlet="nzSubTitle">
{{ nzSubTitle }}
</div>
} {
<ng-content select="div[nz-result-subtitle]"></ng-content>
}
<ng-content select="nz-result-content, [nz-result-content]"></ng-content>
(nzExtra) {
<div class="ant-result-extra" *nzStringTemplateOutlet="nzExtra">
{{ nzExtra }}
</div>
} {
<ng-content select="div[nz-result-extra]"></ng-content>
}
`,
host: {
class: 'ant-result',
'[class.ant-result-success]': `nzStatus === 'success'`,
'[class.ant-result-error]': `nzStatus === 'error'`,
'[class.ant-result-info]': `nzStatus === 'info'`,
'[class.ant-result-warning]': `nzStatus === 'warning'`,
'[class.ant-result-rtl]': `dir === 'rtl'`
},
imports: [
NzOutletModule,
NzIconModule,
NzResultNotFoundComponent,
NzResultServerErrorComponent,
NzResultUnauthorizedComponent
],
standalone: true
}]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.Directionality, decorators: [{
type: Optional
}] }], propDecorators: { nzIcon: [{
type: Input
}], nzTitle: [{
type: Input
}], nzStatus: [{
type: Input
}], nzSubTitle: [{
type: Input
}], nzExtra: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"result.component.js","sourceRoot":"","sources":["../../../components/result/result.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { NzOutletModule } from 'ng-zorro-antd/core/outlet';\nimport { NzIconModule } from 'ng-zorro-antd/icon';\n\nimport { NzResultNotFoundComponent } from './partial/not-found';\nimport { NzResultServerErrorComponent } from './partial/server-error.component';\nimport { NzResultUnauthorizedComponent } from './partial/unauthorized';\n\nexport type NzResultIconType = 'success' | 'error' | 'info' | 'warning';\nexport type NzExceptionStatusType = '404' | '500' | '403';\nexport type NzResultStatusType = NzExceptionStatusType | NzResultIconType;\n\nconst IconMap = {\n  success: 'check-circle',\n  error: 'close-circle',\n  info: 'exclamation-circle',\n  warning: 'warning'\n};\nconst ExceptionStatus = ['404', '500', '403'];\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-result',\n  exportAs: 'nzResult',\n  template: `\n    <div class=\"ant-result-icon\">\n      @if (!isException) {\n        @if (icon) {\n          <ng-container *nzStringTemplateOutlet=\"icon; let icon\">\n            <span nz-icon [nzType]=\"icon\" nzTheme=\"fill\"></span>\n          </ng-container>\n        } @else {\n          <ng-content select=\"[nz-result-icon]\"></ng-content>\n        }\n      } @else {\n        @switch (nzStatus) {\n          @case ('404') {\n            <nz-result-not-found />\n          }\n          @case ('500') {\n            <nz-result-server-error />\n          }\n          @case ('403') {\n            <nz-result-unauthorized />\n          }\n        }\n      }\n    </div>\n    @if (nzTitle) {\n      <div class=\"ant-result-title\" *nzStringTemplateOutlet=\"nzTitle\">\n        {{ nzTitle }}\n      </div>\n    } @else {\n      <ng-content select=\"div[nz-result-title]\"></ng-content>\n    }\n\n    @if (nzSubTitle) {\n      <div class=\"ant-result-subtitle\" *nzStringTemplateOutlet=\"nzSubTitle\">\n        {{ nzSubTitle }}\n      </div>\n    } @else {\n      <ng-content select=\"div[nz-result-subtitle]\"></ng-content>\n    }\n    <ng-content select=\"nz-result-content, [nz-result-content]\"></ng-content>\n    @if (nzExtra) {\n      <div class=\"ant-result-extra\" *nzStringTemplateOutlet=\"nzExtra\">\n        {{ nzExtra }}\n      </div>\n    } @else {\n      <ng-content select=\"div[nz-result-extra]\"></ng-content>\n    }\n  `,\n  host: {\n    class: 'ant-result',\n    '[class.ant-result-success]': `nzStatus === 'success'`,\n    '[class.ant-result-error]': `nzStatus === 'error'`,\n    '[class.ant-result-info]': `nzStatus === 'info'`,\n    '[class.ant-result-warning]': `nzStatus === 'warning'`,\n    '[class.ant-result-rtl]': `dir === 'rtl'`\n  },\n  imports: [\n    NzOutletModule,\n    NzIconModule,\n    NzResultNotFoundComponent,\n    NzResultServerErrorComponent,\n    NzResultUnauthorizedComponent\n  ],\n  standalone: true\n})\nexport class NzResultComponent implements OnChanges, OnDestroy, OnInit {\n  @Input() nzIcon?: string | TemplateRef<void>;\n  @Input() nzTitle?: string | TemplateRef<void>;\n  @Input() nzStatus: NzResultStatusType = 'info';\n  @Input() nzSubTitle?: string | TemplateRef<void>;\n  @Input() nzExtra?: string | TemplateRef<void>;\n\n  icon?: string | TemplateRef<void>;\n  isException = false;\n  dir: Direction = 'ltr';\n\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    @Optional() private directionality: Directionality\n  ) {}\n\n  ngOnInit(): void {\n    this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction: Direction) => {\n      this.dir = direction;\n      this.cdr.detectChanges();\n    });\n\n    this.dir = this.directionality.value;\n  }\n\n  ngOnChanges(): void {\n    this.setStatusIcon();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  private setStatusIcon(): void {\n    const icon = this.nzIcon;\n\n    this.isException = ExceptionStatus.indexOf(this.nzStatus) !== -1;\n    this.icon = icon\n      ? typeof icon === 'string'\n        ? IconMap[icon as NzResultIconType] || icon\n        : icon\n      : this.isException\n        ? undefined\n        : IconMap[this.nzStatus as NzResultIconType];\n  }\n}\n"]}