Liking cljdoc? Tell your friends :D

com.fulcrologic.fulcro.algorithms.timbre-support

Logging helpers to make js console logging more readable. The recommended use of these functions is as follows:

  • Make sure you're using Binaryage devtools (on classpath. shadow-cljs will auto-add it when detected).
  • IMPORTANT: Enable custom formatters in console settings for Chrome. This will print cljs data as cljs (instead of raw js).
  • Make a development preload cljs file, and tell shadow-cljs to preload it.
  • In the preload file, add something like this:
(ns app.development-preload
  (:require
    [taoensso.timbre :as log]
    [com.fulcrologic.fulcro.algorithms.timbre-support :refer [console-appender prefix-output-fn]))

(log/set-level! :debug)
(log/merge-config! {:output-fn prefix-output-fn
                    :appenders {:console (console-appender)}})

and you'll get much more readable error messages in the js console.

NOTE: when logging errors, be sure to log the exception first. This is documented in timbre, but easy to miss:

(try
  ...
  (catch :default ex
    (log/error ex ...))

See the development_preload.cljs and shadow-cljs.edn files in the latest Fulcro 3 template for an example.

Logging helpers to make js console logging more readable. The recommended use of these functions is as follows:

- Make sure you're using Binaryage devtools (on classpath. shadow-cljs will auto-add it when detected).
- IMPORTANT: Enable custom formatters in console settings for Chrome. This will print cljs data as cljs (instead of raw js).
- Make a development preload cljs file, and tell shadow-cljs to preload it.
- In the preload file, add something like this:

```
(ns app.development-preload
  (:require
    [taoensso.timbre :as log]
    [com.fulcrologic.fulcro.algorithms.timbre-support :refer [console-appender prefix-output-fn]))

(log/set-level! :debug)
(log/merge-config! {:output-fn prefix-output-fn
                    :appenders {:console (console-appender)}})
```

and you'll get much more readable error messages in the js console.

NOTE: when logging errors, be sure to log the exception first. This is documented in timbre, but easy to miss:

```
(try
  ...
  (catch :default ex
    (log/error ex ...))
```

See the development_preload.cljs and shadow-cljs.edn files in the latest Fulcro 3 template for an example.
raw docstring

console-appendercljs

(console-appender & [opts])

Returns a js/console appender for ClojureScript. This appender uses the normal output-fn to generate the main message, but it also does raw output of the original logging args so that devtools can format data structures.

Furthermore, if it detects an ExceptionInfo it will print the ex-message after so that you can see the real message of the exception last in the console. This is particularly handy when using specs and expound with spec instrumentation.

For accurate line numbers in Chrome, add these Blackbox[1] patterns: /taoensso/timbre/appenders/core\.js$ /taoensso/timbre\.js$ /cljs/core\.js$

[1] Ref. https://goo.gl/ZejSvR

Returns a js/console appender for ClojureScript. This appender uses the normal output-fn to generate the main
message, but it also does raw output of the original logging args so that devtools can format data structures.

Furthermore, if it detects an ExceptionInfo it will print the `ex-message` *after* so that you can see the real
message of the exception last in the console.  This is particularly handy when using specs and expound with
spec instrumentation.

For accurate line numbers in Chrome, add these Blackbox[1] patterns:
  `/taoensso/timbre/appenders/core\.js$`
  `/taoensso/timbre\.js$`
  `/cljs/core\.js$`

[1] Ref. https://goo.gl/ZejSvR
sourceraw docstring

prefix-output-fncljs

(prefix-output-fn data)
(prefix-output-fn opts data)

Mostly taken from timbre, but just formats message prefix as output (e.g. only location/line/level). Use with the console appender from this namespace to get better logging output in cljs.

Mostly taken from timbre, but just formats message prefix as output (e.g. only location/line/level). Use with the
console appender from this namespace to get better logging output in cljs.
sourceraw docstring

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close