Search
App
@xyc
// JSX can be used in the client val thanks to this magic comment
Script
// JSX can be used in the client val thanks to this magic comment
/** @jsxImportSource https://esm.sh/react **/
// Make sure to only import from esm.sh (npm: specifier are not supported in the browser)
import { GGMLQuantizationType, gguf } from "https://esm.sh/@huggingface/gguf";
import React from "https://esm.sh/react";
import ReactDOM from "https://esm.sh/react-dom";
import { ObjectInspector } from "https://esm.sh/react-inspector";
async function fetchGgufMetadata(url: string) {
function Counter() {
const [counter, setCounter] = React.useState(0);
return (
return (
<h1>React Example</h1>
<Counter />
// The app will be rendered inside the root div
const root = ReactDOM.createRoot(document.getElementById("root"));
root.render(<App />);
tldrawclient
@robcobb
tldraw client forked from tfayyaz (thanks!) Open https://www.val.town/v/robcobb/tldrawcanvasserver to actually view the page; this is a js script imported into that val. Goal is do some little experiments with the tldraw client: a little tldraw console (like the chrome devtools, but populated with tldraw objects) a little version of microworlds logo, but on a tldraw canvas some other experiments! we'll see Uses a pinned older version of tldraw because the other ones seem to fail on a weird dependency issue. My guess is that the val.town bundler tricks don't work so good on transitive deps, but I don't really know.
@use-gesture/react couldn't find the right import for a call to useMemo.
Script
# tldraw client
forked from tfayyaz (thanks!)
Open https://www.val.town/v/robcobb/tldrawcanvasserver to actually view the page; this is a js script imported into that val.
Goal is do some little experiments with the tldraw client:
- a little tldraw console (like the chrome devtools, but populated with tldraw objects)
Uses a pinned older version of tldraw because the other ones seem to fail on a weird dependency issue. My guess is that the val.town bundler tricks don't work so good on transitive deps, but I don't really know.
@use-gesture/react couldn't find the right import for a call to useMemo.
/** @jsxImportSource https://esm.sh/react@18.2.0 **/
// Make sure to only import from esm.sh (npm: specifier are not supported in the browser)
import ReactDOM from "https://esm.sh/react-dom@18.2.0";
import React from "https://esm.sh/react@18.2.0";
import { Tldraw } from "https://esm.sh/tldraw@2.1.0";
</div>
// The app will be rendered inside the root div
const root = ReactDOM.createRoot(document.getElementById("root"));
root.render(<App />);
proudMagentaTurtle
@Murtaza
@jsxImportSource https://esm.sh/react@18.2.0
HTTP
/** @jsxImportSource https://esm.sh/react@18.2.0 */
import React, { useState, useRef } from "https://esm.sh/react@18.2.0";
import { createRoot } from "https://esm.sh/react-dom@18.2.0/client";
import { PDFDocument } from "https://esm.sh/pdf-lib@1.17.1";
</div>
function client() {
createRoot(document.getElementById("root")).render(<App />);
if (typeof document !== "undefined") { client(); }
export default async function server(request: Request): Promise<Response> {
} catch (serverError) {
console.error("Server-side crop error:", serverError);
return new Response(`Error processing PDF: ${serverError.message}`, { status: 500 });
honoAlpineHtmxDemo
@yawnxyz
This example shows how Hono, Alpine, and Htmx can play together. Alpine is great at reactive client-side updates Htmx is great at sending/receiving content from server These two can be combined for reactive clients plus easy AJAX
HTTP
This example shows how Hono, Alpine, and Htmx can play together.
- Alpine is great at reactive client-side updates
- Htmx is great at sending/receiving content from server
- These two can be combined for reactive clients plus easy AJAX
<meta charset="UTF-8">
<title>Reactive Form with Alpine.js</title>
<script defer src="https://cdn.jsdelivr.net/npm/alpinejs@3.x.x/dist/cdn.min.js"></script>
StripeCheckoutDemo
@vawogbemi
@jsxImportSource https://esm.sh/react
HTTP
/** @jsxImportSource https://esm.sh/react */
import React, { useEffect, useState } from "https://esm.sh/react";
import DatePicker from "https://esm.sh/react-datepicker";
import { createRoot } from "https://esm.sh/react-dom/client";
.react-datepicker {
.react-datepicker__header {
.react-datepicker__current-month {
.react-datepicker__day-names, .react-datepicker__week {
.react-datepicker__day-name, .react-datepicker__day {
.react-datepicker__day:hover {
yuktiVoiceAssistant
@Aditya230
@jsxImportSource https://esm.sh/react
HTTP
/** @jsxImportSource https://esm.sh/react */
import React, { useState, useEffect, useRef } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
function App() {
window.speechSynthesis.speak(utterance);
const handleSubmit = async (e: React.FormEvent) => {
e.preventDefault();
</div>
function client() {
createRoot(document.getElementById("root")).render(<App />);
if (typeof document !== "undefined") { client(); }
export default async function server(request: Request): Promise<Response> {
} catch (error) {
console.error("Detailed Server-side error:", error);
return new Response(JSON.stringify({
getBlobAndRenderAsImage
@ashryanio
getBlobAndRenderAsImage Shows how to get a Val Town blob and render it as an image in the DOM with React. Setup Make sure you have an image named test.png in your Val Town blob storage (alternatively, you can change the key name in the blob getter in the script). To easily upload an image to your blob storage, fork this val , run it, and enter your API key in the password input. How it works Fetching the blob: The client-side React component makes a fetch request to "/image". This request is handled by our server function. Server-side handling: The server function calls blob.get("test.png") . This blob.get() method makes an HTTP request to the Val Town API. The API returns a Response object containing the image data. Processing the blob on the server: We receive this Response object from blob.get() . We don't need to extract the data on the server side. We can directly return this Response object to the client. Sending the response to the client: We set the appropriate "Content-Type" header (e.g., "image/png"). We return the Response object to the client. Client-side handling: The fetch request in the React component receives the Response. We call response.blob() to get a Blob object from the Response. Creating a data URL: We create a FileReader object. We use FileReader to read the Blob as a data URL. This data URL is a base64-encoded string representing the image. Updating the React state: We set the data URL as the state of our component. Rendering the image: We use the data URL as the src attribute of an <img> tag. The browser decodes the base64 data and renders the image. Further reading on Val Town blobs Blob storage overview in Val Town docs Val Town REST API references for blobs Val Town blob std lib source code
HTTP
Shows how to get a Val Town blob and render it as an image in the DOM with React.
- The client-side React component makes a fetch request to "/image".
2. Server-side handling:
- We don't need to extract the data on the server side.
- We can directly return this Response object to the client.
/** @jsxImportSource https://esm.sh/react */
import React, { useEffect, useState } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
function client() {
client();
blob_admin
@stevekrouse1
Blob Admin This is a lightweight Blob Admin interface to view and debug your Blob data. Versions 0-17 of this val were done with Hono and server-rendering.
Versions 18+ were generated with Townie and use client-side React. To use this val, fork it to your account.
Authentication is handled by @stevekrouse/lastlogin,
so only the owner of the val will be able to see and edit their own blobs.
HTTP
Versions 18+ were generated with Townie and use client-side React.
/** @jsxImportSource https://esm.sh/react@18.2.0 */
import { createRoot } from "https://esm.sh/react-dom@18.2.0/client";
import { useDropzone } from "https://esm.sh/react-dropzone?deps=react@18.2.0,react-dom@18.2.0";
import React, { ReactNode, useCallback, useEffect, useRef, useState } from "https://esm.sh/react@18.2.0";
children: ReactNode;
const handleClickOutside = (event: MouseEvent) => {
document.addEventListener("mousedown", handleClickOutside);
document.removeEventListener("mousedown", handleClickOutside);
function handleClickOutside(event) {
document.addEventListener("mousedown", handleClickOutside);
GROKPROMPT
@AppleLamps
@jsxImportSource https://esm.sh/react@18.2.0
HTTP
/** @jsxImportSource https://esm.sh/react@18.2.0 */
import { motion } from "https://esm.sh/framer-motion@10.16.4";
import { createRoot } from "https://esm.sh/react-dom@18.2.0/client";
import React, { useEffect, useState } from "https://esm.sh/react@18.2.0";
* App Component
<p className="text-lg font-semibold">How to Use:</p>
<ol className="list-decimal list-inside mt-2 space-y-1 text-sm">
<li>Choose between text or image input.</li>
${isDarkMode ? "bg-gray-600 text-white border-gray-500" : "border-gray-300 text-gray-900"}
p-2 // Added padding 3 (all sides)
<div className="space-y-4">
</div>
* Client entry point
function client() {
createRoot(document.getElementById("root")).render(<App />);
document.body.appendChild(script);
if (typeof document !== "undefined") { client(); }
* Server-side logic for generating prompts.
* The server expects a POST request to "/generate-prompts" with either text or image form data.
summarizeHn
@prashamtrivedi
A simple utility to summarize Hacker News articles, using Gemini Models. Inspired from Simon Willison's TIL , Prompt Inspiration
HTTP
/** @jsxImportSource https://esm.sh/react */
import React, { useState, useEffect } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
function client() {
console.log("Client function called");
console.log("Rendering React app");
console.log("React app rendered");
console.error("Error rendering React app:", error);
console.log("Document is defined, setting up client");
document.addEventListener("DOMContentLoaded", client);
blob_admin
@nbbaier
Blob Admin This is a lightweight Blob Admin interface to view and debug your Blob data. Versions 0-17 of this val were done with Hono and server-rendering.
Versions 18+ were generated with Townie and use client-side React. To use this val, fork it to your account.
Authentication is handled by @stevekrouse/lastlogin,
so only the owner of the val will be able to see and edit their own blobs.
HTTP
Versions 18+ were generated with Townie and use client-side React.
/** @jsxImportSource https://esm.sh/react */
import React, { ReactNode, useCallback, useEffect, useRef, useState } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
import { useDropzone } from "https://esm.sh/react-dropzone";
children: ReactNode;
const handleClickOutside = (event: MouseEvent) => {
document.addEventListener("mousedown", handleClickOutside);
document.removeEventListener("mousedown", handleClickOutside);
function handleClickOutside(event) {
document.addEventListener("mousedown", handleClickOutside);
getJsonAndRenderAsImage
@ashryanio
getJsonAndRenderAsImage Shows how to get a JSON object containing a base64 imaged stored in Val Town blob storage and render it as an image in the DOM with React. Setup Make sure you have a JSON object named image-test in your Val Town blob storage (alternatively, you can change the key name in the blob getter in the script). The object should look like this: {
"image": "base64stringgoeshere"
} To easily upload an image to your blob storage, fork this val , run it, and enter your API key in the password input. How it works Fetching the JSON: The client-side React component makes a fetch request to "/image". This request is handled by our server function. Server-side handling: The server function calls blob.getJSON("image-test") . This blob.getJSON() method makes an HTTP request to the Val Town API. The API returns a Response object containing the JSON data. Processing the blob on the server: We receive this Response object from blob.getJSON() . We don't need to extract the data on the server side. We can directly return this Response object to the client. Sending the response to the client: We set the appropriate "Content-Type" header (e.g., "application/json"). We return the Response object to the client. Client-side handling: The fetch request in the React component receives the Response. We call response.json() to parse the JSON object from the Response. Creating a data URL: We extract the image data from the JSON object at data.image . We prepend the data URL prefix to the image data. This data URL is a base64-encoded string representing the image. Updating the React state: We set the data URL as the state of our component. Rendering the image: We use the data URL as the src attribute of an <img> tag. The browser decodes the base64 data and renders the image. Further reading on Val Town blobs Blob storage overview in Val Town docs Val Town REST API references for blobs Val Town blob std lib source code
HTTP
Shows how to get a JSON object containing a base64 imaged stored in Val Town blob storage and render it as an image in the DOM with React.
- The client-side React component makes a fetch request to "/image".
2. Server-side handling:
- We don't need to extract the data on the server side.
- We can directly return this Response object to the client.
/** @jsxImportSource https://esm.sh/react */
import React, { useEffect, useState } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
function client() {
client();
prodigiousTanTurtle
@ocholap9
/** Toll Management and Payment System This val implements a Toll Management and Payment System with separate interfaces for drivers, toll operators, and administrators. Features User Authentication: Register and login as a driver, toll operator, or administrator. Profile Management: Update user profile information. Vehicle Registration: Drivers can register and view their vehicles. Transaction History: Drivers can view their recent toll transactions. Toll Booth Management: Operators can view and update toll booth statuses. Revenue Reporting: Administrators can view revenue reports. Traffic Analytics: Administrators can access traffic analytics data. User Roles Driver: Can register vehicles, view transaction history, and manage their profile. Toll Operator: Can manage toll booth statuses. Administrator: Can access revenue reports and traffic analytics. How to Use Register an account with your desired role (driver, operator, or admin). Log in to access your role-specific dashboard. Navigate through the application using the provided links and forms. Note: This is a simplified version of a toll management system and does not include all features of a production-ready application.
*/
HTTP
* Note: This is a simplified version of a toll management system and does not include all features of a production-ready application.
/** @jsxImportSource https://esm.sh/react */
import React, { useState, useEffect } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
import { BrowserRouter as Router, Route, Link, Routes, useNavigate } from "https://esm.sh/react-router-dom";
import { jwtDecode } from "https://esm.sh/jwt-decode";
</div>
// Client-side rendering
function client() {
createRoot(document.getElementById("root")).render(<App />);
if (typeof document !== "undefined") { client(); }
// Server-side code
export default async function server(request: Request): Promise<Response> {
quaintBeigeCaribou
@stevekrouse
WinSky BlueSky frontend that resembles an early 2000s forum
HTTP
/** @jsxImportSource https://esm.sh/react@18.3.1 */
import { AppBskyActorDefs, AppBskyFeedDefs, AtpAgent, RichText } from "https://esm.sh/@atproto/api@0.13.15";
import { createRoot } from "https://esm.sh/react-dom@18.3.1/client";
import React, { useCallback, useEffect, useState } from "https://esm.sh/react@18.3.1";
function App() {
<div className="max-w-4xl mx-auto p-4 flex">
{/* Start menu-like sidebar */}
<div className="w-48 mr-4">
</div>
function client() {
createRoot(document.getElementById("root")!).render(<App />);
if (typeof document !== "undefined") {
client();
const manifest = {
short_name: "WinSky",
description: "A Windows XP-styled BlueSky client",
start_url: "/",
<meta name="theme-color" content="#3A6EA5">
<link rel="icon" href="">
<script src="https://cdn.tailwindcss.com"></script>
billGeneratorWebApp
@applemetabank
@jsxImportSource https://esm.sh/react@18.2.0
HTTP
/** @jsxImportSource https://esm.sh/react@18.2.0 */
import React, { useState, useEffect } from "https://esm.sh/react@18.2.0";
import { createRoot } from "https://esm.sh/react-dom@18.2.0/client";
function generatePDFServerSide(invoiceData, template) {
// Client Info
.text(`${invoiceData.clientInfo.name}`)
.text(`${invoiceData.clientInfo.address}`)
.text(`${invoiceData.clientInfo.email}`);
const [clientInfo, setClientInfo] = useState({
clientInfo,