>>1,l=e[r];if(!(void 0!==l&&0P(a,n))void 0!==u&&0>P(u,a)?(e[r]=u,e[o]=n,r=o):(e[r]=a,e[i]=n,r=i);else{if(!(void 0!==u&&0>P(u,n)))break e;e[r]=u,e[o]=n,r=o}}}return t}return null}function P(e,t){var n=e.sortIndex-t.sortIndex;return 0!==n?n:e.id-t.id}var N=[],O=[],F=1,z=null,I=3,M=!1,R=!1,L=!1;function D(e){for(var t=C(O);null!==t;){if(null===t.callback)_(O);else{if(!(t.startTime<=e))break;_(O),t.sortIndex=t.expirationTime,T(N,t)}t=C(O)}}function j(e){if(L=!1,D(e),!R)if(null!==C(N))R=!0,r(A);else{var t=C(O);null!==t&&l(j,t.startTime-e)}}function A(e,n){R=!1,L&&(L=!1,i()),M=!0;var r=I;try{for(D(n),z=C(N);null!==z&&(!(z.expirationTime>n)||e&&!a());){var o=z.callback;if(null!==o){z.callback=null,I=z.priorityLevel;var u=o(z.expirationTime<=n);n=t.unstable_now(),"function"==typeof u?z.callback=u:z===C(N)&&_(N),D(n)}else _(N);z=C(N)}if(null!==z)var c=!0;else{var s=C(O);null!==s&&l(j,s.startTime-n),c=!1}return c}finally{z=null,I=r,M=!1}}function U(e){switch(e){case 1:return-1;case 2:return 250;case 5:return 1073741823;case 4:return 1e4;default:return 5e3}}var V=o;t.unstable_IdlePriority=5,t.unstable_ImmediatePriority=1,t.unstable_LowPriority=4,t.unstable_NormalPriority=3,t.unstable_Profiling=null,t.unstable_UserBlockingPriority=2,t.unstable_cancelCallback=function(e){e.callback=null},t.unstable_continueExecution=function(){R||M||(R=!0,r(A))},t.unstable_getCurrentPriorityLevel=function(){return I},t.unstable_getFirstCallbackNode=function(){return C(N)},t.unstable_next=function(e){switch(I){case 1:case 2:case 3:var t=3;break;default:t=I}var n=I;I=t;try{return e()}finally{I=n}},t.unstable_pauseExecution=function(){},t.unstable_requestPaint=V,t.unstable_runWithPriority=function(e,t){switch(e){case 1:case 2:case 3:case 4:case 5:break;default:e=3}var n=I;I=e;try{return t()}finally{I=n}},t.unstable_scheduleCallback=function(e,n,a){var o=t.unstable_now();if("object"==typeof a&&null!==a){var u=a.delay;u="number"==typeof u&&0o?(e.sortIndex=u,T(O,e),null===C(N)&&e===C(O)&&(L?i():L=!0,l(j,u-o))):(e.sortIndex=a,T(N,e),R||M||(R=!0,r(A))),e},t.unstable_shouldYield=function(){var e=t.unstable_now();D(e);var n=C(N);return n!==z&&null!==z&&null!==n&&null!==n.callback&&n.startTime<=e&&n.expirationTimee.length)&&(t=e.length);for(var n=0,r=new Array(t);n=0,f=s?[].concat(l(r.slice(0,c)),l(r.slice(c+1))):[].concat(l(r),[n+t]);return a.createElement(a.Fragment,null,a.createElement("button",{type:"button",onClick:function(){return i(f)},className:"expandbutton"},s?String.fromCharCode(8211):"+"),a.createElement("a",{href:"javascript:void(0)",onClick:function(){return u(n+t)}},t))}return a.createElement("a",{href:"./".concat(n).concat(t,".html")},t)}function c(e,t){var n="none";for(var r in e)if(e[r]){var l=t[r].classForPercent;if("none"===l)continue;("low"==l||"medium"===l&&"low"!==n||"high"===l&&"low"!==n&&"medium"!==n)&&(n=l)}return n}e.exports=function e(t){var n=t.prefix,l=t.metrics,i=t.file,s=t.children,f=t.tabSize,d=t.metricsToShow,p=t.expandedLines,m=t.setExpandedLines,h=t.fileFilter,v=t.setFileFilter;return f=f||0,s&&f>0&&f--,n=(h?h+"/":"")+(n||""),a.createElement(a.Fragment,null,a.createElement("tr",null,a.createElement("td",{className:"file "+c(d,l)},Array.apply(null,{length:f}).map((function(e,t){return a.createElement("span",{className:"filetab",key:t})})),a.createElement(u,{file:i,prefix:n,expandedLines:p,setExpandedLines:m,hasChildren:Boolean(s),setFileFilter:v})),d.statements&&a.createElement(o,{metrics:l.statements}),d.branches&&a.createElement(o,{metrics:l.branches}),d.functions&&a.createElement(o,{metrics:l.functions}),d.lines&&a.createElement(o,{metrics:l.lines})),s&&p.indexOf(n+i)>=0&&s.map((function(t){return a.createElement(e,r({},t,{tabSize:f+2,key:t.file,prefix:n+i+"/",metricsToShow:d,expandedLines:p,setExpandedLines:m,setFileFilter:v}))})))}},function(e,t,n){"use strict";var r=n(0);function l(e){for(var t=e.metrics,n=e.metricsToShow,l=Object.keys(n),i=[],a=0;a0&&i.push("".concat(u," ").concat(o).concat(1===u?"":"branch"===o?"es":"s"))}}return 0!==i.length&&r.createElement("div",{className:"toolbar__item"},r.createElement("span",{className:"strong"},i.join(", ")),r.createElement("span",{className:"quiet"},"Ignored"))}function i(e){var t=e.data,n=e.name;return r.createElement("div",{className:"toolbar__item"},r.createElement("span",{className:"strong"},t.pct,"%")," ",r.createElement("span",{className:"quiet"},n)," ",r.createElement("span",{className:"fraction "+t.classForPercent},t.covered,"/",t.total))}e.exports=function(e){var t=e.metrics,n=e.metricsToShow;return r.createElement("div",{className:"toolbar"},n.statements&&r.createElement(i,{data:t.statements,name:"Statements"}),n.branches&&r.createElement(i,{data:t.branches,name:"Branches"}),n.functions&&r.createElement(i,{data:t.functions,name:"Functions"}),n.lines&&r.createElement(i,{data:t.lines,name:"Lines"}),r.createElement(l,{metrics:t,metricsToShow:n}))}},function(e,t,n){"use strict";function r(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){if("undefined"==typeof Symbol||!(Symbol.iterator in Object(e)))return;var n=[],r=!0,l=!1,i=void 0;try{for(var a,o=e[Symbol.iterator]();!(r=(a=o.next()).done)&&(n.push(a.value),!t||n.length!==t);r=!0);}catch(e){l=!0,i=e}finally{try{r||null==o.return||o.return()}finally{if(l)throw i}}return n}(e,t)||i(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function l(e){return function(e){if(Array.isArray(e))return a(e)}(e)||function(e){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(e))return Array.from(e)}(e)||i(e)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function i(e,t){if(e){if("string"==typeof e)return a(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(n):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?a(e,t):void 0}}function a(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);ne.length)&&(t=e.length);for(var n=0,r=new Array(t);nBack';
+ };
+
+ this.metricsToShow = opts.metricsToShow || [
+ 'lines',
+ 'branches',
+ 'functions'
+ ];
+ }
+
+ getWriter(context) {
+ if (!this.subdir) {
+ return context.writer;
+ }
+ return context.writer.writerForDir(this.subdir);
+ }
+
+ onStart(root, context) {
+ this.htmlReport.onStart(root, context);
+
+ const writer = this.getWriter(context);
+ const srcDir = path.resolve(__dirname, './assets');
+ fs.readdirSync(srcDir).forEach(f => {
+ const resolvedSource = path.resolve(srcDir, f);
+ const resolvedDestination = '.';
+ const stat = fs.statSync(resolvedSource);
+ let dest;
+
+ if (stat.isFile()) {
+ dest = resolvedDestination + '/' + f;
+ if (this.verbose) {
+ console.log('Write asset: ' + dest);
+ }
+ writer.copyFile(resolvedSource, dest);
+ }
+ });
+ }
+
+ onDetail(node, context) {
+ this.htmlReport.onDetail(node, context);
+ }
+
+ getMetric(metric, type, context) {
+ const isEmpty = metric.total === 0;
+ return {
+ total: metric.total,
+ covered: metric.covered,
+ skipped: metric.skipped,
+ pct: isEmpty ? 0 : metric.pct,
+ classForPercent: isEmpty
+ ? 'empty'
+ : context.classForPercent(type, metric.pct)
+ };
+ }
+
+ toDataStructure(node, context) {
+ const coverageSummary = node.getCoverageSummary();
+ const metrics = {
+ statements: this.getMetric(
+ coverageSummary.statements,
+ 'statements',
+ context
+ ),
+ branches: this.getMetric(
+ coverageSummary.branches,
+ 'branches',
+ context
+ ),
+ functions: this.getMetric(
+ coverageSummary.functions,
+ 'functions',
+ context
+ ),
+ lines: this.getMetric(coverageSummary.lines, 'lines', context)
+ };
+
+ return {
+ file: node.getRelativeName(),
+ isEmpty: coverageSummary.isEmpty(),
+ metrics,
+ children:
+ node.isSummary() &&
+ node
+ .getChildren()
+ .map(child => this.toDataStructure(child, context))
+ };
+ }
+
+ onEnd(rootNode, context) {
+ const data = this.toDataStructure(rootNode, context);
+
+ const cw = this.getWriter(context).writeFile(
+ this.linkMapper.getPath(rootNode)
+ );
+
+ cw.write(
+ `
+
+
+
+
+
+
+
+
+
+
+ `
+ );
+ cw.close();
+ }
+}
+
+module.exports = HtmlSpaReport;
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/fileBreadcrumbs.js b/node_modules/istanbul-reports/lib/html-spa/src/fileBreadcrumbs.js
new file mode 100644
index 00000000..b123d37f
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/fileBreadcrumbs.js
@@ -0,0 +1,31 @@
+const React = require('react');
+
+module.exports = function FileBreadcrumbs({ fileFilter = '', setFileFilter }) {
+ const parts = fileFilter.split('/');
+ const breadcrumbs = [
+ {
+ path: '',
+ name: 'all files'
+ },
+ ...parts.map((part, i) => ({
+ path: parts.slice(0, i + 1).join('/'),
+ name: part
+ }))
+ ];
+
+ return breadcrumbs.map(({ path, name }) =>
+ path === fileFilter ? (
+ name
+ ) : (
+ <>
+ setFileFilter(path)}
+ >
+ {name}
+
+ /
+ >
+ )
+ );
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/filterToggle.js b/node_modules/istanbul-reports/lib/html-spa/src/filterToggle.js
new file mode 100644
index 00000000..b636b535
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/filterToggle.js
@@ -0,0 +1,50 @@
+const React = require('react');
+
+function ToggleOption({ children, filter, activeFilters, setFilters }) {
+ return (
+
+ );
+}
+
+module.exports = function FilterToggle({ activeFilters, setFilters }) {
+ return (
+
+
Filter:
+
+
+ Low
+
+
+ Medium
+
+
+ High
+
+
+
+ );
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/flattenToggle.js b/node_modules/istanbul-reports/lib/html-spa/src/flattenToggle.js
new file mode 100644
index 00000000..8bb6ea37
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/flattenToggle.js
@@ -0,0 +1,25 @@
+const React = require('react');
+
+module.exports = function FlattenButton({ setIsFlat, isFlat }) {
+ return (
+
+
Files:
+
+
+
+
{' '}
+
+ );
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/getChildData.js b/node_modules/istanbul-reports/lib/html-spa/src/getChildData.js
new file mode 100644
index 00000000..eff5d315
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/getChildData.js
@@ -0,0 +1,155 @@
+function addPath(node, parentPath) {
+ if (!parentPath) {
+ return node;
+ }
+ return { ...node, file: parentPath + '/' + node.file };
+}
+
+function flatten(nodes, parentPath) {
+ let children = [];
+ for (let i = 0; i < nodes.length; i++) {
+ const child = nodes[i];
+ if (child.children) {
+ children = [
+ ...children,
+ ...flatten(
+ child.children,
+ (parentPath ? parentPath + '/' : '') + child.file
+ )
+ ];
+ } else {
+ children.push(addPath(child, parentPath));
+ }
+ }
+ return children;
+}
+
+function filterByFile(nodes, fileFilter, parentPath) {
+ let children = [];
+
+ for (let i = 0; i < nodes.length; i++) {
+ const child = nodes[i];
+ const childFullPath = (parentPath ? parentPath + '/' : '') + child.file;
+
+ const isChildUnderFilter =
+ fileFilter === childFullPath ||
+ fileFilter.indexOf(childFullPath + '/') === 0;
+ const isChildAboveFilter =
+ childFullPath.indexOf(fileFilter + '/') === 0;
+
+ if (isChildUnderFilter) {
+ // flatten and continue looking underneath
+ children = [
+ ...children,
+ ...filterByFile(child.children, fileFilter, childFullPath)
+ ];
+ } else if (isChildAboveFilter) {
+ // remove the parent path and add everything underneath
+ const charsToRemoveFromFile =
+ fileFilter.length - (parentPath ? parentPath.length : 0);
+ let childFilename = child.file.slice(charsToRemoveFromFile);
+ if (childFilename[0] === '/') {
+ childFilename = childFilename.slice(1);
+ }
+ children.push({
+ ...child,
+ file: childFilename
+ });
+ }
+ }
+ return children;
+}
+
+function sort(childData, activeSort) {
+ const top = activeSort.order === 'asc' ? 1 : -1;
+ const bottom = activeSort.order === 'asc' ? -1 : 1;
+ childData.sort((a, b) => {
+ let valueA;
+ let valueB;
+ if (activeSort.sortKey === 'file') {
+ valueA = a.file;
+ valueB = b.file;
+ } else {
+ const [metricType, valueType] = activeSort.sortKey.split('.');
+ valueA = a.metrics[metricType][valueType];
+ valueB = b.metrics[metricType][valueType];
+ }
+
+ if (valueA === valueB) {
+ return 0;
+ }
+ return valueA < valueB ? top : bottom;
+ });
+
+ for (let i = 0; i < childData.length; i++) {
+ const child = childData[i];
+ if (child.children) {
+ childData[i] = {
+ ...child,
+ children: sort(child.children, activeSort)
+ };
+ }
+ }
+ return childData;
+}
+
+function filter(nodes, metricsMap, activeFilters) {
+ const children = [];
+ for (let i = 0; i < nodes.length; i++) {
+ let child = nodes[i];
+ if (child.children) {
+ const newSubChildren = filter(
+ child.children,
+ metricsMap,
+ activeFilters
+ );
+ if (newSubChildren.length) {
+ child = { ...child, children: newSubChildren };
+ children.push(child);
+ }
+ } else {
+ if (
+ (metricsMap.statements &&
+ activeFilters[child.metrics.statements.classForPercent]) ||
+ (metricsMap.branches &&
+ activeFilters[child.metrics.branches.classForPercent]) ||
+ (metricsMap.functions &&
+ activeFilters[child.metrics.functions.classForPercent]) ||
+ (metricsMap.lines &&
+ activeFilters[child.metrics.lines.classForPercent])
+ ) {
+ children.push(child);
+ }
+ }
+ }
+ return children;
+}
+
+module.exports = function getChildData(
+ sourceData,
+ metricsToShow,
+ activeSort,
+ isFlat,
+ activeFilters,
+ fileFilter
+) {
+ let childData = sourceData.children;
+
+ if (isFlat) {
+ childData = flatten(childData.slice(0));
+ }
+
+ if (fileFilter) {
+ childData = filterByFile(childData, fileFilter);
+ }
+
+ if (activeFilters.low) {
+ activeFilters = { ...activeFilters, empty: true };
+ }
+ childData = filter(childData, metricsToShow, activeFilters);
+
+ if (activeSort) {
+ childData = sort(childData, activeSort);
+ }
+ return childData;
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/index.js b/node_modules/istanbul-reports/lib/html-spa/src/index.js
new file mode 100644
index 00000000..e8fd1458
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/index.js
@@ -0,0 +1,156 @@
+// The index file for the spa running on the summary page
+const React = require('react');
+const ReactDOM = require('react-dom');
+const SummaryTableHeader = require('./summaryTableHeader');
+const SummaryTableLine = require('./summaryTableLine');
+const SummaryHeader = require('./summaryHeader');
+const getChildData = require('./getChildData');
+const FlattenToggle = require('./flattenToggle');
+const FilterToggle = require('./filterToggle');
+const FileBreadcrumbs = require('./fileBreadcrumbs');
+const { setLocation, decodeLocation } = require('./routing');
+
+const { useState, useMemo, useEffect } = React;
+
+const sourceData = window.data;
+const metricsToShow = {};
+for (let i = 0; i < window.metricsToShow.length; i++) {
+ metricsToShow[window.metricsToShow[i]] = true;
+}
+
+let firstMount = true;
+
+function App() {
+ const routingDefaults = decodeLocation();
+
+ const [activeSort, setSort] = useState(
+ (routingDefaults && routingDefaults.activeSort) || {
+ sortKey: 'file',
+ order: 'desc'
+ }
+ );
+ const [isFlat, setIsFlat] = useState(
+ (routingDefaults && routingDefaults.isFlat) || false
+ );
+ const [activeFilters, setFilters] = useState(
+ (routingDefaults && routingDefaults.activeFilters) || {
+ low: true,
+ medium: true,
+ high: true
+ }
+ );
+ const [expandedLines, setExpandedLines] = useState(
+ (routingDefaults && routingDefaults.expandedLines) || []
+ );
+ const [fileFilter, setFileFilter] = useState(
+ (routingDefaults && routingDefaults.fileFilter) || ''
+ );
+ const childData = useMemo(
+ () =>
+ getChildData(
+ sourceData,
+ metricsToShow,
+ activeSort,
+ isFlat,
+ activeFilters,
+ fileFilter
+ ),
+ [activeSort, isFlat, activeFilters, fileFilter]
+ );
+ const overallMetrics = sourceData.metrics;
+
+ useEffect(() => {
+ setLocation(
+ firstMount,
+ activeSort,
+ isFlat,
+ activeFilters,
+ fileFilter,
+ expandedLines
+ );
+ firstMount = false;
+ }, [activeSort, isFlat, activeFilters, fileFilter, expandedLines]);
+
+ useEffect(() => {
+ window.onpopstate = () => {
+ const routingState = decodeLocation();
+ if (routingState) {
+ // make sure all the state is set before rendering to avoid url updates
+ // alternative is to merge all the states into one so it can be set in one go
+ // https://github.com/facebook/react/issues/14259
+ ReactDOM.unstable_batchedUpdates(() => {
+ setFilters(routingState.activeFilters);
+ setSort(routingState.activeSort);
+ setIsFlat(routingState.isFlat);
+ setExpandedLines(routingState.expandedLines);
+ setFileFilter(routingState.fileFilter);
+ });
+ }
+ };
+ }, []);
+
+ return (
+
+
+
+
+
+
+
+
+
+
+
+
+ {
+ setSort(newSort);
+ }}
+ activeSort={activeSort}
+ metricsToShow={metricsToShow}
+ />
+
+ {childData.map(child => (
+
+ ))}
+
+
+
+
+ Code coverage generated by{' '}
+
+ istanbul
+ {' '}
+ at {window.generatedDatetime}
+
+
+ );
+}
+
+ReactDOM.render(, document.getElementById('app'));
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/routing.js b/node_modules/istanbul-reports/lib/html-spa/src/routing.js
new file mode 100644
index 00000000..a4d0bc77
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/routing.js
@@ -0,0 +1,52 @@
+exports.setLocation = function setLocation(
+ isReplace,
+ activeSort,
+ isFlat,
+ activeFilters,
+ fileFilter,
+ expandedLines
+) {
+ const params = [
+ activeSort.sortKey,
+ activeSort.order,
+ isFlat,
+ activeFilters.low,
+ activeFilters.medium,
+ activeFilters.high,
+ encodeURIComponent(fileFilter),
+ expandedLines.map(encodeURIComponent).join(',')
+ ];
+ const newUrl = `#${params.join('/')}`;
+
+ if (newUrl === location.hash) {
+ return;
+ }
+
+ window.history[isReplace ? 'replaceState' : 'pushState'](null, '', newUrl);
+};
+
+exports.decodeLocation = function decodeLocation() {
+ const items = location.hash.substr(1).split('/');
+ if (items.length !== 8) {
+ return null;
+ }
+
+ try {
+ return {
+ activeSort: {
+ sortKey: items[0],
+ order: items[1]
+ },
+ isFlat: JSON.parse(items[2]),
+ activeFilters: {
+ low: JSON.parse(items[3]),
+ medium: JSON.parse(items[4]),
+ high: JSON.parse(items[5])
+ },
+ fileFilter: decodeURIComponent(items[6]),
+ expandedLines: items[7].split(',').map(decodeURIComponent)
+ };
+ } catch (e) {
+ return null;
+ }
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/summaryHeader.js b/node_modules/istanbul-reports/lib/html-spa/src/summaryHeader.js
new file mode 100644
index 00000000..3bdd8ffb
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/summaryHeader.js
@@ -0,0 +1,63 @@
+const React = require('react');
+
+function Ignores({ metrics, metricsToShow }) {
+ const metricKeys = Object.keys(metricsToShow);
+ const result = [];
+
+ for (let i = 0; i < metricKeys.length; i++) {
+ const metricKey = metricKeys[i];
+ if (metricsToShow[metricKey]) {
+ const skipped = metrics[metricKey].skipped;
+ if (skipped > 0) {
+ result.push(
+ `${skipped} ${metricKey}${
+ skipped === 1 ? '' : metricKey === 'branch' ? 'es' : 's'
+ }`
+ );
+ }
+ }
+ }
+
+ if (result.length === 0) {
+ return false;
+ }
+
+ return (
+
+ {result.join(', ')}
+ Ignored
+
+ );
+}
+
+function StatusMetric({ data, name }) {
+ return (
+
+ {data.pct}%{' '}
+ {name}{' '}
+
+ {data.covered}/{data.total}
+
+
+ );
+}
+
+module.exports = function SummaryHeader({ metrics, metricsToShow }) {
+ return (
+
+ {metricsToShow.statements && (
+
+ )}
+ {metricsToShow.branches && (
+
+ )}
+ {metricsToShow.functions && (
+
+ )}
+ {metricsToShow.lines && (
+
+ )}
+
+
+ );
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/summaryTableHeader.js b/node_modules/istanbul-reports/lib/html-spa/src/summaryTableHeader.js
new file mode 100644
index 00000000..c27b3ce0
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/summaryTableHeader.js
@@ -0,0 +1,124 @@
+const React = require('react');
+
+function getSortDetails(sortKey, activeSort) {
+ let newSort = { sortKey, order: 'desc' };
+ let sortClass = '';
+ if (activeSort && activeSort.sortKey === sortKey) {
+ sortClass = 'sorted';
+ if (activeSort.order === 'desc') {
+ sortClass += '-desc';
+ newSort.order = 'asc';
+ } else {
+ if (sortKey !== 'file') {
+ newSort = { sortKey: 'file', order: 'desc' };
+ }
+ }
+ }
+
+ return {
+ newSort,
+ sortClass
+ };
+}
+
+function SummaryTableHeaderCell({ name, onSort, sortKey, activeSort }) {
+ const { newSort, sortClass } = getSortDetails(sortKey, activeSort);
+ return (
+ onSort(newSort)}
+ >
+ {name}
+
+ |
+ );
+}
+
+function FileHeaderCell({ onSort, activeSort }) {
+ const { newSort, sortClass } = getSortDetails('file', activeSort);
+
+ return (
+ onSort(newSort)}
+ >
+ File
+
+ |
+ );
+}
+
+function SubHeadings({ sortKeyPrefix, onSort, activeSort }) {
+ return (
+ <>
+
+ |
+
+
+ >
+ );
+}
+
+module.exports = function SummaryTableHeader({
+ onSort,
+ activeSort,
+ metricsToShow
+}) {
+ return (
+
+
+ |
+ {metricsToShow.statements && Statements | }
+ {metricsToShow.branches && Branches | }
+ {metricsToShow.functions && Functions | }
+ {metricsToShow.lines && Lines | }
+
+
+
+ {metricsToShow.statements && (
+
+ )}
+ {metricsToShow.branches && (
+
+ )}
+ {metricsToShow.functions && (
+
+ )}
+ {metricsToShow.lines && (
+
+ )}
+
+
+ );
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/src/summaryTableLine.js b/node_modules/istanbul-reports/lib/html-spa/src/summaryTableLine.js
new file mode 100644
index 00000000..be4f9508
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/src/summaryTableLine.js
@@ -0,0 +1,158 @@
+const React = require('react');
+
+function MetricCells({ metrics }) {
+ const { classForPercent, pct, covered, total } = metrics;
+
+ return (
+ <>
+ {Math.round(pct)}% |
+
+
+ |
+ {covered} |
+ {total} |
+ >
+ );
+}
+
+function FileCell({
+ file,
+ prefix,
+ expandedLines,
+ setExpandedLines,
+ hasChildren,
+ setFileFilter
+}) {
+ if (hasChildren) {
+ const expandedIndex = expandedLines.indexOf(prefix + file);
+ const isExpanded = expandedIndex >= 0;
+ const newExpandedLines = isExpanded
+ ? [
+ ...expandedLines.slice(0, expandedIndex),
+ ...expandedLines.slice(expandedIndex + 1)
+ ]
+ : [...expandedLines, prefix + file];
+
+ return (
+ <>
+
+ setFileFilter(prefix + file)}
+ >
+ {file}
+
+ >
+ );
+ } else {
+ return {file};
+ }
+}
+
+function getWorstMetricClassForPercent(metricsToShow, metrics) {
+ let classForPercent = 'none';
+ for (const metricToShow in metricsToShow) {
+ if (metricsToShow[metricToShow]) {
+ const metricClassForPercent = metrics[metricToShow].classForPercent;
+
+ // ignore none metrics so they don't change whats shown
+ if (metricClassForPercent === 'none') {
+ continue;
+ }
+
+ // if the metric low or lower than whats currently being used, replace it
+ if (
+ metricClassForPercent == 'low' ||
+ (metricClassForPercent === 'medium' &&
+ classForPercent !== 'low') ||
+ (metricClassForPercent === 'high' &&
+ classForPercent !== 'low' &&
+ classForPercent !== 'medium')
+ ) {
+ classForPercent = metricClassForPercent;
+ }
+ }
+ }
+ return classForPercent;
+}
+
+module.exports = function SummaryTableLine({
+ prefix,
+ metrics,
+ file,
+ children,
+ tabSize,
+ metricsToShow,
+ expandedLines,
+ setExpandedLines,
+ fileFilter,
+ setFileFilter
+}) {
+ tabSize = tabSize || 0;
+ if (children && tabSize > 0) {
+ tabSize--;
+ }
+ prefix = (fileFilter ? fileFilter + '/' : '') + (prefix || '');
+
+ return (
+ <>
+
+ |
+ {/* eslint-disable-line prefer-spread */ Array.apply(null, {
+ length: tabSize
+ }).map((nothing, index) => (
+
+ ))}
+
+ |
+ {metricsToShow.statements && (
+
+ )}
+ {metricsToShow.branches && (
+
+ )}
+ {metricsToShow.functions && (
+
+ )}
+ {metricsToShow.lines && }
+
+ {children &&
+ expandedLines.indexOf(prefix + file) >= 0 &&
+ children.map(child => (
+
+ ))}
+ >
+ );
+};
diff --git a/node_modules/istanbul-reports/lib/html-spa/webpack.config.js b/node_modules/istanbul-reports/lib/html-spa/webpack.config.js
new file mode 100644
index 00000000..02a2d6c2
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html-spa/webpack.config.js
@@ -0,0 +1,22 @@
+'use strict';
+
+const path = require('path');
+
+module.exports = {
+ entry: path.resolve(__dirname, 'src/index.js'),
+ output: {
+ path: path.resolve(__dirname, 'assets'),
+ filename: 'bundle.js'
+ },
+ module: {
+ rules: [
+ {
+ test: /\.js$/,
+ exclude: /node_modules/,
+ use: {
+ loader: 'babel-loader'
+ }
+ }
+ ]
+ }
+};
diff --git a/node_modules/istanbul-reports/lib/html/annotator.js b/node_modules/istanbul-reports/lib/html/annotator.js
new file mode 100644
index 00000000..c385b785
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html/annotator.js
@@ -0,0 +1,269 @@
+/*
+ Copyright 2012-2015, Yahoo Inc.
+ Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.
+ */
+'use strict';
+
+const InsertionText = require('./insertion-text');
+const lt = '\u0001';
+const gt = '\u0002';
+const RE_LT = //g;
+const RE_AMP = /&/g;
+// eslint-disable-next-line
+var RE_lt = /\u0001/g;
+// eslint-disable-next-line
+var RE_gt = /\u0002/g;
+
+function title(str) {
+ return ' title="' + str + '" ';
+}
+
+function customEscape(text) {
+ text = String(text);
+ return text
+ .replace(RE_AMP, '&')
+ .replace(RE_LT, '<')
+ .replace(RE_GT, '>')
+ .replace(RE_lt, '<')
+ .replace(RE_gt, '>');
+}
+
+function annotateLines(fileCoverage, structuredText) {
+ const lineStats = fileCoverage.getLineCoverage();
+ if (!lineStats) {
+ return;
+ }
+ Object.entries(lineStats).forEach(([lineNumber, count]) => {
+ if (structuredText[lineNumber]) {
+ structuredText[lineNumber].covered = count > 0 ? 'yes' : 'no';
+ structuredText[lineNumber].hits = count;
+ }
+ });
+}
+
+function annotateStatements(fileCoverage, structuredText) {
+ const statementStats = fileCoverage.s;
+ const statementMeta = fileCoverage.statementMap;
+ Object.entries(statementStats).forEach(([stName, count]) => {
+ const meta = statementMeta[stName];
+ const type = count > 0 ? 'yes' : 'no';
+ const startCol = meta.start.column;
+ let endCol = meta.end.column + 1;
+ const startLine = meta.start.line;
+ const endLine = meta.end.line;
+ const openSpan =
+ lt +
+ 'span class="' +
+ (meta.skip ? 'cstat-skip' : 'cstat-no') +
+ '"' +
+ title('statement not covered') +
+ gt;
+ const closeSpan = lt + '/span' + gt;
+ let text;
+
+ if (type === 'no' && structuredText[startLine]) {
+ if (endLine !== startLine) {
+ endCol = structuredText[startLine].text.originalLength();
+ }
+ text = structuredText[startLine].text;
+ text.wrap(
+ startCol,
+ openSpan,
+ startCol < endCol ? endCol : text.originalLength(),
+ closeSpan
+ );
+ }
+ });
+}
+
+function annotateFunctions(fileCoverage, structuredText) {
+ const fnStats = fileCoverage.f;
+ const fnMeta = fileCoverage.fnMap;
+ if (!fnStats) {
+ return;
+ }
+ Object.entries(fnStats).forEach(([fName, count]) => {
+ const meta = fnMeta[fName];
+ const type = count > 0 ? 'yes' : 'no';
+ const startCol = meta.decl.start.column;
+ let endCol = meta.decl.end.column + 1;
+ const startLine = meta.decl.start.line;
+ const endLine = meta.decl.end.line;
+ const openSpan =
+ lt +
+ 'span class="' +
+ (meta.skip ? 'fstat-skip' : 'fstat-no') +
+ '"' +
+ title('function not covered') +
+ gt;
+ const closeSpan = lt + '/span' + gt;
+ let text;
+
+ if (type === 'no' && structuredText[startLine]) {
+ if (endLine !== startLine) {
+ endCol = structuredText[startLine].text.originalLength();
+ }
+ text = structuredText[startLine].text;
+ text.wrap(
+ startCol,
+ openSpan,
+ startCol < endCol ? endCol : text.originalLength(),
+ closeSpan
+ );
+ }
+ });
+}
+
+function annotateBranches(fileCoverage, structuredText) {
+ const branchStats = fileCoverage.b;
+ const branchMeta = fileCoverage.branchMap;
+ if (!branchStats) {
+ return;
+ }
+
+ Object.entries(branchStats).forEach(([branchName, branchArray]) => {
+ const sumCount = branchArray.reduce((p, n) => p + n, 0);
+ const metaArray = branchMeta[branchName].locations;
+ let i;
+ let count;
+ let meta;
+ let startCol;
+ let endCol;
+ let startLine;
+ let endLine;
+ let openSpan;
+ let closeSpan;
+ let text;
+
+ // only highlight if partial branches are missing or if there is a
+ // single uncovered branch.
+ if (sumCount > 0 || (sumCount === 0 && branchArray.length === 1)) {
+ for (
+ i = 0;
+ i < branchArray.length && i < metaArray.length;
+ i += 1
+ ) {
+ count = branchArray[i];
+ meta = metaArray[i];
+ startCol = meta.start.column;
+ endCol = meta.end.column + 1;
+ startLine = meta.start.line;
+ endLine = meta.end.line;
+ openSpan =
+ lt +
+ 'span class="branch-' +
+ i +
+ ' ' +
+ (meta.skip ? 'cbranch-skip' : 'cbranch-no') +
+ '"' +
+ title('branch not covered') +
+ gt;
+ closeSpan = lt + '/span' + gt;
+
+ if (count === 0 && structuredText[startLine]) {
+ //skip branches taken
+ if (endLine !== startLine) {
+ endCol = structuredText[
+ startLine
+ ].text.originalLength();
+ }
+ text = structuredText[startLine].text;
+ if (branchMeta[branchName].type === 'if') {
+ // 'if' is a special case
+ // since the else branch might not be visible, being non-existent
+ text.insertAt(
+ startCol,
+ lt +
+ 'span class="' +
+ (meta.skip
+ ? 'skip-if-branch'
+ : 'missing-if-branch') +
+ '"' +
+ title(
+ (i === 0 ? 'if' : 'else') +
+ ' path not taken'
+ ) +
+ gt +
+ (i === 0 ? 'I' : 'E') +
+ lt +
+ '/span' +
+ gt,
+ true,
+ false
+ );
+ } else {
+ text.wrap(
+ startCol,
+ openSpan,
+ startCol < endCol ? endCol : text.originalLength(),
+ closeSpan
+ );
+ }
+ }
+ }
+ }
+ });
+}
+
+function annotateSourceCode(fileCoverage, sourceStore) {
+ let codeArray;
+ let lineCoverageArray;
+ try {
+ const sourceText = sourceStore.getSource(fileCoverage.path);
+ const code = sourceText.split(/(?:\r?\n)|\r/);
+ let count = 0;
+ const structured = code.map(str => {
+ count += 1;
+ return {
+ line: count,
+ covered: 'neutral',
+ hits: 0,
+ text: new InsertionText(str, true)
+ };
+ });
+ structured.unshift({
+ line: 0,
+ covered: null,
+ text: new InsertionText('')
+ });
+ annotateLines(fileCoverage, structured);
+ //note: order is important, since statements typically result in spanning the whole line and doing branches late
+ //causes mismatched tags
+ annotateBranches(fileCoverage, structured);
+ annotateFunctions(fileCoverage, structured);
+ annotateStatements(fileCoverage, structured);
+ structured.shift();
+
+ codeArray = structured.map(
+ item => customEscape(item.text.toString()) || ' '
+ );
+
+ lineCoverageArray = structured.map(item => ({
+ covered: item.covered,
+ hits: item.hits > 0 ? item.hits + 'x' : ' '
+ }));
+
+ return {
+ annotatedCode: codeArray,
+ lineCoverage: lineCoverageArray,
+ maxLines: structured.length
+ };
+ } catch (ex) {
+ codeArray = [ex.message];
+ lineCoverageArray = [{ covered: 'no', hits: 0 }];
+ String(ex.stack || '')
+ .split(/\r?\n/)
+ .forEach(line => {
+ codeArray.push(line);
+ lineCoverageArray.push({ covered: 'no', hits: 0 });
+ });
+ return {
+ annotatedCode: codeArray,
+ lineCoverage: lineCoverageArray,
+ maxLines: codeArray.length
+ };
+ }
+}
+
+module.exports = annotateSourceCode;
diff --git a/node_modules/istanbul-reports/lib/html/assets/base.css b/node_modules/istanbul-reports/lib/html/assets/base.css
new file mode 100644
index 00000000..f418035b
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html/assets/base.css
@@ -0,0 +1,224 @@
+body, html {
+ margin:0; padding: 0;
+ height: 100%;
+}
+body {
+ font-family: Helvetica Neue, Helvetica, Arial;
+ font-size: 14px;
+ color:#333;
+}
+.small { font-size: 12px; }
+*, *:after, *:before {
+ -webkit-box-sizing:border-box;
+ -moz-box-sizing:border-box;
+ box-sizing:border-box;
+ }
+h1 { font-size: 20px; margin: 0;}
+h2 { font-size: 14px; }
+pre {
+ font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
+ margin: 0;
+ padding: 0;
+ -moz-tab-size: 2;
+ -o-tab-size: 2;
+ tab-size: 2;
+}
+a { color:#0074D9; text-decoration:none; }
+a:hover { text-decoration:underline; }
+.strong { font-weight: bold; }
+.space-top1 { padding: 10px 0 0 0; }
+.pad2y { padding: 20px 0; }
+.pad1y { padding: 10px 0; }
+.pad2x { padding: 0 20px; }
+.pad2 { padding: 20px; }
+.pad1 { padding: 10px; }
+.space-left2 { padding-left:55px; }
+.space-right2 { padding-right:20px; }
+.center { text-align:center; }
+.clearfix { display:block; }
+.clearfix:after {
+ content:'';
+ display:block;
+ height:0;
+ clear:both;
+ visibility:hidden;
+ }
+.fl { float: left; }
+@media only screen and (max-width:640px) {
+ .col3 { width:100%; max-width:100%; }
+ .hide-mobile { display:none!important; }
+}
+
+.quiet {
+ color: #7f7f7f;
+ color: rgba(0,0,0,0.5);
+}
+.quiet a { opacity: 0.7; }
+
+.fraction {
+ font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
+ font-size: 10px;
+ color: #555;
+ background: #E8E8E8;
+ padding: 4px 5px;
+ border-radius: 3px;
+ vertical-align: middle;
+}
+
+div.path a:link, div.path a:visited { color: #333; }
+table.coverage {
+ border-collapse: collapse;
+ margin: 10px 0 0 0;
+ padding: 0;
+}
+
+table.coverage td {
+ margin: 0;
+ padding: 0;
+ vertical-align: top;
+}
+table.coverage td.line-count {
+ text-align: right;
+ padding: 0 5px 0 20px;
+}
+table.coverage td.line-coverage {
+ text-align: right;
+ padding-right: 10px;
+ min-width:20px;
+}
+
+table.coverage td span.cline-any {
+ display: inline-block;
+ padding: 0 5px;
+ width: 100%;
+}
+.missing-if-branch {
+ display: inline-block;
+ margin-right: 5px;
+ border-radius: 3px;
+ position: relative;
+ padding: 0 4px;
+ background: #333;
+ color: yellow;
+}
+
+.skip-if-branch {
+ display: none;
+ margin-right: 10px;
+ position: relative;
+ padding: 0 4px;
+ background: #ccc;
+ color: white;
+}
+.missing-if-branch .typ, .skip-if-branch .typ {
+ color: inherit !important;
+}
+.coverage-summary {
+ border-collapse: collapse;
+ width: 100%;
+}
+.coverage-summary tr { border-bottom: 1px solid #bbb; }
+.keyline-all { border: 1px solid #ddd; }
+.coverage-summary td, .coverage-summary th { padding: 10px; }
+.coverage-summary tbody { border: 1px solid #bbb; }
+.coverage-summary td { border-right: 1px solid #bbb; }
+.coverage-summary td:last-child { border-right: none; }
+.coverage-summary th {
+ text-align: left;
+ font-weight: normal;
+ white-space: nowrap;
+}
+.coverage-summary th.file { border-right: none !important; }
+.coverage-summary th.pct { }
+.coverage-summary th.pic,
+.coverage-summary th.abs,
+.coverage-summary td.pct,
+.coverage-summary td.abs { text-align: right; }
+.coverage-summary td.file { white-space: nowrap; }
+.coverage-summary td.pic { min-width: 120px !important; }
+.coverage-summary tfoot td { }
+
+.coverage-summary .sorter {
+ height: 10px;
+ width: 7px;
+ display: inline-block;
+ margin-left: 0.5em;
+ background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
+}
+.coverage-summary .sorted .sorter {
+ background-position: 0 -20px;
+}
+.coverage-summary .sorted-desc .sorter {
+ background-position: 0 -10px;
+}
+.status-line { height: 10px; }
+/* yellow */
+.cbranch-no { background: yellow !important; color: #111; }
+/* dark red */
+.red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
+.low .chart { border:1px solid #C21F39 }
+.highlighted,
+.highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{
+ background: #C21F39 !important;
+}
+/* medium red */
+.cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
+/* light red */
+.low, .cline-no { background:#FCE1E5 }
+/* light green */
+.high, .cline-yes { background:rgb(230,245,208) }
+/* medium green */
+.cstat-yes { background:rgb(161,215,106) }
+/* dark green */
+.status-line.high, .high .cover-fill { background:rgb(77,146,33) }
+.high .chart { border:1px solid rgb(77,146,33) }
+/* dark yellow (gold) */
+.status-line.medium, .medium .cover-fill { background: #f9cd0b; }
+.medium .chart { border:1px solid #f9cd0b; }
+/* light yellow */
+.medium { background: #fff4c2; }
+
+.cstat-skip { background: #ddd; color: #111; }
+.fstat-skip { background: #ddd; color: #111 !important; }
+.cbranch-skip { background: #ddd !important; color: #111; }
+
+span.cline-neutral { background: #eaeaea; }
+
+.coverage-summary td.empty {
+ opacity: .5;
+ padding-top: 4px;
+ padding-bottom: 4px;
+ line-height: 1;
+ color: #888;
+}
+
+.cover-fill, .cover-empty {
+ display:inline-block;
+ height: 12px;
+}
+.chart {
+ line-height: 0;
+}
+.cover-empty {
+ background: white;
+}
+.cover-full {
+ border-right: none !important;
+}
+pre.prettyprint {
+ border: none !important;
+ padding: 0 !important;
+ margin: 0 !important;
+}
+.com { color: #999 !important; }
+.ignore-none { color: #999; font-weight: normal; }
+
+.wrapper {
+ min-height: 100%;
+ height: auto !important;
+ height: 100%;
+ margin: 0 auto -48px;
+}
+.footer, .push {
+ height: 48px;
+}
diff --git a/node_modules/istanbul-reports/lib/html/assets/block-navigation.js b/node_modules/istanbul-reports/lib/html/assets/block-navigation.js
new file mode 100644
index 00000000..abed602d
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html/assets/block-navigation.js
@@ -0,0 +1,78 @@
+var jumpToCode = (function init() {
+ // Classes of code we would like to highlight in the file view
+ var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];
+
+ // Elements to highlight in the file listing view
+ var fileListingElements = ['td.pct.low'];
+
+ // 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 =
+ fileListingElements.join(', ') +
+ ', ' +
+ 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);
diff --git a/node_modules/istanbul-reports/lib/html/assets/favicon.png b/node_modules/istanbul-reports/lib/html/assets/favicon.png
new file mode 100644
index 00000000..66918178
Binary files /dev/null and b/node_modules/istanbul-reports/lib/html/assets/favicon.png differ
diff --git a/node_modules/istanbul-reports/lib/html/assets/sort-arrow-sprite.png b/node_modules/istanbul-reports/lib/html/assets/sort-arrow-sprite.png
new file mode 100644
index 00000000..03f704a6
Binary files /dev/null and b/node_modules/istanbul-reports/lib/html/assets/sort-arrow-sprite.png differ
diff --git a/node_modules/istanbul-reports/lib/html/assets/sorter.js b/node_modules/istanbul-reports/lib/html/assets/sorter.js
new file mode 100644
index 00000000..878725e0
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html/assets/sorter.js
@@ -0,0 +1,169 @@
+var addSorting = (function() {
+ 'use strict';
+ var cols,
+ currentSort = {
+ index: 0,
+ desc: false
+ };
+
+ // returns the summary table element
+ function getTable() {
+ return document.querySelector('.coverage-summary');
+ }
+ // returns the thead element of the summary table
+ function getTableHeader() {
+ return getTable().querySelector('thead tr');
+ }
+ // returns the tbody element of the summary table
+ function getTableBody() {
+ return getTable().querySelector('tbody');
+ }
+ // returns the th element for nth column
+ function getNthColumn(n) {
+ return getTableHeader().querySelectorAll('th')[n];
+ }
+
+ // loads all columns
+ function loadColumns() {
+ var colNodes = getTableHeader().querySelectorAll('th'),
+ colNode,
+ cols = [],
+ col,
+ i;
+
+ for (i = 0; i < colNodes.length; i += 1) {
+ colNode = colNodes[i];
+ col = {
+ key: colNode.getAttribute('data-col'),
+ sortable: !colNode.getAttribute('data-nosort'),
+ type: colNode.getAttribute('data-type') || 'string'
+ };
+ cols.push(col);
+ if (col.sortable) {
+ col.defaultDescSort = col.type === 'number';
+ colNode.innerHTML =
+ colNode.innerHTML + '';
+ }
+ }
+ return cols;
+ }
+ // attaches a data attribute to every tr element with an object
+ // of data values keyed by column name
+ function loadRowData(tableRow) {
+ var tableCols = tableRow.querySelectorAll('td'),
+ colNode,
+ col,
+ data = {},
+ i,
+ val;
+ for (i = 0; i < tableCols.length; i += 1) {
+ colNode = tableCols[i];
+ col = cols[i];
+ val = colNode.getAttribute('data-value');
+ if (col.type === 'number') {
+ val = Number(val);
+ }
+ data[col.key] = val;
+ }
+ return data;
+ }
+ // loads all row data
+ function loadData() {
+ var rows = getTableBody().querySelectorAll('tr'),
+ i;
+
+ for (i = 0; i < rows.length; i += 1) {
+ rows[i].data = loadRowData(rows[i]);
+ }
+ }
+ // sorts the table using the data for the ith column
+ function sortByIndex(index, desc) {
+ var key = cols[index].key,
+ sorter = function(a, b) {
+ a = a.data[key];
+ b = b.data[key];
+ return a < b ? -1 : a > b ? 1 : 0;
+ },
+ finalSorter = sorter,
+ tableBody = document.querySelector('.coverage-summary tbody'),
+ rowNodes = tableBody.querySelectorAll('tr'),
+ rows = [],
+ i;
+
+ if (desc) {
+ finalSorter = function(a, b) {
+ return -1 * sorter(a, b);
+ };
+ }
+
+ for (i = 0; i < rowNodes.length; i += 1) {
+ rows.push(rowNodes[i]);
+ tableBody.removeChild(rowNodes[i]);
+ }
+
+ rows.sort(finalSorter);
+
+ for (i = 0; i < rows.length; i += 1) {
+ tableBody.appendChild(rows[i]);
+ }
+ }
+ // removes sort indicators for current column being sorted
+ function removeSortIndicators() {
+ var col = getNthColumn(currentSort.index),
+ cls = col.className;
+
+ cls = cls.replace(/ sorted$/, '').replace(/ sorted-desc$/, '');
+ col.className = cls;
+ }
+ // adds sort indicators for current column being sorted
+ function addSortIndicators() {
+ getNthColumn(currentSort.index).className += currentSort.desc
+ ? ' sorted-desc'
+ : ' sorted';
+ }
+ // adds event listeners for all sorter widgets
+ function enableUI() {
+ var i,
+ el,
+ ithSorter = function ithSorter(i) {
+ var col = cols[i];
+
+ return function() {
+ var desc = col.defaultDescSort;
+
+ if (currentSort.index === i) {
+ desc = !currentSort.desc;
+ }
+ sortByIndex(i, desc);
+ removeSortIndicators();
+ currentSort.index = i;
+ currentSort.desc = desc;
+ addSortIndicators();
+ };
+ };
+ for (i = 0; i < cols.length; i += 1) {
+ if (cols[i].sortable) {
+ // add the click event handler on the th so users
+ // dont have to click on those tiny arrows
+ el = getNthColumn(i).querySelector('.sorter').parentElement;
+ if (el.addEventListener) {
+ el.addEventListener('click', ithSorter(i));
+ } else {
+ el.attachEvent('onclick', ithSorter(i));
+ }
+ }
+ }
+ }
+ // adds sorting functionality to the UI
+ return function() {
+ if (!getTable()) {
+ return;
+ }
+ cols = loadColumns();
+ loadData();
+ addSortIndicators();
+ enableUI();
+ };
+})();
+
+window.addEventListener('load', addSorting);
diff --git a/node_modules/istanbul-reports/lib/html/assets/vendor/prettify.css b/node_modules/istanbul-reports/lib/html/assets/vendor/prettify.css
new file mode 100644
index 00000000..b317a7cd
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html/assets/vendor/prettify.css
@@ -0,0 +1 @@
+.pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee}
diff --git a/node_modules/istanbul-reports/lib/html/assets/vendor/prettify.js b/node_modules/istanbul-reports/lib/html/assets/vendor/prettify.js
new file mode 100644
index 00000000..ef51e038
--- /dev/null
+++ b/node_modules/istanbul-reports/lib/html/assets/vendor/prettify.js
@@ -0,0 +1 @@
+window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;arat[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^
+
+
+
+