@touchpoll/tp-survey 0.0.23 → 0.0.25

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.
Files changed (60) hide show
  1. package/fesm2022/touchpoll-tp-survey.mjs +202 -150
  2. package/fesm2022/touchpoll-tp-survey.mjs.map +1 -1
  3. package/lib/component/answer/answer.ms/answer.ms.component.d.ts +3 -3
  4. package/lib/component/answer/answer.sl/answer.sl.component.d.ts +3 -3
  5. package/lib/component/survey.play/survey.play.component.d.ts +2 -2
  6. package/lib/pipe/get.question.image.background.size/get.question.image.background.css.size.pipe.d.ts +12 -0
  7. package/lib/tp.survey.interface.d.ts +4 -4
  8. package/package.json +1 -3
  9. package/styles/platform/component/survey.checkbox.scss +5 -5
  10. package/styles/platform/component/survey.radio.button.scss +3 -3
  11. package/styles/platform/survey.mixins.desktop.scss +9 -9
  12. package/styles/platform/survey.mixins.tablet.scss +3 -3
  13. package/styles/survey.mixins.scss +4 -3
  14. package/styles/survey.themes.scss +5 -2
  15. package/styles/theme/azure.blue.scss +3 -2
  16. package/styles/theme/cyan.orange.scss +4 -2
  17. package/styles/theme/rose.red.scss +3 -2
  18. package/esm2022/lib/component/answer/answer.additional/answer.additional.component.mjs +0 -49
  19. package/esm2022/lib/component/answer/answer.additional/directive/additional.answer.caption.position/additional.answer.caption.position.directive.mjs +0 -61
  20. package/esm2022/lib/component/answer/answer.end/answer.end.component.mjs +0 -30
  21. package/esm2022/lib/component/answer/answer.info/answer.info.component.mjs +0 -30
  22. package/esm2022/lib/component/answer/answer.lang/answer.lang.component.mjs +0 -22
  23. package/esm2022/lib/component/answer/answer.master/answer.master.component.mjs +0 -57
  24. package/esm2022/lib/component/answer/answer.ms/answer.ms.component.mjs +0 -106
  25. package/esm2022/lib/component/answer/answer.od/answer.od.component.mjs +0 -39
  26. package/esm2022/lib/component/answer/answer.ol/answer.ol.component.mjs +0 -40
  27. package/esm2022/lib/component/answer/answer.sl/answer.sl.component.mjs +0 -131
  28. package/esm2022/lib/component/answer/answer.sl/pipe/as.form.array/as.form.array.pipe.mjs +0 -17
  29. package/esm2022/lib/component/answer/answer.sl/pipe/as.form.control/as.form.control.pipe.mjs +0 -17
  30. package/esm2022/lib/component/answer/answer.ss/answer.ss.component.mjs +0 -51
  31. package/esm2022/lib/component/answer/container.answer/container.answer.component.mjs +0 -319
  32. package/esm2022/lib/component/answer/container.answer/container.answer.validator.mjs +0 -130
  33. package/esm2022/lib/component/navigation.button/navigation.button.component.mjs +0 -21
  34. package/esm2022/lib/component/question.caption/question.caption.component.mjs +0 -15
  35. package/esm2022/lib/component/survey.play/survey.play.component.mjs +0 -126
  36. package/esm2022/lib/component/survey.question.preview/survey.question.preview.component.mjs +0 -60
  37. package/esm2022/lib/core/tp.servey.quota/tp.survey.quota.mjs +0 -105
  38. package/esm2022/lib/core/tp.survey.answer/tp.survey.answer.mjs +0 -27
  39. package/esm2022/lib/core/tp.survey.core/tp.survey.core.service.mjs +0 -455
  40. package/esm2022/lib/core/tp.survey.interview/tp.survey.interview.service.mjs +0 -68
  41. package/esm2022/lib/core/tp.survey.logic/tp.survey.logic.service.mjs +0 -42
  42. package/esm2022/lib/directive/alternatives.container/alternatives.container.directive.mjs +0 -130
  43. package/esm2022/lib/directive/focus.and.select/focus.and.select.directive.mjs +0 -27
  44. package/esm2022/lib/directive/survey.theme/survey.theme.directive.mjs +0 -53
  45. package/esm2022/lib/directive/update.font.size/update.font.size.directive.mjs +0 -28
  46. package/esm2022/lib/icons/default.icons/default.icons.mjs +0 -15
  47. package/esm2022/lib/icons/default.icons/default.icons.module.mjs +0 -31
  48. package/esm2022/lib/pipe/get.active.language/get.active.language.pipe.mjs +0 -17
  49. package/esm2022/lib/pipe/get.additional.value.by.value/get.additional.value.by.value.pipe.mjs +0 -18
  50. package/esm2022/lib/pipe/key.values/key.values.pipe.mjs +0 -20
  51. package/esm2022/lib/pipe/multi.lang.object.to.html/multi.lang.object.to.html.pipe.mjs +0 -48
  52. package/esm2022/lib/tp.survey.config.mjs +0 -8
  53. package/esm2022/lib/tp.survey.const.mjs +0 -28
  54. package/esm2022/lib/tp.survey.enum.mjs +0 -50
  55. package/esm2022/lib/tp.survey.interface.mjs +0 -2
  56. package/esm2022/lib/tp.survey.method.mjs +0 -5
  57. package/esm2022/lib/tp.survey.module.mjs +0 -27
  58. package/esm2022/lib/tp.survey.type.mjs +0 -2
  59. package/esm2022/public-api.mjs +0 -14
  60. package/esm2022/touchpoll-tp-survey.mjs +0 -5
