1
0
mirror of https://github.com/vladmandic/sdnext.git synced 2026-01-27 15:02:48 +03:00
Files
sdnext/javascript/timesheet.js
Vladimir Mandic d351fdb98f add more job state updates and update history tab
Signed-off-by: Vladimir Mandic <mandic00@live.com>
2025-09-13 10:54:04 -04:00

55 lines
2.1 KiB
JavaScript

/* eslint max-classes-per-file: ["error", 2] */
class Bubble {
constructor(min, start, end, label, scale, type) {
this.type = type;
this.label = label;
this.min = min;
this.start = start;
this.end = end;
this.scale = scale;
this.offset = Math.round(this.scale * (this.start - this.min));
this.width = Math.round(this.scale * (this.end - this.start));
this.duration = Math.round(1000 * (this.end - this.start)) / 1000;
this.title = `Job: ${this.label}\nDuration: ${this.duration}s\nStart: ${new Date(1000 * this.start).toLocaleString()}\nEnd: ${new Date(1000 * this.end).toLocaleString()}`;
}
getDateLabel() {
return Math.round(1000 * (this.end - this.start)) / 1000;
}
}
class Timesheet {
constructor(container, data) {
this.min = Math.floor(data[0].start);
this.max = Math.round(data[data.length - 1].end + 0.5);
this.data = data;
this.container = container;
const box = container.getBoundingClientRect();
const width = box.width - 140;
this.scale = width / (this.max - this.min);
// draw sections
let html = [];
for (let c = 0; c <= this.max - this.min; c++) html.push(`<section style="width: ${this.scale}px;"></section>`);
container.className = 'timesheet color-scheme-default';
container.innerHTML = `<div class="scale"">${html.join('')}</div>`;
// insert data
html = [];
for (let n = 0, m = this.data.length; n < m; n++) {
const cur = this.data[n];
const bubble = new Bubble(this.min, cur.start, cur.end, cur.label, this.scale, cur.type);
const line = [
`<span title="${bubble.title}" style="margin-left: ${bubble.offset}px; width: ${bubble.width}px;" class="bubble bubble-${bubble.type}" data-duration="${bubble.duration}"></span>`,
`<span class="date" title="${bubble.title}">${bubble.duration}</span> `,
`<span class="label" title="${bubble.title}">${bubble.label}</span>`,
].join('');
html.push(`<li>${line}</li>`);
}
this.container.innerHTML += `<ul class="data">${html.join('')}</ul>`;
}
}
window.Timesheet = Timesheet;