author | Chloe Laisne <chloe.laisne@gmail.com> |
Tue, 07 Jun 2016 12:18:53 +0200 | |
changeset 178 | 4d051f080e7e |
parent 176 | d1baf7ccecc8 |
child 181 | b8a783ca6c4a |
permissions | -rw-r--r-- |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
1 |
import Ember from 'ember'; |
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
2 |
import d3 from 'd3'; |
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
3 |
import env from 'app-client/config/environment'; |
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
4 |
|
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
5 |
|
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
6 |
|
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
7 |
export default Ember.Component.extend({ |
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
8 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
9 |
constants: Ember.inject.service(), |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
10 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
11 |
init: function() { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
12 |
this._super(...arguments); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
13 |
}, |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
14 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
15 |
didRender: function() { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
16 |
var self = this; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
17 |
var baseURL = env.baseURL.replace(/\/$/,"")+'/api/v1'; |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
18 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
19 |
d3.json(baseURL + "/discourses", function(discourses) { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
20 |
console.log(discourses); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
21 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
22 |
var width = self.$().parent().width(); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
23 |
var height = self.$().parent().height(); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
24 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
25 |
var bubble = d3.layout.pack() |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
26 |
.sort(null) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
27 |
.size([width, height]) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
28 |
.padding(33); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
29 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
30 |
var element = d3.select('#' + self.get('elementId')); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
31 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
32 |
var svg = element.append("svg") |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
33 |
.attr("width", width) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
34 |
.attr("height", height) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
35 |
.attr("class", "bubble"); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
36 |
|
178 | 37 |
svg.selectAll(".node") |
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
38 |
.data(bubble.nodes(self.createNodes(discourses))) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
39 |
.enter().append("g") |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
40 |
.attr("width", function(d) { return 2.5 * d.r + 'px'; }) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
41 |
.attr("class", function(d) { return "node" + (!d.children ? " leaf" : ""); }) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
42 |
.attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; }) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
43 |
.style("font-size", function(d) { return Math.max(13, d.r / 2) + 'px'; }); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
44 |
|
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
45 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
46 |
var leaf = svg.selectAll(".leaf") |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
47 |
.on('click', function(d) { document.location = self.setQueryString('discours', d.name); }); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
48 |
|
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
49 |
leaf.append("circle") |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
50 |
.attr("r", function(d) { return d.r; }) |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
51 |
.attr("fill", function(d) { return d.fill; }) |
178 | 52 |
.attr("stroke", function() { return "#000"; }); |
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
53 |
|
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
54 |
leaf.append("text") |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
55 |
.attr("dy", ".3em") |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
56 |
.style("text-anchor", "middle") |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
57 |
.text(function(d) { return d.name; }); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
58 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
59 |
element.style("height", height + "px"); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
60 |
}); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
61 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
62 |
this._super(...arguments); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
63 |
}, |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
64 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
65 |
createNodes: function(json) { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
66 |
var self = this; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
67 |
var nodes = {}; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
68 |
var children = {}; |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
69 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
70 |
Object.keys(json).forEach(function(key) { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
71 |
var discourse = json[key]; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
72 |
var index = self.get('constants').DISCOURSES[key]; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
73 |
var category = self.get('constants').DISCOURSE_CATEGORIES[index]; |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
74 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
75 |
children[index] = children[index] || {}; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
76 |
children[index]['name'] = index; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
77 |
children[index]['children'] = children[index]['children'] || []; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
78 |
children[index]['children'].push({ "name": discourse.label, "value": discourse.count, "fill": category.fill }); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
79 |
}); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
80 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
81 |
nodes.children = []; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
82 |
Object.keys(children).forEach(function(key) { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
83 |
nodes.children.push(children[key]); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
84 |
}); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
85 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
86 |
return nodes; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
87 |
}, |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
88 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
89 |
setQueryString: function(field, value) { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
90 |
var hash = document.location.href.split('?'); |
178 | 91 |
var query_parameters = hash.length > 1 ? hash.pop() : ''; |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
92 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
93 |
// Unserialize |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
94 |
var parameters = []; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
95 |
query_parameters.split('&').forEach(function(parameter){ |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
96 |
var object = parameter.split('='); |
178 | 97 |
if(object[1]) { |
98 |
parameters[object[0]] = object[1]; |
|
99 |
} |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
100 |
}); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
101 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
102 |
// Serialize |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
103 |
var string = []; |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
104 |
parameters[field] = encodeURI(value); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
105 |
Object.keys(parameters).forEach(function(key) { |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
106 |
string.push(key + '=' + parameters[key]); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
107 |
}); |
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
108 |
|
176
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
109 |
return hash + '?' + string.join('&'); |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
110 |
} |
d1baf7ccecc8
Add `thematiques` components
Chloe Laisne <chloe.laisne@gmail.com>
parents:
175
diff
changeset
|
111 |
|
175
7a7cfcba5bfe
Add Discourses Component files
Chloe Laisne <chloe.laisne@gmail.com>
parents:
diff
changeset
|
112 |
}); |