Commit d5ecf56f authored by Connum's avatar Connum

make callback queue handling reusable and implement onUiTabChange()

parent 74f940e8
...@@ -2,24 +2,40 @@ function gradioApp(){ ...@@ -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 })
}); });
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