inst/shiny/src/serial/serial_server.R

output$serial1 <- renderAmCharts({
  ##Data
  data <- as.data.table(get('Titanic', 'package:datasets'))
  data <- data[, .(freq = sum(N)), by = list(Sex, Survived)]
  (data <- split(data, f = data$Survived))
  setkey(data$Yes, Sex)
  setkey(data$No, Sex)
  (dp <- data$Yes[data$No])
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'Sex', startDuration = 0,
                  dataProvider = dp),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'freq', fillAlphas = .8, lineAlpha = .2, title = 'Yes'),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'i.freq', fillAlphas = .8, lineAlpha = .2, title = 'No'),
    addValueAxis(stackType = '100%'),
    addTitle(text = 'Survivors to Titanic'),
    setLegend(useGraphSettings = TRUE),
    setProperties(theme = input$theme)
  )
})

output$code_serial1 <- renderText({
  "
  ##Data
  data <- as.data.table(get('Titanic', 'package:datasets'))
  data <- data[, .(freq = sum(N)), by = list(Survived, Sex)]
  (data <- split(data, f = data$Sex))
  setkey(data$Male, Survived)
  setkey(data$Female, Survived)
  (dp <- data$Male[data$Female])
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'Survived', startDuration = 0,
                  dataProvider = dp),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'freq', fillAlphas = .8, lineAlpha = .2, title = 'Male'),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'i.freq', fillAlphas = .8, lineAlpha = .2, title = 'Female'),
    addValueAxis(stackType = '100%'),
    setTitle(text = 'Survivors to Titanic'),
    setLegend(useGraphSettings = TRUE)
  )
  "
})

output$serial2 <- renderAmCharts({
  ##Data
  dp <- data.table(year  =  c(2010, 2011, 2012, 2013, 2014),
                   income  =  c(20.4, 20.6, 24.3, 21.5, 22.3), 
                   expenses  =  c(31.5, 32.4, 25.6, 22.6, 24.9),
                   dashLengthColumn = c(NA, NA, NA, NA, 5), 
                   alpha = c(NA, NA, NA, NA, 0.2),
                   additional = c('', '', '', '', '(projection)'))
  
  balloonText <- paste('<span style = \'font-size:12px;\'>[[title]] in [[category]]:',
                       '<br><span style = \'font-size:20px;\'>[[value]]</span> [[additional]]</span>')
  ##Plot
  pipeR::pipeline(
    amSerialChart(addClassNames = TRUE, autoMargins = FALSE,
                  dataProvider = dp, marginLeft = 30, marginRight = 8,
                  marginTop = 10, marginBottom = 26, startDuration = 1,
                  categoryField = 'year', startDuration = 0),
    setBalloon(adjustBorderColor = FALSE, horizontalPadding = 10,
               verticalPadding = 8, color = '#ffffff'),
    addValueAxis(axisAlpha = 0, position = 'left'),
    addGraph(alphaField = 'alpha', fillAlphas = 1, title = 'Income',
             balloonText = balloonText, 
             type = 'column', valueField = 'income',
             dashLengthField = 'dashLengthColumn'),
    addGraph(id = 'graph2', bullet = 'round', lineThickness = 3,
             bulletSize = 7, bulletBorderAlpha = 1, bulletColor = '#FFFFFF',
             useLineColorForBulletBorder = TRUE, bulletBorderThickness = 3, 
             fillAlphas = 0, lineAlpha = 1, title = 'Expenses', valueField = 'expenses',
             balloonText = balloonText),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, tickLength = 0)
  )
})

output$code_serial2 <- renderText({
  "
  ##Data
  dp <- data.table(year  =  c(2010, 2011, 2012, 2013, 2014),
                   income  =  c(20.4, 20.6, 24.3, 21.5, 22.3), 
                   expenses  =  c(31.5, 32.4, 25.6, 22.6, 24.9),
                   dashLengthColumn = c(NA, NA, NA, NA, 5), 
                   alpha = c(NA, NA, NA, NA, 0.2),
                   additional = c('', '', '', '', '(projection)'))
  
  balloonText <- paste('<span style = \'font-size:12px;\'>[[title]] in [[category]]:',
                       '<br><span style = \'font-size:20px;\'>[[value]]</span> [[additional]]</span>')
  ##Plot
  pipeR::pipeline(
    amSerialChart(addClassNames = TRUE, autoMargins = FALSE,
                  dataProvider = dp, marginLeft = 30, marginRight = 8,
                  marginTop = 10, marginBottom = 26, startDuration = 1,
                  categoryField = 'year', startDuration = 0),
    setBalloon(adjustBorderColor = FALSE, horizontalPadding = 10,
               verticalPadding = 8, color = '#ffffff'),
    addValueAxis(axisAlpha = 0, position = 'left'),
    addGraph(alphaField = 'alpha', fillAlphas = 1, title = 'Income',
             balloonText = balloonText, 
             type = 'column', valueField = 'income',
             dashLengthField = 'dashLengthColumn'),
    addGraph(id = 'graph2', bullet = 'round', lineThickness = 3,
             bulletSize = 7, bulletBorderAlpha = 1, bulletColor = '#FFFFFF',
             useLineColorForBulletBorder = TRUE, bulletBorderThickness = 3, 
             fillAlphas = 0, lineAlpha = 1, title = 'Expenses', valueField = 'expenses',
             balloonText = balloonText),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, tickLength = 0)
  )
  "
})

