Icaro Motta 7948582e46
Account selection: Implement features related to editing shared addresses (#19177)
* Fix schema error

* Implement feature to edit shared addresses

* fix: show tokens when sharing all future addresses toggled

* fix: eligibility not checked when toggling all addresses

* Revert "fix: show tokens when sharing all future addresses toggled"

This reverts commit 8443a3432e1ea69cd692caf51db03324b64fccda.

* fix: don't fetch balances on mount if toggled share all

---------

Co-authored-by: Cristian Lungu <lungucristian95@gmail.com>
2024-03-18 17:07:15 +02:00
..

Schemas

This document will grow to describe how we use Malli in the project and our conventions. It's still early days 🐪

Guidelines

Use var quote #' when aliasing instrumented vars

It is common in this repository to have aliases to vars. For example, view referring to var-internal, or quo.core/button referring to quo.components.buttons.button.view.

If the original var being aliased is instrumented, the alias var MUST var quote the original var. If you don't do this, the aliased var will not be instrumented.

;; bad, view-internal is instrumented, but both aliases don't use a var quote.
(schema.core/=> view-internal ?schema)
(def view (quo.theme/with-theme view-internal))
(def button quo.components.buttons.button.view/button)

;; good
(schema.core/=> view-internal ?schema)
(def view (quo.theme/with-theme #'view-internal))
(def button #'quo.components.buttons.button.view/button)

Prefix schema references with ?

Prefix schema bindings and vars with a question mark ?. This is the naming convention used by malli itself when functions receive instances of schemas and it's an unambiguous way to avoid naming clashes.

;; bad
(def message-type [:enum ...])

(defn view
  [message-type] ; Shadows `message-type` schema
  (do-something message-type))

;; good
(def ?message-type [:enum ...])

(defn view
  [message-type] ; Unambiguous naming strategy
  (do-something message-type))

Define schemas as functions when needed

Malli has many utility functions to manipulate schemas as data, and they will automatically check if the schemas were already defined in the registry.

For schemas we want to conveniently access from the global registry, like :schema.common/theme, they must be registered before Malli tries to use them.

;; bad, will fail if :schema.common/bar is not registered.
(def ^:private ?foo
  (malli.util/select-keys :schema.common/bar [:id :name]))

;; good, execution will be delayed until the schema ?foo is correctly registered.
(defn- ?foo
  []
  (malli.util/select-keys :schema.common/bar [:id :name]))