File size: 2,671 Bytes
dbc8f44
b6caea7
dbc8f44
b6caea7
 
dbc8f44
 
 
b6caea7
dbc8f44
 
 
b6caea7
 
 
dbc8f44
a40bf40
 
dbc8f44
b6caea7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
93303c1
b6caea7
 
 
 
 
a40bf40
 
 
 
dbc8f44
 
a40bf40
66d8bb7
dbc8f44
 
 
b6caea7
66d8bb7
dbc8f44
 
a40bf40
 
 
66d8bb7
 
 
dbc8f44
b6caea7
 
 
 
 
66d8bb7
b6caea7
 
 
 
 
 
 
 
 
 
 
 
dbc8f44
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import { useStore } from "@/app/store"
import { HuggingClap } from "@/components/icons/hugging-clap"
import { Button } from "@/components/ui/button"
import { base64ToFile } from "@/lib/base64ToFile"
import { uploadToHuggingFace } from "@/lib/uploadToHuggingFace"
import { cn } from "@/lib/utils"

export function BottomBar() {
  const download = useStore(state => state.download)
  const isGeneratingStory = useStore(state => state.isGeneratingStory)
  const prompt = useStore(state => state.prompt)
  const panelGenerationStatus = useStore(state => state.panelGenerationStatus)
  const page = useStore(state => state.page)
  const preset = useStore(state => state.preset)
  const pageToImage = useStore(state => state.pageToImage)

  const allStatus = Object.values(panelGenerationStatus)
  const remainingImages = allStatus.reduce((acc, s) => (acc + (s ? 1 : 0)), 0)
    
  const handleShare = async () => {
    // const dataUrl = await pageToImage()
    // console.log("dataUrl:", dataUrl)
    // const fileToUpload = base64ToFile(dataUrl, "comic.png")
    // const uploadUrl = await uploadToHuggingFace(fileToUpload)
    // console.log("uploadUrl:", uploadUrl)

    const descriptionMd = `
#### Prompt:
\`\`\`${prompt}\`\`\`

#### Preset:
\`\`\`${preset.label}\`\`\`

#### Comic:

(drag & drop your downloaded comic here)
`;
// ![${prompt}](${uploadUrl})

    console.log("descriptionMd:", descriptionMd)

    const params = new URLSearchParams({
      title: `[Comic] ${prompt}`,
      description: descriptionMd,
      });
    const paramsStr = params.toString();
    window.open(`https://huggingface.co/spaces/jbilcke-hf/comic-factory/discussions/new?${paramsStr}`, '_blank');
  }

  const handlePrint = () => {
    window.print()
  }
  return (
    <div className={cn(
      `print:hidden`,
      `fixed bottom-6 right-3`,
      `flex flex-row`,
      `animation-all duration-300 ease-in-out`,
      isGeneratingStory ? `scale-0 opacity-0` : ``,
      `space-x-3`,
      `scale-[0.9]`
    )}>
      <div>
        <Button
          onClick={handlePrint}
          disabled={!prompt?.length}
        >
          Print
        </Button>
      </div>
      <div>
        <Button
          onClick={download}
          disabled={!prompt?.length}
        >{
          remainingImages ? `${allStatus.length - remainingImages}/4 panels ⌛` : `Save`
        }</Button>
      </div>
      <div>
        <Button
          onClick={handleShare}
          disabled={!prompt?.length}
          className="space-x-2"
        >
          <span className="scale-105"><HuggingClap /></span>
          <span>Share to community</span>
        </Button>
      </div>
    </div>
  )
}