Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

layout ggplots in a table #139

Draft
wants to merge 73 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
e5a6803
Test to check for title of 3 plots
siddhesh195 Jul 10, 2024
d11bd6f
added test to verify number of tables , their dimensions and number o…
siddhesh195 Jul 12, 2024
ae7bd35
ramping up on animint.js
siddhesh195 Jul 16, 2024
e516b9a
add all plots in single row
siddhesh195 Jul 16, 2024
6ba7e6a
used element variable
siddhesh195 Jul 16, 2024
89c1e2f
Update .gitignore
siddhesh195 Jul 18, 2024
e53e7d9
put all plots in one column
siddhesh195 Jul 22, 2024
0ae75de
add 2 plots per row and then make a new row
siddhesh195 Jul 22, 2024
adf012b
table with 3 plots per row or user defined layout
siddhesh195 Jul 26, 2024
a2b8c0a
test for putting plots in specific location of outer table
siddhesh195 Jul 26, 2024
45bbcf7
check if svg element exists in a particular location of outer table
siddhesh195 Jul 28, 2024
4951b0b
error message if user forgets to add either row or column
siddhesh195 Jul 28, 2024
96c5a45
made function to check svg
siddhesh195 Jul 29, 2024
0a78f92
put plots with fixed locations first, then put all other plots
siddhesh195 Jul 29, 2024
a692b3d
changed scope of implicitly global variables
siddhesh195 Jul 30, 2024
95cd30f
Give error message if only row or col is added in theme
siddhesh195 Jul 30, 2024
6999ac7
theme_animint now accepts dimensions and not theme
siddhesh195 Jul 31, 2024
91d0abb
removed debugging line
siddhesh195 Aug 6, 2024
5b05e8a
removed comments
siddhesh195 Aug 6, 2024
2e1a5f5
reverted to original style and indentation
siddhesh195 Aug 7, 2024
9af1fe8
made border transparent
siddhesh195 Aug 10, 2024
a1735d2
added var as prefix to make it local
siddhesh195 Aug 10, 2024
8698e18
plots save span
siddhesh195 Sep 2, 2024
fbd9541
Merge branch 'master' into html-plot
siddhesh195 Sep 4, 2024
d4c90aa
rowspan is applied
siddhesh195 Sep 4, 2024
80943e6
colspan can now be applied
siddhesh195 Sep 5, 2024
4ac2937
refactoring
siddhesh195 Sep 7, 2024
4a4d8ea
corrected response.plots[p_name].row toresponse.plots[p_name].positio…
siddhesh195 Sep 24, 2024
7fa9efe
throw error if user is incosistent is passing row and col
siddhesh195 Sep 24, 2024
3499fea
removed check_svg function
siddhesh195 Sep 24, 2024
905feb3
refactoring
siddhesh195 Sep 25, 2024
0287024
corrected code to properly traverse the outer table
siddhesh195 Sep 25, 2024
00040cc
Merge branch 'master' into html-plot
siddhesh195 Sep 26, 2024
e46f73c
Test to check for title of 3 plots
siddhesh195 Jul 10, 2024
3cefb99
added test to verify number of tables , their dimensions and number o…
siddhesh195 Jul 12, 2024
efcd2c5
ramping up on animint.js
siddhesh195 Jul 16, 2024
071eeb5
add all plots in single row
siddhesh195 Jul 16, 2024
744a638
used element variable
siddhesh195 Jul 16, 2024
0fe67a8
Update .gitignore
siddhesh195 Jul 18, 2024
57d530b
put all plots in one column
siddhesh195 Jul 22, 2024
c1fbe30
add 2 plots per row and then make a new row
siddhesh195 Jul 22, 2024
8da6e6c
table with 3 plots per row or user defined layout
siddhesh195 Jul 26, 2024
dbbfcc7
test for putting plots in specific location of outer table
siddhesh195 Jul 26, 2024
e671218
check if svg element exists in a particular location of outer table
siddhesh195 Jul 28, 2024
42eaf91
error message if user forgets to add either row or column
siddhesh195 Jul 28, 2024
3a3141b
made function to check svg
siddhesh195 Jul 29, 2024
cb45b68
put plots with fixed locations first, then put all other plots
siddhesh195 Jul 29, 2024
06d5c10
changed scope of implicitly global variables
siddhesh195 Jul 30, 2024
0368b85
Give error message if only row or col is added in theme
siddhesh195 Jul 30, 2024
28f5cac
theme_animint now accepts dimensions and not theme
siddhesh195 Jul 31, 2024
c5e4c8c
removed debugging line
siddhesh195 Aug 6, 2024
aa07dd9
removed comments
siddhesh195 Aug 6, 2024
7b31296
reverted to original style and indentation
siddhesh195 Aug 7, 2024
70d550d
made border transparent
siddhesh195 Aug 10, 2024
d3e15b3
added var as prefix to make it local
siddhesh195 Aug 10, 2024
731041f
plots save span
siddhesh195 Sep 2, 2024
06d02c8
rowspan is applied
siddhesh195 Sep 4, 2024
1eff5de
colspan can now be applied
siddhesh195 Sep 5, 2024
0ecc99f
refactoring
siddhesh195 Sep 7, 2024
54fcb77
corrected response.plots[p_name].row toresponse.plots[p_name].positio…
siddhesh195 Sep 24, 2024
3a11c39
throw error if user is incosistent is passing row and col
siddhesh195 Sep 24, 2024
a21e13b
removed check_svg function
siddhesh195 Sep 24, 2024
841c4ff
refactoring
siddhesh195 Sep 25, 2024
87ecfda
corrected code to properly traverse the outer table
siddhesh195 Sep 25, 2024
47544aa
Merge branch 'html-plot' of https://github.com/animint/animint2 into …
siddhesh195 Sep 26, 2024
c66cdb0
removed blank lines
siddhesh195 Sep 27, 2024
d9e0310
combined getRowAndColumn and getRowspanAndColumnspan functions
siddhesh195 Sep 30, 2024
446e549
reverting changes for debugging
siddhesh195 Oct 1, 2024
ff96811
merged functions into attribute function
siddhesh195 Oct 1, 2024
9624583
code for handling rowspan
siddhesh195 Oct 2, 2024
3996202
removed unnecessary lines and added test
siddhesh195 Oct 3, 2024
700f1d9
refactored code, added test
siddhesh195 Oct 5, 2024
4580713
Merge branch 'master' into html-plot
siddhesh195 Oct 12, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,4 @@
*ANIMINT_TEST_FOO
*pids.txt
*~
test-renderer1-knit-print.R
8 changes: 4 additions & 4 deletions R/theme.r
Original file line number Diff line number Diff line change
Expand Up @@ -353,18 +353,18 @@ print.theme <- function(x, ...) utils::str(x)
#' }
theme <- function(..., complete = FALSE, validate = TRUE) {
elements <- list(...)

if (!is.null(elements$axis.ticks.margin)) {
warning("`axis.ticks.margin` is deprecated. Please set `margin` property ",
" of `axis.text` instead", call. = FALSE)
elements$axis.ticks.margin <- NULL
}

# Check that all elements have the correct class (element_text, unit, etc)
if (validate) {
mapply(validate_element, elements, names(elements))
}

structure(elements, class = c("theme", "gganimint"),
complete = complete, validate = validate)
}
Expand Down Expand Up @@ -494,7 +494,7 @@ update_theme <- function(oldtheme, newtheme) {
# the default theme -- just replace everything with newtheme
if (attr(newtheme, "complete"))
return(newtheme)

# These are elements in newtheme that aren't already set in oldtheme.
# They will be pulled from the default theme.
newitems <- !names(newtheme) %in% names(oldtheme)
Expand Down
22 changes: 17 additions & 5 deletions R/z_animint.R
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ parsePlot <- function(meta, plot, plot.name){
## Now ggplot specifies panel.margin in 'pt' instead of 'lines'
plot.info$panel_margin_lines <- pt.to.lines(theme.pars$panel.margin)

## No legend if theme(legend.postion="none").
## No legend if theme(legend.position="none").
plot.info$legend <- if(theme.pars$legend.position != "none"){
getLegendList(built)
}
Expand Down Expand Up @@ -103,7 +103,7 @@ parsePlot <- function(meta, plot, plot.name){
# extract minor grid lines
plot.info$grid_minor <- get_grid(theme.pars$panel.grid.minor, theme.pars,
plot.info, meta, built, major = F)

theme <- plot_theme(built$plot)
## Flip labels if coords are flipped - transform does not take care
## of this. Do this BEFORE checking if it is blank or not, so that
## individual axes can be hidden appropriately, e.g. #1.
Expand Down Expand Up @@ -200,7 +200,8 @@ parsePlot <- function(meta, plot, plot.name){
options_list <- getWidthAndHeight(plot$theme)
options_list <- setUpdateAxes(plot$theme, options_list)
plot.info$options <- options_list

plot.info$attributes <- theme_attribute(plot$theme)

list(
plot.info=plot.info,
ggplot=plot,
Expand Down Expand Up @@ -354,11 +355,24 @@ animint2dir <- function(plot.list, out.dir = NULL,
## Call ggplot_build in parsPlot for all ggplots
ggplot.list <- list()
AllPlotsInfo <- list()
custom_layout <- FALSE
for(list.name in names(plot.list)){
p <- plot.list[[list.name]]
if(is.ggplot(p)){
## If plot is correct, save to meta for further processing
parsed_info <- parsePlot(meta, p, list.name) # calls ggplot_build.
if (!is.null(parsed_info$plot.info$position$row) && is.null(parsed_info$plot.info$position$col)) {
stop("You passed row but not the col argument for ",parsed_info$plot.info$title)
}
if (!is.null(parsed_info$plot.info$position$col) && is.null(parsed_info$plot.info$position$row)) {
stop("You passed col but not the row argument for ",parsed_info$plot.info$title)
}
if (!is.null(parsed_info$plot.info$position$row) && !is.null(parsed_info$plot.info$position$col)){
custom_layout<- TRUE
}
if (is.null(parsed_info$plot.info$position$row) && is.null(parsed_info$plot.info$position$col) && custom_layout){
stop("You passed col and row for some plots and not for others, please pass for all or none")
}
AllPlotsInfo[[list.name]] <- parsed_info$plot.info
ggplot.list[[list.name]]$ggplot <- parsed_info$ggplot
ggplot.list[[list.name]]$built <- parsed_info$built
Expand Down Expand Up @@ -638,7 +652,6 @@ animint2dir <- function(plot.list, out.dir = NULL,
stop("missing first selector variable")
}
}

meta$plots <- AllPlotsInfo
meta$time <- AnimationInfo$time
meta$timeValues <- AnimationInfo$timeValues
Expand Down Expand Up @@ -692,7 +705,6 @@ getLegendList <- function(plistextra){
title <- theme$legend.title
# by default, guide boxes are vertically aligned
if(is.null(theme$legend.box)) theme$legend.box <- "vertical" else theme$legend.box

# size of key (also used for bar in colorbar guide)
if(is.null(theme$legend.key.width)) theme$legend.key.width <- theme$legend.key.size
if(is.null(theme$legend.key.height)) theme$legend.key.height <- theme$legend.key.size
Expand Down
10 changes: 10 additions & 0 deletions R/z_animintHelpers.R
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,16 @@ getWidthAndHeight <- function(theme){
options_list
}

theme_attribute <- function(theme){
options_list <- list()
for(attributes in c("rowspan", "colspan","row","col")){
arc <- paste0("animint.", attributes)
options_list[[attributes]] <- if(arc %in% names(theme)){
theme[[arc]]
}
}
options_list
}

setUpdateAxes <- function(theme, options_list){
update_axes <- "animint.update_axes"
Expand Down
19 changes: 19 additions & 0 deletions helper-functions2.R
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
sendKey <- function(key, code, keyCode) {
remDr$Input$dispatchKeyEvent(type = "keyDown", key = key, code = code, windowsVirtualKeyCode = keyCode, nativeVirtualKeyCode = keyCode)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

aren't these functions redundant with other functions? why do they need to be in a separate file? how are they different? please either delete, move, or add a comment here to explain why they need to stay here.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

aren't these functions redundant with other functions? why do they need to be in a separate file? how are they different? please either delete, move, or add a comment here to explain why they need to stay here.

I will take a look into that. I don't remember the exact reason I thought of to make a new file, maybe I missed to notice that a separate file was not necessary.

remDr$Input$dispatchKeyEvent(type = "keyUp", key = key, code = code, windowsVirtualKeyCode = keyCode, nativeVirtualKeyCode = keyCode)
}

clickID <- function(...){
v <- c(...)
stopifnot(length(v) == 1)
runtime_evaluate(script=sprintf("document.getElementById('%s').dispatchEvent(new CustomEvent('click'))", as.character(v)))
}

runtime_evaluate <- function(script=NULL,return.value=FALSE){
eval.result<- remDr$Runtime$evaluate(script,returnByValue = TRUE)
if (return.value){
eval.result$result$value
}else{
eval.result
}
}
163 changes: 159 additions & 4 deletions inst/htmljs/animint.js
Original file line number Diff line number Diff line change
Expand Up @@ -218,11 +218,12 @@ var animint = function (to_select, json_file) {
// Save this geom and load it!
update_geom(g_name, null);
};
var add_plot = function (p_name, p_info) {
var add_plot = function (p_name, p_info,outer_table) {
// Each plot may have one or more legends. To make space for the
// legends, we put each plot in a table with one row and two
// columns: tdLeft and tdRight.
var plot_table = plot_td.append("table").style("display", "inline-block");

var plot_table = outer_table.append("table").style("display", "inline-block");
var plot_tr = plot_table.append("tr");
var tdLeft = plot_tr.append("td");
var tdRight = plot_tr.append("td").attr("class", p_name+"_legend");
Expand Down Expand Up @@ -2023,13 +2024,168 @@ var animint = function (to_select, json_file) {
d3.select("title").text(response.title);
}
// Add plots.


var check_customized_layout = function () {
for (var p_name in response.plots) {
if ("row" in response.plots[p_name].attributes){
return true
}
return false
}
}
var layout_customized=check_customized_layout()
if (layout_customized){
var maximum_row= 0
var maximum_column= 0
var find_maximum_dimensions = function () {
for (var p_name in response.plots) {
count=count+1
if (response.plots[p_name].attributes.row>maximum_row){
maximum_row=response.plots[p_name].attributes.row
}
if (response.plots[p_name].attributes.col>maximum_column){
maximum_column=response.plots[p_name].attributes.col
}
}
}
find_maximum_dimensions()
var create_grid = function () {
let array2D = new Array(maximum_row);
for (let i = 0; i <= maximum_row; i++){
array2D[i] = new Array(maximum_column+1).fill(0); // Fill each row with 0s
}
return array2D
}

var span_grid=create_grid()
var update_rowspan_values = function (start_row,col,rowspan) {
var current_row=start_row
while (current_row< start_row+rowspan-1) {
span_grid[current_row][col]=1
current_row=current_row+1
}
}

var update_rowspan_prefix = function () {
for (var current_row=0;current_row<=maximum_row;current_row=current_row+1){
for (var current_col=1;current_col<=maximum_column;current_col=current_col+1){
span_grid[current_row][current_col]=span_grid[current_row][current_col]+span_grid[current_row][current_col-1]

}

}

}
var construct_outer_table = function () {
function generateKey(row, col) {
return `${row},${col}`;

}
var maximum_dimensions=Math.max(maximum_column,maximum_row)
var outer_table = element.append("table").attr("id", "outerTable");
let rowspan_map = new Map();
let colspan_map = new Map();
for (var p_name in response.plots) {
add_plot(p_name, response.plots[p_name]);
if (('rowspan' in response.plots[p_name].attributes)){
let key = generateKey(response.plots[p_name].attributes.row, response.plots[p_name].attributes.col);
rowspan_map.set(key,response.plots[p_name].attributes)
var rowspan_value=response.plots[p_name].attributes.rowspan
if (rowspan_value>1){
var start_row=response.plots[p_name].attributes.row+1
update_rowspan_values(start_row,response.plots[p_name].attributes.col,response.plots[p_name].attributes.rowspan)

}
}
if (('colspan' in response.plots[p_name].attributes)){
let key = generateKey(response.plots[p_name].attributes.row, response.plots[p_name].attributes.col);
colspan_map.set(key,response.plots[p_name].attributes)
}

}
for (var i = 0; i <=maximum_dimensions; i++) {
var current_row = outer_table.append("tr").style("border","1px solid white");
for (var j = 0; j <=maximum_dimensions; j++){
let key = generateKey(i,j);
if (rowspan_map.has(key) && (colspan_map.has(key))){
var rowspan=rowspan_map.get(key).rowspan
var colspan=colspan_map.get(key).colspan
current_row.append("td").attr("id", "row"+i+"col"+j).attr("rowspan",rowspan).attr("colspan",colspan).style("border","1px solid white");

}
else if(colspan_map.has(key)){
var colspan=colspan_map.get(key).colspan
current_row.append("td").attr("id", "row"+i+"col"+j).attr("colspan",colspan).style("border","1px solid white");
}
else if(rowspan_map.has(key)){
var rowspan=rowspan_map.get(key).rowspan
current_row.append("td").attr("id", "row"+i+"col"+j).attr("rowspan",rowspan).style("border","1px solid white");
}
else{
current_row.append("td").attr("id", "row"+i+"col"+j).style("border","1px solid white");
}
}
}
return outer_table;
}
var outer_table=construct_outer_table();
update_rowspan_prefix();
for (var p_name in response.plots) {
var row=response.plots[p_name].attributes.row
var column=response.plots[p_name].attributes.col
if(column>0){
decrease=span_grid[row][column-1]
}
else{
decrease=0
}

var id= "#row"+response.plots[p_name].attributes.row+"col"+(response.plots[p_name].attributes.col-decrease)
var cell= d3.select(id);
add_plot(p_name, response.plots[p_name],cell);
add_legend(p_name, response.plots[p_name]);
// Append style sheet to document head.
css.appendChild(document.createTextNode(styles.join(" ")));
document.head.appendChild(css);

}
}else{
var count=0
for (var p_name in response.plots){
count=count+1
}
var maximum_dimensions = Math.ceil(Math.sqrt(count))-1;
var construct_outer_table = function () {

var outer_table = element.append("table").attr("id", "outerTable");
for (var i = 0; i <=maximum_dimensions; i++) {
var current_row = outer_table.append("tr").style("border","1px solid white");
for (var j = 0; j <=maximum_dimensions; j++){
current_row.append("td").attr("id", "row"+i+"col"+j).style("border","1px solid white");
}
}
return outer_table;
}
var outer_table=construct_outer_table();

var pointer_row=0
var pointer_column=0
for (var p_name in response.plots) {
var id= "#row"+pointer_row+"col"+pointer_column
var cell= d3.select(id);
pointer_column=pointer_column+1
if (pointer_column>maximum_dimensions){
pointer_column=0
pointer_row=pointer_row+1
}
add_plot(p_name, response.plots[p_name],cell);
add_legend(p_name, response.plots[p_name]);
// Append style sheet to document head.
css.appendChild(document.createTextNode(styles.join(" ")));
document.head.appendChild(css);
}
}

// Then add selectors and start downloading the first data subset.
for (var s_name in response.selectors) {
add_selector(s_name, response.selectors[s_name]);
Expand All @@ -2049,7 +2205,6 @@ var animint = function (to_select, json_file) {
}
}
}

////////////////////////////////////////////
// Widgets at bottom of page
////////////////////////////////////////////
Expand Down
Loading
Loading