aboutsummaryrefslogtreecommitdiff
path: root/editor/forms/add_page.ml
blob: ac45824d8070966177eb165a396e2d01e92eef12 (plain)
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
45
46
47
48
49
50
51
52
53
54
55
56
open Brr
open Brr_note
open Note
module Js = Js_of_ocaml.Js

type t = { title : Jstr.t }

type Events.kind +=
  | AddPage of t [@@unboxed]

let create
  : unit -> Events.t
  = fun () ->

    (* The element which contains the information *)
    let input = El.input ()
        ~at:At.[type' (Jstr.v "text")]
    in

    let state =
      S.hold (AddPage { title = Jstr.empty })
      @@ Evr.on_el
        (Ev.input)
        (fun _ ->
           AddPage { title = El.prop El.Prop.value input }
        )
        input in

    ( state
    , El.div
        [ El.div ~at:At.[class' (Jstr.v "row")]
            [ El.div ~at:At.[class' (Jstr.v "col-25")]
                [ El.label [ El.txt' "Titre"]
                    ~at:[At.for' (Jstr.v "title")]
                ]
            ; El.div ~at:At.[class' (Jstr.v "col-75")]
                [ input ]
            ]
        ] )

let key_of_title
  : Jstr.t -> Jstr.t
  = fun title ->
    title

let on_close
  : t -> State.t -> State.t
  = fun {title} state ->
    let page_id = key_of_title title in
    let new_date = (new%js Js.date_now)##getTime in
    let content_obj = object%js
      val content = Js.null
      val title = Js.some title
      val date = Js.some new_date
    end in
    State.load_page (Some page_id) state content_obj