New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

spartan-multi-image-picker

Package Overview
Dependencies
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

spartan-multi-image-picker - npm Package Compare versions

Comparing version 1.0.1-rc.1 to 1.0.1-rc.2

_config.yml

8

bower.json
{
"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">&#10006;</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">&#10006;</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{

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc