Skip to content

Commit

Permalink
Feature: Add visited index and add dropdown icon to open non-animated…
Browse files Browse the repository at this point in the history
… flow. (#887)

* Add icon to the json.
Fix callers and click handlers.

* Revert changes.

* Fix line not redrawing issue.

* Remove user icon on hover.

* Draw grey circle.

* Dont clear flow in interactive mode.

* Fix click event for dropdown icon.

* Fix removal of previous and next icon in the extension.

* Fix undefined bug.

* Add text style.

* Fix reset button functioning.

* Do not show icon while hovering over controls and bubbles.

* Do not show icon while hovering over controls and bubbles.

* Remove drop down icon when using interactive mode.

* Render usericon while using previous and next button in interactive mode.
  • Loading branch information
amovar18 authored Dec 11, 2024
1 parent ec21243 commit 1b463d5
Show file tree
Hide file tree
Showing 13 changed files with 209 additions and 83 deletions.
2 changes: 1 addition & 1 deletion packages/explorable-explanations/public/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
<main>
<div id="ps-canvas">
<div id="canvas-container">
<div class="controls">
<div id="controls-div" class="controls">
<button id="previous-div" disabled class="play-pause-button">
<svg xmlns="http://www.w3.org/2000/svg" height="20px" viewBox="0 -960 960 960" width="20px"
fill="#808080">
Expand Down
3 changes: 2 additions & 1 deletion packages/explorable-explanations/src/icons.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,6 @@
"pause": "",
"completedCheckMark": "",
"expand": "",
"info": ""
"info": "",
"openWithoutAnimation": ""
}
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ const app = {
visitedIndexOrder: [],
visitedIndexOrderTracker: -1,
isRevisitingNodeInInteractiveMode: false,
usedNextOrPrev: false,
canvasEventListerners: {
main: {
mouseOver: {},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -100,13 +100,13 @@ const ProgressLine = ({
let targetX = x2;

return new Promise((resolve) => {
if (noAnimation || app.isRevisitingNodeInInteractiveMode) {
drawInstantly();
resolve(returnCoordinates);
return;
}

const animate = () => {
if (noAnimation || app.isRevisitingNodeInInteractiveMode) {
drawInstantly();
resolve(returnCoordinates);
return;
}

if (app.cancelPromise) {
resolve();
return;
Expand Down
18 changes: 12 additions & 6 deletions packages/explorable-explanations/src/protectedAudience/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -240,6 +240,7 @@ app.handleInteractivePrev = () => {

app.isRevisitingNodeInInteractiveMode = true;
app.timeline.currentIndex = visitedIndex;
app.usedNextOrPrev = true;

app.drawFlows(visitedIndex);

Expand All @@ -258,7 +259,7 @@ app.handleInteractivePrev = () => {
flow.setButtonsDisabilityState();

utils.wipeAndRecreateMainCanvas();
app.up.clear();
utils.wipeAndRecreateUserCanvas();
timeline.renderUserIcon();
promiseQueue.skipTo(0);
promiseQueue.start();
Expand Down Expand Up @@ -345,6 +346,7 @@ app.handleInteravtiveNext = () => {

app.isRevisitingNodeInInteractiveMode = true;
app.timeline.currentIndex = visitedIndex;
app.usedNextOrPrev = true;

app.drawFlows(visitedIndex);

Expand All @@ -359,7 +361,7 @@ app.handleInteravtiveNext = () => {
flow.setButtonsDisabilityState();

utils.wipeAndRecreateMainCanvas();
app.up.clear();
utils.wipeAndRecreateUserCanvas();
timeline.renderUserIcon();
promiseQueue.skipTo(0);
promiseQueue.start();
Expand All @@ -380,6 +382,7 @@ app.handleControls = () => {

// eslint-disable-next-line no-undef
if (process.env.IS_RUNNING_STANDALONE) {
app.controlsDiv = document.getElementById('controls-div');
app.nextButton = document.getElementById('next-div');
app.prevButton = document.getElementById('previous-div');
app.prevButton.addEventListener('click', app.handlePrevButton);
Expand Down Expand Up @@ -473,6 +476,7 @@ export const sketch = (p) => {
p.pauseIcon = p.loadImage(icons.pause);
p.expandIcon = p.loadImage(icons.expand);
p.infoIcon = p.loadImage(icons.info);
p.openWithoutAnimation = p.loadImage(icons.openWithoutAnimation);

p.completedCheckMark = p.loadImage(icons.completedCheckMark);
};
Expand Down Expand Up @@ -518,7 +522,7 @@ export const userSketch = (p) => {
};
};

app.reset = async () => {
app.reset = async (callFromExtension = false) => {
promiseQueue.stop();
app.cancelPromise = true;
app.timeline.isPaused = true;
Expand All @@ -533,9 +537,11 @@ app.reset = async () => {
utils.markVisitedValue(config.timeline.circles.length, false);
timeline.eraseAndRedraw();
await utils.delay(1000);
setupInterestGroupCanvas(app.igp);
setupUserCanvas(app.up);
setupMainCanvas(app.p);
if (!callFromExtension) {
setupInterestGroupCanvas(app.igp);
setupUserCanvas(app.up);
setupMainCanvas(app.p);
}

app.timeline.isPaused = true;
app.cancelPromise = false;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -502,6 +502,7 @@ auction.draw = (index) => {
if (callBack) {
callBack(returnValue);
}

if (!app.isRevisitingNodeInInteractiveMode) {
if (app.cancelPromise) {
return;
Expand All @@ -512,7 +513,7 @@ auction.draw = (index) => {
}

promiseQueue.add(() => {
if (!app.isRevisitingNodeInInteractiveMode) {
if (!app.isRevisitingNodeInInteractiveMode || !app.isInteractiveMode) {
flow.clearBelowTimelineCircles();
}
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,10 @@ flow.getTimelineCircleCoordinates = (index) => {

const positions = app.timeline.circlePositions[index];

if (app.isRevisitingNodeInInteractiveMode) {
return { x: positions.x, y: positions.y + 20 + diameter / 2 };
}

return { x: positions.x, y: positions.y + diameter / 2 };
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,7 @@ joinInterestGroup.draw = (index) => {
});

promiseQueue.add(() => {
if (!app.isRevisitingNodeInInteractiveMode) {
if (!app.isRevisitingNodeInInteractiveMode || !app.isInteractiveMode) {
flow.clearBelowTimelineCircles();
}
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,23 +48,46 @@ timeline.init = () => {
if (!app.isInteractiveMode) {
return;
}

const { offsetX, offsetY } = event;
let hoveringOnExpandIconPositions = false;

app.timeline.expandIconPositions.forEach((positions) => {
if (
utils.isInsideCircle(
offsetX,
offsetY,
positions.x - 10,
positions.y + config.timeline.circleProps.diameter / 2,
20
)
) {
hoveringOnExpandIconPositions = true;
}
});

app.mouseX = offsetX;
app.mouseY = offsetY;

if (!app.shouldRespondToClick) {
return;
}

if (
hoveringOnExpandIconPositions ||
utils.isOverControls(event.clientX, event.clientY)
) {
app.startTrackingMouse = false;
} else {
app.startTrackingMouse = true;
}

utils.wipeAndRecreateUserCanvas();
timeline.renderUserIcon();
};

app.p.mouseClicked = () => {
if (!app.isInteractiveMode) {
return;
}
if (!app.shouldRespondToClick) {
if (!app.isInteractiveMode || !app.shouldRespondToClick) {
return;
}

Expand All @@ -85,13 +108,15 @@ timeline.init = () => {
}
});

app.usedNextOrPrev = false;

expandIconPositions.forEach((positions) => {
if (
utils.isInsideCircle(
app.mouseX,
app.mouseY,
positions.x + config.timeline.circleProps.diameter / 2,
positions.y,
positions.x - 10,
positions.y + config.timeline.circleProps.diameter / 2,
20
)
) {
Expand Down Expand Up @@ -120,10 +145,13 @@ timeline.init = () => {
app.p.stroke(config.timeline.colors.grey);

config.timeline.circles.forEach((circle, index) => {
app.p.push();
app.p.stroke(config.timeline.colors.grey);
timeline.drawCircle(
index,
circle.visited && index !== clickedIndex ? true : false
);
app.p.pop();

if (circle.visited && index === clickedIndex) {
const position = circlePositions[clickedIndex];
Expand Down Expand Up @@ -209,17 +237,30 @@ timeline.init = () => {
) {
promiseQueue.clear();
flow.clearBelowTimelineCircles();

if (config.timeline.circles[clickedIndex].type === 'advertiser') {
app.joinInterestGroup.joinings[clickedIndex][0].props.y1 += 20;
} else {
app.auction.auctions[clickedIndex][0].props.y1 += 20;
}

app.shouldRespondToClick = false;
app.drawFlows(clickedIndex);

promiseQueue.add(() => {
app.shouldRespondToClick = true;
timeline.renderUserIcon();
app.isRevisitingNodeInInteractiveMode = false;
if (config.timeline.circles[clickedIndex].type === 'advertiser') {
app.joinInterestGroup.joinings[clickedIndex][0].props.y1 -= 20;
} else {
app.auction.auctions[clickedIndex][0].props.y1 -= 20;
}
});

promiseQueue.skipTo(0);
promiseQueue.start();

utils.wipeAndRecreateUserCanvas();
utils.wipeAndRecreateMainCanvas();
return;
Expand Down Expand Up @@ -332,36 +373,54 @@ timeline.drawTimelineLine = () => {
};

timeline.drawCircle = (index, completed = false) => {
const { circleProps, user } = config.timeline;
const { circleProps, user, circles, colors } = config.timeline;
const position = app.timeline.circlePositions[index];
const { diameter } = circleProps;

app.p.circle(position.x, position.y, diameter);

if (completed) {
if (app.isInteractiveMode) {
// app.up.text(
// circles[index].visitedIndex ?? '',
// position.x - 5,
// position.y + diameter / 2
// );
// app.up.image(
// app.p.expandIcon,
// position.x + diameter / 2,
// position.y,
// 20,
// 20
// );
if (!completed) {
return;
}

if (app.isInteractiveMode) {
if (app.usedNextOrPrev && app.timeline.currentIndex === index) {
app.up.image(
app.p.userIcon,
position.x - user.width / 2,
position.y - user.height / 2,
user.width,
user.height
);
return;
}

app.up.push();
app.up.textSize(16);
app.up.fill(colors.visitedBlue);
app.up.stroke(colors.visitedBlue);
app.up.textStyle(app.up.BOLD);
app.up.textAlign(app.up.CENTER, app.up.CENTER);
app.up.text(circles[index].visitedIndex ?? '', position.x, position.y);
app.up.pop();

app.up.image(
app.p.completedCheckMark,
position.x - user.width / 2,
position.y - user.height / 2,
user.width,
user.height
app.p.openWithoutAnimation,
position.x - 10,
position.y + diameter / 2,
20,
20
);
return;
}

app.up.image(
app.p.completedCheckMark,
position.x - user.width / 2,
position.y - user.height / 2,
user.width,
user.height
);
};

timeline.renderUserIcon = () => {
Expand All @@ -379,15 +438,17 @@ timeline.renderUserIcon = () => {
timeline.eraseAndRedraw();
utils.wipeAndRecreateInterestCanvas();

if (app.startTrackingMouse) {
app.up.image(
app.p.userIcon,
circlePosition.x - user.width / 2,
circlePosition.y - user.height / 2,
user.width,
user.height
);
if (!app.startTrackingMouse) {
return;
}

app.up.image(
app.p.userIcon,
circlePosition.x - user.width / 2,
circlePosition.y - user.height / 2,
user.width,
user.height
);
};

timeline.eraseAndRedraw = () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,4 @@ export * from './isInsideCircle';
export * from './canvasEventListener';
export * from './markVisitedValue';
export * from './requestInterval';
export * from './isOverControls';
Loading

0 comments on commit 1b463d5

Please sign in to comment.