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/?q=api&page=276&format=json

For typeahead suggestions, use the /typeahead endpoint:

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

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

Found 12043 results for "api"(1435ms)

stevensDemogenerateFunFacts.ts5 matches

@Suqi0626Updated 3 weeks ago
77async function generateFunFacts(previousFacts) {
78 try {
79 // Get API key from environment
80 const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
81 if (!apiKey) {
82 console.error("Anthropic API key is not configured.");
83 return null;
84 }
85
86 // Initialize Anthropic client
87 const anthropic = new Anthropic({ apiKey });
88
89 // Format previous facts for the prompt

stevensDemo.cursorrules10 matches

@Suqi0626Updated 3 weeks ago
20### 2. HTTP Vals
21
22- Create web APIs and endpoints
23- Handle HTTP requests and responses
24- Example structure:
66- Generate code in TypeScript
67- Add appropriate TypeScript types and interfaces for all data structures
68- Prefer official SDKs or libraries than writing API calls directly
69- Ask the user to supply API or library documentation if you are at all unsure about it
70- **Never bake in secrets into the code** - always use environment variables
71- Include comments explaining complex logic (avoid commenting obvious operations)
190- For AI-generated images, use: `https://maxm-imggenurl.web.val.run/the-description-of-your-image`
191- **Storage:** DO NOT use the Deno KV module for storage
192- **Browser APIs:** DO NOT use the `alert()`, `prompt()`, or `confirm()` methods
193- **Weather Data:** Use open-meteo for weather data (doesn't require API keys) unless otherwise specified
194- **View Source:** Add a view source link with `import.meta.url.replace("esm.town", "val.town")` and include `target="_top"` attribute
195- **Error Debugging:** Add `<script src="https://esm.town/v/std/catch"></script>` to HTML to capture client-side errors
196- **Error Handling:** Only use try...catch when there's a clear local resolution; avoid catches that merely log or return 500s - let errors bubble up with full context
197- **Environment Variables:** Use `Deno.env.get('keyname')` and minimize their use - prefer APIs without keys
198- **Imports:** Use `https://esm.sh` for npm and Deno dependencies to ensure compatibility on server and browser
199- **Storage Strategy:** Only use backend storage if explicitly required; prefer simple static client-side sites
230
231### Backend (Hono) Best Practices
232- Hono is the recommended API framework (similar to Express, Flask, or Sinatra)
233- Main entry point should be `backend/index.ts`
234- **Static asset serving:** Use the utility functions to read and serve project files:
251 });
252 ```
253- Create RESTful API routes for CRUD operations
254- Be careful with error handling as Hono tends to swallow errors
255- Always include this snippet at the top-level Hono app to re-throwing errors to see full stack traces:
268- Use React 18.2.0 consistently in all imports and the `@jsxImportSource` pragma
269- Follow the React component pattern from the example project
270- Handle API calls properly with proper error catching
271
272### Database Patterns
299 - For files in the project, use `readFile` helpers
300
3015. **API Design:**
302 - `fetch` handler is the entry point for HTTP vals
303 - Run the Hono app with `export default app.fetch // This is the entry point for HTTP vals`

stevensDemoApp.tsx8 matches

@Suqi0626Updated 3 weeks ago
10import { NotebookView } from "./NotebookView.tsx";
11
12const API_BASE = "/api/memories";
13const MEMORIES_PER_PAGE = 20; // Increased from 7 to 20 memories per page
14
90
91 // Fetch avatar image
92 fetch("/api/images/stevens.jpg")
93 .then((response) => {
94 if (response.ok) return response.blob();
104
105 // Fetch wood background
106 fetch("/api/images/wood.jpg")
107 .then((response) => {
108 if (response.ok) return response.blob();
133 setError(null);
134 try {
135 const response = await fetch(API_BASE);
136 if (!response.ok) {
137 throw new Error(`HTTP error! status: ${response.status}`);
176
177 try {
178 const response = await fetch(API_BASE, {
179 method: "POST",
180 headers: { "Content-Type": "application/json" },
199
200 try {
201 const response = await fetch(`${API_BASE}/${id}`, {
202 method: "DELETE",
203 });
231
232 try {
233 const response = await fetch(`${API_BASE}/${editingMemory.id}`, {
234 method: "PUT",
235 headers: { "Content-Type": "application/json" },
606 <div className="font-pixel text-[#f8f1e0]">
607 <style jsx>{`
608 @import url("https://fonts.googleapis.com/css2?family=Pixelify+Sans&display=swap");
609
610 @tailwind base;

HonoReactTailwindStarterindex.ts3 matches

@paweljwUpdated 3 weeks ago
8app.get("/frontend/**/*", c => serveFile(c.req.path, import.meta.url));
9
10// app.get("/api/get/:key", async c => c.json(await db.get(c.req.param("key"))));
11// app.get("/api/set/:key/:value", async c => c.json(await db.set(c.req.param("key"), c.req.param("value"))));
12
13app.get("/api/data", c => c.json({ hello: "world" }));
14
15app.get("/", async c => serveFile("/frontend/index.html", import.meta.url));

cloudAdjustermain.tsx1 match

@dcm31Updated 3 weeks ago
323 #root { width: 100%; height: 100%; }
324 canvas { display: block; width: 100%; height: 100%; }
325 @import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital@1&display=swap');
326 .char-build {
327 position: absolute;

charBuildFewCLoudsmain.tsx1 match

@dcm31Updated 3 weeks ago
302 #root { width: 100%; height: 100%; }
303 canvas { display: block; width: 100%; height: 100%; }
304 @import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital@1&display=swap');
305 .char-build {
306 position: absolute;

charBuildCloudsmain.tsx1 match

@dcm31Updated 3 weeks ago
303 #root { width: 100%; height: 100%; }
304 canvas { display: block; width: 100%; height: 100%; }
305 @import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital@1&display=swap');
306 .char-build {
307 position: absolute;

get_instagram_mediamain.tsx7 matches

@darenhuaUpdated 3 weeks ago
222}
223
224function mapInstagramResToOutput(data: DataDto): InstagramMediaResponse {
225 const imageUrl = data.xdt_shortcode_media.display_url;
226 const description = data.xdt_shortcode_media.edge_media_to_caption.edges[0].node.text;
241async function getInstagramMedia(shortcode: string): Promise<InstagramMediaResponse> {
242 try {
243 // This is literally some guy's backend api (https://gram-grabberz.vercel.app/)
244 const apiUrl = `https://gram-grabberz.vercel.app/api/instagram/p/${shortcode}`;
245 const res = await fetch(apiUrl);
246
247 if (!res.ok) {
248 throw new Error("random guy's api failed...");
249 }
250
253
254 if (!data.xdt_shortcode_media) {
255 throw new Error("random guy's api failed...");
256 }
257 const media = mapInstagramResToOutput(data);
258 return media;
259 } catch {

eink-frameweather.tsx1 match

@seigelUpdated 3 weeks ago
2import React from "https://esm.sh/react";
3import { renderToString } from "https://esm.sh/react-dom/server";
4import GetWeather, { type WEATHER_FORECAST } from "../api/weather.ts";
5import { BodyWrapper, Content, Footer, Header, Headline } from "../components.tsx";
6

eink-frameweather.ts3 matches

@seigelUpdated 3 weeks ago
34 const url = new URL(req.url);
35
36 const apiUrl =
37 `https://api.open-meteo.com/v1/forecast?latitude=${latitude}&longitude=${longitude}&current_weather=true&temperature_unit=fahrenheit`;
38 const cacheKey = `weather-forecast-${latitude}-${longitude}`;
39
40 // Cache for 30 minutes
41 const data: WEATHER_FORECAST = await fetchWithCache(apiUrl, cacheKey, 30).then((res) => res.json());
42 return new Response(JSON.stringify(data), {
43 headers: {

social_data_api_project3 file matches

@tsuchi_yaUpdated 19 hours ago

simple-scrabble-api1 file match

@bryUpdated 4 days ago
papimark21
socialdata
Affordable & reliable alternative to Twitter API: ➡️ Access user profiles, tweets, followers & timeline data in real-time ➡️ Monitor profiles with nearly instant alerts for new tweets, follows & profile updates ➡️ Simple integration