Your IP : 216.73.217.77


Current Path : /home/users/unlimited/www/admin.priyotama.com/public/assets/admin/js/
Upload File :
Current File : /home/users/unlimited/www/admin.priyotama.com/public/assets/admin/js/spartan-multi-image-picker.js

/**
 * 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 =
        "data:image/png;base64,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";
    $.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);