From 4e6a9ec41230b166d29d18202fd9fce04a617fa8 Mon Sep 17 00:00:00 2001 From: Will Rossiter Date: Wed, 13 Oct 2010 21:07:53 +0000 Subject: [PATCH] BUGFIX: fixed sortable fields (again) not working on initial page load or when accessing a page directly. BUGFIX: fixed typo of livequery to live. --- javascript/UserForm.js | 108 +++++++++++++++++------------------------ 1 file changed, 44 insertions(+), 64 deletions(-) diff --git a/javascript/UserForm.js b/javascript/UserForm.js index 26d7c8b..255e84f 100644 --- a/javascript/UserForm.js +++ b/javascript/UserForm.js @@ -5,71 +5,57 @@ */ (function($) { $(document).ready(function() { - - /** - * Update the Field sortable - */ - set_sortable(); - /** * Update the sortable properties of the form as a function * since the application will need to refresh the UI dynamically */ - function set_sortable() { - /** - * Sort Fields in the Field List - */ - + function update_sortable() { + $("#Fields_fields").sortable({ + handle: '.fieldHandler', + cursor: 'pointer', + items: 'li.EditableFormField', + placeholder: 'removed-form-field', + opacity: 0.6, + revert: 'true', + change : function (event, ui) { + $("#Fields_fields").sortable('refreshPositions'); + }, + update : function (event, ui) { + var sort = 1; - $("#Fields_fields").sortable({ - handle: '.fieldHandler', - cursor: 'pointer', - items: 'li.EditableFormField', - placeholder: 'removed-form-field', - opacity: 0.6, - revert: 'true', - change : function (event, ui) { - $("#Fields_fields").sortable('refreshPositions'); - }, - update : function (event, ui) { - update_fieldsSortingOrder(); - } + $("li.EditableFormField").each(function() { + $(this).find(".sortHidden").val(sort++); + }); + } }); - /** - * Sort Options in a Field List - Such as options in a - * dropdown field. - * - */ - $(".editableOptions").sortable({ - handle: '.handle', - cursor:'pointer', - items: 'li', - placeholder: 'removed-form-field', - opacity: 0.6, - revert: true, - change : function (event, ui) { - $(this).sortable('refreshPositions'); - }, - update : function (event, ui) { - update_editableOptionsSortingOrder(); - } + $(".editableOptions").sortable({ + handle: '.handle', + cursor:'pointer', + items: 'li', + placeholder: 'removed-form-field', + opacity: 0.6, + revert: true, + change : function (event, ui) { + $(this).sortable('refreshPositions'); + }, + update : function (event, ui) { + var sort = 1; + $(".editableOptions li").each(function() { + $(this).find(".sortOptionHidden").val(sort++); + }); + } }); } - - function update_fieldsSortingOrder(){ - var sort = 1; - $("li.EditableFormField").each(function() { - $(this).find(".sortHidden").val(sort++); - }); - } - - function update_editableOptionsSortingOrder(){ - var sort = 1; - $(".editableOptions li").each(function() { - $(this).find(".sortOptionHidden").val(sort++); - }); - } + + update_sortable(); + + /** + * Workaround for not refreshing the sort + */ + $(".fieldHandler").live('hover', function() { + update_sortable(); + }) /*--------------------- SUBMISSIONS ------------------------ */ @@ -149,8 +135,7 @@ } }); - //update_sortable(); - update_fieldsSortingOrder(); + $("#Fields_fields").sortable('refresh'); return false; }); @@ -251,9 +236,6 @@ } }); - //update_sortable(); - update_editableOptionsSortingOrder(); - return false; }); @@ -274,7 +256,7 @@ /** * Custom Rules Interface */ - $(".customRules .conditionOption").livequery('change',function(){ + $(".customRules .conditionOption").live('change',function(){ var valueInput = $(this).siblings(".ruleValue"); if($(this).val() != "" && $(this).val() != "IsBlank" && $(this).val() != "IsNotBlank") { valueInput.removeClass("hidden"); @@ -326,8 +308,6 @@ // append to the list currentRules.append(newRule); - //update_sortable(); - return false; }); });