nopaque/app/templates/_scripts.html.j2

111 lines
4.2 KiB
Plaintext
Raw Normal View History

2022-07-18 17:10:21 +02:00
<script src="https://cdnjs.cloudflare.com/ajax/libs/fast-json-patch/3.1.1/fast-json-patch.min.js" integrity="sha512-5uDdefwnzyq4N+SkmMBmekZLZNmc6dLixvVxCdlHBfqpyz0N3bzLdrJ55OLm7QrZmgZuhLGgHLDtJwU6RZoFCA==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
2021-12-09 12:50:14 +01:00
<script src="https://cdnjs.cloudflare.com/ajax/libs/list.js/2.3.1/list.min.js" integrity="sha512-93wYgwrIFL+b+P3RvYxi/WUFRXXUDSLCT2JQk9zhVGXuS2mHl2axj6d+R6pP+gcU5isMHRj1u0oYE/mWyt/RjA==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
2023-01-09 08:45:47 +01:00
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.5.4/socket.io.min.js" integrity="sha512-HTENHrkQ/P0NGDFd5nk6ibVtCkcM7jhr2c7GyvXp5O+4X6O5cQO9AhqFzM+MdeBivsX7Hoys2J7pp2wdgMpCvw==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
2021-12-09 15:39:45 +01:00
{%- assets
filters='rjsmin',
output='gen/app.%(version)s.js',
'js/App.js',
2022-09-02 13:07:30 +02:00
'js/Utils.js',
'js/CorpusAnalysis/CQiClient.js',
'js/CorpusAnalysis/CorpusAnalysisApp.js',
'js/CorpusAnalysis/CorpusAnalysisConcordance.js',
'js/CorpusAnalysis/CorpusAnalysisReader.js',
2022-09-07 14:56:40 +02:00
'js/CorpusAnalysis/QueryBuilder.js',
2023-03-08 11:42:53 +01:00
'js/XMLtoObject.js'
%}
<script src="{{ ASSET_URL }}"></script>
{%- endassets %}
{%- assets
filters='rjsmin',
output='gen/Forms.%(version)s.js',
'js/Forms/Form.js',
'js/Forms/CreateCorpusFileForm.js',
'js/Forms/CreateJobForm.js',
'js/Forms/CreateContributionForm.js'
%}
<script src="{{ ASSET_URL }}"></script>
{%- endassets %}
{%- assets
filters='rjsmin',
output='gen/ResourceDisplays.%(version)s.js',
'js/ResourceDisplays/ResourceDisplay.js',
'js/ResourceDisplays/CorpusDisplay.js',
'js/ResourceDisplays/JobDisplay.js'
%}
<script src="{{ ASSET_URL }}"></script>
{%- endassets %}
{%- assets
filters='rjsmin',
output='gen/ResourceLists.%(version)s.js',
2023-01-04 20:00:37 +01:00
'js/ResourceLists/ResourceList.js',
'js/ResourceLists/CorpusFileList.js',
2023-02-09 11:21:03 +01:00
'js/ResourceLists/PublicCorpusFileList.js',
2023-01-04 20:00:37 +01:00
'js/ResourceLists/CorpusList.js',
'js/ResourceLists/FollowedCorpusList.js',
'js/ResourceLists/PublicCorpusList.js',
2023-01-04 20:00:37 +01:00
'js/ResourceLists/JobList.js',
'js/ResourceLists/JobInputList.js',
'js/ResourceLists/JobResultList.js',
'js/ResourceLists/SpacyNLPPipelineModelList.js',
'js/ResourceLists/TesseractOCRPipelineModelList.js',
2023-01-11 13:47:09 +01:00
'js/ResourceLists/UserList.js',
2023-01-09 08:45:47 +01:00
'js/ResourceLists/AdminUserList.js',
2023-03-08 11:42:53 +01:00
'js/ResourceLists/CorpusFollowerList.js'
%}
<script src="{{ ASSET_URL }}"></script>
{%- endassets %}
{%- assets
filters='rjsmin',
output='gen/Requests.%(version)s.js',
'js/Requests/Requests.js',
2023-03-29 14:32:35 +02:00
'js/Requests/admin/admin.js',
2023-03-09 12:07:16 +01:00
'js/Requests/contributions/contributions.js',
'js/Requests/contributions/spacy_nlp_pipeline_models.js',
'js/Requests/contributions/tesseract_ocr_pipeline_models.js',
2023-03-09 14:55:08 +01:00
'js/Requests/corpora/corpora.js',
'js/Requests/corpora/files.js',
'js/Requests/corpora/followers.js',
'js/Requests/jobs/jobs.js',
'js/Requests/users/users.js',
'js/Requests/users/settings.js'
2021-12-09 15:39:45 +01:00
%}
<script src="{{ ASSET_URL }}"></script>
2021-12-09 15:39:45 +01:00
{%- endassets %}
<script>
2021-12-09 15:39:45 +01:00
const app = new App();
{%- if current_user.is_authenticated %}
const currentUserId = {{ current_user.hashid|tojson }};
// Initialize components for current user
app.subscribeUser(currentUserId)
.catch((error) => {throw JSON.stringify(error);});
app.getUser(currentUserId, true, true)
.catch((error) => {throw JSON.stringify(error);});
2021-12-09 15:39:45 +01:00
{%- endif %}
// Disable all option elements with no value
for (let optionElement of document.querySelectorAll('option[value=""]')) {
optionElement.disabled = true;
2021-12-09 15:39:45 +01:00
}
// Set the data-length attribute on textareas/inputs with the maxlength attribute
for (let inputElement of document.querySelectorAll('textarea[maxlength], input[maxlength]')) {
2022-04-12 16:11:24 +02:00
inputElement.dataset.length = inputElement.getAttribute('maxlength');
}
2021-12-09 15:39:45 +01:00
// Initialize components
M.AutoInit();
2022-12-12 15:37:33 +01:00
M.CharacterCounter.init(document.querySelectorAll('input[data-length], textarea[data-length]'));
2021-12-09 15:39:45 +01:00
M.Dropdown.init(
document.querySelectorAll('#nav-more-dropdown-trigger'),
{alignment: 'right', constrainWidth: false, coverTrigger: false}
);
2023-01-04 20:00:37 +01:00
ResourceList.autoInit();
2022-09-02 13:07:30 +02:00
Form.autoInit();
2021-12-09 15:39:45 +01:00
// Display flashed messages
for (let [category, message] of {{ get_flashed_messages(with_categories=True)|tojson }}) {
app.flash(message, message);
2021-12-09 15:39:45 +01:00
}
</script>