Interface with LocalStorage in Elm.
$ npm install --save elm-local-storage-ports
2. In elm-package.json
, import Ports/LocalStorage.elm
Add node_modules/elm-local-storage-ports/lib/elm
to your source-directories
:
// elm-package.json
{
// ...
"source-directories": [
"../../node_modules/elm-local-storage-ports/lib/elm", // Exact path to node_modules may be different for you
"./"
],
// ...
}
type Msg
= SaveSearch String
| RequestLastSearch
| ReceiveFromLocalStorage (String, Json.Decode.Value)
subscriptions : Model -> Sub Msg
subscriptions model =
Ports.LocalStorage.storageGetItemResponse ReceiveFromLocalStorage
update : Msg -> Model -> (Model, Cmd Msg)
update msg model =
case msg of
SaveSearch searchQuery ->
( model
, Ports.LocalStorage.storageSetItem ("lastSearch", Json.Encode.string searchQuery)
)
RequestLastSearch ->
(model, Ports.LocalStorage.storageGetItem "lastSearch")
ReceiveFromLocalStorage ("lastSearch", value) ->
case JD.decodeValue JD.string value of
Ok searchQuery ->
-- Do something with searchQuery
Using Elm Router
var localStoragePorts = require('elm-local-storage-ports');
elmRouter.start(Elm, [localStoragePorts]);
var localStoragePorts = require("elm-local-storage-ports");
var myElmApp = Elm.MyElmApp.embed(document.getElementById("my-elm-app-container"));
localStoragePorts.register(myElmApp.ports);
View the full API reference here.
Feel free to create an issue in the GitHub issue tracker.