129 lines
3.9 KiB
JavaScript
Raw Permalink Normal View History

nopaque.resource_displays.JobDisplay = class JobDisplay extends nopaque.resource_displays.ResourceDisplay {
static htmlClass = 'job-display';
constructor(displayElement) {
super(displayElement);
2021-11-30 16:22:16 +01:00
this.jobId = this.displayElement.dataset.jobId;
}
2021-11-30 16:22:16 +01:00
init(user) {
2022-09-02 13:07:30 +02:00
let job = user.jobs[this.jobId];
2021-11-30 16:22:16 +01:00
this.setCreationDate(job.creation_date);
this.setEndDate(job.creation_date);
this.setDescription(job.description);
this.setService(job.service);
this.setServiceArgs(job.service_args);
this.setServiceVersion(job.service_version);
this.setStatus(job.status);
this.setTitle(job.title);
}
2022-09-02 13:07:30 +02:00
onPatch(patch) {
let re = new RegExp(`^/users/${this.userId}/jobs/${this.jobId}`);
let filteredPatch = patch.filter(operation => re.test(operation.path));
for (let operation of filteredPatch) {
switch(operation.op) {
2022-09-02 13:07:30 +02:00
case 'remove': {
let re = new RegExp(`^/users/${this.userId}/jobs/${this.jobId}$`);
if (re.test(operation.path)) {
window.location.href = '/dashboard#jobs';
}
break;
}
case 'replace': {
let re = new RegExp(`^/users/${this.userId}/jobs/${this.jobId}/end_date$`);
2021-11-30 16:22:16 +01:00
if (re.test(operation.path)) {
this.setEndDate(operation.value);
break;
}
re = new RegExp(`^/users/${this.userId}/jobs/${this.jobId}/status$`);
if (re.test(operation.path)) {
this.setStatus(operation.value);
break;
}
break;
2022-09-02 13:07:30 +02:00
}
default: {
break;
2022-09-02 13:07:30 +02:00
}
}
}
}
setTitle(title) {
2021-12-01 14:15:20 +01:00
this.setElements(this.displayElement.querySelectorAll('.job-title'), title);
}
setDescription(description) {
2021-12-01 14:15:20 +01:00
this.setElements(this.displayElement.querySelectorAll('.job-description'), description);
}
setStatus(status) {
2022-09-02 13:07:30 +02:00
let elements = this.displayElement.querySelectorAll('.job-status');
for (let element of elements) {
element.dataset.status = status;
}
elements = this.displayElement.querySelectorAll('.job-status-spinner');
2022-09-02 13:07:30 +02:00
for (let element of elements) {
if (['COMPLETED', 'FAILED'].includes(status)) {
element.classList.add('hide');
} else {
element.classList.remove('hide');
}
}
elements = this.displayElement.querySelectorAll('.job-log-trigger');
2022-09-02 13:07:30 +02:00
for (let element of elements) {
if (['COMPLETED', 'FAILED'].includes(status)) {
element.classList.remove('hide');
} else {
element.classList.add('hide');
}
}
2022-09-02 13:07:30 +02:00
elements = this.displayElement.querySelectorAll('.action-button[data-action="get-log-request"]');
for (let element of elements) {
if (['COMPLETED', 'FAILED'].includes(status)) {
2022-09-02 13:07:30 +02:00
element.classList.remove('disabled');
} else {
2022-09-02 13:07:30 +02:00
element.classList.add('disabled');
}
}
elements = this.displayElement.querySelectorAll('.action-button[data-action="restart-request"]');
for (let element of elements) {
if (status === 'FAILED') {
element.classList.remove('disabled');
} else {
element.classList.add('disabled');
}
}
}
2021-11-30 16:22:16 +01:00
setCreationDate(creationDate) {
2021-12-01 14:15:20 +01:00
this.setElements(
this.displayElement.querySelectorAll('.job-creation-date'),
new Date(creationDate).toLocaleString('en-US')
);
}
2021-11-30 16:22:16 +01:00
setEndDate(endDate) {
2021-12-01 14:15:20 +01:00
this.setElements(
this.displayElement.querySelectorAll('.job-end-date'),
new Date(endDate).toLocaleString('en-US')
);
}
setService(service) {
2021-12-01 14:15:20 +01:00
this.setElements(this.displayElement.querySelectorAll('.job-service'), service);
}
setServiceArgs(serviceArgs) {
this.setElements(
this.displayElement.querySelectorAll('.job-service-args'),
JSON.stringify(serviceArgs)
);
}
setServiceVersion(serviceVersion) {
2021-12-01 14:15:20 +01:00
this.setElements(this.displayElement.querySelectorAll('.job-service-version'), serviceVersion);
}
2023-10-05 16:08:04 +02:00
};