A clojure tool to navigate through your data.
Project description
portal
A clojure tool to navigate through your data.
The portal UI can be used to inspect values of various shapes and sizes. The UX will probably evolve over time and user feedback is welcome!
For an in-depth explanation of the UI, you can jump to the UI docs.
Demo
To get an overview of the Portal UI and workflow, checkout the following recording of a live demo I gave for London Clojurians.
More video presentations on Portal can be found here.
Usage
To start a repl with portal, run the clojure >= 1.10.0 cli with:
clj -Sdeps '{:deps {djblue/portal {:mvn/version "0.63.1"}}}'
or for a web clojurescript >= 1.10.773 repl, do:
clj -Sdeps '{:deps {djblue/portal {:mvn/version "0.63.1"}
org.clojure/clojurescript {:mvn/version "1.10.844"}}}' \
-m cljs.main
or for a node clojurescript >= 1.10.773 repl, do:
clj -Sdeps '{:deps {djblue/portal {:mvn/version "0.63.1"}
org.clojure/clojurescript {:mvn/version "1.10.844"}}}' \
-m cljs.main -re node
or for a babashka >=0.2.4 repl, do:
bb -Sdeps '{:deps {djblue/portal {:mvn/version "0.63.1"}}}'
or for a lein project.clj, add:
{:profiles {:dev {:dependencies [[djblue/portal "0.63.1"]]}}}
or as a global profile, add to ~/.lein/profiles.clj:
{:portal {:dependencies [[djblue/portal "0.63.1"]]}}
[!NOTE] If you add Portal to a profile other than
:dev, when starting a REPL start it withwith-profiles +portal. The+is important.
or for Clojure CLR, checkout this example project,
or for examples on how to integrate portal into an existing project, look through the examples directory.
[!NOTE] Portal can also be used without a runtime via the standalone version.
API
Try the portal api with the following commands:
;; for node and jvm
(require '[portal.api :as p])
;; for web
;; NOTE: you might need to enable popups for the portal ui to work in the
;; browser.
(require '[portal.web :as p])
(def p (p/open)) ; Open a new inspector
;; or with an extension installed, do:
(def p (p/open {:launcher :vs-code})) ; jvm / node only
(def p (p/open {:launcher :intellij})) ; jvm / node only
(add-tap #'p/submit) ; Add portal as a tap> target
(tap> :hello) ; Start tapping out values
(p/clear) ; Clear all values
(tap> :world) ; Tap out more values
(prn @p) ; bring selected value back into repl
(remove-tap #'p/submit) ; Remove portal from tap> targetset
(p/close) ; Close the inspector when done
(p/docs) ; View docs locally via Portal - jvm / node only
[!WARNING] Portal will keep objects from being garbage collected until they are cleared from the UI.
Options
Options for portal.api/open:
| Option | Description | Default | Spec |
|---|---|---|---|
:window-title |
Custom window title for UI | "portal" | string? |
:theme |
Default theme for UI | :portal.colors/nord | |
:value |
Root value of UI | (atom (list)) | |
:app |
Launch UI in Chrome app window | true | boolean? |
:launcher |
Launch UI using this editor | #{:vs-code :intellij :emacs} | |
:editor |
Enable editor commands, but use separate UI | #{:vs-code :intellij :emacs} | |
:port |
Http server port for UI | 0 | int? |
:host |
Http server host for UI | "localhost" | string? |
For more documentation, take a look through the docs.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file djblue_portal-0.63.1.tar.gz.
File metadata
- Download URL: djblue_portal-0.63.1.tar.gz
- Upload date:
- Size: 1.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.3 CPython/3.13.12 Linux/6.14.0-1017-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9058651addcf23bf24cecde15ec77889ace7d520303c8aa6746f140c63a4ef1f
|
|
| MD5 |
6a2d4d3205e8c2cd982f8ee2a040a89b
|
|
| BLAKE2b-256 |
a627bdf7724283a5a74f6734bcf2a5d8210b233c714d1fb98611c0dc8d569136
|
File details
Details for the file djblue_portal-0.63.1-py3-none-any.whl.
File metadata
- Download URL: djblue_portal-0.63.1-py3-none-any.whl
- Upload date:
- Size: 2.0 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.3 CPython/3.13.12 Linux/6.14.0-1017-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6280b5dc2b25b2f30fabf52b95d3f9071fe67954865d7269fe824fae4a975c26
|
|
| MD5 |
afb9dbca4625ccf50e36caad8714f70d
|
|
| BLAKE2b-256 |
4d3970857fd1cad8ca445e0c0eaf18d583dce472c67a4419fdd33dd8b55e1afb
|