/**
* 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;
}
};
});
|