@recursyve/nice-ui-kit.v2 15.0.0-beta.130 → 15.0.0-beta.131

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -33,12 +33,7 @@ export class TranslationFormComponent {
33
33
  }
34
34
  set disabled(value) {
35
35
  this._disabled = coerceBooleanProperty(value);
36
- if (this._disabled) {
37
- this.currentControl.disable({ emitEvent: false });
38
- }
39
- else {
40
- this.currentControl.enable({ emitEvent: false });
41
- }
36
+ this.handleDisabledState();
42
37
  this.stateChanges.next();
43
38
  }
44
39
  set placeholder(placeholder) {
@@ -117,6 +112,7 @@ export class TranslationFormComponent {
117
112
  }
118
113
  setLanguage(language) {
119
114
  this.currentControl = this.formGroup.get(language);
115
+ this.handleDisabledState();
120
116
  this.changeDetectorRef.markForCheck();
121
117
  }
122
118
  setupFormControls(languages) {
@@ -130,6 +126,15 @@ export class TranslationFormComponent {
130
126
  this.formGroup.removeControl(key);
131
127
  }
132
128
  this.currentControl = this.formGroup.get(languages[0]);
129
+ this.handleDisabledState();
130
+ }
131
+ handleDisabledState() {
132
+ if (this._disabled) {
133
+ this.currentControl?.disable({ emitEvent: false });
134
+ }
135
+ else {
136
+ this.currentControl?.enable({ emitEvent: false });
137
+ }
133
138
  }
134
139
  }
135
140
  TranslationFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TranslationFormComponent, deps: [{ token: i1.ControlContainer }, { token: i2.TranslationContextDirective }, { token: i3.NiceTranslationFormService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
@@ -162,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
162
167
  type: HostBinding,
163
168
  args: ["attr.aria-describedby"]
164
169
  }] } });
