refactor: commit btn list

This commit is contained in:
Xmader 2020-11-10 13:36:49 -05:00
parent 8b6c61c6bc
commit 942acd0842
No known key found for this signature in database
GPG key ID: A20B97FB9EB730E4
2 changed files with 21 additions and 28 deletions

View file

@ -1,6 +1,5 @@
import { loadMscore, WebMscore } from './mscore' import { loadMscore, WebMscore } from './mscore'
import { webpackGlobalOverride } from './webpack-hook'
import i18n from './i18n' import i18n from './i18n'
type BtnElement = HTMLButtonElement type BtnElement = HTMLButtonElement
@ -9,7 +8,7 @@ type BtnElement = HTMLButtonElement
* Select the original Download Button * Select the original Download Button
*/ */
export const getDownloadBtn = (): BtnElement => { export const getDownloadBtn = (): BtnElement => {
const btnsDiv = document.querySelector('.score-right .buttons-wrapper') || document.querySelectorAll('aside > section > section > div')[3] const btnsDiv = document.querySelector('.score-right .buttons-wrapper') || document.querySelectorAll('aside>section>section')[0].children[3]
const btn = btnsDiv.querySelector('button, .button') as BtnElement const btn = btnsDiv.querySelector('button, .button') as BtnElement
btn.onclick = null btn.onclick = null
@ -36,33 +35,15 @@ interface BtnOptions {
readonly tooltip?: string; readonly tooltip?: string;
} }
const SCORE_BTN_MODULE_ID = 'WYqd'
webpackGlobalOverride(SCORE_BTN_MODULE_ID, (_, r, t) => { // override
const fn = r.a
let firstTime = true
// the root container of btns refreshes every 1s
t.d(r, 'a', () => {
return function () {
if (!firstTime) {
// force state update
this.__H.__[0].__[0] = 0
} else {
firstTime = false
}
return fn() as void
}
})
})
export class BtnList { export class BtnList {
private readonly list: BtnElement[] = []; private readonly list: BtnElement[] = [];
constructor (private templateBtn: BtnElement) { } constructor (private getTemplateBtn: () => BtnElement) { }
private antiDetectionText = 'Download' private antiDetectionText = 'Download'
add (options: BtnOptions): BtnElement { add (options: BtnOptions): BtnElement {
const btn = this.templateBtn.cloneNode(true) as HTMLButtonElement const btn = this.getTemplateBtn().cloneNode(true) as HTMLButtonElement
const textNode = [...btn.childNodes].find((x) => { const textNode = [...btn.childNodes].find((x) => {
const txt = x.textContent as string const txt = x.textContent as string
@ -108,11 +89,8 @@ export class BtnList {
return btn return btn
} }
/** private _commit (): Element {
* replace the template button with the list of new buttons const parent = this.getTemplateBtn().parentElement as HTMLDivElement
*/
commit (): void {
const parent = this.templateBtn.parentElement as HTMLDivElement
const shadow = parent.attachShadow({ mode: 'closed' }) const shadow = parent.attachShadow({ mode: 'closed' })
// style the shadow DOM from outside css // style the shadow DOM from outside css
@ -124,6 +102,21 @@ export class BtnList {
const newParent = parent.cloneNode(false) as HTMLDivElement const newParent = parent.cloneNode(false) as HTMLDivElement
newParent.append(...this.list) newParent.append(...this.list)
shadow.append(newParent) shadow.append(newParent)
return parent
}
/**
* replace the template button with the list of new buttons
*/
commit (): void {
let el = this._commit()
const observer = new MutationObserver(() => {
if (!document.contains(el)) {
el = this._commit()
}
})
observer.observe(document, { childList: true, subtree: true })
} }
} }

View file

@ -15,7 +15,7 @@ const main = (): void => {
// eslint-disable-next-line @typescript-eslint/no-floating-promises // eslint-disable-next-line @typescript-eslint/no-floating-promises
recaptcha.init() recaptcha.init()
const btnList = new BtnList(getDownloadBtn()) const btnList = new BtnList(getDownloadBtn)
const filename = scoreinfo.fileName const filename = scoreinfo.fileName
btnList.add({ btnList.add({