Skip to content

Latest commit

 

History

History
84 lines (71 loc) · 1.91 KB

README.md

File metadata and controls

84 lines (71 loc) · 1.91 KB

SerendipJS

Attempt to write a frontend framework from scratch as a learning opportunity

Important

This project has a lot of missing parts/features as this as this is learning project

Features

  • Diffing and patching Algorithm for minimal re render
  • Vdom tree with 4 nodes (portal, element, string and fragment)
  • Full typescript support

Counter app Example

Defining the state

const state = { count: 0 };

Defining the actions

const reducers = {
  add: (state) => ({ count: state.count + 1 }),
  sub: (state) => ({ count: state.count - 1 }),
} satisfies Reducers<typeof state>;

Defining the view

const View: View<typeof state, typeof reducers> = (state, emit) => {
  return h("main", { class: "main-container" }, [
    h(
      "button",
      {
        class: "btn text-massive tooltip",
        "data-tooltip": "decrement",
        on: { click: () => emit("sub") },
      },
      [hString("-")],
    ),
    h("span", { class: "text-massive truncate" }, [
      hString(state.count.toString()),
    ]),
    h(
      "button",
      {
        class: "btn text-massive tooltip",
        "data-tooltip": "increment",
        on: { click: () => emit("add") },
      },
      [hString("+")],
    ),
  ]);
};

Mounting the app

createApp({ state, view: View, reducers }).mount(
  document.getElementById("app")!,
)

Ouput

2024-01-12 18-49-00 (online-video-cutter com)

Project structur

  • /packages/runtime: core library
  • /example/counter: counter app example
  • /example/todo: todo app example

TODOS

  • syntatic sugar in jsx (for loop, if stmt...)
  • jsx
  • error boundaries
  • component fn
  • diffing algorithm
  • add portal virtual nodes
  • rerender node on state changes
  • add state
  • Mounting vnode to dom
  • Create virtual nodes