hvega
Support the creation of Vega-Lite visualizations
in Haskell. This code is released under the BSD3 license.
It is an almost-direct copy of version 2.2.1 of the
Elm Vega library,
which is released under a BSD3 license by Jo Wood of the giCentre at the
City University of London.
Example
let cars =  dataFromUrl "https://vega.github.io/vega-datasets/data/cars.json" []
    enc = encoding
            . position X [ PName "Horsepower", PmType Quantitative ]
            . position Y [ PName "Miles_per_Gallon", PmType Quantitative ]
            . color [ MName "Origin", MmType Nominal ]
    bkg = background "rgba(0, 0, 0, 0.05)"
in toVegaLite [ bkg, cars, mark Circle [], enc [] ]
When viewed with a Vega-Lite aware viewer, the resultant plot is

Documentation
The Elm Vega documentation
can be used as a guide to using this module. The
Vega-Lite Example Gallery has
been converted to an
IHaskell notebook
(unfortunately the plots created by VegaEmbed do not appear
in the notebook when viewed with either GitHub’s viewer or
ipynb viewer).
Differences to Elm Vega
The main changes to version 2.2.1 of
Elm Vega
are:
- 
Replace SpecbyVLSpec(although both are synonyms for the underlying
JSON representation).
 
- 
Add a type for the output of toVegaLite(VegaLite) that is separate fromVLSpec, which is usefull for integration with IHaskell. The JSON
specification is retrieved withfromVL.
 
- 
Take advantage of the lack of backwards compatibality requirements to remove or
replace several symbols (such as add the Utcconstructor toTimeUnit, remove thebinfunction, and useDatarather than(VLProperty, VLSpec)in function
signatures).