Warmup
What is the distribution of X in Y order?
X (e.g., stars)
Y (e.g., ascending, descending)
Data is not loaded yet
items = 'not loaded yet'
$.get('http://bigdatahci2015.github.io/data/yelp/yelp_academic_dataset_business.5000.json.lines.txt')
.success(function(data){
var lines = data.trim().split('\n')
// convert text lines to json arrays and save them in `items`
items = _.map(lines, JSON.parse)
console.log('number of items loaded:', items.length)
console.log('first item', items[0])
})
.error(function(e){
console.error(e)
})
function viz(arg1, arg2, arg3){
// define a template string
var tplString = '<g transform="translate(0 ${d.y})"> \
<text y="20">${d.label}</text> \
<rect x="30" \
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[1].length / 2
}
function computeY(d, i) {
return i * 20
}
function computeColor(d, i) {
return 'red'
}
var groups = _.groupBy(items, arg1)
console.log('groups', groups)
var pairs = _.pairs(groups)
// TODO: sort pairs in the order specified by users
if(arg2) pairs = _.sortBy(pairs, '1');
if(arg2 == 'descending') pairs = _(pairs).reverse().value();
var viz = _.map(pairs, function(d, i){
return {
x: computeX(d, i),
y: computeY(d, i),
width: computeWidth(d, i),
color: computeColor(d, i),
label: d[0]
}
})
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 width="100%" height="100%">' + result + '</svg>')
}
$('button#viz').click(function(){
var arg1 = $('#arg1').val();
var arg2 = $('#arg2').val()
var arg3 = undefined;
viz(arg1, arg2, arg3)
})