|
|
|
import { Controller } from "@hotwired/stimulus"
|
|
|
|
|
|
|
|
export default class extends Controller {
|
|
|
|
initialize() {
|
|
|
|
this.displayConditional()
|
|
|
|
}
|
|
|
|
|
|
|
|
displayConditional() {
|
|
|
|
switch(this.element.type) {
|
|
|
|
case "number":
|
|
|
|
this.displayConditionalNumeric()
|
|
|
|
case "radio":
|
|
|
|
this.displayConditionalRadio()
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
displayConditionalRadio() {
|
|
|
|
if(this.element.checked) {
|
|
|
|
let selectedValue = this.element.value
|
|
|
|
let conditional_for = JSON.parse(this.element.dataset.info)
|
|
|
|
|
|
|
|
Object.entries(conditional_for).map(([targetQuestion, conditions]) => {
|
|
|
|
let div = document.getElementById(targetQuestion + "_div")
|
|
|
|
if(conditions.includes(selectedValue)) {
|
|
|
|
div.style.display = "block"
|
|
|
|
} else {
|
|
|
|
div.style.display = "none"
|
|
|
|
let buttons = document.getElementsByName(`case_log[${targetQuestion}]`);
|
|
|
|
if (buttons.length == 0){
|
|
|
|
buttons = document.getElementsByName(`case_log[${targetQuestion}][]`);
|
|
|
|
}
|
|
|
|
Object.entries(buttons).map(([idx, button]) => {
|
|
|
|
button.checked = false;
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
displayConditionalNumeric() {
|
|
|
|
let enteredValue = this.element.value
|
|
|
|
let conditional_for = JSON.parse(this.element.dataset.info)
|
|
|
|
|
|
|
|
Object.entries(conditional_for).map(([targetQuestion, condition]) => {
|
|
|
|
let div = document.getElementById(targetQuestion + "_div")
|
|
|
|
if(eval((enteredValue + condition))) {
|
|
|
|
div.style.display = "block"
|
|
|
|
} else {
|
|
|
|
div.style.display = "none"
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|