mirror of
https://github.com/Significant-Gravitas/AutoGPT.git
synced 2026-01-09 15:17:59 -05:00
# 🌎 Overview AutoGPT Store Version 2 expands on the Pre-Store by enhancing agent discovery, providing richer content presentation, and introducing new user engagement features. The focus is on creating a visually appealing and interactive marketplace that allows users to explore and evaluate agents through images, videos, and detailed descriptions. ### Vision To create a visually compelling and interactive open-source marketplace for autonomous AI agents, where users can easily discover, evaluate, and interact with agents through media-rich listings, ratings, and version history. ### Objectives 📊 Incorporate visuals (icons, images, videos) into agent listings. ⭐ Introduce a rating system and agent run count. 🔄 Provide version history and update logs from creators. 🔍 Improve user experience with advanced search and filtering features. ### Changes 🏗️ <!-- Concisely describe all of the changes made in this pull request: --> ### Checklist 📋 #### For code changes: - [ ] I have clearly listed my changes in the PR description - [ ] I have made a test plan - [ ] I have tested my changes according to the test plan: <!-- Put your test plan here: --> - [ ] ... <details> <summary>Example test plan</summary> - [ ] Create from scratch and execute an agent with at least 3 blocks - [ ] Import an agent from file upload, and confirm it executes correctly - [ ] Upload agent to marketplace - [ ] Import an agent from marketplace and confirm it executes correctly - [ ] Edit an agent from monitor, and confirm it executes correctly </details> #### For configuration changes: - [ ] `.env.example` is updated or already compatible with my changes - [ ] `docker-compose.yml` is updated or already compatible with my changes - [ ] I have included a list of my configuration changes in the PR description (under **Changes**) <details> <summary>Examples of configuration changes</summary> - Changing ports - Adding new services that need to communicate with each other - Secrets or environment variable changes - New or infrastructure changes such as databases </details> --------- Co-authored-by: Bently <tomnoon9@gmail.com> Co-authored-by: Aarushi <aarushik93@gmail.com>
96 lines
2.6 KiB
TypeScript
96 lines
2.6 KiB
TypeScript
"use client";
|
|
|
|
import * as React from "react";
|
|
import Image from "next/image";
|
|
import { IconStarFilled, IconMore } from "@/components/ui/icons";
|
|
import { Status, StatusType } from "./Status";
|
|
|
|
export interface AgentTableCardProps {
|
|
agent_id: string;
|
|
agent_version: number;
|
|
agentName: string;
|
|
sub_heading: string;
|
|
description: string;
|
|
imageSrc: string[];
|
|
dateSubmitted: string;
|
|
status: StatusType;
|
|
runs: number;
|
|
rating: number;
|
|
id: number;
|
|
onEditSubmission: (submission: StoreSubmissionRequest) => void;
|
|
}
|
|
|
|
export const AgentTableCard: React.FC<AgentTableCardProps> = ({
|
|
agent_id,
|
|
agent_version,
|
|
agentName,
|
|
sub_heading,
|
|
description,
|
|
imageSrc,
|
|
dateSubmitted,
|
|
status,
|
|
runs,
|
|
rating,
|
|
id,
|
|
onEditSubmission,
|
|
}) => {
|
|
const onEdit = () => {
|
|
console.log("Edit agent", agentName);
|
|
onEditSubmission({
|
|
agent_id,
|
|
agent_version,
|
|
slug: "",
|
|
name: agentName,
|
|
sub_heading,
|
|
description,
|
|
image_urls: imageSrc,
|
|
categories: [],
|
|
});
|
|
};
|
|
|
|
return (
|
|
<div className="border-b border-neutral-300 p-4 dark:border-neutral-700">
|
|
<div className="flex gap-4">
|
|
<div className="relative h-[56px] w-[100px] overflow-hidden rounded-lg bg-[#d9d9d9] dark:bg-neutral-800">
|
|
<Image
|
|
src={imageSrc?.[0] ?? "/nada.png"}
|
|
alt={agentName}
|
|
fill
|
|
style={{ objectFit: "cover" }}
|
|
/>
|
|
</div>
|
|
<div className="flex-1">
|
|
<h3 className="text-[15px] font-medium text-neutral-800 dark:text-neutral-200">
|
|
{agentName}
|
|
</h3>
|
|
<p className="line-clamp-2 text-sm text-neutral-600 dark:text-neutral-400">
|
|
{description}
|
|
</p>
|
|
</div>
|
|
<button
|
|
onClick={onEdit}
|
|
className="h-fit rounded-full p-1 hover:bg-neutral-100 dark:hover:bg-neutral-700"
|
|
>
|
|
<IconMore className="h-5 w-5 text-neutral-800 dark:text-neutral-200" />
|
|
</button>
|
|
</div>
|
|
|
|
<div className="mt-4 flex flex-wrap gap-4">
|
|
<Status status={status} />
|
|
<div className="text-sm text-neutral-600 dark:text-neutral-400">
|
|
{dateSubmitted}
|
|
</div>
|
|
<div className="text-sm text-neutral-600 dark:text-neutral-400">
|
|
{runs.toLocaleString()} runs
|
|
</div>
|
|
<div className="flex items-center gap-1">
|
|
<span className="text-sm font-medium text-neutral-800 dark:text-neutral-200">
|
|
{rating.toFixed(1)}
|
|
</span>
|
|
<IconStarFilled className="h-4 w-4 text-neutral-800 dark:text-neutral-200" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|