select2 wip: tags ready
This commit is contained in:
		
							
								
								
									
										1
									
								
								grunt.js
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								grunt.js
									
									
									
									
									
								
							| @@ -164,6 +164,7 @@ module.exports = function(grunt) { | |||||||
|               'src/inputs/date/*.js', |               'src/inputs/date/*.js', | ||||||
|               'src/inputs/dateui/*.js', |               'src/inputs/dateui/*.js', | ||||||
|               'src/inputs/combodate/*.js', |               'src/inputs/combodate/*.js', | ||||||
|  |               'src/inputs/select2/*.js', | ||||||
|                |                | ||||||
|               'src/inputs-ext/address/*.js', |               'src/inputs-ext/address/*.js', | ||||||
|               'src/inputs-ext/wysihtml5/*.js' |               'src/inputs-ext/wysihtml5/*.js' | ||||||
|   | |||||||
| @@ -116,6 +116,7 @@ Applied as jQuery method. | |||||||
|                 cancel: $.proxy(function(){ this.hide('cancel'); }, this), //click on calcel button |                 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) |                 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 |                 rendering: $.proxy(this.setPosition, this), //this allows to place container correctly when loading shown | ||||||
|  |                 resize: $.proxy(this.setPosition, this), //this allows to re-position container when form size is changed  | ||||||
|                 rendered: $.proxy(function(){ |                 rendered: $.proxy(function(){ | ||||||
|                     /**         |                     /**         | ||||||
|                     Fired when container is shown and form is rendered (for select will wait for loading dropdown options) |                     Fired when container is shown and form is rendered (for select will wait for loading dropdown options) | ||||||
|   | |||||||
| @@ -132,11 +132,13 @@ | |||||||
|        /* |        /* | ||||||
|         returns array items from sourceData having value property equal or inArray of 'value' |         returns array items from sourceData having value property equal or inArray of 'value' | ||||||
|        */ |        */ | ||||||
|        itemsByValue: function(value, sourceData) { |        itemsByValue: function(value, sourceData, valueProp) { | ||||||
|            if(!sourceData || value === null) { |            if(!sourceData || value === null) { | ||||||
|                return []; |                return []; | ||||||
|            } |            } | ||||||
|             |             | ||||||
|  |            valueProp = valueProp || 'value'; | ||||||
|  |                        | ||||||
|            var isValArray = $.isArray(value), |            var isValArray = $.isArray(value), | ||||||
|            result = [],  |            result = [],  | ||||||
|            that = this; |            that = this; | ||||||
| @@ -147,11 +149,11 @@ | |||||||
|                } else { |                } else { | ||||||
|                    /*jslint eqeq: true*/ |                    /*jslint eqeq: true*/ | ||||||
|                    if(isValArray) { |                    if(isValArray) { | ||||||
|                        if($.grep(value, function(v){ return v == o.value; }).length) { |                        if($.grep(value, function(v){  return v == (o && typeof o === 'object' ? o[valueProp] : o); }).length) { | ||||||
|                            result.push(o);  |                            result.push(o);  | ||||||
|                        } |                        } | ||||||
|                    } else { |                    } else { | ||||||
|                        if(value == o.value) { |                        if(value == (o && typeof o === 'object' ? o[valueProp] : o)) { | ||||||
|                            result.push(o);  |                            result.push(o);  | ||||||
|                        } |                        } | ||||||
|                    } |                    } | ||||||
|   | |||||||
| @@ -25,6 +25,7 @@ Editableform is linked with one of input types, e.g. 'text', 'select' etc. | |||||||
|             this.input = this.options.input; |             this.input = this.options.input; | ||||||
|              |              | ||||||
|             //set initial value |             //set initial value | ||||||
|  |             //todo: may be add check: typeof str === 'string' ?  | ||||||
|             this.value = this.input.str2value(this.options.value);  |             this.value = this.input.str2value(this.options.value);  | ||||||
|         }, |         }, | ||||||
|         initTemplate: function() { |         initTemplate: function() { | ||||||
|   | |||||||
							
								
								
									
										91
									
								
								src/inputs/select2/select2.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										91
									
								
								src/inputs/select2/select2.js
									
									
									
									
										vendored
									
									
								
							| @@ -26,22 +26,30 @@ $(function(){ | |||||||
|     var Constructor = function (options) { |     var Constructor = function (options) { | ||||||
|         this.init('select2', options, Constructor.defaults); |         this.init('select2', options, Constructor.defaults); | ||||||
|          |          | ||||||
|         //overriding objects in config (as by default jQuery extend() is not recursive) |         var mixin = { | ||||||
|         this.options.select2 = $.extend({}, Constructor.defaults.select2, { |             placeholder:  options.placeholder | ||||||
|             data:  options.source, |         }; | ||||||
|             placeholder:  options.placeholder, |          | ||||||
|             initSelection : function (element, callback) { |         if(options.select2 && options.select2.tags) { | ||||||
|  |              | ||||||
|  |         } | ||||||
|  |        /* | ||||||
|  |         if(!(options.select2 && options.select2.tags)) { | ||||||
|  |             mixin.data = options.source;  | ||||||
|  |             mixin.initSelection = function (element, callback) { | ||||||
|                 //see https://github.com/ivaynberg/select2/issues/710 |                 //see https://github.com/ivaynberg/select2/issues/710 | ||||||
|                     var data;  |                 var data = []; | ||||||
|                 $.each(this.data, function(k, v) { |                 $.each(this.data, function(k, v) { | ||||||
|                     if(v.id ==  element.val()) { |                     if(v.id ==  element.val()) { | ||||||
|                            data = v; |                         data.push(v); | ||||||
|                            return false; |  | ||||||
|                     }  |                     }  | ||||||
|                 }); |                 }); | ||||||
|                 callback(data); |                 callback(data); | ||||||
|  |             };  | ||||||
|         } |         } | ||||||
|         }, options.select2); |       */      | ||||||
|  |         //overriding objects in config (as by default jQuery extend() is not recursive) | ||||||
|  |         this.options.select2 = $.extend({}, Constructor.defaults.select2, mixin, options.select2); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     $.fn.editableutils.inherit(Constructor, $.fn.editabletypes.abstractinput); |     $.fn.editableutils.inherit(Constructor, $.fn.editabletypes.abstractinput); | ||||||
| @@ -51,16 +59,43 @@ $(function(){ | |||||||
|             this.setClass(); |             this.setClass(); | ||||||
|             //apply select2 |             //apply select2 | ||||||
|             this.$input.select2(this.options.select2); |             this.$input.select2(this.options.select2); | ||||||
|  |              | ||||||
|  |             if(this.options.select2.tags) { | ||||||
|  |                this.$input.on('change', function() { | ||||||
|  |                    //trigger resize of editableform to re-position container | ||||||
|  |                    $(this).closest('form').parent().triggerHandler('resize'); | ||||||
|  |                });  | ||||||
|  |             }             | ||||||
|  |              | ||||||
|         }, |         }, | ||||||
|         |         | ||||||
|        value2html: function(value, element) { |        value2html: function(value, element) { | ||||||
|  |            var text = '', data; | ||||||
|            if(this.$input) { //when submitting form  |            if(this.$input) { //when submitting form  | ||||||
|                $(element).text(this.$input.select2('data').text); |                data = this.$input.select2('data'); | ||||||
|            } else { //on init (autotext) |            } else { //on init (autotext) | ||||||
|                //todo: here select2 instance not created yet and data may be even not loaded. |                //here select2 instance not created yet and data may be even not loaded. | ||||||
|                //but we can check data property of select and if it exist find text |                //but we can check data/tags property of select and if it exist lookup text | ||||||
|                $(element).text(''); |                if(this.options.select2.tags) { | ||||||
|  |                    data = value; | ||||||
|  |                } else if(this.options.select2.data) { | ||||||
|  |                    data = $.fn.editableutils.itemsByValue(value, this.options.select2.data, 'id');    | ||||||
|                } |                } | ||||||
|  |            } | ||||||
|  |             | ||||||
|  |            if($.isArray(data)) { | ||||||
|  |                //collect selected data and show with separator | ||||||
|  |                text = []; | ||||||
|  |                $.each(data, function(k, v){ | ||||||
|  |                    text.push(v && typeof v === 'object' ? v.text : v);  | ||||||
|  |                });                    | ||||||
|  |            } else if(data) { | ||||||
|  |                text = data.text;   | ||||||
|  |            } | ||||||
|  |  | ||||||
|  |            text = $.isArray(text) ? text.join(this.options.viewseparator) : text; | ||||||
|  |             | ||||||
|  |            $(element).text(text); | ||||||
|        },        |        },        | ||||||
|          |          | ||||||
|        html2value: function(html) { |        html2value: function(html) { | ||||||
| @@ -68,13 +103,29 @@ $(function(){ | |||||||
|        },  |        },  | ||||||
|         |         | ||||||
|        value2input: function(value) { |        value2input: function(value) { | ||||||
|            this.$input.select2('val', value); | //           this.$input.val(value).select2('val', value); | ||||||
| //           this.$input.val(value); |            this.$input.val(value).trigger('change'); | ||||||
|        }, |        }, | ||||||
|         |         | ||||||
|        input2value: function() {  |        input2value: function() {  | ||||||
|            return this.$input.select2('val'); |            return this.$input.select2('val'); | ||||||
| //           return this.$input.val(); | //           return this.$input.val(); | ||||||
|  |        }, | ||||||
|  |  | ||||||
|  |        str2value: function(str) { | ||||||
|  |             if(typeof str !== 'string') { | ||||||
|  |                 return str; | ||||||
|  |             } | ||||||
|  |             var val, i, l, | ||||||
|  |                 separator = this.options.select2.separator || $.fn.select2.defaults.separator; | ||||||
|  |             if (str === null || str.length < 1) { | ||||||
|  |                 return null; | ||||||
|  |             } | ||||||
|  |             val = str.split(separator); | ||||||
|  |             for (i = 0, l = val.length; i < l; i = i + 1) { | ||||||
|  |                 val[i] = $.trim(val[i]); | ||||||
|  |             } | ||||||
|  |             return val; | ||||||
|        }         |        }         | ||||||
|          |          | ||||||
|     });       |     });       | ||||||
| @@ -105,7 +156,15 @@ $(function(){ | |||||||
|         Source data for select. It will be assigned to select2 `data` property and kept just for convenience. |         Source data for select. It will be assigned to select2 `data` property and kept just for convenience. | ||||||
|         Please note, that format is different from simple `select` input.   |         Please note, that format is different from simple `select` input.   | ||||||
|         **/ |         **/ | ||||||
|         source: null         |         source: null, | ||||||
|  |         /** | ||||||
|  |         Separator used to display tags.  | ||||||
|  |          | ||||||
|  |         @property viewseparator  | ||||||
|  |         @type string | ||||||
|  |         @default ', '         | ||||||
|  |         **/ | ||||||
|  |         viewseparator: ', '         | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     $.fn.editabletypes.select2 = Constructor;       |     $.fn.editabletypes.select2 = Constructor;       | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 vitalets
					vitalets