From a46048c8eaa7a872cf4c82e86628068b60f39aa7 Mon Sep 17 00:00:00 2001 From: cipchk Date: Tue, 19 Sep 2023 18:38:21 +0800 Subject: [PATCH] fix(form): fix `visibleIf` to correctly trigger `reset` - close https://github.com/ng-alain/ng-alain/issues/2419 --- packages/form/src/model/array.property.ts | 5 ++++- packages/form/src/model/form.property.factory.ts | 8 ++++++++ packages/form/src/model/form.property.ts | 11 +++++++++-- packages/form/src/model/object.property.ts | 5 ++++- packages/form/src/sf.component.ts | 6 ++++-- .../widgets/autocomplete/autocomplete.widget.spec.ts | 2 +- .../form/src/widgets/checkbox/checkbox.widget.spec.ts | 5 +++-- 7 files changed, 33 insertions(+), 9 deletions(-) diff --git a/packages/form/src/model/array.property.ts b/packages/form/src/model/array.property.ts index a2016ba337..3b5bd5821c 100644 --- a/packages/form/src/model/array.property.ts +++ b/packages/form/src/model/array.property.ts @@ -1,3 +1,5 @@ +import { Injector } from '@angular/core'; + import { AlainSFConfig } from '@delon/util/config'; import { deepCopy } from '@delon/util/other'; import type { NzSafeAny } from 'ng-zorro-antd/core/types'; @@ -13,6 +15,7 @@ import { SchemaValidatorFactory } from '../validator.factory'; export class ArrayProperty extends PropertyGroup { constructor( + injector: Injector, private formPropertyFactory: FormPropertyFactory, schemaValidatorFactory: SchemaValidatorFactory, schema: SFSchema, @@ -22,7 +25,7 @@ export class ArrayProperty extends PropertyGroup { path: string, options: AlainSFConfig ) { - super(schemaValidatorFactory, schema, ui, formData, parent, path, options); + super(injector, schemaValidatorFactory, schema, ui, formData, parent, path, options); this.properties = []; } diff --git a/packages/form/src/model/form.property.factory.ts b/packages/form/src/model/form.property.factory.ts index 4bd5293eb5..e40c379624 100644 --- a/packages/form/src/model/form.property.factory.ts +++ b/packages/form/src/model/form.property.factory.ts @@ -1,3 +1,5 @@ +import { Injector } from '@angular/core'; + import { AlainConfigService, AlainSFConfig } from '@delon/util/config'; import { ArrayProperty } from './array.property'; @@ -16,6 +18,7 @@ import { SchemaValidatorFactory } from '../validator.factory'; export class FormPropertyFactory { private options: AlainSFConfig; constructor( + private injector: Injector, private schemaValidatorFactory: SchemaValidatorFactory, cogSrv: AlainConfigService ) { @@ -78,6 +81,7 @@ export class FormPropertyFactory { case 'integer': case 'number': newProperty = new NumberProperty( + this.injector, this.schemaValidatorFactory, schema, ui, @@ -89,6 +93,7 @@ export class FormPropertyFactory { break; case 'string': newProperty = new StringProperty( + this.injector, this.schemaValidatorFactory, schema, ui, @@ -100,6 +105,7 @@ export class FormPropertyFactory { break; case 'boolean': newProperty = new BooleanProperty( + this.injector, this.schemaValidatorFactory, schema, ui, @@ -111,6 +117,7 @@ export class FormPropertyFactory { break; case 'object': newProperty = new ObjectProperty( + this.injector, this, this.schemaValidatorFactory, schema, @@ -123,6 +130,7 @@ export class FormPropertyFactory { break; case 'array': newProperty = new ArrayProperty( + this.injector, this, this.schemaValidatorFactory, schema, diff --git a/packages/form/src/model/form.property.ts b/packages/form/src/model/form.property.ts index 92e83d9964..ab80a34a39 100644 --- a/packages/form/src/model/form.property.ts +++ b/packages/form/src/model/form.property.ts @@ -1,4 +1,5 @@ -import { BehaviorSubject, combineLatest, Observable, distinctUntilChanged, map } from 'rxjs'; +import { Injector, NgZone } from '@angular/core'; +import { BehaviorSubject, combineLatest, Observable, distinctUntilChanged, map, take } from 'rxjs'; import { AlainSFConfig } from '@delon/util/config'; import { NzFormStatusService } from 'ng-zorro-antd/core/form'; @@ -33,6 +34,7 @@ export abstract class FormProperty { propertyId?: string; constructor( + private injector: Injector, schemaValidatorFactory: SchemaValidatorFactory, schema: SFSchema, ui: SFUISchema | SFUISchemaItem, @@ -312,7 +314,12 @@ export abstract class FormProperty { this._visibilityChanges.next(visible); // 渲染时需要重新触发 reset if (visible) { - this.resetValue(this.value, true); + this.injector + .get(NgZone) + .onStable.pipe(take(1)) + .subscribe(() => { + this.resetValue(this.value, true); + }); } return this; } diff --git a/packages/form/src/model/object.property.ts b/packages/form/src/model/object.property.ts index 73fdc7449b..3e26585068 100644 --- a/packages/form/src/model/object.property.ts +++ b/packages/form/src/model/object.property.ts @@ -1,3 +1,5 @@ +import { Injector } from '@angular/core'; + import { AlainSFConfig } from '@delon/util/config'; import type { NzSafeAny } from 'ng-zorro-antd/core/types'; @@ -17,6 +19,7 @@ export class ObjectProperty extends PropertyGroup { } constructor( + injector: Injector, private formPropertyFactory: FormPropertyFactory, schemaValidatorFactory: SchemaValidatorFactory, schema: SFSchema, @@ -26,7 +29,7 @@ export class ObjectProperty extends PropertyGroup { path: string, options: AlainSFConfig ) { - super(schemaValidatorFactory, schema, ui, formData, parent, path, options); + super(injector, schemaValidatorFactory, schema, ui, formData, parent, path, options); this.createProperties(); } diff --git a/packages/form/src/sf.component.ts b/packages/form/src/sf.component.ts index d26e160a17..21f6b9a650 100644 --- a/packages/form/src/sf.component.ts +++ b/packages/form/src/sf.component.ts @@ -5,6 +5,7 @@ import { Component, EventEmitter, Inject, + Injector, Input, OnChanges, OnDestroy, @@ -41,10 +42,11 @@ import { SchemaValidatorFactory } from './validator.factory'; import { WidgetFactory } from './widget.factory'; export function useFactory( + injector: Injector, schemaValidatorFactory: SchemaValidatorFactory, cogSrv: AlainConfigService ): FormPropertyFactory { - return new FormPropertyFactory(schemaValidatorFactory, cogSrv); + return new FormPropertyFactory(injector, schemaValidatorFactory, cogSrv); } @Component({ @@ -56,7 +58,7 @@ export function useFactory( { provide: FormPropertyFactory, useFactory, - deps: [SchemaValidatorFactory, AlainConfigService] + deps: [Injector, SchemaValidatorFactory, AlainConfigService] }, TerminatorService ], diff --git a/packages/form/src/widgets/autocomplete/autocomplete.widget.spec.ts b/packages/form/src/widgets/autocomplete/autocomplete.widget.spec.ts index 4da11bcb52..dc67d71d23 100644 --- a/packages/form/src/widgets/autocomplete/autocomplete.widget.spec.ts +++ b/packages/form/src/widgets/autocomplete/autocomplete.widget.spec.ts @@ -130,7 +130,7 @@ describe('form: widget: autocomplete', () => { } } }) - .time(100) + .dc(100) .typeChar(typeValue) .checkCount('nz-auto-option', config.uiEmailSuffixes!.length) .click('nz-auto-option') diff --git a/packages/form/src/widgets/checkbox/checkbox.widget.spec.ts b/packages/form/src/widgets/checkbox/checkbox.widget.spec.ts index 6ebb698bf1..f40fe0558e 100644 --- a/packages/form/src/widgets/checkbox/checkbox.widget.spec.ts +++ b/packages/form/src/widgets/checkbox/checkbox.widget.spec.ts @@ -37,7 +37,7 @@ describe('form: widget: checkbox', () => { expect(page.getEl('.ant-checkbox-checked').nextSibling!.textContent).toBe('item2'); })); - it('#visibleIf', () => { + it('#visibleIf', fakeAsync(() => { page .newSchema({ properties: { @@ -47,8 +47,9 @@ describe('form: widget: checkbox', () => { }) .checkCount(chekcWrapCls, 1) .click(chekcWrapCls) + .dc(100) .checkCount(chekcWrapCls, 2); - }); + })); it('should be ingore title when not array data', () => { const title = 'test';