Fork me on GitHub
#clojurescript
<
2023-05-08
>
emilaasa09:05:03

How do you handle working with time across Clojure & ClojureScript? I currently have clj-time in the backend, which I gather can't be made to work in the browser. There's plenty of business logic that involves filtering in different intervals and so on that I'd like to share. Any favorite solutions?

seancorfield15:05:19

@U6T7M9DBR as the clj-time readme says: "look at clojure.java-time if you want a Clojure wrapper for that, or cljc.java-time for a thin Clojure(Script) wrapper, or juxt/tick for another cross-platform option." You need cljs, so either cljc.java-time or tick.

danieroux15:05:23

https://github.com/juxt/tick to be exact (Googling "tick" is not fun! 🕷️)

seancorfield15:05:02

The clj-time readme helpfully links to both projects:grin:

danieroux15:05:43

And you want to start with https://juxt.github.io/tick/#_intervals if I understand correctly

emccue16:05:39

tick is a different model of time - if you just want "the same code" cljc-java-time is the way

emccue16:05:39

tick is built on top of it, and there is stuff that might be worth considering in tick , but thats a bigger change than I think you want atm

emilaasa05:05:14

Thanks everyone for the answers!

leif19:05:31

Is there any way I can read and write a record? Say for example:

(ns test.core
  (:require [cljs.data.xml :as xml]
            [cljs.tools.reader :as t]))

(t/read-string (pr-str #xml/element{}))
gives me
#error {:message "No reader function for tag xml/element.", :data {:type :reader-exception, :ex-kind :reader-error}}

leif19:05:19

Alternatively, is there any way I can convert a record to a plain dictionary?

leif19:05:26

(That would be fine.)

p-himik19:05:51

For reading - data readers should work just fine. For converting - (into {} my-record).

leif19:05:54

@U2FRKM4TW data readers? Do you mean like edn?

p-himik19:05:47

No, I mean the data_readers.cljc file.

p-himik19:05:33

Although those might work only during compilation, not sure.

leif19:05:21

Oh ya, I got the impression that was the case, but I can double check, thanks.

timrichardt20:05:51

To whom it may concern, the link to to the documentation for data_readers.cljc . https://clojure.org/reference/reader#tagged_literals Even if the Clojure doc is just an essay collection, data_readers.cljc deserves a headline. Really hard to find. clojure.tools.reader does not mention data_readers.cljc . clojure.edn doesn't, too - only links to the old Rich Hickey text about what edn should be.

timrichardt23:05:57

https://clojuredocs.org/clojure.core/*data-readers* data_readers.cljc mentioned here, but the mechanism isn't obvious.

thheller06:05:31

personally I hate data_readers.cljc, since its some implicit state where the mere presence on the classpath changes how your code works.

thheller06:05:47

best to be explicit and supply your readers yourself

thheller06:05:02

read takes an option map. {:readers {'xml/element your-fn-handling-that}}

thheller06:05:22

there is also cljs.reader/register-tag-parser! if you want to register it "globally"

p-himik06:05:41

> where the mere presence on the classpath changes how your code works To be the devil's advocate - isn't that how all required namespaces work? ;) I get what you mean, but that file, along with user and deps.edn files in specific locations outside of the project, is something fixed and known, a part of Clojure itself.

thheller06:05:02

if you ask me data_readers.cljc is configuration, not code. as such it has no place on the classpath. but I also banned tagged literals in my code, and limit it to my data, so I'm never in a situation where I need a reader literal available to read my source code

thheller06:05:55

also saves you from this weird situation where trying to read a tagged literal when the code isn't loaded yet and getting an unbound var error

thheller06:05:22

I have strong feelings about data_readers.cljc being bad, YMMV 😉

👍 2