UNPKG

@delon/abc

Version:

Common business components of ng-alain.

127 lines 16.2 kB
import { NgStyle } from '@angular/common'; import { ChangeDetectionStrategy, Component, ElementRef, Input, Renderer2, ViewEncapsulation, booleanAttribute, inject, numberAttribute } from '@angular/core'; import { NzStringTemplateOutletDirective } from 'ng-zorro-antd/core/outlet'; import * as i0 from "@angular/core"; import * as i1 from "@delon/util/config"; export class SVTitleComponent { constructor() { this.el = inject(ElementRef).nativeElement; this.parentComp = inject(SVContainerComponent, { host: true, optional: true }); this.ren = inject(Renderer2); if (this.parentComp == null) { throw new Error(`[sv-title] must include 'sv-container' component`); } } setClass() { const gutter = this.parentComp.gutter; const el = this.el; 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: SVTitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.5", type: SVTitleComponent, isStandalone: true, selector: "sv-title, [sv-title]", host: { properties: { "class.sv__title": "true" } }, exportAs: ["svTitle"], 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: SVTitleComponent, decorators: [{ type: Component, args: [{ selector: 'sv-title, [sv-title]', exportAs: 'svTitle', template: '<ng-content />', host: { '[class.sv__title]': 'true' }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true }] }], ctorParameters: () => [] }); export class SVContainerComponent { get margin() { return this.bordered ? {} : { 'margin-left.px': -(this.gutter / 2), 'margin-right.px': -(this.gutter / 2) }; } constructor(configSrv) { this.noColon = false; this.bordered = false; configSrv.attach(this, 'sv', { size: 'large', gutter: 32, layout: 'horizontal', col: 3, default: true }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: SVContainerComponent, deps: [{ token: i1.AlainConfigService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: SVContainerComponent, isStandalone: true, selector: "sv-container, [sv-container]", inputs: { colInCon: ["sv-container", "colInCon", (v) => (v == null ? null : numberAttribute(v))], title: "title", size: "size", gutter: ["gutter", "gutter", numberAttribute], layout: "layout", labelWidth: ["labelWidth", "labelWidth", numberAttribute], col: ["col", "col", numberAttribute], default: ["default", "default", booleanAttribute], noColon: ["noColon", "noColon", booleanAttribute], bordered: ["bordered", "bordered", booleanAttribute] }, host: { properties: { "class.sv__container": "true", "class.sv__horizontal": "layout === 'horizontal'", "class.sv__vertical": "layout === 'vertical'", "class.sv__small": "size === 'small'", "class.sv__large": "size === 'large'", "class.sv__bordered": "bordered", "class.clearfix": "true" } }, exportAs: ["svContainer"], ngImport: i0, template: ` <div class="ant-row" [ngStyle]="margin"> @if (title) { <sv-title> <ng-container *nzStringTemplateOutlet="title">{{ title }}</ng-container> </sv-title> } <ng-content /> </div> `, isInline: true, dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: SVTitleComponent, selector: "sv-title, [sv-title]", exportAs: ["svTitle"] }, { 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: SVContainerComponent, decorators: [{ type: Component, args: [{ selector: 'sv-container, [sv-container]', exportAs: 'svContainer', template: ` <div class="ant-row" [ngStyle]="margin"> @if (title) { <sv-title> <ng-container *nzStringTemplateOutlet="title">{{ title }}</ng-container> </sv-title> } <ng-content /> </div> `, host: { '[class.sv__container]': 'true', '[class.sv__horizontal]': `layout === 'horizontal'`, '[class.sv__vertical]': `layout === 'vertical'`, '[class.sv__small]': `size === 'small'`, '[class.sv__large]': `size === 'large'`, '[class.sv__bordered]': `bordered`, '[class.clearfix]': `true` }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [NgStyle, SVTitleComponent, NzStringTemplateOutletDirective] }] }], ctorParameters: () => [{ type: i1.AlainConfigService }], propDecorators: { colInCon: [{ type: Input, args: [{ alias: 'sv-container', transform: (v) => (v == null ? null : numberAttribute(v)) }] }], title: [{ type: Input }], size: [{ type: Input }], gutter: [{ type: Input, args: [{ transform: numberAttribute }] }], layout: [{ type: Input }], labelWidth: [{ type: Input, args: [{ transform: numberAttribute }] }], col: [{ type: Input, args: [{ transform: numberAttribute }] }], default: [{ type: Input, args: [{ transform: booleanAttribute }] }], noColon: [{ type: Input, args: [{ transform: booleanAttribute }] }], bordered: [{ type: Input, args: [{ transform: booleanAttribute }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sv-container.component.js","sourceRoot":"","sources":["../../../../../packages/abc/sv/sv-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgStyle } from '@angular/common';\nimport {\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';\n\nimport type { REP_TYPE } from '@delon/theme';\nimport { AlainConfigService } from '@delon/util/config';\nimport { NzStringTemplateOutletDirective } from 'ng-zorro-antd/core/outlet';\n\n@Component({\n  selector: 'sv-title, [sv-title]',\n  exportAs: 'svTitle',\n  template: '<ng-content />',\n  host: {\n    '[class.sv__title]': 'true'\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true\n})\nexport class SVTitleComponent implements OnInit {\n  private readonly el: HTMLElement = inject(ElementRef).nativeElement;\n  private readonly parentComp = inject(SVContainerComponent, { host: true, optional: true });\n  private readonly ren = inject(Renderer2);\n\n  constructor() {\n    if (this.parentComp == null) {\n      throw new Error(`[sv-title] must include 'sv-container' component`);\n    }\n  }\n\n  private setClass(): void {\n    const gutter = this.parentComp!.gutter;\n    const el = this.el;\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: 'sv-container, [sv-container]',\n  exportAs: 'svContainer',\n  template: `\n    <div class=\"ant-row\" [ngStyle]=\"margin\">\n      @if (title) {\n        <sv-title>\n          <ng-container *nzStringTemplateOutlet=\"title\">{{ title }}</ng-container>\n        </sv-title>\n      }\n      <ng-content />\n    </div>\n  `,\n  host: {\n    '[class.sv__container]': 'true',\n    '[class.sv__horizontal]': `layout === 'horizontal'`,\n    '[class.sv__vertical]': `layout === 'vertical'`,\n    '[class.sv__small]': `size === 'small'`,\n    '[class.sv__large]': `size === 'large'`,\n    '[class.sv__bordered]': `bordered`,\n    '[class.clearfix]': `true`\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [NgStyle, SVTitleComponent, NzStringTemplateOutletDirective]\n})\nexport class SVContainerComponent {\n  @Input({ alias: 'sv-container', transform: (v: unknown) => (v == null ? null : numberAttribute(v)) })\n  colInCon?: REP_TYPE;\n  @Input() title?: string | TemplateRef<void>;\n  @Input() size?: 'small' | 'large' | 'default';\n  /** 列表项间距，单位为 `px` */\n  @Input({ transform: numberAttribute }) gutter!: number;\n  @Input() layout!: 'horizontal' | 'vertical';\n  @Input({ transform: numberAttribute }) labelWidth?: number;\n  /** 指定信息最多分几列展示，最终一行几列由 col 配置结合响应式规则决定 */\n  @Input({ transform: numberAttribute }) col!: number;\n  @Input({ transform: booleanAttribute }) default!: boolean;\n  @Input({ transform: booleanAttribute }) noColon = false;\n  @Input({ transform: booleanAttribute }) bordered = false;\n\n  get margin(): { [k: string]: number } {\n    return this.bordered ? {} : { 'margin-left.px': -(this.gutter / 2), 'margin-right.px': -(this.gutter / 2) };\n  }\n\n  constructor(configSrv: AlainConfigService) {\n    configSrv.attach(this, 'sv', {\n      size: 'large',\n      gutter: 32,\n      layout: 'horizontal',\n      col: 3,\n      default: true\n    });\n  }\n}\n"]}