miso

A tasty Haskell front-end framework

Miso Slack Hackage Haskell Hackage LICENSE Miso Hydra IRC #haskell-miso

**Miso** is a small "[isomorphic](http://nerds.airbnb.com/isomorphic-javascript-future-web-apps/)" [Haskell](https://www.haskell.org/) front-end framework featuring a virtual-dom, diffing / patching algorithm, event delegation, event batching, SVG, Server-sent events, Websockets, and an extensible Subscription-based subsystem. Inspired by [Elm](http://elm-lang.org/), [Redux](http://redux.js.org/) and [Bobril](http://github.com/bobris/bobril). `IO` and other effects (like `XHR`) can be introduced into the system via the `Effect` data type. Miso makes heavy use of the [GHCJS](https://github.com/ghcjs/ghcjs) FFI and therefore has minimal dependencies. ## Examples - TodoMVC - [Link](https://todo-mvc.haskell-miso.org/) - [Source](https://github.com/dmjio/miso/blob/master/examples/todo-mvc/Main.hs) - Mario - [Link](https://mario.haskell-miso.org/) - [Source](https://github.com/dmjio/miso/blob/master/examples/mario/Main.hs) - Websocket - [Link](https://websocket.haskell-miso.org/) - [Source](https://github.com/dmjio/miso/blob/master/examples/websocket/Main.hs) - SVG - [Link](https://svg.haskell-miso.org/) - Simple - [Link](https://simple.haskell-miso.org/) - [Source](https://github.com/dmjio/miso/blob/master/exe/Main.hs) ## Haddocks - [GHCJS](https://haddocks.haskell-miso.org/) - [GHC](http://hackage.haskell.org/package/miso) ## Getting Started ```haskell {-# LANGUAGE RecordWildCards #-} module Main where import Miso type Model = Int main :: IO () main = startApp App {..} where model = 0 update = updateModel view = viewModel events = defaultEvents subs = [] updateModel :: Action -> Model -> Effect Model Action updateModel AddOne m = noEff (m + 1) updateModel SubtractOne m = noEff (m - 1) data Action = AddOne | SubtractOne deriving (Show, Eq) viewModel :: Model -> View Action viewModel x = div_ [] [ button_ [ onClick AddOne ] [ text "+" ] , text (show x) , button_ [ onClick SubtractOne ] [ text "-" ] ] ```