123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- function GetModalAlertTmpl(title, message, error) {
- return '<div class="alert alert-' + (!error?'success':'danger') + ' alert-dismissible fade show" role="alert"><strong>' + title + '</strong> ' + message + '<button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">×</span></button></div>';
- }
- function ShowSystemMsg(title, message, error) {
- var modal_alert_place = $('.modal.show .sys-messages');
- if(!modal_alert_place.length) {
- modal_alert_place = $('form.alert-here .sys-messages');
- }
- if(modal_alert_place.length) {
- modal_alert_place.html(GetModalAlertTmpl(title, message, error));
- }
- }
- function ShowSystemMsgSuccess(title, message) {
- ShowSystemMsg(title, message, false);
- }
- function ShowSystemMsgError(title, message) {
- ShowSystemMsg(title, message, true);
- }
- function AjaxDone(data) {
- try {
- eval(data);
- } catch(e) {
- if(e instanceof SyntaxError) {
- console.log(data);
- console.log('JavaScript Eval Error', e.message)
- }
- }
- }
- function AjaxFail() {
- console.log('Form send fail, page will be reloaded');
- window.location.reload(false);
- }
- function ActionSingOut() {
- $.ajax({
- type: "POST",
- url: '/cp/',
- data: {
- action: 'singout',
- }
- }).done(function(data) {
- AjaxDone(data)
- }).fail(function() {
- AjaxFail();
- });
- }
- $(document).ready(function() {
- // Ajax forms
- $('form').each(function() {
- $(this).submit(function(e) {
- var form = $(this);
- if(form.hasClass('loading')) {
- e.preventDefault();
- return;
- }
- // Block send button
- form.addClass('loading').addClass('alert-here');
- var button = $(this).find('button[type=submit]');
- button.addClass('progress-bar-striped').addClass('progress-bar-animated');
- // Another button
- if(button.attr('data-target') != '') {
- $('#' + button.attr('data-target')).addClass('progress-bar-striped').addClass('progress-bar-animated');
- }
- // Clear form messages
- form.find('.sys-messages').html('');
- $.ajax({
- type: "POST",
- url: form.attr('action'),
- data: form.serialize()
- }).done(function(data) {
- AjaxDone(data)
- }).fail(function() {
- AjaxFail();
- }).always(function() {
- // Add delay for one second
- setTimeout(function() {
- form.removeClass('loading').removeClass('alert-here');
- button.removeClass('progress-bar-striped').removeClass('progress-bar-animated');
- // Another button
- if(button.attr('data-target') != '') {
- $('#' + button.attr('data-target')).removeClass('progress-bar-striped').removeClass('progress-bar-animated');
- }
- }, 100);
- });
- e.preventDefault();
- });
- // Bind to another button
- var button = $(this).find('button[type=submit]');
- if(button.attr('data-target') != '') {
- $('#' + button.attr('data-target')).click(function() {
- button.click();
- });
- }
- });
- // Remove alert from modal on close
- $('.modal.fade').on('hidden.bs.modal', function() {
- modal_alert_place = $(this).find('.sys-messages');
- if(modal_alert_place.length) {
- modal_alert_place.html('');
- }
- // Reset form at modal close
- form = $(this).find('form');
- if(form.length) {
- form[0].reset();
- }
- }).on('show.bs.modal', function() {
- // Reset form at modal open
- form = $(this).find('form');
- if(form.length) {
- form[0].reset();
- }
- });
- });
|