output$serial3 <- renderAmCharts({
  ##Data
  dp <- data.table(
    country = c('USA', 'China', 'Japan', 'Germany', 'UK', 'France',
                'India', 'Spain', 'Netherlands', 'Russia'), 
    visits = c(3025, 1882, 1809, 1322, 1122, 1114, 984, 711, 665, 580), 
    color = c('#FF0F00', '#FF6600', '#FF9E01', '#FCD202', '#F8FF01',
              '#B0DE09', '#04D215', '#0D8ECF', '#0D52D1', '#2A0CD0')
  )
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'country', dataProvider = dp,
                  depth3D = 40, angle = 30),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', fillColorsField = 'color', 
             fillAlphas = 0.85, lineAlpha = 0.1, type = 'column', valueField = 'visits'),
    setChartCursor(categoryBalloonEnabled = FALSE, cursorAlpha = 0, zoomable = FALSE),
    setCategoryAxis(gridPosition = 'start', labelRotation = 45, axisAlpha = 0, gridAlpha = 0)
  )
})

output$code_serial3 <- renderText({
  "
  ##Data
  dp <- data.table(
    country = c('USA', 'China', 'Japan', 'Germany', 'UK', 'France',
                'India', 'Spain', 'Netherlands', 'Russia'), 
    visits = c(3025, 1882, 1809, 1322, 1122, 1114, 984, 711, 665, 580), 
    color = c('#FF0F00', '#FF6600', '#FF9E01', '#FCD202', '#F8FF01',
              '#B0DE09', '#04D215', '#0D8ECF', '#0D52D1', '#2A0CD0')
  )
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'country', dataProvider = dp,
                  depth3D = 40, angle = 30),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', fillColorsField = 'color', 
             fillAlphas = 0.85, lineAlpha = 0.1, type = 'column', valueField = 'visits'),
    setChartCursor(categoryBalloonEnabled = FALSE, cursorAlpha = 0, zoomable = FALSE),
    setCategoryAxis(gridPosition = 'start', labelRotation = 45, axisAlpha = 0, gridAlpha = 0)
  )
  "
})

output$serial4 <- rAmCharts::renderAmCharts({
  ##Data
  dp <- data.table(year = 1994:2012, 
                   cars = rnorm(length(1994:2012), mean = 10), 
                   motorcycles = rnorm(length(1994:2012), mean = 15), 
                   bicycles = rnorm(length(1994:2012), mean = 20))
  dp <- round(dp)
  
  url_car <- 'http://www.amcharts.com/lib/3/images/car.png'
  url_motorcycle <- 'http://www.amcharts.com/lib/3/images/motorcycle.png'
  url_bicycle <- 'http://www.amcharts.com/lib/3/images/bicycle.png'
  pref <- '<img src = '
  suf <- paste('style = \'vertical-align:bottom;',
               'margin-right: 10px; width:28px; height:21px;\'>',
               '<span style = \'font-size:14px; color:#000000;\'>',
               '<b>[[value]]</b></span>')
  ##Plot
  pipeR::pipeline(
    amSerialChart(marginRight = 30, plotAreaBorderAlpha = 0, categoryField = 'year',
                  startDuration = 0, dataProvider = dp, theme = 'light'),
    setLegend(equalWidths = FALSE, periodValueText = 'total: [[value.sum]]',
              position = 'top', valueAlign = 'left', valueWidth = 100),
    addValueAxis(stackType = 'regular', gridAlpha = 0.07, position = 'left',
                 title = 'Traffic incidents'),
    addGraph(balloonText = paste(pref, url_car, suf), fillAlphas = 0.6,
             hidden = TRUE, lineAlpha = 0.4, title = 'Cars', valueField = 'cars'),
    addGraph(balloonText = paste(pref, url_motorcycle, suf), fillAlphas = 0.6,
             lineAlpha = 0.4, title = 'Motorcycles', valueField = 'motorcycles'),
    addGraph(balloonText = paste(pref, url_bicycle, suf), fillAlphas = 0.6,
             lineAlpha = 0.4, title = 'Bicycles', valueField = 'bicycles'),
    setCategoryAxis(startOnAxis = TRUE, axisColor = '#DADADA', gridAlpha = 0.07),
    addGuide(category = '2001', toCategory = '2003',
             lineColor = '#CC0000', lineAlpha = 1, fillAlpha = 0.2,
             fillColor = '#CC0000', dashLength = 2, inside = TRUE,
             labelRotation = 90, label = 'fines for speeding increased'),
    addGuide(category = '2007', lineColor = '#CC0000', lineAlpha = 1,
             dashLength = 2, inside = TRUE, labelRotation = 90,
             label = 'motorcycle fee introduced'),
    setChartScrollbar(oppositeAxis = FALSE, dragIcon = 'dragIconRectBigBlack'),
    setChartCursor(cursorAlpha = 0)
  )
})

output$code_serial4 <- renderText({
  "
  ##Data
  dp <- data.table(year = 1994:2012, 
                   cars = rnorm(length(1994:2012), mean = 10), 
                   motorcycles = rnorm(length(1994:2012), mean = 15), 
                   bicycles = rnorm(length(1994:2012), mean = 20))
  dp <- round(dp)
  
  url_car <- 'http://www.amcharts.com/lib/3/images/car.png'
  url_motorcycle <- 'http://www.amcharts.com/lib/3/images/motorcycle.png'
  url_bicycle <- 'http://www.amcharts.com/lib/3/images/bicycle.png'
  pref <- '<img src = '
  suf <- paste('style = \'vertical-align:bottom;',
               'margin-right: 10px; width:28px; height:21px;\'>',
               '<span style = \'font-size:14px; color:#000000;\'>',
               '<b>[[value]]</b></span>')
  ##Plot
  pipeR::pipeline(
    amSerialChart(marginRight = 30, plotAreaBorderAlpha = 0, categoryField = 'year',
                  startDuration = 0, dataProvider = dp, theme = 'light'),
    setLegend(equalWidths = FALSE, periodValueText = 'total: [[value.sum]]',
              position = 'top', valueAlign = 'left', valueWidth = 100),
    addValueAxis(stackType = 'regular', gridAlpha = 0.07, position = 'left',
                 title = 'Traffic incidents'),
    addGraph(balloonText = paste(pref, url_car, suf), fillAlphas = 0.6,
             hidden = TRUE, lineAlpha = 0.4, title = 'Cars', valueField = 'cars'),
    addGraph(balloonText = paste(pref, url_motorcycle, suf), fillAlphas = 0.6,
             lineAlpha = 0.4, title = 'Motorcycles', valueField = 'motorcycles'),
    addGraph(balloonText = paste(pref, url_bicycle, suf), fillAlphas = 0.6,
             lineAlpha = 0.4, title = 'Bicycles', valueField = 'bicycles'),
    setCategoryAxis(startOnAxis = TRUE, axisColor = '#DADADA', gridAlpha = 0.07),
    addGuide(category = '2001', toCategory = '2003',
             lineColor = '#CC0000', lineAlpha = 1, fillAlpha = 0.2,
             fillColor = '#CC0000', dashLength = 2, inside = TRUE,
             labelRotation = 90, label = 'fines for speeding increased'),
    addGuide(category = '2007', lineColor = '#CC0000', lineAlpha = 1,
             dashLength = 2, inside = TRUE, labelRotation = 90,
             label = 'motorcycle fee introduced'),
    setChartScrollbar(oppositeAxis = FALSE, dragIcon = 'dragIconRectBigBlack'),
    setChartCursor(cursorAlpha = 0)
  )
  "
})

output$serial5 <- renderAmCharts({
  ##Plot
  pipeR::pipeline(
    amSerialChart(marginTop = 0, marginRight = 80, dataDateFormat = 'YYYY',
                  categoryField = 'year', startDuration = 0),
    setDataProvider(data.frame(year = 1950:2015, value = runif(length(1950:2015), -1, 1))),
    addValueAxes(axisAlpha = 0, position = 'left'),
    addGraph(id = 'g1', balloonText =  '[[category]]<br><b><span style="font-size = 14px;">[[value]]</span></b>',
             bullet = 'round', bulletSize =  8, lineColor =  '#d1655d', lineThickness =  2,
             negativeLineColor =  '#637bb6', type =  'smoothedLine', valueField =  'value'),
    setChartScrollbar(graph = 'g1', gridAlpha = 0, color = '#888888', scrollbarHeight = 55, backgroundAlpha = 0,
                      selectedBackgroundAlpha = 0.1, selectedBackgroundColor = '#888888', graphFillAlpha = 0,
                      autoGridCount = TRUE, selectedGraphFillAlpha = 0, graphLineAlpha = 0.2,
                      graphLineColor = '#c2c2c2', selectedGraphLineColor = '#888888', selectedGraphLineAlpha = 1),
    setChartCursor(categoryBalloonDateFormat = 'YYYY', cursorAlpha = 0, valueLineEnabled =TRUE,
                   valueLineBalloonEnabled =TRUE, valueLineAlpha = 0.5, fullWidth = TRUE),
    setCategoryAxis(minPeriod = 'YYYY', parseDates = TRUE, minorGridAlpha = 0.1, minorGridEnabled = TRUE),
    addListener('rendered', paste('function(event) {',
                                  'event.chart.zoomToIndexes(Math.round(event.chart.dataProvider.length * 0.4),',
                                  'Math.round(event.chart.dataProvider.length * 0.55))',
                                  '}'))
  )
})

