MediaWiki:Common.js: Difference between revisions
Jump to navigation
Jump to search
No edit summary |
No edit summary |
||
Line 31: | Line 31: | ||
var _li1 = document.createElement("li"); | var _li1 = document.createElement("li"); | ||
_li1.innerHTML = "<br>Customize this page:"; | _li1.innerHTML = "<br>Customize this page:"; | ||
_li1.setAttribute("class", "mw-list-item"); | // _li1.setAttribute("class", "mw-list-item"); | ||
var _form1 = document.createElement("form"); | var _form1 = document.createElement("form"); | ||
_form1.setAttribute("action", url); // action | _form1.setAttribute("action", url); // action | ||
Line 156: | Line 156: | ||
_li1.appendChild (_form1); | _li1.appendChild (_form1); | ||
_nav.appendChild (_li1); | _nav.appendChild (_li1); | ||
/ | // hide unwanted sections | ||
if (gr_version.length > 0) | if (gr_version.length > 0) | ||
{ | { | ||
Line 163: | Line 163: | ||
{ | { | ||
var _ver = element[i].getAttribute("data-vad"); | var _ver = element[i].getAttribute("data-vad"); | ||
if (_ver != null) | |||
if | |||
{ | { | ||
element[i].setAttribute ("hidden", "true"); | console.log ("div version is ", _ver); | ||
if ((gr_version.indexOf (_ver)) == -1) // not found | |||
{ | |||
element[i].setAttribute ("hidden", "true"); | |||
} | |||
} | } | ||
} | } | ||
} // end have selections | } // end have selections | ||
} // second pass | } // second pass |
Revision as of 16:22, 9 December 2022
"use strict"
/* Any JavaScript here will be loaded for all users on every page load. */
console.log ("Version-adaptive documentation");
var gr_version = "";
var w_loc = window.location.href;
const url1 = new URL(w_loc);
var url2 = url1.toString();
var url = url2.replace("?title=","/");
console.log ("phase2()", url);
var p1 = url1.searchParams.get('ver1');
var p2 = url1.searchParams.get('ver2');
var p3 = url1.searchParams.get('ver3');
console.log (p1,p2,p3);
if ((p1 == null) && (p2 == null) && (p3 == null))
{ // first pass
var _art = document.getElementsByTagName("span");
if (_art.length > 0) // found <span>
{
console.log (_art.length, "spans found");
var _art1 = _art[0].getAttribute("data-vad");
if (_art1 == "gr_vad")
{
console.log ("found data-vad tag in <span>");
var _nav = document.getElementById("p-tb")
var _br = document.createElement("br");
_nav.appendChild (_br);
var _li1 = document.createElement("li");
_li1.innerHTML = "<br>Customize this page:";
// _li1.setAttribute("class", "mw-list-item");
var _form1 = document.createElement("form");
_form1.setAttribute("action", url); // action
// ver1 3.8
var _inp1 = document.createElement("input");
_inp1.setAttribute("type", "checkbox");
_inp1.setAttribute("id", "_ver1");
_inp1.setAttribute("name", "ver1");
_inp1.setAttribute("value", "3.8");
_form1.appendChild (_inp1);
var _lbl1 = document.createElement("label");
_lbl1.setAttribute("for", "_ver1");
_lbl1.innerHTML = " 3.8<br>";
_form1.appendChild (_lbl1);
// ver2 3.9
var _inp2 = document.createElement("input");
_inp2.setAttribute("type", "checkbox");
_inp2.setAttribute("id", "_ver2");
_inp2.setAttribute("name", "ver2");
_inp2.setAttribute("value", "3.9");
_form1.appendChild (_inp2);
var _lbl2 = document.createElement("label");
_lbl2.setAttribute("for", "_ver2");
_lbl2.innerHTML = " 3.9<br>";
_form1.appendChild (_lbl2);
// ver3 3.10
var _inp3 = document.createElement("input");
_inp3.setAttribute("type", "checkbox");
_inp3.setAttribute("id", "_ver3");
_inp3.setAttribute("name", "ver3");
_inp3.setAttribute("value", "3.10");
_form1.appendChild (_inp3);
var _lbl3 = document.createElement("label");
_lbl3.setAttribute("for", "_ver3");
_lbl3.innerHTML = " 3.10<br>";
_form1.appendChild (_lbl3);
_form1.appendChild(_br);
// submit
var _inp4 = document.createElement("input");
_inp4.setAttribute("type", "submit");
_inp4.setAttribute("value", "Submit");
_form1.appendChild (_inp4);
_li1.appendChild (_form1);
_nav.appendChild (_li1);
} // found data-vad tag in <span>
} // end found <span>
} // first pass
else
{ // have selections / second pass
console.log ("phase2 second pass");
if (p1 != null)
{
gr_version += p1;
gr_version += ", ";
}
if (p2 != null)
{
gr_version += p2;
gr_version += ", ";
}
if (p3 != null)
{
gr_version += p3;
}
var ver_len = gr_version.length;
console.log (gr_version, ver_len);
if (gr_version.endsWith (", "))
{
var temp = gr_version.slice (0, ver_len-2);
gr_version = temp;
}
var _nav = document.getElementById("p-tb")
var _br = document.createElement("br");
_nav.appendChild (_br);
var _li1 = document.createElement("li");
_li1.innerHTML = "<br>Customize this page:";
var _form1 = document.createElement("form");
_form1.setAttribute("action", url); // action
// ver1 3.8
var _inp1 = document.createElement("input");
_inp1.setAttribute("type", "checkbox");
_inp1.setAttribute("id", "_ver1");
_inp1.setAttribute("name", "ver1");
_inp1.setAttribute("value", "3.8");
if ((gr_version.indexOf ("3.8")) != -1) // found
_inp1.setAttribute ("checked", "true");
_form1.appendChild (_inp1);
var _lbl1 = document.createElement("label");
_lbl1.setAttribute("for", "_ver1");
_lbl1.innerHTML = " 3.8<br>";
_form1.appendChild (_lbl1);
// ver2 3.9
var _inp2 = document.createElement("input");
_inp2.setAttribute("type", "checkbox");
_inp2.setAttribute("id", "_ver2");
_inp2.setAttribute("name", "ver2");
_inp2.setAttribute("value", "3.9");
if ((gr_version.indexOf ("3.9")) != -1) // found
_inp2.setAttribute ("checked", "true");
_form1.appendChild (_inp2);
var _lbl2 = document.createElement("label");
_lbl2.setAttribute("for", "_ver2");
_lbl2.innerHTML = " 3.9<br>";
_form1.appendChild (_lbl2);
// ver3 3.10
var _inp3 = document.createElement("input");
_inp3.setAttribute("type", "checkbox");
_inp3.setAttribute("id", "_ver3");
_inp3.setAttribute("name", "ver3");
_inp3.setAttribute("value", "3.10");
if ((gr_version.indexOf ("3.10")) != -1) // found
_inp3.setAttribute ("checked", "true");
_form1.appendChild (_inp3);
var _lbl3 = document.createElement("label");
_lbl3.setAttribute("for", "_ver3");
_lbl3.innerHTML = " 3.10<br>";
_form1.appendChild (_lbl3);
_form1.appendChild(_br);
// submit
var _inp4 = document.createElement("input");
_inp4.setAttribute("type", "submit");
_inp4.setAttribute("value", "Submit");
_form1.appendChild (_inp4);
_li1.appendChild (_form1);
_nav.appendChild (_li1);
// hide unwanted sections
if (gr_version.length > 0)
{
var element = document.getElementsByTagName("div");
for (let i = 0; i < element.length; i++)
{
var _ver = element[i].getAttribute("data-vad");
if (_ver != null)
{
console.log ("div version is ", _ver);
if ((gr_version.indexOf (_ver)) == -1) // not found
{
element[i].setAttribute ("hidden", "true");
}
}
}
} // end have selections
} // second pass