make callback queue handling reusable and implement onUiTabChange()

This commit is contained in:
Connum 2022-09-24 01:12:13 +02:00 committed by AUTOMATIC1111
parent 0f77e1852f
commit 910a3d9427

View file

@ -2,24 +2,40 @@ function gradioApp(){
return document.getElementsByTagName('gradio-app')[0].shadowRoot; return document.getElementsByTagName('gradio-app')[0].shadowRoot;
} }
function get_uiCurrentTab() {
return gradioApp().querySelector('.tabs button:not(.border-transparent)')
}
uiUpdateCallbacks = [] uiUpdateCallbacks = []
uiTabChangeCallbacks = []
let uiCurrentTab = null
function onUiUpdate(callback){ function onUiUpdate(callback){
uiUpdateCallbacks.push(callback) uiUpdateCallbacks.push(callback)
} }
function onUiTabChange(callback){
uiTabChangeCallbacks.push(callback)
}
function uiUpdate(root){ function runCallback(x){
uiUpdateCallbacks.forEach(function(x){
try { try {
x() x()
} catch (e) { } catch (e) {
(console.error || console.log).call(console, e.message, e); (console.error || console.log).call(console, e.message, e);
} }
}) }
function executeCallbacks(queue) {
queue.forEach(runCallback)
} }
document.addEventListener("DOMContentLoaded", function() { document.addEventListener("DOMContentLoaded", function() {
var mutationObserver = new MutationObserver(function(m){ var mutationObserver = new MutationObserver(function(m){
uiUpdate(gradioApp()); executeCallbacks(uiUpdateCallbacks);
const newTab = get_uiCurrentTab();
if ( newTab && ( newTab !== uiCurrentTab ) ) {
uiCurrentTab = newTab;
executeCallbacks(uiTabChangeCallbacks);
}
}); });
mutationObserver.observe( gradioApp(), { childList:true, subtree:true }) mutationObserver.observe( gradioApp(), { childList:true, subtree:true })
}); });