output$code_serial5 <- renderText({
  "
  ##Plot
  pipeR::pipeline(
    amSerialChart(marginTop = 0, marginRight = 80, dataDateFormat = 'YYYY',
                  categoryField = 'year'),
    setDataProvider(data.frame(year = 1950:2015, value = runif(length(1950:2015), -1, 1))),
    addValueAxes(axisAlpha = 0, position = 'left'),
    addGraph(id = 'g1', balloonText =  '[[category]]<br><b><span style=\"font-size = 14px;\">[[value]]</span></b>',
             bullet = 'round', bulletSize =  8, lineColor =  '#d1655d', lineThickness =  2,
             negativeLineColor =  '#637bb6', type =  'smoothedLine', valueField =  'value'),
    setChartScrollbar(graph = 'g1', gridAlpha = 0, color = '#888888', scrollbarHeight = 55, backgroundAlpha = 0,
                      selectedBackgroundAlpha = 0.1, selectedBackgroundColor = '#888888', graphFillAlpha = 0,
                      autoGridCount = TRUE, selectedGraphFillAlpha = 0, graphLineAlpha = 0.2,
                      graphLineColor = '#c2c2c2', selectedGraphLineColor = '#888888', selectedGraphLineAlpha = 1),
    setChartCursor(categoryBalloonDateFormat = 'YYYY', cursorAlpha = 0, valueLineEnabled =TRUE,
                   valueLineBalloonEnabled =TRUE, valueLineAlpha = 0.5, fullWidth = TRUE),
    setCategoryAxis(minPeriod = 'YYYY', parseDates = TRUE, minorGridAlpha = 0.1, minorGridEnabled = TRUE),
    addListener('rendered', paste('function(event) {',
                                  'event.chart.zoomToIndexes(Math.round(event.chart.dataProvider.length * 0.4),',
                                  'Math.round(event.chart.dataProvider.length * 0.55))',
                                  '}'))
  )
  "
})

output$serial6 <- renderAmCharts({
  ##Data
  dp <- data.table(binf = c(1, 2, 3, 4, 5),
                   bsup = c(3, 4, 5,6, 7),
                   value = c(2, 3, 4, 5, 6),
                   heure = c('9h', '10h', '11h', '12h', '13h'))
  
  # prepare legend
  legend <- pipeR::pipeline(
    amLegend(equalWidths = FALSE, position = 'bottom', valueAlign = 'left', valueWidth = 100), 
    addListener('hideItem' , paste('function(event){',
                                   'var id = event.dataItem.id;',
                                   'event.chart.hideGraph(event.chart.getGraphById(id + \'_from\'));',
                                   'event.chart.hideGraph(event.chart.getGraphById(id + \'_to\'));',
                                   '}')),
    addListener('showItem' , paste('function(event){',
                                   'var id = event.dataItem.id;',
                                   'event.chart.showGraph(event.chart.getGraphById(id + \'_from\'));',
                                   'event.chart.showGraph(event.chart.getGraphById(id + \'_to\'));',
                                   '}'))
  )
  ##Plot
  pipeR::pipeline(
    amSerialChart(legend = legend, dataProvider = dp, addClassNames=TRUE,
                  autoMargins = TRUE, startDuration = 0.5, categoryField = 'heure'),
    setBalloon(adjustBorderColor = FALSE, horizontalPadding = 10,
               verticalPadding = 8,color = '#ffffff'),
    addValueAxis(axisAlpha = 0, position = 'left'),
    addGraph(id = '2014_from', lineAlpha = 0, valueField = 'binf',
             showBalloon = FALSE, visibleInLegend = FALSE),
    addGraph(id = '2014_to', lineAlpha = 0, fillAlphas = 0.2,
             fillToGraph = '2014_from', valueField = 'bsup', 
             showBalloon = FALSE, visibleInLegend = FALSE),
    addGraph(id = '2014', valueField = 'value', title = 'value'),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, tickLength = 0),
    addTitle(text = 'listeners on legend')
  )
})

