From 3942a4f347e4df1194b3ce54fcb9c4bb74f82726 Mon Sep 17 00:00:00 2001 From: Krishna Anandan Date: Wed, 21 Aug 2024 20:54:39 -0500 Subject: [PATCH 1/2] fix: cease autoplay when maidr is deactivated by clicking outside the interactive plot --- src/js/controls.js | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/js/controls.js b/src/js/controls.js index 9152bfe9..04a2e1de 100644 --- a/src/js/controls.js +++ b/src/js/controls.js @@ -2499,6 +2499,10 @@ class Control { constants.autoplayId = setInterval(function () { position.x += step; + if (!plot || !plot.plotData) { + constants.KillAutoplay(); + return; + } if (position.x < 0 || plot.plotData.length - 1 < position.x) { constants.KillAutoplay(); lockPosition(); From 692aeeeb87fc61e7f3a8f3450f9936e9a76b2643 Mon Sep 17 00:00:00 2001 From: Krishna Anandan Date: Mon, 26 Aug 2024 19:11:49 -0500 Subject: [PATCH 2/2] fix: cease autoplay when maidr is inactive on heatmap and scatterplot --- src/js/audio.js | 1 + src/js/controls.js | 9 +++++++++ src/js/heatmap.js | 2 +- src/js/scatterplot.js | 14 ++++++++++++-- 4 files changed, 23 insertions(+), 3 deletions(-) diff --git a/src/js/audio.js b/src/js/audio.js index 53b1850b..e0e81ccf 100644 --- a/src/js/audio.js +++ b/src/js/audio.js @@ -121,6 +121,7 @@ class Audio { panning = 0; } } else if (constants.chartType == 'heat') { + if (!plot.data || !plot.data[position.y]) return; rawFreq = plot.data[position.y][position.x]; rawPanning = position.x; frequency = this.SlideBetween( diff --git a/src/js/controls.js b/src/js/controls.js index 04a2e1de..243cf141 100644 --- a/src/js/controls.js +++ b/src/js/controls.js @@ -569,6 +569,10 @@ class Control { constants.autoplayId = setInterval(function () { position.x += step; + if (!plot || !plot.plotData) { + constants.KillAutoplay(); + return; + } if (position.x < 0 || plot.plotData.length - 1 < position.x) { constants.KillAutoplay(); lockPosition(); @@ -1724,6 +1728,7 @@ class Control { } constants.autoplayId = setInterval(function () { + if (!plot) return; if ( dir == 'left' || dir == 'right' || @@ -2876,6 +2881,10 @@ class Control { dir == 'reverse-right' ) { position.x += step; + if (!plot || !plot.plotData) { + constants.KillAutoplay(); + return; + } if (position.x < 0 || plot.plotData.length - 1 < position.x) { constants.KillAutoplay(); lockPosition(); diff --git a/src/js/heatmap.js b/src/js/heatmap.js index ec00fc99..65f71272 100644 --- a/src/js/heatmap.js +++ b/src/js/heatmap.js @@ -389,7 +389,7 @@ class HeatMapRect { var rect = document.createElementNS(svgns, 'rect'); rect.setAttribute('id', 'highlight_rect'); rect.setAttribute('x', this.x); - rect.setAttribute('y', this.y); + rect.setAttribute('y', this.y === undefined ? 0 : this.y); rect.setAttribute('width', this.width); rect.setAttribute('height', this.height); rect.setAttribute('stroke', constants.colorSelected); diff --git a/src/js/scatterplot.js b/src/js/scatterplot.js index b2b01526..0fe53ec6 100644 --- a/src/js/scatterplot.js +++ b/src/js/scatterplot.js @@ -462,6 +462,10 @@ class ScatterPlot { constants.sepPlayId = setInterval( function () { // play this tone + if (!audio || !audio.playTone) { + clearInterval(constants.sepPlayId); + return; + } audio.playTone(); // and then set up for the next one @@ -477,6 +481,10 @@ class ScatterPlot { ); // play all tones at the same time } else if (constants.chartType == 'smooth') { // best fit smooth layer + if (!audio || !audio.playTone) { + clearInterval(constants.sepPlayId); + return; + } audio.playTone(); } } @@ -520,7 +528,7 @@ class ScatterPlot { if (elIndex > -1) { data = singleMaidr.data[elIndex]; } else { - data = singleMaidr.data + data = singleMaidr.data; } if (xyFormat == 'object') { for (let i = 0; i < data.length; i++) { @@ -714,7 +722,9 @@ class Layer0Point { plot.plotPoints[this.circleIndex[i]] instanceof SVGUseElement || plot.plotPoints[this.circleIndex[i]] instanceof SVGCircleElement ) { - y = plot.plotPoints[this.circleIndex[i]].getAttribute(plot.prefix + 'y'); + y = plot.plotPoints[this.circleIndex[i]].getAttribute( + plot.prefix + 'y' + ); } point.setAttribute('cy', y);