Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/flexsurfer/re-frisk
Take full control of re-frame app
https://github.com/flexsurfer/re-frisk
clj cljs debugger developer-tools devtools electron frisk frisk-debugger re-frame re-frisk reagent tools watch-events
Last synced: 3 days ago
JSON representation
Take full control of re-frame app
- Host: GitHub
- URL: https://github.com/flexsurfer/re-frisk
- Owner: flexsurfer
- Created: 2016-09-19T12:28:46.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-05-20T10:24:37.000Z (over 2 years ago)
- Last Synced: 2025-01-11T14:05:08.737Z (10 days ago)
- Topics: clj, cljs, debugger, developer-tools, devtools, electron, frisk, frisk-debugger, re-frame, re-frisk, reagent, tools, watch-events
- Language: Clojure
- Homepage: https://flexsurfer.github.io/conduit-re-frisk-demo/
- Size: 9.89 MB
- Stars: 461
- Watchers: 15
- Forks: 28
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-re-frame - re-frisk - frame pattern data in your re-frame apps as a tree structure. (Tools / Debugging)
README
# re-frisk
Take full control of [re-frame](https://github.com/Day8/re-frame) application.
Latest stable version: [![Clojars](https://img.shields.io/clojars/v/re-frisk.svg)](https://clojars.org/re-frisk) [![Clojars](https://img.shields.io/clojars/dt/re-frisk.svg)](https://clojars.org/re-frisk) [![Clojars](https://img.shields.io/clojars/v/re-frisk-remote.svg)](https://clojars.org/re-frisk-remote) [![Clojars](https://img.shields.io/clojars/dt/re-frisk-remote.svg)](https://clojars.org/re-frisk-remote)
## DEMO
https://flexsurfer.github.io/conduit-re-frisk-demo/
## Features
Current state for app-db and subscriptions sorted by keys
Watching keys from app-db
History for key in app-db
Events with app-db difference for each event
### re-frame tracing (**Important**: trace should be [enabled](https://github.com/flexsurfer/re-frisk#enable-traces))
(Note: With lots of events and high zoom might be slow, pause or clear events when working with timeline)
Events and timelineSubscriptions
Views sorted by mount order with subscripions
re-frame handlres statistics
Graph for an epoch
(Note: with lots of subscriptions rendering might be slow!)
Graph accumulated for an app life with weights## Usage
`[re-frisk "1.6.0"]`
`[re-frisk-remote "1.6.0"]`**Important**: Please note the following compatibility table:
re-frisk Version | React Version | Reagent Versions
-------------------- | ----------------- | ----------------
`^1.3.4` | React 16.13.0 | 1.x.x |
`1.1.0-1.3.3` | React 16.13.0 | 0.10.x |
`1.0.0` | React 16.9.0 | 0.9.x |
`0.5.3` | React 16 - 16.8.6 | 0.8.x |### Web application
[![Clojars](https://img.shields.io/clojars/v/re-frisk.svg)](https://clojars.org/re-frisk)
re-frisk will be embedded in the DOM of your application. So my suggestion is to use re-frisk-remote, it doesn't affect your application and has more features
1. Add re-frisk as a dev dependency `[re-frisk "1.6.0"]`2. Enable re-frisk
`:preloads [re-frisk.preload]`
OR if you want a hidden UI and open tool with Ctrl+H
`:preloads [re-frisk.preload-hidden]`
OR
`(:require [re-frisk.core :as re-frisk])`
`(re-frisk/enable)`
### React Native, Electron or Web applications
[![Clojars](https://img.shields.io/clojars/v/re-frisk-remote.svg)](https://clojars.org/re-frisk-remote)
1. Add re-frisk as a dev dependency `[re-frisk-remote "1.6.0"]`
2. Enable re-frisk on default port (4567):
`:preloads [re-frisk-remote.preload]`
OR
`(:require [re-frisk-remote.core :as re-frisk-remote])`
`(re-frisk-remote/enable)`
3. Start re-frisk on default port (4567):`shadow-cljs run re-frisk-remote.core/start`
OR
add in `deps.edn`
`:aliases {:dev {:extra-deps {re-frisk-remote {:mvn/version "1.6.0"}}}}}`
create `re_frisk.clj`
```clojure
(ns re-frisk
(:require [re-frisk-remote.core :as re-frisk-remote]))
(re-frisk-remote/start)
```
`clj -R:dev re_frisk.clj`Open re-frisk in a browser at http://localhost:4567
When remote debugging on an Android device you might need to enable reverse socket connections on port 4567:
```bash
adb reverse tcp:4567 tcp:4567
```
### Enable tracesshadow-cljs
```clojure
:compiler-options {:closure-defines {"re_frame.trace.trace_enabled_QMARK_" true}}
```OR
```clojure
:compiler {:closure-defines {"re_frame.trace.trace_enabled_QMARK_" true}}
```### Settings
External window dimensions
```clojure
(re-frisk/enable {:ext_height 1000 :ext_width 1200})
```Hidden UI, you can open and close tool by Ctrl+H
```clojure
(re-frisk/enable {:hidden true})
```If you don't need to watch events you can disable them
```clojure
(re-frisk/enable {:events? false})
```or exclude specific events
```clojure
(re-frisk/enable {:ignore-events #{::timer-db}})
```Using custom IP or port
```clojure
(re-frisk-remote/enable {:host "192.168.0.2:7890"})(re-frisk-remote/start {"7890"})
```Normalize app-db before send to re-frisk
```clojure
(re-frisk-remote/enable {:normalize-db-fn (fn [app-db] (reduce ...))})
```### bonus re-frame 6-domino cascade
[](
https://docs.google.com/drawings/d/1ptKAIPfb_gtwwSqYmt-JGTkwPVm_6LeWjjm-FcWznBs/edit?usp=sharing)