Search
ssr_react_mini
@stevekrouse
Server-side Render React Mini Framework This is very experimental, more of a prototype of an architecture, than a true framework Example: https://www.val.town/v/stevekrouse/TodoApp
Script
# Server-side Render React Mini Framework
/** @jsxImportSource https://esm.sh/react */
import { renderToString } from "https://esm.sh/react-dom@18.2.0/server";
import { useEffect, useState } from "https://esm.sh/react@18.2.0";
// button that's disabled until client react hydrates
const [clientHydrated, setClientHydrated] = useState(false);
useEffect(() => setClientHydrated(true), []);
return <button disabled={!clientHydrated} {...props}></button>;
const [clientHydrated, setClientHydrated] = useState(false);
useEffect(() => setClientHydrated(true), []);
disabled={!clientHydrated}
reactClient
@iamseeley
š Client Side code for the React example
Script
š Client Side code for the React example
* @title React CSR Client in Val Town
* @description Client-side React application for a personal portfolio website.
/** @jsxImportSource https://esm.sh/react */
import React, { useState, useEffect } from "https://esm.sh/react";
import ReactDOM from "https://esm.sh/react-dom";
import { BrowserRouter, Route, NavLink, Routes } from "https://esm.sh/react-router-dom";
<p><strong>This website is rendered client-side with React.</strong></p>
<p>Check out the <a target='_blank' href='https://www.val.town/v/iamseeley/reactClient'>client</a> and <a target='_blank' href='https://www.val.town/v/iamseeley/reactServer'>server</a> code and start building your own site!</p>
const root = ReactDOM.createRoot(document.getElementById("root"));
react_framer_motion_client
@tfayyaz
* @title Running React on the Client
* @description Vals can also be used to host client-side code!
* @preview https://pomdtr-react_example_server.web.val.run
* @include pomdtr/react_example_client
* @resource [React - Quick Start](https://react.dev/learn)
HTTP
* @title Running React on the Client
* @description Vals can also be used to host client-side code!
* @preview https://pomdtr-react_example_server.web.val.run
* @include pomdtr/react_example_client
* @resource [React - Quick Start](https://react.dev/learn)
// The server response includes a script referencing the client val
export const server = (req) =>
<head>
<title>React Example</title>
<meta name="viewport" content="width=device-width, initial-scale=1" />
<main id="root"></main>
<script type="module" src="https://esm.town/v/tfayyaz/react_framer_motion_script"></script/>
</body>
pleasedLavenderAlbatross
@ganeshkumartk
// This approach creates a simple React component that embeds the MicroReact widget
HTTP
// This approach creates a simple React component that embeds the MicroReact widget
// on the client-side, and the server will return the HTML structure with the
/** @jsxImportSource https://esm.sh/react */
import React from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
interface MicroReactProps {
reactions?: string;
function MicroReact({
reactions = "12345",
}: MicroReactProps) {
chronosphere
@all
@jsxImportSource https://esm.sh/react
HTTP
/** @jsxImportSource https://esm.sh/react */
import React, { useEffect, useRef, useState } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
side: THREE.DoubleSide,
mouse.x = (event.clientX / window.innerWidth) * 2 - 1;
mouse.y = -(event.clientY / window.innerHeight) * 2 + 1;
function client() {
console.log("Client function called");
console.log("Document is defined, calling client function");
client();
react_client
@nbbaier
// 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 React from "https://esm.sh/react";
import ReactDOM from "https://esm.sh/react-dom";
import { Button } from "https://esm.town/v/nbbaier/shadcnButton";
</Table>
// The app will be rendered inside the root div
const root = ReactDOM.createRoot(document.getElementById("root"));
root.render(<App />);
react_tldraw
@tfayyaz
* @title Running React on the Client
* @description Vals can also be used to host client-side code!
* @preview https://tfayyaz-react_tldraw.web.val.run
* @include tfayyaz/reacttldrawclient
* @resource [React - Quick Start](https://react.dev/learn)
* @resource [tldraw - Quick Start](https://tldraw.dev/)
HTTP
* @title Running React on the Client
* @description Vals can also be used to host client-side code!
* @preview https://tfayyaz-react_tldraw.web.val.run
* @include tfayyaz/reacttldrawclient
* @resource [React - Quick Start](https://react.dev/learn)
* @resource [tldraw - Quick Start](https://tldraw.dev/)
// The server response includes a script referencing the client val
export const server = (req) =>
<head>
<title>TLDraw React Example</title>
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover" />
<main id="root"></main>
<script type="module" src="https://esm.town/v/tfayyaz/reacttldrawclient"></script/>
</body>
reactServer
@iamseeley
š React Client-side rendering Server
HTTP
š React Client-side rendering Server
* @title React CSR Server in Val Town
* @description Serve the HTML shell for a client-side rendered React app in Val Town.
import { websiteStyles } from "https://esm.town/v/iamseeley/websiteStyles";
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap" rel="stylesheet">
<title>${personalData.name} | Client-side React</title>
<style>
<div id="root"></div>
<script type="module" src="https://esm.town/v/iamseeley/reactClient"></script>
</body>
freeFireMaxPanel
@Maheshsaini_7
@jsxImportSource https://esm.sh/react@18.2.0
Cron
/** @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 FreeFireAnalytics() {
risk: 'Medium',
description: 'Potential client-side data leakage points'
type: 'š Authentication Weakness',
</div>
function client() {
createRoot(document.getElementById("root")).render(<FreeFireAnalytics />);
if (typeof document !== "undefined") { client(); }
export default async function server(request: Request): Promise<Response> {
sympatheticOliveWildcat
@priyanshu
@jsxImportSource https://esm.sh/react@18.2.0
HTTP
/** @jsxImportSource https://esm.sh/react@18.2.0 */
import React, { useState, useEffect, useRef } from "https://esm.sh/react@18.2.0";
import { createRoot } from "https://esm.sh/react-dom@18.2.0/client";
// Enhanced Color Palette
</div>
// Client-side Rendering
function client() {
createRoot(document.getElementById("root")).render(<VibeCommunityApp />);
// Render client-side code if in browser environment
if (typeof document !== "undefined") { client(); }
// Server-side Response
export default async function server(request: Request): Promise<Response> {
carInventory
@konradmoneta
@jsxImportSource https://esm.sh/react
HTTP
/** @jsxImportSource https://esm.sh/react */
import React, { useState, useEffect } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
import { init, tx, id } from "https://esm.sh/@instantdb/core@0.12.12";
</div>
function client() {
console.log("Client function called");
const root = document.getElementById("root");
if (typeof document !== "undefined") {
console.log("Document is defined, calling client function");
client();
} else {
console.log("Document is undefined, skipping client-side rendering");
async function server(request: Request): Promise<Response> {
clientMultirouteReact
@iamseeley
š Client-Side Rendered React App via CDN
HTTP
š Client-Side Rendered React App via CDN
* @title Client-Side Rendered React App
* @description Create a personal portfolio website with client-side rendering using React and React Router.
<title>${personalData.name} | Client-side React via CDN</title>
<script src="https://cdn.jsdelivr.net/npm/react@17.0.2/umd/react.production.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/react-dom@17.0.2/umd/react-dom.production.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/react-router-dom@5.2.0/umd/react-router-dom.min.js"></script>
const { useState, useEffect } = React;
const { BrowserRouter, Route, NavLink, Switch } = ReactRouterDOM;
<p><strong>This website is rendered client-side with React.</strong></p>
<p>Check out the <a href='https://www.val.town/v/iamseeley/clientMultirouteReact'>source</a> and start building your own site!</p>
react_tldraw
@iamseeley
* @title Running React on the Client
* @description Vals can also be used to host client-side code!
* @preview https://pomdtr-react_example_server.web.val.run
* @include pomdtr/react_example_client
* @resource [React - Quick Start](https://react.dev/learn)
HTTP
* @title Running React on the Client
* @description Vals can also be used to host client-side code!
* @preview https://pomdtr-react_example_server.web.val.run
* @include pomdtr/react_example_client
* @resource [React - Quick Start](https://react.dev/learn)
// The server response includes a script referencing the client val
export const server = (req) =>
<head>
<title>TLDraw React Example</title>
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover" />
<main id="root"></main>
<script type="module" src="https://esm.town/v/iamseeley/reacttldrawclient"></script>
</body>
healthdatasimple
@ejfox
@jsxImportSource https://esm.sh/react
HTTP
/** @jsxImportSource https://esm.sh/react */
import React from "https://esm.sh/react";
import { renderToString } from "https://esm.sh/react-dom/server";
import { createRoot } from "https://esm.sh/react-dom/client";
const BLOB_KEY = 'health_data';
// Client-side App component
function App({ data }) {
</div>
// Client-side rendering
function client() {
fetch('/api/health-data')
if (typeof document !== "undefined") {
client();
export default async function server(request: Request): Promise<Response> {
design32x32bitmap
@chekos
A smol tool to design smol 1-bit bitmap images mostly for my raspberry pi's 128x32 OLED display
HTTP
/** @jsxImportSource https://esm.sh/react */
import React, { useCallback, useEffect, useRef, useState } from "https://esm.sh/react";
import { createRoot } from "https://esm.sh/react-dom/client";
const getPixelIndex = useCallback((event: React.MouseEvent | React.TouchEvent) => {
const rect = canvas.getBoundingClientRect();
const clientX = "touches" in event ? event.touches[0].clientX : event.clientX;
const clientY = "touches" in event ? event.touches[0].clientY : event.clientY;
const x = Math.floor(((clientX - rect.left) / rect.width) * size.width);
const y = Math.floor(((clientY - rect.top) / rect.height) * size.height);
return { index: y * size.width + x, x: clientX, y: clientY };