このチュートリアルでは、自然言語を使用して気分やジャンルの好みを検出し、それに応じて映画を提案する映画提案ボットの設定方法を説明します。
Next.js プロジェクトをセットアップしてその上に Shadcn を追加するか、次のコマンドを使用できます:
npx shadcn@latest init
これにより、Next.js プロジェクトと Shadcn の両方が初期化されます。 ?
次のコマンドを使用して必要なパッケージをインストールします:
npm install @copilotkit/react-core @copilotkit/react-ui @copilotkit/runtime npm install groq-sdk
次に、次のコードを使用して /api/copilotkit バックエンド エンドポイントを追加します:
import { CopilotRuntime, GroqAdapter, copilotRuntimeNextJSAppRouterEndpoint, } from "@copilotkit/runtime"; import { NextRequest } from "next/server"; import Groq from "groq-sdk"; // eslint-disable-next-line @typescript-eslint/no-explicit-any const groq = new Groq({ apiKey: process.env.GROQ_API_KEY }) as any; const copilotKit = new CopilotRuntime(); const serviceAdapter = new GroqAdapter({ groq, model: "llama3-groq-8b-8192-tool-use-preview" }); export const POST = async (req: NextRequest) => { const { handleRequest } = copilotRuntimeNextJSAppRouterEndpoint({ runtime: copilotKit, serviceAdapter, endpoint: "/api/copilotkit", }); return handleRequest(req); };
バックエンドのセットアップを完了するには、サーバー アクションを 1 つ追加するだけです。次のファイルを作成します:
// src/actions/movies.ts "use server" export async function fetchMovies({ query }: { query: string }) { const API_KEY = process.env.OMDB_API_KEY; const URL = `https://www.omdbapi.com/?apikey=${API_KEY}&s=${encodeURIComponent( query )}`; try { const response = await fetch(URL); const result = await response.json(); if (result && result.Search) { return result.Search; } else { return []; } } catch (error) { console.error("Error fetching movies:", error); return []; } }
バックエンドの準備ができたら、このアプリのフロントエンドを構築する必要があります。
次のコマンドを実行して必要なコンポーネントを追加します:
npx shadcn@latest add card badge
また、スピナーコンポーネントを追加します。
次に、src/app/page.tsx で、必要なコンポーネントとフックをインポートします。
import { fetchMovies } from "@/actions/movies"; import { Spinner } from "@/components/ui-expansions/spinner"; import { Badge } from "@/components/ui/badge"; import { Card, CardContent, CardFooter } from "@/components/ui/card"; import { useCopilotAction } from "@copilotkit/react-core"; import { CopilotChat } from "@copilotkit/react-ui"; import "@copilotkit/react-ui/styles.css"; import { Film } from "lucide-react"; import Link from "next/link";
次に、ムービー タイプを定義します:
type Movie = { Title: string; Year: string; imdbID: string; Poster: string; };
useCopilotAction フックを使用して、AI がムービーを取得してユーザーに表示できるようにします。次の JSX を返します:
万歳! ?映画おすすめボットが完成しました。
プロジェクトが気に入った場合は、リポジトリにスターを付けることでプロジェクトへのサポートを示してください。
⭐ スター映画提案ボット
X ハンドルで Copilotkit をフォローし、リポジトリにスターを付けることもできます。
⭐ スター・コパイロットキット
?コパイロットキットをフォローする
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3