Skip to content

Commit

Permalink
Update to Mafs 0.16.0, document components (#17)
Browse files Browse the repository at this point in the history
  • Loading branch information
sritchie committed Jun 8, 2023
1 parent cb9e0d6 commit 60a074e
Show file tree
Hide file tree
Showing 19 changed files with 852 additions and 320 deletions.
26 changes: 26 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,32 @@

## [unreleased]

## [0.3.0]

- #17:

- Upgrades Mafs to 0.17.0 (see the [Mafs CHANGELOG entry
here](https://github.com/stevenpetryk/mafs/blob/main/CHANGELOG.md#0170))

- Adds `mafs.core/Polyline` and `mafs.plot/Inequality`.

- `mafs.core/Mafs` now supports an `:on-click` handler.

- `mafs.vector` and `mafs.matrix` are now `cljc` files, so that projects like
[Emmy-Viewers](https://github.com/mentat-collective/emmy-viewers) can
construct Mafs-style vectors and matrices on the JVM.

- Removes the former `defcomponent` macro in favor of explicit `defn`s. This
makes the project compatible with [Portal](https://github.com/djblue/portal)
and other libraries that need to load cljs files via
[SCI](https://github.com/babashka/sci).

- Upgrades our `reagent` dependency to 1.2.0, and upgrades Clerk for the docs
site build to the latest `main`.

- All components are now well-documented!


## [0.2.1]

- #14:
Expand Down
2 changes: 1 addition & 1 deletion build.clj
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
;; ## Variables

(def lib 'org.mentat/mafs.cljs)
(def version "0.2.1")
(def version "0.3.0")
(def pom-deps
{'org.babashka/sci
{:mvn/version "0.6.37"
Expand Down
10 changes: 5 additions & 5 deletions deps.edn
Original file line number Diff line number Diff line change
@@ -1,23 +1,23 @@
{:paths ["src" "resources"]
:deps {reagent/reagent {:mvn/version "1.1.1"}}
:deps {reagent/reagent {:mvn/version "1.2.0"}}

:aliases
{:nextjournal/clerk
{:extra-paths ["dev"]
:extra-deps
{org.clojure/clojure {:mvn/version "1.11.1"}
org.clojure/clojurescript {:mvn/version "1.11.60"}
org.mentat/clerk-utils {:mvn/version "0.4.1"}
org.mentat/clerk-utils {:mvn/version "0.5.1"}

io.github.nextjournal/clerk
{:git/sha "fad499407d979916d21b33cc7e46e73f7a485e37"}
{:git/sha "1f6c5331418aaf9c5a4335fc2e6e95f07dc3af6b"}
io.github.nextjournal/clerk.render
{:git/url "https://github.com/nextjournal/clerk"
:git/sha "fad499407d979916d21b33cc7e46e73f7a485e37"
:git/sha "1f6c5331418aaf9c5a4335fc2e6e95f07dc3af6b"
:deps/root "render"}}
:exec-fn user/build!}

:build
{:deps {io.github.clojure/tools.build {:git/tag "v0.8.2" :git/sha "ba1a2bf"}
{:deps {io.github.clojure/tools.build {:git/tag "v0.9.4" :git/sha "76b78fe"}
slipset/deps-deploy {:mvn/version "0.2.0"}}
:ns-default build}}}
104 changes: 73 additions & 31 deletions dev/mafs/notebook.clj
Original file line number Diff line number Diff line change
@@ -1,17 +1,16 @@
^#:nextjournal.clerk
{:toc true
:no-cache true
:visibility :hide-ns}
^{:nextjournal.clerk/visibility {:code :hide}}
(ns mafs.notebook
#:nextjournal.clerk
{:toc true :no-cache true}
(:require [mentat.clerk-utils.docs :as docs]
[mentat.clerk-utils.show :refer [show-sci]]
[nextjournal.clerk :as clerk]))

^{::clerk/visibility {:code :hide :result :hide}}
(clerk/eval-cljs
;; These aliases only apply inside this namespace.
'(require '[mafs.core :as mafs])
'(require '[reagent.core :as reagent]))
'(do (require '[mafs.core :as mafs])
(require '[reagent.core :as reagent])))

;; # Mafs.cljs
;;
Expand Down Expand Up @@ -58,9 +57,8 @@
:xy
(let [[ax ay] @!point]
(fn [[x y]]
(js/Array.
(- (- y ay) (- x ax))
(- (- (- x ax)) (- y ay)))))
[(- (- y ay) (- x ax))
(- (- (- x ax)) (- y ay))]))
:xy-opacity
(fn [[x y]]
(/ (+ (Math/abs x) (Math/abs y))
Expand Down Expand Up @@ -108,9 +106,9 @@

;; ```clj
;; (mentat.clerk-utils.css/set-css!
;; "https://unpkg.com/mafs@0.15.2/core.css"
;; "https://unpkg.com/mafs@0.17.0/core.css"
;; "https://unpkg.com/[email protected]/cmu-serif.css"
;; "https://unpkg.com/mafs@0.15.2/font.css")
;; "https://unpkg.com/mafs@0.17.0/font.css")
;; ```
;;
;; Otherwise find some way to load these CSS files in your project's header.
Expand Down Expand Up @@ -569,9 +567,26 @@ clojure -Sdeps '{:deps {io.github.mentat-collective/mafs.cljs {:git/sha \"%s\"}}
:stroke-style "dashed"}]
[mafs/Polygon
{:points [@!c a b]
:color (:blue mafs/Theme)}]
:color :blue}]
[mafs/MovablePoint {:atom !c}]]))

;; A Polyline is a polygon that doesn't connect its first and last points.

^{::clerk/width :wide}
(show-sci
(reagent/with-let
[a [-2 -2]
!bc (reagent/atom {:b [-1 1] :c [1 -1]})
d [2 2]]
[mafs/Mafs
[mafs.coordinates/Cartesian]
[mafs/Polyline
(let [{:keys [b c]} @!bc]
{:points [a b c d]
:color :blue})]
[mafs/MovablePoint {:atom !bc :path :b}]
[mafs/MovablePoint {:atom !bc :path :c}]]))

;; ### Circle

;; Circles take a center vector and a radius.
Expand Down Expand Up @@ -632,14 +647,14 @@ clojure -Sdeps '{:deps {io.github.mentat-collective/mafs.cljs {:git/sha \"%s\"}}
:constrain "vertical"}]]
[mafs/MovablePoint {:atom !state
:path :rotate
:color (:blue mafs/Theme)
:color :blue
;; Constrain this point to only move in a circle
:constrain
(fn [p]
(mafs.vec/with-mag p 3))}]]
[mafs/MovablePoint {:atom !state
:path :translate
:color (:orange mafs/Theme)}]]))
:color :orange}]]))

