// <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";(()=>{var g=new mw.Api;async function y(d){return(await g.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;let d=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();let e=new OO.ui.WindowManager;document.body.append(e.$element[0]);let s=new l;e.addWindows([s]),s.open()}),d.querySelector("a").replaceWith(u),document.querySelector("h2#My_user_scripts + .mw-editsection").after(d);class l extends OO.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){let i=new OO.ui.MessageWidget({type:"error",label:e});this.content=new OO.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=new OO.ui.PanelLayout({padded:!0,expanded:!1}),this.scriptsMultiselect=new OO.ui.CheckboxMultiselectWidget({items:this.scripts.map(i=>new OO.ui.CheckboxMultioptionWidget({data:i.name,label:i.name}))}),this.scriptsMultiselect.$element[0].style.columnCount="2";let s=new OO.ui.FieldLayout(this.scriptsMultiselect,{label:new OO.ui.HtmlSnippet("<b>Scripts to update:</b>"),align:"top"});this.actionsMultiselect=new OO.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})=>new OO.ui.CheckboxMultioptionWidget({data:i,label:r,selected:a??!0}))});let n=new OO.ui.FieldLayout(this.actionsMultiselect,{label:new OO.ui.HtmlSnippet("<b>Actions to take (if applicable):</b>"),align:"top"}),m=new OO.ui.ButtonGroupWidget({items:Object.entries(this.scriptDataUpdaters).map(([i,r])=>{let a=new OO.ui.ButtonWidget({label:i,flags:["progressive"]});return a.on("click",async()=>{mw.notify(`Fetching ${i} data...`,{tag:"update-script-data-notification"});let o=await r();mw.notify(`Successfully fetched ${i} data, opening diff...`,{type:"success",tag:"update-script-data-notification"}),await new Promise(c=>setTimeout(c,500)),this.openDiff(`User:Eejit43/scripts/${i}.json`,o)}),a})}),t=new OO.ui.FieldLayout(m,{label:new OO.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"?new OO.ui.Process(()=>{this.close()}):e==="save"?new OO.ui.Process(()=>{let s=this.scriptsMultiselect.findSelectedItemsData().map(n=>this.scripts.find(m=>m.name===n));this.close(),(async()=>(mw.notify("Syncing scripts...",{tag:"sync-scripts-notification"}),await Promise.all(s.map(n=>this.handleScript(n))),await this.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){let s=$.Deferred();return e().then(n=>s.resolve(n)),s.promise()}loadScriptData=async()=>{let e=await fetch(`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=(await e.json())[0].sha;let s=await fetch(`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})`;let n=await s.json();this.scripts=Object.entries(n).map(([m,t])=>({name:m,...t}))};async handleScript(e){let s=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")){let a=await fetch(`https://raw.githubusercontent.com/${this.REPO_OWNER}/${this.REPO_NAME}/${this.latestCommitHash}/dist/${e.name}.js`);if(a.ok)r=await a.text();else return mw.notify(`Failed to fetch "${e.name}.js" from GitHub: ${a.statusText} (${a.status})`,{type:"error",tag:"sync-scripts-notification"})}e.personal||(s.includes("documentation")&&await this.editOrCreate(n,i.join(`
`),"Syncing script documentation from GitHub"),s.includes("talk")&&await this.editOrCreate(m,"#REDIRECT [[User talk:Eejit43]]","Redirecting script documentation talk page to main user talk page")),r&&await this.editOrCreate(t,r,"Syncing script from GitHub")}mapScripts(e){return e.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(`
`)}async editOrCreate(e,s,n){n+=this.SCRIPT_MESSAGE,await g.edit(e,()=>({text:s,summary:n,watchlist:"watch"})).catch(async(m,t)=>{if(m==="nocreate-missing")await g.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){let n={wpTextbox1:s,wpSummary:`Updating data${this.SCRIPT_MESSAGE}`,wpDiff:"1",wpUltimateParam:"1"},m=new URL(`${mw.config.get("wgScriptPath")}/index.php`,window.___location.origin);m.searchParams.set("title",e),m.searchParams.set("action","submit");let t=document.createElement("form");t.action=m.toString(),t.method="POST",t.target="_blank";for(let[i,r]of Object.entries(n)){let a=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)});async function w(){let u=(await y("Wikipedia:AutoWikiBrowser/Template redirects")??"").matchAll(/\* {{tl\|.+/g).toArray().map(l=>{let p=l[0].matchAll(/{{tl\|(.+?)}}/g).toArray();return{from:p.slice(0,-1).map(e=>e[1]),to:p.at(-1)[1]}});return JSON.stringify(u)}function h(d,u){let l=[];for(let p=0;p<d.length;p+=u){let e=d.slice(p,p+u);l.push(e)}return l}async function b(d){let u=0,l=[],p={continue:{}};for(;"continue"in p&&u<10;)p=await g.get({...d,...p.continue}),l.push(p),u++;return l}async function O(){let d=await g.get({action:"query",list:"categorymembers",cmtitle:"Category:Redirect templates",cmlimit:"max",formatversion:"2"}),u=await g.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:[]}]));await Promise.all(h(e,50).map(async t=>{let i=await g.get({action:"templatedata",titles:t.map(r=>`Template:${r.name}`),formatversion:"2"});for(let r of Object.values(i.pages)){let a=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}})),await Promise.all(h(l,50).map(async t=>{let r=(await b({action:"query",titles:t.map(a=>`Template:${a.name}`),prop:"redirects",rdnamespace:10,rdlimit:"max",formatversion:"2"})).flatMap(a=>a.query.pages);for(let a of r){let o=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)}}));let n=[];await Promise.all(h(p,50).map(async t=>{let i=await g.get({action:"query",titles:t.map(r=>`Template:${r.name}`),prop:"linkshere",lhnamespace:10,lhlimit:"max",formatversion:"2"});for(let r of i.query.pages){let a=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}}));let m=Object.entries(s).map(([t,i])=>{let r={...i.redirect?{redirect:!0}:{},parameters:i.parameters,aliases:i.aliases.sort((a,o)=>a.localeCompare(o))};return[t,r]});for(let t of n)for(let[,i]of m)!i.redirect&&i.aliases.includes(t)&&(i.aliases=i.aliases.filter(r=>r!==t));return JSON.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_params';\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_params';\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                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    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)) ?? [];\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)) ?? [];\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)),\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"]
}
