Commit 6b8c661c authored by AUTOMATIC1111's avatar AUTOMATIC1111

add a visible checkbox to input accordion

parent 452ab8fe
var observerAccordionOpen = new MutationObserver(function(mutations) { function inputAccordionChecked(id, checked) {
mutations.forEach(function(mutationRecord) { var accordion = gradioApp().getElementById(id);
var elem = mutationRecord.target; accordion.visibleCheckbox.checked = checked;
var open = elem.classList.contains('open'); accordion.onVisibleCheckboxChange();
}
var accordion = elem.parentNode; function setupAccordion(accordion){
accordion.classList.toggle('input-accordion-open', open); var labelWrap = accordion.querySelector('.label-wrap');
var gradioCheckbox = gradioApp().querySelector('#' + accordion.id + "-checkbox input");
var extra = gradioApp().querySelector('#' + accordion.id + "-extra");
var span = labelWrap.querySelector('span');
var linked = true;
var checkbox = gradioApp().querySelector('#' + accordion.id + "-checkbox input"); var isOpen = function(){ return labelWrap.classList.contains('open'); }
checkbox.checked = open;
updateInput(checkbox);
var extra = gradioApp().querySelector('#' + accordion.id + "-extra"); var observerAccordionOpen = new MutationObserver(function(mutations) {
if (extra) { mutations.forEach(function(mutationRecord) {
extra.style.display = open ? "" : "none"; accordion.classList.toggle('input-accordion-open', isOpen());
}
if(linked){
accordion.visibleCheckbox.checked = isOpen();
accordion.onVisibleCheckboxChange();
}
});
}); });
}); observerAccordionOpen.observe(labelWrap, {attributes: true, attributeFilter: ['class']});
function inputAccordionChecked(id, checked) { if (extra) {
var label = gradioApp().querySelector('#' + id + " .label-wrap"); labelWrap.insertBefore(extra, labelWrap.lastElementChild);
if (label.classList.contains('open') != checked) { }
label.click();
accordion.onChecked = function(checked){
if (isOpen() != checked) {
labelWrap.click();
}
} }
var visibleCheckbox = document.createElement('INPUT');
visibleCheckbox.type = 'checkbox';
visibleCheckbox.checked = isOpen();
visibleCheckbox.id = accordion.id + "-visible-checkbox";
visibleCheckbox.className = gradioCheckbox.className + " input-accordion-checkbox";
span.insertBefore(visibleCheckbox, span.firstChild);
accordion.visibleCheckbox = visibleCheckbox;
accordion.onVisibleCheckboxChange = function(){
if(linked && isOpen() != visibleCheckbox.checked) {
labelWrap.click();
}
gradioCheckbox.checked = visibleCheckbox.checked;
updateInput(gradioCheckbox);
};
visibleCheckbox.addEventListener('click', function(event){
linked = false;
event.stopPropagation();
});
visibleCheckbox.addEventListener('input', accordion.onVisibleCheckboxChange);
} }
onUiLoaded(function() { onUiLoaded(function() {
for (var accordion of gradioApp().querySelectorAll('.input-accordion')) { for (var accordion of gradioApp().querySelectorAll('.input-accordion')) {
var labelWrap = accordion.querySelector('.label-wrap'); setupAccordion(accordion);
observerAccordionOpen.observe(labelWrap, {attributes: true, attributeFilter: ['class']});
var extra = gradioApp().querySelector('#' + accordion.id + "-extra");
if (extra) {
labelWrap.insertBefore(extra, labelWrap.lastElementChild);
}
} }
}); });
...@@ -204,6 +204,11 @@ div.block.gradio-accordion { ...@@ -204,6 +204,11 @@ div.block.gradio-accordion {
padding: 8px 8px; padding: 8px 8px;
} }
input[type="checkbox"].input-accordion-checkbox{
vertical-align: sub;
margin-right: 0.5em;
}
/* txt2img/img2img specific */ /* txt2img/img2img specific */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment