User:Eejit43/scripts/script-updater.js

// // 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";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;const m=document.querySelector(".mw-editsection").cloneNode(!0),r=document.createElement("a");r.href="#",r.style.fontWeight="bold",r.textContent="Sync from GitHub",r.addEventListener("click",h=>{h.preventDefault;const e=new OO.ui.WindowManager;document.body.append(e.$element[0]);const t=new i;e.addWindows([t]),t.open}),m.querySelector("a").replaceWith(r),document.querySelector("#My_user_scripts.mw-headline").after(m);class i extends OO.ui.ProcessDialog{repoOwner="Eejit43";repoName="wikipedia-scripts";content;checkboxElements=[];latestCommitHash;scripts;constructor{super({size:"medium"}),i.static.name="ScriptUpdaterDialog",i.static.title="What scripts do you want to update?",i.static.actions=[{action:"cancel",label:"Close",flags:["safe","close"]},{action:"save",label:"Run",flags:["primary","progressive"]}]}getSetupProcess==>i.super.prototype.getSetupProcess.call(this).next(=>this.wrapAsyncMethod(this.loadScriptData).then(e=>{if(e){const t=new OO.ui.MessageWidget({type:"error",label:e});this.content=new OO.ui.PanelLayout({padded:!0,expanded:!1}),this.content.$element.append(t.$element),this.$body.append(this.content.$element),this.getActions.setAbilities({save:!1});return}this.content=new OO.ui.PanelLayout({padded:!0,expanded:!1});for(const t of this.scripts){const s=new OO.ui.CheckboxInputWidget;this.checkboxElements.push([t.name,s]);const a=new OO.ui.FieldLayout(s,{align:"inline",label:t.name});this.content.$element.append(a.$element)}this.$body.append(this.content.$element)}));getActionProcess=e=>e==="cancel"?new OO.ui.Process(=>{this.getManager.closeWindow(this)}):e==="save"?new OO.ui.Process(=>{const t=[];for(const[s,a]of this.checkboxElements)a.isSelected&&t.push(this.scripts.find(o=>o.name===s));this.getManager.closeWindow(this),(async=>(mw.notify("Syncing scripts...",{tag:"sync-scripts-notification"}),await Promise.all(t.map(s=>this.handleScript(s))),await this.editOrCreate("User:Eejit43/scripts-info",[this.mapScripts(this.scripts.filter(s=>!s.personal&&!s.fork)),"","=== Forks ===",this.mapScripts(this.scripts.filter(s=>s.fork)),"","=== Personal scripts ===",this.mapScripts(this.scripts.filter(s=>s.personal))].join(` `),"Syncing script list from GitHub"),mw.notify(`Synced ${t.length} script${t.length===1?"":"s"} from GitHub!`,{type:"success",tag:"sync-scripts-notification"})))}):i.super.prototype.getActionProcess.call(this,e);getTeardownProcess==>i.super.prototype.getTeardownProcess.call(this).next(=>{this.$body.empty});wrapAsyncMethod(e){const t=$.Deferred;return e.then(s=>t.resolve(s)),t.promise}loadScriptData=async=>{const e=await fetch(`https://api.github.com/repos/${this.repoOwner}/${this.repoName}/commits`);if(!e.ok)return`Failed to fetch latest commit hash from GitHub: ${e.statusText} (${e.status})`;this.latestCommitHash=(await e.json)[0].sha;const t=await fetch(`https://raw.githubusercontent.com/${this.repoOwner}/${this.repoName}/${this.latestCommitHash}/scripts.json`);if(!t.ok)return`Failed to fetch script data from GitHub: ${t.statusText} (${t.status})`;this.scripts=await t.json};async handleScript(e){const t=`User:Eejit43/scripts/${e.name}`,s=`User talk:Eejit43/scripts/${e.name}`,a=`${t}.js`,o=`${t}.css`,u=[""].filter(Boolean);let c=null;const p=await fetch(`https://raw.githubusercontent.com/${this.repoOwner}/${this.repoName}/${this.latestCommitHash}/dist/scripts/${e.name}.js`);if(p.ok)c=await p.text;else return mw.notify(`Failed to fetch "${e.name}.js" from GitHub: ${p.statusText} (${p.status})`,{type:"error",tag:"sync-scripts-notification"});let d=null;if(e.css){const n=await fetch(`https://raw.githubusercontent.com/${this.repoOwner}/${this.repoName}/${this.latestCommitHash}/dist/styles/${e.name}.css`);n.ok?d=await n.text:mw.notify(`Failed to fetch "${e.name}.css" from GitHub: ${n.statusText} (${n.status})`,{type:"error",tag:"sync-scripts-notification"})}e.personal||(await this.editOrCreate(t,u.join(` `),"Syncing script documentation from GitHub"),await this.editOrCreate(s,"#REDIRECT User talk:Eejit43","Redirecting script documentation talk page to main user talk page")),c&&await this.editOrCreate(a,c,"Syncing script from GitHub"),e.css&&d&&await this.editOrCreate(o,d,"Syncing styles from GitHub")}mapScripts(e){return e.map(t=>`* ${t.name} - ${t["short-description"]||t.description}${t["in-development"]?' ( in development )':""}${t["use-instead"]?' ( deprecated )':""}`).join(` `)}async editOrCreate(e,t,s){s+=" (via script)",await new mw.Api.edit(e,=>({text:t,summary:s,watchlist:"watch"})).catch(async(a,o)=>{if(a==="nocreate-missing")await new mw.Api.create(e,{summary:s,watchlist:"watch"},t).catch((u,c)=>{mw.notify(`Error creating ${e}: ${c?.error.info??"Unknown error"} (${u})`,{type:"error"})});else{mw.notify(`Error editing or creating ${e}: ${o?.error.info??"Unknown error"} (${a})`,{type:"error"});return}})}}Object.assign(i.prototype,OO.ui.ProcessDialog.prototype)});

// //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../scripts/script-updater.ts"],
  "sourcesContent": ["import { MediaWikiDataError } from '../global-types';\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    changelog?: Record<string, string | string[]>;\n    'other-authors'?: string[];\n    fork?: true;\n    personal?: true;\n    'skin-support': Record<string, boolean>;\n    released: string;\n    updated: string;\n    css?: true;\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('#My_user_scripts.mw-headline')!.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 repoOwner = 'Eejit43';\n        private repoName = 'wikipedia-scripts';\n\n        private content!: OO.ui.PanelLayout;\n        private checkboxElements: [string, OO.ui.CheckboxInputWidget][] = [];\n\n        private latestCommitHash!: string;\n        private scripts!: Script[];\n\n        constructor() {\n            super({ size: 'medium' });\n\n            ScriptUpdaterDialog.static.name = 'ScriptUpdaterDialog';\n            ScriptUpdaterDialog.static.title = 'What scripts do you want to update?';\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                    for (const script of this.scripts) {\n                        const checkbox = new OO.ui.CheckboxInputWidget();\n\n                        this.checkboxElements.push([script.name, checkbox]);\n\n                        const layout = new OO.ui.FieldLayout(checkbox, { align: 'inline', label: script.name });\n\n                        this.content.$element.append(layout.$element);\n                    }\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.getManager().closeWindow(this);\n                });\n            else if (action === 'save')\n                return new OO.ui.Process(() => {\n                    const selectedScripts = [];\n                    for (const [scriptName, checkbox] of this.checkboxElements) if (checkbox.isSelected()) selectedScripts.push(this.scripts.find((script) => script.name === scriptName)!);\n\n                    this.getManager().closeWindow(this);\n\n                    (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!`, { type: 'success', tag: 'sync-scripts-notification' });\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            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.repoOwner}/${this.repoName}/commits`);\n            if (!latestCommitHashResponse.ok) 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(`https://raw.githubusercontent.com/${this.repoOwner}/${this.repoName}/${this.latestCommitHash}/scripts.json`);\n            if (!scriptDataResponse.ok) return `Failed to fetch script data from GitHub: ${scriptDataResponse.statusText} (${scriptDataResponse.status})`;\n\n            this.scripts = (await scriptDataResponse.json()) as 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 subpageName = `User:Eejit43/scripts/${script.name}`;\n            const subpageTalkName = `User talk:Eejit43/scripts/${script.name}`;\n            const scriptName = `${subpageName}.js`;\n            const styleName = `${subpageName}.css`;\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'] ? `| use-instead       = [[User:Eejit43/scripts/${script['use-instead']}|${script['use-instead']}]]` : null,\n                script['image-caption'] ? `| image-caption     = ${script['image-caption']}` : null,\n                script['other-authors'] ? `| other-authors     = ${script['other-authors'].map((author) => `[[User:${author}|${author}]]`).join(', ')}` : null,\n                `| description-short = ${script['short-description']}`,\n                `| description       = ${script.description}`,\n                script.usage ? `| usage             = ${script.usage}` : 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/skin-support|${Object.entries(script['skin-support'])\n                    .map(([skin, status]) => `${skin}=${status}`)\n                    .join('|')}}}`,\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            const scriptContentResponse = await fetch(`https://raw.githubusercontent.com/${this.repoOwner}/${this.repoName}/${this.latestCommitHash}/dist/scripts/${script.name}.js`);\n            if (scriptContentResponse.ok) scriptContent = await scriptContentResponse.text();\n            else\n                return mw.notify(`Failed to fetch \"${script.name}.js\" from GitHub: ${scriptContentResponse.statusText} (${scriptContentResponse.status})`, {\n                    type: 'error',\n                    tag: 'sync-scripts-notification',\n                });\n\n            let styleContent = null;\n            if (script.css) {\n                const styleContentResponse = await fetch(`https://raw.githubusercontent.com/${this.repoOwner}/${this.repoName}/${this.latestCommitHash}/dist/styles/${script.name}.css`);\n\n                if (styleContentResponse.ok) styleContent = await styleContentResponse.text();\n                else\n                    mw.notify(`Failed to fetch \"${script.name}.css\" from GitHub: ${styleContentResponse.statusText} (${styleContentResponse.status})`, {\n                        type: 'error',\n                        tag: 'sync-scripts-notification',\n                    });\n            }\n\n            if (!script.personal) {\n                await this.editOrCreate(subpageName, fullSubpageInfo.join('\\n'), 'Syncing script documentation from GitHub');\n                await this.editOrCreate(subpageTalkName, '#REDIRECT [[User talk:Eejit43]]', 'Redirecting script documentation talk page to main user talk page');\n            }\n\n            if (scriptContent) await this.editOrCreate(scriptName, scriptContent, 'Syncing script from GitHub');\n\n            if (script.css && styleContent) await this.editOrCreate(styleName, styleContent, 'Syncing styles 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 += ' (via [[User:Eejit43/scripts/script-updater.js|script]])';\n            await new mw.Api()\n                .edit(title, () => ({ text, summary, watchlist: 'watch' }))\n                .catch(async (errorCode: string, errorInfo: MediaWikiDataError) => {\n                    if (errorCode === 'nocreate-missing')\n                        await new mw.Api().create(title, { summary, watchlist: 'watch' }, text).catch((errorCode: string, errorInfo: MediaWikiDataError) => {\n                            mw.notify(`Error creating ${title}: ${errorInfo?.error.info ?? 'Unknown error'} (${errorCode})`, { type: 'error' });\n                            return;\n                        });\n                    else {\n                        mw.notify(`Error editing or creating ${title}: ${errorInfo?.error.info ?? 'Unknown error'} (${errorCode})`, { type: 'error' });\n                        return;\n                    }\n                });\n        }\n    }\n\n    Object.assign(ScriptUpdaterDialog.prototype, OO.ui.ProcessDialog.prototype);\n});\n"],
  "mappings": "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",
  "names": ["fullLinkElement", "link", "event", "windowManager", "scriptUpdaterDialog", "ScriptUpdaterDialog", "error", "messageElement", "script", "checkbox", "layout", "action", "selectedScripts", "scriptName", "method", "deferred", "result", "latestCommitHashResponse", "scriptDataResponse", "subpageName", "subpageTalkName", "styleName", "fullSubpageInfo", "author", "date", "description", "line", "skin", "status", "scriptContent", "scriptContentResponse", "styleContent", "styleContentResponse", "scripts", "title", "text", "summary", "errorCode", "errorInfo"]
}
