all repos — h3 @ e5762e60a5a428577b1e7b795b7500e7103ce120

A tiny, extremely minimalist JavaScript microframework.

example/assets/js/components/todo.js

 1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
import h3 from "../h3.js";
import store from "../store.js";

export default function Todo(data) {
  const todoStateClass = data.done ? ".done" : ".todo";
  const toggleTodo = (todo) => {
    store.dispatch("todos/toggle", data);
    store.dispatch("mainArea/update");
  };
  const removeTodo = (todo) => {
    store.dispatch("todos/remove", data);
    store.dispatch("mainArea/update");
  };
  return h3(`div#${data.key}.todo-item`, [
    h3(`div.todo-content${todoStateClass}`, [
      h3("span.todo-text", { onclick: () => toggleTodo(data) }, data.text),
    ]),
    h3("span.delete-todo", { onclick: () => removeTodo(data) }, "✘"),
  ]);
}