mirror of
https://gitlab.ub.uni-bielefeld.de/sfb1288inf/nopaque.git
synced 2025-06-12 00:50:40 +00:00
Reviewed Job Package
This commit is contained in:
@ -21,3 +21,11 @@ Requests.jobs.entity.log = (jobId) => {
|
||||
};
|
||||
return Requests.JSONfetch(input, init);
|
||||
}
|
||||
|
||||
Requests.jobs.entity.restart = (jobId) => {
|
||||
let input = `/jobs/${jobId}/restart`;
|
||||
let init = {
|
||||
method: 'POST'
|
||||
};
|
||||
return Requests.JSONfetch(input, init);
|
||||
}
|
||||
|
@ -2,16 +2,6 @@ class JobDisplay extends ResourceDisplay {
|
||||
constructor(displayElement) {
|
||||
super(displayElement);
|
||||
this.jobId = this.displayElement.dataset.jobId;
|
||||
this.displayElement
|
||||
.querySelector('.action-button[data-action="get-log-request"]')
|
||||
.addEventListener('click', (event) => {
|
||||
Utils.getJobLogRequest(this.userId, this.jobId);
|
||||
});
|
||||
this.displayElement
|
||||
.querySelector('.action-button[data-action="restart-request"]')
|
||||
.addEventListener('click', (event) => {
|
||||
Utils.restartJobRequest(this.userId, this.jobId);
|
||||
});
|
||||
}
|
||||
|
||||
init(user) {
|
||||
|
@ -229,138 +229,138 @@ class Utils {
|
||||
});
|
||||
}
|
||||
|
||||
static deleteJobRequest(userId, jobId) {
|
||||
return new Promise((resolve, reject) => {
|
||||
let job;
|
||||
try {
|
||||
job = app.data.users[userId].jobs[jobId];
|
||||
} catch (error) {
|
||||
job = {};
|
||||
}
|
||||
// static deleteJobRequest(userId, jobId) {
|
||||
// return new Promise((resolve, reject) => {
|
||||
// let job;
|
||||
// try {
|
||||
// job = app.data.users[userId].jobs[jobId];
|
||||
// } catch (error) {
|
||||
// job = {};
|
||||
// }
|
||||
|
||||
let confirmElement = modalElement.querySelector('.action-button[data-action="confirm"]');
|
||||
confirmElement.addEventListener('click', (event) => {
|
||||
let jobTitle = job?.title;
|
||||
fetch(`/jobs/${jobId}`, {method: 'DELETE', headers: {Accept: 'application/json'}})
|
||||
.then(
|
||||
(response) => {
|
||||
if (response.status === 403) {app.flash('Forbidden', 'error'); reject(response);}
|
||||
if (response.status === 404) {app.flash('Not Found', 'error'); reject(response);}
|
||||
app.flash(`Job "${jobTitle}" marked for deletion`, 'job');
|
||||
resolve(response);
|
||||
},
|
||||
(response) => {
|
||||
app.flash('Something went wrong', 'error');
|
||||
reject(response);
|
||||
}
|
||||
);
|
||||
});
|
||||
modal.open();
|
||||
});
|
||||
}
|
||||
// let confirmElement = modalElement.querySelector('.action-button[data-action="confirm"]');
|
||||
// confirmElement.addEventListener('click', (event) => {
|
||||
// let jobTitle = job?.title;
|
||||
// fetch(`/jobs/${jobId}`, {method: 'DELETE', headers: {Accept: 'application/json'}})
|
||||
// .then(
|
||||
// (response) => {
|
||||
// if (response.status === 403) {app.flash('Forbidden', 'error'); reject(response);}
|
||||
// if (response.status === 404) {app.flash('Not Found', 'error'); reject(response);}
|
||||
// app.flash(`Job "${jobTitle}" marked for deletion`, 'job');
|
||||
// resolve(response);
|
||||
// },
|
||||
// (response) => {
|
||||
// app.flash('Something went wrong', 'error');
|
||||
// reject(response);
|
||||
// }
|
||||
// );
|
||||
// });
|
||||
// modal.open();
|
||||
// });
|
||||
// }
|
||||
|
||||
static getJobLogRequest(userId, jobId) {
|
||||
return new Promise((resolve, reject) => {
|
||||
fetch(`/jobs/${jobId}/log`, {method: 'GET', headers: {Accept: 'application/json, text/plain'}})
|
||||
.then(
|
||||
(response) => {
|
||||
if (response.status === 403) {app.flash('Forbidden', 'error'); reject(response);}
|
||||
if (response.status === 404) {app.flash('Not Found', 'error'); reject(response);}
|
||||
return response.text();
|
||||
},
|
||||
(response) => {
|
||||
app.flash('Something went wrong', 'error');
|
||||
reject(response);
|
||||
}
|
||||
)
|
||||
.then(
|
||||
(text) => {
|
||||
let modalElement = Utils.HTMLToElement(
|
||||
`
|
||||
<div class="modal">
|
||||
<div class="modal-content">
|
||||
<h4>Job logs</h4>
|
||||
<pre><code>${text}</code></pre>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<a class="btn modal-close waves-effect waves-light">Close</a>
|
||||
</div>
|
||||
</div>
|
||||
`
|
||||
);
|
||||
document.querySelector('#modals').appendChild(modalElement);
|
||||
let modal = M.Modal.init(
|
||||
modalElement,
|
||||
{
|
||||
onCloseEnd: () => {
|
||||
modal.destroy();
|
||||
modalElement.remove();
|
||||
}
|
||||
}
|
||||
);
|
||||
modal.open();
|
||||
resolve(text);
|
||||
}
|
||||
);
|
||||
});
|
||||
}
|
||||
// static getJobLogRequest(userId, jobId) {
|
||||
// return new Promise((resolve, reject) => {
|
||||
// fetch(`/jobs/${jobId}/log`, {method: 'GET', headers: {Accept: 'application/json, text/plain'}})
|
||||
// .then(
|
||||
// (response) => {
|
||||
// if (response.status === 403) {app.flash('Forbidden', 'error'); reject(response);}
|
||||
// if (response.status === 404) {app.flash('Not Found', 'error'); reject(response);}
|
||||
// return response.text();
|
||||
// },
|
||||
// (response) => {
|
||||
// app.flash('Something went wrong', 'error');
|
||||
// reject(response);
|
||||
// }
|
||||
// )
|
||||
// .then(
|
||||
// (text) => {
|
||||
// let modalElement = Utils.HTMLToElement(
|
||||
// `
|
||||
// <div class="modal">
|
||||
// <div class="modal-content">
|
||||
// <h4>Job logs</h4>
|
||||
// <pre><code>${text}</code></pre>
|
||||
// </div>
|
||||
// <div class="modal-footer">
|
||||
// <a class="btn modal-close waves-effect waves-light">Close</a>
|
||||
// </div>
|
||||
// </div>
|
||||
// `
|
||||
// );
|
||||
// document.querySelector('#modals').appendChild(modalElement);
|
||||
// let modal = M.Modal.init(
|
||||
// modalElement,
|
||||
// {
|
||||
// onCloseEnd: () => {
|
||||
// modal.destroy();
|
||||
// modalElement.remove();
|
||||
// }
|
||||
// }
|
||||
// );
|
||||
// modal.open();
|
||||
// resolve(text);
|
||||
// }
|
||||
// );
|
||||
// });
|
||||
// }
|
||||
|
||||
static restartJobRequest(userId, jobId) {
|
||||
return new Promise((resolve, reject) => {
|
||||
let job;
|
||||
try {
|
||||
job = app.data.users[userId].jobs[jobId];
|
||||
} catch (error) {
|
||||
job = {};
|
||||
}
|
||||
// static restartJobRequest(userId, jobId) {
|
||||
// return new Promise((resolve, reject) => {
|
||||
// let job;
|
||||
// try {
|
||||
// job = app.data.users[userId].jobs[jobId];
|
||||
// } catch (error) {
|
||||
// job = {};
|
||||
// }
|
||||
|
||||
let modalElement = Utils.HTMLToElement(
|
||||
`
|
||||
<div class="modal">
|
||||
<div class="modal-content">
|
||||
<h4>Confirm Job restart</h4>
|
||||
<p>Do you really want to restart the Job <b>${job?.title}</b>? All Job Results will be permanently deleted.</p>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<a class="action-button btn modal-close waves-effect waves-light" data-action="cancel">Cancel</a>
|
||||
<a class="action-button btn modal-close red waves-effect waves-light" data-action="confirm">Restart</a>
|
||||
</div>
|
||||
</div>
|
||||
`
|
||||
);
|
||||
document.querySelector('#modals').appendChild(modalElement);
|
||||
let modal = M.Modal.init(
|
||||
modalElement,
|
||||
{
|
||||
dismissible: false,
|
||||
onCloseEnd: () => {
|
||||
modal.destroy();
|
||||
modalElement.remove();
|
||||
}
|
||||
}
|
||||
);
|
||||
// let modalElement = Utils.HTMLToElement(
|
||||
// `
|
||||
// <div class="modal">
|
||||
// <div class="modal-content">
|
||||
// <h4>Confirm Job restart</h4>
|
||||
// <p>Do you really want to restart the Job <b>${job?.title}</b>? All Job Results will be permanently deleted.</p>
|
||||
// </div>
|
||||
// <div class="modal-footer">
|
||||
// <a class="action-button btn modal-close waves-effect waves-light" data-action="cancel">Cancel</a>
|
||||
// <a class="action-button btn modal-close red waves-effect waves-light" data-action="confirm">Restart</a>
|
||||
// </div>
|
||||
// </div>
|
||||
// `
|
||||
// );
|
||||
// document.querySelector('#modals').appendChild(modalElement);
|
||||
// let modal = M.Modal.init(
|
||||
// modalElement,
|
||||
// {
|
||||
// dismissible: false,
|
||||
// onCloseEnd: () => {
|
||||
// modal.destroy();
|
||||
// modalElement.remove();
|
||||
// }
|
||||
// }
|
||||
// );
|
||||
|
||||
let confirmElement = modalElement.querySelector('.action-button[data-action="confirm"]');
|
||||
confirmElement.addEventListener('click', (event) => {
|
||||
let jobTitle = job?.title;
|
||||
fetch(`/jobs/${jobId}/restart`, {method: 'POST', headers: {Accept: 'application/json'}})
|
||||
.then(
|
||||
(response) => {
|
||||
if (response.status === 403) {app.flash('Forbidden', 'error'); reject(response);}
|
||||
if (response.status === 404) {app.flash('Not Found', 'error'); reject(response);}
|
||||
if (response.status === 409) {app.flash('Conflict', 'error'); reject(response);}
|
||||
app.flash(`Job "${jobTitle}" restarted.`, 'job');
|
||||
resolve(response);
|
||||
},
|
||||
(response) => {
|
||||
app.flash('Something went wrong', 'error');
|
||||
reject(response);
|
||||
}
|
||||
);
|
||||
});
|
||||
modal.open();
|
||||
});
|
||||
}
|
||||
// let confirmElement = modalElement.querySelector('.action-button[data-action="confirm"]');
|
||||
// confirmElement.addEventListener('click', (event) => {
|
||||
// let jobTitle = job?.title;
|
||||
// fetch(`/jobs/${jobId}/restart`, {method: 'POST', headers: {Accept: 'application/json'}})
|
||||
// .then(
|
||||
// (response) => {
|
||||
// if (response.status === 403) {app.flash('Forbidden', 'error'); reject(response);}
|
||||
// if (response.status === 404) {app.flash('Not Found', 'error'); reject(response);}
|
||||
// if (response.status === 409) {app.flash('Conflict', 'error'); reject(response);}
|
||||
// app.flash(`Job "${jobTitle}" restarted.`, 'job');
|
||||
// resolve(response);
|
||||
// },
|
||||
// (response) => {
|
||||
// app.flash('Something went wrong', 'error');
|
||||
// reject(response);
|
||||
// }
|
||||
// );
|
||||
// });
|
||||
// modal.open();
|
||||
// });
|
||||
// }
|
||||
|
||||
static deleteUserRequest(userId) {
|
||||
return new Promise((resolve, reject) => {
|
||||
|
Reference in New Issue
Block a user