sl-questionnaire
Version:
Library to integrate questionnaire in SL Projects
162 lines • 22.5 kB
JavaScript
import { __decorate, __values } 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';
var InputComponent = /** @class */ (function () {
function InputComponent(translate, qService) {
this.translate = translate;
this.qService = qService;
this.dimmerCloseText = this.translate['frmelmnts'].btn.close;
}
Object.defineProperty(InputComponent.prototype, "reponseType", {
get: function () {
return ResponseType;
},
enumerable: true,
configurable: true
});
InputComponent.prototype.toggleQuestion = function (parent) {
var _this = this;
var children = parent.children;
this.questions.map(function (q, i) {
if (children.includes(q._id)) {
var child = _this.questions[i];
child['canDisplay'] = _this.canDisplayChildQ(child, i);
if (child['canDisplay'] == false) {
child.value = '';
_this.questionnaireForm.removeControl(child._id);
}
}
});
};
InputComponent.prototype.canDisplayChildQ = function (currentQuestion, currentQuestionIndex) {
var e_1, _a, e_2, _b, e_3, _c, e_4, _d, e_5, _e, e_6, _f;
var display = true;
if (typeof currentQuestion.visibleIf == 'string' || null || undefined) {
return false; //if condition not present
}
try {
for (var _g = __values(this.questions), _h = _g.next(); !_h.done; _h = _g.next()) {
var question = _h.value;
try {
for (var _j = (e_2 = void 0, __values(currentQuestion.visibleIf)), _k = _j.next(); !_k.done; _k = _j.next()) {
var condition = _k.value;
if (condition._id === question._id) {
var expression = [];
if (condition.operator != '===') {
if (question.responseType === 'multiselect') {
try {
for (var _l = (e_3 = void 0, __values(question.value)), _m = _l.next(); !_m.done; _m = _l.next()) {
var parentValue = _m.value;
try {
for (var _o = (e_4 = void 0, __values(condition.value)), _p = _o.next(); !_p.done; _p = _o.next()) {
var value = _p.value;
expression.push('(', "'" + parentValue + "'", '===', "'" + value + "'", ')', condition.operator);
}
}
catch (e_4_1) { e_4 = { error: e_4_1 }; }
finally {
try {
if (_p && !_p.done && (_d = _o.return)) _d.call(_o);
}
finally { if (e_4) throw e_4.error; }
}
}
}
catch (e_3_1) { e_3 = { error: e_3_1 }; }
finally {
try {
if (_m && !_m.done && (_c = _l.return)) _c.call(_l);
}
finally { if (e_3) throw e_3.error; }
}
}
else {
try {
for (var _q = (e_5 = void 0, __values(condition.value)), _r = _q.next(); !_r.done; _r = _q.next()) {
var value = _r.value;
expression.push('(', "'" + question.value + "'", '===', "'" + value + "'", ')', condition.operator);
}
}
catch (e_5_1) { e_5 = { error: e_5_1 }; }
finally {
try {
if (_r && !_r.done && (_e = _q.return)) _e.call(_q);
}
finally { if (e_5) throw e_5.error; }
}
}
expression.pop();
}
else {
if (question.responseType === 'multiselect') {
try {
for (var _s = (e_6 = void 0, __values(question.value)), _t = _s.next(); !_t.done; _t = _s.next()) {
var value = _t.value;
expression.push('(', "'" + condition.value + "'", '===', "'" + value + "'", ')', '||');
}
}
catch (e_6_1) { e_6 = { error: e_6_1 }; }
finally {
try {
if (_t && !_t.done && (_f = _s.return)) _f.call(_s);
}
finally { if (e_6) throw e_6.error; }
}
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);
}
}
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_k && !_k.done && (_b = _j.return)) _b.call(_j);
}
finally { if (e_2) throw e_2.error; }
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_h && !_h.done && (_a = _g.return)) _a.call(_g);
}
finally { if (e_1) throw e_1.error; }
}
return display;
};
InputComponent.ctorParameters = function () { return [
{ 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);
return 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"]}