all repos — h3 @ a10856afd1e8a04af2a7f9914b657984a56787a5

A tiny, extremely minimalist JavaScript microframework.

docs/example/assets/js/components/AddTodoForm.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
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
import { h3, h } from "../h3.js";

export default function AddTodoForm() {
    const focus = () => document.getElementById("new-todo").focus();
    const addTodo = () => {
        if (!newTodo.value) {
            h3.dispatch("error/set");
            h3.redraw();
            focus();
            return;
        }
        h3.dispatch("error/clear");
        h3.dispatch("todos/add", {
            key: `todo_${Date.now()}__${btoa(newTodo.value)}`,
            text: newTodo.value,
        });
        newTodo.value = "";
        h3.redraw();
        focus();
    };
    const addTodoOnEnter = (e) => {
        if (e.keyCode == 13) {
            addTodo();
            e.preventDefault();
        }
    };
    const newTodo = h("input", {
        id: "new-todo",
        placeholder: "What do you want to do?",
        oninput: (e) => (newTodo.value = e.target.value),
        onkeydown: addTodoOnEnter,
    });
    return h("form.add-todo-form", [
        newTodo,
        h(
            "span.submit-todo",
            {
                title: "Add Todo",
                onclick: addTodo,
            },
            "+"
        ),
    ]);
}