Commit 1436ec99 authored by Mael NICOLAS's avatar Mael NICOLAS

working on a nea way for the ffi

parent 5bbc4bc6
...@@ -3,3 +3,4 @@ ...@@ -3,3 +3,4 @@
var ReactEcharts = require("echarts-for-react"); var ReactEcharts = require("echarts-for-react");
exports.eChartsClass = ReactEcharts.default; exports.eChartsClass = ReactEcharts.default;
exports.eChartsClass2 = ReactEcharts.default;
module Chart where module Chart
(
histogram2,
histogram
)
where
import Prelude import Prelude
import CSS (Color, white) import CSS (Color, white)
import Data.Maybe (Maybe(..)) import Data.Maybe (Maybe(..))
import Data.Boolean
import React as R import React as R
import React.DOM (p) import React.DOM (p)
import React.DOM.Props (Props, className, unsafeFromPropsArray) import React.DOM.Props (Props, className, unsafeFromPropsArray)
...@@ -62,10 +68,10 @@ type Option = ...@@ -62,10 +68,10 @@ type Option =
, legend :: Maybe Legend , legend :: Maybe Legend
, tooltip :: Maybe Tooltip , tooltip :: Maybe Tooltip
, grid :: Maybe Grid , grid :: Maybe Grid
, xAxis :: Maybe Array XAxis , xAxis :: Maybe XAxis
, yAxis :: Maybe Array YAxis , yAxis :: Maybe YAxis
, series :: Maybe Array Series , series :: Maybe (Array Series)
, dataZoom :: Maybe Array DataZoom , dataZoom :: Maybe (Array DataZoom)
} }
...@@ -102,7 +108,7 @@ type Legend = ...@@ -102,7 +108,7 @@ type Legend =
, selectedMode :: Maybe Boolean , selectedMode :: Maybe Boolean
, inactiveColor :: Maybe Color , inactiveColor :: Maybe Color
, selected :: Maybe String -- object , selected :: Maybe String -- object
, "data" :: Maybe (Array Data) , "data" :: Array Data
} }
type Data = type Data =
...@@ -111,8 +117,6 @@ type Data = ...@@ -111,8 +117,6 @@ type Data =
, textStyle :: Maybe {} , textStyle :: Maybe {}
} }
type SubtextStyle = type SubtextStyle =
{ color :: Color { color :: Color
, fontStyle :: String , fontStyle :: String
...@@ -144,6 +148,7 @@ type XAxis = ...@@ -144,6 +148,7 @@ type XAxis =
, "type" :: String , "type" :: String
, axisTick :: AxisTick , axisTick :: AxisTick
} }
type AxisTick = type AxisTick =
{ {
alignWithLabel :: Boolean alignWithLabel :: Boolean
...@@ -204,13 +209,13 @@ type Rich = {} ...@@ -204,13 +209,13 @@ type Rich = {}
foreign import eChartsClass :: forall props. R.ReactClass props foreign import eChartsClass :: forall props. R.ReactClass props
foreign import eChartsClass' :: forall props. R.ReactClass Option foreign import eChartsClass2 :: R.ReactClass Option
echarts :: forall eff. Array Props -> R.ReactElement echarts :: forall eff. Array Props -> R.ReactElement
echarts p = R.createElementDynamic eChartsClass (unsafeFromPropsArray p) [] echarts p = R.createElementDynamic eChartsClass (unsafeFromPropsArray p) []
echarts' :: forall eff. Option -> R.ReactElement echarts' :: forall eff. Option -> R.ReactElement
echarts' opt = R.createElementDynamic eChartsClass opt [] echarts' opt = R.createElementDynamic eChartsClass2 opt []
-- Props -- Props
...@@ -367,8 +372,8 @@ yAxisIndex = unsafeMkProps "yAxisIndex" ...@@ -367,8 +372,8 @@ yAxisIndex = unsafeMkProps "yAxisIndex"
-- , p'' -- , p''
-- ] -- ]
legend' :: Maybe Legend legend' :: Legend
legend' = Just $ legend' =
{ {
"type": Nothing "type": Nothing
,show: Nothing ,show: Nothing
...@@ -402,33 +407,53 @@ data2 = {name: "Favorites", icon: Nothing, textStyle: Nothing} ...@@ -402,33 +407,53 @@ data2 = {name: "Favorites", icon: Nothing, textStyle: Nothing}
data3 :: Data data3 :: Data
data3 = {name: "All", icon: Nothing, textStyle: Nothing} data3 = {name: "All", icon: Nothing, textStyle: Nothing}
xAxis :: XAxis xAxis' :: XAxis
xAxis = xAxis' =
{ {
"data": [xData1, xData2, xData3]
, "type": "category"
, axisTick: {alignWithLabel: true}
}
xData1 :: Data
xData1 = {name: "Jan", icon: Nothing, textStyle: Nothing}
xData2 :: Data
xData2 = {name: "Feb", icon: Nothing, textStyle: Nothing}
xData3 :: Data
xData3 = {name: "Mar", icon: Nothing, textStyle: Nothing}
yData1 :: YAxis
yData1 =
{
"type": "value"
, name: "Score metric"
, min: 0
, position: "right"
, axisLabel: {formatter: "{value}"}
} }
opt :: Option opt :: Option
opt = opt =
{ {
title: title' title: title'
,legend: legend' ,legend: Just legend'
,tooltip: tooltip' ,tooltip: tooltip'
,grid: grid' ,grid: grid'
,xAxis: xAxis' ,xAxis: Just xAxis'
,yAxis: yAxis' ,yAxis: Just yData1
,series: series' ,series: series'
,dataZoom: dataZoom' ,dataZoom: Just [dz1', dz1', dz2', dz2']
} }
where title' = Nothing where title' = Nothing
tooltip' = Nothing tooltip' = Nothing
grid' = Nothing grid' = Nothing
yAxis' = Nothing
series' = Nothing series' = Nothing
dataZoom' = Nothing dataZoom' = Nothing
histogram' :: R.ReactElement histogram2 :: R.ReactElement
histogram' = echarts [] histogram2 = echarts' opt
histogram :: R.ReactElement histogram :: R.ReactElement
histogram = echarts histogram = echarts
...@@ -461,18 +486,6 @@ type DataZoom = ...@@ -461,18 +486,6 @@ type DataZoom =
} }
-} -}
dataZoom' :: Array DataZoom -> Props
dataZoom' dzs = unsafeMkProps "dataZoom" $ dzToProps <$> dzs
dzToProps :: forall props. DataZoom -> props
dzToProps dz = unsafeFromPropsArray
[ type' dz."type"
, xAxisIndex dz.xAxisIndex
, filterMode dz.filterMode
, start dz.start
, end dz.end
]
dz1' :: DataZoom dz1' :: DataZoom
dz1' = { dz1' = {
"type": "slider" "type": "slider"
......
...@@ -18,7 +18,7 @@ performAction :: forall eff props. PerformAction (dom :: DOM | eff) State props ...@@ -18,7 +18,7 @@ performAction :: forall eff props. PerformAction (dom :: DOM | eff) State props
performAction _ _ _ = pure unit performAction _ _ _ = pure unit
render :: forall props. Render State props Action render :: forall props. Render State props Action
render dispatch _ state _ = [text "Dashboard", histogram] render dispatch _ state _ = [text "Dashboard", histogram2]
layoutDashboard :: forall props eff. Spec (dom :: DOM | eff) State props Action layoutDashboard :: forall props eff. Spec (dom :: DOM | eff) State props Action
layoutDashboard = simpleSpec performAction render layoutDashboard = simpleSpec performAction render
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment