Skip to content

Commit

Permalink
#75 Updated events behavior.
Browse files Browse the repository at this point in the history
  • Loading branch information
artzub committed Feb 3, 2022
1 parent a9dc457 commit 7b09bb5
Show file tree
Hide file tree
Showing 4 changed files with 77 additions and 40 deletions.
4 changes: 2 additions & 2 deletions src/components/Header/components/ProfileStep/Body.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ const Body = () => {
onClick={onClick(profile)}
>
<ListItemAvatar>
<Avatar src={profile.avatar_url} />
<Avatar src={profile.avatar} />
</ListItemAvatar>
<ListItemText
primary={<Highlight search={search} text={profile.login} />}
Expand All @@ -163,7 +163,7 @@ const Body = () => {
onClick={onClick(profile)}
>
<ListItemAvatar>
<Avatar src={profile.avatar_url} />
<Avatar src={profile.avatar} />
</ListItemAvatar>
<ListItemText
primary={profile.login}
Expand Down
3 changes: 0 additions & 3 deletions src/components/Header/components/Tabs/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -103,11 +103,8 @@ const Tabs = () => {
const [left, setLeft] = useState(0);
const [opacity, setOpacity] = useState(0);

console.log(view);

const onClick = useCallback(
(event) => {
console.log(event.target.dataset.key);
setView(event.target.dataset.key);
},
[setView],
Expand Down
103 changes: 72 additions & 31 deletions src/components/Visualization/UserVisualization/application.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ class Application {

this._simulation = forceSimulation()
.velocityDecay(0.05)
.alphaMin(0.01)
.alphaTarget(0.1)
.force('x', forceX(0).strength(0.05))
.force('y', forceY(0).strength(0.05))
.force('charge', forceManyBody())
Expand Down Expand Up @@ -146,11 +146,9 @@ class Application {

this._calcRadiusDomain(data);
this._calcAlphaDomain(data);
this._simulation
.nodes(data)
.alphaTarget(0.5)
.restart()
;
this._simulation.nodes(data);
this._restartSimulation();

this._data();

return this;
Expand All @@ -164,6 +162,7 @@ class Application {
this._radiusGetter = getter || radiusDefault;
this._calcRadiusDomain(this._simulation.nodes());
this._group.children.forEach(this._updateNodes);
this._restartSimulation();

return this;
}
Expand All @@ -176,6 +175,7 @@ class Application {
this._alphaGetter = getter || alphaDefault;
this._calcAlphaDomain(this._simulation.nodes());
this._group.children.forEach(this._updateNodes);
this._restartSimulation();

return this;
}
Expand All @@ -188,6 +188,7 @@ class Application {
this._groupGetter = getter || groupDefault;
this._colors = scaleOrdinal(colors);
this._group.children.forEach(this._updateNodes);
this._restartSimulation();

return this;
}
Expand All @@ -207,6 +208,14 @@ class Application {
}

this._selected = key;
this._simulation.restart();
}

_restartSimulation() {
this._simulation
.alpha(0.5)
.restart()
;
}

_bindMethods() {
Expand All @@ -229,6 +238,13 @@ class Application {
return;
}

event.stopPropagation();

this._simulation
.velocityDecay(0.05)
.alpha(0.5)
.restart();

const node = event.currentTarget;
this._event.call('itemOver', node, event, node);

Expand All @@ -238,15 +254,14 @@ class Application {
return;
}

this._hovered = node;
this._locator.focused(node);

const item = node.__data__;
if (!item) {
return;
}

this._hovered = this._keyOfItem(item);

item.fx = item.x;
item.fy = item.y;
}
Expand All @@ -256,6 +271,8 @@ class Application {
return;
}

event.stopPropagation();

this._hovered = null;
this._locator.focused(null);

Expand All @@ -273,12 +290,12 @@ class Application {
return;
}

node.children[0].alpha = this._alphaOfItem(item);
delete item.fx;
delete item.fy;
}

_onPointerDown(event) {
event.stopPropagation();
if (event.data.originalEvent.ctrlKey || event.data.originalEvent.button) {
return;
}
Expand All @@ -297,6 +314,7 @@ class Application {
}

_onPointerMove(event) {
event.stopPropagation();
const node = this._dragNode;
const { x, y } = this._dragPrevPoint;
const { x: nx, y: ny } = event.data.getLocalPosition(this._dragNode.parent);
Expand All @@ -322,6 +340,7 @@ class Application {
}

_onPointerUp(event) {
event.stopPropagation();
const node = this._dragNode;
const item = node?.__data__;
const key = this._keyOfItem(item || {});
Expand All @@ -344,6 +363,10 @@ class Application {

this._dragging = false;

if (event.type === 'pointerupoutside') {
this._onPointerOut(event);
}

if (!node) {
return;
}
Expand Down Expand Up @@ -403,6 +426,8 @@ class Application {

this._updateNodes(node);
});

this._simulation.restart();
}

_updateNodes(node) {
Expand All @@ -414,12 +439,15 @@ class Application {

const color = d3color(this._colorOfItem(item));
const radius = +this._radiusOfItem(item);
const alpha = +this._alphaOfItem(item);
let alpha = +this._alphaOfItem(item);

let [circle, border] = node.children;
if (!circle) {
circle = new PIXI.Graphics();
node.addChild(circle);

node._focused = true;
alpha = 1;
} else {
circle.clear();
}
Expand Down Expand Up @@ -487,20 +515,21 @@ class Application {
this._locator.resize(width, height);
}

_updateFocused() {
this._group.children.find((node) => {
_updateFocused(nodes) {
const items = nodes || this._group.children.filter((node) => {
const key = this._keyOfItem(node.__data__);
if (key === this._hovered || key === this._selected) {
node.filters = [filterBrightness];
gsap.to(node.children[0], {
alpha: key === this._hovered ? 0.8 : 0.9,
duration: 0.2,
overwrite: true,
});
return true;
}
return node === this._hovered || key === this._selected;
});

return false;
items.forEach((node) => {
const key = this._keyOfItem(node.__data__);
node._focused = true;
node.filters = [filterBrightness];
gsap.to(node.children[0], {
alpha: key === this._hovered ? 0.9 : 0.8,
duration: 0.2,
overwrite: true,
});
});
}

Expand All @@ -509,26 +538,28 @@ class Application {
}
set _selected(value) {
this.__selected = value;
if (value) {
this._updateFocused();
}
this._updateFocused();
}

get _hovered() {
return this.__hovered;
}
set _hovered(value) {
this.__hovered = value;
if (value) {
this._updateFocused();
}
this._updateFocused();
}

_draw() {
if (this._destroyed) {
return this;
}

const alpha = this._simulation.alpha();
const alphaTarget = this._simulation.alphaTarget();
if (!this._hovered && +alpha.toFixed(15) === alphaTarget) {
this._simulation.stop();
}

this._group.children.forEach((node) => {
const item = node.__data__;
if (!item) {
Expand All @@ -537,13 +568,23 @@ class Application {

const key = this._keyOfItem(item);

if (!(key === this._hovered || key === this._selected) && node.filters?.length) {
node.filters = [];
if (!(node === this._hovered || key === this._selected) && node._focused) {
node._focused = false;
gsap.to(node.children[0], {
alpha: this._alphaOfItem(item),
duration: 0.2,
delay: 0.3,
duration: 0.5,
overwrite: true,
onComplete: () => {
node.filters = null;
},
});

if (node !== this._hovered) {
this._locator.focused(null);
delete item.fx;
delete item.fy;
}
}

node.x = item.x + (item.x % 2 ? 0 : 0.5);
Expand Down
7 changes: 3 additions & 4 deletions src/components/Visualization/shared/Locator.js
Original file line number Diff line number Diff line change
Expand Up @@ -89,8 +89,8 @@ class Locator extends PIXI.Container {
y: -0.5,
},
{
x: i % 2 && (i === 3 ? 1 : -1) * width,
y: i % 2 ? 0 : (i === 2 ? 1 : -1) * height,
x: i % 2 && (i === 3 ? 1 : -1) * width * 3,
y: i % 2 ? 0 : (i === 2 ? 1 : -1) * height * 3,
},
];
drawDashedPolygon(item, points, 0, 0, 0, 6, 18, 0);
Expand All @@ -110,8 +110,7 @@ class Locator extends PIXI.Container {
}

onPointerMove(event) {
if ((this._focused && event?.currentTarget !== this._focused)
|| !event?.data?.global) {
if ((this._focused && event?.currentTarget !== this._focused) || !event?.data?.global) {
return;
}

Expand Down

0 comments on commit 7b09bb5

Please sign in to comment.