HHGtoMyDayindex.html2 matches
12type="image/svg+xml"
13/>
14<link rel="preconnect" href="https://fonts.googleapis.com" />
15<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
16<link
17href="https://fonts.googleapis.com/css2?family=Pixelify+Sans:wght@400..700&display=swap"
18rel="stylesheet"
19/>
HHGtoMyDayhandleUSPSEmail.ts5 matches
85console.log(e.text);
8687// Get Anthropic API key from environment
88const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
89if (!apiKey) {
90console.error("Anthropic API key is not configured for this val.");
91return;
92}
9394// Initialize Anthropic client
95const anthropic = new Anthropic({ apiKey });
9697// Process each image attachment serially
HHGtoMyDayhandleTelegramMessage.ts7 matches
9293/**
94* Format chat history for Anthropic API
95*/
96function formatChatHistoryForAI(history) {
321bot.on("message", async (ctx) => {
322try {
323// Get Anthropic API key from environment
324const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
325if (!apiKey) {
326console.error("Anthropic API key is not configured.");
327ctx.reply(
328"I apologize, but I'm not properly configured at the moment. Please inform the household administrator."
332333// Initialize Anthropic client
334const anthropic = new Anthropic({ apiKey });
335336// Get message text and user info
502// Set webhook if it is not set yet
503if (!isEndpointSet) {
504await bot.api.setWebhook(req.url, {
505secret_token: SECRET_TOKEN,
506});
HHGtoMyDay.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`
HHGtoMyDayApp.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;
TodoistTesttoday_and_overdue.tsx8 matches
120121export default async function server(request: Request): Promise<Response> {
122// Todoist API endpoint
123const TODOIST_API_BASE = "https://api.todoist.com/rest/v2";
124125// Check for Todoist tasks request
126if (new URL(request.url).pathname === "/todoist-tasks") {
127// Retrieve Todoist API token from environment
128const apiToken = Deno.env.get("TODOIST_API_TOKEN");
129130if (!apiToken) {
131return new Response(
132JSON.stringify({
133error: "Todoist API token not configured",
134}),
135{
142try {
143// Fetch active tasks from Todoist
144const todoistResponse = await fetch(`${TODOIST_API_BASE}/tasks`, {
145headers: {
146"Authorization": `Bearer ${apiToken}`,
147"Content-Type": "application/json",
148},
untitled-2512new-file-9861.tsx4 matches
26Focus on identifying:
27- Symptoms or characteristics of ASD (e.g., "difficulty with social communication", "repetitive behaviors", "sensory sensitivities").
28- Types of therapies and interventions (e.g., "Applied Behavior Analysis (ABA)", "speech therapy", "occupational therapy", "DIR Floortime").
29- Diagnostic processes and criteria (e.g., "ADOS assessment", "early diagnosis", "developmental screening").
30- Educational approaches and supports (e.g., "Individualized Education Program (IEP)", "special education services", "inclusive classrooms").
371Â Â <script>
372Â Â Â Â const tagsData = ${tagsJson};
373const sourceApiUrl = "${sourceUrl}"; // For form submission
374375Â Â Â Â function escapeHtml(unsafe) {
510511Â Â Â Â Â Â Â Â Â try {
512Â Â Â Â Â Â Â Â Â Â Â const response = await fetch(sourceApiUrl, {
513Â Â Â Â Â Â Â Â Â Â Â Â Â method: 'POST',
514Â Â Â Â Â Â Â Â Â Â Â Â Â body: formData // FormData handles multipart/form-data encoding
653}
654655// --- Helper Function: Call OpenAI API ---
656async function callOpenAI(
657openai: OpenAI,
githubWebhookApproveSmallPRsmain.tsx3 matches
21const webhookSecret = process.env.githubWebhookApproveSmallPRs;
22// the token to make github requests (needs `repo` permissions)
23const githubApiToken = process.env.githubApproveSmallPRsToken;
2425let valHttpUrl = "https://val.town";
68const { Octokit } = await import("npm:@octokit/core");
69const octokit = new Octokit({
70auth: githubApiToken,
71});
72const { repository, organization } = payload;
108event: "APPROVE",
109headers: {
110"X-GitHub-Api-Version": "2022-11-28",
111},
112},
v2-vals-create-a-val-examplemain.tsx7 matches
1import { API_URL } from "https://esm.town/v/std/API_URL";
2import { fetchJSON } from "https://esm.town/v/stevekrouse/fetchJSON";
3import ValTown from "npm:@valtown/sdk";
28);
2930// Example of using the API to create a new val with a single file
31// First create the val
32const valResponse = await fetch(
33`${API_URL}/v2/vals`,
34{
35method: "POST",
36body: JSON.stringify({
37name: "new-val-api",
38privacy: "public",
39description: "This is an example of using the API to create a val.",
40}),
41headers: {
53const val = await valResponse.json();
54const fileResponse = await fetch(
55`${API_URL}/v2/vals/${val.id}/files?path=main.tsx`,
56{
57method: "POST",
58body: JSON.stringify({
59content: "This is an example of using the API to create a script file at the root.",
60type: "script",
61}),
1# v2/vals Example: Creating a val with a script file
23This val shows how to create a val and add a script file to it both with the SDK and with the API. You can find both examples in `main.tsx`.
45### Getting Started
61. Remix this project
72. Create your own API token [here](https://www.val.town/settings/api/new) with **Val: Read and write** permissions
83. Create an environment variable in your remixed project called `VAL_RW_TOKEN` and paste your new API token into it
94. Run `main.tsx` and you'll create 2 new vals in your account: `new-val-sdk` and `new-val-api`