Browse Source

bubbles continue

dependabot/npm_and_yarn/webpack-bundle-analyzer-3.6.0
Alexey Velikiy 7 years ago
parent
commit
8cdd526cc0
  1. 2
      src/d3-components/bubbles-nested-routes/bubbles.vue
  2. 12
      src/d3-components/bubbles-nested-routes/index.vue
  3. 36
      src/d3-components/bubbles-nested-routes/ph2/index.js
  4. 12
      src/d3-components/bubbles-nested-routes/ph2/layout-contry.js
  5. 12
      src/d3-components/bubbles-nested-routes/ph2/layout-total.js

2
src/d3-components/bubbles-nested-routes/bubbles.vue

@ -12,7 +12,7 @@ Links:
<script>
import PH2 from './ph2';
import PH2 from './ph2/index';
const d3 = require('d3');
export default {

12
src/d3-components/bubbles-nested-routes/index.vue

@ -33,16 +33,16 @@ const LINKS = [
path: '',
layout: 'together'
},
{
name: 'By contry',
path: '/contry',
layout: 'contry'
},
{
name: 'By year',
path: '/year',
layout: 'year'
},
{
name: 'By sex',
path: '/sex',
layout: 'sex'
},
}
].map(d => {
d.path = '#/' + MY_URL_PREFIX + d.path;
return d;

36
src/d3-components/bubbles-nested-routes/ph2.js → src/d3-components/bubbles-nested-routes/ph2/index.js vendored

@ -2,6 +2,11 @@
const d3 = require('d3');
const layoutTotal = require('./layout-total');
const layoutContry = require('./layout-contry');
const _ = require('lodash');
// TODO: do it d3-way so I can use selection.call()
export default class PH2 {
@ -9,21 +14,33 @@ export default class PH2 {
this.svg = elem;
this.setData(data);
this._init();
this.layout = undefined;
this.setLayout(layoutName);
}
setLayout(layoutName) {
// TODO: something special
this.simulation.alpha(1).restart();
if(!this.layouts) {
throw new Error('Layouts are not defined');
}
if(!this.layouts[layoutName]) {
throw new Error('Can`t find layout ' + layoutName);
}
if(this.layout) {
this.layout.exit();
}
this.layout = this.layouts[layoutName];
this.layout.enter();
}
setData(data) {
var range = data.length;
this.data = {
nodes:data.map(d => ({
label: "l"+d ,r:+d.Magnitude
r: +d.Magnitude
})),
links:d3.range(0, range).map(function(){ return {source:~~d3.randomUniform(range)(), target:~~d3.randomUniform(range)()} })
links:d3.range(0, range).map(
function(){ return {source:~~d3.randomUniform(range)(), target:~~d3.randomUniform(range)()}
})
};
}
@ -65,12 +82,17 @@ export default class PH2 {
.nodes(this.data.nodes)
.on("tick", ticked);
this.simulation.force("link")
this.simulation
.force("link")
.links(this.data.links);
}
_initNodeYearPos() {
// TODO: fill
_initLayouts() {
this.layouts = {
'total': layoutTotal,
'county': layoutContry,
};
_.this.layouts
}
}

12
src/d3-components/bubbles-nested-routes/ph2/layout-contry.js vendored

@ -0,0 +1,12 @@
export default class {
constructor(elem, simulation) {
this.elem = elem;
this.simulation = simulation;
}
enter() {
}
exit() {
}
}

12
src/d3-components/bubbles-nested-routes/ph2/layout-total.js vendored

@ -0,0 +1,12 @@
export default class {
constructor(elem, simulation) {
this.elem = elem;
this.simulation = simulation;
}
enter() {
}
exit() {
}
}
Loading…
Cancel
Save