Search
htmlExample
@summerboys
HTML example This is an example of how to return an HTML response. You can also preview it at https://andreterron-htmlExample.web.val.run?name=Andre
HTTP
# HTML example
This is an example of how to return an HTML response.
You can also preview it at https://andreterron-htmlExample.web.val.run?name=Andre
// View at https://andreterron-htmlExample.web.val.run?name=Andre
export default async function(req: Request): Promise<Response> {
const query = new URL(req.url).searchParams;
// Read name from the querystring or body. Defaults to "you" if not present.
const name = query.get("name") || (await req.json().catch(() => ({}))).name || "you";
// Returns the HTML response
return new Response(`<h1>Hi summer ${name}!</h1>`, {
saveToReadwiseReader
@vlad
An interactive, runnable TypeScript val by vlad
Script
export const saveToReadwiseReader = async (
params: ReaderSaveParams,
token: string,
return fetch("https://readwise.io/api/v3/save/", {
method: "POST",
headers: {
"Authorization": `Token ${token}`,
"Content-Type": "application/json",
body: JSON.stringify(params),
interface ReaderSaveParams {
browserbase
@kora
my own library to use it easily by just import { browser, page } from "./browserbase"; Do I need to call page.close() and browser.close()? Maybe it's already automatic
Script
my own library to use it easily by just
```js
Do I need to call page.close() and browser.close()? Maybe it's already automatic
const browser = await puppeteer.connect({
browserWSEndpoint: `wss://connect.browserbase.com?apiKey=${Deno.env.get("BROWSERBASE_API_KEY")}`,
const pages = await browser.pages();
const page = pages[0];
// await page.goto("https://www.val.town");
// const el = await page.waitForSelector("h1");
// const title = await el?.evaluate(el => el.textContent);
translatePost
@byjonathanleung
An interactive, runnable TypeScript val by byjonathanleung
Script
import { translate } from "https://esm.town/v/byjonathanleung/translate";
export let translatePost = async (req, res) => {
const output = await translate(req.body.input);
res.send(output);
kpunkShows
@aeaton
An interactive, runnable TypeScript val by aeaton
Script
import { fetchHtmlDom } from "https://esm.town/v/aeaton/fetchHtmlDom";
export async function kpunkShows() {
const url = "https://kpunk.libsyn.com/";
const dom = await fetchHtmlDom(url);
const items = dom.querySelectorAll(".leftnav a[href^='/webpage']");
const regex = /^\/webpage\/\d{4}\/\d{2}$/;
return [...items].map((link) => link.getAttribute("href")).filter((link) =>
regex.test(link)
).map((link) => new URL(link, url).toString());
valle_tmp_381630316148628973736615889212891
@janpaul123
* This approach uses regular HTML, CSS animations, and JavaScript to recreate the Wordle game with a twist.
* We will setup a grid for the game, handle input via keyboard and visualize the correct and incorrect guesses.
* The CSS will have fun gradients, fonts and generate lively animations for inputs.
HTTP
* This approach uses regular HTML, CSS animations, and JavaScript to recreate the Wordle game with a twist.
* We will setup a grid for the game, handle input via keyboard and visualize the correct and incorrect guesses.
* The CSS will have fun gradients, fonts and generate lively animations for inputs.
export default async function main(req: Request): Promise<Response> {
const html = `
<html>
<head>
<title>Crazy Wordle</title>
<style>
body {
UserProfileHeader
@iamseeley
@jsxImportSource https://esm.sh/hono@latest/jsx
Script
/** @jsxImportSource https://esm.sh/hono@latest/jsx */
interface UserProfileHeaderProps {
user: {
name: string;
bio: string;
avatar: string;
links: { id?: number; label: string; url: string }[];
const UserProfileHeader: FC<UserProfileHeaderProps> = ({ user }) => {
return (
<div className="flex flex-col gap-1 mb-2">
pubmed
@yawnxyz
Pubmed Search Search Pubmed using a public pubmedisearch endpoint https://yawnxyz-pubmed.web.val.run?query=phage therapy
HTTP
# Pubmed Search
Search Pubmed using a public pubmedisearch endpoint
https://yawnxyz-pubmed.web.val.run?query=phage therapy
const app = new Hono();
// PubMed search function (modified to accept more parameters)
async function pubmedSearch(query, userId, additionalParams = {}) {
const url = 'https://www.pubmedisearch.com/api/fetch_articles';
const options = {
method: 'POST',
headers: {
short
@tmcw
Short URLs A URL shortener in Val Town! This turns URLs into strings like https://tmcw-short.express.val.run/JK Which, well - it's not that short 🤣 but it's a start! It's pretty simple! In this case the storage is a private val because it contains some URLs. Part of the magic here is the venerable hashids module, which produces non-sequential string identifiers from an underlying serial numeric ID. So instead of huge UUIDs or fixed-length IDs like nanoid would generate, this generates short IDs, at least initially - like the example above, which is just "JK".
Express (deprecated)
# [Short URLs](https://tmcw-short.express.val.run/)
[A URL shortener in Val Town!](https://tmcw-short.express.val.run/) This turns URLs into strings like
https://tmcw-short.express.val.run/JK
[![URL Shortener](https://dropovercl.s3.amazonaws.com/1b979932-bda8-472d-998a-db30b73760c7/159f857d-6b3c-48b0-95c8-fcea1af4fca8/7637a903-115a-4d58-8f45-8b38b9387444.png)](https://tmcw-short.express.val.run/)
Which, well - it's not _that_ short 🤣 but it's a start! It's pretty simple! In this case the storage is a private val because it contains some URLs. Part of the magic here is the venerable [hashids](https://hashids.org/javascript/) module, which produces non-sequential string identifiers from an underlying serial numeric ID. So instead of huge UUIDs or fixed-length IDs like `nanoid` would generate, this generates short IDs, at least initially - like the example above, which is just "JK".
export let short = async (req, res) => {
const param = req.path.substring(1);
const { default: Hashids } = await import("npm:hashids");
const H = new Hashids(short_storage.salt);
if (!param) {
val_l3Q6EkwIdS
@dhvanil
An interactive, runnable TypeScript val by dhvanil
HTTP
export const jsonOkExample = () => Response.json({ ok: true });
val_SFvomXHUED
@dhvanil
An interactive, runnable TypeScript val by dhvanil
HTTP
export const jsonOkExample = () => Response.json({ ok: true });
helloWorld
@campsite
This is a simple script to create a post on Campsite. Use it as a starting point for other scripts. Campsite API Documentation: https://campsite.com/docs
Script
This is a simple script to create a post on Campsite. Use it as a starting point for other scripts.
Campsite API Documentation: https://campsite.com/docs
* Hello World
* This is a simple script to create a post on Campsite. Use it as a starting point for other scripts.
* Campsite API Documentation: https://campsite.com/docs
const CONTENT = `Hello world`;
const CHANNEL_ID = "<project_id>";
async function main() {
const body = {
title: "Hello World",
helloWorldPDF
@richardkaplan
// View me at https://neverstew-helloWorldPDF.web.val.run
Script
// View me at https://neverstew-helloWorldPDF.web.val.run
export const helloWorldPDF = async (req: Request) => {
const { jsPDF } = await import("npm:jspdf");
const doc = new jsPDF();
doc.text("Hello world - Just a test!", 10, 10);
return new Response(doc.output(), {
headers: { "Content-Type": "application/pdf" },
esmTown
@jdan
wordGame A wordgame inspired by TextTwist. Custom games can be created by appending the available letters to the url. https://jdan-esmtown.web.val.run/nsetyr The dictionary is populated from the following script: import { blob } from "https://esm.town/v/std/blob?v=12";
const dictionaryUrls = [
"https://www.freescrabbledictionary.com/word-lists/3-letter-words/3-letter-words.json",
"https://www.freescrabbledictionary.com/word-lists/4-letter-words/4-letter-words.json",
"https://www.freescrabbledictionary.com/word-lists/5-letter-words/5-letter-words.json",
"https://www.freescrabbledictionary.com/word-lists/6-letter-words/6-letter-words.json",
"https://www.freescrabbledictionary.com/word-lists/7-letter-words/7-letter-words.json",
];
const allWords = await Promise.all(
dictionaryUrls.map(async (url) => {
const res = await fetch(url);
const words = await res.json();
return words.map((entry) => entry.word);
}),
);
blob.setJSON("words", allWords.flat());
HTTP
## wordGame
A wordgame inspired by TextTwist. Custom games can be created by appending the available letters to the url.
https://jdan-esmtown.web.val.run/nsetyr
![image.png](https://imagedelivery.net/iHX6Ovru0O7AjmyT5yZRoA/c4319cfb-b959-4f06-046f-2ff98be6dd00/public)
The dictionary is populated from the following script:
```ts
/** @jsxImportSource npm:hono@3/jsx */
function esmTown(url) {
return fetch(url, {
headers: {
iopEmail
@yurivish
An interactive, runnable TypeScript val by yurivish
HTTP
let { submittedEmailAddresses } = await import("https://esm.town/v/yurivish/submittedEmailAddresses");
export const iopEmail = async (req: Request) => {
// Create somewhere to store data if it doesn't already exist
if (submittedEmailAddresses === undefined) {
submittedEmailAddresses = [];
// Pick out the form data
const formData = await req.formData();
const emailAddress = formData.get("email") as string;
const init = { headers: { "Content-Type": "text/html" } };
if (submittedEmailAddresses.includes(emailAddress)) {