+ {/* Header */}
+
+
+
+ 🔍
+
+
+ InsightAI
+
+
+
+ AI Research Agent powered by{" "}
+
+ Cortensor
+
+ 's decentralized inference network
+
+
+ Decentralized AI
+ Verifiable
+ Trusted
+
+
+
+ {/* Research Input */}
+
+
+
+
+ 📝 Research Query
+
+
+ Ask any research question or provide a URL to analyze
+
+
+
+
+
+
+
+ {/* Error Display */}
+ {error && (
+
+
+
+
+ ❌ {error}
+
+
+
+
+ )}
+
+ {/* Results Display */}
+ {result && (
+
+
+
+
+
+ 📊 Research Results
+
+ {result.isDemo ? (
+
+ 🎮 Demo Mode
+
+ ) : result.verified && (
+
+ ✓ Verified via Cortensor
+
+ )}
+
+
+ Query: "{result.query}"
+
+
+
+ {/* Summary */}
+ {result.summary && (
+
+
+ 💡 Summary
+
+
+ {result.summary}
+
+
+ )}
+
+ {/* Key Points */}
+ {result.bulletPoints.length > 0 && (
+
+
+ 📌 Key Findings
+
+
+ {result.bulletPoints.map((point, index) => (
+ -
+ {index + 1}.
+ {point}
+
+ ))}
+
+
+ )}
+
+ {/* Sources */}
+ {result.sources.length > 0 && (
+
+
+ 🔗 Sources
+
+
+ {result.sources.map((source, index) => (
+
+ {source}
+
+ ))}
+
+
+ )}
+
+ {/* Verification */}
+ {result.sessionId && (
+
+ )}
+
+
+
+ {/* Powered by */}
+
+
+ Powered by{" "}
+
+ Cortensor
+
+ {" "}decentralized inference • Built for Hackathon #3
+
+
+
+ )}
+
+ {/* Empty State */}
+ {!result && !isLoading && (
+
+
🧠
+
Ready to Research
+
+ Enter your research question above and let InsightAI analyze it using
+ decentralized AI inference for trusted, verifiable insights.
+
+
+ )}
+
+ );
+}
diff --git a/apps/insightai/src/components/ui/badge.tsx b/apps/insightai/src/components/ui/badge.tsx
new file mode 100644
index 0000000..fd3a406
--- /dev/null
+++ b/apps/insightai/src/components/ui/badge.tsx
@@ -0,0 +1,46 @@
+import * as React from "react"
+import { Slot } from "@radix-ui/react-slot"
+import { cva, type VariantProps } from "class-variance-authority"
+
+import { cn } from "@/lib/utils"
+
+const badgeVariants = cva(
+ "inline-flex items-center justify-center rounded-full border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive transition-[color,box-shadow] overflow-hidden",
+ {
+ variants: {
+ variant: {
+ default:
+ "border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90",
+ secondary:
+ "border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90",
+ destructive:
+ "border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",
+ outline:
+ "text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground",
+ },
+ },
+ defaultVariants: {
+ variant: "default",
+ },
+ }
+)
+
+function Badge({
+ className,
+ variant,
+ asChild = false,
+ ...props
+}: React.ComponentProps<"span"> &
+ VariantProps