sl-questionnaire
Version:
Library to integrate questionnaire in SL Projects
95 lines • 17.9 kB
JavaScript
import { __decorate } from "tslib";
import { Component, Input } from '@angular/core';
import { ResponseType } from '../interfaces/questionnaire.type';
import { SlTranslateService } from '../services/translate.service';
import { SlQuestionnaireService } from '../services/sl-questionnaire.service';
let InputComponent = class InputComponent {
constructor(translate, qService) {
this.translate = translate;
this.qService = qService;
this.dimmerCloseText = this.translate['frmelmnts'].btn.close;
}
get reponseType() {
return ResponseType;
}
toggleQuestion(parent) {
const { children } = parent;
this.questions.map((q, i) => {
if (children.includes(q._id)) {
let child = this.questions[i];
child['canDisplay'] = this.canDisplayChildQ(child, i);
if (child['canDisplay'] == false) {
child.value = '';
this.questionnaireForm.removeControl(child._id);
}
}
});
}
canDisplayChildQ(currentQuestion, currentQuestionIndex) {
let display = true;
if (typeof currentQuestion.visibleIf == 'string' || null || undefined) {
return false; //if condition not present
}
for (const question of this.questions) {
for (const condition of currentQuestion.visibleIf) {
if (condition._id === question._id) {
let expression = [];
if (condition.operator != '===') {
if (question.responseType === 'multiselect') {
for (const parentValue of question.value) {
for (const value of condition.value) {
expression.push('(', "'" + parentValue + "'", '===', "'" + value + "'", ')', condition.operator);
}
}
}
else {
for (const value of condition.value) {
expression.push('(', "'" + question.value + "'", '===', "'" + value + "'", ')', condition.operator);
}
}
expression.pop();
}
else {
if (question.responseType === 'multiselect') {
for (const value of question.value) {
expression.push('(', "'" + condition.value + "'", '===', "'" + value + "'", ')', '||');
}
expression.pop();
}
else {
expression.push('(', "'" + question.value + "'", condition.operator, "'" + condition.value + "'", ')');
}
}
if (!eval(expression.join(''))) {
this.questions[currentQuestionIndex].isCompleted = true;
return false;
}
else {
// this.questions[currentQuestionIndex].isCompleted =
// this.utils.isQuestionComplete(currentQuestion);
}
}
}
}
return display;
}
};
InputComponent.ctorParameters = () => [
{ type: SlTranslateService },
{ type: SlQuestionnaireService }
];
__decorate([
Input()
], InputComponent.prototype, "questions", void 0);
__decorate([
Input()
], InputComponent.prototype, "questionnaireForm", void 0);
InputComponent = __decorate([
Component({
selector: 'sl-input',
template: "<div *ngFor=\"let question of questions; let qi = index\">\n <div\n [ngClass]=\"{\n 'ui card question-card sb--card relative9':\n question.responseType != 'pageQuestions'\n }\"\n *ngIf=\"!question.visibleIf.length || question.canDisplay == true\"\n >\n <div [ngClass]=\"{ content: question.responseType != 'pageQuestions' }\">\n <div class=\"d-flex flex-ai-flex-start flex-jc-space-between\">\n <div\n *ngFor=\"let q of question.question; let qai = index\"\n [ngClass]=\"{\n 'mb-20': q.length,\n 'valid-response': questionnaireForm?.controls[question._id]?.valid\n }\"\n >\n <div class=\"sb-h5\">\n {{ qai == 0 ? qi + 1 + \")\" : \"\" }} {{ q }}\n </div>\n </div>\n <div *ngIf=\"question?.hint\">\n <i\n class=\"icon large lightbulb\"\n (click)=\"dimmerIndex = qi; isDimmed = !isDimmed\"\n ></i>\n </div>\n </div>\n <div *ngIf=\"question?.tip\" class=\"mb-10\">\n <small class=\"mb-10\">{{ question?.tip }}</small>\n </div>\n <div class=\"sbt-page-content-questionnaireFormarea'\">\n <sl-text-input\n *ngIf=\"question.responseType == reponseType.TEXT\"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n ></sl-text-input>\n <sl-date-input\n *ngIf=\"question.responseType == reponseType.DATE\"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n ></sl-date-input>\n <sl-number-input\n *ngIf=\"question.responseType == reponseType.NUMBER\"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n ></sl-number-input>\n <sl-range-input\n *ngIf=\"question.responseType == reponseType.SLIDER\"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n ></sl-range-input>\n <sl-radio-input\n *ngIf=\"question.responseType == reponseType.RADIO\"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n [options]=\"question.options\"\n (dependentParent)=\"toggleQuestion($event)\"\n ></sl-radio-input>\n <sl-checkbox-input\n *ngIf=\"question.responseType == reponseType.MULTISELECT\"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n [options]=\"question.options\"\n (dependentParent)=\"toggleQuestion($event)\"\n ></sl-checkbox-input>\n <sl-page-questions\n *ngIf=\"\n question.responseType == reponseType.PAGEQUESTIONS;\n pageQuestions\n \"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n ></sl-page-questions>\n <sl-matrix-questions\n *ngIf=\"question.responseType == reponseType.MATRIX\"\n [questionnaireForm]=\"questionnaireForm\"\n [question]=\"question\"\n ></sl-matrix-questions>\n <sl-ques-remarks\n [question]=\"question\"\n *ngIf=\"question.showRemarks\"\n ></sl-ques-remarks>\n <sl-attachment\n [data]=\"{\n submissionId: qService.getSubmissionId(),\n files: question.fileName\n }\"\n *ngIf=\"question.file\"\n ></sl-attachment>\n <sui-dimmer\n [(isDimmed)]=\"isDimmed\"\n [isClickable]=\"true\"\n *ngIf=\"dimmerIndex == qi && question?.hint\"\n >\n <div class=\"center\">\n <h4 class=\"ui inverted header\">{{ question?.hint }}</h4>\n <button\n type=\"button\"\n class=\"sb-btn sb-btn-sm sb-btn-white text-uppercase flex-basis-1\"\n type=\"submit\"\n >\n {{ dimmerCloseText }}\n </button>\n </div>\n </sui-dimmer>\n </div>\n </div>\n </div>\n</div>\n",
styles: [".question-card{border-radius:28px;padding:20px;width:100%;margin-bottom:20px}.question-card:last-child{margin-bottom:20px}:host .question-card.sb--card,:host .sb-radio-btn-checkbox{width:100%;background-color:var(--sb-card-bg);color:var(--primary-color)}:host label{color:var(--body-color)}:host ::ng-deep .question-card .sb-checkbox label,:host ::ng-deep .question-card .sb-radio-btn-checkbox label{color:var(--body-color);font-weight:400}:host ::ng-deep .question-card input:focus,:host ::ng-deep .question-card input:focus~label{color:var(--body-color)}:host ::ng-deep .question-card #range{background-color:var(--sb-card-bg)}:host ::ng-deep .question-card .student-card{background-color:var(--sb-card-bg)}:host ::ng-deep .question-card .question-date-input,:host ::ng-deep .question-card input:active.question-date-input,:host ::ng-deep .question-card input:focus.question-date-input{background:var(--cc-sbcard-data1-bg);color:var(--sb-prominent-filter-title)}.remarks{margin-top:15px}.valid-response{color:var(--green)}"]
})
], InputComponent);
export { InputComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"ng://sl-questionnaire/","sources":["lib/input/input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { Question, ResponseType } from '../interfaces/questionnaire.type';\nimport { SlTranslateService } from '../services/translate.service';\nimport { SlQuestionnaireService } from '../services/sl-questionnaire.service';\n\n@Component({\n  selector: 'sl-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n})\nexport class InputComponent {\n  @Input() questions: Array<Question>;\n  @Input() questionnaireForm: FormGroup;\n  selectedIndex: number;\n  dimmerIndex;\n  isDimmed;\n  dimmerCloseText = this.translate['frmelmnts'].btn.close;\n\n  constructor(private translate: SlTranslateService,public qService:SlQuestionnaireService) {}\n\n  public get reponseType(): typeof ResponseType {\n    return ResponseType;\n  }\n\n  toggleQuestion(parent) {\n    const { children } = parent;\n\n    this.questions.map((q, i) => {\n      if (children.includes(q._id)) {\n        let child = this.questions[i];\n        child['canDisplay'] = this.canDisplayChildQ(child, i);\n        if (child['canDisplay'] == false) {\n          child.value = '';\n          this.questionnaireForm.removeControl(child._id);\n        }\n      }\n    });\n  }\n\n  canDisplayChildQ(currentQuestion: Question, currentQuestionIndex: number) {\n    let display = true;\n    if (typeof currentQuestion.visibleIf == 'string' || null || undefined) {\n      return false; //if condition not present\n    }\n    for (const question of this.questions) {\n      for (const condition of currentQuestion.visibleIf) {\n        if (condition._id === question._id) {\n          let expression = [];\n          if (condition.operator != '===') {\n            if (question.responseType === 'multiselect') {\n              for (const parentValue of question.value) {\n                for (const value of condition.value) {\n                  expression.push(\n                    '(',\n                    \"'\" + parentValue + \"'\",\n                    '===',\n                    \"'\" + value + \"'\",\n                    ')',\n                    condition.operator\n                  );\n                }\n              }\n            } else {\n              for (const value of condition.value) {\n                expression.push(\n                  '(',\n                  \"'\" + question.value + \"'\",\n                  '===',\n                  \"'\" + value + \"'\",\n                  ')',\n                  condition.operator\n                );\n              }\n            }\n            expression.pop();\n          } else {\n            if (question.responseType === 'multiselect') {\n              for (const value of question.value) {\n                expression.push(\n                  '(',\n                  \"'\" + condition.value + \"'\",\n                  '===',\n                  \"'\" + value + \"'\",\n                  ')',\n                  '||'\n                );\n              }\n              expression.pop();\n            } else {\n              expression.push(\n                '(',\n                \"'\" + question.value + \"'\",\n                condition.operator,\n                \"'\" + condition.value + \"'\",\n                ')'\n              );\n            }\n          }\n          if (!eval(expression.join(''))) {\n            this.questions[currentQuestionIndex].isCompleted = true;\n            return false;\n          } else {\n            // this.questions[currentQuestionIndex].isCompleted =\n            //   this.utils.isQuestionComplete(currentQuestion);\n          }\n        }\n      }\n    }\n    return display;\n  }\n}\n"]}