Jump to content
Wikipedia The Free Encyclopedia

User:Eejit43/scripts/script-updater.js

From Wikipedia, the free encyclopedia
Code that you insert on this page could contain malicious content capable of compromising your account. If you import a script from another page with "importScript", "mw.loader.load", "iusc", or "lusc", take note that this causes you to dynamically load a remote script, which could be changed by others. Editors are responsible for all edits and actions they perform, including by scripts. User scripts are not centrally supported and may malfunction or become inoperable due to software changes. A guide to help you find broken scripts is available. If you are unsure whether code you are adding to this page is safe, you can ask at the appropriate village pump.
This code will be executed when previewing this page.
Documentation for this user script can be added at User:Eejit43/scripts/script-updater.
Note: After saving, you have to bypass your browser's cache to see the changes. Google Chrome, Firefox, Microsoft Edge and Safari: Hold down the ⇧ Shift key and click the Reload toolbar button. For details and instructions about other browsers, see Wikipedia:Bypass your cache.
 // <pre>
 // Note: This script was compiled and minified from TypeScript. For a more readable version, see https://github.com/Eejit43/wikipedia-scripts/blob/main/scripts/script-updater.ts

 "use strict";(()=>{varg=newmw.Api;asyncfunctiony(d){return(awaitg.get({action:"query",formatversion:"2",prop:"revisions",rvprop:"content",rvslots:"main",titles:d})).query.pages[0].revisions?.[0].slots.main.content.trim()}mw.loader.using(["mediawiki.util","oojs-ui-core","oojs-ui-widgets","oojs-ui-windows"],()=>{if(mw.config.get("wgUserName")!=="Eejit43"||mw.config.get("wgPageName")!=="User:Eejit43")return;letd=document.querySelector(".mw-editsection").cloneNode(!0),u=document.createElement("a");u.href="#",u.style.fontWeight="bold",u.textContent="Sync from GitHub",u.addEventListener("click",p=>{p.preventDefault();lete=newOO.ui.WindowManager;document.body.append(e.$element[0]);lets=newl;e.addWindows([s]),s.open()}),d.querySelector("a").replaceWith(u),document.querySelector("h2#My_user_scripts + .mw-editsection").after(d);classlextendsOO.ui.ProcessDialog{REPO_OWNER="Eejit43";REPO_NAME="wikipedia-scripts";SCRIPT_MESSAGE=" (via [[User:Eejit43/scripts/script-updater.js|script]])";content;scriptsMultiselect;actionsMultiselect;latestCommitHash;scripts;scriptDataUpdaters={"article-cleaner":w,"redirect-helper":O};constructor(){super({size:"medium"}),l.static.name="ScriptUpdaterDialog",l.static.title="script-updater",l.static.actions=[{action:"cancel",label:"Close",flags:["safe","close"]},{action:"save",label:"Run",flags:["primary","progressive"]}]}getSetupProcess=()=>l.super.prototype.getSetupProcess.call(this).next(()=>this.wrapAsyncMethod(this.loadScriptData).then(e=>{if(e){leti=newOO.ui.MessageWidget({type:"error",label:e});this.content=newOO.ui.PanelLayout({padded:!0,expanded:!1}),this.content.$element.append(i.$element),this.$body.append(this.content.$element),this.getActions().setAbilities({save:!1});return}this.content=newOO.ui.PanelLayout({padded:!0,expanded:!1}),this.scriptsMultiselect=newOO.ui.CheckboxMultiselectWidget({items:this.scripts.map(i=>newOO.ui.CheckboxMultioptionWidget({data:i.name,label:i.name}))}),this.scriptsMultiselect.$element[0].style.columnCount="2";lets=newOO.ui.FieldLayout(this.scriptsMultiselect,{label:newOO.ui.HtmlSnippet("<b>Scripts to update:</b>"),align:"top"});this.actionsMultiselect=newOO.ui.CheckboxMultiselectWidget({items:[{id:"documentation",name:"Update script documentation"},{id:"script",name:"Update script code"},{id:"talk",name:"Create talk redirect",selectedDefault:!1}].map(({id:i,name:r,selectedDefault:a})=>newOO.ui.CheckboxMultioptionWidget({data:i,label:r,selected:a??!0}))});letn=newOO.ui.FieldLayout(this.actionsMultiselect,{label:newOO.ui.HtmlSnippet("<b>Actions to take (if applicable):</b>"),align:"top"}),m=newOO.ui.ButtonGroupWidget({items:Object.entries(this.scriptDataUpdaters).map(([i,r])=>{leta=newOO.ui.ButtonWidget({label:i,flags:["progressive"]});returna.on("click",async()=>{mw.notify(`Fetching ${i} data...`,{tag:"update-script-data-notification"});leto=awaitr();mw.notify(`Successfully fetched ${i} data, opening diff...`,{type:"success",tag:"update-script-data-notification"}),awaitnewPromise(c=>setTimeout(c,500)),this.openDiff(`User:Eejit43/scripts/${i}.json`,o)}),a})}),t=newOO.ui.FieldLayout(m,{label:newOO.ui.HtmlSnippet("<b>Script data updaters:</b>"),align:"top"});this.content.$element.append(s.$element),this.content.$element.append(n.$element),this.content.$element.append(t.$element),this.$body.append(this.content.$element)}));getActionProcess=e=>e==="cancel"?newOO.ui.Process(()=>{this.close()}):e==="save"?newOO.ui.Process(()=>{lets=this.scriptsMultiselect.findSelectedItemsData().map(n=>this.scripts.find(m=>m.name===n));this.close(),(async()=>(mw.notify("Syncing scripts...",{tag:"sync-scripts-notification"}),awaitPromise.all(s.map(n=>this.handleScript(n))),awaitthis.editOrCreate("User:Eejit43/scripts-info",[this.mapScripts(this.scripts.filter(n=>!n.personal&&!n.fork)),"","=== Forks ===",this.mapScripts(this.scripts.filter(n=>n.fork)),"","=== Personal scripts ===",this.mapScripts(this.scripts.filter(n=>n.personal))].join(`
 `),"Syncing script list from GitHub"),mw.notify(`Synced ${s.length} script${s.length===1?"":"s"} from GitHub!`,{type:"success",tag:"sync-scripts-notification"})))()}):l.super.prototype.getActionProcess.call(this,e);getTeardownProcess=()=>l.super.prototype.getTeardownProcess.call(this).next(()=>{this.$body.empty()});wrapAsyncMethod(e){lets=$.Deferred();returne().then(n=>s.resolve(n)),s.promise()}loadScriptData=async()=>{lete=awaitfetch(`https://api.github.com/repos/${this.REPO_OWNER}/${this.REPO_NAME}/commits`);if(!e.ok)return`Failed to fetch latest commit hash from GitHub: ${e.statusText} (${e.status})`;this.latestCommitHash=(awaite.json())[0].sha;lets=awaitfetch(`https://raw.githubusercontent.com/${this.REPO_OWNER}/${this.REPO_NAME}/${this.latestCommitHash}/scripts.json`);if(!s.ok)return`Failed to fetch script data from GitHub: ${s.statusText} (${s.status})`;letn=awaits.json();this.scripts=Object.entries(n).map(([m,t])=>({name:m,...t}))};asynchandleScript(e){lets=this.actionsMultiselect.findSelectedItemsData(),n=`User:Eejit43/scripts/${e.name}`,m=`User talk:Eejit43/scripts/${e.name}`,t=`${n}.js`,i=["{{User:Eejit43/script-documentation",e.image===!1?`| image = ${e.image}`:null,e["in-development"]?`| in-development = ${e["in-development"]}`:null,e["use-instead"]?`| use-instead = ${e["use-instead"].includes("User:")?e["use-instead"]:`[[User:Eejit43/scripts/${e["use-instead"]}|${e["use-instead"]}]]`}`:null,e["image-caption"]?`| image-caption = ${e["image-caption"]}`:null,e["other-authors"]?`| other-authors = ${e["other-authors"].map(a=>`[[User:${a}|${a}]]`).join(", ")}`:null,`| description-short = ${e["short-description"]}`,`| description = ${e.description}`,e.usage?`| usage = ${e.usage}`:null,e.configuration?`| configuration = ${e.configuration}`:null,e.changelog?`| changelog = 
 ${Object.entries(e.changelog).map(([a,o])=>`* '''{{start date and age|${a}}}:'''${Array.isArray(o)?`
 ${o.map(c=>`** ${c}`).join(`
 `)}`:` ${o}`}`).join(`
 `)}`:null,`| skin-support = {{User:Eejit43/script-documentation/skin-support|${Object.entries(e["skin-support"]).map(([a,o])=>`${a}=${o}`).join("|")}}}`,e["source-multiple"]?`| source-multiple = ${e["source-multiple"]}`:null,`| released = {{start date and age|${e.released}}}`,`| updated = {{start date and age|${e.updated}}}`,"}}"].filter(Boolean),r=null;if(s.includes("script")){leta=awaitfetch(`https://raw.githubusercontent.com/${this.REPO_OWNER}/${this.REPO_NAME}/${this.latestCommitHash}/dist/${e.name}.js`);if(a.ok)r=awaita.text();elsereturnmw.notify(`Failed to fetch "${e.name}.js" from GitHub: ${a.statusText} (${a.status})`,{type:"error",tag:"sync-scripts-notification"})}e.personal||(s.includes("documentation")&&awaitthis.editOrCreate(n,i.join(`
 `),"Syncing script documentation from GitHub"),s.includes("talk")&&awaitthis.editOrCreate(m,"#REDIRECT [[User talk:Eejit43]]","Redirecting script documentation talk page to main user talk page")),r&&awaitthis.editOrCreate(t,r,"Syncing script from GitHub")}mapScripts(e){returne.map(s=>`* [[User:Eejit43/scripts/${s.name}${s.personal?".js":""}|${s.name}]] - ${s["short-description"]||s.description}${s["in-development"]?' (<span style="color: #bd2828">in development</span>)':""}${s["use-instead"]?' (<span style="color: #bd2828">deprecated</span>)':""}`).join(`
 `)}asynceditOrCreate(e,s,n){n+=this.SCRIPT_MESSAGE,awaitg.edit(e,()=>({text:s,summary:n,watchlist:"watch"})).catch(async(m,t)=>{if(m==="nocreate-missing")awaitg.create(e,{summary:n,watchlist:"watch"},s).catch((i,r)=>{mw.notify(`Error creating ${e}: ${r?.error?.info??"Unknown error"} (${i})`,{type:"error"})});else{mw.notify(`Error editing or creating ${e}: ${t?.error?.info??"Unknown error"} (${m})`,{type:"error"});return}})}openDiff(e,s){letn={wpTextbox1:s,wpSummary:`Updating data${this.SCRIPT_MESSAGE}`,wpDiff:"1",wpWatchthis:"1",wpUltimateParam:"1"},m=newURL(`${mw.config.get("wgScriptPath")}/index.php`,window.location.origin);m.searchParams.set("title",e),m.searchParams.set("action","submit");lett=document.createElement("form");t.action=m.toString(),t.method="POST",t.target="_blank";for(let[i,r]ofObject.entries(n)){leta=document.createElement("input");a.type="hidden",a.name=i,a.value=r,t.append(a)}document.body.append(t),t.submit(),t.remove()}}Object.assign(l.prototype,OO.ui.ProcessDialog.prototype)});asyncfunctionw(){letu=(awaity("Wikipedia:AutoWikiBrowser/Template redirects")??"").matchAll(/\* {{tl\|.+/g).toArray().map(l=>{letp=l[0].matchAll(/{{tl\|(.+?)}}/g).toArray();return{from:p.slice(0,-1).map(e=>e[1]),to:p.at(-1)[1]}});returnJSON.stringify(u)}functionh(d,u){letl=[];for(letp=0;p<d.length;p+=u){lete=d.slice(p,p+u);l.push(e)}returnl}asyncfunctionb(d){letu=0,l=[],p={continue:{}};for(;"continue"inp&&u<10;)p=awaitg.get({...d,...p.continue}),l.push(p),u++;returnl}asyncfunctionO(){letd=awaitg.get({action:"query",list:"categorymembers",cmtitle:"Category:Redirect templates",cmlimit:"max",formatversion:"2"}),u=awaitg.get({action:"query",list:"categorymembers",cmtitle:"Category:Template redirects with possibilities",cmlimit:"max",formatversion:"2"}),l=d.query.categorymembers.filter(t=>t.title.startsWith("Template:R ")&&t.title!=="Template:R template index").map(t=>({name:t.title.split(":")[1],redirect:!1})),p=u.query.categorymembers.filter(t=>t.title.startsWith("Template:R ")&&t.title!=="Template:R with possibilities").map(t=>({name:t.title.split(":")[1],redirect:!0})),e=[...l,...p].sort((t,i)=>t.name.startsWith("R comics")||t.name.startsWith("R ME")?1:i.name.startsWith("R comics")||i.name.startsWith("R ME")?-1:t.name.localeCompare(i.name)),s=Object.fromEntries(e.map(t=>[t.name,{redirect:t.redirect,parameters:{},aliases:[]}]));awaitPromise.all(h(e,50).map(asynct=>{leti=awaitg.get({action:"templatedata",titles:t.map(r=>`Template:${r.name}`),formatversion:"2"});for(letrofObject.values(i.pages)){leta=Object.fromEntries(Object.entries(r.params).map(([o,c])=>[o,{aliases:c.aliases,label:c.label?.en??null,description:c.description?.en??null,type:c.type,required:c.required,suggested:c.suggested,default:c.default?.en??null,example:c.example?.en??null}]));s[r.title.split(":")[1]].parameters=a}})),awaitPromise.all(h(l,50).map(asynct=>{letr=(awaitb({action:"query",titles:t.map(a=>`Template:${a.name}`),prop:"redirects",rdnamespace:10,rdlimit:"max",formatversion:"2"})).flatMap(a=>a.query.pages);for(letaofr){leto=a.redirects?.map(c=>c.title.split(":")[1]).filter(c=>!p.some(f=>f.name===c)).sort((c,f)=>c.localeCompare(f))??[];s[a.title.split(":")[1]].aliases.push(...o)}}));letn=[];awaitPromise.all(h(p,50).map(asynct=>{leti=awaitg.get({action:"query",titles:t.map(r=>`Template:${r.name}`),prop:"linkshere",lhnamespace:10,lhlimit:"max",formatversion:"2"});for(letrofi.query.pages){leta=r.linkshere?.filter(o=>o.redirect).map(o=>o.title.split(":")[1]).filter(o=>!o.endsWith("/doc")&&!o.endsWith("/sandbox")).sort((o,c)=>o.localeCompare(c))??[];n.push(...a),s[r.title.split(":")[1]].aliases=a}}));letm=Object.entries(s).map(([t,i])=>{letr={...i.redirect?{redirect:!0}:{},parameters:i.parameters,aliases:i.aliases.sort((a,o)=>a.localeCompare(o))};return[t,r]});for(lettofn)for(let[,i]ofm)!i.redirect&&i.aliases.includes(t)&&(i.aliases=i.aliases.filter(r=>r!==t));returnJSON.stringify(Object.fromEntries(m))}})();

 // </pre>
 //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../utility.ts", "../scripts/script-updater.ts"],
  "sourcesContent": ["import type { ApiQueryRevisionsParams } from 'types-mediawiki-api';\nimport type { PageRevisionsResult } from './global-types';\n\nexport const api = new mw.Api();\n\n/**\n * Fetches the content of a given page.\n * @param title The title to fetch.\n */\nexport async function getPageContent(title: string) {\n    return (\n        (await api.get({\n            action: 'query',\n            formatversion: '2',\n            prop: 'revisions',\n            rvprop: 'content',\n            rvslots: 'main',\n            titles: title,\n        } satisfies ApiQueryRevisionsParams)) as PageRevisionsResult\n    ).query.pages[0].revisions?.[0].slots.main.content.trim();\n}\n", "import type {\n    ApiQueryBacklinkspropParams,\n    ApiQueryCategoryMembersParams,\n    ApiQueryParams,\n    TemplateDataApiTemplateDataParams,\n} from 'types-mediawiki-api';\nimport type { ApiResponse } from 'types-mediawiki/mw/Api';\nimport type {\n    CategoryMembersResult,\n    LinksHereResult,\n    MediaWikiDataError,\n    QueryContinuation,\n    RedirectsResult,\n    TemplateDataResult,\n} from '../global-types';\nimport { api, getPageContent } from '../utility';\n\ninterface Script {\n    'name': string;\n    'in-development'?: boolean;\n    'use-instead'?: string;\n    'image'?: false;\n    'image-caption'?: string;\n    'short-description': string;\n    'description': string;\n    'usage'?: string;\n    'configuration'?: string;\n    'changelog'?: Record<string, string | string[]>;\n    'other-authors'?: string[];\n    'fork'?: true;\n    'personal'?: true;\n    'skin-support': Record<string, boolean>;\n    'source-multiple'?: true;\n    'released': string;\n    'updated': string;\n}\n\nmw.loader.using(['mediawiki.util', 'oojs-ui-core', 'oojs-ui-widgets', 'oojs-ui-windows'], () => {\n    if (mw.config.get('wgUserName') !== 'Eejit43' || mw.config.get('wgPageName') !== 'User:Eejit43') return;\n\n    const fullLinkElement = document.querySelector('.mw-editsection')!.cloneNode(true) as HTMLSpanElement;\n\n    const link = document.createElement('a');\n    link.href = '#';\n    link.style.fontWeight = 'bold';\n    link.textContent = 'Sync from GitHub';\n    link.addEventListener('click', (event) => {\n        event.preventDefault();\n\n        const windowManager = new OO.ui.WindowManager();\n        document.body.append(windowManager.$element[0]);\n\n        const scriptUpdaterDialog = new ScriptUpdaterDialog();\n        windowManager.addWindows([scriptUpdaterDialog]);\n\n        scriptUpdaterDialog.open();\n    });\n\n    fullLinkElement.querySelector('a')!.replaceWith(link);\n\n    document.querySelector('h2#My_user_scripts + .mw-editsection')!.after(fullLinkElement);\n\n    /**\n     * An instance of this class is a dialog that manages updating scripts.\n     */\n    class ScriptUpdaterDialog extends OO.ui.ProcessDialog {\n        private readonly REPO_OWNER = 'Eejit43';\n        private readonly REPO_NAME = 'wikipedia-scripts';\n\n        private readonly SCRIPT_MESSAGE = ' (via [[User:Eejit43/scripts/script-updater.js|script]])';\n\n        private content!: OO.ui.PanelLayout;\n        private scriptsMultiselect!: OO.ui.CheckboxMultiselectWidget;\n        private actionsMultiselect!: OO.ui.CheckboxMultiselectWidget;\n\n        private latestCommitHash!: string;\n        private scripts!: Script[];\n\n        private scriptDataUpdaters = {\n            'article-cleaner': getArticleCleanerData,\n            'redirect-helper': getRedirectHelperData,\n        };\n\n        constructor() {\n            super({ size: 'medium' });\n\n            ScriptUpdaterDialog.static.name = 'ScriptUpdaterDialog';\n            ScriptUpdaterDialog.static.title = 'script-updater';\n            ScriptUpdaterDialog.static.actions = [\n                { action: 'cancel', label: 'Close', flags: ['safe', 'close'] },\n                { action: 'save', label: 'Run', flags: ['primary', 'progressive'] },\n            ];\n        }\n\n        getSetupProcess = () => {\n            return ScriptUpdaterDialog.super.prototype.getSetupProcess.call(this).next(() => {\n                return this.wrapAsyncMethod(this.loadScriptData).then((error?: string) => {\n                    if (error) {\n                        const messageElement = new OO.ui.MessageWidget({ type: 'error', label: error });\n\n                        this.content = new OO.ui.PanelLayout({ padded: true, expanded: false });\n                        this.content.$element.append(messageElement.$element);\n\n                        (this as unknown as { $body: JQuery }).$body.append(this.content.$element);\n\n                        this.getActions().setAbilities({ save: false });\n\n                        return;\n                    }\n\n                    this.content = new OO.ui.PanelLayout({ padded: true, expanded: false });\n\n                    this.scriptsMultiselect = new OO.ui.CheckboxMultiselectWidget({\n                        items: this.scripts.map((script) => new OO.ui.CheckboxMultioptionWidget({ data: script.name, label: script.name })),\n                    });\n                    this.scriptsMultiselect.$element[0].style.columnCount = '2';\n\n                    const scriptsMultiselectLayout = new OO.ui.FieldLayout(this.scriptsMultiselect, {\n                        label: new OO.ui.HtmlSnippet('<b>Scripts to update:</b>'),\n                        align: 'top',\n                    });\n\n                    this.actionsMultiselect = new OO.ui.CheckboxMultiselectWidget({\n                        items: [\n                            { id: 'documentation', name: 'Update script documentation' },\n                            { id: 'script', name: 'Update script code' },\n                            { id: 'talk', name: 'Create talk redirect', selectedDefault: false },\n                        ].map(\n                            ({ id, name, selectedDefault }) =>\n                                new OO.ui.CheckboxMultioptionWidget({ data: id, label: name, selected: selectedDefault ?? true }),\n                        ),\n                    });\n\n                    const actionsMultiselectLayout = new OO.ui.FieldLayout(this.actionsMultiselect, {\n                        label: new OO.ui.HtmlSnippet('<b>Actions to take (if applicable):</b>'),\n                        align: 'top',\n                    });\n\n                    const buttonGroup = new OO.ui.ButtonGroupWidget({\n                        items: Object.entries(this.scriptDataUpdaters).map(([name, updater]) => {\n                            const button = new OO.ui.ButtonWidget({\n                                label: name,\n                                flags: ['progressive'],\n                            });\n                            button.on('click', async () => {\n                                mw.notify(`Fetching ${name} data...`, { tag: 'update-script-data-notification' });\n\n                                const data = await updater();\n\n                                mw.notify(`Successfully fetched ${name} data, opening diff...`, {\n                                    type: 'success',\n                                    tag: 'update-script-data-notification',\n                                });\n\n                                await new Promise((resolve) => setTimeout(resolve, 500)); // Allow the notification to be shown\n\n                                this.openDiff(`User:Eejit43/scripts/${name}.json`, data);\n                            });\n\n                            return button;\n                        }),\n                    });\n\n                    const scriptDataUpdatersMultiselectLayout = new OO.ui.FieldLayout(buttonGroup, {\n                        label: new OO.ui.HtmlSnippet('<b>Script data updaters:</b>'),\n                        align: 'top',\n                    });\n\n                    this.content.$element.append(scriptsMultiselectLayout.$element);\n                    this.content.$element.append(actionsMultiselectLayout.$element);\n                    this.content.$element.append(scriptDataUpdatersMultiselectLayout.$element);\n\n                    (this as unknown as { $body: JQuery }).$body.append(this.content.$element);\n                });\n            });\n        };\n\n        getActionProcess = (action: string) => {\n            if (action === 'cancel')\n                return new OO.ui.Process(() => {\n                    this.close();\n                });\n            else if (action === 'save')\n                return new OO.ui.Process(() => {\n                    const selectedScripts = (this.scriptsMultiselect.findSelectedItemsData() as string[]).map(\n                        (scriptName) => this.scripts.find((script) => script.name === scriptName)!,\n                    );\n\n                    this.close();\n\n                    void (async () => {\n                        mw.notify('Syncing scripts...', { tag: 'sync-scripts-notification' });\n\n                        await Promise.all(selectedScripts.map((script) => this.handleScript(script)));\n\n                        await this.editOrCreate(\n                            'User:Eejit43/scripts-info',\n                            [\n                                this.mapScripts(this.scripts.filter((script) => !script.personal && !script.fork)),\n                                '',\n                                '=== Forks ===',\n                                this.mapScripts(this.scripts.filter((script) => script.fork)),\n                                '',\n                                '=== Personal scripts ===',\n                                this.mapScripts(this.scripts.filter((script) => script.personal)),\n                            ].join('\\n'),\n                            'Syncing script list from GitHub',\n                        );\n\n                        mw.notify(`Synced ${selectedScripts.length} script${selectedScripts.length === 1 ? '' : 's'} from GitHub!`, {\n                            type: 'success',\n                            tag: 'sync-scripts-notification',\n                        });\n                    })();\n                });\n            else return ScriptUpdaterDialog.super.prototype.getActionProcess.call(this, action);\n        };\n\n        getTeardownProcess = () => {\n            return ScriptUpdaterDialog.super.prototype.getTeardownProcess.call(this).next(() => {\n                (this as unknown as { $body: JQuery }).$body.empty();\n            });\n        };\n\n        /**\n         * Wraps an async method into a jQuery Deferred object.\n         * @param method The method to wrap.\n         */\n        private wrapAsyncMethod(method: () => Promise<unknown>) {\n            const deferred = $.Deferred();\n\n            void method().then((result) => deferred.resolve(result));\n\n            return deferred.promise();\n        }\n\n        /**\n         * Loads data for all scripts.\n         */\n        private loadScriptData = async () => {\n            const latestCommitHashResponse = await fetch(`https://api.github.com/repos/${this.REPO_OWNER}/${this.REPO_NAME}/commits`);\n            if (!latestCommitHashResponse.ok)\n                return `Failed to fetch latest commit hash from GitHub: ${latestCommitHashResponse.statusText} (${latestCommitHashResponse.status})`;\n\n            this.latestCommitHash = ((await latestCommitHashResponse.json()) as { sha: string }[])[0].sha;\n\n            const scriptDataResponse = await fetch(\n                `https://raw.githubusercontent.com/${this.REPO_OWNER}/${this.REPO_NAME}/${this.latestCommitHash}/scripts.json`,\n            );\n            if (!scriptDataResponse.ok)\n                return `Failed to fetch script data from GitHub: ${scriptDataResponse.statusText} (${scriptDataResponse.status})`;\n\n            const scriptData = (await scriptDataResponse.json()) as Record<string, Omit<Script, 'name'>>;\n\n            this.scripts = Object.entries(scriptData).map(([scriptName, script]) => ({ name: scriptName, ...script }));\n        };\n\n        /**\n         * Handles and edits/creates pages for a given script.\n         * @param script The script to handle.\n         */\n        private async handleScript(script: Script) {\n            const actionsToTake = this.actionsMultiselect.findSelectedItemsData() as ('documentation' | 'script' | 'talk')[];\n\n            const subpageName = `User:Eejit43/scripts/${script.name}`;\n            const subpageTalkName = `User talk:Eejit43/scripts/${script.name}`;\n            const scriptName = `${subpageName}.js`;\n\n            const fullSubpageInfo = [\n                '{{User:Eejit43/script-documentation',\n                script.image === false ? `| image             = ${script.image}` : null,\n                script['in-development'] ? `| in-development    = ${script['in-development']}` : null,\n                script['use-instead']\n                    ? `| use-instead       = ${script['use-instead'].includes('User:') ? script['use-instead'] : `[[User:Eejit43/scripts/${script['use-instead']}|${script['use-instead']}]]`}`\n                    : null,\n                script['image-caption'] ? `| image-caption     = ${script['image-caption']}` : null,\n                script['other-authors']\n                    ? `| other-authors     = ${script['other-authors'].map((author) => `[[User:${author}|${author}]]`).join(', ')}`\n                    : null,\n                `| description-short = ${script['short-description']}`,\n                `| description       = ${script.description}`,\n                script.usage ? `| usage             = ${script.usage}` : null,\n                script.configuration ? `| configuration     = ${script.configuration}` : null,\n                script.changelog\n                    ? `| changelog         = \\n${Object.entries(script.changelog)\n                          .map(\n                              ([date, description]) =>\n                                  `* '''{{start date and age|${date}}}:'''${Array.isArray(description) ? `\\n${description.map((line) => `** ${line}`).join('\\n')}` : ` ${description}`}`,\n                          )\n                          .join('\\n')}`\n                    : null,\n                `| skin-support      = {{User:Eejit43/script-documentation/skin-support|${Object.entries(script['skin-support'])\n                    .map(([skin, status]) => `${skin}=${status}`)\n                    .join('|')}}}`,\n                script['source-multiple'] ? `| source-multiple   = ${script['source-multiple']}` : null,\n                `| released          = {{start date and age|${script.released}}}`,\n                `| updated           = {{start date and age|${script.updated}}}`,\n                '}}',\n            ].filter(Boolean);\n\n            let scriptContent = null;\n\n            if (actionsToTake.includes('script')) {\n                const scriptContentResponse = await fetch(\n                    `https://raw.githubusercontent.com/${this.REPO_OWNER}/${this.REPO_NAME}/${this.latestCommitHash}/dist/${script.name}.js`,\n                );\n                if (scriptContentResponse.ok) scriptContent = await scriptContentResponse.text();\n                else\n                    return mw.notify(\n                        `Failed to fetch \"${script.name}.js\" from GitHub: ${scriptContentResponse.statusText} (${scriptContentResponse.status})`,\n                        { type: 'error', tag: 'sync-scripts-notification' },\n                    );\n            }\n\n            if (!script.personal) {\n                if (actionsToTake.includes('documentation'))\n                    await this.editOrCreate(subpageName, fullSubpageInfo.join('\\n'), 'Syncing script documentation from GitHub');\n\n                if (actionsToTake.includes('talk'))\n                    await this.editOrCreate(\n                        subpageTalkName,\n                        '#REDIRECT [[User talk:Eejit43]]',\n                        'Redirecting script documentation talk page to main user talk page',\n                    );\n            }\n\n            if (scriptContent) await this.editOrCreate(scriptName, scriptContent, 'Syncing script from GitHub');\n        }\n\n        /**\n         * Maps scripts to a bulleted list.\n         * @param scripts The scripts to map.\n         * @returns The mapped scripts.\n         */\n        private mapScripts(scripts: Script[]) {\n            return scripts\n                .map(\n                    (script) =>\n                        `* [[User:Eejit43/scripts/${script.name}${script.personal ? '.js' : ''}|${script.name}]] - ${script['short-description'] || script.description}${\n                            script['in-development'] ? ' (<span style=\"color: #bd2828\">in development</span>)' : ''\n                        }${script['use-instead'] ? ' (<span style=\"color: #bd2828\">deprecated</span>)' : ''}`,\n                )\n                .join('\\n');\n        }\n\n        /**\n         * Edits a page, or creates it if it doesn't exist.\n         * @param title The title of the page to edit.\n         * @param text The page content to set.\n         * @param summary The edit summary (will append script notice).\n         */\n        private async editOrCreate(title: string, text: string, summary: string) {\n            summary += this.SCRIPT_MESSAGE;\n\n            await api\n                .edit(title, () => ({ text, summary, watchlist: 'watch' }))\n                .catch(async (errorCode, errorInfo) => {\n                    if (errorCode === 'nocreate-missing')\n                        await api.create(title, { summary, watchlist: 'watch' }, text).catch((errorCode, errorInfo) => {\n                            mw.notify(\n                                `Error creating ${title}: ${(errorInfo as MediaWikiDataError)?.error?.info ?? 'Unknown error'} (${errorCode})`,\n                                { type: 'error' },\n                            );\n                            return;\n                        });\n                    else {\n                        mw.notify(\n                            `Error editing or creating ${title}: ${(errorInfo as MediaWikiDataError)?.error?.info ?? 'Unknown error'} (${errorCode})`,\n                            { type: 'error' },\n                        );\n                        return;\n                    }\n                });\n        }\n\n        /**\n         * Opens a diff for the given page title and content.\n         * @param pageTitle The title of the page to open a diff for.\n         * @param content The content to set for the page.\n         */\n        private openDiff(pageTitle: string, content: string) {\n            const formData = {\n                wpTextbox1: content,\n                wpSummary: `Updating data${this.SCRIPT_MESSAGE}`,\n                wpDiff: '1', // Any truthy value makes this work\n                wpWatchthis: '1',\n                wpUltimateParam: '1', // Marks the end of form data\n            };\n\n            const formUrl = new URL(`${mw.config.get('wgScriptPath')}/index.php`, window.location.origin);\n            formUrl.searchParams.set('title', pageTitle);\n            formUrl.searchParams.set('action', 'submit');\n\n            const form = document.createElement('form');\n            form.action = formUrl.toString();\n            form.method = 'POST';\n            form.target = '_blank';\n\n            for (const [key, value] of Object.entries(formData)) {\n                const hiddenField = document.createElement('input');\n                hiddenField.type = 'hidden';\n                hiddenField.name = key;\n                hiddenField.value = value;\n\n                form.append(hiddenField);\n            }\n\n            document.body.append(form);\n            form.submit();\n            form.remove();\n        }\n    }\n\n    Object.assign(ScriptUpdaterDialog.prototype, OO.ui.ProcessDialog.prototype);\n});\n\n/**\n * Gets the script data for article-cleaner.\n */\nasync function getArticleCleanerData() {\n    const content = (await getPageContent('Wikipedia:AutoWikiBrowser/Template redirects')) ?? '';\n\n    const replacements = content\n        .matchAll(/\\* {{tl\\|.+/g)\n        .toArray()\n        .map((line) => {\n            const templates = line[0].matchAll(/{{tl\\|(.+?)}}/g).toArray();\n\n            return { from: templates.slice(0, -1).map((template) => template[1]), to: templates.at(-1)![1] };\n        });\n\n    return JSON.stringify(replacements);\n}\n\n/**\n * Chunks an array into smaller arrays of a specified size.\n * @param array The array to chunk.\n * @param chunkSize The size of each chunk.\n */\nfunction chunkArray<T>(array: T[], chunkSize: number): T[][] {\n    const chunked = [];\n\n    for (let index = 0; index < array.length; index += chunkSize) {\n        const chunk = array.slice(index, index + chunkSize);\n\n        chunked.push(chunk);\n    }\n\n    return chunked;\n}\n\n/**\n * Gets a continued query result from the API, returning an array of results.\n * @param query The query parameters to use for the API request.\n */\nasync function getContinuedQuery(query: ApiQueryParams): Promise<ApiResponse[]> {\n    let iteration = 0;\n\n    const returnValue = [];\n\n    let response = { continue: {} } as ApiResponse & QueryContinuation;\n\n    while ('continue' in response && iteration < 10) {\n        response = await api.get({ ...query, ...response.continue } as ApiQueryParams); // eslint-disable-line no-await-in-loop\n\n        returnValue.push(response);\n\n        iteration++;\n    }\n\n    return returnValue;\n}\n\n/**\n * Gets the script data for redirect-helper.\n */\nasync function getRedirectHelperData() {\n    const allRedirectTemplates = (await api.get({\n        action: 'query',\n        list: 'categorymembers',\n        cmtitle: 'Category:Redirect templates',\n        cmlimit: 'max',\n        formatversion: '2',\n    } satisfies ApiQueryCategoryMembersParams)) as CategoryMembersResult;\n    const allPossibleRedirectTemplates = (await api.get({\n        action: 'query',\n        list: 'categorymembers',\n        cmtitle: 'Category:Template redirects with possibilities',\n        cmlimit: 'max',\n        formatversion: '2',\n    } satisfies ApiQueryCategoryMembersParams)) as CategoryMembersResult;\n\n    const redirectTemplates = allRedirectTemplates.query.categorymembers\n        .filter((page) => page.title.startsWith('Template:R ') && page.title !== 'Template:R template index')\n        .map((page) => ({ name: page.title.split(':')[1], redirect: false }));\n    const possibleRedirectTemplates = allPossibleRedirectTemplates.query.categorymembers\n        .filter((page) => page.title.startsWith('Template:R ') && page.title !== 'Template:R with possibilities')\n        .map((page) => ({ name: page.title.split(':')[1], redirect: true }));\n\n    // eslint-disable-next-line unicorn/no-array-sort\n    const allTemplates = [...redirectTemplates, ...possibleRedirectTemplates].sort((a, b) => {\n        // Force comics and Middle Earth templates to the end of the list\n        if (a.name.startsWith('R comics') || a.name.startsWith('R ME')) return 1;\n        else if (b.name.startsWith('R comics') || b.name.startsWith('R ME')) return -1;\n        else return a.name.localeCompare(b.name);\n    });\n\n    const finalData = Object.fromEntries(\n        allTemplates.map((page) => [page.name, { redirect: page.redirect, parameters: {}, aliases: [] as string[] }]),\n    );\n\n    // Fetch the TemplateData for all templates\n    await Promise.all(\n        chunkArray(allTemplates, 50).map(async (chunk) => {\n            const templateDataQueryResult = (await api.get({\n                action: 'templatedata',\n                titles: chunk.map((page) => `Template:${page.name}`),\n                formatversion: '2',\n            } satisfies TemplateDataApiTemplateDataParams)) as TemplateDataResult;\n\n            for (const page of Object.values(templateDataQueryResult.pages)) {\n                const formattedParameters = Object.fromEntries(\n                    Object.entries(page.params).map(([name, data]) => [\n                        name,\n                        {\n                            aliases: data.aliases,\n                            label: data.label?.en ?? null,\n                            description: data.description?.en ?? null,\n                            type: data.type,\n                            required: data.required,\n                            suggested: data.suggested,\n                            default: data.default?.en ?? null,\n                            example: data.example?.en ?? null,\n                        },\n                    ]),\n                );\n\n                finalData[page.title.split(':')[1]].parameters = formattedParameters;\n            }\n        }),\n    );\n\n    // Find aliases of redirect templates\n    await Promise.all(\n        chunkArray(redirectTemplates, 50).map(async (chunk) => {\n            const allRedirectsQueryResult = (await getContinuedQuery({\n                action: 'query',\n                titles: chunk.map((page) => `Template:${page.name}`),\n                prop: 'redirects',\n                rdnamespace: 10,\n                rdlimit: 'max',\n                formatversion: '2',\n            } satisfies ApiQueryBacklinkspropParams)) as RedirectsResult[];\n\n            const redirectsQueryResultPages = allRedirectsQueryResult.flatMap((result) => result.query.pages);\n\n            for (const page of redirectsQueryResultPages) {\n                const mappedRedirects =\n                    page.redirects\n                        ?.map((redirect) => redirect.title.split(':')[1])\n                        .filter((redirect) => !possibleRedirectTemplates.some((template) => template.name === redirect))\n                        .sort((a, b) => a.localeCompare(b)) ?? []; // eslint-disable-line unicorn/no-array-sort\n\n                finalData[page.title.split(':')[1]].aliases.push(...mappedRedirects); // Data might exist from previous queries, so update instead of overwriting\n            }\n        }),\n    );\n\n    // Find aliases of possible redirect templates\n    const allAliasesOfPossibleTemplates: string[] = [];\n\n    await Promise.all(\n        chunkArray(possibleRedirectTemplates, 50).map(async (chunk) => {\n            const linksQueryResult = (await api.get({\n                action: 'query',\n                titles: chunk.map((page) => `Template:${page.name}`),\n                prop: 'linkshere',\n                lhnamespace: 10,\n                lhlimit: 'max',\n                formatversion: '2',\n            } satisfies ApiQueryBacklinkspropParams)) as LinksHereResult;\n\n            for (const page of linksQueryResult.query.pages) {\n                const mappedRedirects =\n                    page.linkshere\n                        ?.filter((page) => page.redirect)\n                        .map((page) => page.title.split(':')[1])\n                        .filter((page) => !page.endsWith('/doc') && !page.endsWith('/sandbox'))\n                        .sort((a, b) => a.localeCompare(b)) ?? []; // eslint-disable-line unicorn/no-array-sort\n\n                allAliasesOfPossibleTemplates.push(...mappedRedirects);\n\n                finalData[page.title.split(':')[1]].aliases = mappedRedirects;\n            }\n        }),\n    );\n\n    const mappedFinalData = Object.entries(finalData).map(([name, templateData]) => {\n        const finalTemplateData = {\n            ...(templateData.redirect ? { redirect: true } : {}),\n            parameters: templateData.parameters,\n            aliases: templateData.aliases.sort((a, b) => a.localeCompare(b)), // eslint-disable-line unicorn/no-array-sort\n        };\n\n        return [name, finalTemplateData] as const;\n    });\n\n    for (const possibleTemplateAlias of allAliasesOfPossibleTemplates)\n        for (const [, data] of mappedFinalData)\n            if (!data.redirect && data.aliases.includes(possibleTemplateAlias))\n                data.aliases = data.aliases.filter((alias) => alias !== possibleTemplateAlias);\n\n    return JSON.stringify(Object.fromEntries(mappedFinalData));\n}\n"],
  "mappings": "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",
  "names": ["api", "getPageContent", "title", "fullLinkElement", "link", "event", "windowManager", "scriptUpdaterDialog", "ScriptUpdaterDialog", "getArticleCleanerData", "getRedirectHelperData", "error", "messageElement", "script", "scriptsMultiselectLayout", "id", "name", "selectedDefault", "actionsMultiselectLayout", "buttonGroup", "updater", "button", "data", "resolve", "scriptDataUpdatersMultiselectLayout", "action", "selectedScripts", "scriptName", "method", "deferred", "result", "latestCommitHashResponse", "scriptDataResponse", "scriptData", "actionsToTake", "subpageName", "subpageTalkName", "fullSubpageInfo", "author", "date", "description", "line", "skin", "status", "scriptContent", "scriptContentResponse", "scripts", "title", "text", "summary", "api", "errorCode", "errorInfo", "pageTitle", "content", "formData", "formUrl", "form", "key", "value", "hiddenField", "replacements", "getPageContent", "templates", "template", "chunkArray", "array", "chunkSize", "chunked", "index", "chunk", "getContinuedQuery", "query", "iteration", "returnValue", "response", "allRedirectTemplates", "allPossibleRedirectTemplates", "redirectTemplates", "page", "possibleRedirectTemplates", "allTemplates", "a", "b", "finalData", "templateDataQueryResult", "formattedParameters", "redirectsQueryResultPages", "mappedRedirects", "redirect", "allAliasesOfPossibleTemplates", "linksQueryResult", "mappedFinalData", "templateData", "finalTemplateData", "possibleTemplateAlias", "alias"]
}


AltStyle によって変換されたページ (->オリジナル) /