Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: add uncovered block navigation (#136)
- Loading branch information
1 parent
24104a7
commit c798930
Showing
5 changed files
with
76 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
63 changes: 63 additions & 0 deletions
63
packages/istanbul-reports/lib/html/assets/block-navigation.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
var jumpToCode = (function init () { | ||
// Classes of code we would like to highlight | ||
var missingCoverageClasses = [ '.cbranch-no', '.cstat-no', '.fstat-no' ]; | ||
|
||
// We don't want to select elements that are direct descendants of another match | ||
var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > ` | ||
|
||
// Selecter that finds elements on the page to which we can jump | ||
var selector = notSelector + missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b` | ||
|
||
// The NodeList of matching elements | ||
var missingCoverageElements = document.querySelectorAll(selector); | ||
|
||
var currentIndex; | ||
|
||
function toggleClass(index) { | ||
missingCoverageElements.item(currentIndex).classList.remove('highlighted'); | ||
missingCoverageElements.item(index).classList.add('highlighted'); | ||
} | ||
|
||
function makeCurrent(index) { | ||
toggleClass(index); | ||
currentIndex = index; | ||
missingCoverageElements.item(index) | ||
.scrollIntoView({ behavior: 'smooth', block: 'center', inline: 'center' }); | ||
} | ||
|
||
function goToPrevious() { | ||
var nextIndex = 0; | ||
if (typeof currentIndex !== 'number' || currentIndex === 0) { | ||
nextIndex = missingCoverageElements.length - 1; | ||
} else if (missingCoverageElements.length > 1) { | ||
nextIndex = currentIndex - 1; | ||
} | ||
|
||
makeCurrent(nextIndex); | ||
} | ||
|
||
function goToNext() { | ||
var nextIndex = 0; | ||
|
||
if (typeof currentIndex === 'number' && currentIndex < (missingCoverageElements.length - 1)) { | ||
nextIndex = currentIndex + 1; | ||
} | ||
|
||
makeCurrent(nextIndex); | ||
} | ||
|
||
return function jump(event) { | ||
switch (event.which) { | ||
case 78: // n | ||
case 74: // j | ||
goToNext(); | ||
break; | ||
case 66: // b | ||
case 75: // k | ||
case 80: // p | ||
goToPrevious(); | ||
break; | ||
} | ||
}; | ||
}()); | ||
window.addEventListener('keydown', jumpToCode); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters