UNPKG

@delon/abc

Version:

Common business components of ng-alain.

158 lines 19.9 kB
import { ChangeDetectionStrategy, Component, ElementRef, Input, Renderer2, ViewEncapsulation, booleanAttribute, inject, numberAttribute } from '@angular/core'; import { BehaviorSubject, filter } from 'rxjs'; import { NzStringTemplateOutletDirective } from 'ng-zorro-antd/core/outlet'; import * as i0 from "@angular/core"; import * as i1 from "@delon/util/config"; export class SETitleComponent { constructor() { this.parentComp = inject(SEContainerComponent, { host: true, optional: true }); this.el = inject(ElementRef).nativeElement; this.ren = inject(Renderer2); if (this.parentComp == null) { throw new Error(`[se-title] must include 'se-container' component`); } } setClass() { const { el } = this; const gutter = this.parentComp.gutter; this.ren.setStyle(el, 'padding-left', `${gutter / 2}px`); this.ren.setStyle(el, 'padding-right', `${gutter / 2}px`); } ngOnInit() { this.setClass(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: SETitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.5", type: SETitleComponent, isStandalone: true, selector: "se-title, [se-title]", host: { properties: { "class.se__title": "true" } }, exportAs: ["seTitle"], ngImport: i0, template: '<ng-content />', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: SETitleComponent, decorators: [{ type: Component, args: [{ selector: 'se-title, [se-title]', exportAs: 'seTitle', template: '<ng-content />', host: { '[class.se__title]': 'true' }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true }] }], ctorParameters: () => [] }); export class SEContainerComponent { get gutter() { return this.nzLayout === 'horizontal' ? this._gutter : 0; } set gutter(value) { this._gutter = value; } get nzLayout() { return this._nzLayout; } set nzLayout(value) { this._nzLayout = value; if (value === 'inline') { this.size = 'compact'; } } set errors(val) { this.setErrors(val); } get margin() { return -(this.gutter / 2); } get errorNotify() { return this.errorNotify$.pipe(filter(v => v != null)); } constructor(configSrv) { this.errorNotify$ = new BehaviorSubject(null); this.noColon = false; this.line = false; configSrv.attach(this, 'se', { size: 'default', nzLayout: 'horizontal', gutter: 32, col: 2, labelWidth: 150, firstVisual: false, ingoreDirty: false }); } setErrors(errors) { for (const error of errors) { this.errorNotify$.next(error); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: SEContainerComponent, deps: [{ token: i1.AlainConfigService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: SEContainerComponent, isStandalone: true, selector: "se-container, [se-container]", inputs: { colInCon: ["se-container", "colInCon", (v) => (v == null ? null : numberAttribute(v))], col: ["col", "col", (v) => (v == null ? null : numberAttribute(v))], labelWidth: ["labelWidth", "labelWidth", (v) => (v == null ? null : numberAttribute(v))], noColon: ["noColon", "noColon", booleanAttribute], title: "title", gutter: ["gutter", "gutter", numberAttribute], nzLayout: "nzLayout", size: "size", firstVisual: ["firstVisual", "firstVisual", booleanAttribute], ingoreDirty: ["ingoreDirty", "ingoreDirty", booleanAttribute], line: ["line", "line", booleanAttribute], errors: "errors" }, host: { properties: { "class.ant-row": "true", "class.se__container": "true", "class.se__horizontal": "nzLayout === 'horizontal'", "class.se__vertical": "nzLayout === 'vertical'", "class.se__inline": "nzLayout === 'inline'", "class.se__compact": "size === 'compact'", "style.margin-left.px": "margin", "style.margin-right.px": "margin" } }, exportAs: ["seContainer"], ngImport: i0, template: ` @if (title) { <div se-title> <ng-container *nzStringTemplateOutlet="title">{{ title }}</ng-container> </div> } <ng-content /> `, isInline: true, dependencies: [{ kind: "component", type: SETitleComponent, selector: "se-title, [se-title]", exportAs: ["seTitle"] }, { kind: "directive", type: NzStringTemplateOutletDirective, selector: "[nzStringTemplateOutlet]", inputs: ["nzStringTemplateOutletContext", "nzStringTemplateOutlet"], exportAs: ["nzStringTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: SEContainerComponent, decorators: [{ type: Component, args: [{ selector: 'se-container, [se-container]', exportAs: 'seContainer', template: ` @if (title) { <div se-title> <ng-container *nzStringTemplateOutlet="title">{{ title }}</ng-container> </div> } <ng-content /> `, host: { '[class.ant-row]': `true`, '[class.se__container]': `true`, '[class.se__horizontal]': `nzLayout === 'horizontal'`, '[class.se__vertical]': `nzLayout === 'vertical'`, '[class.se__inline]': `nzLayout === 'inline'`, '[class.se__compact]': `size === 'compact'`, '[style.margin-left.px]': `margin`, '[style.margin-right.px]': `margin` }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [SETitleComponent, NzStringTemplateOutletDirective] }] }], ctorParameters: () => [{ type: i1.AlainConfigService }], propDecorators: { colInCon: [{ type: Input, args: [{ alias: 'se-container', transform: (v) => (v == null ? null : numberAttribute(v)) }] }], col: [{ type: Input, args: [{ transform: (v) => (v == null ? null : numberAttribute(v)) }] }], labelWidth: [{ type: Input, args: [{ transform: (v) => (v == null ? null : numberAttribute(v)) }] }], noColon: [{ type: Input, args: [{ transform: booleanAttribute }] }], title: [{ type: Input }], gutter: [{ type: Input, args: [{ transform: numberAttribute }] }], nzLayout: [{ type: Input }], size: [{ type: Input }], firstVisual: [{ type: Input, args: [{ transform: booleanAttribute }] }], ingoreDirty: [{ type: Input, args: [{ transform: booleanAttribute }] }], line: [{ type: Input, args: [{ transform: booleanAttribute }] }], errors: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"se-container.component.js","sourceRoot":"","sources":["../../../../../packages/abc/se/se-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  Renderer2,\n  TemplateRef,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n  numberAttribute\n} from '@angular/core';\nimport { BehaviorSubject, Observable, filter } from 'rxjs';\n\nimport type { REP_TYPE } from '@delon/theme';\nimport { AlainConfigService } from '@delon/util/config';\nimport { NzStringTemplateOutletDirective } from 'ng-zorro-antd/core/outlet';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nimport { SEErrorRefresh, SELayout } from './se.types';\n\n@Component({\n  selector: 'se-title, [se-title]',\n  exportAs: 'seTitle',\n  template: '<ng-content />',\n  host: {\n    '[class.se__title]': 'true'\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true\n})\nexport class SETitleComponent implements OnInit {\n  private readonly parentComp = inject(SEContainerComponent, { host: true, optional: true });\n  private readonly el: HTMLElement = inject(ElementRef).nativeElement;\n  private readonly ren = inject(Renderer2);\n  constructor() {\n    if (this.parentComp == null) {\n      throw new Error(`[se-title] must include 'se-container' component`);\n    }\n  }\n\n  private setClass(): void {\n    const { el } = this;\n    const gutter = this.parentComp!.gutter as number;\n    this.ren.setStyle(el, 'padding-left', `${gutter / 2}px`);\n    this.ren.setStyle(el, 'padding-right', `${gutter / 2}px`);\n  }\n\n  ngOnInit(): void {\n    this.setClass();\n  }\n}\n\n@Component({\n  selector: 'se-container, [se-container]',\n  exportAs: 'seContainer',\n  template: `\n    @if (title) {\n      <div se-title>\n        <ng-container *nzStringTemplateOutlet=\"title\">{{ title }}</ng-container>\n      </div>\n    }\n    <ng-content />\n  `,\n  host: {\n    '[class.ant-row]': `true`,\n    '[class.se__container]': `true`,\n    '[class.se__horizontal]': `nzLayout === 'horizontal'`,\n    '[class.se__vertical]': `nzLayout === 'vertical'`,\n    '[class.se__inline]': `nzLayout === 'inline'`,\n    '[class.se__compact]': `size === 'compact'`,\n    '[style.margin-left.px]': `margin`,\n    '[style.margin-right.px]': `margin`\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [SETitleComponent, NzStringTemplateOutletDirective]\n})\nexport class SEContainerComponent {\n  private errorNotify$ = new BehaviorSubject<SEErrorRefresh>(null as NzSafeAny);\n  @Input({ alias: 'se-container', transform: (v: unknown) => (v == null ? null : numberAttribute(v)) })\n  colInCon?: REP_TYPE;\n  @Input({ transform: (v: unknown) => (v == null ? null : numberAttribute(v)) }) col!: REP_TYPE;\n  @Input({ transform: (v: unknown) => (v == null ? null : numberAttribute(v)) }) labelWidth!: number;\n  @Input({ transform: booleanAttribute }) noColon = false;\n  @Input() title?: string | TemplateRef<void> | null;\n\n  @Input({ transform: numberAttribute })\n  get gutter(): number {\n    return this.nzLayout === 'horizontal' ? this._gutter : 0;\n  }\n  set gutter(value: number) {\n    this._gutter = value;\n  }\n  private _gutter!: number;\n\n  @Input()\n  get nzLayout(): SELayout {\n    return this._nzLayout;\n  }\n  set nzLayout(value: SELayout) {\n    this._nzLayout = value;\n    if (value === 'inline') {\n      this.size = 'compact';\n    }\n  }\n  private _nzLayout!: SELayout;\n\n  @Input() size!: 'default' | 'compact';\n  @Input({ transform: booleanAttribute }) firstVisual!: boolean;\n  @Input({ transform: booleanAttribute }) ingoreDirty!: boolean;\n  @Input({ transform: booleanAttribute }) line = false;\n  @Input()\n  set errors(val: SEErrorRefresh[]) {\n    this.setErrors(val);\n  }\n\n  get margin(): number {\n    return -((this.gutter as number) / 2);\n  }\n\n  get errorNotify(): Observable<SEErrorRefresh> {\n    return this.errorNotify$.pipe(filter(v => v != null));\n  }\n\n  constructor(configSrv: AlainConfigService) {\n    configSrv.attach(this, 'se', {\n      size: 'default',\n      nzLayout: 'horizontal',\n      gutter: 32,\n      col: 2,\n      labelWidth: 150,\n      firstVisual: false,\n      ingoreDirty: false\n    });\n  }\n\n  setErrors(errors: SEErrorRefresh[]): void {\n    for (const error of errors) {\n      this.errorNotify$.next(error);\n    }\n  }\n}\n"]}