;; ### Plot

Expand All @@ -655,8 +670,40 @@ clojure -Sdeps '{:deps {io.github.mentat-collective/mafs.cljs {:git/sha \"%s\"}}

[mafs/Mafs
[mafs.coordinates/Cartesian]
[mafs.plot/OfX {:y Math/sin :color (:blue mafs/Theme)}]
[mafs.plot/OfY {:x sigmoid1 :color (:pink mafs/Theme)}]])
[mafs.plot/OfX {:y Math/sin :color :blue}]
[mafs.plot/OfY {:x sigmoid1 :color :pink}]])

;; #### Inequalities of $x$ and $y$

;; Inequalities represent the region less than or greater than one or two
;; functions. Mafs allows you to plot the region between two functions, or a
;; function and a constant. The inequality can be a function of $x$ or $y$.

;; You cannot provide an `:x` and a `:y` prop to `Inequality` - it will throw a
;; runtime exception. Similarly, you cannot pass conflicting inequality
;; operators — like both `"<"` and `"<="`.

^{::clerk/width :wide}
(show-sci
(reagent/with-let
[!point (reagent/atom [0 -1])]
[mafs/Mafs
[mafs.coordinates/Cartesian]
[mafs.plot/Inequality
{:x (let [[ax ay] @!point]
{:<= (fn [y]
(- (Math/cos (+ y ay)) ax))
:>(fn [y]
(+ (Math/sin (- y ay)) ax))})
:color :blue}]
[mafs.plot/Inequality
{:y (let [[ax ay] @!point]
{:<= (fn [x]
(- (Math/cos (+ x ax)) ay))
:>(fn [x]
(+ (Math/sin (- x ax)) ay))})
:color :pink}]
[mafs/MovablePoint {:atom !point}]]))

