1621 lines
		
	
	
		
			50 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			1621 lines
		
	
	
		
			50 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
/**
 | 
						|
 * Copyright © Magento, Inc. All rights reserved.
 | 
						|
 * See COPYING.txt for license details.
 | 
						|
 */
 | 
						|
 | 
						|
// also depends on a mage/adminhtml/tools.js for Base64 encoding
 | 
						|
/* global varienGrid, setLocation, varienGlobalEvents, FORM_KEY,
 | 
						|
    BASE_URL, Base64, varienGridMassaction, varienStringArray, serializerController
 | 
						|
*/
 | 
						|
/* eslint-disable strict */
 | 
						|
define([
 | 
						|
    'jquery',
 | 
						|
    'mage/template',
 | 
						|
    'Magento_Ui/js/modal/alert',
 | 
						|
    'Magento_Ui/js/modal/confirm',
 | 
						|
    'mage/mage',
 | 
						|
    'prototype',
 | 
						|
    'mage/adminhtml/form',
 | 
						|
    'mage/adminhtml/events'
 | 
						|
], function (jQuery, mageTemplate, alert, confirm) {
 | 
						|
    /**
 | 
						|
     * @param {*} grid
 | 
						|
     * @param {*} event
 | 
						|
     */
 | 
						|
    function openGridRow(grid, event) {
 | 
						|
        var element = Event.findElement(event, 'tr');
 | 
						|
 | 
						|
        if (['a', 'input', 'select', 'option'].indexOf(Event.element(event).tagName.toLowerCase()) !== -1) {
 | 
						|
            return;
 | 
						|
        }
 | 
						|
 | 
						|
        if (element.title) {
 | 
						|
            setLocation(element.title);
 | 
						|
        }
 | 
						|
    }
 | 
						|
    window.openGridRow = openGridRow;
 | 
						|
 | 
						|
    window.varienGrid = new Class.create();
 | 
						|
 | 
						|
    varienGrid.prototype = {
 | 
						|
        /**
 | 
						|
         * @param {String} containerId
 | 
						|
         * @param {String} url
 | 
						|
         * @param {*} pageVar
 | 
						|
         * @param {*} sortVar
 | 
						|
         * @param {*} dirVar
 | 
						|
         * @param {*} filterVar
 | 
						|
         */
 | 
						|
        initialize: function (containerId, url, pageVar, sortVar, dirVar, filterVar) {
 | 
						|
            this.containerId = containerId;
 | 
						|
            jQuery('#' + containerId).data('gridObject', this);
 | 
						|
            this.url = url;
 | 
						|
            this.pageVar = pageVar || false;
 | 
						|
            this.sortVar = sortVar || false;
 | 
						|
            this.dirVar = dirVar || false;
 | 
						|
            this.filterVar = filterVar || false;
 | 
						|
            this.tableSufix = '_table';
 | 
						|
            this.useAjax = false;
 | 
						|
            this.rowClickCallback = false;
 | 
						|
            this.checkboxCheckCallback = false;
 | 
						|
            this.preInitCallback = false;
 | 
						|
            this.initCallback = false;
 | 
						|
            this.initRowCallback = false;
 | 
						|
            this.doFilterCallback = false;
 | 
						|
            this.sortableUpdateCallback = false;
 | 
						|
            this.targetElement = undefined;
 | 
						|
            this.filterKeyPressCallback = false;
 | 
						|
 | 
						|
            this.reloadParams = false;
 | 
						|
 | 
						|
            this.trOnMouseOver = this.rowMouseOver.bindAsEventListener(this);
 | 
						|
            this.trOnMouseOut = this.rowMouseOut.bindAsEventListener(this);
 | 
						|
            this.trOnMouseDown = this.rowMouseDown.bindAsEventListener(this);
 | 
						|
            this.trOnClick = this.rowMouseClick.bindAsEventListener(this);
 | 
						|
            this.trOnDblClick = this.rowMouseDblClick.bindAsEventListener(this);
 | 
						|
            this.trOnKeyPress = this.keyPress.bindAsEventListener(this);
 | 
						|
 | 
						|
            this.thLinkOnClick = this.doSort.bindAsEventListener(this);
 | 
						|
            this.initGrid();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Init grid.
 | 
						|
         */
 | 
						|
        initGrid: function () {
 | 
						|
            var row, columns, col;
 | 
						|
 | 
						|
            if (this.preInitCallback) {
 | 
						|
                this.preInitCallback(this);
 | 
						|
            }
 | 
						|
 | 
						|
            if ($(this.containerId + this.tableSufix)) {
 | 
						|
                this.rows = $$('#' + this.containerId + this.tableSufix + ' tbody tr');
 | 
						|
 | 
						|
                for (row = 0; row < this.rows.length; row++) {
 | 
						|
                    if (row % 2 == 0) { //eslint-disable-line eqeqeq, max-depth
 | 
						|
                        Element.addClassName(this.rows[row], 'even');
 | 
						|
                    }
 | 
						|
 | 
						|
                    Event.observe(this.rows[row], 'mouseover', this.trOnMouseOver);
 | 
						|
                    Event.observe(this.rows[row], 'mouseout', this.trOnMouseOut);
 | 
						|
                    Event.observe(this.rows[row], 'mousedown', this.trOnMouseDown);
 | 
						|
                    Event.observe(this.rows[row], 'click', this.trOnClick);
 | 
						|
                    Event.observe(this.rows[row], 'dblclick', this.trOnDblClick);
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            if (this.sortVar && this.dirVar) {
 | 
						|
                columns = $$('#' + this.containerId + this.tableSufix + ' thead [data-sort]');
 | 
						|
 | 
						|
                for (col = 0; col < columns.length; col++) {
 | 
						|
                    Event.observe(columns[col], 'click', this.thLinkOnClick);
 | 
						|
                }
 | 
						|
            }
 | 
						|
            this.bindFilterFields();
 | 
						|
            this.bindFieldsChange();
 | 
						|
 | 
						|
            if (this.initCallback) {
 | 
						|
                try {
 | 
						|
                    this.initCallback(this);
 | 
						|
                } catch (e) {
 | 
						|
                    if (window.console) { //eslint-disable-line max-depth
 | 
						|
                        console.log(e);
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
            jQuery('#' + this.containerId).trigger('gridinit', this);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Init grid ajax.
 | 
						|
         */
 | 
						|
        initGridAjax: function () {
 | 
						|
            this.initGrid();
 | 
						|
            this.initGridRows();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Init grid rows.
 | 
						|
         */
 | 
						|
        initGridRows: function () {
 | 
						|
            var row;
 | 
						|
 | 
						|
            if (this.initRowCallback) {
 | 
						|
                for (row = 0; row < this.rows.length; row++) {
 | 
						|
                    try { //eslint-disable-line max-depth
 | 
						|
                        this.initRowCallback(this, this.rows[row]);
 | 
						|
                    } catch (e) {
 | 
						|
                        if (window.console) { //eslint-disable-line max-depth
 | 
						|
                            console.log(e);
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} event
 | 
						|
         */
 | 
						|
        rowMouseOver: function (event) {
 | 
						|
            var element = Event.findElement(event, 'tr');
 | 
						|
 | 
						|
            if (!element.title) {
 | 
						|
                return;
 | 
						|
            }
 | 
						|
 | 
						|
            Element.addClassName(element, 'on-mouse');
 | 
						|
 | 
						|
            if (!Element.hasClassName('_clickable') && (this.rowClickCallback !== openGridRow || element.title)) {
 | 
						|
                if (element.title) {
 | 
						|
                    Element.addClassName(element, '_clickable');
 | 
						|
                }
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} event
 | 
						|
         */
 | 
						|
        rowMouseOut: function (event) {
 | 
						|
            var element = Event.findElement(event, 'tr');
 | 
						|
 | 
						|
            Element.removeClassName(element, 'on-mouse');
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} event
 | 
						|
         */
 | 
						|
        rowMouseDown: function (event) {
 | 
						|
            this.targetElement = event.target;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} event
 | 
						|
         */
 | 
						|
        rowMouseClick: function (event) {
 | 
						|
            if (this.rowClickCallback) {
 | 
						|
                try {
 | 
						|
                    this.rowClickCallback(this, event);
 | 
						|
                } catch (e) {
 | 
						|
                }
 | 
						|
            }
 | 
						|
            varienGlobalEvents.fireEvent('gridRowClick', event);
 | 
						|
            this.targetElement = undefined;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} event
 | 
						|
         */
 | 
						|
        rowMouseDblClick: function (event) {
 | 
						|
            varienGlobalEvents.fireEvent('gridRowDblClick', event);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Key press.
 | 
						|
         */
 | 
						|
        keyPress: function () {
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} event
 | 
						|
         * @return {Boolean}
 | 
						|
         */
 | 
						|
        doSort: function (event) {
 | 
						|
            var element = Event.findElement(event, 'th');
 | 
						|
 | 
						|
            if (element.readAttribute('data-sort') && element.readAttribute('data-direction')) {
 | 
						|
                this.addVarToUrl(this.sortVar, element.readAttribute('data-sort'));
 | 
						|
                this.addVarToUrl(this.dirVar, element.readAttribute('data-direction'));
 | 
						|
                this.reload(this.url);
 | 
						|
            }
 | 
						|
            Event.stop(event);
 | 
						|
 | 
						|
            return false;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} element
 | 
						|
         */
 | 
						|
        loadByElement: function (element) {
 | 
						|
            if (element && element.name) {
 | 
						|
                this.reload(this.addVarToUrl(element.name, element.value));
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} data
 | 
						|
         * @param {*} textStatus
 | 
						|
         * @param {*} transport
 | 
						|
         * @private
 | 
						|
         */
 | 
						|
        _onAjaxSeccess: function (data, textStatus, transport) {
 | 
						|
            var responseText, response, divId;
 | 
						|
 | 
						|
            /* eslint-disable max-depth */
 | 
						|
            try {
 | 
						|
                responseText = transport.responseText;
 | 
						|
 | 
						|
                if (transport.responseText.isJSON()) {
 | 
						|
                    response = transport.responseText.evalJSON();
 | 
						|
 | 
						|
                    if (response.error) {
 | 
						|
                        alert({
 | 
						|
                            content: response.message
 | 
						|
                        });
 | 
						|
                    }
 | 
						|
 | 
						|
                    if (response.ajaxExpired && response.ajaxRedirect) {
 | 
						|
                        setLocation(response.ajaxRedirect);
 | 
						|
                    }
 | 
						|
                } else {
 | 
						|
 | 
						|
                    /*eslint-disable max-len*/
 | 
						|
                    /**
 | 
						|
                     * For IE <= 7.
 | 
						|
                     * If there are two elements, and first has name, that equals id of second.
 | 
						|
                     * In this case, IE will choose one that is above
 | 
						|
                     *
 | 
						|
                     * @see https://prototype.lighthouseapp.com/projects/8886/tickets/994-id-selector-finds-elements-by-name-attribute-in-ie7
 | 
						|
                     */
 | 
						|
 | 
						|
                    /*eslint-enable max-len*/
 | 
						|
                    divId = $(this.containerId);
 | 
						|
 | 
						|
                    if (divId.id == this.containerId) { //eslint-disable-line eqeqeq
 | 
						|
                        divId.update(responseText);
 | 
						|
                    } else {
 | 
						|
                        $$('div[id="' + this.containerId + '"]')[0].update(responseText);
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            } catch (e) {
 | 
						|
                divId = $(this.containerId);
 | 
						|
 | 
						|
                if (divId.id == this.containerId) { //eslint-disable-line eqeqeq
 | 
						|
                    divId.update(responseText);
 | 
						|
                } else {
 | 
						|
                    $$('div[id="' + this.containerId + '"]')[0].update(responseText);
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            /* eslint-enable max-depth */
 | 
						|
            jQuery('#' + this.containerId).trigger('contentUpdated');
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} url
 | 
						|
         * @param {Function} onSuccessCallback
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        reload: function (url, onSuccessCallback) {
 | 
						|
            var ajaxSettings, ajaxRequest;
 | 
						|
 | 
						|
            this.reloadParams = this.reloadParams || {};
 | 
						|
            this.reloadParams['form_key'] = FORM_KEY;
 | 
						|
            url = url || this.url;
 | 
						|
 | 
						|
            if (this.useAjax) {
 | 
						|
                ajaxSettings = {
 | 
						|
                    url: url + (url.match(new RegExp('\\?')) ? '&ajax=true' : '?ajax=true'),
 | 
						|
                    showLoader: true,
 | 
						|
                    method: 'post',
 | 
						|
                    context: jQuery('#' + this.containerId),
 | 
						|
                    data: this.reloadParams,
 | 
						|
                    error: this._processFailure.bind(this),
 | 
						|
                    complete: this.initGridAjax.bind(this),
 | 
						|
                    dataType: 'html',
 | 
						|
 | 
						|
                    /**
 | 
						|
                     * Success callback.
 | 
						|
                     */
 | 
						|
                    success: function (data, textStatus, transport) {
 | 
						|
                        this._onAjaxSeccess(data, textStatus, transport);
 | 
						|
 | 
						|
                        if (onSuccessCallback && typeof onSuccessCallback === 'function') {
 | 
						|
                            // execute the callback, passing parameters as necessary
 | 
						|
                            onSuccessCallback();
 | 
						|
                        }
 | 
						|
                    }.bind(this)
 | 
						|
                };
 | 
						|
                jQuery('#' + this.containerId).trigger('gridajaxsettings', ajaxSettings);
 | 
						|
                ajaxRequest = jQuery.ajax(ajaxSettings);
 | 
						|
                jQuery('#' + this.containerId).trigger('gridajax', ajaxRequest);
 | 
						|
 | 
						|
                return ajaxRequest;
 | 
						|
            }
 | 
						|
 | 
						|
            if (this.reloadParams) {
 | 
						|
                $H(this.reloadParams).each(function (pair) {
 | 
						|
                    url = this.addVarToUrl(pair.key, pair.value);
 | 
						|
                }.bind(this));
 | 
						|
            }
 | 
						|
            location.href = url;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @private
 | 
						|
         */
 | 
						|
        _processFailure: function () {
 | 
						|
            location.href = BASE_URL;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} url
 | 
						|
         * @param {*} varName
 | 
						|
         * @param {*} varValue
 | 
						|
         * @return {String|*}
 | 
						|
         * @private
 | 
						|
         */
 | 
						|
        _addVarToUrl: function (url, varName, varValue) {
 | 
						|
            var re = new RegExp('\/(' + varName + '\/.*?\/)'),
 | 
						|
                parts = url.split(new RegExp('\\?'));
 | 
						|
 | 
						|
            url = parts[0].replace(re, '/');
 | 
						|
            url += varName + '/' + varValue + '/';
 | 
						|
 | 
						|
            if (parts.size() > 1) {
 | 
						|
                url += '?' + parts[1];
 | 
						|
            }
 | 
						|
 | 
						|
            return url;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Builds the form with fields containing the and submits
 | 
						|
         *
 | 
						|
         * @param {String} url
 | 
						|
         * @param {String} varName
 | 
						|
         * @param {String} varValue
 | 
						|
         * @private
 | 
						|
         */
 | 
						|
        _buildFormAndSubmit: function (url, varName, varValue) {
 | 
						|
            var re = new RegExp('\/(' + varName + '\/.*?\/)'),
 | 
						|
                parts = url.split(new RegExp('\\?')),
 | 
						|
                form = jQuery('<form></form>'),
 | 
						|
                inputProps = [
 | 
						|
                    {
 | 
						|
                        name: varName,
 | 
						|
                        value: varValue
 | 
						|
                    },
 | 
						|
                    {
 | 
						|
                        name: 'form_key',
 | 
						|
                        value: window.FORM_KEY
 | 
						|
                    }
 | 
						|
                ],
 | 
						|
                input;
 | 
						|
 | 
						|
            url = parts[0].replace(re, '/');
 | 
						|
 | 
						|
            if (parts.size() > 1) {
 | 
						|
                url += '?' + parts[1];
 | 
						|
            }
 | 
						|
 | 
						|
            form.attr('action', url);
 | 
						|
            form.attr('method', 'POST');
 | 
						|
 | 
						|
            inputProps.forEach(function (item) {
 | 
						|
                input = jQuery('<input/>');
 | 
						|
                input.attr('name', item.name);
 | 
						|
                input.attr('type', 'hidden');
 | 
						|
                input.val(item.value);
 | 
						|
                form.append(input);
 | 
						|
            });
 | 
						|
            jQuery('[data-container="body"]').append(form);
 | 
						|
            form.submit();
 | 
						|
            form.remove();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} varName
 | 
						|
         * @param {*} varValue
 | 
						|
         * @return {*|String}
 | 
						|
         */
 | 
						|
        addVarToUrl: function (varName, varValue) {
 | 
						|
            this.url = this._addVarToUrl(this.url, varName, varValue);
 | 
						|
 | 
						|
            return this.url;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Do export.
 | 
						|
         */
 | 
						|
        doExport: function () {
 | 
						|
            var exportUrl;
 | 
						|
 | 
						|
            if ($(this.containerId + '_export')) {
 | 
						|
                exportUrl = $(this.containerId + '_export').value;
 | 
						|
 | 
						|
                if (this.massaction && this.massaction.checkedString) {
 | 
						|
                    this._buildFormAndSubmit(
 | 
						|
                        exportUrl,
 | 
						|
                        this.massaction.formFieldNameInternal,
 | 
						|
                        this.massaction.checkedString
 | 
						|
                    );
 | 
						|
                } else {
 | 
						|
                    location.href = exportUrl;
 | 
						|
                }
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Bind filter fields.
 | 
						|
         */
 | 
						|
        bindFilterFields: function () {
 | 
						|
            var filters = $$(
 | 
						|
                '#' + this.containerId + ' [data-role="filter-form"] input',
 | 
						|
                '#' + this.containerId + ' [data-role="filter-form"] select'
 | 
						|
                ),
 | 
						|
                i;
 | 
						|
 | 
						|
            for (i = 0; i < filters.length; i++) {
 | 
						|
                Event.observe(filters[i], 'keypress', this.filterKeyPress.bind(this));
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Bind field change.
 | 
						|
         */
 | 
						|
        bindFieldsChange: function () {
 | 
						|
            var dataElements, i;
 | 
						|
 | 
						|
            if (!$(this.containerId)) {
 | 
						|
                return;
 | 
						|
            }
 | 
						|
            //var dataElements = $(this.containerId+this.tableSufix).down('.data tbody').select('input', 'select');
 | 
						|
            // eslint-disable-next-line jquery-no-input-event-shorthand
 | 
						|
            dataElements = $(this.containerId + this.tableSufix).down('tbody').select('input', 'select');
 | 
						|
 | 
						|
            for (i = 0; i < dataElements.length; i++) {
 | 
						|
                Event.observe(dataElements[i], 'change', dataElements[i].setHasChanges.bind(dataElements[i]));
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Bind sortable.
 | 
						|
         */
 | 
						|
        bindSortable: function () {
 | 
						|
            if (jQuery('#' + this.containerId).find('.draggable-handle').length) {
 | 
						|
                jQuery('#' + this.containerId).find('tbody').sortable({
 | 
						|
                    axis: 'y',
 | 
						|
                    handle: '.draggable-handle',
 | 
						|
 | 
						|
                    /**
 | 
						|
                     * @param {*} event
 | 
						|
                     * @param {*} ui
 | 
						|
                     * @return {*}
 | 
						|
                     */
 | 
						|
                    helper: function (event, ui) {
 | 
						|
                        ui.children().each(function () {
 | 
						|
                            jQuery(this).width(jQuery(this).width());
 | 
						|
                        });
 | 
						|
 | 
						|
                        return ui;
 | 
						|
                    },
 | 
						|
                    update: this.sortableUpdateCallback ? this.sortableUpdateCallback : function () {
 | 
						|
                    },
 | 
						|
                    tolerance: 'pointer'
 | 
						|
                });
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} event
 | 
						|
         */
 | 
						|
        filterKeyPress: function (event) {
 | 
						|
            if (event.keyCode == Event.KEY_RETURN) { //eslint-disable-line eqeqeq
 | 
						|
                this.doFilter();
 | 
						|
            }
 | 
						|
 | 
						|
            if (this.filterKeyPressCallback) {
 | 
						|
                this.filterKeyPressCallback(this, event);
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Function} callback
 | 
						|
         */
 | 
						|
        doFilter: function (callback) {
 | 
						|
            var filters = $$(
 | 
						|
                '#' + this.containerId + ' [data-role="filter-form"] input',
 | 
						|
                '#' + this.containerId + ' [data-role="filter-form"] select'
 | 
						|
                ),
 | 
						|
                elements = [],
 | 
						|
                i;
 | 
						|
 | 
						|
            for (i in filters) {
 | 
						|
                if (filters[i].value && filters[i].value.length) {
 | 
						|
                    elements.push(filters[i]);
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            if (!this.doFilterCallback || this.doFilterCallback && this.doFilterCallback()) {
 | 
						|
                this.reload(
 | 
						|
                    this.addVarToUrl(this.filterVar, Base64.encode(Form.serializeElements(elements))),
 | 
						|
                    callback
 | 
						|
                );
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Function} callback
 | 
						|
         */
 | 
						|
        resetFilter: function (callback) {
 | 
						|
            this.reload(this.addVarToUrl(this.filterVar, ''), callback);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} element
 | 
						|
         */
 | 
						|
        checkCheckboxes: function (element) {
 | 
						|
            var elements = Element.select($(this.containerId), 'input[name="' + element.name + '"]'),
 | 
						|
                i;
 | 
						|
 | 
						|
            for (i = 0; i < elements.length; i++) {
 | 
						|
                this.setCheckboxChecked(elements[i], element.checked);
 | 
						|
            }
 | 
						|
 | 
						|
            /*eslint-enable no-undef*/
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         *
 | 
						|
         * @param {HTMLElement} element
 | 
						|
         * @param {*} checked
 | 
						|
         */
 | 
						|
        setCheckboxChecked: function (element, checked) {
 | 
						|
            element.checked = checked;
 | 
						|
            jQuery(element).trigger('change');
 | 
						|
            element.setHasChanges({});
 | 
						|
 | 
						|
            if (this.checkboxCheckCallback) {
 | 
						|
                this.checkboxCheckCallback(this, element, checked);
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} event
 | 
						|
         * @param {*} lastId
 | 
						|
         */
 | 
						|
        inputPage: function (event, lastId) {
 | 
						|
            var element = Event.element(event),
 | 
						|
                keyCode = event.keyCode || event.which,
 | 
						|
                enteredValue = parseInt(element.value, 10),
 | 
						|
                pageId = parseInt(lastId, 10);
 | 
						|
 | 
						|
            if (keyCode == Event.KEY_RETURN) { //eslint-disable-line eqeqeq
 | 
						|
                if (enteredValue > pageId) {
 | 
						|
                    this.setPage(pageId);
 | 
						|
                } else {
 | 
						|
                    this.setPage(enteredValue);
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            /*if(keyCode>47 && keyCode<58){
 | 
						|
 | 
						|
             }
 | 
						|
             else{
 | 
						|
             Event.stop(event);
 | 
						|
             }*/
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} pageNumber
 | 
						|
         */
 | 
						|
        setPage: function (pageNumber) {
 | 
						|
            this.reload(this.addVarToUrl(this.pageVar, pageNumber));
 | 
						|
        }
 | 
						|
    };
 | 
						|
 | 
						|
    window.varienGridMassaction = Class.create();
 | 
						|
    varienGridMassaction.prototype = {
 | 
						|
        /* Predefined vars */
 | 
						|
        checkedValues: $H({}),
 | 
						|
        checkedString: '',
 | 
						|
        oldCallbacks: {},
 | 
						|
        errorText: '',
 | 
						|
        items: {},
 | 
						|
        gridIds: [],
 | 
						|
        useSelectAll: false,
 | 
						|
        currentItem: false,
 | 
						|
        lastChecked: {
 | 
						|
            left: false,
 | 
						|
            top: false,
 | 
						|
            checkbox: false
 | 
						|
        },
 | 
						|
        fieldTemplate: mageTemplate('<input type="hidden" name="<%- name %>" value="<%- value %>" />'),
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} containerId
 | 
						|
         * @param {*} grid
 | 
						|
         * @param {*} checkedValues
 | 
						|
         * @param {*} formFieldNameInternal
 | 
						|
         * @param {*} formFieldName
 | 
						|
         */
 | 
						|
        initialize: function (containerId, grid, checkedValues, formFieldNameInternal, formFieldName) {
 | 
						|
            this.setOldCallback('row_click', grid.rowClickCallback);
 | 
						|
            this.setOldCallback('init', grid.initCallback);
 | 
						|
            this.setOldCallback('init_row', grid.initRowCallback);
 | 
						|
            this.setOldCallback('pre_init', grid.preInitCallback);
 | 
						|
 | 
						|
            this.useAjax = false;
 | 
						|
            this.grid = grid;
 | 
						|
            this.grid.massaction = this;
 | 
						|
            this.containerId = containerId;
 | 
						|
            this.initMassactionElements();
 | 
						|
 | 
						|
            this.checkedString = checkedValues;
 | 
						|
            this.formFieldName = formFieldName;
 | 
						|
            this.formFieldNameInternal = formFieldNameInternal;
 | 
						|
 | 
						|
            this.grid.initCallback = this.onGridInit.bind(this);
 | 
						|
            this.grid.preInitCallback = this.onGridPreInit.bind(this);
 | 
						|
            this.grid.initRowCallback = this.onGridRowInit.bind(this);
 | 
						|
            this.grid.rowClickCallback = this.onGridRowClick.bind(this);
 | 
						|
            this.initCheckboxes();
 | 
						|
            this.checkCheckboxes();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} flag
 | 
						|
         */
 | 
						|
        setUseAjax: function (flag) {
 | 
						|
            this.useAjax = flag;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} flag
 | 
						|
         */
 | 
						|
        setUseSelectAll: function (flag) {
 | 
						|
            this.useSelectAll = flag;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Init massaction elements.
 | 
						|
         */
 | 
						|
        initMassactionElements: function () {
 | 
						|
            this.container = $(this.containerId);
 | 
						|
            this.multiselect = $(this.containerId + '-mass-select');
 | 
						|
            this.count = $(this.containerId + '-count');
 | 
						|
            this.formHiddens = $(this.containerId + '-form-hiddens');
 | 
						|
            this.formAdditional = $(this.containerId + '-form-additional');
 | 
						|
            this.select = $(this.containerId + '-select');
 | 
						|
            this.form = this.prepareForm();
 | 
						|
            jQuery(this.form).mage('validation');
 | 
						|
            this.select.observe('change', this.onSelectChange.bindAsEventListener(this));
 | 
						|
            this.lastChecked = {
 | 
						|
                left: false,
 | 
						|
                top: false,
 | 
						|
                checkbox: false
 | 
						|
            };
 | 
						|
            this.select.addClassName(this.select.value ? '_selected' : '');
 | 
						|
            this.initMassSelect();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {jQuery|*|HTMLElement}
 | 
						|
         */
 | 
						|
        prepareForm: function () {
 | 
						|
            var form = $(this.containerId + '-form'),
 | 
						|
                formPlace = null,
 | 
						|
                formElement = this.formHiddens || this.formAdditional;
 | 
						|
 | 
						|
            if (!formElement) {
 | 
						|
                formElement = this.container.getElementsByTagName('button')[0];
 | 
						|
                formElement && formElement.parentNode;
 | 
						|
            }
 | 
						|
 | 
						|
            if (!form && formElement) {
 | 
						|
                /* fix problem with rendering form in FF through innerHTML property */
 | 
						|
                form = document.createElement('form');
 | 
						|
                form.setAttribute('method', 'post');
 | 
						|
                form.setAttribute('action', '');
 | 
						|
                form.id = this.containerId + '-form';
 | 
						|
                formPlace = formElement.parentNode;
 | 
						|
                formPlace.parentNode.appendChild(form);
 | 
						|
                form.appendChild(formPlace);
 | 
						|
            }
 | 
						|
 | 
						|
            return form;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Array} gridIds
 | 
						|
         */
 | 
						|
        setGridIds: function (gridIds) {
 | 
						|
            this.gridIds = gridIds;
 | 
						|
            this.updateCount();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Array}
 | 
						|
         */
 | 
						|
        getGridIds: function () {
 | 
						|
            return this.gridIds;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} items
 | 
						|
         */
 | 
						|
        setItems: function (items) {
 | 
						|
            this.items = items;
 | 
						|
            this.updateCount();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Object}
 | 
						|
         */
 | 
						|
        getItems: function () {
 | 
						|
            return this.items;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} itemId
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        getItem: function (itemId) {
 | 
						|
            if (this.items[itemId]) {
 | 
						|
                return this.items[itemId];
 | 
						|
            }
 | 
						|
 | 
						|
            return false;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {String} callbackName
 | 
						|
         * @return {Function}
 | 
						|
         */
 | 
						|
        getOldCallback: function (callbackName) {
 | 
						|
            return this.oldCallbacks[callbackName] ? this.oldCallbacks[callbackName] : Prototype.emptyFunction;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {String} callbackName
 | 
						|
         * @param {Function} callback
 | 
						|
         */
 | 
						|
        setOldCallback: function (callbackName, callback) {
 | 
						|
            this.oldCallbacks[callbackName] = callback;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} grid
 | 
						|
         */
 | 
						|
        onGridPreInit: function (grid) {
 | 
						|
            this.initMassactionElements();
 | 
						|
            this.getOldCallback('pre_init')(grid);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} grid
 | 
						|
         */
 | 
						|
        onGridInit: function (grid) {
 | 
						|
            this.initCheckboxes();
 | 
						|
            this.checkCheckboxes();
 | 
						|
            this.updateCount();
 | 
						|
            this.getOldCallback('init')(grid);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} grid
 | 
						|
         * @param {*} row
 | 
						|
         */
 | 
						|
        onGridRowInit: function (grid, row) {
 | 
						|
            this.getOldCallback('init_row')(grid, row);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} evt
 | 
						|
         */
 | 
						|
        isDisabled: function (evt) {
 | 
						|
            var target = jQuery(evt.target),
 | 
						|
                tr,
 | 
						|
                checkbox;
 | 
						|
 | 
						|
            tr = target.is('tr') ? target : target.closest('tr');
 | 
						|
            checkbox = tr.find('input[type="checkbox"]');
 | 
						|
 | 
						|
            return checkbox.is(':disabled');
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} grid
 | 
						|
         * @param {*} evt
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        onGridRowClick: function (grid, evt) {
 | 
						|
            var tdElement = Event.findElement(evt, 'td'),
 | 
						|
                trElement = Event.findElement(evt, 'tr'),
 | 
						|
                checkbox, isInput, checked;
 | 
						|
 | 
						|
            if (this.isDisabled(evt)) {
 | 
						|
                return false;
 | 
						|
            }
 | 
						|
 | 
						|
            if (!$(tdElement).down('input')) {
 | 
						|
                if ($(tdElement).down('a') || $(tdElement).down('select')) {
 | 
						|
                    return; //eslint-disable-line
 | 
						|
                }
 | 
						|
 | 
						|
                if (trElement.title && trElement.title.strip() != '#') { //eslint-disable-line eqeqeq
 | 
						|
                    this.getOldCallback('row_click')(grid, evt);
 | 
						|
                } else {
 | 
						|
                    checkbox = Element.select(trElement, 'input');
 | 
						|
                    isInput = Event.element(evt).tagName == 'input'; //eslint-disable-line eqeqeq
 | 
						|
                    checked = isInput ? checkbox[0].checked : !checkbox[0].checked;
 | 
						|
 | 
						|
                    if (checked) { //eslint-disable-line max-depth
 | 
						|
                        this.checkedString = varienStringArray.add(checkbox[0].value, this.checkedString);
 | 
						|
                    } else {
 | 
						|
                        this.checkedString = varienStringArray.remove(checkbox[0].value, this.checkedString);
 | 
						|
                    }
 | 
						|
                    this.grid.setCheckboxChecked(checkbox[0], checked);
 | 
						|
                    this.updateCount();
 | 
						|
                }
 | 
						|
 | 
						|
                return; //eslint-disable-line
 | 
						|
            }
 | 
						|
 | 
						|
            if (Event.element(evt).isMassactionCheckbox) {
 | 
						|
                this.setCheckbox(Event.element(evt));
 | 
						|
            } else if (checkbox = this.findCheckbox(evt)) { //eslint-disable-line no-cond-assign
 | 
						|
                checkbox.checked = !checkbox.checked;
 | 
						|
                jQuery(checkbox).trigger('change');
 | 
						|
                this.setCheckbox(checkbox);
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} evt
 | 
						|
         */
 | 
						|
        onSelectChange: function (evt) {
 | 
						|
            var item = this.getSelectedItem();
 | 
						|
 | 
						|
            if (item) {
 | 
						|
                this.formAdditional.update($(this.containerId + '-item-' + item.id + '-block').innerHTML);
 | 
						|
                evt.target.addClassName('_selected');
 | 
						|
            } else {
 | 
						|
                this.formAdditional.update('');
 | 
						|
                evt.target.removeClassName('_selected');
 | 
						|
            }
 | 
						|
            jQuery(this.form).data('validator').resetForm();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} evt
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        findCheckbox: function (evt) {
 | 
						|
            if (['a', 'input', 'select'].indexOf(Event.element(evt).tagName.toLowerCase()) !== -1) {
 | 
						|
                return false;
 | 
						|
            }
 | 
						|
            checkbox = false; //eslint-disable-line no-undef
 | 
						|
            Event.findElement(evt, 'tr').select('[data-role="select-row"]').each(function (element) { //eslint-disable-line
 | 
						|
                if (element.isMassactionCheckbox) {
 | 
						|
                    checkbox = element; //eslint-disable-line no-undef
 | 
						|
                }
 | 
						|
            });
 | 
						|
 | 
						|
            return checkbox; //eslint-disable-line no-undef
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Init checkobox.
 | 
						|
         */
 | 
						|
        initCheckboxes: function () {
 | 
						|
            this.getCheckboxes().each(function (checkbox) { //eslint-disable-line no-extra-bind
 | 
						|
                checkbox.isMassactionCheckbox = true; //eslint-disable-line no-undef
 | 
						|
            });
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Check checkbox.
 | 
						|
         */
 | 
						|
        checkCheckboxes: function () {
 | 
						|
            this.getCheckboxes().each(function (checkbox) {
 | 
						|
                checkbox.checked = varienStringArray.has(checkbox.value, this.checkedString);
 | 
						|
                jQuery(checkbox).trigger('change');
 | 
						|
            }.bind(this));
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Boolean}
 | 
						|
         */
 | 
						|
        selectAll: function () {
 | 
						|
            this.setCheckedValues(this.useSelectAll ? this.getGridIds() : this.getCheckboxesValuesAsString());
 | 
						|
            this.checkCheckboxes();
 | 
						|
            this.updateCount();
 | 
						|
            this.clearLastChecked();
 | 
						|
 | 
						|
            return false;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Boolean}
 | 
						|
         */
 | 
						|
        unselectAll: function () {
 | 
						|
            this.setCheckedValues('');
 | 
						|
            this.checkCheckboxes();
 | 
						|
            this.updateCount();
 | 
						|
            this.clearLastChecked();
 | 
						|
 | 
						|
            return false;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Boolean}
 | 
						|
         */
 | 
						|
        selectVisible: function () {
 | 
						|
            this.setCheckedValues(this.getCheckboxesValuesAsString());
 | 
						|
            this.checkCheckboxes();
 | 
						|
            this.updateCount();
 | 
						|
            this.clearLastChecked();
 | 
						|
 | 
						|
            return false;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Boolean}
 | 
						|
         */
 | 
						|
        unselectVisible: function () {
 | 
						|
            this.getCheckboxesValues().each(function (key) {
 | 
						|
                this.checkedString = varienStringArray.remove(key, this.checkedString);
 | 
						|
            }.bind(this));
 | 
						|
            this.checkCheckboxes();
 | 
						|
            this.updateCount();
 | 
						|
            this.clearLastChecked();
 | 
						|
 | 
						|
            return false;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} values
 | 
						|
         */
 | 
						|
        setCheckedValues: function (values) {
 | 
						|
            this.checkedString = values;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {String}
 | 
						|
         */
 | 
						|
        getCheckedValues: function () {
 | 
						|
            return this.checkedString;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Array}
 | 
						|
         */
 | 
						|
        getCheckboxes: function () {
 | 
						|
            var result = [];
 | 
						|
 | 
						|
            this.grid.rows.each(function (row) {
 | 
						|
                var checkboxes = row.select('[data-role="select-row"]');
 | 
						|
 | 
						|
                checkboxes.each(function (checkbox) {
 | 
						|
                    result.push(checkbox);
 | 
						|
                });
 | 
						|
            });
 | 
						|
 | 
						|
            return result;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {Array}
 | 
						|
         */
 | 
						|
        getCheckboxesValues: function () {
 | 
						|
            var result = [];
 | 
						|
 | 
						|
            this.getCheckboxes().each(function (checkbox) { //eslint-disable-line no-extra-bind
 | 
						|
                result.push(checkbox.value);
 | 
						|
            });
 | 
						|
 | 
						|
            return result;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {String}
 | 
						|
         */
 | 
						|
        getCheckboxesValuesAsString: function () {
 | 
						|
            return this.getCheckboxesValues().join(',');
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} checkbox
 | 
						|
         */
 | 
						|
        setCheckbox: function (checkbox) {
 | 
						|
            if (checkbox.checked) {
 | 
						|
                this.checkedString = varienStringArray.add(checkbox.value, this.checkedString);
 | 
						|
            } else {
 | 
						|
                this.checkedString = varienStringArray.remove(checkbox.value, this.checkedString);
 | 
						|
            }
 | 
						|
            this.updateCount();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Update count.
 | 
						|
         */
 | 
						|
        updateCount: function () {
 | 
						|
            var checkboxesTotal = varienStringArray.count(
 | 
						|
                this.useSelectAll ? this.getGridIds() : this.getCheckboxesValuesAsString()
 | 
						|
                ),
 | 
						|
                checkboxesChecked = varienStringArray.count(this.checkedString);
 | 
						|
 | 
						|
            jQuery('[data-role="counter"]', this.count).html(checkboxesChecked);
 | 
						|
 | 
						|
            if (!checkboxesTotal) {
 | 
						|
                this.multiselect.addClassName('_disabled');
 | 
						|
            } else {
 | 
						|
                this.multiselect.removeClassName('_disabled');
 | 
						|
            }
 | 
						|
 | 
						|
            if (checkboxesChecked == checkboxesTotal && checkboxesTotal != 0) { //eslint-disable-line eqeqeq
 | 
						|
                this.count.removeClassName('_empty');
 | 
						|
                this.multiselect.addClassName('_checked').removeClassName('_indeterminate');
 | 
						|
            } else if (checkboxesChecked == 0) { //eslint-disable-line eqeqeq
 | 
						|
                this.count.addClassName('_empty');
 | 
						|
                this.multiselect.removeClassName('_checked').removeClassName('_indeterminate');
 | 
						|
            } else {
 | 
						|
                this.count.removeClassName('_empty');
 | 
						|
                this.multiselect.addClassName('_checked').addClassName('_indeterminate');
 | 
						|
            }
 | 
						|
 | 
						|
            if (!this.grid.reloadParams) {
 | 
						|
                this.grid.reloadParams = {};
 | 
						|
            }
 | 
						|
            this.grid.reloadParams[this.formFieldNameInternal] = this.checkedString;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        getSelectedItem: function () {
 | 
						|
            if (this.getItem(this.select.value)) {
 | 
						|
                return this.getItem(this.select.value);
 | 
						|
            }
 | 
						|
 | 
						|
            return false;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Apply.
 | 
						|
         */
 | 
						|
        apply: function () {
 | 
						|
            var item, fieldName;
 | 
						|
 | 
						|
            if (varienStringArray.count(this.checkedString) == 0) { //eslint-disable-line eqeqeq
 | 
						|
                alert({
 | 
						|
                    content: this.errorText
 | 
						|
                });
 | 
						|
 | 
						|
                return;
 | 
						|
            }
 | 
						|
 | 
						|
            item = this.getSelectedItem();
 | 
						|
 | 
						|
            if (!item) {
 | 
						|
                jQuery(this.form).valid();
 | 
						|
 | 
						|
                return;
 | 
						|
            }
 | 
						|
            this.currentItem = item;
 | 
						|
            fieldName = item.field ? item.field : this.formFieldName;
 | 
						|
 | 
						|
            if (this.currentItem.confirm) {
 | 
						|
                confirm({
 | 
						|
                    content: this.currentItem.confirm,
 | 
						|
                    actions: {
 | 
						|
                        confirm: this.onConfirm.bind(this, fieldName, item)
 | 
						|
                    }
 | 
						|
                });
 | 
						|
            } else {
 | 
						|
                this.onConfirm(fieldName, item);
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} fieldName
 | 
						|
         * @param {*} item
 | 
						|
         */
 | 
						|
        onConfirm: function (fieldName, item) {
 | 
						|
            this.formHiddens.update('');
 | 
						|
            new Insertion.Bottom(this.formHiddens, this.fieldTemplate({
 | 
						|
                name: fieldName,
 | 
						|
                value: this.checkedString
 | 
						|
            }));
 | 
						|
            new Insertion.Bottom(this.formHiddens, this.fieldTemplate({
 | 
						|
                name: 'massaction_prepare_key',
 | 
						|
                value: fieldName
 | 
						|
            }));
 | 
						|
 | 
						|
            if (!jQuery(this.form).valid()) {
 | 
						|
                return;
 | 
						|
            }
 | 
						|
 | 
						|
            if (this.useAjax && item.url) {
 | 
						|
                new Ajax.Request(item.url, {
 | 
						|
                    'method': 'post',
 | 
						|
                    'parameters': this.form.serialize(true),
 | 
						|
                    'onComplete': this.onMassactionComplete.bind(this)
 | 
						|
                });
 | 
						|
            } else if (item.url) {
 | 
						|
                this.form.action = item.url;
 | 
						|
                this.form.submit();
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} transport
 | 
						|
         */
 | 
						|
        onMassactionComplete: function (transport) {
 | 
						|
            var listener;
 | 
						|
 | 
						|
            if (this.currentItem.complete) {
 | 
						|
                try {
 | 
						|
                    listener = this.getListener(this.currentItem.complete) || Prototype.emptyFunction;
 | 
						|
                    listener(this.grid, this, transport);
 | 
						|
                } catch (e) {
 | 
						|
                }
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} strValue
 | 
						|
         * @return {Object}
 | 
						|
         */
 | 
						|
        getListener: function (strValue) {
 | 
						|
            return eval(strValue); //eslint-disable-line no-eval
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Init mass select.
 | 
						|
         */
 | 
						|
        initMassSelect: function () {
 | 
						|
            $$('input[data-role="select-row"]').each(function (element) {
 | 
						|
                element.observe('click', this.massSelect.bind(this));
 | 
						|
            }.bind(this));
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Clear last checked.
 | 
						|
         */
 | 
						|
        clearLastChecked: function () {
 | 
						|
            this.lastChecked = {
 | 
						|
                left: false,
 | 
						|
                top: false,
 | 
						|
                checkbox: false
 | 
						|
            };
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Object} evt
 | 
						|
         */
 | 
						|
        massSelect: function (evt) {
 | 
						|
            var currentCheckbox, lastCheckbox, start, finish;
 | 
						|
 | 
						|
            if (this.lastChecked.left !== false &&
 | 
						|
                this.lastChecked.top !== false &&
 | 
						|
                evt.button === 0 &&
 | 
						|
                evt.shiftKey === true
 | 
						|
            ) {
 | 
						|
                currentCheckbox = Event.element(evt);
 | 
						|
                lastCheckbox = this.lastChecked.checkbox;
 | 
						|
 | 
						|
                if (lastCheckbox != currentCheckbox) { //eslint-disable-line eqeqeq
 | 
						|
                    start = this.getCheckboxOrder(lastCheckbox);
 | 
						|
                    finish = this.getCheckboxOrder(currentCheckbox);
 | 
						|
 | 
						|
                    if (start !== false && finish !== false) { //eslint-disable-line max-depth
 | 
						|
                        this.selectCheckboxRange(
 | 
						|
                            Math.min(start, finish),
 | 
						|
                            Math.max(start, finish),
 | 
						|
                            currentCheckbox.checked
 | 
						|
                        );
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            this.lastChecked = {
 | 
						|
                left: Event.element(evt).viewportOffset().left,
 | 
						|
                top: Event.element(evt).viewportOffset().top,
 | 
						|
                checkbox: Event.element(evt) // "boundary" checkbox
 | 
						|
            };
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} curCheckbox
 | 
						|
         * @return {Boolean}
 | 
						|
         */
 | 
						|
        getCheckboxOrder: function (curCheckbox) {
 | 
						|
            var order = false;
 | 
						|
 | 
						|
            this.getCheckboxes().each(function (checkbox, key) {
 | 
						|
                if (curCheckbox == checkbox) { //eslint-disable-line eqeqeq
 | 
						|
                    order = key;
 | 
						|
                }
 | 
						|
            });
 | 
						|
 | 
						|
            return order;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} start
 | 
						|
         * @param {*} finish
 | 
						|
         * @param {*} isChecked
 | 
						|
         */
 | 
						|
        selectCheckboxRange: function (start, finish, isChecked) {
 | 
						|
            this.getCheckboxes().each(function (checkbox, key) {
 | 
						|
                if (key >= start && key <= finish) {
 | 
						|
                    checkbox.checked = isChecked;
 | 
						|
                    this.setCheckbox(checkbox);
 | 
						|
                }
 | 
						|
            }.bind(this));
 | 
						|
        }
 | 
						|
    };
 | 
						|
 | 
						|
    window.varienGridAction = {
 | 
						|
        /**
 | 
						|
         * @param {Object} select
 | 
						|
         */
 | 
						|
        execute: function (select) {
 | 
						|
            var config, win;
 | 
						|
 | 
						|
            if (!select.value || !select.value.isJSON()) {
 | 
						|
                return;
 | 
						|
            }
 | 
						|
 | 
						|
            config = select.value.evalJSON();
 | 
						|
 | 
						|
            if (config.confirm && !window.confirm(config.confirm)) { //eslint-disable-line no-alert
 | 
						|
                select.options[0].selected = true;
 | 
						|
 | 
						|
                return;
 | 
						|
            }
 | 
						|
 | 
						|
            if (config.popup) {
 | 
						|
                win = window.open(config.href, 'action_window', 'width=500,height=600,resizable=1,scrollbars=1');
 | 
						|
                win.focus();
 | 
						|
                select.options[0].selected = true;
 | 
						|
            } else {
 | 
						|
                setLocation(config.href);
 | 
						|
            }
 | 
						|
        }
 | 
						|
    };
 | 
						|
 | 
						|
    window.varienStringArray = {
 | 
						|
        /**
 | 
						|
         * @param {*} str
 | 
						|
         * @param {*} haystack
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        remove: function (str, haystack) {
 | 
						|
            haystack = ',' + haystack + ',';
 | 
						|
            haystack = haystack.replace(new RegExp(',' + str + ',', 'g'), ',');
 | 
						|
 | 
						|
            return this.trimComma(haystack);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} str
 | 
						|
         * @param {*} haystack
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        add: function (str, haystack) {
 | 
						|
            haystack = ',' + haystack + ',';
 | 
						|
 | 
						|
            if (haystack.search(new RegExp(',' + str + ',', 'g'), haystack) === -1) {
 | 
						|
                haystack += str + ',';
 | 
						|
            }
 | 
						|
 | 
						|
            return this.trimComma(haystack);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} str
 | 
						|
         * @param {*} haystack
 | 
						|
         * @return {Boolean}
 | 
						|
         */
 | 
						|
        has: function (str, haystack) {
 | 
						|
            haystack = ',' + haystack + ',';
 | 
						|
 | 
						|
            if (haystack.search(new RegExp(',' + str + ',', 'g'), haystack) === -1) {
 | 
						|
                return false;
 | 
						|
            }
 | 
						|
 | 
						|
            return true;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} haystack
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        count: function (haystack) {
 | 
						|
            var match;
 | 
						|
 | 
						|
            if (typeof haystack != 'string') {
 | 
						|
                return 0;
 | 
						|
            }
 | 
						|
 | 
						|
            /* eslint-disable no-undef, no-cond-assign, eqeqeq */
 | 
						|
            if (match = haystack.match(new RegExp(',', 'g'))) {
 | 
						|
                return match.length + 1;
 | 
						|
            } else if (haystack.length != 0) {
 | 
						|
                return 1;
 | 
						|
            }
 | 
						|
 | 
						|
            /* eslint-enable no-undef, no-cond-assign, eqeqeq */
 | 
						|
            return 0;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} haystack
 | 
						|
         * @param {*} fnc
 | 
						|
         */
 | 
						|
        each: function (haystack, fnc) {
 | 
						|
            var i;
 | 
						|
 | 
						|
            haystack = haystack.split(',');
 | 
						|
 | 
						|
            for (i = 0; i < haystack.length; i++) {
 | 
						|
                fnc(haystack[i]);
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {String} string
 | 
						|
         * @return {String}
 | 
						|
         */
 | 
						|
        trimComma: function (string) {
 | 
						|
            string = string.replace(new RegExp('^(,+)', 'i'), '');
 | 
						|
            string = string.replace(new RegExp('(,+)$', 'i'), '');
 | 
						|
 | 
						|
            return string;
 | 
						|
        }
 | 
						|
    };
 | 
						|
 | 
						|
    window.serializerController = Class.create();
 | 
						|
    serializerController.prototype = {
 | 
						|
        oldCallbacks: {},
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} hiddenDataHolder
 | 
						|
         * @param {*} predefinedData
 | 
						|
         * @param {*} inputsToManage
 | 
						|
         * @param {*} grid
 | 
						|
         * @param {*} reloadParamName
 | 
						|
         */
 | 
						|
        initialize: function (hiddenDataHolder, predefinedData, inputsToManage, grid, reloadParamName) {
 | 
						|
            //Grid inputs
 | 
						|
            this.tabIndex = 1000;
 | 
						|
            this.inputsToManage = inputsToManage;
 | 
						|
            this.multidimensionalMode = inputsToManage.length > 0;
 | 
						|
 | 
						|
            //Hash with grid data
 | 
						|
            this.gridData = this.getGridDataHash(predefinedData);
 | 
						|
 | 
						|
            //Hidden input data holder
 | 
						|
            this.hiddenDataHolder = $(hiddenDataHolder);
 | 
						|
            this.hiddenDataHolder.value = this.serializeObject();
 | 
						|
 | 
						|
            this.grid = grid;
 | 
						|
 | 
						|
            // Set old callbacks
 | 
						|
            this.setOldCallback('row_click', this.grid.rowClickCallback);
 | 
						|
            this.setOldCallback('init_row', this.grid.initRowCallback);
 | 
						|
            this.setOldCallback('checkbox_check', this.grid.checkboxCheckCallback);
 | 
						|
 | 
						|
            //Grid
 | 
						|
            this.reloadParamName = reloadParamName;
 | 
						|
            this.grid.reloadParams = {};
 | 
						|
            this.grid.reloadParams[this.reloadParamName + '[]'] = this.getDataForReloadParam();
 | 
						|
            this.grid.rowClickCallback = this.rowClick.bind(this);
 | 
						|
            this.grid.initRowCallback = this.rowInit.bind(this);
 | 
						|
            this.grid.checkboxCheckCallback = this.registerData.bind(this);
 | 
						|
            this.grid.rows.each(this.eachRow.bind(this));
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {String} callbackName
 | 
						|
         * @param {Function} callback
 | 
						|
         */
 | 
						|
        setOldCallback: function (callbackName, callback) {
 | 
						|
            this.oldCallbacks[callbackName] = callback;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {String} callbackName
 | 
						|
         * @return {Prototype.emptyFunction}
 | 
						|
         */
 | 
						|
        getOldCallback: function (callbackName) {
 | 
						|
            return this.oldCallbacks[callbackName] ? this.oldCallbacks[callbackName] : Prototype.emptyFunction;
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} grid
 | 
						|
         * @param {*} element
 | 
						|
         * @param {*} checked
 | 
						|
         */
 | 
						|
        registerData: function (grid, element, checked) {
 | 
						|
            var i;
 | 
						|
 | 
						|
            if (this.multidimensionalMode) {
 | 
						|
                if (checked) {
 | 
						|
                    /*eslint-disable max-depth*/
 | 
						|
                    if (element.inputElements) {
 | 
						|
                        this.gridData.set(element.value, {});
 | 
						|
 | 
						|
                        for (i = 0; i < element.inputElements.length; i++) {
 | 
						|
                            element.inputElements[i].disabled = false;
 | 
						|
                            this.gridData.get(element.value)[element.inputElements[i].name] =
 | 
						|
                                element.inputElements[i].value;
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                } else {
 | 
						|
                    if (element.inputElements) {
 | 
						|
                        for (i = 0; i < element.inputElements.length; i++) {
 | 
						|
                            element.inputElements[i].disabled = true;
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                    this.gridData.unset(element.value);
 | 
						|
                }
 | 
						|
            } else {
 | 
						|
                if (checked) { //eslint-disable-line no-lonely-if
 | 
						|
                    this.gridData.set(element.value, element.value);
 | 
						|
                } else {
 | 
						|
                    this.gridData.unset(element.value);
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            this.hiddenDataHolder.value = this.serializeObject();
 | 
						|
            this.grid.reloadParams = {};
 | 
						|
            this.grid.reloadParams[this.reloadParamName + '[]'] = this.getDataForReloadParam();
 | 
						|
            this.getOldCallback('checkbox_check')(grid, element, checked);
 | 
						|
 | 
						|
            /*eslint-enable max-depth*/
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} row
 | 
						|
         */
 | 
						|
        eachRow: function (row) {
 | 
						|
            this.rowInit(this.grid, row);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} grid
 | 
						|
         * @param {*} event
 | 
						|
         */
 | 
						|
        rowClick: function (grid, event) {
 | 
						|
            var trElement = Event.findElement(event, 'tr'),
 | 
						|
                isInput = Event.element(event).tagName == 'INPUT', //eslint-disable-line eqeqeq
 | 
						|
                checkbox, checked;
 | 
						|
 | 
						|
            if (trElement) {
 | 
						|
                // eslint-disable-next-line jquery-no-input-event-shorthand
 | 
						|
                checkbox = Element.select(trElement, 'input');
 | 
						|
 | 
						|
                if (checkbox[0] && !checkbox[0].disabled) {
 | 
						|
                    checked = isInput ? checkbox[0].checked : !checkbox[0].checked;
 | 
						|
                    this.grid.setCheckboxChecked(checkbox[0], checked);
 | 
						|
                }
 | 
						|
            }
 | 
						|
            this.getOldCallback('row_click')(grid, event);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} event
 | 
						|
         */
 | 
						|
        inputChange: function (event) {
 | 
						|
            var element = Event.element(event);
 | 
						|
 | 
						|
            if (element && element.checkboxElement && element.checkboxElement.checked) {
 | 
						|
                this.gridData.get(element.checkboxElement.value)[element.name] = element.value;
 | 
						|
                this.hiddenDataHolder.value = this.serializeObject();
 | 
						|
            }
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {*} grid
 | 
						|
         * @param {*} row
 | 
						|
         */
 | 
						|
        rowInit: function (grid, row) {
 | 
						|
            var checkbox, selectors, inputs, i;
 | 
						|
 | 
						|
            if (this.multidimensionalMode) {
 | 
						|
                // eslint-disable-next-line jquery-no-input-event-shorthand
 | 
						|
                checkbox = $(row).select('.checkbox')[0];
 | 
						|
                selectors = this.inputsToManage.map(function (name) {
 | 
						|
                    return ['input[name="' + name + '"]', 'select[name="' + name + '"]'];
 | 
						|
                });
 | 
						|
                inputs = $(row).select.apply($(row), selectors.flatten());
 | 
						|
 | 
						|
                if (checkbox && inputs.length > 0) {
 | 
						|
                    checkbox.inputElements = inputs;
 | 
						|
 | 
						|
                    /* eslint-disable max-depth */
 | 
						|
                    for (i = 0; i < inputs.length; i++) {
 | 
						|
                        inputs[i].checkboxElement = checkbox;
 | 
						|
 | 
						|
                        if (this.gridData.get(checkbox.value) && this.gridData.get(checkbox.value)[inputs[i].name]) {
 | 
						|
                            inputs[i].value = this.gridData.get(checkbox.value)[inputs[i].name];
 | 
						|
                        }
 | 
						|
                        inputs[i].disabled = !checkbox.checked;
 | 
						|
                        inputs[i].tabIndex = this.tabIndex++;
 | 
						|
                        Event.observe(inputs[i], 'keyup', this.inputChange.bind(this));
 | 
						|
                        Event.observe(inputs[i], 'change', this.inputChange.bind(this));
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            /* eslint-enable max-depth */
 | 
						|
            this.getOldCallback('init_row')(grid, row);
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * Stuff methods.
 | 
						|
         *
 | 
						|
         * @param {*} _object
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        getGridDataHash: function (_object) {
 | 
						|
            return $H(this.multidimensionalMode ? _object : this.convertArrayToObject(_object));
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        getDataForReloadParam: function () {
 | 
						|
            return this.multidimensionalMode ? this.gridData.keys() : this.gridData.values();
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @return {*}
 | 
						|
         */
 | 
						|
        serializeObject: function () {
 | 
						|
            var clone;
 | 
						|
 | 
						|
            if (this.multidimensionalMode) {
 | 
						|
                clone = this.gridData.clone();
 | 
						|
                clone.each(function (pair) {
 | 
						|
                    clone.set(pair.key, Base64.encode(Object.toQueryString(pair.value)));
 | 
						|
                });
 | 
						|
 | 
						|
                return clone.toQueryString();
 | 
						|
            }
 | 
						|
 | 
						|
            return this.gridData.values().join('&');
 | 
						|
        },
 | 
						|
 | 
						|
        /**
 | 
						|
         * @param {Array} _array
 | 
						|
         * @return {Object}
 | 
						|
         */
 | 
						|
        convertArrayToObject: function (_array) {
 | 
						|
            var _object = {},
 | 
						|
                i, l;
 | 
						|
 | 
						|
            for (i = 0, l = _array.length; i < l; i++) {
 | 
						|
                _object[_array[i]] = _array[i];
 | 
						|
            }
 | 
						|
 | 
						|
            return _object;
 | 
						|
        }
 | 
						|
    };
 | 
						|
});
 |