bug: source loaded twice if sourceCache = true
This commit is contained in:
		| @@ -33,7 +33,7 @@ Applied as jQuery method. | ||||
|                 this.destroy(); | ||||
|             }, this));  | ||||
|              | ||||
|             //attach document handlers (once) | ||||
|             //attach document handler to close containers on click / escape | ||||
|             if(!$(document).data('editable-handlers-attached')) { | ||||
|                 //close all on escape | ||||
|                 $(document).on('keyup.editable', function (e) { | ||||
| @@ -59,7 +59,7 @@ Applied as jQuery method. | ||||
|                          } | ||||
|                     } | ||||
|                        | ||||
|                     //close all open containers (except one) | ||||
|                     //close all open containers (except one - target) | ||||
|                     Popup.prototype.closeOthers(e.target); | ||||
|                 }); | ||||
|                  | ||||
| @@ -72,6 +72,7 @@ Applied as jQuery method. | ||||
|             this.containerOptions = {}; | ||||
|             this.formOptions = {}; | ||||
|             var cDef = $.fn[this.containerName].defaults; | ||||
|             //keys defined in container defaults go to container, others go to form | ||||
|             for(var k in this.options) { | ||||
|               if(k in cDef) { | ||||
|                  this.containerOptions[k] = this.options[k]; | ||||
| @@ -90,9 +91,9 @@ Applied as jQuery method. | ||||
|             this.$form = $('<div>') | ||||
|             .editableform(this.formOptions) | ||||
|             .on({ | ||||
|                 save: $.proxy(this.save, this), | ||||
|                 cancel: $.proxy(function(){ this.hide('cancel'); }, this), | ||||
|                 nochange: $.proxy(function(){ this.hide('nochange'); }, this), | ||||
|                 save: $.proxy(this.save, this), //click on submit button (value changed) | ||||
|                 nochange: $.proxy(function(){ this.hide('nochange'); }, this), //click on submit button (value NOT changed)                 | ||||
|                 cancel: $.proxy(function(){ this.hide('cancel'); }, this), //click on calcel button | ||||
|                 show: $.proxy(this.setPosition, this), //re-position container every time form is shown (occurs each time after loading state) | ||||
|                 rendering: $.proxy(this.setPosition, this), //this allows to place container correctly when loading shown | ||||
|                 rendered: $.proxy(function(){ | ||||
|   | ||||
| @@ -21,8 +21,8 @@ Editableform is linked with one of input types, e.g. 'text', 'select' etc. | ||||
|     EditableForm.prototype = { | ||||
|         constructor: EditableForm, | ||||
|         initInput: function() {  //called once | ||||
|             //create input of specified type | ||||
|             this.input = $.fn.editableutils.createInput(this.options); | ||||
|             //take input from options or create new input instance | ||||
|             this.input = this.options.input || $.fn.editableutils.createInput(this.options); | ||||
|             if(!this.input) { | ||||
|                 return;  | ||||
|             }              | ||||
|   | ||||
| @@ -241,7 +241,8 @@ Makes editable any HTML element on the page. Applied as jQuery method. | ||||
|             //init editableContainer: popover, tooltip, inline, etc.. | ||||
|             if(!this.container) { | ||||
|                 var containerOptions = $.extend({}, this.options, { | ||||
|                     value: this.value | ||||
|                     value: this.value, | ||||
|                     input: this.input //pass input to form (as it is already created) | ||||
|                 }); | ||||
|                 this.$element.editableContainer(containerOptions); | ||||
|                 this.$element.on("save.internal", $.proxy(this.save, this)); | ||||
| @@ -355,6 +356,9 @@ Makes editable any HTML element on the page. Applied as jQuery method. | ||||
|             if(this.container) { | ||||
|                this.container.destroy();  | ||||
|             } | ||||
|              | ||||
|             this.$element.off("save.internal"); | ||||
|              | ||||
|             this.$element.removeClass('editable'); | ||||
|             this.$element.removeClass('editable-open'); | ||||
|             this.$element.removeData('editable'); | ||||
|   | ||||
| @@ -32,6 +32,9 @@ $(function(){ | ||||
|     $.extend(Checklist.prototype, { | ||||
|         renderList: function() { | ||||
|             var $label, $div; | ||||
|              | ||||
|             this.$tpl.empty(); | ||||
|              | ||||
|             if(!$.isArray(this.sourceData)) { | ||||
|                 return; | ||||
|             } | ||||
|   | ||||
| @@ -17,8 +17,6 @@ List - abstract class for inputs that have source option loaded from js array or | ||||
|             var deferred = $.Deferred(); | ||||
|  | ||||
|             this.error = null; | ||||
|             this.sourceData = null; | ||||
|             this.prependData = null; | ||||
|             this.onSourceReady(function () { | ||||
|                 this.renderList(); | ||||
|                 deferred.resolve(); | ||||
|   | ||||
| @@ -30,12 +30,14 @@ $(function(){ | ||||
|  | ||||
|     $.extend(Select.prototype, { | ||||
|         renderList: function() { | ||||
|             this.$input.empty(); | ||||
|              | ||||
|             if(!$.isArray(this.sourceData)) { | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             for(var i=0; i<this.sourceData.length; i++) { | ||||
|                 this.$tpl.append($('<option>', {value: this.sourceData[i].value}).text(this.sourceData[i].text));  | ||||
|                 this.$input.append($('<option>', {value: this.sourceData[i].value}).text(this.sourceData[i].text));  | ||||
|             } | ||||
|              | ||||
|             this.setClass(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 vitalets
					vitalets