all repos — h3 @ 6e17f5c3f70ef7273e5b5ae7ee42d2254d785d4f

A tiny, extremely minimalist JavaScript microframework.

example/assets/js/app.js

 1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
import h3, { mount, region } from "./h3.js";
import AddTodoForm from "./components/addTodoForm.js";
import EmptyTodoError from "./components/emptyTodoError.js";
import NavigationBar from "./components/navigationBar.js";
import TodoList from "./components/todoList.js";
import store from "./store.js";

//store.on("log", (state, data) => console.log(data, state));

const app = () => {
  const { todos, filteredTodos, filter } = store.get();
  const [error, updateError] = region(EmptyTodoError);
  store.on("error/update", updateError);
  const [mainArea, updateMainArea] = region(() => {
    store.dispatch("todos/filter", filter);
    localStorage.setItem("h3_todo_list", JSON.stringify(todos));
    return h3("div#main-area", [NavigationBar(), TodoList()]);
  });
  store.on("mainArea/update", () => {
    updateMainArea();
  });
  return h3("div#todolist.todo-list-container", [
    h3("h1", "To Do List"),
    AddTodoForm(),
    error,
    mainArea,
  ]);
};

store.dispatch("todos/load");
mount("app", app());