26 lines
568 B
TypeScript
26 lines
568 B
TypeScript
import { TLAssetStore, uniqueId } from 'tldraw'
|
|
import { WORKER_URL } from '../routes/Board'
|
|
|
|
export const multiplayerAssetStore: TLAssetStore = {
|
|
async upload(_asset, file) {
|
|
const id = uniqueId()
|
|
const objectName = `${id}-${file.name}`.replace(/[^a-zA-Z0-9.]/g, '-')
|
|
const url = `${WORKER_URL}/uploads/${objectName}`
|
|
|
|
const response = await fetch(url, {
|
|
method: 'POST',
|
|
body: file,
|
|
})
|
|
|
|
if (!response.ok) {
|
|
throw new Error(`Failed to upload asset: ${response.statusText}`)
|
|
}
|
|
|
|
return url
|
|
},
|
|
|
|
resolve(asset) {
|
|
return asset.props.src
|
|
},
|
|
}
|