Skip to content

Commit

Permalink
Fixes duplicate line being shown as "seen" even when its not seen. (#676
Browse files Browse the repository at this point in the history
)

* adds lineCount to lineID in sessionStatesList

* fixes resume panktee problem

* resumes from mainLineID

* gracefully handles changing bani settings when resuming from bani

* resume bani if length is not changed
  • Loading branch information
inderpreetsingh authored and maneetpaul committed Jun 27, 2019
1 parent bf66247 commit 989afa0
Showing 1 changed file with 17 additions and 9 deletions.
26 changes: 17 additions & 9 deletions www/js/search.js
Original file line number Diff line number Diff line change
Expand Up @@ -587,15 +587,16 @@ module.exports = {
onclick: ev => {
const $panktee = ev.target;
const { resumePanktee } = sessionStatesList[sessionKey];
const resumePankteeLineID = resumePanktee ? resumePanktee.split('-')[0] : MainLineID;
switch (type) {
case 'bani':
this.loadBani(SearchID, resumePanktee, true);
this.loadBani(SearchID, resumePankteeLineID, true);
break;
case 'ceremony':
this.loadCeremony(SearchID, resumePanktee, true);
this.loadCeremony(SearchID, resumePankteeLineID, true);
break;
default:
this.loadShabad(SearchID, resumePanktee);
this.loadShabad(SearchID, resumePankteeLineID);
}
const sessionLines = this.$session.querySelectorAll('a.panktee');
Array.from(sessionLines).forEach(el => el.classList.remove('current'));
Expand Down Expand Up @@ -742,8 +743,14 @@ module.exports = {
// create a unique shabadID for whole bani, and append it with length
const shabadID = `${rowsDb[0].Token || rowsDb[0].Bani.Token}-${baniLength}`;
const nameOfBani = rowsDb[0].Gurmukhi || rowsDb[0].Bani.Gurmukhi;
const thisBaniState = sessionStatesList[`bani-${BaniID}`];
if (!historyReload) {
this.addToHistory(BaniID, null, nameOfBani, 'bani');
if (thisBaniState && thisBaniState.resumePanktee && !LineID) {
thisBaniState.resumePanktee = `${rowsDb[0].ID}-1`;
thisBaniState.seenPanktees = new Set(`${rowsDb[0].ID}-1`);
} else {
this.addToHistory(BaniID, null, nameOfBani, 'bani');
}
}
const rows = rowsDb
.filter(rowDb => rowDb.MangalPosition !== blackListedMangalPosition)
Expand Down Expand Up @@ -795,6 +802,7 @@ module.exports = {
lineFactory(line, rows) {
const mainLineExists = !!document.querySelector('.main');
const englishHeadingEl = document.createElement('span');
const lineSessionID = `${line.ID}-${line.lineCount}`;
englishHeadingEl.innerHTML = line.English;
const englishHeading = englishHeadingEl.querySelector('h1')
? englishHeadingEl.querySelector('h1').innerText
Expand All @@ -812,10 +820,10 @@ module.exports = {
let seenClasses = '';
const shabadState = sessionStatesList[line.sessionKey || `shabad-${line.ShabadID}`];
if (shabadState && shabadState.resumePanktee) {
if (shabadState.seenPanktees.has(line.ID)) {
if (shabadState.seenPanktees.has(lineSessionID) || shabadState.seenPanktees.has(line.ID)) {
seenClasses = '.seen_check';
}
if (shabadState.resumePanktee === line.ID) {
if (shabadState.resumePanktee === lineSessionID) {
seenClasses += '.current';
}
if (shabadState.mainPanktee === line.ID && !mainLineExists) {
Expand Down Expand Up @@ -1019,7 +1027,7 @@ module.exports = {
const $panktee = e.target.parentNode;
Array.from(lines).forEach(el => el.classList.remove('main'));
$panktee.classList.add('main', 'seen_check');
shabadState.seenPanktees.add(LineID);
shabadState.seenPanktees.add(`${LineID}-${Line.lineCount}`);
} else if (e.target.classList.contains('panktee')) {
// Change line to click target
const $panktee = e.target;
Expand All @@ -1029,8 +1037,8 @@ module.exports = {
Array.from(lines).forEach(el => el.classList.remove('current'));
// Add 'current' and 'seen-check' to selected Panktee
$panktee.classList.add('current', 'seen_check');
shabadState.seenPanktees.add(LineID);
shabadState.resumePanktee = LineID;
shabadState.seenPanktees.add(`${LineID}-${Line.lineCount}`);
shabadState.resumePanktee = `${LineID}-${Line.lineCount}`;
}
this.checkAutoPlay(LineID);
},
Expand Down

0 comments on commit 989afa0

Please sign in to comment.