stevensDemogenerateFunFacts.ts5 matches
77async function generateFunFacts(previousFacts) {
78try {
79// Get API key from environment
80const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
81if (!apiKey) {
82console.error("Anthropic API key is not configured.");
83return null;
84}
8586// Initialize Anthropic client
87const anthropic = new Anthropic({ apiKey });
8889// Format previous facts for the prompt
stevensDemo.cursorrules10 matches
20### 2. HTTP Vals
2122- 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
230231### 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
271272### Database Patterns
299- For files in the project, use `readFile` helpers
3003015. **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
10import { NotebookView } from "./NotebookView.tsx";
1112const API_BASE = "/api/memories";
13const MEMORIES_PER_PAGE = 20; // Increased from 7 to 20 memories per page
149091// Fetch avatar image
92fetch("/api/images/stevens.jpg")
93.then((response) => {
94if (response.ok) return response.blob();
104105// Fetch wood background
106fetch("/api/images/wood.jpg")
107.then((response) => {
108if (response.ok) return response.blob();
133setError(null);
134try {
135const response = await fetch(API_BASE);
136if (!response.ok) {
137throw new Error(`HTTP error! status: ${response.status}`);
176177try {
178const response = await fetch(API_BASE, {
179method: "POST",
180headers: { "Content-Type": "application/json" },
199200try {
201const response = await fetch(`${API_BASE}/${id}`, {
202method: "DELETE",
203});
231232try {
233const response = await fetch(`${API_BASE}/${editingMemory.id}`, {
234method: "PUT",
235headers: { "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");
609610@tailwind base;
simple_moirkdown_blogmoi.md1 match
5date: "2025-04-26"
6url: "https://dcm31--45d1947422b711f0be5c569c3dd06744.web.val.run"
7imageUrl: "https://chatgpt.com/backend-api/public_content/enc/eyJpZCI6Im1fNjgwZDBjYzQxYTcwODE5MWFlZTZmNzhjZmJjNGVhNGQ6ZmlsZV8wMDAwMDAwMDU0MTg2MWY2YTRiOWMxOWE3NTA4Yjk5NCIsInRzIjoiNDg0OTEyIiwicCI6InB5aSIsInNpZyI6IjFhODc1NDE1ZjJkNmNlM2EwYjY4YjMzYmZhYTIwMDM2YmIzMWI5NjU2YWYzZTdkYmM2N2IxOWRmMzdlZjliYzIiLCJ2IjoiMCIsImdpem1vX2lkIjpudWxsfQ=="
8tags: ["markdown", "blog", "val-town", "template"]
9---
vtProjectSearchmoi.md2 matches
2title: "Val Town Project Search"
3description: "A search engine for Val Town projects, vals, and users"
4imageUrl: "https://chatgpt.com/backend-api/public_content/enc/eyJpZCI6Im1fNjgwYzQyM2VmNTIwODE5MTkzOGNjY2Q1NTkxZmU0YjQ6ZmlsZV8wMDAwMDAwMGIwNGM2MjMwOGY5MTUwMjdlYjhiMDM3ZCIsInRzIjoiNDg0ODk4IiwicCI6InB5aSIsInNpZyI6ImQ5MjNjZGY4MTlkY2RmMTkwMzliM2E0NDY4N2RlYWNlZjNjNzQwYmE1ZGFlODg2NjNmMGU0ZWNmNjE0MzYwNzAiLCJ2IjoiMCIsImdpem1vX2lkIjpudWxsfQ=="
5url: "https://charliesusersearch.val.run/"
6author: "dcm31"
7tags: ["search", "val-town", "typescript", "api"]
8---
9
26type TestResponse = { llmOutput: string; error?: string };
2728// Final result structure for API responses including logs
29type FinalRes<T> = { data?: T; error?: string; dtls?: string; logs: LogEntry[]; reqId: string };
30342log("DEBUG", "LLM", `OpenAI Call`, { sysL: systemPrompt.length, usrL: userPrompt.length }, reqId);
343try {
344// IMPORTANT: Replace with your actual OpenAI API key mechanism (e.g., environment variable)
345const oa = new OpenAI(); // Assumes OPENAI_API_KEY env var is set
346const completion = await oa.chat.completions.create({
347// Consider using a more powerful model for prompt generation, maybe cheaper for testing
361} catch (err: any) {
362const errD = { msg: err.message, name: err.name, status: err.status, type: err.type, code: err.code };
363log("ERROR", "LLM", `OpenAI API call failed`, { error: errD }, reqId);
364throw new Error(`LLM API error: ${err.message}${err.code ? ` (Code: ${err.code})` : ''}`);
365}
366}
117const finalSys = sysPrompt + `\n\nREMINDER: Info only, not medical advice. Verify & use clinical judgment.`;
118try {
119const oa = new OpenAI(); // Assumes API key is set in environment
120const completion = await oa.chat.completions.create({
121model: "gpt-4o-mini", // Use appropriate model
130} catch (err: any) {
131const errD = { msg: err.message, name: err.name, status: err.status, type: err.type, code: err.code };
132log("ERROR", "LLM", `OpenAI API task ${tid} failed`, { error: errD }, mid, tid);
133throw new Error(`OpenAI API error: ${err.message}${err.code ? ` (Code: ${err.code})` : ''}`);
134}
135}
12},
13{
14prompt: "weather dashboard for nyc using open-meteo API for NYC with icons",
15title: "Weather App",
16code:
12},
13{
14prompt: "weather dashboard for nyc using open-meteo API for NYC with icons",
15title: "Weather App",
16code:
12},
13{
14prompt: "weather dashboard for nyc using open-meteo API for NYC with icons",
15title: "Weather App",
16code: