spartan-multi-image-picker
Advanced tools
Comparing version 1.0.1-rc.1 to 1.0.1-rc.2
{ | ||
"name": "spartan-multi-image-picker", | ||
"description": "Multi image picker for you", | ||
"description": "A Jquery multi image picker with preview (with madness)", | ||
"main": "index.js", | ||
@@ -8,6 +8,10 @@ "authors": [ | ||
], | ||
"dependencies" : { | ||
"jquery": "~3.3.1" | ||
}, | ||
"license": "ISC", | ||
"keywords": [ | ||
"ImagePicker", | ||
"MultiImagePicker" | ||
"MultiImagePicker", | ||
"Jquery Plugin" | ||
], | ||
@@ -14,0 +18,0 @@ "homepage": "https://github.com/adispartadev/spartan-multi-image-picker", |
@@ -1,1 +0,1 @@ | ||
!function(e){"use strict";e.fn.spartanMultiImagePicker=function(a){var A=0,t=0,i=0,n={fieldName:"",groupClassName:"col-md-4 col-sm-4 col-xs-6",rowHeight:"200px",placeholderImage:{image:"",width:"64px"},maxCount:"",allowedExt:"png|jpg|jpeg|gif",onAddRow:function(){},onRenderedPreview:function(){},onRemoveRow:function(){},onExtensionErr:function(){}},r=e.extend({},n,a);function d(a,i){t=A;var n=a.groupClassName,r=a.rowHeight,d=a.fieldName,o=a.placeholderImage,l=`<div class="${n}" data-spartanindexrow="${A}" style="margin-bottom : 20px;">`+`<label class="file_upload" style="width: 100%; height: ${r}; border: 2px dashed #ddd; border-radius: 3px; cursor: pointer; text-align: center; overflow: hidden; padding: 5px; margin-top: 5px; margin-bottom : 5px; position : relative; display: flex; align-items: center; margin: auto; justify-content: center; flex-direction: column;">`+`<a href="javascript:void(0)" data-spartanindexremove="${A}" style="position: absolute !important; right : 3px; top: 3px; display : none; background : #ED3C20; border-radius: 3px; width: 30px; height: 30px; line-height : 30px; text-align: center; text-decoration : none; color : #FFF;" class="spartan_remove_row">✖</a>`+`<img style="width: ${o.width}; margin: 0 auto; vertical-align: middle;" data-spartanindexi="${A}" src="${o.image}" /> `+`<img style="width: 100%; vertical-align: middle; display:none;" class="img_" data-spartanindeximage="${A}">`+`<input class="form-control spartan_image_input" accept="image/*" data-spartanindexinput="${A}" style="display : none" name="${d}" type="file">`+"</label> </div>",s=e.parseHTML(l);e(i).append(s);++A;a.onAddRow.call()}return this.each(function(){var a=this;d(r,a),e(this).on("change",".spartan_image_input",function(){!function(a,A,t){if(A.files&&A.files[0]){var n=A.files[0],r=a.allowedExt,o=n.type;if(!new RegExp(`(.*?).(${r})$`).test(o))return a.onExtensionErr.call(),!1;var l=new FileReader;l.onload=function(i){var n=e(A).data("spartanindexinput");e(t).find('img[data-spartanindexi="'+n+'"]').hide(),e(t).find('a[data-spartanindexremove="'+n+'"]').show(),e(t).find('img[data-spartanindeximage="'+n+'"]').attr("src",i.target.result),e(t).find('img[data-spartanindeximage="'+n+'"]').show(),a.onRenderedPreview.call()},l.readAsDataURL(A.files[0]),i++,""==a.maxCount?d(a,t):""!=a.maxCount&&i<a.maxCount&&d(a,t)}}(r,this,a)}),e(this).on("click",".spartan_remove_row",function(){!function(a,A,n){var r=e(A).data("spartanindexremove");e(n).find('[data-spartanindexrow="'+r+'"]').remove(),t==r&&d(a,n),i--,a.onRemoveRow.call()}(r,this,a)})})}}(jQuery); | ||
!function(e){"use strict";e.fn.spartanMultiImagePicker=function(a){var A=0,i=0,t=0,n={fieldName:"",groupClassName:"col-md-4 col-sm-4 col-xs-6",rowHeight:"200px",placeholderImage:{image:"",width:"64px"},maxCount:"",maxFileSize:"",allowedExt:"png|jpg|jpeg|gif",onAddRow:function(){},onRenderedPreview:function(){},onRemoveRow:function(){},onExtensionErr:function(){},onSizeErr:function(){}},r=e.extend({},n,a);function o(a,t){i=A;var n=a.groupClassName,r=a.rowHeight,o=a.fieldName,d=a.placeholderImage,l=`<div class="${n}" data-spartanindexrow="${A}" style="margin-bottom : 20px;">`+`<label class="file_upload" style="width: 100%; height: ${r}; border: 2px dashed #ddd; border-radius: 3px; cursor: pointer; text-align: center; overflow: hidden; padding: 5px; margin-top: 5px; margin-bottom : 5px; position : relative; display: flex; align-items: center; margin: auto; justify-content: center; flex-direction: column;">`+`<a href="javascript:void(0)" data-spartanindexremove="${A}" style="position: absolute !important; right : 3px; top: 3px; display : none; background : #ED3C20; border-radius: 3px; width: 30px; height: 30px; line-height : 30px; text-align: center; text-decoration : none; color : #FFF;" class="spartan_remove_row">✖</a>`+`<img style="width: ${d.width}; margin: 0 auto; vertical-align: middle;" data-spartanindexi="${A}" src="${d.image}" /> `+`<img style="width: 100%; vertical-align: middle; display:none;" class="img_" data-spartanindeximage="${A}">`+`<input class="form-control spartan_image_input" accept="image/*" data-spartanindexinput="${A}" style="display : none" name="${o}" type="file">`+"</label> </div>",s=e.parseHTML(l);e(t).append(s);++A;a.onAddRow.call()}return this.each(function(){var a=this;o(r,a),e(this).on("change",".spartan_image_input",function(){!function(a,A,i){if(A.files&&A.files[0]){var n=A.files[0],r=a.allowedExt,d=a.maxFileSize,l=n.type;if(!new RegExp(`(.*?).(${r})$`).test(l))return a.onExtensionErr.call(),!1;if(""==d||""!=d&&n.size<=d){var s=new FileReader;s.onload=function(t){var n=e(A).data("spartanindexinput");e(i).find('img[data-spartanindexi="'+n+'"]').hide(),e(i).find('a[data-spartanindexremove="'+n+'"]').show(),e(i).find('img[data-spartanindeximage="'+n+'"]').attr("src",t.target.result),e(i).find('img[data-spartanindeximage="'+n+'"]').show(),a.onRenderedPreview.call()},s.readAsDataURL(A.files[0]),t++,""==a.maxCount?o(a,i):""!=a.maxCount&&t<a.maxCount&&o(a,i)}else if(""!=d&&n.size>d)a.onSizeErr.call()}}(r,this,a)}),e(this).on("click",".spartan_remove_row",function(){!function(a,A,n){var r=e(A).data("spartanindexremove");e(n).find('[data-spartanindexrow="'+r+'"]').remove(),i==r&&o(a,n),t--,a.onRemoveRow.call()}(r,this,a)})})}}(jQuery); |
@@ -25,2 +25,3 @@ /** | ||
maxCount: '', | ||
maxFileSize: '', | ||
allowedExt: 'png|jpg|jpeg|gif', | ||
@@ -30,3 +31,4 @@ onAddRow: function() {}, | ||
onRemoveRow: function() {}, | ||
onExtensionErr: function() {} | ||
onExtensionErr: function() {}, | ||
onSizeErr: function() {} | ||
}; | ||
@@ -76,26 +78,35 @@ | ||
var file_select = input.files[0], allowedExt = settings.allowedExt; | ||
var file_select = input.files[0], allowedExt = settings.allowedExt, maxFileSize = settings.maxFileSize; | ||
var file_select_type = file_select.type, | ||
regex = new RegExp(`(.*?)\.(${allowedExt})$`); | ||
if(regex.test(file_select_type)){ | ||
var reader = new FileReader(); | ||
reader.onload = function(e) { | ||
var index = $(input).data('spartanindexinput'); | ||
$(parent).find('img[data-spartanindexi="'+index+'"]').hide(); | ||
$(parent).find('a[data-spartanindexremove="'+index+'"]').show(); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').attr('src', e.target.result); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').show(); | ||
settings.onRenderedPreview.call(); | ||
}; | ||
if((maxFileSize == '') || (maxFileSize != '' && file_select.size <= maxFileSize)){ | ||
reader.readAsDataURL(input.files[0]); | ||
total_count++; | ||
if(settings.maxCount == ''){ | ||
addRow(settings, parent); | ||
var reader = new FileReader(); | ||
reader.onload = function(e) { | ||
var index = $(input).data('spartanindexinput'); | ||
$(parent).find('img[data-spartanindexi="'+index+'"]').hide(); | ||
$(parent).find('a[data-spartanindexremove="'+index+'"]').show(); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').attr('src', e.target.result); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').show(); | ||
settings.onRenderedPreview.call(); | ||
}; | ||
reader.readAsDataURL(input.files[0]); | ||
total_count++; | ||
if(settings.maxCount == ''){ | ||
addRow(settings, parent); | ||
} | ||
else if(settings.maxCount != '' && total_count < settings.maxCount ){ | ||
addRow(settings, parent); | ||
} | ||
} | ||
else if(settings.maxCount != '' && total_count < settings.maxCount ){ | ||
addRow(settings, parent); | ||
else if(maxFileSize != '' && file_select.size > maxFileSize){ | ||
settings.onSizeErr.call(); | ||
return false; | ||
} | ||
} | ||
@@ -102,0 +113,0 @@ else{ |
{ | ||
"name": "spartan-multi-image-picker", | ||
"version": "1.0.1-rc.1", | ||
"description": "Multi image picker for you", | ||
"version": "1.0.1-rc.2", | ||
"description": "A Jquery multi image picker with preview (with madness)", | ||
"main": "index.js", | ||
@@ -27,2 +27,3 @@ "scripts": { | ||
"keywords": [ | ||
"Jquery Plugin", | ||
"ImagePicker", | ||
@@ -29,0 +30,0 @@ "MultiImagePicker" |
# spartan-multi-image-picker | ||
This plugin enable you to upload multiple files on a html form without giving your dummy user a pain in the ass to hold their `Ctrl` keyboard. | ||
This plugin enable you to upload multiple files on a html form without giving your dummy user a pain in the ass to hold their `Ctrl` keyboard for non ajax upload file. | ||
@@ -47,7 +47,8 @@ | ||
| `fieldName` | String | `fileUpload[]` or `fileUpload` for single image | | ||
| `maxCount` | Number | `1`, `2` | | ||
| `maxCount` | Number | `1`, `2` remove for unlimited count | | ||
| `rowHeight` | String | `200px` | | ||
| `groupClassName` | String | `col-md-4 col-sm-4 col-xs-6` | | ||
| `allowedExt` | String | `png|jpg|jpeg|gif` | | ||
| `allowedExt` | String | `png|jpg|jpeg|gif` or empty string for all type | | ||
| `placeholderImage` | Object with `image` and `width` properties | `{ image: 'placeholder.png', width: '100%'}` | | ||
| `maxFileSize` | Number (in kb) | `40000` | | ||
@@ -62,2 +63,3 @@ ### Callback | ||
| `onExtensionErr` | Called on extension didn't match as `allowedExtension` | | ||
| `onSizeErr` | Called on image size is more than `maxFileSize` prop | | ||
@@ -87,5 +89,9 @@ ### Full customize example: | ||
console.log('extension error'); | ||
alert('Please only input png or jpg type file') | ||
alert('Please only input png or jpg type file'); | ||
}, | ||
onSizeErr : function(){ | ||
console.log('file size too big'); | ||
alert('File size too big'); | ||
} | ||
}); | ||
``` |
@@ -25,2 +25,3 @@ /** | ||
maxCount: '', | ||
maxFileSize: '', | ||
allowedExt: 'png|jpg|jpeg|gif', | ||
@@ -30,3 +31,4 @@ onAddRow: function() {}, | ||
onRemoveRow: function() {}, | ||
onExtensionErr: function() {} | ||
onExtensionErr: function() {}, | ||
onSizeErr: function() {} | ||
}; | ||
@@ -76,26 +78,37 @@ | ||
var file_select = input.files[0], allowedExt = settings.allowedExt; | ||
var file_select = input.files[0], allowedExt = settings.allowedExt, maxFileSize = settings.maxFileSize; | ||
var file_select_type = file_select.type, | ||
regex = new RegExp(`(.*?)\.(${allowedExt})$`); | ||
if(regex.test(file_select_type)){ | ||
var reader = new FileReader(); | ||
reader.onload = function(e) { | ||
var index = $(input).data('spartanindexinput'); | ||
$(parent).find('img[data-spartanindexi="'+index+'"]').hide(); | ||
$(parent).find('a[data-spartanindexremove="'+index+'"]').show(); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').attr('src', e.target.result); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').show(); | ||
settings.onRenderedPreview.call(); | ||
}; | ||
if((maxFileSize == '') || (maxFileSize != '' && file_select.size <= maxFileSize)){ | ||
reader.readAsDataURL(input.files[0]); | ||
total_count++; | ||
if(settings.maxCount == ''){ | ||
addRow(settings, parent); | ||
var reader = new FileReader(); | ||
reader.onload = function(e) { | ||
var index = $(input).data('spartanindexinput'); | ||
$(parent).find('img[data-spartanindexi="'+index+'"]').hide(); | ||
$(parent).find('a[data-spartanindexremove="'+index+'"]').show(); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').attr('src', e.target.result); | ||
$(parent).find('img[data-spartanindeximage="'+index+'"]').show(); | ||
settings.onRenderedPreview.call(); | ||
}; | ||
reader.readAsDataURL(input.files[0]); | ||
total_count++; | ||
if(settings.maxCount == ''){ | ||
addRow(settings, parent); | ||
} | ||
else if(settings.maxCount != '' && total_count < settings.maxCount ){ | ||
addRow(settings, parent); | ||
} | ||
} | ||
else if(settings.maxCount != '' && total_count < settings.maxCount ){ | ||
addRow(settings, parent); | ||
else if(maxFileSize != '' && file_select.size > maxFileSize){ | ||
settings.onSizeErr.call(); | ||
return false; | ||
} | ||
} | ||
@@ -102,0 +115,0 @@ else{ |
1683995
11
313
94