blob: a40b2e63a58eaeed58f1db140d4971b2aec1724e [file] [log] [blame]
import './index';
import { $, $$ } from '../../../infra-sk/modules/dom';
import {
AnomalyData,
PlotSimpleSk,
PlotSimpleSkTraceEventDetails,
PlotSimpleSkZoomEventDetails,
} from './plot-simple-sk';
import { Anomaly } from '../json';
import '../../../infra-sk/modules/theme-chooser-sk';
import { MISSING_DATA_SENTINEL } from '../const/const';
import { ticks } from './ticks';
// Create our own random number generator that's deterministic so that we get
// consistent Gold images.
let seed = 1;
const MAX = 1e20;
const random = (): number => {
seed = (seed * 999331) /* a prime number */ % MAX;
return seed / MAX;
};
const dummyAnomaly = (isImprovement: boolean): Anomaly => ({
id: 0,
test_path: '',
bug_id: 123456,
start_revision: 0,
end_revision: 3,
is_improvement: isImprovement,
recovered: true,
state: '',
statistic: '',
units: '',
degrees_of_freedom: 0,
median_before_anomaly: 0,
median_after_anomaly: 0,
p_value: 0,
segment_size_after: 0,
segment_size_before: 0,
std_dev_before_anomaly: 0,
t_statistic: 0,
});
window.customElements.whenDefined('plot-simple-sk').then(() => {
const ele = $$<PlotSimpleSk>('#plot')!;
let n = 0;
let traces: { [name: string]: number[] } = {};
function add(plot: PlotSimpleSk, num: number) {
const labels = [];
for (let i = 0; i < 50; i++) {
labels.push(new Date(1554143900000 + i * i * 5 * 1000 * 60));
}
traces = {};
for (let j = 0; j < num; j++) {
const trace = [];
for (let i = 0; i < 50; i++) {
if (random() < 0.9) {
trace.push(1000000 * (8 + Math.sin(i / 10) + j + random() * 1 + 10));
} else {
trace.push(MISSING_DATA_SENTINEL);
}
}
const id = `trace${j + n}`;
traces[id] = trace;
}
n += num;
plot.addLines(traces, ticks(labels));
}
$<PlotSimpleSk>('plot-simple-sk').forEach((plot) => {
add(plot, 10);
});
$$<HTMLButtonElement>('#add')!.addEventListener('click', () => {
add(ele, 10);
});
$$<HTMLButtonElement>('#addalot')!.addEventListener('click', () => {
add(ele, 100);
});
$$<HTMLButtonElement>('#clear')!.addEventListener('click', () => {
ele.removeAll();
});
$$<HTMLButtonElement>('#reset')!.addEventListener('click', () => {
ele.zoom = null;
});
$$<HTMLButtonElement>('#high')!.addEventListener('click', () => {
ele.highlight = ['trace0', 'trace1'];
});
$$<HTMLButtonElement>('#clearhigh')!.addEventListener('click', () => {
ele.highlight = [];
});
$$<HTMLButtonElement>('#xbar')!.addEventListener('click', () => {
ele.xbar = 3;
});
$$<HTMLButtonElement>('#clearxbar')!.addEventListener('click', () => {
ele.xbar = -1;
});
$$<HTMLButtonElement>('#zoomAction')!.addEventListener('click', () => {
ele.zoom = [20, 40];
});
$$<PlotSimpleSk>('#plot')!.addEventListener('trace_selected', (e) => {
$$('#selected')!.textContent = JSON.stringify(
(e as CustomEvent<PlotSimpleSkTraceEventDetails>).detail
);
});
$$<PlotSimpleSk>('#plot')!.addEventListener('trace_focused', (e) => {
$$('#focused')!.textContent = JSON.stringify(
(e as CustomEvent<PlotSimpleSkTraceEventDetails>).detail
);
});
$$<PlotSimpleSk>('#plot')!.addEventListener('zoom', (e) => {
$$('#zoom')!.textContent = JSON.stringify(
(e as CustomEvent<PlotSimpleSkZoomEventDetails>).detail
);
});
$$<HTMLButtonElement>('#bands')!.addEventListener('click', () => {
ele.bands = [1, 4, 20, 30];
});
$$<HTMLButtonElement>('#toggleDots')!.addEventListener('click', () => {
ele.dots = !ele.dots;
});
$$<HTMLButtonElement>('#special')!.addEventListener('click', () => {
const trace = [];
for (let i = 0; i < 50; i++) {
trace.push(0);
}
ele.addLines({ specialZero: trace }, []);
});
$$<HTMLButtonElement>('#anomaly')!.addEventListener('click', () => {
const anomalyDataMap: { [key: string]: AnomalyData[] } = {};
const keys = Object.keys(traces);
if (keys.length > 0) {
const id = keys[0];
anomalyDataMap[id] = [
{
x: 5,
y: traces[id][5],
anomaly: dummyAnomaly(false),
},
{
x: 20,
y: traces[id][20],
anomaly: dummyAnomaly(true),
},
];
}
ele.anomalyDataMap = anomalyDataMap;
});
$$<HTMLButtonElement>('#clearanomaly')!.addEventListener('click', () => {
ele.anomalyDataMap = {};
});
});