Scenegraph zipper added

This commit is contained in:
Daniel Ziltener 2017-07-19 15:34:56 +00:00
parent f828198639
commit 45eb96960b
2 changed files with 59 additions and 16 deletions

View File

@ -1,4 +1,4 @@
(defproject clojurefx "0.0.23" (defproject clojurefx "0.0.24-SNAPSHOT"
:description "A Clojure wrapper for JavaFX." :description "A Clojure wrapper for JavaFX."
:license "Like Clojure." :license "Like Clojure."
:url "https://www.bitbucket.org/zilti/clojurefx" :url "https://www.bitbucket.org/zilti/clojurefx"
@ -6,6 +6,6 @@
[swiss-arrows "1.0.0"] [swiss-arrows "1.0.0"]
[com.taoensso/timbre "4.7.4" :exclusions [com.taoensso/carmine]] [com.taoensso/timbre "4.7.4" :exclusions [com.taoensso/carmine]]
[clojure-jsr-223 "0.1.0"]] [clojure-jsr-223 "0.1.0"]]
:profiles {:uberjar {:aot :all}} ;; :profiles {:uberjar {:aot :all}}
:source-paths ["src"] :source-paths ["src"]
:java-source-paths ["src"]) :java-source-paths ["src"])

View File

@ -8,22 +8,65 @@
(:import (javafx.scene.layout Region) (:import (javafx.scene.layout Region)
(javafx.scene.shape Rectangle))) (javafx.scene.shape Rectangle)))
;; Fuck you, whoever made that API design.
;; (defonce force-toolkit-init (javafx.embed.swing.JFXPanel.))
(timbre/refer-timbre) (timbre/refer-timbre)
;; (import '(clojurefx AppWrap) (defonce force-toolkit-init (javafx.embed.swing.JFXPanel.))
;; '(javafx.scene.control Labeled Label TextField TextArea CheckBox ComboBox Menu MenuItem MenuBar
;; MenuButton ContextMenu ToolBar SplitPane ScrollPane Accordion ;; ## Scenegraph
;; TitledPane TabPane Tab TableColumnBase Labeled ButtonBase)
;; '(javafx.scene Node Scene Parent) (defmacro fi
;; '(javafx.scene.layout Pane VBox) [interface args & code]
;; '(javafx.stage Stage) (let [interface-type (.getMapping *ns* interface)
;; '(javafx.collections FXCollections ObservableList)
;; '(javafx.css Styleable) methods (-> (.getMethods interface-type)
;; '(javafx.event Event ActionEvent EventTarget) seq)
;; '(java.util Collection)) method-sym (.getName (first methods))]
(when-not (= (count methods) 1)
(throw (new Exception "can't take an interface with more then one method.")))
`(proxy [~interface] []
(~method-sym ~args
~@code))))
(defn branch? [obj]
(or (instance? javafx.scene.Parent obj)
(instance? javafx.scene.control.MenuBar obj)
(instance? javafx.scene.control.Menu obj)))
(defn make-node [node children]
nil)
(defmulti down (fn [x] (class x)))
(defmethod down javafx.scene.Parent [obj]
(.getChildren obj))
(defmethod down javafx.scene.control.MenuBar [obj]
(.getMenus obj))
(defmethod down javafx.scene.control.Menu [obj]
(.getItems obj))
(defmethod down javafx.scene.control.Label [obj]
[(.getGraphic obj)])
(defmethod down javafx.scene.control.ProgressIndicator [obj]
[(.getContextMenu obj)])
(defmethod down :default [obj]
nil)
(defn sgzipper [root]
(zip/zipper branch? down make-node root))
(defn by-id [root id]
(try
(cond
(not (instance? clojure.lang.IFn root)) (do (debug "Raw input confirmed. Starting.")
(by-id (sgzipper root) id))
(zip/end? root) (do (debug "Search ended without result.")
nil)
(nil? (zip/node root)) (by-id (zip/next root) id)
(= id (.getId (zip/node root))) (do (debug "Found item:" (zip/node root))
(zip/node root))
:else (do (info "id of" (zip/node root) "does not match, proceeding to" (zip/node (zip/next root)))
(by-id (zip/next root) id)))
(catch Exception e (error e))))
;; ## Data ;; ## Data