Spaces:
Sleeping
Sleeping
| // attaches listeners to the txt2img and img2img galleries to update displayed generation param text when the image changes | |
| let txt2img_gallery, img2img_gallery, modal = undefined; | |
| onAfterUiUpdate(function() { | |
| if (!txt2img_gallery) { | |
| txt2img_gallery = attachGalleryListeners("txt2img"); | |
| } | |
| if (!img2img_gallery) { | |
| img2img_gallery = attachGalleryListeners("img2img"); | |
| } | |
| if (!modal) { | |
| modal = gradioApp().getElementById('lightboxModal'); | |
| modalObserver.observe(modal, {attributes: true, attributeFilter: ['style']}); | |
| } | |
| }); | |
| let modalObserver = new MutationObserver(function(mutations) { | |
| mutations.forEach(function(mutationRecord) { | |
| let selectedTab = gradioApp().querySelector('#tabs div button.selected')?.innerText; | |
| if (mutationRecord.target.style.display === 'none' && (selectedTab === 'txt2img' || selectedTab === 'img2img')) { | |
| gradioApp().getElementById(selectedTab + "_generation_info_button")?.click(); | |
| } | |
| }); | |
| }); | |
| function attachGalleryListeners(tab_name) { | |
| var gallery = gradioApp().querySelector('#' + tab_name + '_gallery'); | |
| gallery?.addEventListener('click', () => gradioApp().getElementById(tab_name + "_generation_info_button").click()); | |
| gallery?.addEventListener('keydown', (e) => { | |
| if (e.keyCode == 37 || e.keyCode == 39) { // left or right arrow | |
| gradioApp().getElementById(tab_name + "_generation_info_button").click(); | |
| } | |
| }); | |
| return gallery; | |
| } | |