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;
logoWorkshopOpenMojiAPI_DOCS.md15 matches
1# Logo Workshop OpenMoji API Documentation
23The Logo Workshop API allows you to generate custom logo SVGs with OpenMoji emoji integration.
45## Endpoint
67```
8GET /api
9```
1057## Auto Mode
5859By default, the API uses an automatic mode that determines whether to use one-line or two-line layout based on the total character count:
6061- **Total characters ≤ 10**: Uses one-line mode with original case preserved
66## Text Processing
6768The API processes text differently based on the selected mode:
6970- **Two-Line Mode**: Text is split between `firstPart` (top line) and `lastPart` (bottom line), and converted to uppercase
71- **One-Line Mode**: If using `firstPart` and `lastPart`, they are combined with a space; if text already has a space, it will be used to split for dual-color effect
7273If using the `words` parameter, the API will automatically:
741. Use the first word as `firstPart`
752. Use remaining words as `lastPart`
130131```
132/api?words=Developer%20Hub&emoji=👨💻
133```
134This will automatically use two-line mode with uppercase text because the total character count (11) is greater than the threshold (10).
135136```
137/api?words=DevHub&emoji=👨💻
138```
139This will automatically use one-line mode with original case because the total character count (6) is less than the threshold (10).
142143```
144/api?firstPart=Developer&lastPart=Hub&emoji=👨💻&singleLine=true
145```
146Forces one-line mode regardless of character count.
149150```
151/api?firstPart=CLOUD&lastPart=COMPUTING&emoji=☁️
152```
153Uses two-line mode with uppercase text.
156157```
158/api?words=Developer%20Hub&emoji=👨💻&format=json
159```
160Returns a JSON response with both the SVG and metadata.
164Key aspects of the logo generation:
1651661. **Automatic Mode Selection**: The API intelligently chooses between one-line and two-line modes based on text length, with different styling for each.
1671682. **Text Processing**:
181182```html
183<img src="https://dcm31--b07cdf9722504af99241dfb0c07fb6a1.web.val.run/api?words=Developer%20Hub&emoji=👨💻" alt="Logo" />
184```
185188```javascript
189async function getLogo(words, emoji) {
190const url = `https://dcm31--b07cdf9722504af99241dfb0c07fb6a1.web.val.run/api?words=${encodeURIComponent(words)}&emoji=${encodeURIComponent(emoji)}&format=json`;
191
192const response = await fetch(url);
200## Limitations
201202- The API does not support custom sizing of the overall logo (fixed at 301x113.266)
203- Only OpenMoji emoji set is supported
204- Text X position is fixed at 112px and cannot be changed
stevensDemosetupDatabase.ts1 match
46
47// Run this file directly if needed
48// @ts-ignore: Deno-specific API
49if (import.meta.url && import.meta.url === Deno.mainModule) {
50await setupDatabase();
stevensDemoinitializeApp.ts3 matches
32} catch (error) {
33console.warn("⚠️ Could not import calendar events:", error.message);
34console.warn("To enable calendar integration, set the required Google Calendar API credentials as environment variables.");
35}
36
46
47// Run this file directly to initialize the app
48// @ts-ignore: Deno-specific API
49if (import.meta.url === Deno.mainModule) {
50// Check for command line args
51// @ts-ignore: Deno-specific API
52const args = Deno.args;
53const cleanFirst = args.includes("--clean") || args.includes("-c");
stevensDemocleanDatabase.ts1 match
23
24// Run this file directly if needed
25// @ts-ignore: Deno-specific API
26if (import.meta.url === Deno.mainModule) {
27await cleanDatabase();
stevensDemogetWeather.ts5 matches
28async function generateConciseWeatherSummary(weatherDay) {
29try {
30// Get API key from environment
31const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
32if (!apiKey) {
33console.error("Anthropic API key is not configured.");
34return null;
35}
3637// Initialize Anthropic client
38const anthropic = new Anthropic({ apiKey });
3940const response = await anthropic.messages.create({
telegramBotStarterindex.ts1 match
30// This is a no-op if nothing's changed
31if (!isEndpointSet) {
32await bot.api.setWebhook(req.url, {
33secret_token: SECRET_TOKEN,
34});
testplaywrightmain.tsx5 matches
5console.info("Launching browser...");
67// Use Deno.env to get the API key
8const apiKey = Deno.env.get("BROWSERBASE_API_KEY");
9if (!apiKey) {
10console.error("BROWSERBASE_API_KEY environment variable is not set");
11Deno.exit(1);
12}
14try {
15const browser = await chromium.connectOverCDP(
16`wss://connect.browserbase.com?apiKey=${apiKey}`,
17);
18console.info("Connected!");
accomplishedYellowDinosaurmain.tsx4 matches
244const { code, name } = await request.json();
245246// Create a new val using the Val Town API
247const response = await fetch("https://api.val.town/v1/vals", {
248method: "POST",
249headers: {
250"Content-Type": "application/json",
251"Authorization": `Bearer ${Deno.env.get("VAL_TOWN_API_KEY")}`,
252},
253body: JSON.stringify({
290291const css = `
292@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600&display=swap');
293294body {