Skip to content

Instantly share code, notes, and snippets.

@evancz
Created September 22, 2016 01:22
Show Gist options
  • Star 35 You must be signed in to star a gist
  • Fork 3 You must be signed in to fork a gist
  • Save evancz/e69723b23958e69b63d5b5502b0edf90 to your computer and use it in GitHub Desktop.
Save evancz/e69723b23958e69b63d5b5502b0edf90 to your computer and use it in GitHub Desktop.
elm-make Spelling.elm --output=spelling.js
<div id="spelling"></div>
<script src="spelling.js"></script>
<script>
var app = Elm.Spelling.fullscreen();
app.ports.check.subscribe(function(word) {
var suggestions = spellCheck(word);
app.ports.suggestions.send(suggestions);
});
function spellCheck(word) {
// have a real implementation!
return [];
}
</script>
port module Spelling exposing (..)
import Html exposing (..)
import Html.App as App
import Html.Attributes exposing (..)
import Html.Events exposing (..)
import String
main =
App.program
{ init = init
, view = view
, update = update
, subscriptions = subscriptions
}
-- MODEL
type alias Model =
{ word : String
, suggestions : List String
}
init : (Model, Cmd Msg)
init =
(Model "" [], Cmd.none)
-- UPDATE
type Msg
= Change String
| Check
| Suggest (List String)
port check : String -> Cmd msg
update : Msg -> Model -> (Model, Cmd Msg)
update msg model =
case msg of
Change newWord ->
( Model newWord [], Cmd.none )
Check ->
( model, check model.word )
Suggest newSuggestions ->
( Model model.word newSuggestions, Cmd.none )
-- SUBSCRIPTIONS
port suggestions : (List String -> msg) -> Sub msg
subscriptions : Model -> Sub Msg
subscriptions model =
suggestions Suggest
-- VIEW
view : Model -> Html Msg
view model =
div []
[ input [ onInput Change ] []
, button [ onClick Check ] [ text "Check" ]
, div [] [ text (String.join ", " model.suggestions) ]
]
@groteck
Copy link

groteck commented Feb 21, 2017

I did some fixes on my fork for elm 0.18 https://gist.github.com/groteck/e4cc180ac182436f31f1d709466df768

@jphedley
Copy link

Note: no word goes through port in this form, which I noticed by including a console.log(word) side effect in app.ports.check.subscribe callback. To send word across port, change update to
Check-> ( model, (check model.word) )
so check port function is called.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment