feat: btns fallback to load from MSCZ file (Individual Parts)

This commit is contained in:
Xmader 2020-11-13 00:54:20 -05:00
parent 0764117544
commit 9aa6c406c6
No known key found for this signature in database
GPG key ID: A20B97FB9EB730E4
3 changed files with 31 additions and 9 deletions

View file

@ -1,5 +1,6 @@
import { loadMscore, WebMscore } from './mscore'
import { useTimeout } from './utils'
import i18n from './i18n'
// @ts-ignore
import btnListCss from './btn.css'
@ -159,12 +160,18 @@ export namespace BtnAction {
})
}
export const download = (url: UrlInput): BtnAction => {
return process(async (): Promise<any> => {
const _url = await normalizeUrlInput(url)
const a = document.createElement('a')
a.href = _url
a.dispatchEvent(new MouseEvent('click'))
export const download = (url: UrlInput, fallback?: () => Promisable<void>, timeout = 30 * 1000): BtnAction => {
return process(async (): Promise<void> => {
try {
const _url = await useTimeout(normalizeUrlInput(url), timeout)
const a = document.createElement('a')
a.href = _url
a.dispatchEvent(new MouseEvent('click'))
} catch (err) {
// use fallback
console.error(err)
return fallback?.()
}
})
}

View file

@ -13,6 +13,8 @@ const main = (): void => {
const btnList = new BtnList()
const filename = scoreinfo.fileName
let indvPartBtn: HTMLButtonElement | null = null
btnList.add({
name: i18n('DOWNLOAD')('MSCZ'),
action: BtnAction.process(downloadMscz),
@ -35,15 +37,15 @@ const main = (): void => {
btnList.add({
name: i18n('DOWNLOAD')('MIDI'),
action: BtnAction.download(() => getFileUrl('midi')),
action: BtnAction.download(() => getFileUrl('midi'), () => indvPartBtn?.click()),
})
btnList.add({
name: i18n('DOWNLOAD')('MP3'),
action: BtnAction.download(() => getFileUrl('mp3')),
action: BtnAction.download(() => getFileUrl('mp3'), () => indvPartBtn?.click()),
})
btnList.add({
indvPartBtn = btnList.add({
name: i18n('IND_PARTS')(),
tooltip: i18n('IND_PARTS_TOOLTIP')(),
action: BtnAction.mscoreWindow(async (w, score, txt) => {

View file

@ -19,6 +19,19 @@ export const fetchData = async (url: string, init?: RequestInit): Promise<Uint8A
return new Uint8Array(data)
}
export const useTimeout = async <T> (promise: T | Promise<T>, ms: number): Promise<T> => {
if (!(promise instanceof Promise)) {
return promise
}
return new Promise((resolve, reject) => {
const i = setTimeout(() => {
reject(new Error('timeout'))
}, ms)
promise.then(resolve, reject).finally(() => clearTimeout(i))
})
}
export const waitForDocumentLoaded = (): Promise<void> => {
if (document.readyState !== 'complete') {
return new Promise(resolve => {