165
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translation-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/translation-form/components/translation-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from \"@angular/cdk/coercion\";\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n} from \"@angular/core\";\nimport {\n    AbstractControlDirective,\n    ControlContainer,\n    ControlValueAccessor,\n    FormControl,\n    FormGroup,\n    NgControl,\n    Validators,\n} from \"@angular/forms\";\nimport { MatFormFieldControl } from \"@angular/material/form-field\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport * as uuid from \"uuid\";\nimport { TranslationContextDirective } from \"../directives/translation-context.directive\";\nimport { NiceTranslationFormService } from \"../providers/nice-translation-form.service\";\n\n@Component({\n    template: ``,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport abstract class TranslationFormComponent\n    implements\n        OnInit,\n        OnDestroy,\n        MatFormFieldControl<string>,\n        ControlValueAccessor\n{\n    @HostBinding(\"class\")\n    public get classList(): any {\n        return {\n            \"w-full\": true\n        };\n    }\n\n    @HostBinding(\"class.floating\")\n    public get shouldLabelFloat(): boolean {\n        return this.floating || !this.empty;\n    }\n\n    @Input()\n    public set required(req) {\n        this._required = coerceBooleanProperty(req);\n        this.stateChanges.next();\n    }\n\n    public get required(): boolean {\n        return (\n            this._required ??\n            this.ngControl?.control?.hasValidator(Validators.required) ??\n            false\n        );\n    }\n\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n\n    public set disabled(value: boolean) {\n        this._disabled = coerceBooleanProperty(value);\n\n        if (this._disabled) {\n            this.currentControl.disable({ emitEvent: false });\n        } else {\n            this.currentControl.enable({ emitEvent: false });\n        }\n\n        this.stateChanges.next();\n    }\n\n    @Input()\n    public set placeholder(placeholder: string) {\n        this._placeholder = placeholder;\n        this.stateChanges.next();\n    }\n\n    public get placeholder(): string {\n        return this._placeholder;\n    }\n\n    public set value(value: any) {\n        if (value === this._value) {\n            return;\n        }\n\n        this._value = value;\n        this.propagate(this._value);\n    }\n\n    public get value(): any {\n        return this._value;\n    }\n\n    public get empty(): boolean {\n        const emptyControlValue =\n            !this.currentControl?.value || !this.currentControl.value.length;\n\n        const emptyValue =\n            !this._value ||\n            (typeof this._value === \"string\" && !this._value.length);\n\n        return emptyControlValue && emptyValue;\n    }\n\n    public get errorState(): boolean {\n        return this.ngControl\n            ? this.ngControl.touched && this.ngControl.invalid\n            : false;\n    }\n\n    constructor(\n        private container: ControlContainer,\n        private context: TranslationContextDirective,\n        private service: NiceTranslationFormService,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {}\n\n    @Input()\n    public floating = true;\n\n    @Input()\n    public maxLength = 524288; // The maximum number of characters allowed in the <input> element. Default value is 524288\n\n    @HostBinding()\n    public id: string = uuid.v4();\n\n    @HostBinding(\"attr.aria-describedby\")\n    public describedBy = \"\";\n\n    public formGroup: FormGroup;\n    public currentControl?: FormControl;\n    public stateChanges = new Subject<void>();\n    public ngControl: AbstractControlDirective | NgControl;\n    public focused: boolean;\n    public controlType = \"translationForm\";\n\n    private _unsubscribeAll$ = new Subject<void>();\n    private _required: boolean;\n    private _disabled = false;\n    private _placeholder: string;\n    private _value: any;\n\n    public readonly autofilled: boolean;\n    public readonly userAriaDescribedBy: string;\n\n    public propagate: (value: string) => void = () => {};\n\n    public onContainerClick(event: MouseEvent): void {}\n\n    public setDescribedByIds(ids: string[]): void {\n        this.describedBy = ids.join(\" \");\n    }\n\n    public registerOnChange(fn: any): void {\n        this.propagate = fn;\n    }\n\n    public registerOnTouched(fn: any): void {}\n\n    public writeValue(value: any): void {\n        this._value = value;\n    }\n\n    public ngOnInit(): void {\n        this.formGroup = this.container.control as FormGroup;\n\n        this.service.languages$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((languages) => {\n                if (!languages?.length) {\n                    return;\n                }\n\n                this.setupFormControls(languages);\n            });\n\n        this.context.activeLanguage$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((activeLanguage) => {\n                this.setLanguage(activeLanguage);\n            });\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribeAll$.next();\n        this._unsubscribeAll$.complete();\n    }\n\n    public setLanguage(language: string): void {\n        this.currentControl = this.formGroup.get(language) as FormControl;\n        this.changeDetectorRef.markForCheck();\n    }\n\n    private setupFormControls(languages: string[]): void {\n        for (const language of languages) {\n            if (!this.formGroup.controls[language]) {\n                this.formGroup.addControl(language, new FormControl(\"\"));\n            }\n        }\n\n        const controlToRemove = Object.keys(this.formGroup.controls).filter(\n            (key) => !languages.includes(key)\n        );\n\n        for (const key of controlToRemove) {\n            this.formGroup.removeControl(key);\n        }\n\n        this.currentControl = this.formGroup.get(languages[0]) as FormControl;\n    }\n}\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translation-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/translation-form/components/translation-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from \"@angular/cdk/coercion\";\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n} from \"@angular/core\";\nimport {\n    AbstractControlDirective,\n    ControlContainer,\n    ControlValueAccessor,\n    FormControl,\n    FormGroup,\n    NgControl,\n    Validators,\n} from \"@angular/forms\";\nimport { MatFormFieldControl } from \"@angular/material/form-field\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport * as uuid from \"uuid\";\nimport { TranslationContextDirective } from \"../directives/translation-context.directive\";\nimport { NiceTranslationFormService } from \"../providers/nice-translation-form.service\";\n\n@Component({\n    template: ``,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport abstract class TranslationFormComponent\n    implements\n        OnInit,\n        OnDestroy,\n        MatFormFieldControl<string>,\n        ControlValueAccessor\n{\n    @HostBinding(\"class\")\n    public get classList(): any {\n        return {\n            \"w-full\": true\n        };\n    }\n\n    @HostBinding(\"class.floating\")\n    public get shouldLabelFloat(): boolean {\n        return this.floating || !this.empty;\n    }\n\n    @Input()\n    public set required(req) {\n        this._required = coerceBooleanProperty(req);\n        this.stateChanges.next();\n    }\n\n    public get required(): boolean {\n        return (\n            this._required ??\n            this.ngControl?.control?.hasValidator(Validators.required) ??\n            false\n        );\n    }\n\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n\n    public set disabled(value: boolean) {\n        this._disabled = coerceBooleanProperty(value);\n\n        this.handleDisabledState();\n        this.stateChanges.next();\n    }\n\n    @Input()\n    public set placeholder(placeholder: string) {\n        this._placeholder = placeholder;\n        this.stateChanges.next();\n    }\n\n    public get placeholder(): string {\n        return this._placeholder;\n    }\n\n    public set value(value: any) {\n        if (value === this._value) {\n            return;\n        }\n\n        this._value = value;\n        this.propagate(this._value);\n    }\n\n    public get value(): any {\n        return this._value;\n    }\n\n    public get empty(): boolean {\n        const emptyControlValue =\n            !this.currentControl?.value || !this.currentControl.value.length;\n\n        const emptyValue =\n            !this._value ||\n            (typeof this._value === \"string\" && !this._value.length);\n\n        return emptyControlValue && emptyValue;\n    }\n\n    public get errorState(): boolean {\n        return this.ngControl\n            ? this.ngControl.touched && this.ngControl.invalid\n            : false;\n    }\n\n    constructor(\n        private container: ControlContainer,\n        private context: TranslationContextDirective,\n        private service: NiceTranslationFormService,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {}\n\n    @Input()\n    public floating = true;\n\n    @Input()\n    public maxLength = 524288; // The maximum number of characters allowed in the <input> element. Default value is 524288\n\n    @HostBinding()\n    public id: string = uuid.v4();\n\n    @HostBinding(\"attr.aria-describedby\")\n    public describedBy = \"\";\n\n    public formGroup: FormGroup;\n    public currentControl?: FormControl;\n    public stateChanges = new Subject<void>();\n    public ngControl: AbstractControlDirective | NgControl;\n    public focused: boolean;\n    public controlType = \"translationForm\";\n\n    private _unsubscribeAll$ = new Subject<void>();\n    private _required: boolean;\n    private _disabled = false;\n    private _placeholder: string;\n    private _value: any;\n\n    public readonly autofilled: boolean;\n    public readonly userAriaDescribedBy: string;\n\n    public propagate: (value: string) => void = () => {};\n\n    public onContainerClick(event: MouseEvent): void {}\n\n    public setDescribedByIds(ids: string[]): void {\n        this.describedBy = ids.join(\" \");\n    }\n\n    public registerOnChange(fn: any): void {\n        this.propagate = fn;\n    }\n\n    public registerOnTouched(fn: any): void {}\n\n    public writeValue(value: any): void {\n        this._value = value;\n    }\n\n    public ngOnInit(): void {\n        this.formGroup = this.container.control as FormGroup;\n\n        this.service.languages$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((languages) => {\n                if (!languages?.length) {\n                    return;\n                }\n\n                this.setupFormControls(languages);\n            });\n\n        this.context.activeLanguage$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((activeLanguage) => {\n                this.setLanguage(activeLanguage);\n            });\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribeAll$.next();\n        this._unsubscribeAll$.complete();\n    }\n\n    public setLanguage(language: string): void {\n        this.currentControl = this.formGroup.get(language) as FormControl;\n        this.handleDisabledState();\n        this.changeDetectorRef.markForCheck();\n    }\n\n    private setupFormControls(languages: string[]): void {\n        for (const language of languages) {\n            if (!this.formGroup.controls[language]) {\n                this.formGroup.addControl(language, new FormControl(\"\"));\n            }\n        }\n\n        const controlToRemove = Object.keys(this.formGroup.controls).filter(\n            (key) => !languages.includes(key)\n        );\n\n        for (const key of controlToRemove) {\n            this.formGroup.removeControl(key);\n        }\n\n        this.currentControl = this.formGroup.get(languages[0]) as FormControl;\n        this.handleDisabledState();\n    }\n\n    private handleDisabledState(): void {\n        if (this._disabled) {\n            this.currentControl?.disable({ emitEvent: false });\n        } else {\n            this.currentControl?.enable({ emitEvent: false });\n        }\n    }\n}\n"]}
@@ -2737,13 +2737,13 @@ class NiceAsyncTypeaheadService {
2737
2737
  var _a;
2738
2738
  (_a = this.requestsSubscription$) === null || _a === void 0 ? void 0 : _a.unsubscribe();
2739
2739
  }