output$code_serial6 <- renderText({
  "
  #Data
  dp <- data.table(binf = c(1, 2, 3, 4, 5),
                   bsup = c(3, 4, 5,6, 7),
                   value = c(2, 3, 4, 5, 6),
                   heure = c('9h', '10h', '11h', '12h', '13h'))
  
  # prepare legend
  legend <- pipeR::pipeline(
    amLegend(equalWidths = FALSE, position = 'bottom', valueAlign = 'left', valueWidth = 100), 
    addListener('hideItem' , paste('function(event){',
                                   'var id = event.dataItem.id;',
                                   'event.chart.hideGraph(event.chart.getGraphById(id + \'_from\'));',
                                   'event.chart.hideGraph(event.chart.getGraphById(id + \'_to\'));',
                                   '}')),
    addListener('showItem' , paste('function(event){',
                                   'var id = event.dataItem.id;',
                                   'event.chart.showGraph(event.chart.getGraphById(id + \'_from\'));',
                                   'event.chart.showGraph(event.chart.getGraphById(id + \'_to\'));',
                                   '}'))
  )
  
  ##Plot
  pipeR::pipeline(
    amSerialChart(legend = legend, dataProvider = dp, addClassNames=TRUE,
                  autoMargins = TRUE, startDuration = 0.5, categoryField = 'heure'),
    setBalloon(adjustBorderColor = FALSE, horizontalPadding = 10,
               verticalPadding = 8,color = '#ffffff'),
    addValueAxis(axisAlpha = 0, position = 'left'),
    addGraph(id = '2014_from', lineAlpha = 0, valueField = 'binf',
             showBalloon = FALSE, visibleInLegend = FALSE),
    addGraph(id = '2014_to', lineAlpha = 0, fillAlphas = 0.2,
             fillToGraph = '2014_from', valueField = 'bsup', 
             showBalloon = FALSE, visibleInLegend = FALSE),
    addGraph(id = '2014', valueField = 'value', title = 'value'),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, tickLength = 0),
    addTitle(text = 'listeners on legend')
  )
  "
})

output$serial7 <- renderAmCharts({
  ##Data
  data <- as.data.table(get('Titanic', 'package:datasets'))
  data <- data[, .(freq = sum(N)), by = list(Sex, Survived)]
  (data <- split(data, f = data$Survived))
  setkey(data$Yes, Sex)
  setkey(data$No, Sex)
  (dp <- data$Yes[data$No])
  catAxis <- pipeR::pipeline(
    categoryAxis(gridPosition = 'start'),
    addListener('clickItem', 'function(event) {alert(\'Click on category axis\')}')
  )
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'Sex', startDuration = 0,
                  dataProvider = dp, categoryAxis = catAxis),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'freq', fillAlphas = .8, lineAlpha = .2, title = 'Yes'),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'i.freq', fillAlphas = .8, lineAlpha = .2, title = 'No'),
    addValueAxis(stackType = '100%'),
    addTitle(text = 'Survivors to Titanic'),
    setLegend(useGraphSettings = TRUE)
  )
})

output$code_serial7 <- renderText({
  "
  ##Data
  data <- as.data.table(get('Titanic', 'package:datasets'))
  data <- data[, .(freq = sum(N)), by = list(Sex, Survived)]
  (data <- split(data, f = data$Survived))
  setkey(data$Yes, Sex)
  setkey(data$No, Sex)
  (dp <- data$Yes[data$No])
  catAxis <- pipeR::pipeline(
    categoryAxis(gridPosition = 'start'),
    addListener('clickItem', 'function(event) {alert(\'Click on category axis\')}')
  )
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'Sex', startDuration = 0,
                  dataProvider = dp, categoryAxis = catAxis),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'freq', fillAlphas = .8, lineAlpha = .2, title = 'Yes'),
    addGraph(balloonText = '[[category]]: <b>[[value]]</b>', type = 'column',
             valueField = 'i.freq', fillAlphas = .8, lineAlpha = .2, title = 'No'),
    addValueAxis(stackType = '100%'),
    addTitle(text = 'Survivors to Titanic'),
    setLegend(useGraphSettings = TRUE)
  )
  "
})

output$serial8 <- renderAmCharts({
  ##Data
  dp <- data.table(
    country = c('USA', 'China', 'Japan', 'Germany', 'UK', 'France',
                'India', 'Spain', 'Netherlands', 'Russia'), 
    visits = c(3025, 1882, 1809, 1322, 1122, 1114, 984, 711, 665, 580), 
    color = c('#FF0F00', '#FF6600', '#FF9E01', '#FCD202', '#F8FF01',
              '#B0DE09', '#04D215', '#0D8ECF', '#0D52D1', '#2A0CD0')
  )
  chartCursor_obj <- pipeR::pipeline(
    chartCursor(categoryBalloonEnabled = FALSE, cursorAlpha = 0),
    addListener('zoomed', 'function(event) {alert(\'Zoom to some period\')}')
  )
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'country', dataProvider = dp,
                  chartCursor = chartCursor_obj),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', fillColorsField = 'color', 
             fillAlphas = 0.85, lineAlpha = 0.1, type = 'column', valueField = 'visits'),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, gridAlpha = 0)
  )
})

