hw6 first commit
This commit is contained in:
84
hw6/public/js/tileChart.js
Normal file
84
hw6/public/js/tileChart.js
Normal file
@@ -0,0 +1,84 @@
|
||||
|
||||
/** Class implementing the tileChart. */
|
||||
class TileChart {
|
||||
|
||||
/**
|
||||
* Initializes the svg elements required to lay the tiles
|
||||
* and to populate the legend.
|
||||
*/
|
||||
constructor(tooltip){
|
||||
|
||||
let divTiles = d3.select("#tiles").classed("content", true);
|
||||
this.margin = {top: 30, right: 20, bottom: 30, left: 50};
|
||||
//Gets access to the div element created for this chart and legend element from HTML
|
||||
let svgBounds = divTiles.node().getBoundingClientRect();
|
||||
this.svgWidth = svgBounds.width - this.margin.left - this.margin.right;
|
||||
this.svgHeight = this.svgWidth/2;
|
||||
let legendHeight = 150;
|
||||
//add the svg to the div
|
||||
let legend = d3.select("#legend").classed("content",true);
|
||||
|
||||
//creates svg elements within the div
|
||||
this.legendSvg = legend.append("svg")
|
||||
.attr("width",this.svgWidth)
|
||||
.attr("height",legendHeight)
|
||||
.attr("transform", "translate(" + this.margin.left + ",0)")
|
||||
this.svg = divTiles.append("svg")
|
||||
.attr("width",this.svgWidth)
|
||||
.attr("height",this.svgHeight)
|
||||
.attr("transform", "translate(" + this.margin.left + ",0)")
|
||||
|
||||
this.tooltip = tooltip;
|
||||
};
|
||||
|
||||
/**
|
||||
* Returns the class that needs to be assigned to an element.
|
||||
*
|
||||
* @param party an ID for the party that is being referred to.
|
||||
*/
|
||||
chooseClass (party) {
|
||||
if (party == "R"){
|
||||
return "republican";
|
||||
}
|
||||
else if (party== "D"){
|
||||
return "democrat";
|
||||
}
|
||||
else if (party == "I"){
|
||||
return "independent";
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates tiles and tool tip for each state, legend for encoding the
|
||||
* color scale information.
|
||||
*
|
||||
* @param electionResult election data for the year selected
|
||||
* @param colorScale global quantile scale based on the winning
|
||||
* margin between republicans and democrats
|
||||
*/
|
||||
update (electionResult, colorScale){
|
||||
|
||||
//Calculates the maximum number of rows and columns
|
||||
this.maxColumns = d3.max(electionResult, d => +d.Space) + 1;
|
||||
this.maxRows = d3.max(electionResult, d => +d.Row) + 1;
|
||||
|
||||
// ******* TODO: PART IV *******
|
||||
//Tansform the legend element to appear in the center and make a call to this element for it to display.
|
||||
|
||||
//Lay rectangles corresponding to each state according to the 'row' and 'column' information in the data.
|
||||
|
||||
//Display the state abbreviation and number of electoral votes on each of these rectangles
|
||||
|
||||
//Use global color scale to color code the tiles.
|
||||
|
||||
//HINT: Use .tile class to style your tiles;
|
||||
// .tilestext to style the text corresponding to tiles
|
||||
|
||||
//Call the tool tip on hover over the tiles to display stateName, count of electoral votes
|
||||
//then, vote percentage and number of votes won by each party.
|
||||
//HINT: Use the .republican, .democrat and .independent classes to style your elements.
|
||||
|
||||
};
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user