build fixes
This commit is contained in:
parent
ea82bbce75
commit
954a47688c
4
next.config.mjs
Normal file
4
next.config.mjs
Normal file
@ -0,0 +1,4 @@
|
||||
/** @type {import('next').NextConfig} */
|
||||
const nextConfig = {};
|
||||
|
||||
export default nextConfig;
|
@ -1,65 +0,0 @@
|
||||
import { NextRequest, NextResponse } from 'next/server'
|
||||
|
||||
if (!process.env.ADOBE_API_KEY || !process.env.ADOBE_CLIENT_SECRET) {
|
||||
throw new Error('Adobe API credentials not configured')
|
||||
}
|
||||
|
||||
const ADOBE_API_URL = 'https://firefly-api.adobe.io
|
||||
|
||||
export async function POST(req: NextRequest): Promise<NextResponse> {
|
||||
try {
|
||||
const { prompt } = await req.json()
|
||||
|
||||
if (!prompt) {
|
||||
return NextResponse.json(
|
||||
{ error: 'Prompt is required' },
|
||||
{ status: 400 }
|
||||
)
|
||||
}
|
||||
|
||||
// Adobe Firefly API request
|
||||
const response = await fetch(ADOBE_API_URL, {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'x-api-key': process.env.ADOBE_API_KEY,
|
||||
'Authorization': `Bearer ${process.env.ADOBE_API_KEY}`,
|
||||
'Content-Type': 'application/json',
|
||||
},
|
||||
body: JSON.stringify({
|
||||
prompt: prompt,
|
||||
n: 1,
|
||||
size: { width: 1024, height: 1024 },
|
||||
styles: ["default"],
|
||||
seed: Math.floor(Math.random() * 1000000),
|
||||
quality: "standard",
|
||||
contentClass: "photo"
|
||||
}),
|
||||
})
|
||||
|
||||
if (!response.ok) {
|
||||
const errorData = await response.json()
|
||||
console.error('Adobe API error:', errorData)
|
||||
throw new Error(`Adobe API error: ${response.status}`)
|
||||
}
|
||||
|
||||
const data = await response.json()
|
||||
console.log('Adobe generation result:', data)
|
||||
|
||||
// Extract the image URL from the response
|
||||
const imageUrl = data.outputs?.[0]?.image
|
||||
|
||||
if (!imageUrl) {
|
||||
throw new Error('No image URL in response')
|
||||
}
|
||||
|
||||
return NextResponse.json({ imageUrl })
|
||||
} catch (error) {
|
||||
console.error('Adobe generation error:', error)
|
||||
return NextResponse.json(
|
||||
{ error: error instanceof Error ? error.message : 'Failed to generate image' },
|
||||
{ status: 500 }
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
export const dynamic = 'force-dynamic'
|
@ -1,37 +0,0 @@
|
||||
import { NextRequest, NextResponse } from 'next/server'
|
||||
import { GoogleGenerativeAI } from '@google/generative-ai'
|
||||
|
||||
if (!process.env.GEMINI_API_KEY) {
|
||||
throw new Error('GEMINI_API_KEY is not configured in environment variables')
|
||||
}
|
||||
|
||||
const genAI = new GoogleGenerativeAI(process.env.GEMINI_API_KEY)
|
||||
const model = genAI.getGenerativeModel({ model: "gemini-1.5-pro" })
|
||||
|
||||
export async function POST(req: NextRequest): Promise<NextResponse> {
|
||||
try {
|
||||
const { prompt } = await req.json()
|
||||
|
||||
if (!prompt) {
|
||||
return NextResponse.json(
|
||||
{ error: 'Prompt is required' },
|
||||
{ status: 400 }
|
||||
)
|
||||
}
|
||||
|
||||
const result = await model.generateContent(prompt)
|
||||
const response = await result.response
|
||||
const text = response.text()
|
||||
|
||||
console.log('Gemini generation result:', text)
|
||||
return NextResponse.json({ response: text })
|
||||
} catch (error) {
|
||||
console.error('Gemini generation error:', error)
|
||||
return NextResponse.json(
|
||||
{ error: error instanceof Error ? error.message : 'Failed to generate text' },
|
||||
{ status: 500 }
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
export const dynamic = 'force-dynamic'
|
@ -1,47 +0,0 @@
|
||||
import { NextRequest, NextResponse } from 'next/server'
|
||||
import OpenAI from "openai";
|
||||
|
||||
if (!process.env.XAI_API_KEY) {
|
||||
throw new Error('XAI_API_KEY is not configured in environment variables')
|
||||
}
|
||||
|
||||
const GROK_API_URL = 'https://api.openai.com/v1'
|
||||
|
||||
export async function POST(req: NextRequest): Promise<NextResponse> {
|
||||
try {
|
||||
const { prompt } = await req.json()
|
||||
|
||||
if (!prompt) {
|
||||
return NextResponse.json(
|
||||
{ error: 'Prompt is required' },
|
||||
{ status: 400 }
|
||||
)
|
||||
}
|
||||
|
||||
const openai = new OpenAI({
|
||||
apiKey: process.env.XAI_API_KEY,
|
||||
baseURL: GROK_API_URL,
|
||||
});
|
||||
|
||||
const image = await openai.images.generate({ model: "dall-e-3", prompt: prompt });
|
||||
|
||||
|
||||
// Extract the image URL from Grok's response
|
||||
const imageUrl = image.data[0].url
|
||||
|
||||
if (!imageUrl) {
|
||||
console.error('No image in response:', data)
|
||||
throw new Error('No image generated in Grok API result')
|
||||
}
|
||||
|
||||
return NextResponse.json({ imageUrl })
|
||||
} catch (error) {
|
||||
console.error('Grok generation error:', error)
|
||||
return NextResponse.json(
|
||||
{ error: error instanceof Error ? error.message : 'Failed to generate image' },
|
||||
{ status: 500 }
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
export const dynamic = 'force-dynamic'
|
@ -11,6 +11,12 @@ interface WalletState {
|
||||
publicKey: string | null
|
||||
}
|
||||
|
||||
declare global {
|
||||
interface Window {
|
||||
solflare: any; // Or use a more specific type if available
|
||||
}
|
||||
}
|
||||
|
||||
const Page: React.FC = (): React.ReactElement => {
|
||||
const [walletState, setWalletState] = useState<WalletState>({
|
||||
connected: false,
|
||||
|
@ -3,7 +3,7 @@ import {
|
||||
TOKEN_PROGRAM_ID,
|
||||
createTransferInstruction,
|
||||
getAssociatedTokenAddress,
|
||||
createAssociatedTokenAccountInstruction as createATAInstruction,
|
||||
createAssociatedTokenAccountInstruction,
|
||||
ASSOCIATED_TOKEN_PROGRAM_ID
|
||||
} from '@solana/spl-token'
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user