<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://linguifex.com/w/index.php?action=history&amp;feed=atom&amp;title=MediaWiki%3AGadget-VisibilityToggles.js</id>
	<title>MediaWiki:Gadget-VisibilityToggles.js - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://linguifex.com/w/index.php?action=history&amp;feed=atom&amp;title=MediaWiki%3AGadget-VisibilityToggles.js"/>
	<link rel="alternate" type="text/html" href="https://linguifex.com/w/index.php?title=MediaWiki:Gadget-VisibilityToggles.js&amp;action=history"/>
	<updated>2026-04-14T00:32:08Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.6</generator>
	<entry>
		<id>https://linguifex.com/w/index.php?title=MediaWiki:Gadget-VisibilityToggles.js&amp;diff=475055&amp;oldid=prev</id>
		<title>Sware: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="https://linguifex.com/w/index.php?title=MediaWiki:Gadget-VisibilityToggles.js&amp;diff=475055&amp;oldid=prev"/>
		<updated>2025-11-04T17:52:41Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 17:52, 4 November 2025&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Sware</name></author>
	</entry>
	<entry>
		<id>https://linguifex.com/w/index.php?title=MediaWiki:Gadget-VisibilityToggles.js&amp;diff=475054&amp;oldid=prev</id>
		<title>wikt&gt;Surjection at 17:18, 23 September 2025</title>
		<link rel="alternate" type="text/html" href="https://linguifex.com/w/index.php?title=MediaWiki:Gadget-VisibilityToggles.js&amp;diff=475054&amp;oldid=prev"/>
		<updated>2025-09-23T17:18:09Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 17:18, 23 September 2025&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l252&quot;&gt;Line 252:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 252:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;				this[i].status = status;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;				this[i].status = status;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;			this.sidebarToggle.&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;html&lt;/del&gt;((status ? &quot;Hide &quot; : &quot;Show &quot;) + this.name);&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;			this.sidebarToggle.&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;text&lt;/ins&gt;((status ? &quot;Hide &quot; : &quot;Show &quot;) + this.name);&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;		},&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;		},&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;	},&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;	},&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>wikt&gt;Surjection</name></author>
	</entry>
	<entry>
		<id>https://linguifex.com/w/index.php?title=MediaWiki:Gadget-VisibilityToggles.js&amp;diff=462313&amp;oldid=prev</id>
		<title>Sware: Created page with &quot;/* eslint-env es5, browser, jquery */ /* eslint semi: &quot;error&quot; */ /* jshint esversion: 5, eqeqeq: true */ /* globals $, mw */ /* requires mw.cookie, mw.storage */ (function VisibilityTogglesIIFE () { &quot;use strict&quot;;  // Toggle object that is constructed so that `toggle.status = !toggle.status` // automatically calls either `toggle.show()` or `toggle.hide()` as appropriate. // Creating toggle also automatically calls either the show or the hide function. function Toggle (sho...&quot;</title>
		<link rel="alternate" type="text/html" href="https://linguifex.com/w/index.php?title=MediaWiki:Gadget-VisibilityToggles.js&amp;diff=462313&amp;oldid=prev"/>
		<updated>2025-07-10T00:01:10Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;&lt;span class=&quot;autocomment&quot;&gt;eslint-env es5, browser, jquery: &lt;/span&gt; &lt;span class=&quot;autocomment&quot;&gt;eslint semi: &amp;quot;error&amp;quot;: &lt;/span&gt; &lt;span class=&quot;autocomment&quot;&gt;jshint esversion: 5, eqeqeq: true: &lt;/span&gt; &lt;span class=&quot;autocomment&quot;&gt;globals $, mw: &lt;/span&gt; &lt;span class=&quot;autocomment&quot;&gt;requires mw.cookie, mw.storage: &lt;/span&gt; (function VisibilityTogglesIIFE () { &amp;quot;use strict&amp;quot;;  // Toggle object that is constructed so that `toggle.status = !toggle.status` // automatically calls either `toggle.show()` or `toggle.hide()` as appropriate. // Creating toggle also automatically calls either the show or the hide function. function Toggle (sho...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;/* eslint-env es5, browser, jquery */&lt;br /&gt;
/* eslint semi: &amp;quot;error&amp;quot; */&lt;br /&gt;
/* jshint esversion: 5, eqeqeq: true */&lt;br /&gt;
/* globals $, mw */&lt;br /&gt;
/* requires mw.cookie, mw.storage */&lt;br /&gt;
(function VisibilityTogglesIIFE () {&lt;br /&gt;
&amp;quot;use strict&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
// Toggle object that is constructed so that `toggle.status = !toggle.status`&lt;br /&gt;
// automatically calls either `toggle.show()` or `toggle.hide()` as appropriate.&lt;br /&gt;
// Creating toggle also automatically calls either the show or the hide function.&lt;br /&gt;
function Toggle (showFunction, hideFunction) {&lt;br /&gt;
	this.show = showFunction, this.hide = hideFunction;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
Toggle.prototype = {&lt;br /&gt;
	get status () {&lt;br /&gt;
		return this._status;&lt;br /&gt;
	},&lt;br /&gt;
	set status (newStatus) {&lt;br /&gt;
		if (typeof newStatus !== &amp;quot;boolean&amp;quot;)&lt;br /&gt;
			throw new TypeError(&amp;quot;Value of &amp;#039;status&amp;#039; must be a boolean.&amp;quot;);&lt;br /&gt;
		if (newStatus === this._status)&lt;br /&gt;
			return;&lt;br /&gt;
&lt;br /&gt;
		this._status = newStatus;&lt;br /&gt;
&lt;br /&gt;
		if (this._status !== this.toggleCategory.status)&lt;br /&gt;
			this.toggleCategory.updateToggle(this._status);&lt;br /&gt;
&lt;br /&gt;
		if (this._status)&lt;br /&gt;
			this.show();&lt;br /&gt;
		else&lt;br /&gt;
			this.hide();&lt;br /&gt;
	},&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
/*&lt;br /&gt;
 * Handles storing a boolean value associated with a `name` stored in&lt;br /&gt;
 * localStorage under `key`.&lt;br /&gt;
 *&lt;br /&gt;
 * The `get` method returns `true`, `false`, or `undefined` (if the storage&lt;br /&gt;
 * hasn&amp;#039;t been tampered with).&lt;br /&gt;
 * The `set` method only allows setting `true` or `false`.&lt;br /&gt;
 */&lt;br /&gt;
function BooleanStorage(key, name) {&lt;br /&gt;
	if (typeof key !== &amp;quot;string&amp;quot;)&lt;br /&gt;
		throw new TypeError(&amp;quot;Expected string&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
	if (!(typeof name === &amp;quot;string&amp;quot; &amp;amp;&amp;amp; name !== &amp;quot;&amp;quot;)) {&lt;br /&gt;
		throw new TypeError(&amp;quot;Expected non-empty string&amp;quot;);&lt;br /&gt;
	}&lt;br /&gt;
	this.key = key; // key for localStorage&lt;br /&gt;
	this.name = name; // name of toggle category&lt;br /&gt;
&lt;br /&gt;
	function convertOldCookie(cookie) {&lt;br /&gt;
		return cookie.split(&amp;#039;;&amp;#039;)&lt;br /&gt;
			.filter(function(e) { return e !== &amp;#039;&amp;#039;; })&lt;br /&gt;
			.reduce(function(memo, currentValue) {&lt;br /&gt;
				var match = /(.+?)=(\d)/.exec(currentValue); // only to test for temporary =[01] format&lt;br /&gt;
				if (match) {&lt;br /&gt;
					memo[match[1]] = Boolean(Number(match[2]));&lt;br /&gt;
				} else {&lt;br /&gt;
					memo[currentValue] = true;&lt;br /&gt;
				}&lt;br /&gt;
				return memo;&lt;br /&gt;
			}, {});&lt;br /&gt;
	}&lt;br /&gt;
	// Look for cookie in old format.&lt;br /&gt;
	var cookie = mw.cookie.get(key);&lt;br /&gt;
	if (cookie !== null) {&lt;br /&gt;
		this.obj = $.extend(this.obj, convertOldCookie(cookie));&lt;br /&gt;
		mw.cookie.set(key, null);  // Remove cookie.&lt;br /&gt;
	}&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
BooleanStorage.prototype = {&lt;br /&gt;
	get: function () {&lt;br /&gt;
		return this.obj[this.name];&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	set: function (value) {&lt;br /&gt;
		if (typeof value !== &amp;quot;boolean&amp;quot;)&lt;br /&gt;
			throw new TypeError(&amp;quot;Expected boolean&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
		var obj = this.obj;&lt;br /&gt;
		if (obj[this.name] !== value) {&lt;br /&gt;
			obj[this.name] = value;&lt;br /&gt;
			this.obj = obj;&lt;br /&gt;
		}&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	// obj allows getting and setting the object version of the stored value.&lt;br /&gt;
	get obj() {&lt;br /&gt;
		if (typeof this.rawValue !== &amp;quot;string&amp;quot;)&lt;br /&gt;
			return {};&lt;br /&gt;
		try {&lt;br /&gt;
			return JSON.parse(this.rawValue);&lt;br /&gt;
		} catch (e) {&lt;br /&gt;
			if (e instanceof SyntaxError) {&lt;br /&gt;
				return {};&lt;br /&gt;
			} else {&lt;br /&gt;
				throw e;&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	set obj(value) {&lt;br /&gt;
		// throws TypeError (&amp;quot;cyclic object value&amp;quot;)&lt;br /&gt;
		this.rawValue = JSON.stringify(value);&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	// rawValue allows simple getting and setting of the stringified object.&lt;br /&gt;
	get rawValue () {&lt;br /&gt;
		return mw.storage.get(this.key);&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	set rawValue (value) {&lt;br /&gt;
		return mw.storage.set(this.key, value);&lt;br /&gt;
	},&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
// This is a version of the actual CSS identifier syntax (described here:&lt;br /&gt;
// https://stackoverflow.com/a/2812097), with only ASCII and that must begin&lt;br /&gt;
// with an alphabetic character.&lt;br /&gt;
var asciiCssIdentifierRegex = /^[a-zA-Z][a-zA-Z0-9_-]+$/;&lt;br /&gt;
&lt;br /&gt;
function ToggleCategory (name, defaultStatus) {&lt;br /&gt;
	this.name = name;&lt;br /&gt;
	this.sidebarToggle = this.newSidebarToggle();&lt;br /&gt;
	this.storage = new BooleanStorage(&amp;quot;Visibility&amp;quot;, name);&lt;br /&gt;
	this.status = this.getInitialStatus(defaultStatus);&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
// Have toggle category inherit array methods.&lt;br /&gt;
ToggleCategory.prototype = [];&lt;br /&gt;
&lt;br /&gt;
ToggleCategory.prototype.addToggle = function (showFunction, hideFunction) {&lt;br /&gt;
	var toggle = new Toggle(showFunction, hideFunction);&lt;br /&gt;
	toggle.toggleCategory = this;&lt;br /&gt;
	this.push(toggle);&lt;br /&gt;
	toggle.status = this.status;&lt;br /&gt;
	return toggle;&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
// Generate an identifier consisting of a lowercase ASCII letter and a random integer.&lt;br /&gt;
function randomAsciiCssIdentifier() {&lt;br /&gt;
	var digits = 9;&lt;br /&gt;
	var lowCodepoint = &amp;quot;a&amp;quot;.codePointAt(0), highCodepoint = &amp;quot;z&amp;quot;.codePointAt(0);&lt;br /&gt;
	return String.fromCodePoint(&lt;br /&gt;
			lowCodepoint + Math.floor(Math.random() * (highCodepoint - lowCodepoint)))&lt;br /&gt;
		+ String(Math.floor(Math.random() * Math.pow(10, digits)));&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
function getCssIdentifier(name) {&lt;br /&gt;
	name = name.replace(/\s+/g, &amp;quot;-&amp;quot;);&lt;br /&gt;
	// Generate a valid ASCII CSS identifier.&lt;br /&gt;
	if (!asciiCssIdentifierRegex.test(name)) {&lt;br /&gt;
		// Remove characters that are invalid in an ASCII CSS identifier.&lt;br /&gt;
		name = name.replace(/^[^a-zA-Z]+/, &amp;quot;&amp;quot;).replace(/[^a-zA-Z_-]+/g, &amp;quot;&amp;quot;);&lt;br /&gt;
		if (!asciiCssIdentifierRegex.test(name))&lt;br /&gt;
			name = randomAsciiCssIdentifier();&lt;br /&gt;
	}&lt;br /&gt;
	return name;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
// Add a new global toggle to the sidebar.&lt;br /&gt;
ToggleCategory.prototype.newSidebarToggle = function () {&lt;br /&gt;
	var name = getCssIdentifier(this.name);&lt;br /&gt;
	var id = &amp;quot;p-visibility-&amp;quot; + name;&lt;br /&gt;
	&lt;br /&gt;
	var sidebarToggle = $(&amp;quot;#&amp;quot; + id);&lt;br /&gt;
	if (sidebarToggle.length &amp;gt; 0)&lt;br /&gt;
		return sidebarToggle;&lt;br /&gt;
&lt;br /&gt;
	var listEntry = $(&amp;quot;&amp;lt;li&amp;gt;&amp;quot;);&lt;br /&gt;
	if (mw.config.get(&amp;quot;skin&amp;quot;) === &amp;quot;vector-2022&amp;quot;)&lt;br /&gt;
		listEntry.addClass(&amp;quot;mw-list-item&amp;quot;);&lt;br /&gt;
	&lt;br /&gt;
	sidebarToggle = $(&amp;quot;&amp;lt;a&amp;gt;&amp;quot;, {&lt;br /&gt;
			id: id,&lt;br /&gt;
			href: &amp;quot;#visibility-&amp;quot; + this.name,&lt;br /&gt;
		})&lt;br /&gt;
		.click((function () {&lt;br /&gt;
			this.status = !this.status;&lt;br /&gt;
			this.storage.set(this.status);&lt;br /&gt;
			return false;&lt;br /&gt;
		}).bind(this));&lt;br /&gt;
&lt;br /&gt;
	listEntry.append(sidebarToggle).appendTo(this.buttons);&lt;br /&gt;
&lt;br /&gt;
	return sidebarToggle;&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
// Update the status of the sidebar toggle for the category when all of its&lt;br /&gt;
// toggles on the page are toggled one way.&lt;br /&gt;
ToggleCategory.prototype.updateToggle = function (status) {&lt;br /&gt;
	if (this.length &amp;gt; 0 &amp;amp;&amp;amp; this.every(function (toggle) { return toggle.status === status; }))&lt;br /&gt;
		this.status = status;&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
// getInitialStatus is only called when a category is first created.&lt;br /&gt;
ToggleCategory.prototype.getInitialStatus = function (defaultStatus) {&lt;br /&gt;
	function isFragmentSet(name) {&lt;br /&gt;
		return location.hash.toLowerCase().split(&amp;quot;_&amp;quot;)[0] === &amp;quot;#&amp;quot; + name.toLowerCase();&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	function isHideCatsSet(name) {&lt;br /&gt;
		var match = /^.+?\?(?:.*?&amp;amp;)*?hidecats=(.+?)(?:&amp;amp;.*)?$/.exec(location.href);&lt;br /&gt;
		if (match !== null) {&lt;br /&gt;
			var hidecats = match[1].split(&amp;quot;,&amp;quot;);&lt;br /&gt;
			for (var i = 0; i &amp;lt; hidecats.length; ++i) {&lt;br /&gt;
				switch (hidecats[i]) {&lt;br /&gt;
					case name: case &amp;quot;all&amp;quot;:&lt;br /&gt;
						return false;&lt;br /&gt;
					case &amp;quot;!&amp;quot; + name: case &amp;quot;none&amp;quot;:&lt;br /&gt;
						return true;&lt;br /&gt;
				}&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
		return false;&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	function isWiktionaryPreferencesCookieSet() {&lt;br /&gt;
		return mw.cookie.get(&amp;quot;WiktionaryPreferencesShowNav&amp;quot;) === &amp;quot;true&amp;quot;;&lt;br /&gt;
	}&lt;br /&gt;
	// TODO check category-specific cookies&lt;br /&gt;
	return isFragmentSet(this.name)&lt;br /&gt;
		|| isHideCatsSet(this.name)&lt;br /&gt;
		|| isWiktionaryPreferencesCookieSet()&lt;br /&gt;
		|| (function(storedValue) {&lt;br /&gt;
            return storedValue !== undefined ? storedValue : Boolean(defaultStatus);&lt;br /&gt;
        }(this.storage.get()));&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
Object.defineProperties(ToggleCategory.prototype, {&lt;br /&gt;
	status: {&lt;br /&gt;
		get: function () {&lt;br /&gt;
			return this._status;&lt;br /&gt;
		},&lt;br /&gt;
		set: function (status) {&lt;br /&gt;
			if (typeof status !== &amp;quot;boolean&amp;quot;)&lt;br /&gt;
				throw new TypeError(&amp;quot;Value of &amp;#039;status&amp;#039; must be a boolean.&amp;quot;);&lt;br /&gt;
			if (status === this._status)&lt;br /&gt;
				return;&lt;br /&gt;
&lt;br /&gt;
			this._status = status;&lt;br /&gt;
&lt;br /&gt;
			// Change the state of all Toggles in the ToggleCategory.&lt;br /&gt;
			for (var i = 0; i &amp;lt; this.length; i++)&lt;br /&gt;
				this[i].status = status;&lt;br /&gt;
&lt;br /&gt;
			this.sidebarToggle.html((status ? &amp;quot;Hide &amp;quot; : &amp;quot;Show &amp;quot;) + this.name);&lt;br /&gt;
		},&lt;br /&gt;
	},&lt;br /&gt;
&lt;br /&gt;
	buttons: {&lt;br /&gt;
		get: function () {&lt;br /&gt;
			var buttons = $(&amp;quot;#p-visibility ul&amp;quot;);&lt;br /&gt;
			if (buttons.length &amp;gt; 0)&lt;br /&gt;
				return buttons;&lt;br /&gt;
			buttons = $(&amp;quot;&amp;lt;ul&amp;gt;&amp;quot;);&lt;br /&gt;
			// unused var collapsed = mw.cookie.get(&amp;quot;vector-nav-p-visibility&amp;quot;) === &amp;quot;false&amp;quot;;&lt;br /&gt;
			if (mw.config.get(&amp;quot;skin&amp;quot;) === &amp;quot;vector-2022&amp;quot;) {&lt;br /&gt;
				/* add to right-hand side (&amp;#039;tools&amp;#039;) bar */&lt;br /&gt;
				var toolbox = $(&amp;quot;&amp;lt;div&amp;gt;&amp;quot;, {&lt;br /&gt;
						&amp;quot;class&amp;quot;: &amp;quot;vector-menu mw-portlet mw-portlet-visibility&amp;quot;,&lt;br /&gt;
						&amp;quot;id&amp;quot;: &amp;quot;p-visibility&amp;quot;&lt;br /&gt;
					})&lt;br /&gt;
					.append($(&amp;#039;&amp;lt;div id=&amp;quot;p-visibility-label&amp;quot; aria-label=&amp;quot;&amp;quot; class=&amp;quot;vector-menu-heading&amp;quot;&amp;gt;Visibility&amp;lt;/div&amp;gt;&amp;#039;))&lt;br /&gt;
					.append($(&amp;quot;&amp;lt;div&amp;gt;&amp;quot;, { class: &amp;quot;vector-menu-content&amp;quot; }).append(buttons.addClass(&amp;quot;vector-menu-content-list&amp;quot;)));&lt;br /&gt;
				$(&amp;#039;#vector-page-tools&amp;#039;).append(toolbox);&lt;br /&gt;
				&lt;br /&gt;
			} else {&lt;br /&gt;
				var toolbox = $(&amp;quot;&amp;lt;div&amp;gt;&amp;quot;, {&lt;br /&gt;
						&amp;quot;class&amp;quot;: &amp;quot;vector-menu vector-menu-portal portal portlet&amp;quot;,&lt;br /&gt;
						&amp;quot;id&amp;quot;: &amp;quot;p-visibility&amp;quot;&lt;br /&gt;
					})&lt;br /&gt;
					.append($(&amp;#039;&amp;lt;label id=&amp;quot;p-visibility-label&amp;quot; aria-label=&amp;quot;&amp;quot; class=&amp;quot;vector-menu-heading&amp;quot;&amp;gt;&amp;lt;span class=&amp;quot;vector-menu-heading-label&amp;quot;&amp;gt;Visibility&amp;lt;/span&amp;gt;&amp;lt;/label&amp;gt;&amp;#039;))&lt;br /&gt;
					.append($(&amp;quot;&amp;lt;div&amp;gt;&amp;quot;, { class: &amp;quot;pBody body vector-menu-content&amp;quot; }).append(buttons));&lt;br /&gt;
				var insert = document.getElementById(&amp;quot;p-lang&amp;quot;) || document.getElementById(&amp;quot;p-feedback&amp;quot;);&lt;br /&gt;
				if (insert) {&lt;br /&gt;
					$(insert).before(toolbox);&lt;br /&gt;
				} else {&lt;br /&gt;
					var sidebar = document.getElementById(&amp;quot;mw-panel&amp;quot;) || document.getElementById(&amp;quot;column-one&amp;quot;);&lt;br /&gt;
					$(sidebar).append(toolbox);&lt;br /&gt;
				}&lt;br /&gt;
			}&lt;br /&gt;
&lt;br /&gt;
			return buttons;&lt;br /&gt;
		}&lt;br /&gt;
	}&lt;br /&gt;
});&lt;br /&gt;
&lt;br /&gt;
function VisibilityToggles () {&lt;br /&gt;
	// table containing ToggleCategories&lt;br /&gt;
	this.togglesByCategory = {};&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
// Add a new toggle, adds a Show/Hide category button in the toolbar.&lt;br /&gt;
// Returns a function that when called, calls showFunction and hideFunction&lt;br /&gt;
// alternately and updates the sidebar toggle for the category if necessary.&lt;br /&gt;
VisibilityToggles.prototype.register = function (category, showFunction, hideFunction, defaultStatus) {&lt;br /&gt;
	if (!(typeof category === &amp;quot;string&amp;quot; &amp;amp;&amp;amp; category !== &amp;quot;&amp;quot;))&lt;br /&gt;
		return;&lt;br /&gt;
&lt;br /&gt;
	var toggle = this.addToggleCategory(category, defaultStatus)&lt;br /&gt;
					.addToggle(showFunction, hideFunction);&lt;br /&gt;
&lt;br /&gt;
	return function () {&lt;br /&gt;
		toggle.status = !toggle.status;&lt;br /&gt;
	};&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
VisibilityToggles.prototype.addToggleCategory = function (name, defaultStatus) {&lt;br /&gt;
	return (this.togglesByCategory[name] = this.togglesByCategory[name] || new ToggleCategory(name, defaultStatus));&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
window.alternativeVisibilityToggles = new VisibilityToggles();&lt;br /&gt;
window.VisibilityToggles = window.alternativeVisibilityToggles;&lt;br /&gt;
&lt;br /&gt;
})();&lt;/div&gt;</summary>
		<author><name>Sware</name></author>
	</entry>
</feed>