@@ -1,22 +0,0 @@
1
- import { Component, input, output } from '@angular/core';
2
- import { AnswerMasterComponent } from '../answer.master/answer.master.component';
3
- import { MatButton } from '@angular/material/button';
4
- import { MatIcon } from '@angular/material/icon';
5
- import * as i0 from "@angular/core";
6
- export class AnswerLangComponent extends AnswerMasterComponent {
7
- constructor() {
8
- super(...arguments);
9
- this.languageList = input.required();
10
- this.onLanguageChange = output();
11
- }
12
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerLangComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
13
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: AnswerLangComponent, isStandalone: true, selector: "tp-survey-answer-lang", inputs: { languageList: { classPropertyName: "languageList", publicName: "languageList", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { onLanguageChange: "onLanguageChange" }, usesInheritance: true, ngImport: i0, template: "@for (language of languageList(); track $index) {\r\n <button mat-button (click)=\"onLanguageChange.emit(language.Value)\">\r\n {{language.Caption}}\r\n </button>\r\n}\r\n", styles: [""], dependencies: [{ kind: "component", type: MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }] }); }
14
- }
15
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerLangComponent, decorators: [{
16
- type: Component,
17
- args: [{ selector: 'tp-survey-answer-lang', standalone: true, imports: [
18
- MatButton,
19
- MatIcon
20
- ], template: "@for (language of languageList(); track $index) {\r\n <button mat-button (click)=\"onLanguageChange.emit(language.Value)\">\r\n {{language.Caption}}\r\n </button>\r\n}\r\n" }]
21
- }] });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5zd2VyLmxhbmcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHAuc3VydmV5L3NyYy9saWIvY29tcG9uZW50L2Fuc3dlci9hbnN3ZXIubGFuZy9hbnN3ZXIubGFuZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cC5zdXJ2ZXkvc3JjL2xpYi9jb21wb25lbnQvYW5zd2VyL2Fuc3dlci5sYW5nL2Fuc3dlci5sYW5nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2RCxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUUvRSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDbkQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLHdCQUF3QixDQUFDOztBQWEvQyxNQUFNLE9BQU8sbUJBQW9CLFNBQVEscUJBQTZCO0lBWHRFOztRQVlFLGlCQUFZLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBZ0MsQ0FBQztRQUM5RCxxQkFBZ0IsR0FBRyxNQUFNLEVBQVUsQ0FBQztLQUNyQzs4R0FIWSxtQkFBbUI7a0dBQW5CLG1CQUFtQixtVENqQmhDLDhLQUtBLDBERE9JLFNBQVM7OzJGQUtBLG1CQUFtQjtrQkFYL0IsU0FBUzsrQkFDRSx1QkFBdUIsY0FHckIsSUFBSSxXQUNQO3dCQUNQLFNBQVM7d0JBQ1QsT0FBTztxQkFDUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBpbnB1dCwgb3V0cHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtBbnN3ZXJNYXN0ZXJDb21wb25lbnR9IGZyb20gJy4uL2Fuc3dlci5tYXN0ZXIvYW5zd2VyLm1hc3Rlci5jb21wb25lbnQnO1xyXG5pbXBvcnQge0lkYkJhc2VQYXJhbXNMYW5ndWFnZX0gZnJvbSAnLi4vLi4vLi4vdHAuc3VydmV5LmludGVyZmFjZSc7XHJcbmltcG9ydCB7TWF0QnV0dG9ufSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQge01hdEljb259IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0cC1zdXJ2ZXktYW5zd2VyLWxhbmcnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9hbnN3ZXIubGFuZy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vYW5zd2VyLmxhbmcuY29tcG9uZW50LnNjc3MnXSxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIE1hdEJ1dHRvbixcclxuICAgIE1hdEljb25cclxuICBdXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgQW5zd2VyTGFuZ0NvbXBvbmVudCBleHRlbmRzIEFuc3dlck1hc3RlckNvbXBvbmVudDxudW1iZXI+e1xyXG4gIGxhbmd1YWdlTGlzdCA9IGlucHV0LnJlcXVpcmVkPEFycmF5PElkYkJhc2VQYXJhbXNMYW5ndWFnZT4+KCk7XHJcbiAgb25MYW5ndWFnZUNoYW5nZSA9IG91dHB1dDxudW1iZXI+KCk7XHJcbn1cclxuIiwiQGZvciAobGFuZ3VhZ2Ugb2YgbGFuZ3VhZ2VMaXN0KCk7IHRyYWNrICRpbmRleCkge1xyXG4gPGJ1dHRvbiBtYXQtYnV0dG9uIChjbGljayk9XCJvbkxhbmd1YWdlQ2hhbmdlLmVtaXQobGFuZ3VhZ2UuVmFsdWUpXCI+XHJcbiAge3tsYW5ndWFnZS5DYXB0aW9ufX1cclxuIDwvYnV0dG9uPlxyXG59XHJcbiJdfQ==
@@ -1,57 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, DestroyRef, forwardRef, inject, input } from '@angular/core';
2
- import { FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';
3
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
- import { ViewModel } from '../../../tp.survey.enum';
5
- import * as i0 from "@angular/core";
6
- export class AnswerMasterComponent {
7
- constructor() {
8
- this.language = input.required();
9
- this.viewModel = input.required();
10
- this.findVariable = input.required();
11
- this.repositoryPath = input('');
12
- this.viewModelE = ViewModel;
13
- this.onModelChange = (data) => { };
14
- this.onModelTouched = () => { };
15
- this.destroyRef = inject(DestroyRef);
16
- this.control = new FormControl(null);
17
- this.control.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(res => {
18
- this.onModelChange(res);
19
- });
20
- }
21
- registerOnChange(fn) {
22
- this.onModelChange = fn;
23
- }
24
- registerOnTouched(fn) {
25
- this.onModelTouched();
26
- }
27
- setDisabledState(isDisabled) {
28
- }
29
- writeValue(value) {
30
- this.control.patchValue(value, { emitEvent: false });
31
- }
32
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerMasterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
33
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.1", type: AnswerMasterComponent, isStandalone: true, selector: "app-answer-master", inputs: { language: { classPropertyName: "language", publicName: "language", isSignal: true, isRequired: true, transformFunction: null }, viewModel: { classPropertyName: "viewModel", publicName: "viewModel", isSignal: true, isRequired: true, transformFunction: null }, findVariable: { classPropertyName: "findVariable", publicName: "findVariable", isSignal: true, isRequired: true, transformFunction: null }, repositoryPath: { classPropertyName: "repositoryPath", publicName: "repositoryPath", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
34
- {
35
- provide: NG_VALUE_ACCESSOR,
36
- useExisting: forwardRef(() => AnswerMasterComponent),
37
- multi: true
38
- },
39
- ], ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
40
- }
41
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerMasterComponent, decorators: [{
42
- type: Component,
43
- args: [{
44
- selector: 'app-answer-master',
45
- template: '',
46
- changeDetection: ChangeDetectionStrategy.OnPush,
47
- standalone: true,
48
- providers: [
49
- {
50
- provide: NG_VALUE_ACCESSOR,
51
- useExisting: forwardRef(() => AnswerMasterComponent),
52
- multi: true
53
- },
54
- ],
55
- }]
56
- }], ctorParameters: () => [] });
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5zd2VyLm1hc3Rlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cC5zdXJ2ZXkvc3JjL2xpYi9jb21wb25lbnQvYW5zd2VyL2Fuc3dlci5tYXN0ZXIvYW5zd2VyLm1hc3Rlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEcsT0FBTyxFQUF1QixXQUFXLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNwRixPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUU5RCxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0seUJBQXlCLENBQUM7O0FBZ0JsRCxNQUFNLE9BQWdCLHFCQUFxQjtJQVV6QztRQVRBLGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFDcEMsY0FBUyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQWEsQ0FBQztRQUN4QyxpQkFBWSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXFCLENBQUM7UUFDbkQsbUJBQWMsR0FBRyxLQUFLLENBQVMsRUFBRSxDQUFDLENBQUM7UUFDbkMsZUFBVSxHQUFHLFNBQVMsQ0FBQztRQUViLGtCQUFhLEdBQUcsQ0FBQyxJQUFPLEVBQUUsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUNoQyxtQkFBYyxHQUFHLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUNqQixlQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRWpELElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUM3QixrQkFBa0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQ25DLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ2hCLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBSSxDQUFDLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsRUFBcUI7UUFDcEMsSUFBSSxDQUFDLGFBQWEsR0FBRyxFQUFFLENBQUM7SUFDMUIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxVQUFtQjtJQUNwQyxDQUFDO0lBRUQsVUFBVSxDQUFDLEtBQVE7UUFDakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxDQUFDLENBQUM7SUFDckQsQ0FBQzs4R0FoQ21CLHFCQUFxQjtrR0FBckIscUJBQXFCLDhtQkFUOUI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHFCQUFxQixDQUFDO2dCQUNwRCxLQUFLLEVBQUUsSUFBSTthQUNaO1NBQ0YsMEJBVFMsRUFBRTs7MkZBWVEscUJBQXFCO2tCQWQxQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFFBQVEsRUFBRSxFQUFFO29CQUNaLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLHNCQUFzQixDQUFDOzRCQUNwRCxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRjtpQkFFRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRGVzdHJveVJlZiwgZm9yd2FyZFJlZiwgaW5qZWN0LCBpbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29udHJvbFZhbHVlQWNjZXNzb3IsIEZvcm1Db250cm9sLCBOR19WQUxVRV9BQ0NFU1NPUn0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQge3Rha2VVbnRpbERlc3Ryb3llZH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xyXG5pbXBvcnQge0Fuc3dlclQsIFRGaW5kVmFyaWFibGVWb2lkfSBmcm9tICcuLi8uLi8uLi90cC5zdXJ2ZXkudHlwZSc7XHJcbmltcG9ydCB7Vmlld01vZGVsfSBmcm9tICcuLi8uLi8uLi90cC5zdXJ2ZXkuZW51bSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1hbnN3ZXItbWFzdGVyJyxcclxuICB0ZW1wbGF0ZTogJycsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IEFuc3dlck1hc3RlckNvbXBvbmVudCksXHJcbiAgICAgIG11bHRpOiB0cnVlXHJcbiAgICB9LFxyXG4gIF0sXHJcblxyXG59KVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQW5zd2VyTWFzdGVyQ29tcG9uZW50PFQgZXh0ZW5kcyBBbnN3ZXJUPiBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcclxuICBsYW5ndWFnZSA9IGlucHV0LnJlcXVpcmVkPG51bWJlcj4oKTtcclxuICB2aWV3TW9kZWwgPSBpbnB1dC5yZXF1aXJlZDxWaWV3TW9kZWw+KCk7XHJcbiAgZmluZFZhcmlhYmxlID0gaW5wdXQucmVxdWlyZWQ8VEZpbmRWYXJpYWJsZVZvaWQ+KCk7XHJcbiAgcmVwb3NpdG9yeVBhdGggPSBpbnB1dDxzdHJpbmc+KCcnKTtcclxuICB2aWV3TW9kZWxFID0gVmlld01vZGVsO1xyXG4gIGNvbnRyb2w6IEZvcm1Db250cm9sPFQgfCBudWxsPjtcclxuICBwcm90ZWN0ZWQgb25Nb2RlbENoYW5nZSA9IChkYXRhOiBUKSA9PiB7fTtcclxuICBwcm90ZWN0ZWQgb25Nb2RlbFRvdWNoZWQgPSAoKSA9PiB7fTtcclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgZGVzdHJveVJlZiA9IGluamVjdChEZXN0cm95UmVmKTtcclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIHRoaXMuY29udHJvbCA9IG5ldyBGb3JtQ29udHJvbChudWxsKTtcclxuICAgIHRoaXMuY29udHJvbC52YWx1ZUNoYW5nZXMucGlwZShcclxuICAgICB0YWtlVW50aWxEZXN0cm95ZWQodGhpcy5kZXN0cm95UmVmKVxyXG4gICAgKS5zdWJzY3JpYmUocmVzID0+IHtcclxuICAgICAgdGhpcy5vbk1vZGVsQ2hhbmdlKHJlcyEpO1xyXG4gICAgfSlcclxuICB9XHJcbiAgXHJcbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogKGRhdGE6IFQpID0+IHZvaWQpOiB2b2lkIHtcclxuICAgIHRoaXMub25Nb2RlbENoYW5nZSA9IGZuO1xyXG4gIH1cclxuXHJcbiAgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSk6IHZvaWQge1xyXG4gICAgdGhpcy5vbk1vZGVsVG91Y2hlZCgpO1xyXG4gIH1cclxuXHJcbiAgc2V0RGlzYWJsZWRTdGF0ZShpc0Rpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XHJcbiAgfVxyXG4gIFxyXG4gIHdyaXRlVmFsdWUodmFsdWU6IFQpOiB2b2lkIHtcclxuICAgIHRoaXMuY29udHJvbC5wYXRjaFZhbHVlKHZhbHVlLCB7ZW1pdEV2ZW50OiBmYWxzZX0pO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,106 +0,0 @@
1
- import { Component, forwardRef, input, output } from '@angular/core';
2
- import { FormArray, FormControl, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
3
- import { MatCheckbox } from '@angular/material/checkbox';
4
- import { map } from 'rxjs/operators';
5
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
- import { MatIcon } from '@angular/material/icon';
7
- import { MatRadioGroup } from '@angular/material/radio';
8
- import { filter, tap } from 'rxjs';
9
- import { MultiLangObjectToHtmlPipe } from '../../../pipe/multi.lang.object.to.html/multi.lang.object.to.html.pipe';
10
- import { AnswerMasterComponent } from '../answer.master/answer.master.component';
11
- import { AlternativesContainerDirective } from '../../../directive/alternatives.container/alternatives.container.directive';
12
- import * as i0 from "@angular/core";
13
- import * as i1 from "@angular/forms";
14
- export class AnswerMSComponent extends AnswerMasterComponent {
15
- constructor() {
16
- super();
17
- this.question = input.required();
18
- this.alternativeList = input.required();
19
- this.alternativeMaxAnswersCount = input.required();
20
- this.onAlternativeClick = output();
21
- this.answerMSForm = new FormGroup({
22
- alternativeList: new FormArray([])
23
- });
24
- }
25
- ngOnInit() {
26
- const alternativeList = this.alternativeList();
27
- const answerAsArray = Array.isArray(this.control.value) ? this.control.value : [];
28
- const maxCount = this.alternativeMaxAnswersCount();
29
- this.answerMSForm.controls.alternativeList.clear({ emitEvent: false });
30
- alternativeList.forEach(alt => {
31
- const control = new FormControl(answerAsArray.includes(alt.Value), { nonNullable: true });
32
- //У альтернативы есть понятие "Группа". Группа это число. Если выбирают альтернативу с определённой группой, то альтернативы с другой группой должны быть отжаты.
33
- control.valueChanges.pipe(filter(value => value), takeUntilDestroyed(this.destroyRef)).subscribe({
34
- next: () => this.#uncheckControlsWithOtherGroup(alt.GroupNo)
35
- });
36
- this.answerMSForm.controls.alternativeList.push(control, { emitEvent: false });
37
- });
38
- this.answerMSForm.controls.alternativeList.valueChanges.pipe(map((_) => {
39
- const checkedArray = this.answerMSForm.controls.alternativeList.controls.map(c => c.value) ?? [];
40
- return this.alternativeList()
41
- .map(alt => alt.Value)
42
- .filter((_, index) => checkedArray[index]);
43
- }), tap(answerArray => this.#disableExtraControls(answerArray.length, maxCount)), takeUntilDestroyed(this.destroyRef)).subscribe({
44
- next: res => this.control.patchValue(res, { emitEvent: true })
45
- });
46
- }
47
- //отжимает контролы у которых отличается номер группы
48
- #uncheckControlsWithOtherGroup(groupNumber) {
49
- //сначала отбираем контролы у которых другая группа.
50
- const otherGroupAlternativesList = this.alternativeList()
51
- .map((alt, altIndex) => ({ alternative: alt, index: altIndex })) //нужен индекс, по нему проще выбирать контролы в answerMSForm.controls.alternativeList
52
- .filter(data => data.alternative.GroupNo !== groupNumber); //контролы у которых другая группа
53
- //"отжимаем галочку"
54
- otherGroupAlternativesList.forEach(data => {
55
- const altControl = this.answerMSForm.controls.alternativeList.at(data.index);
56
- altControl.patchValue(false, { emitEvent: false });
57
- });
58
- }
59
- //дизейблит контроли если выбрали максимальное количество или енейблит если выбрали не максимальное количество
60
- #disableExtraControls(currentCount, maxCount) {
61
- //если в настройках анкеты указали что максимальное возможное количество выбранных альтернатив = 0, но ничего контролировать не надо.
62
- if (maxCount === 0) {
63
- return;
64
- }
65
- this.alternativeList().forEach((_, altIndex) => {
66
- const isDisable = currentCount >= maxCount;
67
- const control = this.answerMSForm.controls.alternativeList.at(altIndex);
68
- if (isDisable) {
69
- //надо дизейблить те которые не выбраны
70
- if (!control.value) {
71
- control.disable({ emitEvent: false });
72
- }
73
- }
74
- else {
75
- //лимита нет, можно выбирать все
76
- control.enable({ emitEvent: false });
77
- }
78
- });
79
- }
80
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerMSComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
81
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: AnswerMSComponent, isStandalone: true, selector: "tp-survey-answer-ms", inputs: { question: { classPropertyName: "question", publicName: "question", isSignal: true, isRequired: true, transformFunction: null }, alternativeList: { classPropertyName: "alternativeList", publicName: "alternativeList", isSignal: true, isRequired: true, transformFunction: null }, alternativeMaxAnswersCount: { classPropertyName: "alternativeMaxAnswersCount", publicName: "alternativeMaxAnswersCount", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { onAlternativeClick: "onAlternativeClick" }, providers: [
82
- {
83
- provide: NG_VALUE_ACCESSOR,
84
- useExisting: forwardRef(() => AnswerMSComponent),
85
- multi: true
86
- },
87
- ], usesInheritance: true, ngImport: i0, template: "<ng-container [formGroup]=\"answerMSForm\">\r\n <div\r\n class=\"container-ms-ss-alternatives\"\r\n [tpSurveyAlternativesContainer] = \"question()\"\r\n [containerViewModel]=\"viewModel()\"\r\n formArrayName=\"alternativeList\">\r\n @for (alt of answerMSForm.controls.alternativeList.controls; track alt; let indx = $index) {\r\n <mat-checkbox\r\n #tablet_alt\r\n [formControl]=\"alt\"\r\n [style.font-size.%]=\"viewModel() === viewModelE.vmTablet ? question().AlternativeTabletFontSize : undefined\"\r\n (change)=\"onAlternativeClick.emit(alternativeList()[indx].Value)\"\r\n class=\"alternative-ss-ms tp-survey-checkbox\">\r\n @if (alternativeList()[indx].IsMute) {\r\n <mat-icon class=\"icon-is-mute\" svgIcon=\"iconIsMute\"></mat-icon>\r\n }\r\n <div class=\"container-caption\">\r\n @if (alternativeList()[indx].BackGround.Image) {\r\n <img alt=\"answer logo\" [style.height.px]=\"alternativeList()[indx].BackGround.ImageHeight ?? question().AlternativeBackgroundImageHeight ?? 30\" [src]=\"repositoryPath()+'/' + alternativeList()[indx].BackGround.Image\" importance=\"low\" loading=\"lazy\">\r\n }\r\n <span class=\"alternative-ss-ms-caption survey-object-caption\" [innerHTML]= \"alternativeList()[indx].MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </div>\r\n </mat-checkbox>\r\n }\r\n </div>\r\n</ng-container>\r\n", styles: [".container-main-tablet{position:absolute;width:100%;height:100%;top:0;box-sizing:border-box;overflow:hidden}.radio-button{margin:4px}@media (max-width: 480px){.container-controls{padding:1em}}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "component", type: MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "pipe", type: MultiLangObjectToHtmlPipe, name: "multiLangObjectToHtml" }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: AlternativesContainerDirective, selector: "[tpSurveyAlternativesContainer]", inputs: ["tpSurveyAlternativesContainer", "containerViewModel"] }] }); }
88
- }
89
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerMSComponent, decorators: [{
90
- type: Component,
91
- args: [{ selector: 'tp-survey-answer-ms', standalone: true, imports: [
92
- ReactiveFormsModule,
93
- MatCheckbox,
94
- MultiLangObjectToHtmlPipe,
95
- MatIcon,
96
- MatRadioGroup,
97
- AlternativesContainerDirective,
98
- ], providers: [
99
- {
100
- provide: NG_VALUE_ACCESSOR,
101
- useExisting: forwardRef(() => AnswerMSComponent),
102
- multi: true
103
- },
104
- ], template: "<ng-container [formGroup]=\"answerMSForm\">\r\n <div\r\n class=\"container-ms-ss-alternatives\"\r\n [tpSurveyAlternativesContainer] = \"question()\"\r\n [containerViewModel]=\"viewModel()\"\r\n formArrayName=\"alternativeList\">\r\n @for (alt of answerMSForm.controls.alternativeList.controls; track alt; let indx = $index) {\r\n <mat-checkbox\r\n #tablet_alt\r\n [formControl]=\"alt\"\r\n [style.font-size.%]=\"viewModel() === viewModelE.vmTablet ? question().AlternativeTabletFontSize : undefined\"\r\n (change)=\"onAlternativeClick.emit(alternativeList()[indx].Value)\"\r\n class=\"alternative-ss-ms tp-survey-checkbox\">\r\n @if (alternativeList()[indx].IsMute) {\r\n <mat-icon class=\"icon-is-mute\" svgIcon=\"iconIsMute\"></mat-icon>\r\n }\r\n <div class=\"container-caption\">\r\n @if (alternativeList()[indx].BackGround.Image) {\r\n <img alt=\"answer logo\" [style.height.px]=\"alternativeList()[indx].BackGround.ImageHeight ?? question().AlternativeBackgroundImageHeight ?? 30\" [src]=\"repositoryPath()+'/' + alternativeList()[indx].BackGround.Image\" importance=\"low\" loading=\"lazy\">\r\n }\r\n <span class=\"alternative-ss-ms-caption survey-object-caption\" [innerHTML]= \"alternativeList()[indx].MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </div>\r\n </mat-checkbox>\r\n }\r\n </div>\r\n</ng-container>\r\n", styles: [".container-main-tablet{position:absolute;width:100%;height:100%;top:0;box-sizing:border-box;overflow:hidden}.radio-button{margin:4px}@media (max-width: 480px){.container-controls{padding:1em}}\n"] }]
105
- }], ctorParameters: () => [] });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"answer.ms.component.js","sourceRoot":"","sources":["../../../../../../../projects/tp.survey/src/lib/component/answer/answer.ms/answer.ms.component.ts","../../../../../../../projects/tp.survey/src/lib/component/answer/answer.ms/answer.ms.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, input, OnInit, output} from '@angular/core';\r\nimport {FormArray, FormControl, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\r\nimport {MatCheckbox} from '@angular/material/checkbox';\r\nimport {map} from 'rxjs/operators';\r\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\r\nimport {MatIcon} from '@angular/material/icon';\r\nimport {MatRadioGroup} from '@angular/material/radio';\r\nimport {filter, tap} from 'rxjs';\r\nimport {MultiLangObjectToHtmlPipe} from '../../../pipe/multi.lang.object.to.html/multi.lang.object.to.html.pipe';\r\nimport {AnswerMasterComponent} from '../answer.master/answer.master.component';\r\nimport {IdbAlternative, IdbQuestion} from '../../../tp.survey.interface';\r\nimport {AlternativesContainerDirective} from '../../../directive/alternatives.container/alternatives.container.directive';\r\n\r\ninterface IAnswerMSForm {\r\n  alternativeList: FormArray<FormControl<boolean>>;\r\n}\r\n\r\n@Component({\r\n  selector: 'tp-survey-answer-ms',\r\n  templateUrl: './answer.ms.component.html',\r\n  styleUrls: ['./answer.ms.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    ReactiveFormsModule,\r\n    MatCheckbox,\r\n    MultiLangObjectToHtmlPipe,\r\n    MatIcon,\r\n    MatRadioGroup,\r\n    AlternativesContainerDirective,\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AnswerMSComponent),\r\n      multi: true\r\n    },\r\n  ],\r\n})\r\nexport class AnswerMSComponent extends AnswerMasterComponent<Array<number>> implements OnInit{\r\n  question = input.required<IdbQuestion>();\r\n  alternativeList = input.required<Array<IdbAlternative>>();\r\n  alternativeMaxAnswersCount = input.required<number>();\r\n  onAlternativeClick = output<number>();\r\n  readonly answerMSForm: FormGroup<IAnswerMSForm>;\r\n  constructor() {\r\n    super();\r\n    this.answerMSForm = new FormGroup<IAnswerMSForm>({\r\n      alternativeList: new FormArray<FormControl<boolean>>([])\r\n    })\r\n  }\r\n\r\n\r\n  ngOnInit(): void {\r\n    const alternativeList = this.alternativeList();\r\n    const answerAsArray: Array<number> = Array.isArray(this.control.value) ? this.control.value : [];\r\n    const maxCount = this.alternativeMaxAnswersCount();\r\n\r\n    this.answerMSForm.controls.alternativeList.clear({emitEvent: false});\r\n    alternativeList.forEach( alt => {\r\n      const control= new FormControl<boolean>( answerAsArray.includes(alt.Value), {nonNullable: true});\r\n\r\n      //У альтернативы есть понятие \"Группа\". Группа это число. Если выбирают альтернативу с определённой группой, то альтернативы с другой группой должны быть отжаты.\r\n      control.valueChanges.pipe(\r\n       filter(value => value),\r\n       takeUntilDestroyed(this.destroyRef)\r\n      ).subscribe( {\r\n        next: () => this.#uncheckControlsWithOtherGroup(alt.GroupNo)\r\n      });\r\n\r\n      this.answerMSForm.controls.alternativeList.push(control, {emitEvent: false});\r\n    });\r\n\r\n    this.answerMSForm.controls.alternativeList.valueChanges.pipe(\r\n     map((_) => {\r\n      const checkedArray = this.answerMSForm.controls.alternativeList.controls.map(c => c.value) ?? [];\r\n      return this.alternativeList()\r\n       .map(alt => alt.Value)\r\n       .filter((_, index) => checkedArray[index] )\r\n     }),\r\n     tap(answerArray => this.#disableExtraControls(answerArray.length, maxCount)),\r\n     takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe({\r\n      next: res => this.control.patchValue(res, {emitEvent: true})\r\n    })\r\n  }\r\n\r\n  //отжимает контролы у которых отличается номер группы\r\n  #uncheckControlsWithOtherGroup(groupNumber: number): void {\r\n    //сначала отбираем контролы у которых другая группа.\r\n    const otherGroupAlternativesList = this.alternativeList()\r\n     .map((alt, altIndex) => ({alternative: alt, index: altIndex}) )  //нужен индекс, по нему проще выбирать контролы в answerMSForm.controls.alternativeList\r\n     .filter(data => data.alternative.GroupNo !== groupNumber); //контролы у которых другая группа\r\n\r\n    //\"отжимаем галочку\"\r\n    otherGroupAlternativesList.forEach(data => {\r\n      const altControl = this.answerMSForm.controls.alternativeList.at(data.index);\r\n      altControl.patchValue(false, {emitEvent: false})\r\n    })\r\n  }\r\n  \r\n  //дизейблит контроли если выбрали максимальное количество или енейблит если выбрали не максимальное количество\r\n  #disableExtraControls(currentCount:number, maxCount: number): void{\r\n    //если в настройках анкеты указали что максимальное возможное количество выбранных альтернатив = 0, но ничего контролировать не надо.\r\n    if (maxCount === 0) {\r\n      return\r\n    }\r\n    this.alternativeList().forEach((_, altIndex) => {\r\n      const isDisable = currentCount >= maxCount;\r\n      const control = this.answerMSForm.controls.alternativeList.at(altIndex);\r\n      if (isDisable) {\r\n        //надо дизейблить те которые не выбраны\r\n        if (!control.value) {\r\n          control.disable({emitEvent: false})\r\n        }\r\n      } else {\r\n        //лимита нет, можно выбирать все\r\n        control.enable({emitEvent: false})\r\n      }\r\n    })\r\n  }\r\n}\r\n","<ng-container [formGroup]=\"answerMSForm\">\r\n <div\r\n  class=\"container-ms-ss-alternatives\"\r\n  [tpSurveyAlternativesContainer] = \"question()\"\r\n  [containerViewModel]=\"viewModel()\"\r\n  formArrayName=\"alternativeList\">\r\n  @for (alt of answerMSForm.controls.alternativeList.controls; track alt; let indx = $index) {\r\n   <mat-checkbox\r\n    #tablet_alt\r\n    [formControl]=\"alt\"\r\n    [style.font-size.%]=\"viewModel() === viewModelE.vmTablet ? question().AlternativeTabletFontSize : undefined\"\r\n    (change)=\"onAlternativeClick.emit(alternativeList()[indx].Value)\"\r\n    class=\"alternative-ss-ms tp-survey-checkbox\">\r\n    @if (alternativeList()[indx].IsMute) {\r\n     <mat-icon class=\"icon-is-mute\" svgIcon=\"iconIsMute\"></mat-icon>\r\n    }\r\n    <div class=\"container-caption\">\r\n     @if (alternativeList()[indx].BackGround.Image) {\r\n      <img alt=\"answer logo\" [style.height.px]=\"alternativeList()[indx].BackGround.ImageHeight ?? question().AlternativeBackgroundImageHeight ?? 30\" [src]=\"repositoryPath()+'/' + alternativeList()[indx].BackGround.Image\" importance=\"low\" loading=\"lazy\">\r\n     }\r\n     <span class=\"alternative-ss-ms-caption survey-object-caption\" [innerHTML]= \"alternativeList()[indx].MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n    </div>\r\n   </mat-checkbox>\r\n  }\r\n </div>\r\n</ng-container>\r\n"]}
@@ -1,39 +0,0 @@
1
- import { Component, forwardRef, input } from '@angular/core';
2
- import { MatFormField } from '@angular/material/form-field';
3
- import { MatInput } from '@angular/material/input';
4
- import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
5
- import { FocusAndSelectDirective } from '../../../directive/focus.and.select/focus.and.select.directive';
6
- import { AnswerMasterComponent } from '../answer.master/answer.master.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/forms";
9
- export class AnswerODComponent extends AnswerMasterComponent {
10
- constructor() {
11
- super(...arguments);
12
- this.minValue = input(1);
13
- this.maxValue = input(null);
14
- }
15
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerODComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
16
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.1", type: AnswerODComponent, isStandalone: true, selector: "tp-survey-answer-od", inputs: { minValue: { classPropertyName: "minValue", publicName: "minValue", isSignal: true, isRequired: false, transformFunction: null }, maxValue: { classPropertyName: "maxValue", publicName: "maxValue", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
17
- {
18
- provide: NG_VALUE_ACCESSOR,
19
- useExisting: forwardRef(() => AnswerODComponent),
20
- multi: true
21
- },
22
- ], usesInheritance: true, ngImport: i0, template: "<div class=\"container-main\">\r\n <mat-form-field appearance=\"outline\" class=\"input-od-number\">\r\n <input [formControl]=\"control\" [min]=\"minValue()\" [max]=\"maxValue()\" tpSurveyFocusAndSelect matInput type=\"number\">\r\n </mat-form-field>\r\n</div>\r\n\r\n", styles: [".container-main{display:flex;width:100%;justify-content:center;align-items:center;flex-flow:column;gap:2em}.input-od-number{max-width:150px}\n"], dependencies: [{ kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i1.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: FocusAndSelectDirective, selector: "[tpSurveyFocusAndSelect]" }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] }); }
23
- }
24
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerODComponent, decorators: [{
25
- type: Component,
26
- args: [{ selector: 'tp-survey-answer-od', standalone: true, imports: [
27
- MatFormField,
28
- ReactiveFormsModule,
29
- FocusAndSelectDirective,
30
- MatInput,
31
- ], providers: [
32
- {
33
- provide: NG_VALUE_ACCESSOR,
34
- useExisting: forwardRef(() => AnswerODComponent),
35
- multi: true
36
- },
37
- ], template: "<div class=\"container-main\">\r\n <mat-form-field appearance=\"outline\" class=\"input-od-number\">\r\n <input [formControl]=\"control\" [min]=\"minValue()\" [max]=\"maxValue()\" tpSurveyFocusAndSelect matInput type=\"number\">\r\n </mat-form-field>\r\n</div>\r\n\r\n", styles: [".container-main{display:flex;width:100%;justify-content:center;align-items:center;flex-flow:column;gap:2em}.input-od-number{max-width:150px}\n"] }]
38
- }] });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5zd2VyLm9kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RwLnN1cnZleS9zcmMvbGliL2NvbXBvbmVudC9hbnN3ZXIvYW5zd2VyLm9kL2Fuc3dlci5vZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cC5zdXJ2ZXkvc3JjL2xpYi9jb21wb25lbnQvYW5zd2VyL2Fuc3dlci5vZC9hbnN3ZXIub2QuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzNELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUMxRCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDakQsT0FBTyxFQUFDLGlCQUFpQixFQUFFLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDdEUsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sZ0VBQWdFLENBQUM7QUFDdkcsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMENBQTBDLENBQUM7OztBQXFCL0UsTUFBTSxPQUFPLGlCQUFrQixTQUFRLHFCQUE2QjtJQW5CcEU7O1FBb0JFLGFBQVEsR0FBRyxLQUFLLENBQVMsQ0FBQyxDQUFDLENBQUM7UUFDNUIsYUFBUSxHQUFHLEtBQUssQ0FBZ0IsSUFBSSxDQUFDLENBQUM7S0FDdkM7OEdBSFksaUJBQWlCO2tHQUFqQixpQkFBaUIsZ1ZBUmpCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztnQkFDaEQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGlEQ3hCSCxtUkFNQSx3TURPSSxZQUFZLDJMQUNaLG1CQUFtQixrbUNBQ25CLHVCQUF1QixxRUFDdkIsUUFBUTs7MkZBVUMsaUJBQWlCO2tCQW5CN0IsU0FBUzsrQkFDRSxxQkFBcUIsY0FHbkIsSUFBSSxXQUNQO3dCQUNQLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQix1QkFBdUI7d0JBQ3ZCLFFBQVE7cUJBQ1QsYUFDVTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxrQkFBa0IsQ0FBQzs0QkFDaEQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgZm9yd2FyZFJlZiwgaW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge01hdEZvcm1GaWVsZH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XHJcbmltcG9ydCB7TWF0SW5wdXR9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuaW1wb3J0IHtOR19WQUxVRV9BQ0NFU1NPUiwgUmVhY3RpdmVGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQge0ZvY3VzQW5kU2VsZWN0RGlyZWN0aXZlfSBmcm9tICcuLi8uLi8uLi9kaXJlY3RpdmUvZm9jdXMuYW5kLnNlbGVjdC9mb2N1cy5hbmQuc2VsZWN0LmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7QW5zd2VyTWFzdGVyQ29tcG9uZW50fSBmcm9tICcuLi9hbnN3ZXIubWFzdGVyL2Fuc3dlci5tYXN0ZXIuY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndHAtc3VydmV5LWFuc3dlci1vZCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Fuc3dlci5vZC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vYW5zd2VyLm9kLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBNYXRGb3JtRmllbGQsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgRm9jdXNBbmRTZWxlY3REaXJlY3RpdmUsXHJcbiAgICBNYXRJbnB1dCxcclxuICBdLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gQW5zd2VyT0RDb21wb25lbnQpLFxyXG4gICAgICBtdWx0aTogdHJ1ZVxyXG4gICAgfSxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQW5zd2VyT0RDb21wb25lbnQgZXh0ZW5kcyBBbnN3ZXJNYXN0ZXJDb21wb25lbnQ8bnVtYmVyPiB7XHJcbiAgbWluVmFsdWUgPSBpbnB1dDxudW1iZXI+KDEpO1xyXG4gIG1heFZhbHVlID0gaW5wdXQ8bnVtYmVyIHwgbnVsbD4obnVsbCk7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImNvbnRhaW5lci1tYWluXCI+XHJcbiAgPG1hdC1mb3JtLWZpZWxkIGFwcGVhcmFuY2U9XCJvdXRsaW5lXCIgY2xhc3M9XCJpbnB1dC1vZC1udW1iZXJcIj5cclxuICAgIDxpbnB1dCBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiIFttaW5dPVwibWluVmFsdWUoKVwiIFttYXhdPVwibWF4VmFsdWUoKVwiIHRwU3VydmV5Rm9jdXNBbmRTZWxlY3QgbWF0SW5wdXQgdHlwZT1cIm51bWJlclwiPlxyXG4gIDwvbWF0LWZvcm0tZmllbGQ+XHJcbjwvZGl2PlxyXG5cclxuIl19
@@ -1,40 +0,0 @@
1
- import { Component, forwardRef, input } from '@angular/core';
2
- import { FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
3
- import { MatFormField, MatPrefix } from '@angular/material/form-field';
4
- import { MatInput } from '@angular/material/input';
5
- import { FocusAndSelectDirective } from '../../../directive/focus.and.select/focus.and.select.directive';
6
- import { AnswerMasterComponent } from '../answer.master/answer.master.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/forms";
9
- export class AnswerOLComponent extends AnswerMasterComponent {
10
- constructor() {
11
- super(...arguments);
12
- this.telephoneInput = input(false);
13
- }
14
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerOLComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
15
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: AnswerOLComponent, isStandalone: true, selector: "tp-survey-answer-ol", inputs: { telephoneInput: { classPropertyName: "telephoneInput", publicName: "telephoneInput", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
16
- {
17
- provide: NG_VALUE_ACCESSOR,
18
- useExisting: forwardRef(() => AnswerOLComponent),
19
- multi: true
20
- },
21
- ], usesInheritance: true, ngImport: i0, template: "<div class=\"container-main\">\r\n @if (telephoneInput()) {\r\n <mat-form-field appearance=\"outline\">\r\n <input\r\n type=\"text\"\r\n inputmode=\"numeric\"\r\n matInput\r\n [formControl]=\"control\" tpSurveyFocusAndSelect>\r\n <span matTextPrefix>+380 &nbsp;</span>\r\n </mat-form-field>\r\n } @else {\r\n <mat-form-field appearance=\"outline\" class=\"input-text\">\r\n <textarea rows=\"10\" matInput [formControl]=\"control\" tpSurveyFocusAndSelect></textarea>\r\n </mat-form-field>\r\n\r\n<!-- <mat-form-field class=\"container-controls\" appearance=\"outline\">-->\r\n<!-- <textarea rows=\"10\" autofocus matInput [(ngModel)]=\"answer.AnswerValue\" (ngModelChange)=\"answerChange()\" appFocusAndSelect></textarea>-->\r\n<!-- </mat-form-field>-->\r\n }\r\n\r\n<!-- <mat-form-field appearance=\"outline\" class=\"input-od-number\">-->\r\n<!-- <input [formControl]=\"control\" tpSurveyFocusAndSelect matInput type=\"number\">-->\r\n<!-- </mat-form-field>-->\r\n</div>\r\n", styles: [":host{width:100%}.container-main{display:flex;width:100%;justify-content:center;align-items:center;flex-flow:column;gap:2em;padding:0 2em;box-sizing:border-box}.input-text{width:100%}\n"], dependencies: [{ kind: "directive", type: FocusAndSelectDirective, selector: "[tpSurveyFocusAndSelect]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }] }); }
22
- }
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerOLComponent, decorators: [{
24
- type: Component,
25
- args: [{ selector: 'tp-survey-answer-ol', standalone: true, imports: [
26
- FocusAndSelectDirective,
27
- FormsModule,
28
- MatFormField,
29
- MatInput,
30
- ReactiveFormsModule,
31
- MatPrefix
32
- ], providers: [
33
- {
34
- provide: NG_VALUE_ACCESSOR,
35
- useExisting: forwardRef(() => AnswerOLComponent),
36
- multi: true
37
- },
38
- ], template: "<div class=\"container-main\">\r\n @if (telephoneInput()) {\r\n <mat-form-field appearance=\"outline\">\r\n <input\r\n type=\"text\"\r\n inputmode=\"numeric\"\r\n matInput\r\n [formControl]=\"control\" tpSurveyFocusAndSelect>\r\n <span matTextPrefix>+380 &nbsp;</span>\r\n </mat-form-field>\r\n } @else {\r\n <mat-form-field appearance=\"outline\" class=\"input-text\">\r\n <textarea rows=\"10\" matInput [formControl]=\"control\" tpSurveyFocusAndSelect></textarea>\r\n </mat-form-field>\r\n\r\n<!-- <mat-form-field class=\"container-controls\" appearance=\"outline\">-->\r\n<!-- <textarea rows=\"10\" autofocus matInput [(ngModel)]=\"answer.AnswerValue\" (ngModelChange)=\"answerChange()\" appFocusAndSelect></textarea>-->\r\n<!-- </mat-form-field>-->\r\n }\r\n\r\n<!-- <mat-form-field appearance=\"outline\" class=\"input-od-number\">-->\r\n<!-- <input [formControl]=\"control\" tpSurveyFocusAndSelect matInput type=\"number\">-->\r\n<!-- </mat-form-field>-->\r\n</div>\r\n", styles: [":host{width:100%}.container-main{display:flex;width:100%;justify-content:center;align-items:center;flex-flow:column;gap:2em;padding:0 2em;box-sizing:border-box}.input-text{width:100%}\n"] }]
39
- }] });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5zd2VyLm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RwLnN1cnZleS9zcmMvbGliL2NvbXBvbmVudC9hbnN3ZXIvYW5zd2VyLm9sL2Fuc3dlci5vbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cC5zdXJ2ZXkvc3JjL2xpYi9jb21wb25lbnQvYW5zd2VyL2Fuc3dlci5vbC9hbnN3ZXIub2wuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQ25FLE9BQU8sRUFBQyxXQUFXLEVBQUUsaUJBQWlCLEVBQUUsbUJBQW1CLEVBQWEsTUFBTSxnQkFBZ0IsQ0FBQztBQUMvRixPQUFPLEVBQUMsWUFBWSxFQUFFLFNBQVMsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3JFLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNqRCxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSxnRUFBZ0UsQ0FBQztBQUN2RyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQzs7O0FBdUIvRSxNQUFNLE9BQU8saUJBQWtCLFNBQVEscUJBQTZCO0lBckJwRTs7UUFzQkUsbUJBQWMsR0FBRSxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7S0FDdkM7OEdBRlksaUJBQWlCO2tHQUFqQixpQkFBaUIsaU9BUmpCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztnQkFDaEQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGlEQzFCSCwyL0JBd0JBLG1QRFhJLHVCQUF1QixvRUFDdkIsV0FBVyx1WkFDWCxZQUFZLDRMQUNaLFFBQVEsZ1VBQ1IsbUJBQW1CLGtOQUNuQixTQUFTOzsyRkFVQSxpQkFBaUI7a0JBckI3QixTQUFTOytCQUNFLHFCQUFxQixjQUduQixJQUFJLFdBQ1A7d0JBQ1AsdUJBQXVCO3dCQUN2QixXQUFXO3dCQUNYLFlBQVk7d0JBQ1osUUFBUTt3QkFDUixtQkFBbUI7d0JBQ25CLFNBQVM7cUJBQ1YsYUFDVTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxrQkFBa0IsQ0FBQzs0QkFDaEQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgZm9yd2FyZFJlZiwgaW5wdXQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Rm9ybXNNb2R1bGUsIE5HX1ZBTFVFX0FDQ0VTU09SLCBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBWYWxpZGF0b3JzfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7TWF0Rm9ybUZpZWxkLCBNYXRQcmVmaXh9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQge01hdElucHV0fSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7Rm9jdXNBbmRTZWxlY3REaXJlY3RpdmV9IGZyb20gJy4uLy4uLy4uL2RpcmVjdGl2ZS9mb2N1cy5hbmQuc2VsZWN0L2ZvY3VzLmFuZC5zZWxlY3QuZGlyZWN0aXZlJztcclxuaW1wb3J0IHtBbnN3ZXJNYXN0ZXJDb21wb25lbnR9IGZyb20gJy4uL2Fuc3dlci5tYXN0ZXIvYW5zd2VyLm1hc3Rlci5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0cC1zdXJ2ZXktYW5zd2VyLW9sJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYW5zd2VyLm9sLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9hbnN3ZXIub2wuY29tcG9uZW50LnNjc3MnXSxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIEZvY3VzQW5kU2VsZWN0RGlyZWN0aXZlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBNYXRGb3JtRmllbGQsXHJcbiAgICBNYXRJbnB1dCxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBNYXRQcmVmaXhcclxuICBdLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gQW5zd2VyT0xDb21wb25lbnQpLFxyXG4gICAgICBtdWx0aTogdHJ1ZVxyXG4gICAgfSxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQW5zd2VyT0xDb21wb25lbnQgZXh0ZW5kcyBBbnN3ZXJNYXN0ZXJDb21wb25lbnQ8bnVtYmVyPntcclxuICB0ZWxlcGhvbmVJbnB1dD0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJjb250YWluZXItbWFpblwiPlxyXG4gQGlmICh0ZWxlcGhvbmVJbnB1dCgpKSB7XHJcbiAgPG1hdC1mb3JtLWZpZWxkIGFwcGVhcmFuY2U9XCJvdXRsaW5lXCI+XHJcbiAgIDxpbnB1dFxyXG4gICAgIHR5cGU9XCJ0ZXh0XCJcclxuICAgICBpbnB1dG1vZGU9XCJudW1lcmljXCJcclxuICAgICBtYXRJbnB1dFxyXG4gICAgIFtmb3JtQ29udHJvbF09XCJjb250cm9sXCIgdHBTdXJ2ZXlGb2N1c0FuZFNlbGVjdD5cclxuICAgIDxzcGFuIG1hdFRleHRQcmVmaXg+KzM4MCAmbmJzcDs8L3NwYW4+XHJcbiAgPC9tYXQtZm9ybS1maWVsZD5cclxuIH0gQGVsc2Uge1xyXG4gICAgPG1hdC1mb3JtLWZpZWxkICBhcHBlYXJhbmNlPVwib3V0bGluZVwiIGNsYXNzPVwiaW5wdXQtdGV4dFwiPlxyXG4gICAgICA8dGV4dGFyZWEgcm93cz1cIjEwXCIgbWF0SW5wdXQgW2Zvcm1Db250cm9sXT1cImNvbnRyb2xcIiB0cFN1cnZleUZvY3VzQW5kU2VsZWN0PjwvdGV4dGFyZWE+XHJcbiAgICAgPC9tYXQtZm9ybS1maWVsZD5cclxuXHJcbjwhLS0gIDxtYXQtZm9ybS1maWVsZCBjbGFzcz1cImNvbnRhaW5lci1jb250cm9sc1wiIGFwcGVhcmFuY2U9XCJvdXRsaW5lXCI+LS0+XHJcbjwhLS0gICA8dGV4dGFyZWEgcm93cz1cIjEwXCIgYXV0b2ZvY3VzIG1hdElucHV0ICBbKG5nTW9kZWwpXT1cImFuc3dlci5BbnN3ZXJWYWx1ZVwiIChuZ01vZGVsQ2hhbmdlKT1cImFuc3dlckNoYW5nZSgpXCIgYXBwRm9jdXNBbmRTZWxlY3Q+PC90ZXh0YXJlYT4tLT5cclxuPCEtLSAgPC9tYXQtZm9ybS1maWVsZD4tLT5cclxuIH1cclxuXHJcbjwhLS0gPG1hdC1mb3JtLWZpZWxkIGFwcGVhcmFuY2U9XCJvdXRsaW5lXCIgY2xhc3M9XCJpbnB1dC1vZC1udW1iZXJcIj4tLT5cclxuPCEtLSAgPGlucHV0IFtmb3JtQ29udHJvbF09XCJjb250cm9sXCIgdHBTdXJ2ZXlGb2N1c0FuZFNlbGVjdCBtYXRJbnB1dCB0eXBlPVwibnVtYmVyXCI+LS0+XHJcbjwhLS0gPC9tYXQtZm9ybS1maWVsZD4tLT5cclxuPC9kaXY+XHJcbiJdfQ==
@@ -1,131 +0,0 @@
1
- import { booleanAttribute, Component, forwardRef, input, numberAttribute } from '@angular/core';
2
- import { FormArray, FormControl, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
3
- import { MatCheckbox } from '@angular/material/checkbox';
4
- import { JsonPipe, KeyValuePipe } from '@angular/common';
5
- import { MatIcon } from '@angular/material/icon';
6
- import { MatRadioButton, MatRadioGroup } from '@angular/material/radio';
7
- import { map } from 'rxjs/operators';
8
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
9
- import { filter, tap } from 'rxjs';
10
- import { MultiLangObjectToHtmlPipe } from '../../../pipe/multi.lang.object.to.html/multi.lang.object.to.html.pipe';
11
- import { AsFormArrayPipe } from './pipe/as.form.array/as.form.array.pipe';
12
- import { AsFormControlPipe } from './pipe/as.form.control/as.form.control.pipe';
13
- import { AnswerMasterComponent } from '../answer.master/answer.master.component';
14
- import * as i0 from "@angular/core";
15
- import * as i1 from "@angular/forms";
16
- export class AnswerSLComponent extends AnswerMasterComponent {
17
- constructor() {
18
- super(...arguments);
19
- this.alternativeList = input.required();
20
- this.sectionList = input.required();
21
- this.multiSelect = input(false, { transform: booleanAttribute });
22
- this.maxCount = input(0, { transform: numberAttribute });
23
- this.answerSLForm = new FormGroup({});
24
- }
25
- ngOnInit() {
26
- const multiSelect = this.multiSelect();
27
- this.sectionList().forEach(section => {
28
- const sectionControl = this.#createSectionRowControl(multiSelect, []);
29
- this.answerSLForm.addControl(section.SectionGuid.toString(), sectionControl);
30
- });
31
- this.answerSLForm.valueChanges.pipe(map((fullAnswer) => {
32
- let res = {};
33
- //Если в настройках указали мультивыбор для секции, то в данной реализации, при изменении форма возвращает массив boolean?, true/false, нажата отжата.
34
- //Этот массив нужно конвертировать в массив number, в котором будут только нажатые альтернативы.
35
- if (this.multiSelect()) {
36
- Object.entries(fullAnswer).forEach(([key]) => {
37
- const sectionAnswerCheckedArray = this.answerSLForm.get(key)?.value;
38
- res[key] = this.alternativeList()
39
- .map(alt => alt.Value)
40
- .filter((_, index) => sectionAnswerCheckedArray[index]);
41
- });
42
- }
43
- else {
44
- //если единичный выбор для секции, то ответ просто исходное значение.
45
- res = fullAnswer;
46
- }
47
- return res;
48
- }), tap(res => this.#disableExtraControls(this.maxCount())), takeUntilDestroyed(this.destroyRef)).subscribe({
49
- next: res => this.control.patchValue(res, { emitEvent: true })
50
- });
51
- }
52
- #createSectionRowControl(multiSelect, answers) {
53
- if (multiSelect) {
54
- const msArray = new FormArray([]);
55
- const answerAsArray = Array(answers);
56
- this.alternativeList().forEach((alt) => {
57
- const control = new FormControl(answerAsArray.includes(alt.Value), { nonNullable: true });
58
- msArray.push(control, { emitEvent: false });
59
- //В режиме multiSelect у альтернативы есть понятие "Группа". Группа это число. Если выбирают альтернативу с определённой группой, то альтернативы с другой группой должны быть отжаты.
60
- //Логика такая же как и в ms вопросе
61
- control.valueChanges.pipe(filter(value => value && this.multiSelect()), takeUntilDestroyed(this.destroyRef)).subscribe({
62
- next: () => {
63
- //сначала отбираем контролы у которых другая группа.
64
- const otherGroupAlternativesList = this.alternativeList()
65
- .map((alt, altIndex) => ({ alternative: alt, index: altIndex })) //нужен индекс, по нему проще выбирать контролы в msArray
66
- .filter(data => data.alternative.GroupNo !== alt.GroupNo); //контролы у которых другая группа
67
- //"отжимаем галочку"
68
- otherGroupAlternativesList.forEach(data => {
69
- const altControl = msArray.controls.at(data.index);
70
- altControl.patchValue(false, { emitEvent: false });
71
- });
72
- }
73
- });
74
- });
75
- return msArray;
76
- }
77
- else {
78
- return new FormControl(Number(answers), { nonNullable: true });
79
- }
80
- }
81
- //дизейблит контроли если выбрали максимальное количество или енейблит если выбрали не максимальное количество
82
- #disableExtraControls(maxCount) {
83
- //если в настройках анкеты указали что максимальное возможное количество выбранных альтернатив = 0, но ничего контролировать не надо.
84
- if (maxCount === 0 || !this.multiSelect()) {
85
- return;
86
- }
87
- this.sectionList().forEach(sec => {
88
- const sectionControlArray = this.answerSLForm.get(sec.SectionGuid.toString());
89
- const values = sectionControlArray.value;
90
- const checkedCount = values.filter(v => v).length;
91
- sectionControlArray.controls.forEach(control => {
92
- if (checkedCount >= maxCount && !control.value) {
93
- control.disable({ emitEvent: false });
94
- }
95
- else {
96
- control.enable({ emitEvent: false });
97
- }
98
- });
99
- });
100
- }
101
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerSLComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
102
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: AnswerSLComponent, isStandalone: true, selector: "tp-survey-answer-sl", inputs: { alternativeList: { classPropertyName: "alternativeList", publicName: "alternativeList", isSignal: true, isRequired: true, transformFunction: null }, sectionList: { classPropertyName: "sectionList", publicName: "sectionList", isSignal: true, isRequired: true, transformFunction: null }, multiSelect: { classPropertyName: "multiSelect", publicName: "multiSelect", isSignal: true, isRequired: false, transformFunction: null }, maxCount: { classPropertyName: "maxCount", publicName: "maxCount", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
103
- {
104
- provide: NG_VALUE_ACCESSOR,
105
- useExisting: forwardRef(() => AnswerSLComponent),
106
- multi: true
107
- },
108
- ], usesInheritance: true, ngImport: i0, template: "<table class=\"default-view\" [formGroup]=\"answerSLForm\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <th class=\"SLAlternativeCaption\">\r\n <span [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n @for (secControl of answerSLForm.controls | keyvalue; track secControl.key; let sectionIndex = $index) {\r\n @if (multiSelect()){\r\n <tr>\r\n <td>\r\n <span [innerHTML]= \"sectionList()[sectionIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n </td>\r\n @for (alternativeControl of (secControl.value | asFormArray).controls ; track alternativeControl) {\r\n <td>\r\n <mat-checkbox\r\n [formControl]=\"alternativeControl\"\r\n class=\"alternative-sl tp-survey-checkbox\"/>\r\n </td>\r\n }\r\n </tr>\r\n } @else {\r\n <mat-radio-group [formControl]=\"secControl.value | asFormControl\" class=\"single-select-row\">\r\n <td class=\"single-select-item\">\r\n <span [innerHTML]= \"sectionList()[sectionIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n </td>\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <td class=\"single-select-item\">\r\n <mat-radio-button\r\n class=\"alternative-sl tp-survey-radio-button\"\r\n [value]=\"alt.Value\">\r\n </mat-radio-button>\r\n </td>\r\n }\r\n </mat-radio-group>\r\n }\r\n }\r\n </tbody>\r\n</table>\r\n\r\n<div class=\"mobile-view\" [formGroup]=\"answerSLForm\">\r\n @for (secControl of answerSLForm.controls | keyvalue; track secControl.key; let secIndex = $index) {\r\n <div class=\"mobile-view-section-row\" [formArrayName]=\"secControl.key\">\r\n <span [innerHTML]= \"sectionList()[secIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"mobile-view-section-caption section-sl-caption survey-object-caption\"></span>\r\n @if (multiSelect()) {\r\n <div class=\"mobile-view-alternative-list\">\r\n @for (alternativeControl of (secControl.value | asFormArray).controls; track alternativeControl; let altIndex = $index) {\r\n <mat-checkbox\r\n [formControl]=\"alternativeControl\"\r\n class=\"alternative-sl tp-survey-checkbox\">\r\n <span class=\"alternative-sl-caption survey-object-caption\" [innerHTML]= \"alternativeList()[altIndex].MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </mat-checkbox>\r\n }\r\n </div>\r\n } @else {\r\n <mat-radio-group\r\n class=\"mobile-view-alternative-list\"\r\n [formControl]=\"secControl.value | asFormControl\">\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <mat-radio-button\r\n class=\"tp-survey-radio-button\"\r\n [value]=\"alt.Value\">\r\n <span class=\"alternative-sl-caption survey-object-caption\" [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </mat-radio-button>\r\n }\r\n </mat-radio-group>\r\n }\r\n </div>\r\n }\r\n</div>\r\n", styles: ["td{text-align:center}table{width:100%}tr td{border-bottom:1px solid rgba(102,102,103,.49)}.default-view{display:block}.mobile-view{display:none;padding:1em;flex-flow:column;gap:4em}.mobile-view-alternative-list{display:flex;flex-flow:column}.mobile-view-section-row{margin-bottom:2em}.mobile-view-section-caption{display:block;border-bottom:1px solid}.section-sl-caption{font-size:1.3em}.alternative-sl-caption{font-size:1.1em}.single-select-row{display:table-row;vertical-align:middle;border-bottom:1px solid rgba(102,102,103,.49)}.single-select-item{vertical-align:middle;border-bottom:1px solid rgba(102,102,103,.49)}@media (max-width: 480px){.default-view{display:none}.mobile-view{display:block}}\n"], dependencies: [{ kind: "pipe", type: MultiLangObjectToHtmlPipe, name: "multiLangObjectToHtml" }, { kind: "component", type: MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "pipe", type: KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: AsFormArrayPipe, name: "asFormArray" }, { kind: "component", type: MatRadioButton, selector: "mat-radio-button", inputs: ["id", "name", "aria-label", "aria-labelledby", "aria-describedby", "disableRipple", "tabIndex", "checked", "value", "labelPosition", "disabled", "required", "color"], outputs: ["change"], exportAs: ["matRadioButton"] }, { kind: "directive", type: MatRadioGroup, selector: "mat-radio-group", inputs: ["color", "name", "labelPosition", "value", "selected", "disabled", "required"], outputs: ["change"], exportAs: ["matRadioGroup"] }, { kind: "pipe", type: AsFormControlPipe, name: "asFormControl" }] }); }
109
- }
110
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AnswerSLComponent, decorators: [{
111
- type: Component,
112
- args: [{ selector: 'tp-survey-answer-sl', standalone: true, imports: [
113
- MultiLangObjectToHtmlPipe,
114
- MatCheckbox,
115
- ReactiveFormsModule,
116
- KeyValuePipe,
117
- MatIcon,
118
- JsonPipe,
119
- AsFormArrayPipe,
120
- MatRadioButton,
121
- MatRadioGroup,
122
- AsFormControlPipe
123
- ], providers: [
124
- {
125
- provide: NG_VALUE_ACCESSOR,
126
- useExisting: forwardRef(() => AnswerSLComponent),
127
- multi: true
128
- },
129
- ], template: "<table class=\"default-view\" [formGroup]=\"answerSLForm\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <th class=\"SLAlternativeCaption\">\r\n <span [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n @for (secControl of answerSLForm.controls | keyvalue; track secControl.key; let sectionIndex = $index) {\r\n @if (multiSelect()){\r\n <tr>\r\n <td>\r\n <span [innerHTML]= \"sectionList()[sectionIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n </td>\r\n @for (alternativeControl of (secControl.value | asFormArray).controls ; track alternativeControl) {\r\n <td>\r\n <mat-checkbox\r\n [formControl]=\"alternativeControl\"\r\n class=\"alternative-sl tp-survey-checkbox\"/>\r\n </td>\r\n }\r\n </tr>\r\n } @else {\r\n <mat-radio-group [formControl]=\"secControl.value | asFormControl\" class=\"single-select-row\">\r\n <td class=\"single-select-item\">\r\n <span [innerHTML]= \"sectionList()[sectionIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n </td>\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <td class=\"single-select-item\">\r\n <mat-radio-button\r\n class=\"alternative-sl tp-survey-radio-button\"\r\n [value]=\"alt.Value\">\r\n </mat-radio-button>\r\n </td>\r\n }\r\n </mat-radio-group>\r\n }\r\n }\r\n </tbody>\r\n</table>\r\n\r\n<div class=\"mobile-view\" [formGroup]=\"answerSLForm\">\r\n @for (secControl of answerSLForm.controls | keyvalue; track secControl.key; let secIndex = $index) {\r\n <div class=\"mobile-view-section-row\" [formArrayName]=\"secControl.key\">\r\n <span [innerHTML]= \"sectionList()[secIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"mobile-view-section-caption section-sl-caption survey-object-caption\"></span>\r\n @if (multiSelect()) {\r\n <div class=\"mobile-view-alternative-list\">\r\n @for (alternativeControl of (secControl.value | asFormArray).controls; track alternativeControl; let altIndex = $index) {\r\n <mat-checkbox\r\n [formControl]=\"alternativeControl\"\r\n class=\"alternative-sl tp-survey-checkbox\">\r\n <span class=\"alternative-sl-caption survey-object-caption\" [innerHTML]= \"alternativeList()[altIndex].MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </mat-checkbox>\r\n }\r\n </div>\r\n } @else {\r\n <mat-radio-group\r\n class=\"mobile-view-alternative-list\"\r\n [formControl]=\"secControl.value | asFormControl\">\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <mat-radio-button\r\n class=\"tp-survey-radio-button\"\r\n [value]=\"alt.Value\">\r\n <span class=\"alternative-sl-caption survey-object-caption\" [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </mat-radio-button>\r\n }\r\n </mat-radio-group>\r\n }\r\n </div>\r\n }\r\n</div>\r\n", styles: ["td{text-align:center}table{width:100%}tr td{border-bottom:1px solid rgba(102,102,103,.49)}.default-view{display:block}.mobile-view{display:none;padding:1em;flex-flow:column;gap:4em}.mobile-view-alternative-list{display:flex;flex-flow:column}.mobile-view-section-row{margin-bottom:2em}.mobile-view-section-caption{display:block;border-bottom:1px solid}.section-sl-caption{font-size:1.3em}.alternative-sl-caption{font-size:1.1em}.single-select-row{display:table-row;vertical-align:middle;border-bottom:1px solid rgba(102,102,103,.49)}.single-select-item{vertical-align:middle;border-bottom:1px solid rgba(102,102,103,.49)}@media (max-width: 480px){.default-view{display:none}.mobile-view{display:block}}\n"] }]
130
- }] });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"answer.sl.component.js","sourceRoot":"","sources":["../../../../../../../projects/tp.survey/src/lib/component/answer/answer.sl/answer.sl.component.ts","../../../../../../../projects/tp.survey/src/lib/component/answer/answer.sl/answer.sl.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,eAAe,EAAS,MAAM,eAAe,CAAC;AACtG,OAAO,EAAC,SAAS,EAAE,WAAW,EAAE,SAAS,EAAE,iBAAiB,EAAE,mBAAmB,EAAC,MAAM,gBAAgB,CAAC;AACzG,OAAO,EAAC,WAAW,EAAC,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAC,QAAQ,EAAE,YAAY,EAAC,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAC,OAAO,EAAC,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAC,cAAc,EAAE,aAAa,EAAC,MAAM,yBAAyB,CAAC;AACtE,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AACnC,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAC,MAAM,EAAE,GAAG,EAAC,MAAM,MAAM,CAAC;AACjC,OAAO,EAAC,yBAAyB,EAAC,MAAM,wEAAwE,CAAC;AACjH,OAAO,EAAC,eAAe,EAAC,MAAM,yCAAyC,CAAC;AACxE,OAAO,EAAC,iBAAiB,EAAC,MAAM,6CAA6C,CAAC;AAC9E,OAAO,EAAC,qBAAqB,EAAC,MAAM,0CAA0C,CAAC;;;AAiC/E,MAAM,OAAO,iBAAkB,SAAQ,qBAAmC;IAzB1E;;QA0BE,oBAAe,GAAG,KAAK,CAAC,QAAQ,EAAyB,CAAC;QAC1D,gBAAW,GAAG,KAAK,CAAC,QAAQ,EAAqB,CAAC;QAClD,gBAAW,GAAG,KAAK,CAAC,KAAK,EAAE,EAAC,SAAS,EAAE,gBAAgB,EAAC,CAAC,CAAC;QAC1D,aAAQ,GAAG,KAAK,CAAC,CAAC,EAAE,EAAC,SAAS,EAAE,eAAe,EAAC,CAAC,CAAC;QAClD,iBAAY,GAAG,IAAI,SAAS,CAAgB,EAAE,CAAC,CAAA;KA4FhD;IA1FC,QAAQ;QACN,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAEvC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACnC,MAAM,cAAc,GAAG,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;YACtE,IAAI,CAAC,YAAa,CAAC,UAAU,CAAC,OAAO,CAAC,WAAW,CAAC,QAAQ,EAAE,EAAE,cAAc,CAAG,CAAC;QAClF,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAClC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;YACjB,IAAI,GAAG,GAA2C,EAAE,CAAC;YACrD,sJAAsJ;YACtJ,gGAAgG;YAChG,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;gBACvB,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE;oBAC3C,MAAM,yBAAyB,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC;oBACpE,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE;yBAC/B,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC;yBACrB,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAE,CAAA;gBAC3D,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,qEAAqE;gBACrE,GAAG,GAAG,UAAoC,CAAC;YAC7C,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,EACvD,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CACnC,CAAC,SAAS,CAAC;YACV,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,EAAE,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC;SAC7D,CAAC,CAAA;IACJ,CAAC;IAED,wBAAwB,CAAC,WAAoB,EAAE,OAA+B;QAC5E,IAAI,WAAW,EAAE,CAAC;YAChB,MAAM,OAAO,GAAG,IAAI,SAAS,CAAuB,EAAE,CAAC,CAAC;YACxD,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC;YAErC,IAAI,CAAC,eAAe,EAAE,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBACrC,MAAM,OAAO,GAAE,IAAI,WAAW,CAAW,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,CAAC,CAAC;gBACjG,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;gBAE1C,sLAAsL;gBACtL,oCAAoC;gBACpC,OAAO,CAAC,YAAY,CAAC,IAAI,CACxB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,EAC5C,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CACnC,CAAC,SAAS,CAAC;oBACV,IAAI,EAAE,GAAG,EAAE;wBACT,oDAAoD;wBACpD,MAAM,0BAA0B,GAAG,IAAI,CAAC,eAAe,EAAE;6BACvD,GAAG,CAAC,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAC,WAAW,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAC,CAAC,CAAE,CAAE,yDAAyD;6BACzH,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,KAAK,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,kCAAkC;wBAE9F,oBAAoB;wBACpB,0BAA0B,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;4BACxC,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;4BACnD,UAAW,CAAC,UAAU,CAAC,KAAK,EAAE,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAA;wBACnD,CAAC,CAAC,CAAC;oBACL,CAAC;iBACF,CAAC,CAAA;YACJ,CAAC,CAAC,CAAC;YACH,OAAO,OAAO,CAAC;QACjB,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,WAAW,CAAS,MAAM,CAAC,OAAO,CAAC,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,CAAC,CAAC;QACvE,CAAC;IACH,CAAC;IAED,8GAA8G;IAC9G,qBAAqB,CAAC,QAAgB;QACpC,qIAAqI;QACrI,IAAI,QAAQ,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YAC1C,OAAM;QACR,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YAC/B,MAAM,mBAAmB,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAoC,CAAC;YACjH,MAAM,MAAM,GAAG,mBAAmB,CAAC,KAAK,CAAC;YACzC,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;YAElD,mBAAmB,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC7C,IAAI,YAAY,IAAI,QAAQ,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;oBAC/C,OAAO,CAAC,OAAO,CAAC,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAA;gBACrC,CAAC;qBAAM,CAAC;oBACN,OAAO,CAAC,MAAM,CAAC,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAA;gBACpC,CAAC;YACH,CAAC,CAAC,CAAA;QAEJ,CAAC,CAAC,CAAA;IACJ,CAAC;8GAhGU,iBAAiB;kGAAjB,iBAAiB,unBARjB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;gBAChD,KAAK,EAAE,IAAI;aACZ;SACF,iDC3CH,kuGA2EA,ovBDjDI,yBAAyB,8DACzB,WAAW,gUACX,mBAAmB,ysBACnB,YAAY,4CAGZ,eAAe,oDACf,cAAc,gSACd,aAAa,kMACb,iBAAiB;;2FAUR,iBAAiB;kBAzB7B,SAAS;+BACE,qBAAqB,cAGnB,IAAI,WACP;wBACP,yBAAyB;wBACzB,WAAW;wBACX,mBAAmB;wBACnB,YAAY;wBACZ,OAAO;wBACP,QAAQ;wBACR,eAAe;wBACf,cAAc;wBACd,aAAa;wBACb,iBAAiB;qBAClB,aACU;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;4BAChD,KAAK,EAAE,IAAI;yBACZ;qBACF","sourcesContent":["import {booleanAttribute, Component, forwardRef, input, numberAttribute, OnInit} from '@angular/core';\r\nimport {FormArray, FormControl, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\r\nimport {MatCheckbox} from '@angular/material/checkbox';\r\nimport {JsonPipe, KeyValuePipe} from '@angular/common';\r\nimport {MatIcon} from '@angular/material/icon';\r\nimport {MatRadioButton, MatRadioGroup} from '@angular/material/radio';\r\nimport {map} from 'rxjs/operators';\r\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\r\nimport {filter, tap} from 'rxjs';\r\nimport {MultiLangObjectToHtmlPipe} from '../../../pipe/multi.lang.object.to.html/multi.lang.object.to.html.pipe';\r\nimport {AsFormArrayPipe} from './pipe/as.form.array/as.form.array.pipe';\r\nimport {AsFormControlPipe} from './pipe/as.form.control/as.form.control.pipe';\r\nimport {AnswerMasterComponent} from '../answer.master/answer.master.component';\r\nimport {AnswerSlType} from '../../../tp.survey.type';\r\nimport {IdbAlternative, IdbSection} from '../../../tp.survey.interface';\r\n\r\ninterface IAnswerSLForm {\r\n  [key: string]: FormArray<FormControl<boolean>> | FormControl<number> | FormControl<Array<number>>\r\n}\r\n\r\n@Component({\r\n  selector: 'tp-survey-answer-sl',\r\n  templateUrl: './answer.sl.component.html',\r\n  styleUrls: ['./answer.sl.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    MultiLangObjectToHtmlPipe,\r\n    MatCheckbox,\r\n    ReactiveFormsModule,\r\n    KeyValuePipe,\r\n    MatIcon,\r\n    JsonPipe,\r\n    AsFormArrayPipe,\r\n    MatRadioButton,\r\n    MatRadioGroup,\r\n    AsFormControlPipe\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AnswerSLComponent),\r\n      multi: true\r\n    },\r\n  ],\r\n})\r\nexport class AnswerSLComponent extends AnswerMasterComponent<AnswerSlType> implements OnInit{\r\n  alternativeList = input.required<Array<IdbAlternative>>();\r\n  sectionList = input.required<Array<IdbSection>>();\r\n  multiSelect = input(false, {transform: booleanAttribute});\r\n  maxCount = input(0, {transform: numberAttribute});\r\n  answerSLForm = new FormGroup<IAnswerSLForm>({})\r\n\r\n  ngOnInit(): void {\r\n    const multiSelect = this.multiSelect();\r\n\r\n    this.sectionList().forEach(section => {\r\n      const sectionControl = this.#createSectionRowControl(multiSelect, []);\r\n      this.answerSLForm!.addControl(section.SectionGuid.toString(), sectionControl, );\r\n    })\r\n\r\n    this.answerSLForm.valueChanges.pipe(\r\n     map((fullAnswer) => {\r\n       let res: Record<string, Array<number> | number> = {};\r\n       //Если в настройках указали мультивыбор для секции, то в данной реализации, при изменении форма возвращает массив boolean?, true/false, нажата отжата.\r\n       //Этот массив нужно конвертировать в массив number, в котором будут только нажатые альтернативы.\r\n       if (this.multiSelect()) {\r\n         Object.entries(fullAnswer).forEach(([key]) => {\r\n           const sectionAnswerCheckedArray = this.answerSLForm.get(key)?.value;\r\n           res[key] = this.alternativeList()\r\n            .map(alt => alt.Value)\r\n            .filter((_, index) => sectionAnswerCheckedArray[index] )\r\n         });\r\n       } else {\r\n         //если единичный выбор для секции, то ответ просто исходное значение.\r\n         res = fullAnswer as Record<string, number>;\r\n       }\r\n       return res;\r\n     }),\r\n     tap(res => this.#disableExtraControls(this.maxCount())),\r\n     takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe({\r\n      next: res => this.control.patchValue(res, {emitEvent: true})\r\n    })\r\n  }\r\n\r\n  #createSectionRowControl(multiSelect: boolean, answers: number | Array<number>): FormArray<FormControl<boolean>> | FormControl<number> {\r\n    if (multiSelect) {\r\n      const msArray = new FormArray<FormControl<boolean>>([]);\r\n      const answerAsArray = Array(answers);\r\n      \r\n      this.alternativeList().forEach((alt) => {\r\n        const control= new FormControl<boolean>( answerAsArray.includes(alt.Value), {nonNullable: true});\r\n        msArray.push(control, {emitEvent: false});\r\n\r\n        //В режиме multiSelect у альтернативы есть понятие \"Группа\". Группа это число. Если выбирают альтернативу с определённой группой, то альтернативы с другой группой должны быть отжаты.\r\n        //Логика такая же как и в ms вопросе\r\n        control.valueChanges.pipe(\r\n         filter(value => value && this.multiSelect()),\r\n         takeUntilDestroyed(this.destroyRef),\r\n        ).subscribe({\r\n          next: () => {\r\n            //сначала отбираем контролы у которых другая группа.\r\n            const otherGroupAlternativesList = this.alternativeList()\r\n             .map((alt, altIndex) => ({alternative: alt, index: altIndex}) )  //нужен индекс, по нему проще выбирать контролы в msArray\r\n             .filter(data => data.alternative.GroupNo !== alt.GroupNo); //контролы у которых другая группа\r\n\r\n            //\"отжимаем галочку\"\r\n            otherGroupAlternativesList.forEach(data => {\r\n              const altControl = msArray.controls.at(data.index);\r\n              altControl!.patchValue(false, {emitEvent: false})\r\n            });\r\n          }\r\n        })\r\n      });\r\n      return msArray;\r\n    } else {\r\n      return new FormControl<number>(Number(answers), {nonNullable: true});\r\n    }\r\n  }\r\n\r\n  //дизейблит контроли если выбрали максимальное количество или енейблит если выбрали не максимальное количество\r\n  #disableExtraControls(maxCount: number): void{\r\n    //если в настройках анкеты указали что максимальное возможное количество выбранных альтернатив = 0, но ничего контролировать не надо.\r\n    if (maxCount === 0 || !this.multiSelect()) {\r\n      return\r\n    }\r\n\r\n    this.sectionList().forEach(sec => {\r\n      const sectionControlArray = this.answerSLForm.get(sec.SectionGuid.toString()) as FormArray<FormControl<boolean>>;\r\n      const values = sectionControlArray.value;\r\n      const checkedCount = values.filter(v => v).length;\r\n\r\n      sectionControlArray.controls.forEach(control => {\r\n        if (checkedCount >= maxCount && !control.value) {\r\n          control.disable({emitEvent: false})\r\n        } else {\r\n          control.enable({emitEvent: false})\r\n        }\r\n      })\r\n\r\n    })\r\n  }\r\n}\r\n","<table class=\"default-view\" [formGroup]=\"answerSLForm\">\r\n <thead>\r\n <tr>\r\n  <th></th>\r\n  @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n   <th class=\"SLAlternativeCaption\">\r\n    <span [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n   </th>\r\n  }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n  @for (secControl of answerSLForm.controls | keyvalue; track secControl.key; let sectionIndex = $index) {\r\n   @if (multiSelect()){\r\n    <tr>\r\n     <td>\r\n      <span [innerHTML]= \"sectionList()[sectionIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n     </td>\r\n     @for (alternativeControl of (secControl.value | asFormArray).controls ; track alternativeControl) {\r\n      <td>\r\n       <mat-checkbox\r\n        [formControl]=\"alternativeControl\"\r\n        class=\"alternative-sl tp-survey-checkbox\"/>\r\n      </td>\r\n     }\r\n    </tr>\r\n   } @else {\r\n    <mat-radio-group [formControl]=\"secControl.value | asFormControl\" class=\"single-select-row\">\r\n     <td class=\"single-select-item\">\r\n      <span [innerHTML]= \"sectionList()[sectionIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"survey-object-caption\"></span>\r\n     </td>\r\n     @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n      <td class=\"single-select-item\">\r\n       <mat-radio-button\r\n        class=\"alternative-sl  tp-survey-radio-button\"\r\n        [value]=\"alt.Value\">\r\n       </mat-radio-button>\r\n      </td>\r\n     }\r\n    </mat-radio-group>\r\n   }\r\n  }\r\n </tbody>\r\n</table>\r\n\r\n<div class=\"mobile-view\" [formGroup]=\"answerSLForm\">\r\n @for (secControl of answerSLForm.controls | keyvalue; track secControl.key; let secIndex = $index) {\r\n  <div class=\"mobile-view-section-row\" [formArrayName]=\"secControl.key\">\r\n   <span [innerHTML]= \"sectionList()[secIndex].MultiLangCaptions | multiLangObjectToHtml:language()\" class=\"mobile-view-section-caption section-sl-caption survey-object-caption\"></span>\r\n   @if (multiSelect()) {\r\n    <div class=\"mobile-view-alternative-list\">\r\n     @for (alternativeControl of (secControl.value | asFormArray).controls; track alternativeControl; let altIndex = $index) {\r\n      <mat-checkbox\r\n       [formControl]=\"alternativeControl\"\r\n       class=\"alternative-sl tp-survey-checkbox\">\r\n       <span class=\"alternative-sl-caption survey-object-caption\" [innerHTML]= \"alternativeList()[altIndex].MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n      </mat-checkbox>\r\n     }\r\n    </div>\r\n   } @else {\r\n    <mat-radio-group\r\n     class=\"mobile-view-alternative-list\"\r\n     [formControl]=\"secControl.value | asFormControl\">\r\n     @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n      <mat-radio-button\r\n       class=\"tp-survey-radio-button\"\r\n       [value]=\"alt.Value\">\r\n       <span class=\"alternative-sl-caption survey-object-caption\" [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n      </mat-radio-button>\r\n     }\r\n    </mat-radio-group>\r\n   }\r\n  </div>\r\n }\r\n</div>\r\n"]}
@@ -1,17 +0,0 @@
1
- import { Pipe } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class AsFormArrayPipe {
4
- transform(value) {
5
- return value;
6
- }
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AsFormArrayPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
8
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.0.1", ngImport: i0, type: AsFormArrayPipe, isStandalone: true, name: "asFormArray" }); }
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AsFormArrayPipe, decorators: [{
11
- type: Pipe,
12
- args: [{
13
- name: 'asFormArray',
14
- standalone: true
15
- }]
16
- }] });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXMuZm9ybS5hcnJheS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHAuc3VydmV5L3NyYy9saWIvY29tcG9uZW50L2Fuc3dlci9hbnN3ZXIuc2wvcGlwZS9hcy5mb3JtLmFycmF5L2FzLmZvcm0uYXJyYXkucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsSUFBSSxFQUFnQixNQUFNLGVBQWUsQ0FBQzs7QUFPbEQsTUFBTSxPQUFPLGVBQWU7SUFFMUIsU0FBUyxDQUFDLEtBQVU7UUFDbEIsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDOzhHQUpVLGVBQWU7NEdBQWYsZUFBZTs7MkZBQWYsZUFBZTtrQkFKM0IsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsYUFBYTtvQkFDbkIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtQaXBlLCBQaXBlVHJhbnNmb3JtfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtGb3JtQXJyYXksIEZvcm1Db250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5AUGlwZSh7XHJcbiAgbmFtZTogJ2FzRm9ybUFycmF5JyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBc0Zvcm1BcnJheVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuXHJcbiAgdHJhbnNmb3JtKHZhbHVlOiBhbnkpOiBGb3JtQXJyYXk8Rm9ybUNvbnRyb2w8Ym9vbGVhbj4+IHtcclxuICAgIHJldHVybiB2YWx1ZTtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
@@ -1,17 +0,0 @@
1
- import { Pipe } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class AsFormControlPipe {
4
- transform(value) {
5
- return value;
6
- }
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AsFormControlPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
8
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.0.1", ngImport: i0, type: AsFormControlPipe, isStandalone: true, name: "asFormControl" }); }
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AsFormControlPipe, decorators: [{
11
- type: Pipe,
12
- args: [{
13
- name: 'asFormControl',
14
- standalone: true
15
- }]
16
- }] });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXMuZm9ybS5jb250cm9sLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cC5zdXJ2ZXkvc3JjL2xpYi9jb21wb25lbnQvYW5zd2VyL2Fuc3dlci5zbC9waXBlL2FzLmZvcm0uY29udHJvbC9hcy5mb3JtLmNvbnRyb2wucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsSUFBSSxFQUFnQixNQUFNLGVBQWUsQ0FBQzs7QUFPbEQsTUFBTSxPQUFPLGlCQUFpQjtJQUU1QixTQUFTLENBQUMsS0FBVTtRQUNsQixPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7OEdBSlUsaUJBQWlCOzRHQUFqQixpQkFBaUI7OzJGQUFqQixpQkFBaUI7a0JBSjdCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLGVBQWU7b0JBQ3JCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7UGlwZSwgUGlwZVRyYW5zZm9ybX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Rm9ybUNvbnRyb2x9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnYXNGb3JtQ29udHJvbCcsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXNGb3JtQ29udHJvbFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuICBcclxuICB0cmFuc2Zvcm0odmFsdWU6IGFueSk6IEZvcm1Db250cm9sPG51bWJlcj4ge1xyXG4gICAgcmV0dXJuIHZhbHVlO1xyXG4gIH1cclxuXHJcbn1cclxuIl19