Pokemon Form

In the previous page, the selection of which attributes to visualize were hard coded. Let's make our viz more interactive and flexible by providing forms for users to select which attributes to visualize dynamically.

One attribute

Attribute (e.g., Attack):

Comparing two attributes

Attribute 1: Attribute 2:

One attribute with sorting

Attribute:

Three attributes

Width 1: Width 2: Color:

Viz

Data is not loaded yet

// pokemonData is a global variable
pokemonData = 'not loaded yet'

$.get('/data/pokemon-small.json')
 .success(function(data){
     console.log('data loaded', data)
     // TODO: show in the myviz that the data is loaded
     pokemonData = data          
 })


function vizAsHorizontalBars(attributeName){

    // TODO: modify this function to visualize the data as horizontal
    // bars to compare attack points

    // define a template string
    var tplString = '<g transform="translate(0 ${d.y})"> \
                    <rect   \
                         width="${d.width}" \
                         height="20"    \
                         style="fill:${d.color};    \
                                stroke-width:3; \
                                stroke:rgb(0,0,0)" />   \
                    </g>'

    // compile the string to get a template function
    var template = _.template(tplString)

    function computeX(d, i) {
        return 0
    }

    function computeWidth(d, i) {        
        return d[attributeName]
    }

    function computeY(d, i) {
        return i * 20
    }

    function computeColor(d, i) {
        return 'red'
    }

    var viz = _.map(pokemonData, function(d, i){
                return {
                    x: computeX(d, i),
                    y: computeY(d, i),
                    width: computeWidth(d, i),
                    color: computeColor(d, i)
                }
             })
    console.log('viz', viz)

    var result = _.map(viz, function(d){
             // invoke the compiled template function on each viz data
             return template({d: d})
         })
    console.log('result', result)

    $('.myviz').html('<svg>' + result + '</svg>')
}

$('button#viz-horizontal').click(function(){
   
    var attributeName =  $('input#pokemon-attribute-name').val()  
    vizAsHorizontalBars(attributeName)
})  


// TODO: complete the code below

function vizSideBySide(attributeName1, attributeName2){

    var tplString = '<g transform="translate(120 ${d.y})"> \
                    <rect   \
                         x="-${d.width}" \
                         width="${d.width}" \
                         height="20"    \
                         style="fill:${d.color};    \
                                stroke-width:1; \
                                stroke:rgb(0,0,0)" />   \
                     <rect   \
                         x="0" \
                         width="${d.height}" \
                         height="20"    \
                         style="fill:blue;    \
                                stroke-width:1; \
                                stroke:rgb(0,0,0)" />   \
                    <text transform="translate(0 15)">${d.name} </text> \
                    </g>'

    // compile the string to get a template function
    var template = _.template(tplString)

    function computeX(d, i) {
        return i * 20
    }

    function computeWidth(d, i) {
        return   d[attributeName1]
    }

    function computeY(d, i) {
      return i * 20
    }
    function computeColor(d, i) {
    return 'red'
}
function computeName(d, i) {
    return d.Name
}
function computeHeight(d, i) {
    return  d[attributeName2]
}
    var viz = _.map(pokemonData, function(d, i){
                return {
                     x: computeX(d, i),
                y: computeY(d, i),
                width: computeWidth(d, i),
                color: computeColor(d, i),
                name:  computeName(d,i),
                height:computeHeight(d,i)
                }
             })
    console.log('viz', viz)

    var result = _.map(viz, function(d){
             // invoke the compiled template function on each viz data
             return template({d: d})
         })
    console.log('result', result)

    $('.myviz').html('<svg>' + result + '</svg>')
}

$('button#viz-compare').click(function(){    
    var attributeName1 =  $('input#pokemon-attribute-name-1').val()  
    var attributeName2 =  $('input#pokemon-attribute-name-2').val()  
    vizSideBySide(attributeName1, attributeName2)
})  

// TODO: complete the code below

