mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2024-11-11 10:06:53 +08:00
d209b3abcd
* Update share modal window * Fix markup
170 lines
5.2 KiB
JavaScript
170 lines
5.2 KiB
JavaScript
//= require repositories/import/records_importer.js
|
|
|
|
/*
|
|
global animateSpinner repositoryRecordsImporter getParam
|
|
RepositoryDatatable PerfectScrollbar HelperModule
|
|
*/
|
|
|
|
(function(global) {
|
|
'use strict';
|
|
|
|
global.pageReload = function() {
|
|
animateSpinner();
|
|
location.reload();
|
|
};
|
|
|
|
function handleErrorSubmit(XHR) {
|
|
var formGroup = $('#form-records-file').find('.form-group');
|
|
formGroup.addClass('has-error');
|
|
formGroup.find('.help-block').remove();
|
|
formGroup.append(
|
|
'<span class="help-block">' + XHR.responseJSON.message + '</span>'
|
|
);
|
|
}
|
|
|
|
function handleSuccessfulSubmit(data) {
|
|
$('#modal-import-records').modal('hide');
|
|
$(data.html).appendTo('body').promise().done(function() {
|
|
$('#parse-records-modal')
|
|
.modal('show')
|
|
.on('hidden.bs.modal', function() {
|
|
animateSpinner();
|
|
location.reload();
|
|
});
|
|
repositoryRecordsImporter();
|
|
});
|
|
}
|
|
|
|
function initParseRecordsModal() {
|
|
var form = $('#form-records-file');
|
|
var submitBtn = form.find('input[type="submit"]');
|
|
submitBtn.on('click', function(event) {
|
|
var data = new FormData();
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
data.append('file', document.getElementById('file').files[0]);
|
|
data.append('team_id', document.getElementById('team_id').value);
|
|
$.ajax({
|
|
type: 'POST',
|
|
url: form.attr('action'),
|
|
data: data,
|
|
success: handleSuccessfulSubmit,
|
|
error: handleErrorSubmit,
|
|
processData: false,
|
|
contentType: false
|
|
});
|
|
});
|
|
}
|
|
|
|
function initImportRecordsModal() {
|
|
$('#importRecordsButton').off().on('click', function() {
|
|
$('#modal-import-records').modal('show');
|
|
initParseRecordsModal();
|
|
});
|
|
}
|
|
|
|
function loadRepositoryTab() {
|
|
var param = getParam('repository');
|
|
$('#repository-tabs a').on('click', function(e) {
|
|
var pane = $(this);
|
|
e.preventDefault();
|
|
$.ajax({
|
|
url: $(this).attr('data-url'),
|
|
type: 'GET',
|
|
dataType: 'json',
|
|
success: function(data) {
|
|
var tabBody = $(pane.context.hash).find('.tab-content-body');
|
|
tabBody.html(data.html);
|
|
pane.tab('show').promise().done(function(el) {
|
|
initImportRecordsModal();
|
|
RepositoryDatatable.destroy();
|
|
RepositoryDatatable.init(el.attr('data-repo-table'));
|
|
});
|
|
},
|
|
error: function() {
|
|
// TODO
|
|
}
|
|
});
|
|
});
|
|
|
|
// on page load
|
|
if (param) {
|
|
// load selected tab
|
|
$('a[href="#custom_repo_' + param + '"]').click();
|
|
} else {
|
|
// load first tab content
|
|
$('#repository-tabs a:first').click();
|
|
}
|
|
|
|
// clean tab content
|
|
$('a[data-toggle="tab"]').on('hide.bs.tab', function() {
|
|
$('.tab-content-body').html('');
|
|
});
|
|
}
|
|
|
|
function initShareModal() {
|
|
var form = $('.share-repo-modal').find('form');
|
|
var sharedCBs = form.find("input[name='share_team_ids[]']");
|
|
var permissionCBs = form.find("input[name='write_permissions[]']");
|
|
var permissionChanges = form.find("input[name='permission_changes']");
|
|
var submitBtn = form.find('input[type="submit"]');
|
|
var selectAllCheckbox = form.find('.all-teams .simple-checkbox');
|
|
|
|
form.find('.teams-list').find('input.simple-checkbox, .permission-selector')
|
|
.toggleClass('hidden', selectAllCheckbox.is(':checked'));
|
|
form.find('.all-teams .trigger-checkbox')
|
|
.toggleClass('hidden', !selectAllCheckbox.is(':checked'))
|
|
.attr('disabled', !selectAllCheckbox.is(':checked'));
|
|
|
|
selectAllCheckbox.change(function() {
|
|
form.find('.teams-list').find('input.simple-checkbox, .permission-selector')
|
|
.toggleClass('hidden', this.checked);
|
|
form.find('.all-teams .trigger-checkbox').toggleClass('hidden', !this.checked)
|
|
.attr('disabled', !this.checked);
|
|
});
|
|
|
|
sharedCBs.change(function() {
|
|
$('#editable_' + this.value).toggleClass('hidden', !this.checked)
|
|
.attr('disabled', !this.checked);
|
|
});
|
|
|
|
new PerfectScrollbar(form.find('.teams-list')[0]);
|
|
|
|
permissionCBs.change(function() {
|
|
var changes = JSON.parse(permissionChanges.val());
|
|
changes[this.value] = 'true';
|
|
permissionChanges.val(JSON.stringify(changes));
|
|
});
|
|
|
|
submitBtn.on('click', function(event) {
|
|
event.preventDefault();
|
|
$.ajax({
|
|
type: 'POST',
|
|
url: form.attr('action'),
|
|
data: form.serialize(),
|
|
success: function(data) {
|
|
if (data.warnings) {
|
|
alert(data.warnings);
|
|
}
|
|
$(`#slide-panel li.active .repository-share-status,
|
|
#repository-toolbar .repository-share-status
|
|
`).toggleClass('hidden', !data.status);
|
|
HelperModule.flashAlertMsg(form.data('success-message'), 'success');
|
|
$('.share-repo-modal').modal('hide');
|
|
},
|
|
error: function(data) {
|
|
alert(data.responseJSON.errors);
|
|
$('.share-repo-modal').modal('hide');
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
$('#shareRepoBtn').on('ajax:success', function() {
|
|
initShareModal();
|
|
});
|
|
|
|
$('.create-new-repository').initializeModal('#create-repo-modal');
|
|
loadRepositoryTab();
|
|
initImportRecordsModal();
|
|
}(window));
|