This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2023-09-30
Channels
- # announcements (1)
- # asami (60)
- # babashka (7)
- # beginners (19)
- # biff (5)
- # calva (12)
- # cherry (4)
- # cider (8)
- # clerk (3)
- # clojure-europe (3)
- # clojuredesign-podcast (2)
- # clojurescript (8)
- # data-science (48)
- # fulcro (8)
- # hyperfiddle (21)
- # leiningen (1)
- # malli (7)
- # music (3)
- # off-topic (7)
- # pedestal (15)
- # portal (8)
- # releases (2)
I need to call a JS function from Electric and receive the return value via a callback I'm passing to the function. I need that value "in Electric" so that I can perform some action with it in the backend. I can achieve this by creating a temporary JS atom and watching that, but perhaps there is a better way to do this with missionary?
(e/client
(let [!res (atom nil)]
(js/chrome.tabs.sendMessage js/chrome.devtools.inspectedWindow.tabId
(clj->js {:action "do-sth"})
#(reset! !res (js->clj %)))
(when-let [new-res (e/watch !res)]
(e/server (println "!res changed" new-res)))))
Actually, I either need to wrap it in another e/server
call
(e/server
(e/client
(let [!res (atom nil)]
(js/chrome.tabs.sendMessage js/chrome.devtools.inspectedWindow.tabId
(clj->js {:action "do-sth"})
#(reset! !res (js->clj %)))
(when-let [new-res (e/watch !res)]
(e/server (println "!res changed" new-res))))))
or do some other stuff in the server, like another print statement
(e/client
(e/server (println "sth"))
(let [!res (atom nil)]
(js/chrome.tabs.sendMessage js/chrome.devtools.inspectedWindow.tabId
(clj->js {:action "do-sth"})
#(reset! !res (js->clj %)))
(when-let [new-res (e/watch !res)]
(e/server (println "!res changed" new-res)))))
Otherwise I don't see the backend print statement "!res changed"differential electric is natively streaming, it works on streaming event sources (like LLM completions) natively. It fixes several implementation issues as well that were preventing Electric e/for from achieving optimal network IO and introducing unexpected latency
differential electric is a strong enough foundation to build ultradynamic responsive UIs like say microsoft word. By operating on flows of diffs instead of flows of values it basically means UI code never has to fullscan a collection, even large lists can be rendered without fullscan. Unlike e/for-by today which traverses the full list everytime any element changes
It is probably also a strong enough foundation to build reactive databases like Rama and Materialized in a small amount of LOC, though this is not our mission. Such a database could have an electric client/server split right through the middle of the query engine and indexes, potentially solving the local-first problem once and for all. In this worldview basically the DB and UI are unified and interwoven in the same way that client/server are in electric
so to the end user, extremely responsive and fast ui, and the programming model doesn't need to worry about how big our collection is? are there other benefits for the user?
ah so this will be huge for streaming with llms. i thought some parts of electric were already differential
Will differential also be an option for strings, e.g. streaming building up a string? Workaround is trivial but
if the string is rendered as text only you can just collect them and dom/text
them in. If it's parsed and a DOM structure is built differential electric will help with that. No snippets to share on that yet though 🙂
Yes arbitrary differential collections including accumulating collections of strings (i.e, for rendering a table view based on a stream of strings)
@U09FL65DK I dont understand your statement