;; #### Parametric functions

Expand Down Expand Up @@ -701,9 +748,8 @@ clojure -Sdeps '{:deps {io.github.mentat-collective/mafs.cljs {:git/sha \"%s\"}}
:xy
(let [[ax ay] @!point]
(fn [[x y]]
(js/Array.
(- (- y ay) (- x ax))
(- (- (- x ax)) (- y ay)))))
[(- (- y ay) (- x ax))
(- (- (- x ax)) (- y ay))]))
:xy-opacity
(fn [[x y]]
(/ (+ (Math/abs x) (Math/abs y))
Expand Down Expand Up @@ -825,10 +871,10 @@ clojure -Sdeps '{:deps {io.github.mentat-collective/mafs.cljs {:git/sha \"%s\"}}
[HelloBox]]
[mafs/MovablePoint {:atom !state
:path :scale
:color (:blue mafs/Theme)}]]
:color :blue}]]
[mafs/MovablePoint {:atom !state
:path :rotate
:color (:green mafs/Theme)
:color :green
:constrain mafs.vec/normalize}]]
[mafs/MovablePoint {:atom !state
:path :translate}]]))
Expand Down Expand Up @@ -958,22 +1004,19 @@ clojure -Sdeps '{:deps {io.github.mentat-collective/mafs.cljs {:git/sha \"%s\"}}

;; Beyond constraining horizontally or vertically, points can also be
;; constrained to arbitrary paths. This is done by passing a function to
;; `:constrain`. The function is expected to take a point `[x y], which is where
;; the user is trying to move to, and to return a new point, `[x' y']`, which is
;; where the point should _actually_ go.
;; `:constrain`. The function is expected to take a point `[x y]`, which is
;; where the user is trying to move to, and to return a new point, `[x' y']`,
;; which is where the point should _actually_ go.
;;
;; > Note that for now you'll need to return a `js/Array` instead of a vector.

;; To demonstrate this, imagine constraining a point to "snap" to the nearest
;; whole number point. We take where the user is trying to move to, and round it
;; to the nearest whole number.

;; ```clj
;; [mafs/MovablePoint
;; {:constrain (fn [[x y]]
;; (js/Array.
;; (Math/round x)
;; (Math/round y)))}]
;; [(Math/round x)
;; (Math/round y)])}]
;; ```

;; Another common use case is to constrain motion to be circular —
Expand All @@ -982,8 +1025,7 @@ clojure -Sdeps '{:deps {io.github.mentat-collective/mafs.cljs {:git/sha \"%s\"}}
;; ```clj
;; [mafs/MovablePoint
;; {:constrain (fn [point]
;; (clj->js
;; (mafs.vec/with-mag point 1)))}]
;; (mafs.vec/with-mag point 1))}]
;; ```

;; You can also constrain a point to follow a straight line by setting constrain
Expand Down
4 changes: 2 additions & 2 deletions dev/user.clj
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@

(css/set-css!
"https://unpkg.com/[email protected]/cmu-serif.css"
"https://unpkg.com/mafs@0.15.2/core.css"
"https://unpkg.com/mafs@0.15.2/font.css")
"https://unpkg.com/mafs@0.17.0/core.css"
"https://unpkg.com/mafs@0.17.0/font.css")

(def index
"dev/mafs/notebook.clj")
Expand Down
54 changes: 47 additions & 7 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
"d3-require": "1.3.0",
"framer-motion": "6.5.1",
"katex": "0.12.0",
"mafs": "0.15.2",
"mafs": "0.17.0",
"markdown-it": "12.3.2",
"markdown-it-block-image": "0.0.3",
"markdown-it-footnote": "3.0.3",
Expand Down
4 changes: 0 additions & 4 deletions resources/clj-kondo.exports/org.mentat/mafs.cljs/config.edn

This file was deleted.

Loading

0 comments on commit 60a074e

Please sign in to comment.