UNPKG

@ohayojp/form

Version:
246 lines 16.6 kB
/** * @fileoverview added by tsickle * Generated from: src/widget.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectorRef, Directive, HostBinding, Inject, Injector } from '@angular/core'; import { DomSanitizer } from '@angular/platform-browser'; import { takeUntil } from 'rxjs/operators'; import { SFItemComponent } from './sf-item.component'; import { SFComponent } from './sf.component'; import { di } from './utils'; /** * @abstract * @template T, UIT */ export class Widget { /** * @param {?} cd * @param {?} injector * @param {?=} sfItemComp * @param {?=} sfComp */ constructor(cd, injector, sfItemComp, sfComp) { this.cd = cd; this.injector = injector; this.sfItemComp = sfItemComp; this.sfComp = sfComp; this.showError = false; this.id = ''; this.firstVisual = false; } /** * @return {?} */ get cls() { return this.ui.class || ''; } /** * @return {?} */ get disabled() { if (this.schema.readOnly === true || (/** @type {?} */ (this.sfComp)).disabled) { return true; } return null; } /** * @return {?} */ get l() { return (/** @type {?} */ (this.formProperty.root.widget.sfComp)).locale; } /** * @return {?} */ get oh() { return (/** @type {?} */ (this.ui.optionalHelp)); } /** * @return {?} */ get dom() { return this.injector.get(DomSanitizer); } /** * @return {?} */ get cleanValue() { var _a; return (/** @type {?} */ ((_a = this.sfComp) === null || _a === void 0 ? void 0 : _a.cleanValue)); } /** * @return {?} */ ngAfterViewInit() { this.formProperty.errorsChanges.pipe(takeUntil((/** @type {?} */ (this.sfItemComp)).unsubscribe$)).subscribe((/** * @param {?} errors * @return {?} */ (errors) => { if (errors == null) return; di(this.ui, 'errorsChanges', this.formProperty.path, errors); // 不显示首次校验视觉 if (this.firstVisual) { this.showError = errors.length > 0; this.error = this.showError ? ((/** @type {?} */ (errors[0].message))) : ''; this.cd.detectChanges(); } this.firstVisual = true; })); this.afterViewInit(); } /** * @param {?} value * @return {?} */ setValue(value) { this.formProperty.setValue(value, false); di(this.ui, 'valueChanges', this.formProperty.path, this.formProperty); } /** * @return {?} */ get value() { return this.formProperty.value; } /** * @param {?=} onlySelf * @return {?} */ detectChanges(onlySelf = false) { if (onlySelf) { this.cd.markForCheck(); } else { this.formProperty.root.widget.cd.markForCheck(); } } } Widget.decorators = [ { type: Directive } ]; /** @nocollapse */ Widget.ctorParameters = () => [ { type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] }, { type: Injector, decorators: [{ type: Inject, args: [Injector,] }] }, { type: SFItemComponent, decorators: [{ type: Inject, args: [SFItemComponent,] }] }, { type: SFComponent, decorators: [{ type: Inject, args: [SFComponent,] }] } ]; Widget.propDecorators = { cls: [{ type: HostBinding, args: ['class',] }] }; if (false) { /** @type {?} */ Widget.prototype.formProperty; /** @type {?} */ Widget.prototype.error; /** @type {?} */ Widget.prototype.showError; /** @type {?} */ Widget.prototype.id; /** @type {?} */ Widget.prototype.schema; /** @type {?} */ Widget.prototype.ui; /** @type {?} */ Widget.prototype.firstVisual; /** @type {?} */ Widget.prototype.cd; /** @type {?} */ Widget.prototype.injector; /** @type {?} */ Widget.prototype.sfItemComp; /** @type {?} */ Widget.prototype.sfComp; /** * @abstract * @param {?} value * @return {?} */ Widget.prototype.reset = function (value) { }; /** * @abstract * @return {?} */ Widget.prototype.afterViewInit = function () { }; } export class ControlWidget extends Widget { /** * @param {?} _value * @return {?} */ reset(_value) { } /** * @return {?} */ afterViewInit() { } } ControlWidget.decorators = [ { type: Directive } ]; /** * @template UIT */ export class ControlUIWidget extends Widget { /** * @param {?} _value * @return {?} */ reset(_value) { } /** * @return {?} */ afterViewInit() { } } ControlUIWidget.decorators = [ { type: Directive } ]; export class ArrayLayoutWidget extends Widget { /** * @param {?} _value * @return {?} */ reset(_value) { } /** * @return {?} */ afterViewInit() { } /** * @return {?} */ ngAfterViewInit() { this.formProperty.errorsChanges.pipe(takeUntil((/** @type {?} */ (this.sfItemComp)).unsubscribe$)).subscribe((/** * @return {?} */ () => this.cd.detectChanges())); } } ArrayLayoutWidget.decorators = [ { type: Directive } ]; export class ObjectLayoutWidget extends Widget { /** * @param {?} _value * @return {?} */ reset(_value) { } /** * @return {?} */ afterViewInit() { } /** * @return {?} */ ngAfterViewInit() { this.formProperty.errorsChanges.pipe(takeUntil((/** @type {?} */ (this.sfItemComp)).unsubscribe$)).subscribe((/** * @return {?} */ () => this.cd.detectChanges())); } } ObjectLayoutWidget.decorators = [ { type: Directive } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.js","sourceRoot":"../../../../packages/form/","sources":["src/widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Directive, HostBinding, Inject, Injector } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { LocaleData } from '@ohayojp/theme';\nimport { takeUntil } from 'rxjs/operators';\nimport { ErrorData } from './errors';\nimport { SFValue } from './interface';\nimport { ArrayProperty } from './model/array.property';\nimport { FormProperty } from './model/form.property';\nimport { ObjectProperty } from './model/object.property';\nimport { SFSchema } from './schema';\nimport { SFOptionalHelp, SFUISchemaItem } from './schema/ui';\nimport { SFItemComponent } from './sf-item.component';\nimport { SFComponent } from './sf.component';\nimport { di } from './utils';\nimport { SFArrayWidgetSchema, SFObjectWidgetSchema } from './widgets';\n\n@Directive()\nexport abstract class Widget<T extends FormProperty, UIT extends SFUISchemaItem> implements AfterViewInit {\n  formProperty: T;\n  error: string;\n  showError = false;\n  id = '';\n  schema: SFSchema;\n  ui: UIT;\n  firstVisual = false;\n\n  @HostBinding('class')\n  get cls(): string | string[] {\n    return this.ui.class || '';\n  }\n\n  get disabled(): boolean | null {\n    if (this.schema.readOnly === true || this.sfComp!.disabled) {\n      return true;\n    }\n\n    return null;\n  }\n\n  get l(): LocaleData {\n    return this.formProperty.root.widget.sfComp!.locale;\n  }\n\n  get oh(): SFOptionalHelp {\n    return this.ui.optionalHelp as SFOptionalHelp;\n  }\n\n  get dom(): DomSanitizer {\n    return this.injector.get(DomSanitizer);\n  }\n\n  get cleanValue(): boolean {\n    return this.sfComp?.cleanValue!;\n  }\n\n  constructor(\n    @Inject(ChangeDetectorRef) public readonly cd: ChangeDetectorRef,\n    @Inject(Injector) public readonly injector: Injector,\n    @Inject(SFItemComponent) public readonly sfItemComp?: SFItemComponent,\n    @Inject(SFComponent) public readonly sfComp?: SFComponent,\n  ) { }\n\n  ngAfterViewInit(): void {\n    this.formProperty.errorsChanges.pipe(takeUntil(this.sfItemComp!.unsubscribe$)).subscribe((errors: ErrorData[] | null) => {\n      if (errors == null) return;\n      di(this.ui, 'errorsChanges', this.formProperty.path, errors);\n\n      // 不显示首次校验视觉\n      if (this.firstVisual) {\n        this.showError = errors.length > 0;\n        this.error = this.showError ? (errors[0].message as string) : '';\n\n        this.cd.detectChanges();\n      }\n      this.firstVisual = true;\n    });\n    this.afterViewInit();\n  }\n\n  setValue(value: SFValue): void {\n    this.formProperty.setValue(value, false);\n    di(this.ui, 'valueChanges', this.formProperty.path, this.formProperty);\n  }\n\n  get value(): any {\n    return this.formProperty.value;\n  }\n\n  detectChanges(onlySelf: boolean = false): void {\n    if (onlySelf) {\n      this.cd.markForCheck();\n    } else {\n      this.formProperty.root.widget.cd.markForCheck();\n    }\n  }\n\n  abstract reset(value: SFValue): void;\n\n  abstract afterViewInit(): void;\n}\n\n@Directive()\nexport class ControlWidget extends Widget<FormProperty, SFUISchemaItem> {\n  reset(_value: SFValue): void { }\n  afterViewInit(): void { }\n}\n\n@Directive()\nexport class ControlUIWidget<UIT extends SFUISchemaItem> extends Widget<FormProperty, UIT> {\n  reset(_value: SFValue): void { }\n  afterViewInit(): void { }\n}\n\n@Directive()\nexport class ArrayLayoutWidget extends Widget<ArrayProperty, SFArrayWidgetSchema> implements AfterViewInit {\n  reset(_value: SFValue): void { }\n  afterViewInit(): void { }\n\n  ngAfterViewInit(): void {\n    this.formProperty.errorsChanges.pipe(takeUntil(this.sfItemComp!.unsubscribe$)).subscribe(() => this.cd.detectChanges());\n  }\n}\n\n@Directive()\nexport class ObjectLayoutWidget extends Widget<ObjectProperty, SFObjectWidgetSchema> implements AfterViewInit {\n  reset(_value: SFValue): void { }\n  afterViewInit(): void { }\n\n  ngAfterViewInit(): void {\n    this.formProperty.errorsChanges.pipe(takeUntil(this.sfItemComp!.unsubscribe$)).subscribe(() => this.cd.detectChanges());\n  }\n}\n"]}