Last active
December 18, 2015 02:59
-
-
Save danielristic/5715490 to your computer and use it in GitHub Desktop.
A simple line chart using d3.js with some mouse interactions
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| [{"outcome_id":22,"history":[{"time":"2013-05-06T16:38:55+03:00","balance_of_power":0.2},{"time":"2013-05-07T00:38:55+03:00","balance_of_power":0.2222222222222222},{"time":"2013-05-07T08:38:55+03:00","balance_of_power":0.36363636363636365},{"time":"2013-05-07T16:38:55+03:00","balance_of_power":0.2857142857142857},{"time":"2013-05-08T00:38:55+03:00","balance_of_power":0.4117647058823529},{"time":"2013-05-08T08:38:55+03:00","balance_of_power":0.47368421052631576},{"time":"2013-05-08T16:38:55+03:00","balance_of_power":0.45},{"time":"2013-05-09T00:38:55+03:00","balance_of_power":0.42857142857142855},{"time":"2013-05-09T08:38:55+03:00","balance_of_power":0.391304347826087},{"time":"2013-05-09T16:38:55+03:00","balance_of_power":0.44},{"time":"2013-05-10T00:38:55+03:00","balance_of_power":0.39285714285714285},{"time":"2013-05-10T08:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-10T16:38:55+03:00","balance_of_power":0.3235294117647059},{"time":"2013-05-11T00:38:55+03:00","balance_of_power":0.3142857142857143},{"time":"2013-05-11T08:38:55+03:00","balance_of_power":0.2972972972972973},{"time":"2013-05-11T16:38:55+03:00","balance_of_power":0.35},{"time":"2013-05-12T00:38:55+03:00","balance_of_power":0.38095238095238093},{"time":"2013-05-12T08:38:55+03:00","balance_of_power":0.35555555555555557},{"time":"2013-05-12T16:38:55+03:00","balance_of_power":0.3404255319148936},{"time":"2013-05-13T00:38:55+03:00","balance_of_power":0.38},{"time":"2013-05-13T08:38:55+03:00","balance_of_power":0.36538461538461536},{"time":"2013-05-13T16:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-14T00:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-14T08:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-14T16:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-15T00:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-15T08:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-15T16:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-16T00:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-16T08:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-16T16:38:55+03:00","balance_of_power":0.3584905660377358},{"time":"2013-05-17T00:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-17T08:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-17T16:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-18T00:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-18T08:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-18T16:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-19T00:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-19T08:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-19T16:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-20T00:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-20T08:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-20T16:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-21T00:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-21T08:38:55+03:00","balance_of_power":0.3064516129032258},{"time":"2013-05-21T16:38:55+03:00","balance_of_power":0.40425531914893614},{"time":"2013-05-22T00:38:55+03:00","balance_of_power":0.40425531914893614},{"time":"2013-05-22T08:38:55+03:00","balance_of_power":0.40425531914893614},{"time":"2013-05-22T16:38:55+03:00","balance_of_power":0.40425531914893614},{"time":"2013-05-23T00:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-23T08:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-23T16:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-24T00:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-24T08:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-24T16:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-25T00:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-25T08:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-25T16:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-26T00:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-26T08:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-26T16:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-27T00:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-27T08:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-27T16:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-28T00:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-28T08:38:55+03:00","balance_of_power":0.3958333333333333},{"time":"2013-05-28T16:38:55+03:00","balance_of_power":0.3958333333333333}],"winner":true,"name":"Pauline"},{"outcome_id":23,"history":[{"time":"2013-05-06T16:38:55+03:00","balance_of_power":0.2},{"time":"2013-05-07T00:38:55+03:00","balance_of_power":0.1111111111111111},{"time":"2013-05-07T08:38:55+03:00","balance_of_power":0.09090909090909091},{"time":"2013-05-07T16:38:55+03:00","balance_of_power":0.2857142857142857},{"time":"2013-05-08T00:38:55+03:00","balance_of_power":0.23529411764705882},{"time":"2013-05-08T08:38:55+03:00","balance_of_power":0.21052631578947367},{"time":"2013-05-08T16:38:55+03:00","balance_of_power":0.2},{"time":"2013-05-09T00:38:55+03:00","balance_of_power":0.19047619047619047},{"time":"2013-05-09T08:38:55+03:00","balance_of_power":0.17391304347826086},{"time":"2013-05-09T16:38:55+03:00","balance_of_power":0.16},{"time":"2013-05-10T00:38:55+03:00","balance_of_power":0.14285714285714285},{"time":"2013-05-10T08:38:55+03:00","balance_of_power":0.12903225806451613},{"time":"2013-05-10T16:38:55+03:00","balance_of_power":0.11764705882352941},{"time":"2013-05-11T00:38:55+03:00","balance_of_power":0.11428571428571428},{"time":"2013-05-11T08:38:55+03:00","balance_of_power":0.10810810810810811},{"time":"2013-05-11T16:38:55+03:00","balance_of_power":0.1},{"time":"2013-05-12T00:38:55+03:00","balance_of_power":0.09523809523809523},{"time":"2013-05-12T08:38:55+03:00","balance_of_power":0.08888888888888889},{"time":"2013-05-12T16:38:55+03:00","balance_of_power":0.0851063829787234},{"time":"2013-05-13T00:38:55+03:00","balance_of_power":0.08},{"time":"2013-05-13T08:38:55+03:00","balance_of_power":0.07692307692307693},{"time":"2013-05-13T16:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-14T00:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-14T08:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-14T16:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-15T00:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-15T08:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-15T16:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-16T00:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-16T08:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-16T16:38:55+03:00","balance_of_power":0.07547169811320754},{"time":"2013-05-17T00:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-17T08:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-17T16:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-18T00:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-18T08:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-18T16:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-19T00:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-19T08:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-19T16:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-20T00:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-20T08:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-20T16:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-21T00:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-21T08:38:55+03:00","balance_of_power":0.06451612903225806},{"time":"2013-05-21T16:38:55+03:00","balance_of_power":0.0851063829787234},{"time":"2013-05-22T00:38:55+03:00","balance_of_power":0.0851063829787234},{"time":"2013-05-22T08:38:55+03:00","balance_of_power":0.0851063829787234},{"time":"2013-05-22T16:38:55+03:00","balance_of_power":0.0851063829787234},{"time":"2013-05-23T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-23T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-23T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-24T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-24T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-24T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-25T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-25T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-25T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-26T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-26T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-26T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-27T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-27T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-27T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-28T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-28T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-28T16:38:55+03:00","balance_of_power":0.10416666666666667}],"winner":false,"name":"Romain"},{"outcome_id":24,"history":[{"time":"2013-05-06T16:38:55+03:00","balance_of_power":0.2},{"time":"2013-05-07T00:38:55+03:00","balance_of_power":0.1111111111111111},{"time":"2013-05-07T08:38:55+03:00","balance_of_power":0.09090909090909091},{"time":"2013-05-07T16:38:55+03:00","balance_of_power":0.07142857142857142},{"time":"2013-05-08T00:38:55+03:00","balance_of_power":0.058823529411764705},{"time":"2013-05-08T08:38:55+03:00","balance_of_power":0.05263157894736842},{"time":"2013-05-08T16:38:55+03:00","balance_of_power":0.05},{"time":"2013-05-09T00:38:55+03:00","balance_of_power":0.047619047619047616},{"time":"2013-05-09T08:38:55+03:00","balance_of_power":0.043478260869565216},{"time":"2013-05-09T16:38:55+03:00","balance_of_power":0.04},{"time":"2013-05-10T00:38:55+03:00","balance_of_power":0.14285714285714285},{"time":"2013-05-10T08:38:55+03:00","balance_of_power":0.22580645161290322},{"time":"2013-05-10T16:38:55+03:00","balance_of_power":0.20588235294117646},{"time":"2013-05-11T00:38:55+03:00","balance_of_power":0.2},{"time":"2013-05-11T08:38:55+03:00","balance_of_power":0.1891891891891892},{"time":"2013-05-11T16:38:55+03:00","balance_of_power":0.175},{"time":"2013-05-12T00:38:55+03:00","balance_of_power":0.16666666666666666},{"time":"2013-05-12T08:38:55+03:00","balance_of_power":0.15555555555555556},{"time":"2013-05-12T16:38:55+03:00","balance_of_power":0.19148936170212766},{"time":"2013-05-13T00:38:55+03:00","balance_of_power":0.18},{"time":"2013-05-13T08:38:55+03:00","balance_of_power":0.21153846153846154},{"time":"2013-05-13T16:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-14T00:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-14T08:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-14T16:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-15T00:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-15T08:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-15T16:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-16T00:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-16T08:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-16T16:38:55+03:00","balance_of_power":0.22641509433962265},{"time":"2013-05-17T00:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-17T08:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-17T16:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-18T00:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-18T08:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-18T16:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-19T00:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-19T08:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-19T16:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-20T00:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-20T08:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-20T16:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-21T00:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-21T08:38:55+03:00","balance_of_power":0.1935483870967742},{"time":"2013-05-21T16:38:55+03:00","balance_of_power":0.2553191489361702},{"time":"2013-05-22T00:38:55+03:00","balance_of_power":0.2553191489361702},{"time":"2013-05-22T08:38:55+03:00","balance_of_power":0.2553191489361702},{"time":"2013-05-22T16:38:55+03:00","balance_of_power":0.2553191489361702},{"time":"2013-05-23T00:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-23T08:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-23T16:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-24T00:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-24T08:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-24T16:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-25T00:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-25T08:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-25T16:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-26T00:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-26T08:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-26T16:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-27T00:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-27T08:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-27T16:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-28T00:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-28T08:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-28T16:38:55+03:00","balance_of_power":0.25}],"winner":false,"name":"Tad"},{"outcome_id":25,"history":[{"time":"2013-05-06T16:38:55+03:00","balance_of_power":0.2},{"time":"2013-05-07T00:38:55+03:00","balance_of_power":0.1111111111111111},{"time":"2013-05-07T08:38:55+03:00","balance_of_power":0.09090909090909091},{"time":"2013-05-07T16:38:55+03:00","balance_of_power":0.07142857142857142},{"time":"2013-05-08T00:38:55+03:00","balance_of_power":0.058823529411764705},{"time":"2013-05-08T08:38:55+03:00","balance_of_power":0.05263157894736842},{"time":"2013-05-08T16:38:55+03:00","balance_of_power":0.05},{"time":"2013-05-09T00:38:55+03:00","balance_of_power":0.047619047619047616},{"time":"2013-05-09T08:38:55+03:00","balance_of_power":0.043478260869565216},{"time":"2013-05-09T16:38:55+03:00","balance_of_power":0.04},{"time":"2013-05-10T00:38:55+03:00","balance_of_power":0.03571428571428571},{"time":"2013-05-10T08:38:55+03:00","balance_of_power":0.03225806451612903},{"time":"2013-05-10T16:38:55+03:00","balance_of_power":0.029411764705882353},{"time":"2013-05-11T00:38:55+03:00","balance_of_power":0.05714285714285714},{"time":"2013-05-11T08:38:55+03:00","balance_of_power":0.05405405405405406},{"time":"2013-05-11T16:38:55+03:00","balance_of_power":0.05},{"time":"2013-05-12T00:38:55+03:00","balance_of_power":0.047619047619047616},{"time":"2013-05-12T08:38:55+03:00","balance_of_power":0.1111111111111111},{"time":"2013-05-12T16:38:55+03:00","balance_of_power":0.10638297872340426},{"time":"2013-05-13T00:38:55+03:00","balance_of_power":0.1},{"time":"2013-05-13T08:38:55+03:00","balance_of_power":0.09615384615384616},{"time":"2013-05-13T16:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-14T00:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-14T08:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-14T16:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-15T00:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-15T08:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-15T16:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-16T00:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-16T08:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-16T16:38:55+03:00","balance_of_power":0.09433962264150944},{"time":"2013-05-17T00:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-17T08:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-17T16:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-18T00:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-18T08:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-18T16:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-19T00:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-19T08:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-19T16:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-20T00:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-20T08:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-20T16:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-21T00:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-21T08:38:55+03:00","balance_of_power":0.08064516129032258},{"time":"2013-05-21T16:38:55+03:00","balance_of_power":0.10638297872340426},{"time":"2013-05-22T00:38:55+03:00","balance_of_power":0.10638297872340426},{"time":"2013-05-22T08:38:55+03:00","balance_of_power":0.10638297872340426},{"time":"2013-05-22T16:38:55+03:00","balance_of_power":0.10638297872340426},{"time":"2013-05-23T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-23T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-23T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-24T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-24T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-24T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-25T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-25T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-25T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-26T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-26T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-26T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-27T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-27T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-27T16:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-28T00:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-28T08:38:55+03:00","balance_of_power":0.10416666666666667},{"time":"2013-05-28T16:38:55+03:00","balance_of_power":0.10416666666666667}],"winner":false,"name":"Zayra"},{"outcome_id":26,"history":[{"time":"2013-05-06T16:38:55+03:00","balance_of_power":0.2},{"time":"2013-05-07T00:38:55+03:00","balance_of_power":0.4444444444444444},{"time":"2013-05-07T08:38:55+03:00","balance_of_power":0.36363636363636365},{"time":"2013-05-07T16:38:55+03:00","balance_of_power":0.2857142857142857},{"time":"2013-05-08T00:38:55+03:00","balance_of_power":0.23529411764705882},{"time":"2013-05-08T08:38:55+03:00","balance_of_power":0.21052631578947367},{"time":"2013-05-08T16:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-09T00:38:55+03:00","balance_of_power":0.2857142857142857},{"time":"2013-05-09T08:38:55+03:00","balance_of_power":0.34782608695652173},{"time":"2013-05-09T16:38:55+03:00","balance_of_power":0.32},{"time":"2013-05-10T00:38:55+03:00","balance_of_power":0.2857142857142857},{"time":"2013-05-10T08:38:55+03:00","balance_of_power":0.25806451612903225},{"time":"2013-05-10T16:38:55+03:00","balance_of_power":0.3235294117647059},{"time":"2013-05-11T00:38:55+03:00","balance_of_power":0.3142857142857143},{"time":"2013-05-11T08:38:55+03:00","balance_of_power":0.35135135135135137},{"time":"2013-05-11T16:38:55+03:00","balance_of_power":0.325},{"time":"2013-05-12T00:38:55+03:00","balance_of_power":0.30952380952380953},{"time":"2013-05-12T08:38:55+03:00","balance_of_power":0.28888888888888886},{"time":"2013-05-12T16:38:55+03:00","balance_of_power":0.2765957446808511},{"time":"2013-05-13T00:38:55+03:00","balance_of_power":0.26},{"time":"2013-05-13T08:38:55+03:00","balance_of_power":0.25},{"time":"2013-05-13T16:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-14T00:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-14T08:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-14T16:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-15T00:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-15T08:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-15T16:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-16T00:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-16T08:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-16T16:38:55+03:00","balance_of_power":0.24528301886792453},{"time":"2013-05-17T00:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-17T08:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-17T16:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-18T00:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-18T08:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-18T16:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-19T00:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-19T08:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-19T16:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-20T00:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-20T08:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-20T16:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-21T00:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-21T08:38:55+03:00","balance_of_power":0.3548387096774194},{"time":"2013-05-21T16:38:55+03:00","balance_of_power":0.14893617021276595},{"time":"2013-05-22T00:38:55+03:00","balance_of_power":0.14893617021276595},{"time":"2013-05-22T08:38:55+03:00","balance_of_power":0.14893617021276595},{"time":"2013-05-22T16:38:55+03:00","balance_of_power":0.14893617021276595},{"time":"2013-05-23T00:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-23T08:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-23T16:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-24T00:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-24T08:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-24T16:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-25T00:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-25T08:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-25T16:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-26T00:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-26T08:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-26T16:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-27T00:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-27T08:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-27T16:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-28T00:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-28T08:38:55+03:00","balance_of_power":0.14583333333333334},{"time":"2013-05-28T16:38:55+03:00","balance_of_power":0.14583333333333334}],"winner":false,"name":"Manika"}] |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| <!DOCTYPE html> | |
| <meta charset="utf-8"> | |
| <style> | |
| #line-chart { | |
| width: 700px; | |
| height: 120px; | |
| } | |
| .line { | |
| opacity: 0.3; | |
| stroke-width: 3px; | |
| fill: none; | |
| stroke: steelblue; | |
| } | |
| .winner.line { | |
| opacity: 1; | |
| } | |
| .current.line { | |
| opacity: 1; | |
| } | |
| .dot { | |
| pointer-events: all; | |
| } | |
| #donut-chart svg { | |
| padding: 2px; | |
| } | |
| .arc { | |
| opacity: 0.3; | |
| } | |
| .winner.arc { | |
| opacity: 1; | |
| } | |
| .current.arc { | |
| opacity: 1; | |
| } | |
| #line-chart, #donut-chart { | |
| display: inline-block; | |
| vertical-align: top; | |
| } | |
| </style> | |
| <script src="http://d3js.org/d3.v3.min.js"></script> | |
| <div id="line-chart"></div> | |
| <div id="donut-chart"></div> | |
| <script> | |
| //// Helper Methods | |
| function last_array_elt(a) { | |
| return a[a.length - 1]; | |
| } | |
| function latest_balance(outcome) { | |
| return last_array_elt(outcome.history).balance_of_power; | |
| } | |
| function valueInPercent(value) { | |
| return d3.round(value*100)+"%"; | |
| } | |
| function appendTooltip(selection, accessor) { | |
| selection | |
| .classed("has-tip tip-right", true) | |
| .attr("title", accessor) | |
| .attr("data-tooltip", ""); | |
| } | |
| function onmouseoverline(d, i) { | |
| d3.select(this) | |
| .classed("current", true); | |
| d3.selectAll(".arc[data-outcome-id='"+d.outcome_id+"']") | |
| .classed("current", true); | |
| } | |
| function onmouseoverdonut(d, i) { | |
| d3.select(this) | |
| .classed("current", true); | |
| d3.selectAll(".line[data-outcome-id='"+d.data.outcome_id+"']") | |
| .classed("current", true); | |
| } | |
| function onmouseout(d, i) { | |
| d3.selectAll(".line") | |
| .classed("current", false); | |
| d3.selectAll(".arc") | |
| .classed("current", false); | |
| } | |
| var color = d3.scale.category20(); | |
| var margin = {top: 2, right: 0, bottom: 5, left: 0}, | |
| width = 700 - margin.left - margin.right, | |
| height = 120 - margin.top - margin.bottom; | |
| var formatDate = d3.time.format.iso; | |
| var x = d3.time.scale() | |
| .range([0, width]); | |
| var y = d3.scale.linear() | |
| .range([height, 0]); | |
| var line = d3.svg.line() | |
| .interpolate("basis") | |
| .x(function(d) { return x(d.time); }) | |
| .y(function(d) { return y(+d.balance_of_power); }); | |
| var svg = d3.select("#line-chart").append("svg") | |
| .attr("width", width + margin.left + margin.right) | |
| .attr("height", height + margin.top + margin.bottom) | |
| .append("g") | |
| .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); | |
| d3.json("data.json", function(data) { | |
| var outcomes_list = data.map(function(d) { return d.outcome_id; }); | |
| color.domain(outcomes_list); | |
| // Parse times | |
| data.forEach(function(d) { | |
| d.history.forEach(function(h) { | |
| h.time = formatDate.parse(h.time); | |
| }); | |
| }); | |
| var all_times = data.map(function(d) {return d.history.map(function (h) {return h.time})}).reduce(function(a,b) {return a.concat(b)}); | |
| var all_balances = data.map(function(d) {return d.history.map(function (h) {return h.balance_of_power})}).reduce(function(a,b) {return a.concat(b)}); | |
| x.domain(d3.extent(all_times)); | |
| y.domain(d3.extent(all_balances)); | |
| var outcome_g = svg.selectAll(".outcome_g") | |
| .data(data) | |
| .enter().append("g") | |
| .attr("class", "outcome_g"); | |
| var outcome_line = outcome_g.append("path") | |
| .attr("class", "line") | |
| .attr("data-outcome-id", function(d) { return d.outcome_id; }) | |
| .attr("d", function(d) { return line(d.history)}) | |
| .style("stroke", function(d) { return color(d.outcome_id) }); | |
| // Adding invisible dots | |
| // var outcome_dots = outcome_g.selectAll(".dot") | |
| // .data(function(d) { return d.history; }) | |
| // .enter().append("svg:circle") | |
| // .attr("class", "dot") | |
| // .attr("cx", function(d) { return x(d.time); }) | |
| // .attr("cy", function(d) { return y(+d.balance_of_power); }) | |
| // .attr("r", 5) | |
| // .attr("opacity", 0) | |
| // .append("svg:title").text(function(d) {return "Time: " + d.time + "\nValue: " + valueInPercent(d.balance_of_power);}); | |
| // Tooltips | |
| appendTooltip(outcome_line, function(d) { return d.name; }); | |
| // Highlight the winner | |
| outcome_line | |
| .classed("winner", function(d) { return d.winner; }); | |
| // Mouseover stuff for line chart | |
| outcome_line | |
| .on("mouseover", onmouseoverline) | |
| .on("mouseout", onmouseout); | |
| // Draw the Donut chart | |
| // Adding the last values of balance of power as a key | |
| var final_balances = data.map(function(outcome_object) { | |
| outcome_object["latest_balance"] = latest_balance(outcome_object) | |
| return outcome_object; | |
| }); | |
| (function() { | |
| var width = 122, | |
| height = 122, | |
| radius = Math.min(width, height) / 2; | |
| var arc = d3.svg.arc() | |
| .outerRadius(radius) | |
| .innerRadius(radius - 40); | |
| var pie = d3.layout.pie() | |
| .value(function(d) { return d.latest_balance; }) | |
| .sort(function(a,b) { return d3.descending(a.latest_balance, b.latest_balance) }); | |
| var svg = d3.select("#donut-chart").append("svg") | |
| .attr("width", width) | |
| .attr("height", height) | |
| .append("g") | |
| .attr("transform", "translate(" + width / 2 + "," + height / 2 + ")"); | |
| var g = svg.selectAll(".arc") | |
| .data(pie(final_balances)) | |
| .enter().append("g") | |
| .attr("class", "arc") | |
| .attr("data-outcome-id", function(d) { return d.data.outcome_id; }); | |
| // Tooltips | |
| appendTooltip(g, function(d) { return d.data.name+" / "+valueInPercent(d.data.latest_balance); }); | |
| g | |
| .append("path") | |
| .attr("d", arc) | |
| .style("fill", function(d) { return color(d.data.outcome_id); }); | |
| g | |
| .classed("winner", function(d) { return d.data.winner; }); | |
| g | |
| .filter(function(d) { return d.data.winner; }) | |
| .style("stroke", function(d) { return d3.rgb(color(d.data.outcome_id)).darker(); }) | |
| .style("stroke-width", 2); | |
| g | |
| .on("mouseover", onmouseoverdonut) | |
| .on("mouseout", onmouseout); | |
| }).call(this); | |
| }); | |
| </script> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment