UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

419 lines 33.4 kB
/** * @fileoverview added by tsickle * Generated from: se.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __decorate, __metadata } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, Host, Input, Optional, Renderer2, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core'; import { FormControlName, NgModel, RequiredValidator } from '@angular/forms'; import { ResponsiveService } from '@ohayojp.com/theme'; import { InputBoolean, InputNumber, isEmpty } from '@ohayojp.com/util'; import { helpMotion } from 'ng-zorro-antd/core/animation'; import { Subject } from 'rxjs'; import { filter, takeUntil } from 'rxjs/operators'; import { SEContainerComponent } from './se-container.component'; /** @type {?} */ const prefixCls = `se`; /** @type {?} */ let nextUniqueId = 0; export class SEComponent { /** * @param {?} el * @param {?} parent * @param {?} rep * @param {?} ren * @param {?} cdr */ constructor(el, parent, rep, ren, cdr) { this.parent = parent; this.rep = rep; this.ren = ren; this.cdr = cdr; this.unsubscribe$ = new Subject(); this.clsMap = []; this.inited = false; this.onceFlag = false; this.errorData = {}; this.isBindModel = false; this.invalid = false; this._labelWidth = null; this.required = false; this.controlClass = ''; this._id = `_se-${++nextUniqueId}`; this._autoId = true; if (parent == null) { throw new Error(`[se] must include 'se-container' component`); } this.el = el.nativeElement; parent.errorNotify .pipe(takeUntil(this.unsubscribe$), filter((/** * @param {?} w * @return {?} */ w => this.inited && this.ngControl != null && this.ngControl.name === w.name))) .subscribe((/** * @param {?} item * @return {?} */ item => { this.error = item.error; this.updateStatus((/** @type {?} */ (this.ngControl.invalid))); })); } /** * @param {?} val * @return {?} */ set error(val) { this.errorData = typeof val === 'string' || val instanceof TemplateRef ? { '': val } : val; } /** * @param {?} value * @return {?} */ set id(value) { this._id = value; this._autoId = false; } // #endregion /** * @return {?} */ get paddingValue() { return this.parent.gutter / 2; } /** * @return {?} */ get showErr() { return this.invalid && !!this._error && !this.compact; } /** * @return {?} */ get compact() { return this.parent.size === 'compact'; } /** * @private * @return {?} */ get ngControl() { return this.ngModel || this.formControlName; } /** * @private * @template THIS * @this {THIS} * @return {THIS} */ setClass() { const { el, ren, clsMap, col, parent, cdr, line, labelWidth, rep } = (/** @type {?} */ (this)); (/** @type {?} */ (this))._labelWidth = parent.nzLayout === 'horizontal' ? (labelWidth != null ? labelWidth : parent.labelWidth) : null; clsMap.forEach((/** * @param {?} cls * @return {?} */ cls => ren.removeClass(el, cls))); clsMap.length = 0; /** @type {?} */ const repCls = parent.nzLayout === 'horizontal' ? rep.genCls(col != null ? col : parent.colInCon || parent.col) : []; clsMap.push(`ant-form-item`, ...repCls, `${prefixCls}__item`); if (line || parent.line) { clsMap.push(`${prefixCls}__line`); } clsMap.forEach((/** * @param {?} cls * @return {?} */ cls => ren.addClass(el, cls))); cdr.detectChanges(); return (/** @type {?} */ (this)); } /** * @private * @return {?} */ bindModel() { var _a, _b; if (!this.ngControl || this.isBindModel) return; this.isBindModel = true; (/** @type {?} */ (this.ngControl.statusChanges)).pipe(takeUntil(this.unsubscribe$)).subscribe((/** * @param {?} res * @return {?} */ res => this.updateStatus(res === 'INVALID'))); if (this._autoId) { /** @type {?} */ const controlAccessor = (/** @type {?} */ (this.ngControl.valueAccessor)); /** @type {?} */ const control = (/** @type {?} */ ((_a = ((controlAccessor === null || controlAccessor === void 0 ? void 0 : controlAccessor.elementRef) || (controlAccessor === null || controlAccessor === void 0 ? void 0 : controlAccessor._elementRef))) === null || _a === void 0 ? void 0 : _a.nativeElement)); if (!!control) { if (control.id) { this._id = control.id; } else { control.id = this._id; } } } // auto required if (this.required !== true) { /** @type {?} */ const rawValidators = (/** @type {?} */ ((_b = ((/** @type {?} */ (this.ngControl)))) === null || _b === void 0 ? void 0 : _b._rawValidators)); this.required = rawValidators.find((/** * @param {?} w * @return {?} */ w => w instanceof RequiredValidator)) != null; this.cdr.detectChanges(); } } /** * @private * @param {?} invalid * @return {?} */ updateStatus(invalid) { if (this.ngControl.disabled || this.ngControl.isDisabled) { return; } this.invalid = !this.onceFlag && invalid && this.parent.ingoreDirty === false && !this.ngControl.dirty ? false : invalid; /** @type {?} */ const errors = this.ngControl.errors; if (errors != null && Object.keys(errors).length > 0) { /** @type {?} */ const key = Object.keys(errors)[0] || ''; /** @type {?} */ const err = this.errorData[key]; this._error = err != null ? err : this.errorData[''] || ''; } this.cdr.detectChanges(); } /** * @return {?} */ checkContent() { /** @type {?} */ const el = this.contentElement.nativeElement; /** @type {?} */ const cls = `${prefixCls}__item-empty`; if (isEmpty(el)) { this.ren.addClass(el, cls); } else { this.ren.removeClass(el, cls); } } /** * @return {?} */ ngAfterContentInit() { this.checkContent(); } /** * @return {?} */ ngOnChanges() { this.onceFlag = this.parent.firstVisual; if (this.inited) { this.setClass().bindModel(); } } /** * @return {?} */ ngAfterViewInit() { this.setClass().bindModel(); this.inited = true; if (this.onceFlag) { Promise.resolve().then((/** * @return {?} */ () => { this.updateStatus((/** @type {?} */ (this.ngControl.invalid))); this.onceFlag = false; })); } } /** * @return {?} */ ngOnDestroy() { const { unsubscribe$ } = this; unsubscribe$.next(); unsubscribe$.complete(); } } SEComponent.decorators = [ { type: Component, args: [{ selector: 'se', exportAs: 'se', template: "<div class=\"ant-form-item-label\" [class.se__nolabel]=\"!label\" [style.width.px]=\"_labelWidth\">\n <label *ngIf=\"label\" [attr.for]=\"_id\" class=\"se__label\" [ngClass]=\"{ 'ant-form-item-required': required }\">\n <span class=\"se__label-text\">\n <ng-container *nzStringTemplateOutlet=\"label\">{{ label }}</ng-container>\n </span>\n <span *ngIf=\"optional || optionalHelp\" class=\"se__label-optional\" [class.se__label-optional-no-text]=\"!optional\">\n <ng-container *nzStringTemplateOutlet=\"optional\">{{ optional }}</ng-container>\n <i *ngIf=\"optionalHelp\" nz-tooltip [nzTooltipTitle]=\"optionalHelp\" [nzTooltipColor]=\"optionalHelpColor\" nz-icon nzType=\"question-circle\"></i>\n </span>\n </label>\n</div>\n<div class=\"ant-form-item-control se__control\">\n <div class=\"ant-form-item-control-input {{ controlClass }}\">\n <div class=\"ant-form-item-control-input-content\" (cdkObserveContent)=\"checkContent()\" #contentElement>\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"ant-form-item-explain ant-form-item-explain-error\" *ngIf=\"showErr\">\n <div @helpMotion>\n <ng-container *nzStringTemplateOutlet=\"_error\">{{ _error }}</ng-container>\n </div>\n </div>\n <div *ngIf=\"extra && !compact\" class=\"ant-form-item-extra\">\n <ng-container *nzStringTemplateOutlet=\"extra\">{{ extra }}</ng-container>\n </div>\n</div>\n", host: { '[style.padding-left.px]': 'paddingValue', '[style.padding-right.px]': 'paddingValue', '[class.ant-form-item-has-error]': 'invalid', '[class.ant-form-item-with-help]': 'showErr', }, preserveWhitespaces: false, animations: [helpMotion], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ SEComponent.ctorParameters = () => [ { type: ElementRef }, { type: SEContainerComponent, decorators: [{ type: Optional }, { type: Host }] }, { type: ResponsiveService }, { type: Renderer2 }, { type: ChangeDetectorRef } ]; SEComponent.propDecorators = { ngModel: [{ type: ContentChild, args: [NgModel, { static: true },] }], formControlName: [{ type: ContentChild, args: [FormControlName, { static: true },] }], contentElement: [{ type: ViewChild, args: ['contentElement', { static: true },] }], optional: [{ type: Input }], optionalHelp: [{ type: Input }], optionalHelpColor: [{ type: Input }], error: [{ type: Input }], extra: [{ type: Input }], label: [{ type: Input }], col: [{ type: Input }], required: [{ type: Input }], controlClass: [{ type: Input }], line: [{ type: Input }], labelWidth: [{ type: Input }], id: [{ type: Input }] }; __decorate([ InputNumber(null), __metadata("design:type", Number) ], SEComponent.prototype, "col", void 0); __decorate([ InputBoolean(), __metadata("design:type", Object) ], SEComponent.prototype, "required", void 0); __decorate([ InputBoolean(null), __metadata("design:type", Boolean) ], SEComponent.prototype, "line", void 0); __decorate([ InputNumber(null), __metadata("design:type", Number) ], SEComponent.prototype, "labelWidth", void 0); if (false) { /** @type {?} */ SEComponent.ngAcceptInputType_col; /** @type {?} */ SEComponent.ngAcceptInputType_required; /** @type {?} */ SEComponent.ngAcceptInputType_line; /** @type {?} */ SEComponent.ngAcceptInputType_labelWidth; /** * @type {?} * @private */ SEComponent.prototype.el; /** * @type {?} * @private */ SEComponent.prototype.unsubscribe$; /** * @type {?} * @private */ SEComponent.prototype.ngModel; /** * @type {?} * @private */ SEComponent.prototype.formControlName; /** * @type {?} * @private */ SEComponent.prototype.contentElement; /** * @type {?} * @private */ SEComponent.prototype.clsMap; /** * @type {?} * @private */ SEComponent.prototype.inited; /** * @type {?} * @private */ SEComponent.prototype.onceFlag; /** * @type {?} * @private */ SEComponent.prototype.errorData; /** * @type {?} * @private */ SEComponent.prototype.isBindModel; /** @type {?} */ SEComponent.prototype.invalid; /** @type {?} */ SEComponent.prototype._labelWidth; /** @type {?} */ SEComponent.prototype._error; /** @type {?} */ SEComponent.prototype.optional; /** @type {?} */ SEComponent.prototype.optionalHelp; /** @type {?} */ SEComponent.prototype.optionalHelpColor; /** @type {?} */ SEComponent.prototype.extra; /** @type {?} */ SEComponent.prototype.label; /** @type {?} */ SEComponent.prototype.col; /** @type {?} */ SEComponent.prototype.required; /** @type {?} */ SEComponent.prototype.controlClass; /** @type {?} */ SEComponent.prototype.line; /** @type {?} */ SEComponent.prototype.labelWidth; /** @type {?} */ SEComponent.prototype._id; /** @type {?} */ SEComponent.prototype._autoId; /** * @type {?} * @private */ SEComponent.prototype.parent; /** * @type {?} * @private */ SEComponent.prototype.rep; /** * @type {?} * @private */ SEComponent.prototype.ren; /** * @type {?} * @private */ SEComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"se.component.js","sourceRoot":"C:/android/@ohayojp/packages/components/se/","sources":["se.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  Host,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControlName, NgModel, RequiredValidator, Validator } from '@angular/forms';\nimport { ResponsiveService } from '@ohayo/theme';\nimport { BooleanInput, InputBoolean, InputNumber, isEmpty, NumberInput } from '@ohayo/util';\nimport { helpMotion } from 'ng-zorro-antd/core/animation';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { SEContainerComponent } from './se-container.component';\nimport { SEError, SEErrorType } from './se.types';\n\nconst prefixCls = `se`;\nlet nextUniqueId = 0;\n\n@Component({\n  selector: 'se',\n  exportAs: 'se',\n  templateUrl: './se.component.html',\n  host: {\n    '[style.padding-left.px]': 'paddingValue',\n    '[style.padding-right.px]': 'paddingValue',\n    '[class.ant-form-item-has-error]': 'invalid',\n    '[class.ant-form-item-with-help]': 'showErr',\n  },\n  preserveWhitespaces: false,\n  animations: [helpMotion],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SEComponent implements OnChanges, AfterContentInit, AfterViewInit, OnDestroy {\n  static ngAcceptInputType_col: NumberInput;\n  static ngAcceptInputType_required: BooleanInput;\n  static ngAcceptInputType_line: BooleanInput;\n  static ngAcceptInputType_labelWidth: NumberInput;\n\n  private el: HTMLElement;\n  private unsubscribe$ = new Subject<void>();\n  @ContentChild(NgModel, { static: true }) private readonly ngModel: NgModel;\n  @ContentChild(FormControlName, { static: true })\n  private readonly formControlName: FormControlName;\n  @ViewChild('contentElement', { static: true }) private readonly contentElement: ElementRef;\n  private clsMap: string[] = [];\n  private inited = false;\n  private onceFlag = false;\n  private errorData: SEError = {};\n  private isBindModel = false;\n  invalid = false;\n  _labelWidth: number | null = null;\n  _error: string | TemplateRef<void>;\n\n  // #region fields\n\n  @Input() optional: string | TemplateRef<void>;\n  @Input() optionalHelp: string | TemplateRef<void>;\n  @Input() optionalHelpColor: string;\n  @Input()\n  set error(val: SEErrorType) {\n    this.errorData = typeof val === 'string' || val instanceof TemplateRef ? { '': val } : val;\n  }\n  @Input() extra: string | TemplateRef<void>;\n  @Input() label: string | TemplateRef<void>;\n  @Input() @InputNumber(null) col: number;\n  @Input() @InputBoolean() required = false;\n  @Input() controlClass: string = '';\n  @Input() @InputBoolean(null) line: boolean;\n  @Input() @InputNumber(null) labelWidth: number;\n\n  @Input()\n  set id(value: string) {\n    this._id = value;\n    this._autoId = false;\n  }\n\n  _id = `_se-${++nextUniqueId}`;\n  _autoId = true;\n\n  // #endregion\n\n  get paddingValue(): number {\n    return this.parent.gutter / 2;\n  }\n\n  get showErr(): boolean {\n    return this.invalid && !!this._error && !this.compact;\n  }\n\n  get compact(): boolean {\n    return this.parent.size === 'compact';\n  }\n\n  private get ngControl(): NgModel | FormControlName {\n    return this.ngModel || this.formControlName;\n  }\n\n  constructor(\n    el: ElementRef,\n    @Optional() @Host() private parent: SEContainerComponent,\n    private rep: ResponsiveService,\n    private ren: Renderer2,\n    private cdr: ChangeDetectorRef,\n  ) {\n    if (parent == null) {\n      throw new Error(`[se] must include 'se-container' component`);\n    }\n    this.el = el.nativeElement;\n    parent.errorNotify\n      .pipe(\n        takeUntil(this.unsubscribe$),\n        filter(w => this.inited && this.ngControl != null && this.ngControl.name === w.name),\n      )\n      .subscribe(item => {\n        this.error = item.error;\n        this.updateStatus(this.ngControl.invalid!);\n      });\n  }\n\n  private setClass(): this {\n    const { el, ren, clsMap, col, parent, cdr, line, labelWidth, rep } = this;\n    this._labelWidth = parent.nzLayout === 'horizontal' ? (labelWidth != null ? labelWidth : parent.labelWidth) : null;\n    clsMap.forEach(cls => ren.removeClass(el, cls));\n    clsMap.length = 0;\n    const repCls = parent.nzLayout === 'horizontal' ? rep.genCls(col != null ? col : parent.colInCon || parent.col) : [];\n    clsMap.push(`ant-form-item`, ...repCls, `${prefixCls}__item`);\n    if (line || parent.line) {\n      clsMap.push(`${prefixCls}__line`);\n    }\n    clsMap.forEach(cls => ren.addClass(el, cls));\n    cdr.detectChanges();\n    return this;\n  }\n\n  private bindModel(): void {\n    if (!this.ngControl || this.isBindModel) return;\n\n    this.isBindModel = true;\n    this.ngControl.statusChanges!.pipe(takeUntil(this.unsubscribe$)).subscribe(res => this.updateStatus(res === 'INVALID'));\n    if (this._autoId) {\n      const controlAccessor = this.ngControl.valueAccessor as NzSafeAny;\n      const control = (controlAccessor?.elementRef || controlAccessor?._elementRef)?.nativeElement as HTMLElement;\n      if (!!control) {\n        if (control.id) {\n          this._id = control.id;\n        } else {\n          control.id = this._id;\n        }\n      }\n    }\n    // auto required\n    if (this.required !== true) {\n      const rawValidators = (this.ngControl as NzSafeAny)?._rawValidators as Array<Validator>;\n      this.required = rawValidators.find(w => w instanceof RequiredValidator) != null;\n      this.cdr.detectChanges();\n    }\n  }\n\n  private updateStatus(invalid: boolean): void {\n    if (this.ngControl.disabled || this.ngControl.isDisabled) {\n      return;\n    }\n    this.invalid = !this.onceFlag && invalid && this.parent.ingoreDirty === false && !this.ngControl.dirty ? false : invalid;\n    const errors = this.ngControl.errors;\n    if (errors != null && Object.keys(errors).length > 0) {\n      const key = Object.keys(errors)[0] || '';\n      const err = this.errorData[key];\n      this._error = err != null ? err : this.errorData[''] || '';\n    }\n\n    this.cdr.detectChanges();\n  }\n\n  checkContent(): void {\n    const el = this.contentElement.nativeElement;\n    const cls = `${prefixCls}__item-empty`;\n    if (isEmpty(el)) {\n      this.ren.addClass(el, cls);\n    } else {\n      this.ren.removeClass(el, cls);\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.checkContent();\n  }\n\n  ngOnChanges(): void {\n    this.onceFlag = this.parent.firstVisual;\n    if (this.inited) {\n      this.setClass().bindModel();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.setClass().bindModel();\n    this.inited = true;\n    if (this.onceFlag) {\n      Promise.resolve().then(() => {\n        this.updateStatus(this.ngControl.invalid!);\n        this.onceFlag = false;\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    const { unsubscribe$ } = this;\n    unsubscribe$.next();\n    unsubscribe$.complete();\n  }\n}\n"]}