function vizAsSortedHorizontalBars(attributeName, sortDirection){

    var tplString = '<g transform="translate(0 ${d.y})"> \
                    <rect   \
                         width="${d.width}" \
                         height="20"    \
                         style="fill:${d.color};    \
                                stroke-width:3; \
                                stroke:rgb(0,0,0)" />   \
                                 <text transform="translate(0 15)">${d.name} </text> \
                    </g>'

    // compile the string to get a template function
    var template = _.template(tplString)

    function computeX(d, i) {
        return 0
    }

    function computeWidth(d, i) {
        return  d[attributeName]
    }

    function computeY(d, i) {
        return i * 20
    }

    function computeColor(d, i) {
        return 'red'
    }
    function computeName(d, i) {
    return d.Name
}

    if(sortDirection=="asc")
    pokemonData=_.sortBy(pokemonData,attributeName)
    else
    pokemonData=_.sortBy(pokemonData,attributeName).reverse()
    var viz = _.map(pokemonData, function(d, i){
                return {
                    x: computeX(d, i),
                    y: computeY(d, i),
                    width: computeWidth(d, i),
                    color: computeColor(d, i),
                    name:  computeName(d,i)
                }
             })
    console.log('viz', viz)

    var result = _.map(viz, function(d){
             // invoke the compiled template function on each viz data
             return template({d: d})
         })
    console.log('result', result)

    $('.myviz').html('<svg>' + result + '</svg>')
}

    
    
    $('button#viz-horizontal-sorted-asc').click(function(){    
    var sortDirection = 'asc'
    
    var attributeName =  $('input#pokemon-sorted-attribute-name').val() 
   vizAsSortedHorizontalBars(attributeName, sortDirection)
})  

    $('button#viz-horizontal-sorted-desc').click(function(){    
    var sortDirection = "desc"
    
    var attributeName =  $('input#pokemon-sorted-attribute-name').val() 
   vizAsSortedHorizontalBars(attributeName, sortDirection)
})  

   


// TODO: complete the code below
// visualize three attributes, the first two attributes as side-by-side bar charts
// using bar widths to represent attribute values, and the third attribute's value
// is represented using the red color brightness
function vizThreeAttributes(attributeName1, attributeName2, attributeName3){

    var tplString = '<g transform="translate(120 ${d.y})"> \
                    <rect   \
                         x="-${d.width}" \
                         width="${d.width}" \
                         height="20"    \
                         style="fill:${d.color};    \
                                stroke-width:1; \
                                stroke:rgb(0,0,0)" />   \
                     <rect   \
                         x="0" \
                         width="${d.height}" \
                         height="20"    \
                         style="fill:${d.color};    \
                                stroke-width:1; \
                                stroke:rgb(0,0,0)" />   \
                    <text transform="translate(0 15)">${d.name} </text> \
                    </g>'

    // compile the string to get a template function
    var template = _.template(tplString)

    function computeX(d, i) {
        return i * 20
    }

    function computeWidth(d, i) {
        return   d[attributeName1]
    }

    function computeY(d, i) {
      return i * 20
    }
    function computeColor(d, i) {
    return attributeName3
}
function computeName(d, i) {
    return d.Name
}
function computeHeight(d, i) {
    return  d[attributeName2]
}
    var viz = _.map(pokemonData, function(d, i){
                return {
                     x: computeX(d, i),
                y: computeY(d, i),
                width: computeWidth(d, i),
                color: computeColor(d, i),
                name:  computeName(d,i),
                height:computeHeight(d,i)
                }
             })
    console.log('viz', viz)

    var result = _.map(viz, function(d){
             // invoke the compiled template function on each viz data
             return template({d: d})
         })
    console.log('result', result)

    $('.myviz').html('<svg>' + result + '</svg>')
}

$('button#viz-three').click(function(){    
    var attributeName1 = $('input#pokemon-three-width1').val() 
    var attributeName2 = $('input#pokemon-three-width2').val() 
    var attributeName3 = $('input#pokemon-three-color').val()     
    vizThreeAttributes(attributeName1, attributeName2, attributeName3)
})