From d1135ff55db85ef81bbe2bd8f283cdbbd5464298 Mon Sep 17 00:00:00 2001 From: Joris Date: Mon, 13 Jul 2020 21:30:32 +0200 Subject: Show map and add marks with right click --- src/Lib/Dom/Document.ml | 14 ++++++++++ src/Lib/Dom/Element.ml | 42 +++++++++++++++++++++++++++++ src/Lib/Dom/H.ml | 72 +++++++++++++++++++++++++++++++++++++++++++++++++ src/Lib/Leaflet.ml | 35 ++++++++++++++++++++++++ 4 files changed, 163 insertions(+) create mode 100644 src/Lib/Dom/Document.ml create mode 100644 src/Lib/Dom/Element.ml create mode 100644 src/Lib/Dom/H.ml create mode 100644 src/Lib/Leaflet.ml (limited to 'src/Lib') diff --git a/src/Lib/Dom/Document.ml b/src/Lib/Dom/Document.ml new file mode 100644 index 0000000..867e28c --- /dev/null +++ b/src/Lib/Dom/Document.ml @@ -0,0 +1,14 @@ +external createElement : string -> Dom.element = "createElement" + [@@bs.val] [@@bs.scope "document"] + +external createElementNS : string -> string -> Dom.element = "createElementNS" + [@@bs.val] [@@bs.scope "document"] + +external querySelector : string -> Dom.element Js.Nullable.t = "querySelector" + [@@bs.val] [@@bs.scope "document"] + +let querySelectorUnsafe id = + querySelector id |> Js.Nullable.toOption |> Js.Option.getExn + +external createTextNode : string -> Dom.element = "createTextNode" + [@@bs.val] [@@bs.scope "document"] diff --git a/src/Lib/Dom/Element.ml b/src/Lib/Dom/Element.ml new file mode 100644 index 0000000..3e3b78a --- /dev/null +++ b/src/Lib/Dom/Element.ml @@ -0,0 +1,42 @@ +external setValue : Dom.element -> string -> unit = "value" [@@bs.set] + +external setTextContent : Dom.element -> string -> unit = "textContent" + [@@bs.set] + +external setStyle : Dom.element -> string -> unit = "style" [@@bs.set] + +external setClassName : Dom.element -> string -> unit = "className" [@@bs.set] + +external setAttribute : Dom.element -> string -> string -> unit = "setAttribute" + [@@bs.send] + +external setAttributeNS : Dom.element -> string -> string -> string -> unit + = "setAttributeNS" + [@@bs.send] + +external addEventListener : Dom.element -> string -> (Dom.event -> unit) -> unit + = "addEventListener" + [@@bs.send] + +external appendChild : Dom.element -> Dom.element -> unit = "appendChild" + [@@bs.send] + +external firstChild : Dom.element -> Dom.element Js.Nullable.t = "firstChild" + [@@bs.get] + +external removeChild : Dom.element -> Dom.element -> unit = "removeChild" + [@@bs.send] + +let removeFirstChild element = + match Js.toOption (firstChild element) with + | Some child -> + let () = removeChild element child in + true + | _ -> false + +let rec removeChildren element = + if removeFirstChild element then removeChildren element else () + +let mountOn base element = + let () = removeChildren base in + appendChild base element diff --git a/src/Lib/Dom/H.ml b/src/Lib/Dom/H.ml new file mode 100644 index 0000000..8183a02 --- /dev/null +++ b/src/Lib/Dom/H.ml @@ -0,0 +1,72 @@ +(* Element creation *) + +let h tag ?(attributes = [||]) ?(eventListeners = [||]) ?(children = [||]) () : + Dom.element = + let element = + if tag == "svg" || tag == "path" then + Document.createElementNS "http://www.w3.org/2000/svg" tag + else Document.createElement tag + in + let () = + Js.Array.forEach + (fun (name, value) -> Element.setAttribute element name value) + attributes + in + let () = + Js.Array.forEach + (fun (name, eventListener) -> + Element.addEventListener element name eventListener) + eventListeners + in + let () = + Js.Array.forEach (fun child -> Element.appendChild element child) children + in + element + +(* Node creation *) + +let text = Document.createTextNode + +let div = h "div" + +let span = h "span" + +let header = h "header" + +let button = h "button" + +let section = h "section" + +let svg = h "svg" + +let path = h "path" + +let form = h "form" + +let label = h "label" + +let input_ = h "input" + +(* Attribute creation *) + +let id v = ("id", v) + +let className v = ("class", v) + +let viewBox v = ("viewBox", v) + +let d v = ("d", v) + +let type_ v = ("type", v) + +let min_ v = ("min", v) + +let value v = ("value", v) + +(* Event listeners *) + +let onClick f = ("click", f) + +let onInput f = ("input", f) + +let onSubmit f = ("submit", f) diff --git a/src/Lib/Leaflet.ml b/src/Lib/Leaflet.ml new file mode 100644 index 0000000..45e2963 --- /dev/null +++ b/src/Lib/Leaflet.ml @@ -0,0 +1,35 @@ +type map + +external map : string -> map = "map" + [@@bs.val] [@@bs.scope "L"] + +external setView : map -> float array -> int -> unit = "setView" + [@@bs.send] + +type mapEvent + +external on : map -> string -> (mapEvent -> unit) -> unit = "on" + [@@bs.send] + +type latLng = + { lat : float; + lng : float; + } + +external latLng : mapEvent -> latLng = "latlng" + [@@bs.get] + +type addable + +external tileLayer : string -> addable = "tileLayer" + [@@bs.val] [@@bs.scope "L"] + +external addTo : addable -> map -> unit = "addTo" + [@@bs.send] + +type markerInput = + { title : string; + } + +external marker : latLng -> markerInput -> addable = "marker" + [@@bs.val] [@@bs.scope "L"] -- cgit v1.2.3