You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

318 lines
16 KiB

/**
* spartan-multi-image-picker.js
* Repo : https://github.com/adispartadev/spartan-multi-image-picker
* Created By I Wayan Adi Sparta, 2018
*/
(function ($) {
"use strict";
var ADDICON = '';
$.fn.spartanMultiImagePicker = function(options) {
var count = 0;
var last_index = 0;
var total_count = 0;
var defaults = {
fieldName: '',
groupClassName: 'col-md-4 col-sm-4 col-xs-6',
rowHeight: '200px',
dropFileLabel: 'Drop file here',
placeholderImage: {
image : ADDICON,
width : '64px'
},
maxCount: '',
maxFileSize: '',
allowedExt: 'png|jpg|jpeg|gif',
onAddRow: function() {},
onRenderedPreview: function() {},
onRemoveRow: function() {},
onExtensionErr: function() {},
onSizeErr: function() {},
directUpload : {
loaderIcon: '<i class="fas fa-sync fa-spin"></i>',
status: false,
url: '',
success: function() {},
error: function() {}
},
};
var settings = $.extend( {}, defaults, options );
/**
* CALLED ON IMAGE SUCCESS RENDERED AND ADD NEW IMAGE
* @param {[type]} settings [description]
* @param {[type]} el [description]
*/
function addRow(settings, el){
last_index = count;
var groupClassName = settings.groupClassName, rowHeight = settings.rowHeight, fieldName = settings.fieldName, placeholderImage = settings.placeholderImage, dropFileLabel = settings.dropFileLabel;
var placeholderImageTarget = placeholderImage.image;
var placeholderImageWidth = '64px';
var uploadLoaderIcon = '<i class="fas fa-sync fa-spin"></i>';
if(typeof settings.directUpload.loaderIcon != 'undefined'){
uploadLoaderIcon = settings.directUpload.loaderIcon;
}
if(typeof placeholderImage.width != 'undefined'){
placeholderImageWidth = placeholderImage.width;
}
var template = `<div class="${groupClassName} spartan_item_wrapper" data-spartanindexrow="${count}" style="margin-bottom : 20px; ">`+
`<div style="position: relative;">`+
`<div class="spartan_item_loader" data-spartanindexloader="${count}" style=" position: absolute; width: 100%; height: ${rowHeight}; background: rgba(255,255,255, 0.7); z-index: 22; text-align: center; align-items: center; margin: auto; justify-content: center; flex-direction: column; display : none; font-size : 1.7em; color: #CECECE">` +
`${uploadLoaderIcon}` +
`</div>`+
`<label class="file_upload" style="width: 100%; height: ${rowHeight}; 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="${count}" style="position: absolute !important; right : 3px; top: 3px; display : none; background : transparent; border-radius: 3px; width: 30px; height: 30px; line-height : 30px; text-align: center; text-decoration : none; color : #ff0700;" class="spartan_remove_row"><i class="tio-add-to-trash"></i></a>`+
`<img style="width: ${placeholderImageWidth}; margin: 0 auto; vertical-align: middle;" data-spartanindexi="${count}" src="${placeholderImageTarget}" class="spartan_image_placeholder" /> `+
`<p data-spartanlbldropfile="${count}" style="color : #5FAAE1; display: none; width : auto; ">${dropFileLabel}</p>`+
`<img style="width: 100%; vertical-align: middle; display:none;" class="img_" data-spartanindeximage="${count}">`+
`<input class="form-control spartan_image_input" accept="image/*" data-spartanindexinput="${count}" style="display : none" name="${fieldName}" type="file">`+
`</label> `+
`</div>`+
`</div>`;
var html = $.parseHTML(template);
$(el).append(html);
count++;
var param = {
index : count,
last_index : last_index
};
settings.onAddRow.call(this, count);
}
/**
* CALLED ON IMAGE RENDERED
* @param {[type]} settings [description]
* @param {[type]} input [description]
* @param {[type]} parent [description]
* @return {[type]} [description]
*/
function loadImage(settings, input, parent){
var index = $(input).data('spartanindexinput');
if (input.files && input.files[0]) {
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) || allowedExt == ''){
if((maxFileSize == '') || (maxFileSize != '' && file_select.size <= maxFileSize)){
var reader = new FileReader();
reader.onload = function(e) {
$(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(this, index);
// on upload
if(settings.directUpload.status == true){
actionDirectUpload(settings, input, parent);
}
};
reader.readAsDataURL(input.files[0]);
var is_add = false;
if( $(parent).find('img[data-spartanindeximage="'+index+'"]').is(":visible") == false){
total_count++;
is_add = true;
}
if(index == (count - 1) && is_add ){
if(settings.maxCount == ''){
addRow(settings, parent);
}
else if(settings.maxCount != '' && total_count < settings.maxCount ){
addRow(settings, parent);
}
}
}
else if(maxFileSize != '' && file_select.size > maxFileSize){
if( $(parent).find('img[data-spartanindeximage="'+index+'"]').is(":visible") == true){
$(parent).find('img[data-spartanindexi="'+index+'"]').hide();
}
settings.onSizeErr.call(this, index, file_select);
return false;
}
}
else{
if( $(parent).find('img[data-spartanindeximage="'+index+'"]').is(":visible") == true){
$(parent).find('img[data-spartanindexi="'+index+'"]').hide();
}
settings.onExtensionErr.call(this, index, file_select);
return false;
}
}
}
/**
* CALLED ON UPLOAD IS ON
* @param {[type]} settings [description]
* @param {[type]} input [description]
* @param {[type]} parent [description]
* @return {[type]} [description]
*/
function actionDirectUpload(settings, input, parent){
var index = $(input).data('spartanindexinput');
var formData = new FormData();
var file = input.files[0];
var additionalParam = settings.directUpload.additionalParam;
$(parent).find('[data-spartanindexloader="'+index+'"]').css('display', 'flex');
formData.append('file', file);
if(typeof additionalParam != 'undefined'){
$.each(additionalParam, function(key, value){
formData.append(key, value);
});
}
$.ajax({
url: settings.directUpload.url,
type: 'POST',
data: formData,
cache: false,
processData: false,
contentType: false,
success: function(data, textStatus, jqXHR){
$(parent).find('[data-spartanindexloader="'+index+'"]').css('display', 'none');
if(typeof settings.directUpload.success != 'undefined'){
settings.directUpload.success(this, data, textStatus, jqXHR);
}
},
error: function(jqXHR, textStatus, errorThrown){
$(parent).find('[data-spartanindexloader="'+index+'"]').css('display', 'none');
if(typeof settings.directUpload.error != 'undefined'){
settings.directUpload.error(this, jqXHR, textStatus, errorThrown);
}
}
});
}
/**
* CALLED ON CLOSE BUTTON CLICK
* @param {[type]} settings [description]
* @param {[type]} input [description]
* @param {[type]} parent [description]
* @return {[type]} [description]
*/
function removeRow(settings, input, parent){
var index = $(input).data('spartanindexremove');
$(parent).find('[data-spartanindexrow="'+index+'"]').remove();
if (last_index == index || $(parent).find('img[data-spartanindeximage="'+last_index+'"]').is(":visible") == true){
addRow(settings, parent);
}
total_count--;
settings.onRemoveRow.call(this, index);
}
/**
* CALLED ON HOVER THE BOX
* @param {[type]} parent [description]
* @return {[type]} [description]
*/
function onDragEnter(parent){
var index = $(parent).data('spartanindexrow');
$(parent).find('.file_upload').css({'border-color': '#5FAAE1', 'background' : '#DBE9F3'});
if( $(parent).find('img[data-spartanindeximage="'+index+'"]').is(":visible") == false){
$(parent).find('p[data-spartanlbldropfile="'+index+'"]').show();
$(parent).find('img[data-spartanindexi="'+index+'"]').hide();
}
}
/**
* ON LEAVE BOX
* @param {[type]} parent [description]
* @return {[type]} [description]
*/
function onDragLeave(parent){
var index = $(parent).data('spartanindexrow');
$(parent).find('.file_upload').css({'border-color': '#ddd', 'background' : 'none'});
if( $(parent).find('img[data-spartanindeximage="'+index+'"]').is(":visible") == false){
$(parent).find('p[data-spartanlbldropfile="'+index+'"]').hide();
$(parent).find('img[data-spartanindexi="'+index+'"]').show();
}
}
/**
* DROP IMAGE TO BOX
* 1. GET THE FILE
* 2. RESET STYLING
* 3. RENDER THE IMAGE
* @param {[type]} setting [description]
* @param {[type]} input [description]
* @param {[type]} parent [description]
* @param {[type]} evt [description]
* @return {[type]} [description]
*/
function onDropImage(setting, input, parent, evt){
var index = $(input).data('spartanindexrow');
var file_p = $(parent).find('.spartan_image_input[data-spartanindexinput="'+index+'"]');
file_p.files = evt.originalEvent.dataTransfer.files;
// clear on hover style
$(input).find('.file_upload').css({'border-color': '#ddd', 'background' : 'none'});
$(input).find('p[data-spartanlbldropfile="'+index+'"]').hide();
$(input).find('img[data-spartanindexi="'+index+'"]').show();
loadImage(settings, file_p, parent);
}
return this.each( function() {
var that = this;
addRow(settings, that);
$(this).on("change", ".spartan_image_input", function(){
loadImage(settings, this, that);
});
$(this).on("click", ".spartan_remove_row", function(){
removeRow(settings, this, that);
});
$(this).on("dragenter dragover dragstart", '.spartan_item_wrapper', function(event){
event.stopPropagation();
event.preventDefault();
onDragEnter(this);
});
$(this).on("dragleave", '.spartan_item_wrapper', function(){
onDragLeave(this);
});
$(this).on("drop", '.spartan_item_wrapper', function(event){
event.stopPropagation();
event.preventDefault();
onDropImage(settings, this, that, event);
});
});
};
})(jQuery);