# Shpadoinkle Html
[![Goldwater](https://gitlab.com/fresheyeball/Shpadoinkle/badges/master/pipeline.svg)](https://gitlab.com/fresheyeball/Shpadoinkle)
[![Haddock](https://img.shields.io/badge/haddock-master-informational)](https://shpadoinkle.org/html)
[![BSD-3](https://img.shields.io/badge/License-BSD%203--Clause-blue.svg)](https://opensource.org/licenses/BSD-3-Clause)
[![built with nix](https://img.shields.io/badge/built%20with-nix-41439a)](https://builtwithnix.org)
[![Hackage](https://img.shields.io/hackage/v/Shpadoinkle-html.svg)](https://hackage.haskell.org/package/Shpadoinkle-html)
[![Hackage Deps](https://img.shields.io/hackage-deps/v/Shpadoinkle-html.svg)](http://packdeps.haskellers.com/reverse/Shpadoinkle-html)
[![Hackage CI](https://matrix.hackage.haskell.org/api/v2/packages/Shpadoinkle-html/badge)](https://matrix.hackage.haskell.org/#/package/Shpadoinkle-html)
This module provides named functions for generating Html, and other browser utilities.
For example, instead of writing:
```haskell
view = h "div" [ ("class", PText "foo") ]
[ h "span" [] [ text "hi there" ] ]
```
You can write:
```haskell
view = div "foo" [ span_ [ "hi there" ] ]
```
which is a bit nicer, and eleminates the risk of typeos in tag names. It also
provies some nice `IsString` instances for ergonomics.
## Keyboard
This module provides pattern synonyms for common key codes. For example:
```haskell
div [ onKeyup $ \case
Enter -> fireLazors
UpArrow -> jump
DownArrow -> crouch
LeftArrow -> move -1
RightArrow -> move 1
]
```
which is a bit nicer, and harder to get wrong than using magic int's to
identify keys.
## Browser utilities
We provide high-level APIs to lower-level browser APIs. Including:
- Local Storage
I know it's just one right now.
But this is the place to contribute more. Such as:
- Scroll Position
- XHR Requests
- Visibility API
- Notifications
- ect...