'use client'
import { motion } from 'framer-motion'
import { ArrowUpRight, ExternalLink } from 'lucide-react'
import { Button } from '@/components/ui/button'
import Link from 'next/link'
const projects = [
{
title: 'Hacker News Daily AI Reports',
slug: 'hackernews',
description: 'Die Hacker News gelten als zentrale Nachrichtenbörse für versierte, englischsprachige Programmierer. Wer wissen will, was neu oder wichtig ist, findet es dort. Doch die schiere Menge an Beiträgen kann schnell überwältigen.\n\nGenau hier setzt mein Projekt an: Eine KI filtert die wichtigsten Inhalte, fasst sie zusammen, eine andere übersetzt sie. Das Projekt liefert morgens wie abends kompakte Updates. Zusätzlich bewertet sie automatisch, wie relevant die Top-10-Geschichten für Themen wie Künstliche Intelligenz und Maschinelles Lernen sind.\n\nDas System wählt selbstständig geeignete Modelle aus, die Aufgaben effizient und kostengünstig erledigen. So entsteht ein intelligenter Nachrichtenstrom, der effizient Übersicht schafft — und das für lediglich 0 bis 3 Cent pro Ausgabe.',
tech: ['Python', 'FastAPI', 'Openrouter', 'deepseek-reasoner', 'qwen3-max'],
status: 'Aktiv',
url: 'https://jamulix.de/hackernews/',
featured: true,
},
{
title: 'Sichtbare Sortier-Algorithmen (Demo)',
slug: 'sorting',
description: 'Interaktive Visualisierung verschiedener Sortieralgorithmen. Didaktisches Werkzeug für Algorithmen-Verständnis. Digitales Sortieren wird immer wichtiger, weil es viel mehr Daten gibt. Es ist wichtig, sich die Wirkungsweise verschiedener Sortier‑Algorithmen plastisch anzuschauen, weil man so ihre Logik wirklich versteht und nicht nur Pseudocode auswendig lernt. Visuelle Darstellungen zeigen auf einen Blick, wie sich Elemente bewegen, wo sich regionale Ordnung bildet und wie sich Partitionen oder „Blasen“ entwickeln. So wird klar, warum Insertionsort bei fast sortierten Daten schnell wirkt, während Mergesort oder Quicksort bei großen Datenmengen besser skalieren. Zusätzlich hilft die plastische Anschauung, Effizienzunterschiede intuitiv zu erfassen: Man sieht, wann viele Vertauschungen oder Tiefe Rekursion auftreten, und bekommt ein Gefühl für Geschwindigkeit versus Datenverbrauch.',
tech: ['Vibe-Coding', 'LLM', 'Javascript', 'Tailwind'],
status: 'Aktiv',
url: 'https://jamulix.de/sorting',
featured: true,
},
{
title: 'Digitalisierung einer "Mundorgel"',
slug: 'upcoming-1',
description: 'In unserer Gruppe wollen wir Lieder aus Schulzeit und Jugend der 60er- und 70er-Jahre singen. Die „Mundorgel" war damals weit verbreitet, doch heutige Ausgaben enthalten viele dieser Stücke nicht mehr. Antiquarische Exemplare sind selten und teuer, Kopien unpraktisch.\n\nIch habe daher eine alte Mundorgel mit KI-Tools digitalisiert und auf meinem Server durchsuchbar gemacht. So werden analoge Inhalte für moderne Nutzung erschließbar.\n\nDas Projekt diente auch dem Lernen: Die gleichen Verfahren lassen sich auf Bücher, Akten oder Zeitungen übertragen. Im Vergleich zur kürzlich digitalisierten Encyclopaedia Britannica von 1911 (28 Bände) ist mein Projekt klein – doch die zugrunde liegenden Prozesse sind dieselben.',
tech: ['LLM-OCR', 'JSON', 'Typescript', 'Tailwind', 'Vibe-Coding'],
status: 'Aktiv',
url: 'https://jamulix.de/mundorgel/',
featured: false,
},
{
title: 'Desinformationsdetektor',
slug: 'upcoming-2',
description: 'Automatisierte Prüfung von Medieninhalten auf Manipulationspotenzial. Das Projekt analysiert mit verschiedenen KI-unterstützten Programmen veröffentlichte Texte, Audios und Videos auf zentrale Behauptungen, Belege, Lücken und Logik. Es identifiziert prüfbare Aussagen, recherchiert stützende und widersprechende Quellen mit Links, deckt ausgelassene Fakten auf, prüft argumentative Kohärenz und bewertet Framing, Sentiment und Meinungsdichte. Das Ergebnis ist ein transparentes, nachvollziehbares Gutachten zur Qualität und zum Desinformationsrisiko des Inhalts.',
tech: ['Python', 'Rust', 'Pi', 'Typescript', 'Whisper', 'SQLite', 'vLLMs', 'APIs', 'Perplexity'],
status: 'Geplant',
url: null,
featured: false,
},
]
function ProjectCard({ project, index }: { project: typeof projects[0]; index: number }) {
const isClickable = project.url !== null
return (