2740
- initialize(resource, options) {
2740
+ initialize(resource) {
2741
2741
  return __awaiter(this, void 0, void 0, function* () {
2742
2742
  const { initialized } = this.state$.getValue();
2743
2743
  if (initialized) {
2744
2744
  return;
2745
2745
  }
2746
- return this.search(resource, "", options);
2746
+ return this.search(resource, "");
2747
2747
  });
2748
2748
  }
2749
2749
  sendRequest(request) {
@@ -2775,15 +2775,15 @@ class NiceAsyncTypeaheadService {
2775
2775
  this.state$.next(Object.assign(Object.assign({}, this.state$.value), { loading: false, loadingPage: false }));
2776
2776
  }));
2777
2777
  }
2778
- search(resource, searchQuery, options) {
2778
+ search(resource, searchQuery) {
2779
2779
  this.requests$.next({
2780
2780
  resource,
2781
2781
  searchQuery,
2782
- searchOptions: options,
2782
+ searchOptions: this.getSearchOptions(),
2783
2783
  page: 0
2784
2784
  });
2785
2785
  }
2786
- loadMore(resource, options) {
2786
+ loadMore(resource) {
2787
2787
  const { loadingPage, isLastPage } = this.state$.getValue();
2788
2788
  if (loadingPage || isLastPage) {
2789
2789
  return;
@@ -2793,7 +2793,7 @@ class NiceAsyncTypeaheadService {
2793
2793
  resource,
2794
2794
  page,
2795
2795
  searchQuery,
2796
- searchOptions: options,
2796
+ searchOptions: this.getSearchOptions(),
2797
2797
  });
2798
2798
  }
2799
2799
  getActive() {
@@ -2802,10 +2802,16 @@ class NiceAsyncTypeaheadService {
2802
2802
  getInitialized() {
2803
2803
  return this.state$.value.initialized;
2804
2804
  }
2805
+ getSearchOptions() {
2806
+ return this.state$.value.searchOptions;
2807
+ }
2808
+ setSearchOptions(searchOptions) {
2809
+ this.state$.next(Object.assign(Object.assign({}, this.state$.value), { searchOptions }));
2810
+ }
2805
2811
  setActive(entity) {
2806
2812
  this.state$.next(Object.assign(Object.assign({}, this.state$.value), { active: entity !== null && entity !== void 0 ? entity : null }));
2807
2813
  }
2808
- setActiveId(resource, id, options) {
2814
+ setActiveId(resource, id) {
2809
2815
  return __awaiter(this, void 0, void 0, function* () {
2810
2816
  if (!id) {
2811
2817
  return;
@@ -2821,21 +2827,22 @@ class NiceAsyncTypeaheadService {
2821
2827
  this.state$.next(Object.assign(Object.assign({}, this.state$.value), { items: [localItem], active: localItem, page: 0, isLastPage: false }));
2822
2828
  return;
2823
2829
  }
2824
- const entity = yield api.getById(id, options);
2830
+ const entity = yield api.getById(id, this.getSearchOptions());
2825
2831
  if (!entity) {
2826
2832
  return;
2827
2833
  }
2828
2834
  this.state$.next(Object.assign(Object.assign({}, this.state$.value), { items: [entity], active: entity, page: 0, isLastPage: false }));
2829
2835
  }
2830
- catch (_a) { }
2836
+ catch (_a) {
2837
+ }
2831
2838
  finally {
2832
2839
  this.state$.next(Object.assign(Object.assign({}, this.state$.value), { loading: false }));
2833
2840
  }
2834
2841
  });
2835
2842
  }
2836
- reloadActive(resource, options) {
2843
+ reloadActive(resource) {
2837
2844
  var _a;
2838
- return this.setActiveId(resource, (_a = this.state$.value.active) === null || _a === void 0 ? void 0 : _a.id, options);
2845
+ return this.setActiveId(resource, (_a = this.state$.value.active) === null || _a === void 0 ? void 0 : _a.id);
2839
2846
  }
2840
2847
  reloadFilteredItems() {
2841
2848
  // TODO: Use a better way to trigger the items$ observable
@@ -2981,41 +2988,48 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
2981
2988
  this._disabled = false;
2982
2989
  this.id = uuid.v4();
2983
2990
  this.describedBy = "";
2991
+ this.componentInitialized = false;
2984
2992
  this.propagate = () => { };
2985
2993
  if (this.ngControl) {
2986
2994
  this.ngControl.valueAccessor = this;
2987
2995
  }
2988
2996
  }
2989
2997
  ngOnInit() {
2990
- this.service.listenForRequest();
2991
- if (this.ngControl) {
2992
- if (this.ngControl.disabled) {
2993
- this.searchControl.disable({ emitEvent: false });
2994
- }
2995
- this.ngControl.statusChanges.subscribe((status) => {
2996
- this.disabled = status === "DISABLED";
2997
- if (this._disabled) {
2998
+ return __awaiter(this, void 0, void 0, function* () {
2999
+ this.service.listenForRequest();
3000
+ if (this.ngControl) {
3001
+ if (this.ngControl.disabled) {
2998
3002
  this.searchControl.disable({ emitEvent: false });
2999
3003
  }
3000
- else {
3001
- this.searchControl.enable({ emitEvent: false });
3002
- }
3003
- });
3004
- }
3005
- if (this.filterFn) {
3006
- this.service.setFilterFn(this.filterFn);
3007
- }
3008
- if (this.searchControl) {
3009
- this.valueChangesSub$ = this.searchControl.valueChanges.pipe(debounceTime(500), distinctUntilChanged()).subscribe(text => {
3010
- if (typeof text !== "string") {
3011
- return;
3012
- }
3013
- this.service.search(this.resource, text, this.searchOptions);
3014
- });
3015
- }
3016
- if (this.preloadResource) {
3017
- this.service.search(this.resource, "", this.searchOptions);
3018
- }
3004
+ this.ngControl.statusChanges.subscribe((status) => {
3005
+ this.disabled = status === "DISABLED";
3006
+ if (this._disabled) {
3007
+ this.searchControl.disable({ emitEvent: false });
3008
+ }
3009
+ else {
3010
+ this.searchControl.enable({ emitEvent: false });
3011
+ }
3012
+ });
3013
+ }
3014
+ if (this.filterFn) {
3015
+ this.service.setFilterFn(this.filterFn);
3016
+ }
3017
+ if (this.searchControl) {
3018
+ this.valueChangesSub$ = this.searchControl.valueChanges.pipe(debounceTime(500), distinctUntilChanged()).subscribe(text => {
3019
+ if (typeof text !== "string") {
3020
+ return;
3021
+ }
3022
+ this.service.search(this.resource, text);
3023
+ });
3024
+ }
3025
+ if (this.preloadResource) {
3026
+ this.service.search(this.resource, "");
3027
+ }
3028
+ this.componentInitialized = true;
3029
+ if (this.initialWriteValue !== undefined) {
3030
+ yield this.writeValue(this.initialWriteValue);
3031
+ }
3032
+ });
3019
3033
  }
3020
3034
  ngOnDestroy() {
3021
3035
  this.service.closeRequestSubscription();
@@ -3024,8 +3038,9 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
3024
3038
  ngOnChanges(changes) {
3025
3039
  if ("searchOptions" in changes) {
3026
3040
  const change = changes.searchOptions;
3041
+ this.service.setSearchOptions(change.currentValue);
3027
3042
  if (!change.isFirstChange() && change.currentValue !== change.previousValue && this.autoReload) {
3028
- this.service.search(this.resource, "", change.currentValue);
3043
+ this.service.search(this.resource, "");
3029
3044
  this.service.items$.pipe(take(1)).subscribe(() => this.checkIfValueStillExist());
3030
3045
  }
3031
3046
  }
@@ -3044,6 +3059,10 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
3044
3059
  }
3045
3060
  writeValue(value) {
3046
3061
  return __awaiter(this, void 0, void 0, function* () {
3062
+ if (!this.componentInitialized) {
3063
+ this.initialWriteValue = value;
3064
+ return;
3065
+ }
3047
3066
  if (this._value === value || (isNullOrUndefined(this._value) && isNullOrUndefined(value))) {
3048
3067
  return;
3049
3068
  }
@@ -3056,7 +3075,7 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
3056
3075
  return;
3057
3076
  }
3058
3077
  else {
3059
- yield this.service.setActiveId(this.resource, value, this.searchOptions).then(() => this.updateSearchInput());
3078
+ yield this.service.setActiveId(this.resource, value).then(() => this.updateSearchInput());
3060
3079
  }
3061
3080
  this.value = value;
3062
3081
  });
@@ -3099,7 +3118,7 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
3099
3118
  });
3100
3119
  }
3101
3120
  if (this.open && !this.initialized) {
3102
- this.service.initialize(this.resource, this.searchOptions);
3121
+ this.service.initialize(this.resource);
3103
3122
  }
3104
3123
  if (!this.open && this.ngControl) {
3105
3124
  this.ngControl.control.markAsTouched();
@@ -3128,7 +3147,7 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
3128
3147
  this.stateChanges.next();
3129
3148
  this.entityRemoved.emit();
3130
3149
  if (reload) {
3131
- this.service.search(this.resource, "", this.searchOptions);
3150
+ this.service.search(this.resource, "");
3132
3151
  }
3133
3152
  }
3134
3153
  formatLabel(item) {
@@ -3144,7 +3163,7 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
3144
3163
  return item;
3145
3164
  }
3146
3165
  onEndScroll() {
3147
- this.service.loadMore(this.resource, this.searchOptions);
3166
+ this.service.loadMore(this.resource);
3148
3167
  }
3149
3168
  focusChanged(isFocused) {
3150
3169
  if (isFocused !== this.focused) {
@@ -3157,20 +3176,19 @@ class NiceAsyncTypeaheadComponent extends _BaseAsyncTypeaheadComponent {
3157
3176
  }
3158
3177
  reload() {
3159
3178
  var _a, _b;
3160
- return __awaiter(this, void 0, void 0, function* () {
3161
- yield ((_a = this.service) === null || _a === void 0 ? void 0 : _a.search(this.resource, (_b = this.searchControl.value) !== null && _b !== void 0 ? _b : "", this.searchOptions));
3162
- });
3179
+ (_a = this.service) === null || _a === void 0 ? void 0 : _a.search(this.resource, (_b = this.searchControl.value) !== null && _b !== void 0 ? _b : "");
3163
3180
  }
3164
3181
  reloadActive() {
3165
3182
  var _a, _b;
3166
3183
  return __awaiter(this, void 0, void 0, function* () {
3167
- yield ((_a = this.service) === null || _a === void 0 ? void 0 : _a.reloadActive(this.resource, this.searchOptions));
3184
+ yield ((_a = this.service) === null || _a === void 0 ? void 0 : _a.reloadActive(this.resource));
3168
3185
  const active = (_b = this.service) === null || _b === void 0 ? void 0 : _b.getActive();
3169
3186
  this.updateLabel(active);
3170
3187
  });
3171
3188
  }
3172
3189
  setSearchOptions(options) {
3173
3190
  this.searchOptions = options;
3191
+ this.service.setSearchOptions(options);
3174
3192
  }
3175
3193
  updateLabel(item) {
3176
3194
  if (!item) {
@@ -5416,6 +5434,18 @@ class NiceControlStatusDirective {
5416
5434
  actual: this.control.errors[error].actual
5417
5435
  };
5418
5436
  }
5437
+ if (error === "arrayMinLength") {
5438
+ param = {
5439
+ min: this.control.errors[error].min,
5440
+ actual: this.control.errors[error].actual
5441
+ };
5442
+ }
5443
+ if (error === "arrayMaxLength") {
5444
+ param = {
5445
+ max: this.control.errors[error].max,
5446
+ actual: this.control.errors[error].actual
5447
+ };
5448
+ }
5419
5449
  if (typeof this.control.errors[error] === "object" && !param) {
5420
5450
  param = this.control.errors[error];
5421
5451
  }
@@ -10610,12 +10640,7 @@ class TranslationFormComponent {
10610
10640
  }
10611
10641
  set disabled(value) {
10612
10642
  this._disabled = coerceBooleanProperty(value);
10613
- if (this._disabled) {
10614
- this.currentControl.disable({ emitEvent: false });
10615
- }
10616
- else {
10617
- this.currentControl.enable({ emitEvent: false });
10618
- }
10643
+ this.handleDisabledState();
10619
10644
  this.stateChanges.next();
10620
10645
  }
10621
10646
  set placeholder(placeholder) {
@@ -10695,6 +10720,7 @@ class TranslationFormComponent {
10695
10720
  }
10696
10721
  setLanguage(language) {
10697
10722
  this.currentControl = this.formGroup.get(language);
10723
+ this.handleDisabledState();
10698
10724
  this.changeDetectorRef.markForCheck();
10699
10725
  }
10700
10726
  setupFormControls(languages) {
@@ -10708,6 +10734,16 @@ class TranslationFormComponent {
10708
10734
  this.formGroup.removeControl(key);
10709
10735
  }
10710
10736
  this.currentControl = this.formGroup.get(languages[0]);
10737
+ this.handleDisabledState();
10738
+ }
10739
+ handleDisabledState() {
10740
+ var _a, _b;
10741
+ if (this._disabled) {
10742
+ (_a = this.currentControl) === null || _a === void 0 ? void 0 : _a.disable({ emitEvent: false });
10743
+ }
10744
+ else {
10745
+ (_b = this.currentControl) === null || _b === void 0 ? void 0 : _b.enable({ emitEvent: false });
10746
+ }
10711
10747
  }
10712
10748
  }
10713
10749
  TranslationFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TranslationFormComponent, deps: [{ token: i1$3.ControlContainer }, { token: TranslationContextDirective }, { token: NiceTranslationFormService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });