mirror of https://github.com/docusealco/docuseal
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
83 lines
2.1 KiB
83 lines
2.1 KiB
import { target, targetable } from '@github/catalyst/lib/targetable'
|
|
|
|
export default targetable(class extends HTMLElement {
|
|
static [target.static] = ['defaultButton', 'loadingButton']
|
|
|
|
connectedCallback () {
|
|
this.addEventListener('click', () => this.downloadFiles())
|
|
}
|
|
|
|
toggleState () {
|
|
this.defaultButton?.classList?.toggle('hidden')
|
|
this.loadingButton?.classList?.toggle('hidden')
|
|
}
|
|
|
|
downloadFiles () {
|
|
if (!this.dataset.src) return
|
|
|
|
this.toggleState()
|
|
|
|
fetch(this.dataset.src).then((response) => response.json()).then((urls) => {
|
|
const isSafariIos = /iPhone|iPad|iPod/i.test(navigator.userAgent)
|
|
|
|
if (isSafariIos && urls.length > 1) {
|
|
this.downloadSafariIos(urls)
|
|
} else {
|
|
this.downloadUrls(urls)
|
|
}
|
|
})
|
|
}
|
|
|
|
downloadUrls (urls) {
|
|
const fileRequests = urls.map((url) => {
|
|
return () => {
|
|
return fetch(url).then(async (resp) => {
|
|
const blobUrl = URL.createObjectURL(await resp.blob())
|
|
const link = document.createElement('a')
|
|
|
|
link.href = blobUrl
|
|
link.setAttribute('download', decodeURI(url.split('/').pop()))
|
|
|
|
link.click()
|
|
|
|
URL.revokeObjectURL(blobUrl)
|
|
})
|
|
}
|
|
})
|
|
|
|
fileRequests.reduce(
|
|
(prevPromise, request) => prevPromise.then(() => request()),
|
|
Promise.resolve()
|
|
).finally(() => {
|
|
this.toggleState()
|
|
})
|
|
}
|
|
|
|
downloadSafariIos (urls) {
|
|
const fileRequests = urls.map((url) => {
|
|
return fetch(url).then(async (resp) => {
|
|
const blob = await resp.blob()
|
|
const blobUrl = URL.createObjectURL(blob.slice(0, blob.size, 'application/octet-stream'))
|
|
const link = document.createElement('a')
|
|
|
|
link.href = blobUrl
|
|
link.setAttribute('download', decodeURI(url.split('/').pop()))
|
|
|
|
return link
|
|
})
|
|
})
|
|
|
|
Promise.all(fileRequests).then((links) => {
|
|
links.forEach((link, index) => {
|
|
setTimeout(() => {
|
|
link.click()
|
|
|
|
URL.revokeObjectURL(link.href)
|
|
}, index * 50)
|
|
})
|
|
}).finally(() => {
|
|
this.toggleState()
|
|
})
|
|
}
|
|
})
|