feat(individual parts): multiple download types
This commit is contained in:
parent
00fcd63c1c
commit
ad2020f4c2
1 changed files with 46 additions and 7 deletions
53
src/main.ts
53
src/main.ts
|
@ -64,6 +64,35 @@ const main = (): void => {
|
||||||
const fieldset = w.document.createElement('fieldset')
|
const fieldset = w.document.createElement('fieldset')
|
||||||
w.document.body.append(fieldset)
|
w.document.body.append(fieldset)
|
||||||
|
|
||||||
|
interface IndividualDownload {
|
||||||
|
name: string;
|
||||||
|
fileExt: string;
|
||||||
|
action (score: import('webmscore').default): Promise<Uint8Array>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const downloads: IndividualDownload[] = [
|
||||||
|
{
|
||||||
|
name: 'Download PDF',
|
||||||
|
fileExt: 'pdf',
|
||||||
|
action: (score) => score.savePdf(),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Download MIDI',
|
||||||
|
fileExt: 'mid',
|
||||||
|
action: (score) => score.saveMidi(true, true),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Download Part MSCZ',
|
||||||
|
fileExt: 'mscz',
|
||||||
|
action: (score) => score.saveMsc('mscz'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Download Part MusicXML',
|
||||||
|
fileExt: 'mxl',
|
||||||
|
action: (score) => score.saveMxl(),
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
// part selection
|
// part selection
|
||||||
for (const excerpt of metadata.excerpts) {
|
for (const excerpt of metadata.excerpts) {
|
||||||
const id = excerpt.id
|
const id = excerpt.id
|
||||||
|
@ -75,7 +104,7 @@ const main = (): void => {
|
||||||
e.alt = partName
|
e.alt = partName
|
||||||
e.checked = id === 0 // initially select the first part
|
e.checked = id === 0 // initially select the first part
|
||||||
e.onclick = () => {
|
e.onclick = () => {
|
||||||
return score.setExcerptId(id)
|
return score.setExcerptId(id) // set selected part
|
||||||
}
|
}
|
||||||
|
|
||||||
const label = w.document.createElement('label')
|
const label = w.document.createElement('label')
|
||||||
|
@ -88,25 +117,35 @@ const main = (): void => {
|
||||||
await score.setExcerptId(0) // initially select the first part
|
await score.setExcerptId(0) // initially select the first part
|
||||||
|
|
||||||
// submit buttons
|
// submit buttons
|
||||||
for (const btn of btns) {
|
for (const d of downloads) {
|
||||||
const submitBtn = w.document.createElement('input')
|
const submitBtn = w.document.createElement('input')
|
||||||
submitBtn.type = 'submit'
|
submitBtn.type = 'submit'
|
||||||
submitBtn.value = btn.name
|
submitBtn.style.margin = '0.5em'
|
||||||
fieldset.append(submitBtn)
|
fieldset.append(submitBtn)
|
||||||
|
|
||||||
|
const initBtn = () => {
|
||||||
|
submitBtn.onclick = onSubmit
|
||||||
|
submitBtn.disabled = false
|
||||||
|
submitBtn.value = d.name
|
||||||
|
}
|
||||||
|
|
||||||
const onSubmit = async (): Promise<void> => {
|
const onSubmit = async (): Promise<void> => {
|
||||||
// lock the button when processing
|
// lock the button when processing
|
||||||
submitBtn.onclick = null
|
submitBtn.onclick = null
|
||||||
|
submitBtn.disabled = true
|
||||||
|
submitBtn.value = 'Processing…'
|
||||||
|
|
||||||
const checked = fieldset.querySelector('input:checked') as HTMLInputElement
|
const checked = fieldset.querySelector('input:checked') as HTMLInputElement
|
||||||
const partName = checked.alt
|
const partName = checked.alt
|
||||||
|
|
||||||
const data = new Blob([await btn.action(score)])
|
const data = new Blob([await d.action(score)])
|
||||||
saveAs(data, `${filename} - ${partName}.${btn.fileExt}`)
|
saveAs(data, `${filename} - ${partName}.${d.fileExt}`)
|
||||||
|
|
||||||
submitBtn.onclick = onSubmit
|
// unlock button
|
||||||
|
initBtn()
|
||||||
}
|
}
|
||||||
submitBtn.onclick = onSubmit
|
|
||||||
|
initBtn()
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in a new issue