mirror of
https://gitlab.ub.uni-bielefeld.de/sfb1288inf/nopaque.git
synced 2025-01-22 07:40:34 +00:00
327 lines
11 KiB
JavaScript
327 lines
11 KiB
JavaScript
|
class Utils {
|
||
|
static elementFromString(string) {
|
||
|
let tmpElement = document.createElement('div');
|
||
|
tmpElement.innerHTML = string.trim();
|
||
|
return tmpElement.firstChild;
|
||
|
}
|
||
|
|
||
|
static buildCorpusRequest(userId, corpusId) {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let corpus = app.data.users[userId].corpora[corpusId];
|
||
|
|
||
|
fetch(`/corpora/${corpus.id}/build`, {method: 'POST', headers: {Accept: 'application/json'}})
|
||
|
.then(
|
||
|
(response) => {
|
||
|
app.flash(`Corpus "${corpus.title}" marked for building`, 'corpus');
|
||
|
resolve(response);
|
||
|
},
|
||
|
(response) => {
|
||
|
if (response.status === 403) {app.flash('Forbidden', 'error');}
|
||
|
if (response.status === 404) {app.flash('Not Found', 'error');}
|
||
|
if (response.status === 409) {app.flash('Conflict', 'error');}
|
||
|
reject(response);
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
static deleteCorpusRequest(userId, corpusId) {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let corpus = app.data.users[userId].corpora[corpusId];
|
||
|
|
||
|
let modalElement = Utils.elementFromString(
|
||
|
`
|
||
|
<div class="modal">
|
||
|
<div class="modal-content">
|
||
|
<h4>Confirm job deletion</h4>
|
||
|
<p>Do you really want to delete the job <b>${corpus.title}</b>? All files 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">Delete</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 corpusTitle = corpus.title;
|
||
|
fetch(`/corpora/${corpus.id}`, {method: 'DELETE', headers: {Accept: 'application/json'}})
|
||
|
.then(
|
||
|
(response) => {
|
||
|
app.flash(`Corpus "${corpusTitle}" marked for deletion`, 'corpus');
|
||
|
resolve(response);
|
||
|
},
|
||
|
(response) => {
|
||
|
if (response.status === 403) {app.flash('Forbidden', 'error');}
|
||
|
if (response.status === 404) {app.flash('Not Found', 'error');}
|
||
|
reject(response);
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
modal.open();
|
||
|
});
|
||
|
}
|
||
|
|
||
|
static deleteCorpusFileRequest(userId, corpusId, corpusFileId) {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let corpus = app.data.users[userId].corpora[corpusId];
|
||
|
let corpusFile = corpus.files[corpusFileId];
|
||
|
|
||
|
let modalElement = Utils.elementFromString(
|
||
|
`
|
||
|
<div class="modal">
|
||
|
<div class="modal-content">
|
||
|
<h4>Confirm job deletion</h4>
|
||
|
<p>Do you really want to delete the job <b>${corpusFile.title}</b>? All files 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">Delete</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 corpusFileTitle = corpusFile.title;
|
||
|
fetch(`/corpora/${corpusId}/files/${corpusFileId}`, {method: 'DELETE', headers: {Accept: 'application/json'}})
|
||
|
.then(
|
||
|
(response) => {
|
||
|
app.flash(`Corpus file "${corpusFileTitle}" marked for deletion`, 'corpus');
|
||
|
resolve(response);
|
||
|
},
|
||
|
(response) => {
|
||
|
if (response.status === 403) {app.flash('Forbidden', 'error');}
|
||
|
if (response.status === 404) {app.flash('Not Found', 'error');}
|
||
|
reject(response);
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
modal.open();
|
||
|
});
|
||
|
}
|
||
|
|
||
|
static deleteJobRequest(userId, jobId) {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let job = app.data.users[userId].jobs[jobId];
|
||
|
|
||
|
let modalElement = Utils.elementFromString(
|
||
|
`
|
||
|
<div class="modal">
|
||
|
<div class="modal-content">
|
||
|
<h4>Confirm job deletion</h4>
|
||
|
<p>Do you really want to delete the job <b>${job.title}</b>? All files 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">Delete</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/${job.id}`, {method: 'DELETE', headers: {Accept: 'application/json'}})
|
||
|
.then(
|
||
|
(response) => {
|
||
|
app.flash(`Job "${jobTitle}" marked for deletion`, 'job');
|
||
|
resolve(response);
|
||
|
},
|
||
|
(response) => {
|
||
|
if (response.status === 403) {app.flash('Forbidden', 'error');}
|
||
|
if (response.status === 404) {app.flash('Not Found', 'error');}
|
||
|
reject(response);
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
modal.open();
|
||
|
});
|
||
|
}
|
||
|
|
||
|
static getJobLogRequest(userId, jobId) {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let job = app.data.users[userId].jobs[jobId];
|
||
|
|
||
|
fetch(`/jobs/${job.id}/log`, {method: 'GET', headers: {Accept: 'application/json, text/plain'}})
|
||
|
.then(
|
||
|
(response) => {
|
||
|
resolve(response);
|
||
|
return response.text();
|
||
|
},
|
||
|
(response) => {
|
||
|
if (response.status === 403) {app.flash('Forbidden', 'error');}
|
||
|
if (response.status === 404) {app.flash('Not Found', 'error');}
|
||
|
reject(response);
|
||
|
}
|
||
|
)
|
||
|
.then(
|
||
|
(text) => {
|
||
|
let modalElement = Utils.elementFromString(
|
||
|
`
|
||
|
<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();
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
static restartJobRequest(userId, jobId) {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let job = app.data.users[userId].jobs[jobId];
|
||
|
|
||
|
let modalElement = Utils.elementFromString(
|
||
|
`
|
||
|
<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 log and result files 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/${job.id}/restart`, {method: 'POST', headers: {Accept: 'application/json'}})
|
||
|
.then(
|
||
|
(response) => {
|
||
|
app.flash(`Job "${jobTitle}" restarted.`, 'job');
|
||
|
resolve(response);
|
||
|
},
|
||
|
(response) => {
|
||
|
if (response.status === 403) {app.flash('Forbidden', 'error');}
|
||
|
if (response.status === 404) {app.flash('Not Found', 'error');}
|
||
|
if (response.status === 409) {app.flash('Conflict', 'error');}
|
||
|
reject(response);
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
modal.open();
|
||
|
});
|
||
|
}
|
||
|
|
||
|
static deleteUserRequest(userId) {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let user = app.data.users[userId];
|
||
|
|
||
|
let modalElement = Utils.elementFromString(
|
||
|
`
|
||
|
<div class="modal">
|
||
|
<div class="modal-content">
|
||
|
<h4>Confirm job deletion</h4>
|
||
|
<p>Do you really want to delete the user <b>${user.username}</b>? All files 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">Delete</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 userName = user.username;
|
||
|
fetch(`/users/${user.id}`, {method: 'DELETE', headers: {Accept: 'application/json'}})
|
||
|
.then(
|
||
|
(response) => {
|
||
|
app.flash(`User "${userName}" marked for deletion`);
|
||
|
resolve(response);
|
||
|
},
|
||
|
(response) => {
|
||
|
if (response.status === 403) {app.flash('Forbidden', 'error');}
|
||
|
if (response.status === 404) {app.flash('Not Found', 'error');}
|
||
|
reject(response);
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
modal.open();
|
||
|
});
|
||
|
}
|
||
|
}
|