Skip to content

Latest commit

 

History

History
55 lines (35 loc) · 1.59 KB

README.md

File metadata and controls

55 lines (35 loc) · 1.59 KB

the-super-tiny-liveview

intentional tradeoffs

  • ✅ The API user doesn't need to worry too much about syncing state between clients/server, they can just focus on app logic

  • ✅ Rendering is familiar to React SSR devs

  • ✅ Low number of dependencies

  • ✅ Simple API

  • 🛑 Unoptimized, potentially quite slow

  • 🛑 Insecure

  • 🛑 Far less features than other LiveView systems

  • 🛑 Consuming the library is not very ergonomic

why

There are lots of cool liveview implementations out there already!

I wanted to break down the concept as simply as I could to get a good understanding of how they work behind the scenes.

Along the way I thought maybe a tiny example without many dependencies or features would help me & others understand how LiveView style webapps function.

The focus now is sharpening it into a tiny, fun DSL to make quick & dirty multiplayer apps simple to build.

how

To install dependencies:

bun install

To run:

bun examples/kitchen-sink-counter.tsx

docs

live view apps only require a render function. you can also supply:

  • mount - called on app startup, can be used to add timers
  • dispatch - called when a client dispatches an action, or when a timer fires
  • local/shared - the initial values for local (per-socket) data and data shared by all sockets

data-stl-action add this attribute to a clickable DOM element to dispatch an action to your app's dispatch function

if you need a more complex payload, add data-stl-payload-foo='bar' to add the payload {foo: bar} to your action

Examples

See ./examples

Run with bun ./examples/<name>