@recursyve/nice-ui-kit.v2 15.0.0-beta.129 → 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.
- package/esm2020/lib/components/async-typeahead/async-typeahead.component.mjs +23 -12
- package/esm2020/lib/components/async-typeahead/providers/async-typeahead.service.mjs +22 -12
- package/esm2020/lib/components/form-error/control-status.directive.mjs +14 -2
- package/esm2020/lib/components/translation-form/components/translation-form.component.mjs +12 -7
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs +90 -54
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs +67 -29
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/lib/components/async-typeahead/async-typeahead.component.d.ts +4 -2
- package/lib/components/async-typeahead/providers/async-typeahead.service.d.ts +8 -5
- package/lib/components/translation-form/components/translation-form.component.d.ts +1 -0
- package/lib/components/translation-form/validators/require-for-languages.validator.d.ts +1 -1
- package/package.json +1 -1
|
@@ -33,12 +33,7 @@ export class TranslationFormComponent {
|
|
|
33
33
|
}
|
|
34
34
|
set disabled(value) {
|
|
35
35
|
this._disabled = coerceBooleanProperty(value);
|
|
36
|
-
|
|
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
|
|
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, ""
|
|
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
|
|
2778
|
+
search(resource, searchQuery) {
|
|
2779
2779
|
this.requests$.next({
|
|
2780
2780
|
resource,
|
|
2781
2781
|
searchQuery,
|
|
2782
|
-
searchOptions:
|
|
2782
|
+
searchOptions: this.getSearchOptions(),
|
|
2783
2783
|
page: 0
|
|
2784
2784
|
});
|
|
2785
2785
|
}
|
|
2786
|
-
loadMore(resource
|
|
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:
|
|
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
|
|
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,
|
|
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
|
|
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
|
|
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
|
|
2991
|
-
|
|
2992
|
-
if (this.ngControl
|
|
2993
|
-
this.
|
|
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
|
-
|
|
3001
|
-
this.
|
|
3002
|
-
|
|
3003
|
-
|
|
3004
|
-
|
|
3005
|
-
|
|
3006
|
-
|
|
3007
|
-
|
|
3008
|
-
|
|
3009
|
-
|
|
3010
|
-
|
|
3011
|
-
|
|
3012
|
-
|
|
3013
|
-
|
|
3014
|
-
|
|
3015
|
-
|
|
3016
|
-
|
|
3017
|
-
|
|
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, ""
|
|
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
|
|
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
|
|
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, ""
|
|
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
|
|
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
|
-
|
|
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
|
|
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) {
|
|
@@ -5377,7 +5395,7 @@ class NiceControlStatusDirective {
|
|
|
5377
5395
|
}
|
|
5378
5396
|
ngAfterViewInit() {
|
|
5379
5397
|
this.control = this.formField._control.ngControl;
|
|
5380
|
-
this.
|
|
5398
|
+
this.formField._control.stateChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(() => this.onChange());
|
|
5381
5399
|
}
|
|
5382
5400
|
ngOnDestroy() {
|
|
5383
5401
|
this.unsubscribeAll$.next();
|
|
@@ -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
|
-
|
|
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 });
|