@delon/abc
Version:
Common business components of ng-alain.
158 lines • 19.9 kB
JavaScript
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"]}