summaryrefslogtreecommitdiff
path: root/org-roam-ui.el
diff options
context:
space:
mode:
authorThomas F. K. Jorna <[email protected]>2021-07-28 16:48:10 +0200
committerThomas F. K. Jorna <[email protected]>2021-07-28 16:48:10 +0200
commit173963d752bc8ea9c18d4165c0bcf88097c69cbe (patch)
treefba23285ef87ee4af35a88bb554ff4580e3744c4 /org-roam-ui.el
parent8b9d53389fe346259f4288f341abc2df5d5679aa (diff)
changed theme sync to websockets
Diffstat (limited to 'org-roam-ui.el')
-rw-r--r--org-roam-ui.el29
1 files changed, 28 insertions, 1 deletions
diff --git a/org-roam-ui.el b/org-roam-ui.el
index 7a84d2f..c218aee 100644
--- a/org-roam-ui.el
+++ b/org-roam-ui.el
@@ -107,12 +107,18 @@ This serves the web-build and API over HTTP."
:host 'local
:on-open (lambda (ws) (progn (setq oru-ws ws) (org-roam-ui--send-graphdata) (message "Connection established with org-roam-ui")))
:on-close (lambda (_websocket) (setq oru-ws nil) (message "Connection with org-roam-ui closed succesfully."))))
+ (if (boundp 'counsel-load-theme
+(advice-add 'counsel-load-theme :after #'org-roam-ui-sync-theme--advice)
+ (advice-add 'load-theme :after #'org-roam-ui-sync-theme-manually)))
(add-hook 'post-command-hook #'org-roam-ui--update-current-node)
(add-hook 'post-command-hook #'org-roam-ui-update))
(t
(progn
(remove-hook 'post-command-hook #'org-roam-ui-update)
(remove-hook 'post-command-hook #'org-roam-ui--update-current-node)
+ (if (boundp 'counsel-load-theme
+(advice-remove 'counsel-load-theme #'org-roam-ui-sync-theme--advice)
+ (advice-remove 'load-theme #'org-roam-ui-sync-theme--advice)))
(websocket-server-close org-roam-ui-ws)
(delete-process org-roam-ui-ws)
(httpd-stop)))))
@@ -137,6 +143,27 @@ This serves the web-build and API over HTTP."
(interactive)
(websocket-send-text oru-ws (json-encode `((type . "command") (data . ((commandName . "follow") (id . ,(org-roam-id-at-point))))))))
+(defun org-roam-ui-sync-theme--advice ()
+ (websocket-send-text oru-ws (json-encode `((type . "theme") (data . ,(org-roam-ui--update-theme))))))
+
+(defun org-roam-ui-sync-theme-manually ()
+ (interactive)
+ (websocket-send-text oru-ws (json-encode `((type . "theme") (data . ,(org-roam-ui--update-theme))))))
+
+(defun org-roam-ui--update-theme ()
+ (let ((ui-theme (list nil)))
+ (if org-roam-ui-sync-theme
+ (if (boundp 'doom-themes--colors)
+ (let*
+ ((colors (butlast doom-themes--colors (- (length doom-themes--colors) 25))) doom-theme (list-nil))
+ (progn
+ (dolist (color colors) (push (cons (car color) (car (cdr color))) doom-theme)))
+ (setq ui-theme doom-theme))
+ (setq ui-theme (org-roam-ui-get-theme)))
+ (when org-roam-ui-custom-theme
+ org-roam-ui-custom-theme))
+ ui-theme))
+
(defservlet* graph application/json ()
(let* ((nodes-columns [id file title level])
(links-columns [source dest type])
@@ -221,7 +248,7 @@ This function is added to `post-command-hook'."
((colors (butlast doom-themes--colors (- (length doom-themes--colors) 25))) ui-theme (list nil))
(progn
(dolist (color colors) (push (cons (car color) (car (cdr color))) ui-theme))
- (insert (format "data: %s\n\n" (json-encode ui-theme)))))
+ ui-theme)))))
(insert (format "data: %s\n\n" (json-encode (org-roam-ui-get-theme)))))
(when org-roam-ui-custom-theme
(insert (format "data %s\n\n" (json-encode org-roam-ui-custom-theme)))))