Commit
·
223236c
1
Parent(s):
5c5e659
before the lora, let's make the base system work properly
Browse files- .env +1 -1
- src/app/layout.tsx +4 -3
- src/app/page.tsx +1 -0
- src/app/server/actions/animation.ts +12 -11
.env
CHANGED
@@ -3,7 +3,7 @@
|
|
3 |
# VIDEO_HOTSHOT_XL_API_OFFICIAL
|
4 |
# VIDEO_HOTSHOT_XL_API_JBILCKE
|
5 |
# VIDEO_HOTSHOT_XL_API_FFFILONI
|
6 |
-
VIDEO_ENGINE="
|
7 |
|
8 |
# the official API developed by the Hotshot-XL team
|
9 |
# note: it isn't released yet
|
|
|
3 |
# VIDEO_HOTSHOT_XL_API_OFFICIAL
|
4 |
# VIDEO_HOTSHOT_XL_API_JBILCKE
|
5 |
# VIDEO_HOTSHOT_XL_API_FFFILONI
|
6 |
+
VIDEO_ENGINE="VIDEO_HOTSHOT_XL_API_FFFILONI"
|
7 |
|
8 |
# the official API developed by the Hotshot-XL team
|
9 |
# note: it isn't released yet
|
src/app/layout.tsx
CHANGED
@@ -10,9 +10,10 @@ export const metadata: Metadata = {
|
|
10 |
// giffer
|
11 |
// gipher
|
12 |
// GIF Factory
|
13 |
-
// GIF
|
14 |
-
|
15 |
-
|
|
|
16 |
}
|
17 |
|
18 |
export default function RootLayout({
|
|
|
10 |
// giffer
|
11 |
// gipher
|
12 |
// GIF Factory
|
13 |
+
// GIF Magic
|
14 |
+
// AI GIF Genie
|
15 |
+
title: 'Hotshot-XL Text-to-GIF 🧞',
|
16 |
+
description: 'Hotshot-XL Text-to-GIF 🧞',
|
17 |
}
|
18 |
|
19 |
export default function RootLayout({
|
src/app/page.tsx
CHANGED
@@ -20,6 +20,7 @@ export default function Page() {
|
|
20 |
</Head>
|
21 |
<main className={cn(
|
22 |
`light text-cyan-900`,
|
|
|
23 |
`bg-gradient-to-r from-cyan-500 to-blue-400`,
|
24 |
)}>
|
25 |
{isLoaded && <Main />}
|
|
|
20 |
</Head>
|
21 |
<main className={cn(
|
22 |
`light text-cyan-900`,
|
23 |
+
// `bg-gradient-to-r from-green-500 to-yellow-400`,
|
24 |
`bg-gradient-to-r from-cyan-500 to-blue-400`,
|
25 |
)}>
|
26 |
{isLoaded && <Main />}
|
src/app/server/actions/animation.ts
CHANGED
@@ -54,35 +54,36 @@ export async function generateAnimation({
|
|
54 |
|
55 |
return content
|
56 |
} else if (videoEngine === "VIDEO_HOTSHOT_XL_API_FFFILONI") {
|
57 |
-
const res = await fetch(
|
58 |
method: "POST",
|
59 |
headers: {
|
60 |
"Content-Type": "application/json",
|
61 |
// access isn't secured for now, the free lunch is open
|
62 |
// Authorization: `Bearer ${token}`,
|
63 |
},
|
64 |
-
body: JSON.stringify(
|
65 |
-
0,
|
66 |
-
|
67 |
-
|
68 |
-
|
69 |
-
|
|
|
|
|
70 |
cache: "no-store",
|
71 |
// we can also use this (see https://vercel.com/blog/vercel-cache-api-nextjs-cache)
|
72 |
// next: { revalidate: 1 }
|
73 |
})
|
74 |
-
console.log("res:", res)
|
75 |
|
76 |
-
const
|
77 |
-
console.log("content:", content)
|
78 |
|
79 |
// Recommendation: handle errors
|
80 |
if (res.status !== 200) {
|
81 |
-
console.error(content)
|
82 |
// This will activate the closest `error.js` Error Boundary
|
83 |
throw new Error('Failed to fetch data')
|
84 |
}
|
|
|
85 |
|
|
|
86 |
} else {
|
87 |
throw new Error(`not implemented yet!`)
|
88 |
}
|
|
|
54 |
|
55 |
return content
|
56 |
} else if (videoEngine === "VIDEO_HOTSHOT_XL_API_FFFILONI") {
|
57 |
+
const res = await fetch(fffiloniApi + "api/predict", {
|
58 |
method: "POST",
|
59 |
headers: {
|
60 |
"Content-Type": "application/json",
|
61 |
// access isn't secured for now, the free lunch is open
|
62 |
// Authorization: `Bearer ${token}`,
|
63 |
},
|
64 |
+
body: JSON.stringify({
|
65 |
+
fn_index: 0,
|
66 |
+
data: [
|
67 |
+
prompt,
|
68 |
+
// lora, // not supported
|
69 |
+
// size, // not supported
|
70 |
+
],
|
71 |
+
}),
|
72 |
cache: "no-store",
|
73 |
// we can also use this (see https://vercel.com/blog/vercel-cache-api-nextjs-cache)
|
74 |
// next: { revalidate: 1 }
|
75 |
})
|
|
|
76 |
|
77 |
+
const { data } = await res.json()
|
|
|
78 |
|
79 |
// Recommendation: handle errors
|
80 |
if (res.status !== 200) {
|
|
|
81 |
// This will activate the closest `error.js` Error Boundary
|
82 |
throw new Error('Failed to fetch data')
|
83 |
}
|
84 |
+
// console.log("data:", data.slice(0, 50))
|
85 |
|
86 |
+
return data
|
87 |
} else {
|
88 |
throw new Error(`not implemented yet!`)
|
89 |
}
|