Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alandipert/storage-atom
ClojureScript atoms backed by HTML5 web storage.
https://github.com/alandipert/storage-atom
Last synced: 7 days ago
JSON representation
ClojureScript atoms backed by HTML5 web storage.
- Host: GitHub
- URL: https://github.com/alandipert/storage-atom
- Owner: alandipert
- Created: 2013-01-26T06:17:25.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2022-10-28T09:07:52.000Z (about 2 years ago)
- Last Synced: 2025-01-01T12:06:17.096Z (14 days ago)
- Language: Clojure
- Size: 36.1 KB
- Stars: 192
- Watchers: 9
- Forks: 19
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-clojurescript - storage-atom
README
# storage-atom
storage-atom is a
[ClojureScript](https://github.com/clojure/clojurescript) library that
provides an easy way to create atoms backed by
[HTML5 Web Storage](http://en.wikipedia.org/wiki/Web_storage).Any change in the atom will be saved into the web storage.
The reverse is also true. This means that an atom modified in a tab
or a window will also be modified in all of them.[![Build Status](https://travis-ci.org/alandipert/storage-atom.png?branch=master)](https://travis-ci.org/alandipert/storage-atom)
## Usage
### Dependency
```clojure
[alandipert/storage-atom "1.2.4"]
```Or, to try the latest version that uses [Transit](https://github.com/cognitect/transit-cljs):
```clojure
[alandipert/storage-atom "2.0.1"]
```### Example
```clojure
;; Require or use alandipert.storage-atom in your namespace.
;; The primary functions it provides are html-storage, session-storage and local-storage.
;; It also provides the IStorageBackend protocol.(ns your-ns
(:require [alandipert.storage-atom :refer [local-storage]]));; Persist atom to HTML localStorage. The local-storage function takes an
;; atom and a key to store with, and returns the atom. If the key in storage
;; isn't set it will be initialized with the value obtained by dereferencing
;; the provided atom. Otherwise the atom's value will be reset! with the value
;; obtained from localStorage. All subsequent swap! and reset! operations on
;; the atom will cause the value in localStorage to be updated.(def prefs (local-storage (atom {}) :prefs))
;; You can use the atom normally now - values are transparently persisted.
(add-watch prefs
:new
(fn [_ _ _ v]
(.log js/console "new preference" v)))(swap! prefs assoc :bg-color "red")
(:bg-color @prefs) ;=> "red"
;; Check that current value has been stored in localStorage.
(.getItem js/localStorage ":prefs") ;=> "{:bg-color \"red\"}"
;; To remove an item or clear all storage, use the provided methods instead
;; of calling the js method. This ensures that affected atoms are updated.(alandipert.storage-atom/remove-local-storage! :prefs) ;; remove single value
(alandipert.storage-atom/clear-local-storage!) ;; clear all values;; Note: clearing a value will reset it to the initial value of the atom passed
;; to `local-storage`, not nil. This is probably what you want.
```## Notes
Because web storage keys and values are stored as strings, only values
that can be printed readably may be used as storage keys or values.I haven't done any performance testing, but this approach is much
slower than using web storage directly because the entire atom contents
are written on every `swap!`.To prevent superfluous writes to the local storage, there is a 10 ms
debounce (when a bunch of changes happen quickly, the *last* value is
committed). It can be modified with the `storage-delay` atom or the
`*storage-delay*` dynamic var. :```clj
(reset! alandipert.storage-atom/storage-delay 100) ;; permanently
;; increase
;; debounce to 100
;; ms(binding [alandipert.storage-atom/*storage-delay* 500]
... do some stuff ... ) ;; temporarily increase debounce to
;; 500 ms```
[enduro](https://github.com/alandipert/enduro) is a Clojure library
that provides similar functionality by using files or a database for
storage.The cross-window propagation doesn't always work if browsing the
`.html` directly instead of passing throught a webserver.
(Yes Chrome, I'm looking at you...)## Testing
[PhantomJS](http://phantomjs.org/) 1.7.0 is used for unit testing.
With it installed, you can run the tests like so:boot test-cljs
## License
Copyright © Alan Dipert & Contributors
Distributed under the Eclipse Public License, the same as Clojure.