146 lines
5.2 KiB
JavaScript
Raw Normal View History

class CorpusDisplay extends RessourceDisplay {
constructor(displayElement) {
super(displayElement);
this.corpusId = displayElement.dataset.corpusId;
2022-09-02 13:07:30 +02:00
this.displayElement
.querySelector('.action-button[data-action="build-request"]')
.addEventListener('click', (event) => {
Utils.buildCorpusRequest(this.userId, this.corpusId);
});
this.displayElement
.querySelector('.action-button[data-action="delete-request"]')
.addEventListener('click', (event) => {
Utils.deleteCorpusRequest(this.userId, this.corpusId);
});
2023-02-09 16:22:37 +01:00
this.displayElement
.querySelector('.action-switch[data-action="toggle-is-public"]')
.addEventListener('click', (event) => {
if (event.target.tagName !== 'INPUT') {return;}
if (event.target.checked) {
Utils.enableCorpusIsPublicRequest(this.userId, this.corpusId);
} else {
Utils.disableCorpusIsPublicRequest(this.userId, this.corpusId);
}
});
}
2021-11-30 16:22:16 +01:00
init(user) {
2022-09-02 13:07:30 +02:00
let corpus = user.corpora[this.corpusId];
2021-11-30 16:22:16 +01:00
this.setCreationDate(corpus.creation_date);
this.setDescription(corpus.description);
this.setStatus(corpus.status);
this.setTitle(corpus.title);
2021-12-01 14:15:20 +01:00
this.setNumTokens(corpus.num_tokens);
this.setShareLink();
}
2022-09-02 13:07:30 +02:00
onPatch(patch) {
let re = new RegExp(`^/users/${this.userId}/corpora/${this.corpusId}`);
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}/corpora/${this.corpusId}$`);
if (re.test(operation.path)) {
window.location.href = '/dashboard#corpora';
}
break;
}
case 'replace': {
2021-12-01 14:15:20 +01:00
re = new RegExp(`^/users/${this.userId}/corpora/${this.corpusId}/num_tokens`);
if (re.test(operation.path)) {
2021-12-03 16:10:54 +01:00
this.setNumTokens(operation.value);
2021-12-01 14:15:20 +01:00
break;
}
2021-11-30 16:22:16 +01:00
re = new RegExp(`^/users/${this.userId}/corpora/${this.corpusId}/status$`);
2021-12-01 14:15:20 +01:00
if (re.test(operation.path)) {
2021-12-03 16:10:54 +01:00
this.setStatus(operation.value);
2021-12-01 14:15:20 +01:00
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('.corpus-title'), title);
}
2021-12-01 14:15:20 +01:00
setNumTokens(numTokens) {
this.setElements(
this.displayElement.querySelectorAll('.corpus-token-ratio'),
`${numTokens}/${app.data.users[this.userId].corpora[this.corpusId].max_num_tokens}`
2021-12-01 14:15:20 +01:00
);
}
setDescription(description) {
2021-12-01 14:15:20 +01:00
this.setElements(this.displayElement.querySelectorAll('.corpus-description'), description);
}
setStatus(status) {
2022-09-02 13:07:30 +02:00
let elements = this.displayElement.querySelectorAll('.corpus-analyse-trigger')
for (let element of elements) {
if (['BUILT', 'STARTING_ANALYSIS_SESSION', 'RUNNING_ANALYSIS_SESSION', 'CANCELING_ANALYSIS_SESSION'].includes(status)) {
2021-01-11 15:43:15 +01:00
element.classList.remove('disabled');
} else {
2021-01-11 15:43:15 +01:00
element.classList.add('disabled');
}
}
2022-09-02 13:07:30 +02:00
elements = this.displayElement.querySelectorAll('.action-button[data-action="build-request"]');
for (let element of elements) {
if (['UNPREPARED', 'FAILED'].includes(status) && Object.values(app.data.users[this.userId].corpora[this.corpusId].files).length > 0) {
2021-01-11 15:43:15 +01:00
element.classList.remove('disabled');
} else {
element.classList.add('disabled');
}
}
elements = this.displayElement.querySelectorAll('.corpus-status');
2022-09-02 13:07:30 +02:00
for (let element of elements) {
element.dataset.status = status;
}
elements = this.displayElement.querySelectorAll('.corpus-status-spinner');
2022-09-02 13:07:30 +02:00
for (let element of elements) {
if (['SUBMITTED', 'QUEUED', 'BUILDING', 'STARTING_ANALYSIS_SESSION', 'CANCELING_ANALYSIS_SESSION'].includes(status)) {
element.classList.remove('hide');
} else {
element.classList.add('hide');
}
}
}
2021-11-30 16:22:16 +01:00
setCreationDate(creationDate) {
2021-12-01 14:15:20 +01:00
this.setElements(
this.displayElement.querySelectorAll('.corpus-creation-date'),
new Date(creationDate).toLocaleString("en-US")
);
}
setShareLink() {
let generateShareLinkButton = this.displayElement.querySelector('#generate-share-link-button');
let copyShareLinkButton = this.displayElement.querySelector('#copy-share-link-button');
let shareLinkInput = this.displayElement.querySelector('#share-link-input');
2023-02-23 09:50:09 +01:00
let shareLinkContainer = this.displayElement.querySelector('#share-link-container');
let roleSelect = this.displayElement.querySelector('#role-select');
let expirationDate = this.displayElement.querySelector('#expiration');
generateShareLinkButton.addEventListener('click', () => {
Utils.generateCorpusShareLinkRequest(`${this.corpusId}`, roleSelect.value, expirationDate.value)
.then((shareLink) => {
2023-02-23 09:50:09 +01:00
shareLinkContainer.classList.remove('hide');
shareLinkInput.value = shareLink;
});
});
copyShareLinkButton.addEventListener('click', () => {
shareLinkInput.select();
navigator.clipboard.writeText(shareLinkInput.value);
app.flash(`Copied!`, 'success');
});
}
}