aboutsummaryrefslogtreecommitdiff
path: root/scripts/theme-studio/browser-gates.js
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/theme-studio/browser-gates.js')
-rw-r--r--scripts/theme-studio/browser-gates.js25
1 files changed, 25 insertions, 0 deletions
diff --git a/scripts/theme-studio/browser-gates.js b/scripts/theme-studio/browser-gates.js
index ad7a586df..2b85fc8bb 100644
--- a/scripts/theme-studio/browser-gates.js
+++ b/scripts/theme-studio/browser-gates.js
@@ -649,3 +649,28 @@ if(location.hash==='#roundtriptest'){let ok=true;const notes=[];const A=(c,n)=>{
PALETTE=saveP;for(const k in MAP)delete MAP[k];Object.assign(MAP,saveM);syncSyntaxFromCache();LOCKED=saveL;
document.title='ROUNDTRIPTEST '+(ok?'PASS':'FAIL');
const d=document.createElement('div');d.id='roundtriptest';d.textContent='ROUNDTRIPTEST '+(ok?'PASS':'FAIL')+(notes.length?' | '+notes.join(' ; '):'');document.body.appendChild(d);}
+// View-selector gate (open with #viewtest): the assignment panel is driven by a
+// single #viewsel dropdown -- two editor entries (@code, @ui) then a "package
+// faces" optgroup of every app, in order -- and switching it shows exactly one
+// of the three view blocks.
+if(location.hash==='#viewtest'){let ok=true;const notes=[];const A=(c,n)=>{if(!c){ok=false;notes.push(n);}};
+ const sel=document.getElementById('viewsel');
+ A(!!sel,'viewsel-exists');
+ if(sel){
+ A(sel.options[0]&&sel.options[0].value==='@code','first-option-code');
+ A(sel.options[1]&&sel.options[1].value==='@ui','second-option-ui');
+ const og=sel.querySelector('optgroup');
+ A(og&&og.label==='package faces','package-faces-optgroup');
+ if(og){const appOpts=[...og.querySelectorAll('option')].map(o=>o.value);
+ A(JSON.stringify(appOpts)===JSON.stringify(Object.keys(APPS)),'optgroup-lists-apps-in-order');}
+ const vis=id=>{const e=document.getElementById(id);return !!e&&e.style.display!=='none';};
+ sel.value='@code';onViewChange();
+ A(vis('view-code')&&!vis('view-ui')&&!vis('view-pkg'),'code-view-only');
+ sel.value='@ui';onViewChange();
+ A(!vis('view-code')&&vis('view-ui')&&!vis('view-pkg'),'ui-view-only');
+ const firstApp=Object.keys(APPS)[0];sel.value=firstApp;onViewChange();
+ A(!vis('view-code')&&!vis('view-ui')&&vis('view-pkg'),'pkg-view-only');
+ A(curApp()===firstApp,'curApp-returns-selected-app');
+ }
+ document.title='VIEWTEST '+(ok?'PASS':'FAIL');
+ const d=document.createElement('div');d.id='viewtest';d.textContent='VIEWTEST '+(ok?'PASS':'FAIL')+(notes.length?' fails='+notes.join(','):'');document.body.appendChild(d);}