-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.html
More file actions
94 lines (94 loc) · 5.01 KB
/
Copy pathindex.html
File metadata and controls
94 lines (94 loc) · 5.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<meta
name="description"
content="Mini is a local-first character chatbot with a React frontend, Express backend, and Ollama-powered LLM proxy."
/>
<title>Mini · Local Character Chatbot</title>
<link rel="preconnect" href="https://fonts.googleapis.com" />
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600&display=swap" rel="stylesheet" />
<link rel="stylesheet" href="styles.css" />
</head>
<body>
<div class="canvas">
<main class="hero-card">
<section class="hero">
<div class="hero-copy">
<div class="hero-brandline">
<img class="brand" src="assets/logo.png" alt="Mini logo" />
<p class="eyebrow">Local character chatbot</p>
</div>
<h1>Spin up characters, chat privately, on your laptop.</h1>
<p class="hero-lede">
Mini is a tiny, fast, local AI chatbot that feels surprisingly alive. Switch personas, explore ideas,
and build your own characters — all running privately on your own machine.
</p>
<div class="hero-actions">
<a class="btn primary" href="https://github.com/hackjutsu/mini-chatbot" target="_blank" rel="noreferrer">
<svg viewBox="0 0 16 16" aria-hidden="true" focusable="false">
<path
d="M8 0C3.58 0 0 3.58 0 8a8 8 0 0 0 5.47 7.59c.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2 .37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82a7.5 7.5 0 0 1 4 0c1.53-1.03 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8 8 0 0 0 16 8c0-4.42-3.58-8-8-8Z"
fill="currentColor"
/>
</svg>
GitHub
</a>
<a
class="btn secondary"
href="https://medium.com/@cosmo.lepton/from-vibing-to-engineering-a-case-study-of-building-a-character-chatbot-80ec4cd57406"
target="_blank"
rel="noreferrer"
>
Read the story
</a>
</div>
<ul class="hero-facts">
<li><strong>Fast and private:</strong> runs entirely on your device.</li>
<li><strong>Fully customizable:</strong> create and refine any character.</li>
<li><strong>Built to grow:</strong> lightweight now, extensible later.</li>
</ul>
</div>
<div class="carousel" aria-label="Mini interface gallery">
<div class="carousel-track" data-active-index="0">
<figure class="carousel-slide is-active" data-index="0">
<img src="assets/hero.png" alt="Screenshot of Mini chat session" />
<figcaption>Everything renders locally—no hosted dependency.</figcaption>
</figure>
<figure class="carousel-slide" data-index="1">
<img src="assets/character.png" alt="Character creation interface" />
<figcaption>Craft persona prompts, avatars, and archetypes.</figcaption>
</figure>
<figure class="carousel-slide" data-index="2">
<img src="assets/manage.png" alt="Character management screen" />
<figcaption>Organize your characters in one panel.</figcaption>
</figure>
<figure class="carousel-slide" data-index="3">
<img src="assets/share.png" alt="Share message dialog" />
<figcaption>Turn replies into beautiful share cards.</figcaption>
</figure>
</div>
<div class="carousel-controls">
<button class="carousel-btn" type="button" data-direction="prev" aria-label="Previous screenshot">
‹
</button>
<div class="carousel-dots" role="tablist">
<button class="dot is-active" type="button" data-index="0" aria-label="View screenshot 1"></button>
<button class="dot" type="button" data-index="1" aria-label="View screenshot 2"></button>
<button class="dot" type="button" data-index="2" aria-label="View screenshot 3"></button>
<button class="dot" type="button" data-index="3" aria-label="View screenshot 4"></button>
</div>
<button class="carousel-btn" type="button" data-direction="next" aria-label="Next screenshot">
›
</button>
</div>
</div>
</section>
</main>
</div>
<script src="script.js"></script>
</body>
</html>