@touchpoll/tp-survey 0.0.1
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/README.md +24 -0
- package/esm2022/lib/component/answer/answer.additional/answer.additional.component.mjs +49 -0
- package/esm2022/lib/component/answer/answer.additional/directive/additional.answer.caption.position/additional.answer.caption.position.directive.mjs +61 -0
- package/esm2022/lib/component/answer/answer.end/answer.end.component.mjs +30 -0
- package/esm2022/lib/component/answer/answer.info/answer.info.component.mjs +30 -0
- package/esm2022/lib/component/answer/answer.lang/answer.lang.component.mjs +22 -0
- package/esm2022/lib/component/answer/answer.master/answer.master.component.mjs +55 -0
- package/esm2022/lib/component/answer/answer.ms/answer.ms.component.mjs +106 -0
- package/esm2022/lib/component/answer/answer.od/answer.od.component.mjs +39 -0
- package/esm2022/lib/component/answer/answer.ol/answer.ol.component.mjs +39 -0
- package/esm2022/lib/component/answer/answer.sl/answer.sl.component.mjs +131 -0
- package/esm2022/lib/component/answer/answer.sl/pipe/as.form.array/as.form.array.pipe.mjs +17 -0
- package/esm2022/lib/component/answer/answer.sl/pipe/as.form.control/as.form.control.pipe.mjs +17 -0
- package/esm2022/lib/component/answer/answer.ss/answer.ss.component.mjs +51 -0
- package/esm2022/lib/component/answer/container.answer/container.answer.component.mjs +317 -0
- package/esm2022/lib/component/answer/container.answer/container.answer.validator.mjs +124 -0
- package/esm2022/lib/component/navigation.button/navigation.button.component.mjs +21 -0
- package/esm2022/lib/component/question.caption/question.caption.component.mjs +15 -0
- package/esm2022/lib/component/survey.play/survey.play.component.mjs +131 -0
- package/esm2022/lib/component/survey.question.preview/survey.question.preview.component.mjs +44 -0
- package/esm2022/lib/core/tp.servey.quota/tp.survey.quota.mjs +82 -0
- package/esm2022/lib/core/tp.survey.answer/tp.survey.answer.mjs +30 -0
- package/esm2022/lib/core/tp.survey.core/tp.survey.core.service.mjs +370 -0
- package/esm2022/lib/core/tp.survey.interview/tp.survey.interview.service.mjs +70 -0
- package/esm2022/lib/core/tp.survey.logic/tp.survey.logic.service.mjs +43 -0
- package/esm2022/lib/directive/alternatives.container/alternatives.container.directive.mjs +130 -0
- package/esm2022/lib/directive/focus.and.select/focus.and.select.directive.mjs +27 -0
- package/esm2022/lib/directive/survey.theme/survey.theme.directive.mjs +53 -0
- package/esm2022/lib/directive/update.font.size/update.font.size.directive.mjs +28 -0
- package/esm2022/lib/icons/default.icons/default.icons.mjs +15 -0
- package/esm2022/lib/icons/default.icons/default.icons.module.mjs +31 -0
- package/esm2022/lib/pipe/get.active.language/get.active.language.pipe.mjs +17 -0
- package/esm2022/lib/pipe/get.additional.value.by.value/get.additional.value.by.value.pipe.mjs +18 -0
- package/esm2022/lib/pipe/key.values/key.values.pipe.mjs +20 -0
- package/esm2022/lib/pipe/multi.lang.object.to.html/multi.lang.object.to.html.pipe.mjs +26 -0
- package/esm2022/lib/tp.survey.config.mjs +8 -0
- package/esm2022/lib/tp.survey.const.mjs +28 -0
- package/esm2022/lib/tp.survey.enum.mjs +59 -0
- package/esm2022/lib/tp.survey.interface.mjs +2 -0
- package/esm2022/lib/tp.survey.method.mjs +5 -0
- package/esm2022/lib/tp.survey.module.mjs +27 -0
- package/esm2022/lib/tp.survey.type.mjs +2 -0
- package/esm2022/public-api.mjs +14 -0
- package/esm2022/touchpoll-tp-survey.mjs +5 -0
- package/fesm2022/touchpoll-tp-survey.mjs +2210 -0
- package/fesm2022/touchpoll-tp-survey.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/component/answer/answer.additional/answer.additional.component.d.ts +17 -0
- package/lib/component/answer/answer.additional/directive/additional.answer.caption.position/additional.answer.caption.position.directive.d.ts +16 -0
- package/lib/component/answer/answer.end/answer.end.component.d.ts +6 -0
- package/lib/component/answer/answer.info/answer.info.component.d.ts +6 -0
- package/lib/component/answer/answer.lang/answer.lang.component.d.ts +9 -0
- package/lib/component/answer/answer.master/answer.master.component.d.ts +21 -0
- package/lib/component/answer/answer.ms/answer.ms.component.d.ts +21 -0
- package/lib/component/answer/answer.od/answer.od.component.d.ts +8 -0
- package/lib/component/answer/answer.ol/answer.ol.component.d.ts +7 -0
- package/lib/component/answer/answer.sl/answer.sl.component.d.ts +21 -0
- package/lib/component/answer/answer.sl/pipe/as.form.array/as.form.array.pipe.d.ts +8 -0
- package/lib/component/answer/answer.sl/pipe/as.form.control/as.form.control.pipe.d.ts +8 -0
- package/lib/component/answer/answer.ss/answer.ss.component.d.ts +10 -0
- package/lib/component/answer/container.answer/container.answer.component.d.ts +36 -0
- package/lib/component/answer/container.answer/container.answer.validator.d.ts +10 -0
- package/lib/component/navigation.button/navigation.button.component.d.ts +9 -0
- package/lib/component/question.caption/question.caption.component.d.ts +8 -0
- package/lib/component/survey.play/survey.play.component.d.ts +36 -0
- package/lib/component/survey.question.preview/survey.question.preview.component.d.ts +16 -0
- package/lib/core/tp.servey.quota/tp.survey.quota.d.ts +12 -0
- package/lib/core/tp.survey.answer/tp.survey.answer.d.ts +17 -0
- package/lib/core/tp.survey.core/tp.survey.core.service.d.ts +29 -0
- package/lib/core/tp.survey.interview/tp.survey.interview.service.d.ts +14 -0
- package/lib/core/tp.survey.logic/tp.survey.logic.service.d.ts +12 -0
- package/lib/directive/alternatives.container/alternatives.container.directive.d.ts +17 -0
- package/lib/directive/focus.and.select/focus.and.select.directive.d.ts +9 -0
- package/lib/directive/survey.theme/survey.theme.directive.d.ts +13 -0
- package/lib/directive/update.font.size/update.font.size.directive.d.ts +10 -0
- package/lib/icons/default.icons/default.icons.d.ts +5 -0
- package/lib/icons/default.icons/default.icons.module.d.ts +12 -0
- package/lib/pipe/get.active.language/get.active.language.pipe.d.ts +8 -0
- package/lib/pipe/get.additional.value.by.value/get.additional.value.by.value.pipe.d.ts +8 -0
- package/lib/pipe/key.values/key.values.pipe.d.ts +14 -0
- package/lib/pipe/multi.lang.object.to.html/multi.lang.object.to.html.pipe.d.ts +11 -0
- package/lib/tp.survey.config.d.ts +11 -0
- package/lib/tp.survey.const.d.ts +4 -0
- package/lib/tp.survey.enum.d.ts +51 -0
- package/lib/tp.survey.interface.d.ts +320 -0
- package/lib/tp.survey.method.d.ts +1 -0
- package/lib/tp.survey.module.d.ts +10 -0
- package/lib/tp.survey.type.d.ts +13 -0
- package/package.json +25 -0
- package/public-api.d.ts +9 -0
- package/styles/platform/component/survey.checkbox.scss +102 -0
- package/styles/platform/component/survey.radio.button.scss +34 -0
- package/styles/platform/survey.mixins.desktop.scss +146 -0
- package/styles/platform/survey.mixins.tablet.scss +132 -0
- package/styles/survey.mixins.scss +76 -0
- package/styles/survey.themes.scss +56 -0
- package/styles/theme/azure.blue.scss +54 -0
- package/styles/theme/cyan.orange.scss +54 -0
- package/styles/theme/rose.red.scss +54 -0
|
@@ -0,0 +1,131 @@
|
|
|
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.6", ngImport: i0, type: AnswerSLComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
102
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", 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()\"></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()\"></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()\"></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\"></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\" [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\" [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.6", 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()\"></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()\"></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()\"></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\"></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\" [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\" [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":"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","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()\"></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()\"></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()\"></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\"></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\" [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\" [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"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
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.6", ngImport: i0, type: AsFormArrayPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
8
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.0.6", ngImport: i0, type: AsFormArrayPipe, isStandalone: true, name: "asFormArray" }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", 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==
|
|
@@ -0,0 +1,17 @@
|
|
|
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.6", ngImport: i0, type: AsFormControlPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
8
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.0.6", ngImport: i0, type: AsFormControlPipe, isStandalone: true, name: "asFormControl" }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", 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
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, forwardRef, input, output, } from '@angular/core';
|
|
2
|
+
import { MatRadioButton, MatRadioGroup } from '@angular/material/radio';
|
|
3
|
+
import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { KeyValuePipe } from '@angular/common';
|
|
5
|
+
import { MatFormField } from '@angular/material/form-field';
|
|
6
|
+
import { MatInput } from '@angular/material/input';
|
|
7
|
+
import { MatIcon } from '@angular/material/icon';
|
|
8
|
+
import { MatCheckbox } from '@angular/material/checkbox';
|
|
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 AnswerSSComponent extends AnswerMasterComponent {
|
|
15
|
+
constructor() {
|
|
16
|
+
super(...arguments);
|
|
17
|
+
this.question = input.required();
|
|
18
|
+
this.alternativeList = input.required();
|
|
19
|
+
this.onAlternativeClick = output();
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: AnswerSSComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: AnswerSSComponent, isStandalone: true, selector: "tp-survey-answer-ss", inputs: { question: { classPropertyName: "question", publicName: "question", isSignal: true, isRequired: true, transformFunction: null }, alternativeList: { classPropertyName: "alternativeList", publicName: "alternativeList", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { onAlternativeClick: "onAlternativeClick" }, providers: [
|
|
23
|
+
{
|
|
24
|
+
provide: NG_VALUE_ACCESSOR,
|
|
25
|
+
useExisting: forwardRef(() => AnswerSSComponent),
|
|
26
|
+
multi: true
|
|
27
|
+
},
|
|
28
|
+
], usesInheritance: true, ngImport: i0, template: "<mat-radio-group\r\n class=\"container-ms-ss-alternatives\"\r\n [tpSurveyAlternativesContainer] = \"question()\"\r\n [containerViewModel]=\"viewModel()\"\r\n [formControl]=\"control\">\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <mat-radio-button\r\n #tablet_alt\r\n class=\"alternative-ss-ms tp-survey-radio-button\"\r\n [style.font-size.%]=\"viewModel() === viewModelE.vmTablet ? question().AlternativeTabletFontSize : undefined\"\r\n [value]=\"alt.Value\"\r\n (change)=\"onAlternativeClick.emit($event.value)\">\r\n @if (alt.IsMute) {\r\n <mat-icon class=\"icon-is-mute\" svgIcon=\"iconIsMute\"></mat-icon>\r\n }\r\n <span class=\"alternative-ss-ms-caption\" [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </mat-radio-button>\r\n }\r\n</mat-radio-group>\r\n\r\n", styles: [".container-controls{display:grid;justify-content:center;gap:1em}.container-controls>mat-radio-group{display:grid;grid-column-gap:2em;grid-gap:.5em;min-width:200px}@media (max-width: 480px){.container-controls{padding:1em}}\n"], dependencies: [{ kind: "directive", type: MatRadioGroup, selector: "mat-radio-group", inputs: ["color", "name", "labelPosition", "value", "selected", "disabled", "required"], outputs: ["change"], exportAs: ["matRadioGroup"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { 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: "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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: AnswerSSComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ selector: 'tp-survey-answer-ss', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
33
|
+
MatRadioGroup,
|
|
34
|
+
ReactiveFormsModule,
|
|
35
|
+
MatRadioButton,
|
|
36
|
+
MultiLangObjectToHtmlPipe,
|
|
37
|
+
KeyValuePipe,
|
|
38
|
+
MatFormField,
|
|
39
|
+
MatInput,
|
|
40
|
+
MatIcon,
|
|
41
|
+
MatCheckbox,
|
|
42
|
+
AlternativesContainerDirective
|
|
43
|
+
], providers: [
|
|
44
|
+
{
|
|
45
|
+
provide: NG_VALUE_ACCESSOR,
|
|
46
|
+
useExisting: forwardRef(() => AnswerSSComponent),
|
|
47
|
+
multi: true
|
|
48
|
+
},
|
|
49
|
+
], template: "<mat-radio-group\r\n class=\"container-ms-ss-alternatives\"\r\n [tpSurveyAlternativesContainer] = \"question()\"\r\n [containerViewModel]=\"viewModel()\"\r\n [formControl]=\"control\">\r\n @for (alt of alternativeList(); track alt.Value; let index = $index) {\r\n <mat-radio-button\r\n #tablet_alt\r\n class=\"alternative-ss-ms tp-survey-radio-button\"\r\n [style.font-size.%]=\"viewModel() === viewModelE.vmTablet ? question().AlternativeTabletFontSize : undefined\"\r\n [value]=\"alt.Value\"\r\n (change)=\"onAlternativeClick.emit($event.value)\">\r\n @if (alt.IsMute) {\r\n <mat-icon class=\"icon-is-mute\" svgIcon=\"iconIsMute\"></mat-icon>\r\n }\r\n <span class=\"alternative-ss-ms-caption\" [innerHTML]= \"alt.MultiLangCaptions | multiLangObjectToHtml:language()\"></span>\r\n </mat-radio-button>\r\n }\r\n</mat-radio-group>\r\n\r\n", styles: [".container-controls{display:grid;justify-content:center;gap:1em}.container-controls>mat-radio-group{display:grid;grid-column-gap:2em;grid-gap:.5em;min-width:200px}@media (max-width: 480px){.container-controls{padding:1em}}\n"] }]
|
|
50
|
+
}] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5zd2VyLnNzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RwLnN1cnZleS9zcmMvbGliL2NvbXBvbmVudC9hbnN3ZXIvYW5zd2VyLnNzL2Fuc3dlci5zcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cC5zdXJ2ZXkvc3JjL2xpYi9jb21wb25lbnQvYW5zd2VyL2Fuc3dlci5zcy9hbnN3ZXIuc3MuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQU0sR0FBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RixPQUFPLEVBQUMsY0FBYyxFQUFFLGFBQWEsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3RFLE9BQU8sRUFBQyxpQkFBaUIsRUFBRSxtQkFBbUIsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ3RFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDMUQsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2pELE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUMvQyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDdkQsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sd0VBQXdFLENBQUM7QUFDakgsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFFL0UsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sNEVBQTRFLENBQUM7OztBQTRCMUgsTUFBTSxPQUFPLGlCQUFrQixTQUFRLHFCQUE2QjtJQTFCcEU7O1FBMkJFLGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFlLENBQUM7UUFDekMsb0JBQWUsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUF5QixDQUFDO1FBQzFELHVCQUFrQixHQUFHLE1BQU0sRUFBVSxDQUFDO0tBQ3ZDOzhHQUpZLGlCQUFpQjtrR0FBakIsaUJBQWlCLDBaQVJqQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLENBQUM7Z0JBQ2hELEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRixpRENyQ0gsNjFCQW9CQSwwUkRBSSxhQUFhLHNNQUNiLG1CQUFtQiwwVEFDbkIsY0FBYywyUkFDZCx5QkFBeUIsOERBSXpCLE9BQU8sMklBRVAsOEJBQThCOzsyRkFVckIsaUJBQWlCO2tCQTFCN0IsU0FBUzsrQkFDRSxxQkFBcUIsbUJBR2QsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1A7d0JBQ1AsYUFBYTt3QkFDYixtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QseUJBQXlCO3dCQUN6QixZQUFZO3dCQUNaLFlBQVk7d0JBQ1osUUFBUTt3QkFDUixPQUFPO3dCQUNQLFdBQVc7d0JBQ1gsOEJBQThCO3FCQUMvQixhQUNVO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLGtCQUFrQixDQUFDOzRCQUNoRCxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgaW5wdXQsIG91dHB1dCx9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge01hdFJhZGlvQnV0dG9uLCBNYXRSYWRpb0dyb3VwfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9yYWRpbyc7XHJcbmltcG9ydCB7TkdfVkFMVUVfQUNDRVNTT1IsIFJlYWN0aXZlRm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHtLZXlWYWx1ZVBpcGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7TWF0Rm9ybUZpZWxkfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHtNYXRJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xyXG5pbXBvcnQge01hdEljb259IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQge01hdENoZWNrYm94fSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jaGVja2JveCc7XHJcbmltcG9ydCB7TXVsdGlMYW5nT2JqZWN0VG9IdG1sUGlwZX0gZnJvbSAnLi4vLi4vLi4vcGlwZS9tdWx0aS5sYW5nLm9iamVjdC50by5odG1sL211bHRpLmxhbmcub2JqZWN0LnRvLmh0bWwucGlwZSc7XHJcbmltcG9ydCB7QW5zd2VyTWFzdGVyQ29tcG9uZW50fSBmcm9tICcuLi9hbnN3ZXIubWFzdGVyL2Fuc3dlci5tYXN0ZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHtJZGJBbHRlcm5hdGl2ZSwgSWRiUXVlc3Rpb259IGZyb20gJy4uLy4uLy4uL3RwLnN1cnZleS5pbnRlcmZhY2UnO1xyXG5pbXBvcnQge0FsdGVybmF0aXZlc0NvbnRhaW5lckRpcmVjdGl2ZX0gZnJvbSAnLi4vLi4vLi4vZGlyZWN0aXZlL2FsdGVybmF0aXZlcy5jb250YWluZXIvYWx0ZXJuYXRpdmVzLmNvbnRhaW5lci5kaXJlY3RpdmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0cC1zdXJ2ZXktYW5zd2VyLXNzJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYW5zd2VyLnNzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9hbnN3ZXIuc3MuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIE1hdFJhZGlvR3JvdXAsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgTWF0UmFkaW9CdXR0b24sXHJcbiAgICBNdWx0aUxhbmdPYmplY3RUb0h0bWxQaXBlLFxyXG4gICAgS2V5VmFsdWVQaXBlLFxyXG4gICAgTWF0Rm9ybUZpZWxkLFxyXG4gICAgTWF0SW5wdXQsXHJcbiAgICBNYXRJY29uLFxyXG4gICAgTWF0Q2hlY2tib3gsXHJcbiAgICBBbHRlcm5hdGl2ZXNDb250YWluZXJEaXJlY3RpdmVcclxuICBdLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gQW5zd2VyU1NDb21wb25lbnQpLFxyXG4gICAgICBtdWx0aTogdHJ1ZVxyXG4gICAgfSxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQW5zd2VyU1NDb21wb25lbnQgZXh0ZW5kcyBBbnN3ZXJNYXN0ZXJDb21wb25lbnQ8bnVtYmVyPntcclxuICBxdWVzdGlvbiA9IGlucHV0LnJlcXVpcmVkPElkYlF1ZXN0aW9uPigpO1xyXG4gIGFsdGVybmF0aXZlTGlzdCA9IGlucHV0LnJlcXVpcmVkPEFycmF5PElkYkFsdGVybmF0aXZlPj4oKTtcclxuICBvbkFsdGVybmF0aXZlQ2xpY2sgPSBvdXRwdXQ8bnVtYmVyPigpO1xyXG59XHJcblxyXG5cclxuIiwiPG1hdC1yYWRpby1ncm91cFxyXG4gY2xhc3M9XCJjb250YWluZXItbXMtc3MtYWx0ZXJuYXRpdmVzXCJcclxuIFt0cFN1cnZleUFsdGVybmF0aXZlc0NvbnRhaW5lcl0gPSBcInF1ZXN0aW9uKClcIlxyXG4gW2NvbnRhaW5lclZpZXdNb2RlbF09XCJ2aWV3TW9kZWwoKVwiXHJcbiBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiPlxyXG4gQGZvciAoYWx0IG9mIGFsdGVybmF0aXZlTGlzdCgpOyB0cmFjayBhbHQuVmFsdWU7IGxldCBpbmRleCA9ICRpbmRleCkge1xyXG4gIDxtYXQtcmFkaW8tYnV0dG9uXHJcbiAgICN0YWJsZXRfYWx0XHJcbiAgIGNsYXNzPVwiYWx0ZXJuYXRpdmUtc3MtbXMgdHAtc3VydmV5LXJhZGlvLWJ1dHRvblwiXHJcbiAgIFtzdHlsZS5mb250LXNpemUuJV09XCJ2aWV3TW9kZWwoKSA9PT0gdmlld01vZGVsRS52bVRhYmxldCA/IHF1ZXN0aW9uKCkuQWx0ZXJuYXRpdmVUYWJsZXRGb250U2l6ZSA6IHVuZGVmaW5lZFwiXHJcbiAgIFt2YWx1ZV09XCJhbHQuVmFsdWVcIlxyXG4gICAoY2hhbmdlKT1cIm9uQWx0ZXJuYXRpdmVDbGljay5lbWl0KCRldmVudC52YWx1ZSlcIj5cclxuICAgQGlmIChhbHQuSXNNdXRlKSB7XHJcbiAgICA8bWF0LWljb24gY2xhc3M9XCJpY29uLWlzLW11dGVcIiBzdmdJY29uPVwiaWNvbklzTXV0ZVwiPjwvbWF0LWljb24+XHJcbiAgIH1cclxuICAgPHNwYW4gY2xhc3M9XCJhbHRlcm5hdGl2ZS1zcy1tcy1jYXB0aW9uXCIgW2lubmVySFRNTF09IFwiYWx0Lk11bHRpTGFuZ0NhcHRpb25zIHwgbXVsdGlMYW5nT2JqZWN0VG9IdG1sOmxhbmd1YWdlKClcIj48L3NwYW4+XHJcbiAgPC9tYXQtcmFkaW8tYnV0dG9uPlxyXG4gfVxyXG48L21hdC1yYWRpby1ncm91cD5cclxuXHJcbiJdfQ==
|