output$code_serial8 <- renderText({
  "
  ##Data
  dp <- data.table(
    country = c('USA', 'China', 'Japan', 'Germany', 'UK', 'France',
                'India', 'Spain', 'Netherlands', 'Russia'), 
    visits = c(3025, 1882, 1809, 1322, 1122, 1114, 984, 711, 665, 580), 
    color = c('#FF0F00', '#FF6600', '#FF9E01', '#FCD202', '#F8FF01',
              '#B0DE09', '#04D215', '#0D8ECF', '#0D52D1', '#2A0CD0')
  )
  chartCursor_obj <- pipeR::pipeline(
    chartCursor(categoryBalloonEnabled = FALSE, cursorAlpha = 0),
    addListener('zoomed', 'function(event) {alert(\'Zoom to some period\')}')
  )
  ##Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'country', dataProvider = dp,
                  chartCursor = chartCursor_obj),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', fillColorsField = 'color', 
             fillAlphas = 0.85, lineAlpha = 0.1, type = 'column', valueField = 'visits'),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, gridAlpha = 0)
  )
  "
})

output$serial9 <- renderAmCharts({
  ##Data
  dp <- data.table(
    country = c('USA', 'China', 'Japan', 'Germany', 'UK', 'France',
                'India', 'Spain', 'Netherlands', 'Russia'), 
    visits = c(3025, 1882, 1809, 1322, 1122, 1114, 984, 711, 665, 580),
    random = rnorm(10, mean = 2000, sd = 1000),
    color = c('#FF0F00', '#FF6600', '#FF9E01', '#FCD202', '#F8FF01',
              '#B0DE09', '#04D215', '#0D8ECF', '#0D52D1', '#2A0CD0')
  )
  ##Plot
  valueAxis_obj1 <- pipeR::pipeline(
    valueAxis(id = 'v1', title = 'valueAxis 1', position = 'left'),
    addListener('clickItem', 'function(event) {alert(\'Click on valueAxis 1\')}')
  )
  
  valueAxis_obj2 <- pipeR::pipeline(
    valueAxis(id = 'v2', title = 'valueAxis 2', position = 'right'),
    addListener('clickItem', 'function(event) {Shiny.onInputChange(\'mydata\', event.value);}')
  )
  
  # build the chart
  pipeR::pipeline(
    amSerialChart(categoryField = 'country', dataProvider = dp),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', fillColorsField = 'color', valueAxis = 'v1',
             fillAlphas = 0.85, lineAlpha = 0.1, type = 'column', valueField = 'visits'),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', valueAxis = 'v2', fillAlphas = 0,
             fillAlphas = 0.85, lineAlpha = 0.1, bullet = 'round', valueField = 'random',
             lineColor = '#FF6600', lineThickness = 5),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, gridAlpha = 0),
    addValueAxis(valueAxis_obj1),
    addValueAxis(valueAxis_obj2)
  )
})

output$code_serial9 <- renderText({
  "
  ##Data
  dp <- data.table(
    country = c('USA', 'China', 'Japan', 'Germany', 'UK', 'France',
                'India', 'Spain', 'Netherlands', 'Russia'), 
    visits = c(3025, 1882, 1809, 1322, 1122, 1114, 984, 711, 665, 580),
    random = rnorm(10, mean = 2000, sd = 1000),
    color = c('#FF0F00', '#FF6600', '#FF9E01', '#FCD202', '#F8FF01',
              '#B0DE09', '#04D215', '#0D8ECF', '#0D52D1', '#2A0CD0')
  )
  
  # prepare value axes
  valueAxis_obj1 <- pipeR::pipeline(
    valueAxis(id = 'v1', title = 'valueAxis 1', position = 'left'),
    addListener('clickItem', 'function(event) {alert(\'Click on valueAxis 1\')}')
  )
  
  valueAxis_obj2 <- pipeR::pipeline(
    valueAxis(id = 'v2', title = 'valueAxis 2', position = 'right'),
    addListener('clickItem', 'function(event) {Shiny.onInputChange(\'mydata\', event.value);}')
    )
  
  #Plot
  pipeR::pipeline(
    amSerialChart(categoryField = 'country', dataProvider = dp),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', fillColorsField = 'color', valueAxis = 'v1',
             fillAlphas = 0.85, lineAlpha = 0.1, type = 'column', valueField = 'visits'),
    addGraph(balloonText = '<b>[[category]]: [[value]]</b>', valueAxis = 'v2', fillAlphas = 0,
             fillAlphas = 0.85, lineAlpha = 0.1, bullet = 'round', valueField = 'random',
             lineColor = '#FF6600', lineThickness = 5),
    setCategoryAxis(gridPosition = 'start', axisAlpha = 0, gridAlpha = 0),
    addValueAxis(valueAxis_obj1),
    addValueAxis(valueAxis_obj2)
  )
  "
})

