{-# LANGUAGE OverloadedStrings #-}
module Eventlog.HtmlTemplate where
import Data.Aeson (Value, encode)
import Data.Aeson.Text (encodeToLazyText)
import Data.String
import Data.Text (Text, append)
import qualified Data.Text as T
import qualified Data.Text.Lazy.Encoding as T
import qualified Data.Text.Lazy as TL
import Text.Blaze.Html5 as H
import Text.Blaze.Html5.Attributes as A
import Text.Blaze.Html.Renderer.String
import Eventlog.Javascript
import Eventlog.Args
import Eventlog.Types (Header(..))
import Eventlog.VegaTemplate
type VizID = Int
insertJsonData :: Value -> Html
insertJsonData dat = preEscapedToHtml $ T.unlines [
"data_json= " `append` dat' `append` ";"
, "console.log(data_json);" ]
where
dat' = TL.toStrict (T.decodeUtf8 (encode dat))
encloseScript :: VizID -> Text -> Html
encloseScript vid vegaspec = preEscapedToHtml $ T.unlines [
"var yourVlSpec" `append` vidt `append`"= " `append` vegaspec `append` ";"
, "vegaEmbed('#vis" `append` vidt `append` "', yourVlSpec" `append` vidt `append` ")"
, ".then((res) => "
, "res.view"
, ".insert(\"data_json_samples\", data_json.samples)"
, ".insert(\"data_json_traces\", data_json.traces)"
, ".runAsync());" ]
where
vidt = T.pack $ show vid
htmlHeader :: Value -> Args -> Html
htmlHeader dat as =
H.head $ do
H.title "Heap Profile"
meta ! charset "UTF-8"
script $ insertJsonData dat
if not (noIncludejs as)
then do
script $ preEscapedToHtml vegaLite
script $ preEscapedToHtml vega
script $ preEscapedToHtml vegaEmbed
H.style $ preEscapedToHtml milligram
H.style $ preEscapedToHtml normalizecss
else do
script ! src "https://cdn.jsdelivr.net/npm/vega@5.4.0" $ ""
script ! src "https://cdn.jsdelivr.net/npm/vega-lite@3.3.0" $ ""
script ! src "https://cdn.jsdelivr.net/npm/vega-embed@4.2.0" $ ""
link ! rel "stylesheet" ! href "//fonts.googleapis.com/css?family=Roboto:300,300italic,700,700italic"
link ! rel "stylesheet" ! href "//cdn.rawgit.com/necolas/normalize.css/master/normalize.css"
link ! rel "stylesheet" ! href "//cdn.rawgit.com/milligram/milligram/master/dist/milligram.min.css"
H.style $ preEscapedToHtml stylesheet
template :: Header -> Value -> Args -> Html
template header' dat as = docTypeHtml $ do
htmlHeader dat as
body $ H.div ! class_ "container" $ do
H.div ! class_ "tabcontent" $ do
h1 $ a ! href "https://mpickering.github.io/eventlog2html" $ "eventlog2html"
code $ toHtml $ hJob header'
button ! class_ "tablink button-black" ! onclick "changeTab('areachart', this)" ! A.id "defaultOpen" $ "Area Chart"
button ! class_ "tablink button-black" ! onclick "changeTab('normalizedchart', this)" $ "Normalized"
button ! class_ "tablink button-black" ! onclick "changeTab('streamgraph', this)" $ "Streamgraph"
button ! class_ "tablink button-black" ! onclick "changeTab('linechart', this)" $ "Linechart"
mapM_ (\(vid, chartname, conf) ->
H.div ! A.id chartname ! class_ "tabviz" $ do
renderChart vid
(TL.toStrict (encodeToLazyText (vegaJson (htmlConf as conf)))))
[(1, "areachart", AreaChart Stacked)
,(2, "normalizedchart", AreaChart Normalized)
,(3, "streamgraph", AreaChart StreamGraph)
,(4, "linechart", LineChart)]
script $ preEscapedToHtml tablogic
htmlConf :: Args -> ChartType -> ChartConfig
htmlConf as = ChartConfig 1200 1000 (not (noTraces as)) (userColourScheme as)
renderChart :: VizID -> Text -> Html
renderChart vid vegaSpec = do
H.div ! A.id (fromString $ "vis" ++ show vid) ! class_ "chart" $ ""
script ! type_ "text/javascript" $ do
(encloseScript vid vegaSpec)
renderChartWithJson :: Int -> Value -> Text -> Html
renderChartWithJson k dat vegaSpec = do
script $ insertJsonData dat
renderChart k vegaSpec
templateString :: Header -> Value -> Args -> String
templateString header' dat as =
renderHtml $ template header' dat as