var has_been_moved = false; var modules_list = new Array(); var hooks_list = new Array(); var hookable_list = new Array(); var timer; $(document).ready(function() { // do some place for submit button $('body').css('margin-top', '45px'); // this is the result box, which will "pop up" the succeed or fail result $('#fancy').fancybox({ autoDimensions: true, autoScale: true, width: 300, height: 300, padding: 0, hideOnOverlayClick: false, hideOnContentClick: false, showCloseButton: false }); $('#live_edit_feedback_str').html(''); // add liveToken in each link to navigate into the shop and keeping the liveedit mode $('a').each(function() { var href = this.href; var search = this.search; var hrefAdd = 'live_edit&liveToken=' + get('liveToken') + '&ad=' + get('ad') + '&id_shop=' + get('id_shop') + '&id_employee=' + get('id_employee'); if (href != undefined && href != '#' && href.substr(0, baseDir.length) == baseDir) { if (search.length == 0) this.search = hrefAdd; else this.search += '&' + hrefAdd; } }); // populate getHookableList(); $('.unregisterHook').unbind('click').click(function() { id = $(this).attr('id'); $(this).parent().parent().parent().fadeOut('slow', function() { $(this).remove(); }); return false; }); $('#cancelMove').unbind('click').click(function() { $('#' + cancelMove + '').sortable('cancel'); return false; }); $('#saveLiveEdit').unbind('click').click(function() { saveModulePosition(); return false; }); $('#closeLiveEdit').unbind('click').click(function() { if (!has_been_moved) closeLiveEdit(); else { $("#live_edit_feedback_str").html('

' + confirmClose + '

' + confirm + '' + cancel + '

'); $("#fancy").attr('href', '#live_edit_feedback'); $("#fancy").trigger("click"); } return false; }); $('.add_module_live_edit').unbind('click').click(function() { $("#live_edit_feedback_str").html('
'); $("#fancy").attr('href', '#live_edit_feedback'); $("#fancy").trigger("click"); var id = $(this).attr('id'); getHookableModuleList(id.substr(4, id.length)); return false; }); $('.dndHook').each(function() { var id_hook = $(this).attr('id'); var new_target_id = ''; var old_target = ''; var cancel = false; $('#' + id_hook + '').sortable({ opacity: 0.5, cursor: 'move', connectWith: '.dndHook', receive: function(event, ui) { if (new_target_id == '') { new_target_id = event.target.id; } has_been_moved = true; }, start: function(event, ui) { new_target_id = ui.item[0].parentNode.id; }, stop: function(event, ui) { if (cancel) { $(this).sortable('cancel'); } else { old_target = event.target.id; cancelMove = old_target; if (new_target_id == '') new_target_id = old_target; ids = $(ui.item[0]).attr('id').split('_'); newHookId = $("input[value="+new_target_id+"]").attr('name').substr(10); newHookId = newHookId.substr(0, newHookId.length -1); new_id = ids[0] + "_" + newHookId + "_" + ids[2] + "_" + ids[3] + "_" + ids[4] + "_" + ids[5] ; $(ui.item[0]).attr('id', new_id); } }, change: function(evartent, ui) { new_target_id = $(ui.placeholder).parent().attr('id'); ids = ui.item[0].id.split('_'); if ($.inArray(ids[5], hookable_list[new_target_id]) != -1) { cancel = false; ui.placeholder.css({ visibility: 'visible', border: '1px solid #72CB67', background: '#DFFAD3' }); } else { ui.placeholder.css({ visibility: 'visible', border: '1px solid #EC9B9B', background: '#FAE2E3' }); cancel = true; } } }); $('#' + id_hook + '').disableSelection(); }); }); // init hookable_list function getHookableList() { hooks_list = new Array(); $("input[name^=hook_list]}").each(function(e){ hooks_list.push($(this).val()); }); $.ajax({ type: 'POST', url: baseDir + ad + '/index.php', async: true, dataType: 'json', data: { action: 'getHookableList', tab: 'AdminModulesPositions', ajax:1, hooks_list: hooks_list, modules_list: modules_list, id_shop: get('id_shop'), token: get('liveToken') }, success: function(jsonData) { if (jsonData.hasError) { var errors = ''; for (error in jsonData.errors) //IE6 bug fix if (error != 'indexOf') errors += jsonData.errors[error] + "\n"; alert(errors); } else hookable_list = jsonData;// create and fill input array }, error: function(XMLHttpRequest, textStatus, errorThrown) { $('#live_edit_feedback_str').html('

TECHNICAL ERROR:

' + loadFail + '

' + close + '
'); $("#fancy").attr('href', '#live_edit_feedback'); $("#fancy").trigger("click"); } }); } function getHookableModuleList(hook) { $.ajax({ type: 'GET', url: baseDir + ad + '/index.php', async: true, dataType: 'json', data: { ajax:1, tab: 'AdminModulesPositions', action:'getHookableModuleList', hook: hook, id_shop: get('id_shop'), token: get('liveToken') }, success: function(jsonData) { var select = ''; $("#live_edit_feedback_str").html('
' + select + '

' + add + '

' + cancel + ''); }, error: function(XMLHttpRequest, textStatus, errorThrown) { alert("TECHNICAL ERROR: unable to unregister hook \n\nDetails:\nError thrown: " + XMLHttpRequest + "\n" + 'Text status: ' + textStatus); } }); } function saveModulePosition() { $("input.dynamic-input-save-position").remove(); $("#live_edit_feedback_str").html('
'); $("#fancy").attr('href', '#live_edit_feedback'); $("#fancy").trigger("click"); var str = ''; for (var i = 0; i < hooks_list.length; i++) { str += '&' + hooks_list[i] + '='; $('#' + hooks_list[i] + ' > .dndModule').each(function() { ids = $(this).attr('id').split('_'); $("#liveEdit-action-form") .append(''); }); } $("#liveEdit-action-form") .append(''); datas = $("#liveEdit-action-form").serializeArray(); $.ajax({ type: 'POST', url: baseDir + ad + "/index.php", async: true, dataType: 'json', data: datas, success: function(jsonData) { $('#live_edit_feedback_str').html('

' + saveOK + '

' + close + '
'); timer = setTimeout("hideFeedback()", 3000); has_been_moved = false; }, error: function(XMLHttpRequest, textStatus, errorThrown) { $('#live_edit_feedback_str').html('

TECHNICAL ERROR:

' + unableToSaveModulePosition + '

' + close + '
'); } } ) return true; } function closeFancybox() { clearTimeout(timer); $.fancybox.close(); $('#live_edit_feedback_str').html(''); } function closeLiveEdit() { window.location.href = window.location.protocol+'//'+window.location.host+window.location.pathname; } function hideFeedback() { $('#live_edit_feed_back').fadeOut('slow', function() { $.fancybox.close(); $('#live_edit_feedback_str').html(''); }); }; function get(name) { var regexS = "[\\?&]" + name + "=([^&#]*)"; var regex = new RegExp(regexS); var results = regex.exec(window.location.href); if (results == null) { return ""; } else { return results[1]; } }