output$results <- renderPrint({
  input$mydata
})

# ---
# Candle stick with chartScrollbar zoom
# ---
output$serial10 <- renderAmCharts({
  ##Data
  start <- as.POSIXct('01-01-2015', format = '%d-%m-%Y')
  end <- as.POSIXct('31-12-2015', format = '%d-%m-%Y')
  date <- seq.POSIXt(from = start, to = end, by = 'day')
  date <- format(date, '%m-%d-%Y')
  low <- c() ; open <- c() ; close <- c() ; high <- c() ; median <- c()
  
  n <- 100
  invisible(
    sapply(1:length(date), function(i)
    {
      sample <- rnorm(n, mean = sample(1:10, 1), sd = sample(1:10/10, 1))
      quant <- boxplot(sample, plot = FALSE)$stats
      low <<- c(low, quant[1])
      open <<- c(open, quant[2])
      median <<- c(median, quant[3])
      close <<- c(close, quant[4])
      high <<- c(high, quant[5])
    })
  )
  dp <- data.table(date = date, low = round(low, 2), open = round(open, 2), 
                   close = round(close, 2), high = round(high, 2), median = round(median, 2)) 
  balloonText <- paste('Open:<b>[[open]]</b><br>',
                       'Low:<b>[[low]]</b><br>',
                       'High:<b>[[high]]</b><br>',
                       'Close:<b>[[close]]</b><br>')
  ##Plot
  pipeline(
    amSerialChart(categoryField = 'date', dataDateFormat = 'MM-DD-YYYY',
                  dataProvider = dp, startDuration = 0),
    setCategoryAxis(parseDates = TRUE),
    addGraph(id = 'g1', type = 'candlestick', lineColor = '#7f8da9', lowField = 'low',
             closeField = 'close', highField = 'high', openField = 'open',
             valueField = 'median', balloonText = balloonText, title = 'Price: ',
             lineColor = '#7f8da9', lineAlpha = 1, fillAlphas = 0.9, negativeBase = 5,
             negativeFillColors = '#db4c3c', negativeLineColor = '#db4c3c'),
    setChartCursor(valueLineEnabled = TRUE, valueLineBalloonEnabled = TRUE),
    setChartScrollbar(graph = 'g1', graphType = 'line'),
    addListener("init", paste('function(event) {',
                              'var nbCandles = event.chart.dataProvider.length;',
                              'event.chart.zoomToIndexes(20, 100);',
                              ' }'))
  )
})

output$code_serial10 <- renderText({
  "
  ##Data
  start <- as.POSIXct('01-01-2015', format = '%d-%m-%Y')
  end <- as.POSIXct('31-12-2015', format = '%d-%m-%Y')
  date <- seq.POSIXt(from = start, to = end, by = 'day')
  date <- format(date, '%m-%d-%Y')
  low <- c() ; open <- c() ; close <- c() ; high <- c() ; median <- c()
  
  n <- 100
  invisible(
    sapply(1:length(date), function(i)
    {
      sample <- rnorm(n, mean = sample(1:10, 1), sd = sample(1:10/10, 1))
      quant <- boxplot(sample, plot = FALSE)$stats
      low <<- c(low, quant[1])
      open <<- c(open, quant[2])
      median <<- c(median, quant[3])
      close <<- c(close, quant[4])
      high <<- c(high, quant[5])
    })
  )
  dp <- data.table(date = date, low = round(low, 2), open = round(open, 2), 
                   close = round(close, 2), high = round(high, 2), median = round(median, 2)) 
  balloonText <- paste('Open:<b>[[open]]</b><br>',
                       'Low:<b>[[low]]</b><br>',
                       'High:<b>[[high]]</b><br>',
                       'Close:<b>[[close]]</b><br>')
  ##Plot
  pipeline(
    amSerialChart(categoryField = 'date', dataDateFormat = 'MM-DD-YYYY',
                  dataProvider = dp, startDuration = 0),
    setCategoryAxis(parseDates = TRUE),
    addGraph(id = 'g1', type = 'candlestick', lineColor = '#7f8da9', lowField = 'low',
             closeField = 'close', highField = 'high', openField = 'open',
             valueField = 'median', balloonText = balloonText, title = 'Price: ',
             lineColor = '#7f8da9', lineAlpha = 1, fillAlphas = 0.9, negativeBase = 5,
             negativeFillColors = '#db4c3c', negativeLineColor = '#db4c3c'),
    setChartCursor(valueLineEnabled = TRUE, valueLineBalloonEnabled = TRUE),
    setChartScrollbar(graph = 'g1', graphType = 'line'),
    addListener('init', paste('function(event) {',
                              'var nbCandles = event.chart.dataProvider.length;',
                              'event.chart.zoomToIndexes(20, 100);',
                              ' }'))
  )
  "
})

