|
<script lang="ts"> |
|
import IconCommunity from '$lib/Icons/IconCommunity.svelte'; |
|
import LoadingIcon from '$lib/Icons/LoadingIcon.svelte'; |
|
import { uploadImage } from '$lib/utils'; |
|
import { canvasEl, selectedRoomID } from '$lib/store'; |
|
import { nanoid } from 'nanoid'; |
|
|
|
export let classList = ''; |
|
|
|
let isUploading: boolean = false; |
|
async function handleClick() { |
|
if (isUploading) { |
|
return; |
|
} |
|
const blob: Blob = await new Promise((resolve) => { |
|
$canvasEl.toBlob(resolve as BlobCallback, 'image/jpeg', 0.95); |
|
}); |
|
isUploading = true; |
|
await createCommunityPost(blob); |
|
isUploading = false; |
|
} |
|
|
|
async function createCommunityPost(canvasBlob: Blob) { |
|
const canvasURL = await uploadImage(canvasBlob, { |
|
prompt: 'canvas', |
|
position: { x: 0, y: 0 }, |
|
date: new Date().getTime(), |
|
id: nanoid(), |
|
room: $selectedRoomID || 'default' |
|
}); |
|
const canvasImage = `<img src="${canvasURL.url}" style="width:100%" width="1000" height="1000">`; |
|
const descriptionMd = `#### Stable Diffusion Multiplayer: |
|
### [${$selectedRoomID}](https://huggingface.co/spaces/huggingface-projects/stable-diffusion-multiplayer?roomid=${$selectedRoomID}) |
|
|
|
<div style="display: flex; overflow: scroll; column-gap: 0.75rem;"> |
|
${canvasImage} |
|
</div>`; |
|
|
|
const params = new URLSearchParams({ |
|
title: `Room ${$selectedRoomID}`, |
|
description: descriptionMd |
|
}); |
|
const paramsStr = params.toString(); |
|
window.open( |
|
`https://huggingface.co/spaces/huggingface-projects/stable-diffusion-multiplayer/discussions/new?${paramsStr}`, |
|
'_blank' |
|
); |
|
} |
|
</script> |
|
|
|
|
|
<div |
|
class="{classList} text-xs font-mono flex items-center justify-center bg-black gap-x-1 rounded-xl cursor-pointer px-2 py-1 whitespace-nowrap" |
|
on:click={handleClick} |
|
title="Share with community" |
|
> |
|
{#if isUploading} |
|
<LoadingIcon classList={'animate-spin max-w-[25px] text-white'} /> |
|
{:else} |
|
<IconCommunity /> |
|
{/if} |
|
<p class="text-white font-semibold">Share to community</p> |
|
</div> |
|
|