@ohayojp.com/components
Version:
Common business components of ohayojp.
419 lines • 33.4 kB
JavaScript
/**
* @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"]}