# ---
# Stack bar with negative values
# ---
output$serial11 <- renderAmCharts({
  ##Data
  n <- 15
  (male <- round(sort(runif(n)), 1))
  (female <- -round(sort(runif(n)), 1))
  (category <- factor(paste('cat.', 1:15)))
  dataProvider <- data.table(male, female, category)
  labelFunction1 <- htmlwidgets::JS('function(item) {',
                                    'return Math.abs(item.values.value);',
                                    '}')
  balloonFunction <- htmlwidgets::JS('function(item) {',
                                     'return item.category + \': \' + Math.abs(item.values.value) + \'%\';',
                                     '}')
  labelFunction2 <- htmlwidgets::JS('function(value) {',
                                    'return Math.abs(value) + \'%\';',
                                    '}')
  
  valueAxis_obj <- valueAxis(gridAlpha = 0, ignoreAxisWidth = TRUE, id = 'axis1',
                             labelFunction = labelFunction2)
  ##Plot
  pipeline(
    amSerialChart(startDuration = 0, rotate = TRUE, marginBottom = 50,
                  categoryField = 'category'),
    addGraph(fillAlphas = .8, lineAlpha = .2, type = 'column', valueField = 'male',
             title = 'Male', clustered = FALSE, labelFunction = labelFunction1,
             balloonFunction = balloonFunction),
    addGraph(fillAlphas = .8, lineAlpha = .2, type = 'column', valueField = 'female',
             title = 'Female', clustered = FALSE, labelFunction = labelFunction1,
             balloonFunction = balloonFunction),
    setCategoryAxis(gridPosition = 'start', gridAlpha = .2, axisAlpha = 0),
    setBalloon(fixedPosition = TRUE),
    setChartCursor(valueBalloonEnabled = FALSE, cursorAlpha = .05, fullWidth = TRUE),
    addLabel(text = 'Male', x = '28%', y = '97%', bold = TRUE, align = 'middle'),
    addLabel(text = 'Female', x = '75%', y = '97%', bold = TRUE, align = 'middle'),
    addGuide(value = 0, lineAlpha = .2, valueAxis = 'axis1'),
    setDataProvider(dataProvider = dataProvider)
  )
  
})

output$code_serial11 <- renderText({
  "
  ##Data
  n <- 15
  (male <- round(sort(runif(n)), 1))
  (female <- -round(sort(runif(n)), 1))
  (category <- factor(paste('cat.', 1:15)))
  dataProvider <- data.table(male, female, category)
  labelFunction1 <- htmlwidgets::JS('function(item) {',
                                    'return Math.abs(item.values.value);',
                                    '}')
  balloonFunction <- htmlwidgets::JS('function(item) {',
                                     'return item.category + \': \' + Math.abs(item.values.value) + \'%\';',
                                     '}')
  labelFunction2 <- htmlwidgets::JS('function(value) {',
                                    'return Math.abs(value) + \'%\';',
                                    '}')
  
  valueAxis_obj <- valueAxis(gridAlpha = 0, ignoreAxisWidth = TRUE, id = 'axis1',
                             labelFunction = labelFunction2)
  ##Plot
  pipeline(
    amSerialChart(startDuration = 0, rotate = TRUE, marginBottom = 50,
                  categoryField = 'category'),
    addGraph(fillAlphas = .8, lineAlpha = .2, type = 'column', valueField = 'male',
             title = 'Male', clustered = FALSE, labelFunction = labelFunction1,
             balloonFunction = balloonFunction),
    addGraph(fillAlphas = .8, lineAlpha = .2, type = 'column', valueField = 'female',
             title = 'Female', clustered = FALSE, labelFunction = labelFunction1,
             balloonFunction = balloonFunction),
    setCategoryAxis(gridPosition = 'start', gridAlpha = .2, axisAlpha = 0),
    setBalloon(fixedPosition = TRUE),
    setChartCursor(valueBalloonEnabled = FALSE, cursorAlpha = .05, fullWidth = TRUE),
    addLabel(text = 'Male', x = '28%', y = '97%', bold = TRUE, align = 'middle'),
    addLabel(text = 'Male', x = '75%', y = '97%', bold = TRUE, align = 'middle'),
    addGuide(value = 0, lineAlpha = .2, valueAxis = 'axis1'),
    setDataProvider(dataProvider = dataProvider)
  )
  "
})
datastorm-open/rAmCharts documentation built on Oct. 4, 2022, 7:07 p.m.