Val Town Code SearchReturn to Val Town

API Access

You can access search results via JSON API by adding format=json to your query:

https://codesearch.val.run/$%7Burl%7D?q=function&page=36&format=json

For typeahead suggestions, use the /typeahead endpoint:

https://codesearch.val.run/typeahead?q=function

Returns an array of strings in format "username" or "username/projectName"

Found 19200 results for "function"(802ms)

cerebras_coderindex.html1 match

@OmShankar•Updated 3 days ago
19 <meta property="og:site_name" content="Cerebras Coder">
20 <meta property="og:url" content="https://cerebrascoder.com"/>
21 <meta property="og:description" content="Turn your ideas into fully functional apps in less than a second – powered by Llama3.3-70b on Cerebras's super-fast wafer chips. Code is 100% open-source, hosted on Val Town."">
22 <meta property="og:type" content="website">
23 <meta property="og:image" content="https://stevekrouse-blob_admin.web.val.run/api/public/CerebrasCoderOG.jpg">

cerebras_codergenerate-code.ts2 matches

@OmShankar•Updated 3 days ago
2import STARTER_PROMPTS from "../public/starter-prompts.js";
3
4function extractCodeFromFence(text: string): string {
5 const htmlMatch = text.match(/```html\n([\s\S]*?)\n```/);
6 return htmlMatch ? htmlMatch[1].trim() : text;
7}
8
9export async function generateCode(prompt: string, currentCode: string) {
10 const starterPrompt = STARTER_PROMPTS.find(p => p.prompt === prompt);
11 if (starterPrompt) {

plantymain.tsx29 matches

@jonbo•Updated 3 days ago
15const LOCAL_STORAGE_SYNC_ID_KEY = "planty_sync_id_valtown";
16
17function generateNewSyncIdInternal() {
18 return `sync_${Date.now().toString(36)}${Math.random().toString(36).substring(2, 9)}`;
19}
20
21function getSyncIdFromLocalStorage() {
22 if (typeof localStorage !== "undefined") {
23 return localStorage.getItem(LOCAL_STORAGE_SYNC_ID_KEY);
26}
27
28function setSyncIdInLocalStorage(syncId) {
29 if (typeof localStorage !== "undefined") {
30 localStorage.setItem(LOCAL_STORAGE_SYNC_ID_KEY, syncId);
36const SyncIdContext = createContext<string | null>(null);
37
38function useSyncId() {
39 return useContext(SyncIdContext);
40}
41
42// Main App Component
43function App() {
44 const location = useLocation();
45 const navigate = useNavigate();
106
107// Wrapped App with Router
108function RoutedApp() {
109 return (
110 <Router>
114}
115
116function PlantView() {
117 const syncId = useSyncId();
118 if (!syncId) return <div>Loading sync information...</div>;
125}
126
127function Plant() {
128 const syncId = useSyncId();
129 const [lastWatered, setLastWatered] = useState(null);
131 const [showModal, setShowModal] = useState(false);
132
133 async function fetchLastWateredInternal() {
134 if (!syncId) return;
135 setIsLoading(true);
150 }, [syncId]);
151
152 function getTimeSinceLastWatering() {
153 if (lastWatered === null || typeof lastWatered === "undefined") return "Never";
154 const now = Date.now();
162 }
163
164 function getTextColorClass() {
165 if (lastWatered === null || typeof lastWatered === "undefined") return "text-red-600";
166 const days = Math.floor((Date.now() - Number(lastWatered)) / (1000 * 60 * 60 * 24));
204}
205
206function WatererSelectionModal({ onClose, onWatered }) {
207 const syncId = useSyncId();
208 const [waterers, setWaterers] = useState([]);
210 const [isAdding, setIsAdding] = useState(false);
211
212 async function fetchWaterersInternal() {
213 if (!syncId) return;
214 try {
227 }, [syncId]);
228
229 async function handleWatering(watererName) {
230 if (!syncId || !watererName) return;
231 try {
242 }
243
244 async function handleAddWatererAndWater() {
245 if (!syncId || !newWatererName.trim()) return;
246 setIsAdding(true);
315}
316
317function HistoryView() {
318 const syncId = useSyncId();
319 if (!syncId) return <div>Loading sync information...</div>;
327}
328
329function WateringHistoryComponent() {
330 const syncId = useSyncId();
331 const [waterers, setWaterers] = useState([]);
335 const [isProcessing, setIsProcessing] = useState(false);
336
337 async function fetchDataInternal() {
338 if (!syncId) return;
339 setIsLoading(true);
365 }, [syncId]);
366
367 async function handleAddWaterer() {
368 if (!syncId || !newWatererName.trim()) return;
369 setIsProcessing(true);
387 }
388
389 async function handleRenameWaterer(watererId, currentName) {
390 if (!syncId || !watererId) return;
391 const newName = prompt("Enter new name for " + currentName + ":", currentName);
407 }
408
409 async function handleDeleteWaterer(watererId, watererName) {
410 if (!syncId || !watererId) return;
411 if (!confirm(`Are you sure you want to delete waterer "${watererName}"? This cannot be undone.`)) return;
421 }
422
423 async function handleDeleteHistoryEntry(entryId) {
424 if (!syncId || !entryId) return;
425 if (!confirm("Are you sure you want to delete this history entry? This cannot be undone.")) return;
524// --- SYNC SETTINGS COMPONENTS ---
525
526function SyncSettingsView() {
527 const syncId = useSyncId();
528 if (!syncId) return <div>Loading sync information...</div>;
535}
536
537function SyncSettingsComponent({ currentSyncId }) {
538 const [newCodeInput, setNewCodeInput] = useState("");
539 const [copied, setCopied] = useState(false);
676// --- END SYNC SETTINGS COMPONENTS ---
677
678function client() {
679 // Use the RoutedApp which includes BrowserRouter
680 createRoot(document.getElementById("root")).render(<RoutedApp />);
683if (typeof document !== "undefined") { client(); }
684
685export default async function server(request: Request): Promise<Response> {
686 const { sqlite } = await import("https://esm.town/v/stevekrouse/sqlite");
687
761
762 // Helper to get or create instance data
763 async function getInstanceData(currentSyncId: string) {
764 let result = await sqlite.execute(
765 `SELECT waterers, watering_log, last_watered_timestamp FROM instances WHERE sync_id = ?`,
788
789 // Helper to update instance data
790 async function updateInstanceData(
791 currentSyncId: string,
792 data: { waterers: any[]; watering_log: any[]; last_watered_timestamp: number | null },
957 <script>
958 if ('serviceWorker' in navigator) {
959 window.addEventListener('load', function() {
960 navigator.serviceWorker.register('/sw.js');
961 });

plantymain.tsx1 match

@jonbo•Updated 3 days ago
1export default async function (req: Request): Promise<Response> {
2 return Response.json({ ok: true })
3}

song-mcpindex.tsx1 match

@dglazkov•Updated 3 days ago
2import { StdioServerTransport } from "https://esm.town/@modelcontextprotocol/sdk/server/stdio.js";
3
4export function handler(request: Request) {
5 return Response.json({ ok: true });
6}

markdownBlogStarterLayout.tsx1 match

@jesse_sutherland•Updated 3 days ago
4// import tailwind from "npm:tailwindcss@4.1.6";
5
6export function Layout({ children }: { children: ReactNode }) {
7 return (
8 <html lang="en">

markdownBlogStarterindex.tsx3 matches

@jesse_sutherland•Updated 3 days ago
5import { Layout } from "./Layout.tsx";
6
7function PostComponent({ markdown, link }: { markdown: string; link?: string }) {
8 return (
9 <div style={{ border: "1px solid gray", padding: "10px", marginBottom: "20px", borderRadius: "5px" }}>
14}
15
16export default async function(req: Request): Promise<Response> {
17 const url = new URL(req.url);
18 if (url.pathname === "/") {
55}
56
57function html(children: React.ReactNode) {
58 return new Response(
59 renderToString(

cerebras_coderstarter-prompts.js2 matches

@msd•Updated 3 days ago
4 "title": "Todo App",
5 "code":
6 "<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>Task Master</title>\n <link href=\"https://cdn.jsdelivr.net/npm/tailwindcss@2.2.19/dist/tailwind.min.css\" rel=\"stylesheet\">\n</head>\n<body class=\"bg-gray-100\">\n <div class=\"max-w-md mx-auto mt-12 p-6 rounded-lg shadow-md bg-white\">\n <div class=\"flex justify-between items-center mb-6\">\n <h2 class=\"text-2xl font-bold\">Task Master</h2>\n <span class=\"text-gray-600\">Manage your tasks efficiently</span>\n </div>\n <ul class=\"todo-list\" id=\"todo-list\"></ul>\n <div class=\"add-todo mt-6 flex justify-between items-center\">\n <input type=\"text\" id=\"todo-input\" placeholder=\"Add new task\" class=\"w-full py-2 pl-10 text-sm text-gray-800 border border-gray-400 rounded-lg focus:outline-none focus:ring-2 focus:ring-gray-600 bg-gray-50\">\n <button type=\"button\" id=\"add-todo-btn\" class=\"ml-4 px-4 py-2 bg-green-500 text-white font-medium text-xs leading-tight uppercase rounded shadow-md hover:bg-green-700 hover:shadow-lg focus:bg-green-700 focus:shadow-lg focus:outline-none focus:ring-0 active:bg-green-800 active:shadow-lg transition duration-150 ease-in-out\">Add Task</button>\n </div>\n <div class=\"mt-6 text-center text-gray-600\">\n Built on <a href=\"https://cerebrascoder.com\" target=\"_blank\" class=\"text-gray-900 underline\">Cerebras Coder</a>\n </div>\n </div>\n\n <script>\n // Get the todo list and add todo button elements\n const todoList = document.getElementById('todo-list');\n const addTodoBtn = document.getElementById('add-todo-btn');\n const todoInput = document.getElementById('todo-input');\n\n // Load todos from local storage\n let todos = JSON.parse(localStorage.getItem('todos')) || [];\n\n // Function to render the todo list\n function renderTodoList() {\n todoList.innerHTML = '';\n todos.forEach((todo, index) => {\n const todoItem = document.createElement('li');\n todoItem.innerHTML = `\n <div class=\"flex justify-between items-center py-4 border-b border-gray-300\">\n <div class=\"flex items-center\">\n <input type=\"checkbox\" id=\"todo-${index}\" class=\"mr-4\" ${todo.completed ? 'checked' : ''}>\n <span class=\"todo-text ${todo.completed ? 'text-gray-400 line-through' : 'text-gray-600'}\">${todo.text}</span>\n </div>\n <button type=\"button\" class=\"px-4 py-2 bg-red-500 text-white font-medium text-xs leading-tight uppercase rounded shadow-md hover:bg-red-700 hover:shadow-lg focus:bg-red-700 focus:shadow-lg focus:outline-none focus:ring-0 active:bg-red-800 active:shadow-lg transition duration-150 ease-in-out delete-todo\" data-index=\"${index}\">Delete</button>\n </div>\n `;\n todoList.appendChild(todoItem);\n });\n }\n\n // Render the initial todo list\n renderTodoList();\n\n // Add event listener to the add todo button\n addTodoBtn.addEventListener('click', () => {\n const todoText = todoInput.value.trim();\n if (todoText) {\n todos.push({ text: todoText, completed: false });\n localStorage.setItem('todos', JSON.stringify(todos));\n todoInput.value = '';\n renderTodoList();\n }\n });\n\n // Add event listener to the todo list\n todoList.addEventListener('change', (e) => {\n if (e.target.type === 'checkbox') {\n const index = parseInt(e.target.id.split('-')[1]);\n todos[index].completed = e.target.checked;\n localStorage.setItem('todos', JSON.stringify(todos));\n renderTodoList();\n }\n });\n\n // Add event listener to the delete todo buttons\n todoList.addEventListener('click', (e) => {\n if (e.target.classList.contains('delete-todo')) {\n const index = parseInt(e.target.dataset.index);\n todos.splice(index, 1);\n localStorage.setItem('todos', JSON.stringify(todos));\n renderTodoList();\n }\n });\n </script>\n</body>\n</html>",
7 "performance": {
8 "tokensPerSecond": 2298.56,
26 "title": "Markdown Editor",
27 "code":
28 "<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>Markdown Editor</title>\n <link href=\"https://cdn.jsdelivr.net/npm/tailwindcss@2.2.19/dist/tailwind.min.css\" rel=\"stylesheet\">\n</head>\n<body class=\"bg-white\">\n <div class=\"max-w-full mx-auto p-4 pt-6 md:p-6 lg:p-8\">\n <h1 class=\"text-3xl text-center mb-4\">Markdown Editor</h1>\n <div class=\"flex flex-row\">\n <div class=\"editor p-4 rounded-lg border border-gray-200 w-full md:w-1/2\">\n <textarea id=\"editor\" class=\"w-full h-screen p-2 border border-gray-200 rounded-lg\" placeholder=\"Type your Markdown here...\"></textarea>\n </div>\n <div class=\"preview p-4 rounded-lg border border-gray-200 w-full md:w-1/2 ml-2 md:ml-4 lg:ml-8\">\n <div id=\"preview\"></div>\n </div>\n </div>\n <p class=\"text-center mt-4\">Built on <a href=\"https://cerebrascoder.com\">Cerebras Coder</a></p>\n </div>\n\n <script>\n const editor = document.getElementById('editor');\n const preview = document.getElementById('preview');\n\n // Initialize textarea with default markdown\n const defaultMarkdown = `\n# Introduction to Markdown\nMarkdown is a lightweight markup language that is easy to read and write. It is often used for formatting text in plain text editors, chat applications, and even web pages.\n\n## Headers\nHeaders are denoted by the # symbol followed by a space. The number of # symbols determines the level of the header:\n# Heading 1\n## Heading 2\n### Heading 3\n\n## Emphasis\nYou can use emphasis to make your text **bold** or *italic*:\n*Italics*\n**Bold**\n\n## Lists\nYou can use lists to organize your text:\n* Item 1\n* Item 2\n* Item 3\nOr\n1. Item 1\n2. Item 2\n3. Item 3\n\n## Links\nYou can use links to reference external resources:\n[Google](https://www.google.com)\n\n## Images\nYou can use images to add visual content:\n![Markdown Logo](https://upload.wikimedia.org/wikipedia/commons/thumb/4/48/Markdown-mark.svg/208px-Markdown-mark.svg.png)\n`;\n editor.value = defaultMarkdown;\n\n // Update preview on input\n editor.addEventListener('input', () => {\n const markdown = editor.value;\n const html = markdownToHtml(markdown);\n preview.innerHTML = html;\n });\n\n // Initialize preview with default markdown\n const defaultHtml = markdownToHtml(defaultMarkdown);\n preview.innerHTML = defaultHtml;\n\n // Function to convert Markdown to HTML\n function markdownToHtml(markdown) {\n // Bold\n markdown = markdown.replace(/\\*\\*(.*?)\\*\\*/g, '<b>$1</b>');\n\n // Italic\n markdown = markdown.replace(/\\*(.*?)\\*/g, '<i>$1</i>');\n\n // Links\n markdown = markdown.replace(/\\[(.*?)\\]\\((.*?)\\)/g, '<a href=\"$2\">$1</a>');\n\n // Images\n markdown = markdown.replace(/!\\[(.*?)\\]\\((.*?)\\)/g, '<img src=\"$2\" alt=\"$1\">');\n\n // Headings\n markdown = markdown.replace(/(^#{1,6} )(.*)/gm, (match, level, text) => {\n return `<h${level.length}>${text}</h${level.length}>`;\n });\n\n // Lists\n markdown = markdown.replace(/^(\\*|\\d+\\.) (.*)/gm, (match, marker, text) => {\n if (marker.startsWith('*')) {\n return `<li>${text}</li>`;\n } else {\n return `<li>${text}</li>`;\n }\n });\n\n // Line breaks\n markdown = markdown.replace(/\\n/g, '<br>');\n\n // Fix for nested lists\n markdown = markdown.replace(/<li><li>/g, '<li>');\n markdown = markdown.replace(/<\\/li><\\/li>/g, '</li>');\n\n // Wrap lists in ul\n markdown = markdown.replace(/(<li>.*<\\/li>)/g, '<ul>$1</ul>');\n\n return markdown;\n }\n </script>\n</body>\n</html>",
29 "performance": {
30 "tokensPerSecond": 4092.96,

cerebras_coderqueries.ts5 matches

@msd•Updated 3 days ago
2import { ITERATIONS_TABLE, KEY, PROJECTS_TABLE, SCHEMA_VERSION } from "./migrations.ts";
3
4export async function createProject(prompt: string) {
5 const projectResult = await sqlite.execute(
6 `INSERT INTO ${PROJECTS_TABLE} (initial_prompt) VALUES (?)`,
11}
12
13export async function getNextVersionNumber(projectId: number) {
14 const data = await sqlite.execute(
15 `SELECT version_number FROM ${ITERATIONS_TABLE}
21}
22
23export async function insertVersion(projectId: number, versionNumber: number, prompt: string, code: string) {
24 await sqlite.execute(
25 `INSERT INTO ${ITERATIONS_TABLE}
29}
30
31export async function getCodeInner(table: string, project: string, version?: string) {
32 let data;
33 if (version === undefined) {
50}
51
52export async function getCode(project: string, version?: string) {
53 // try to get code in the new table partition first
54 const code = await getCodeInner(ITERATIONS_TABLE, project, version);

cerebras_codermigrations.ts1 match

@msd•Updated 3 days ago
7export const ITERATIONS_TABLE = "cerebras_coder_iterations";
8
9export async function createTables() {
10 await sqlite.execute(`
11 CREATE TABLE IF NOT EXISTS ${PROJECTS_TABLE} (

getFileEmail4 file matches

@shouser•Updated 2 weeks ago
A helper function to build a file's email
tuna

tuna8 file matches

@jxnblk•Updated 3 weeks ago
Simple functional CSS library for Val Town
lost1991
import { OpenAI } from "https://esm.town/v/std/openai"; export default async function(req: Request): Promise<Response> { if (req.method === "OPTIONS") { return new Response(null, { headers: { "Access-Control-Allow-Origin": "*",
webup
LangChain (https://langchain.com) Ambassador, KubeSphere (https://kubesphere.io) Ambassador, CNCF OpenFunction (https://openfunction.dev) TOC Member.