File: /var/www/vhost/disk-apps/magento.bikenow.co/vendor/magento/module-rule/view/adminhtml/web/rules.js
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
/**
* @api
*/
define([
'jquery',
'Magento_Ui/js/modal/alert',
'mage/translate',
'prototype'
], function (jQuery) {
'use strict';
var VarienRulesForm = new Class.create();
VarienRulesForm.prototype = {
initialize: function (parent, newChildUrl) {
this.parent = $(parent);
this.newChildUrl = newChildUrl;
this.shownElement = null;
this.updateElement = null;
this.chooserSelectedItems = $H({});
this.readOnly = false;
var elems = this.parent.getElementsByClassName('rule-param');
for (var i = 0; i < elems.length; i++) {
this.initParam(elems[i]);
}
},
setReadonly: function (readonly) {
this.readOnly = readonly;
var elems = this.parent.getElementsByClassName('rule-param-remove');
for (var i = 0; i < elems.length; i++) {
var element = elems[i];
if (this.readOnly) {
element.hide();
} else {
element.show();
}
}
var elems = this.parent.getElementsByClassName('rule-param-new-child');
for (var i = 0; i < elems.length; i++) {
var element = elems[i];
if (this.readOnly) {
element.hide();
} else {
element.show();
}
}
var elems = this.parent.getElementsByClassName('rule-param');
for (var i = 0; i < elems.length; i++) {
var container = elems[i];
var label = Element.down(container, '.label');
if (label) {
if (this.readOnly) {
label.addClassName('label-disabled');
} else {
label.removeClassName('label-disabled');
}
}
}
},
initParam: function (container) {
container.rulesObject = this;
var label = Element.down(container, '.label');
if (label) {
Event.observe(label, 'click', this.showParamInputField.bind(this, container));
}
var elem = Element.down(container, '.element');
if (elem) {
var trig = elem.down('.rule-chooser-trigger');
if (trig) {
Event.observe(trig, 'click', this.toggleChooser.bind(this, container));
}
var apply = elem.down('.rule-param-apply');
if (apply) {
Event.observe(apply, 'click', this.hideParamInputField.bind(this, container));
} else {
elem = elem.down('.element-value-changer');
elem.container = container;
if (!elem.multiple) {
Event.observe(elem, 'change', this.hideParamInputField.bind(this, container));
this.changeVisibilityForValueRuleParam(elem);
}
Event.observe(elem, 'blur', this.hideParamInputField.bind(this, container));
}
}
var remove = Element.down(container, '.rule-param-remove');
if (remove) {
Event.observe(remove, 'click', this.removeRuleEntry.bind(this, container));
}
},
showChooserElement: function (chooser) {
this.chooserSelectedItems = $H({});
if (chooser.hasClassName('no-split')) {
this.chooserSelectedItems.set(this.updateElement.value, 1);
} else {
var values = this.updateElement.value.split(','),
s = '';
for (var i = 0; i < values.length; i++) {
s = values[i].strip();
if (s != '') {
this.chooserSelectedItems.set(s, 1);
}
}
}
new Ajax.Request(chooser.getAttribute('url'), {
evalScripts: true,
parameters: {
'form_key': FORM_KEY, 'selected[]': this.chooserSelectedItems.keys()
},
onSuccess: function (transport) {
if (this._processSuccess(transport)) {
jQuery(chooser).html(transport.responseText);
this.showChooserLoaded(chooser, transport);
jQuery(chooser).trigger('contentUpdated');
}
}.bind(this),
onFailure: this._processFailure.bind(this)
});
},
showChooserLoaded: function (chooser, transport) {
chooser.style.display = 'block';
},
showChooser: function (container, event) {
var chooser = container.up('li');
if (!chooser) {
return;
}
chooser = chooser.down('.rule-chooser');
if (!chooser) {
return;
}
this.showChooserElement(chooser);
},
hideChooser: function (container, event) {
var chooser = container.up('li');
if (!chooser) {
return;
}
chooser = chooser.down('.rule-chooser');
if (!chooser) {
return;
}
chooser.style.display = 'none';
},
toggleChooser: function (container, event) {
if (this.readOnly) {
return false;
}
var chooser = container.up('li').down('.rule-chooser');
if (!chooser) {
return;
}
if (chooser.style.display == 'block') {
chooser.style.display = 'none';
this.cleanChooser(container, event);
} else {
this.showChooserElement(chooser);
}
},
cleanChooser: function (container, event) {
var chooser = container.up('li').down('.rule-chooser');
if (!chooser) {
return;
}
chooser.innerHTML = '';
},
showParamInputField: function (container, event) {
if (this.readOnly) {
return false;
}
if (this.shownElement) {
this.hideParamInputField(this.shownElement, event);
}
Element.addClassName(container, 'rule-param-edit');
var elemContainer = Element.down(container, '.element');
var elem = Element.down(elemContainer, 'input.input-text');
jQuery(elem).trigger('contentUpdated');
if (elem) {
elem.focus();
if (elem && elem.id && elem.id.match(/__value$/)) {
this.updateElement = elem;
}
}
var elem = Element.down(elemContainer, '.element-value-changer');
if (elem) {
elem.focus();
}
this.shownElement = container;
},
hideParamInputField: function (container, event) {
Element.removeClassName(container, 'rule-param-edit');
var label = Element.down(container, '.label'),
elem;
if (!container.hasClassName('rule-param-new-child')) {
elem = Element.down(container, '.element-value-changer');
if (elem && elem.options) {
var selectedOptions = [];
for (var i = 0; i < elem.options.length; i++) {
if (elem.options[i].selected) {
selectedOptions.push(elem.options[i].text);
}
}
var str = selectedOptions.join(', ');
label.innerHTML = str != '' ? str : '...';
}
this.changeVisibilityForValueRuleParam(elem);
elem = Element.down(container, 'input.input-text');
if (elem) {
var str = elem.value.replace(/(^\s+|\s+$)/g, '');
elem.value = str;
if (str == '') {
str = '...';
} else if (str.length > 30) {
str = str.substr(0, 30) + '...';
}
label.innerHTML = str.escapeHTML();
}
} else {
elem = container.down('.element-value-changer');
if (elem.value) {
this.addRuleNewChild(elem);
}
elem.value = '';
}
if (elem && elem.id && elem.id.match(/__value$/)) {
this.hideChooser(container, event);
this.updateElement = null;
}
this.shownElement = null;
},
changeVisibilityForValueRuleParam: function(elem) {
var parsedElementId = elem.id.split('__');
if (parsedElementId[2] !== 'operator') {
return false;
}
var valueElement = jQuery('#' + parsedElementId[0] + '__' + parsedElementId[1] + '__value');
if(elem.value === '<=>') {
valueElement.closest('.rule-param').hide();
} else {
valueElement.closest('.rule-param').show();
}
return true;
},
addRuleNewChild: function (elem) {
var parent_id = elem.id.replace(/^.*__(.*)__.*$/, '$1');
var children_ul_id = elem.id.replace(/__/g, ':').replace(/[^:]*$/, 'children').replace(/:/g, '__');
var children_ul = $(this.parent).select('#' + children_ul_id)[0];
var max_id = 0,
i;
var children_inputs = Selector.findChildElements(children_ul, $A(['input.hidden']));
if (children_inputs.length) {
children_inputs.each(function (el) {
if (el.id.match(/__type$/)) {
i = 1 * el.id.replace(/^.*__.*?([0-9]+)__.*$/, '$1');
max_id = i > max_id ? i : max_id;
}
});
}
var new_id = parent_id + '--' + (max_id + 1);
var new_type = elem.value;
var new_elem = document.createElement('LI');
new_elem.className = 'rule-param-wait';
new_elem.innerHTML = jQuery.mage.__('This won\'t take long . . .');
children_ul.insertBefore(new_elem, $(elem).up('li'));
new Ajax.Request(this.newChildUrl, {
evalScripts: true,
parameters: {
form_key: FORM_KEY, type: new_type.replace('/', '-'), id: new_id
},
onComplete: this.onAddNewChildComplete.bind(this, new_elem),
onSuccess: function (transport) {
if (this._processSuccess(transport)) {
$(new_elem).update(transport.responseText);
}
}.bind(this),
onFailure: this._processFailure.bind(this)
});
},
_processSuccess: function (transport) {
if (transport.responseText.isJSON()) {
var response = transport.responseText.evalJSON();
if (response.error) {
alert(response.message);
}
if (response.ajaxExpired && response.ajaxRedirect) {
setLocation(response.ajaxRedirect);
}
return false;
}
return true;
},
_processFailure: function (transport) {
location.href = BASE_URL;
},
onAddNewChildComplete: function (new_elem) {
if (this.readOnly) {
return false;
}
$(new_elem).removeClassName('rule-param-wait');
var elems = new_elem.getElementsByClassName('rule-param');
for (var i = 0; i < elems.length; i++) {
this.initParam(elems[i]);
}
},
removeRuleEntry: function (container, event) {
var li = Element.up(container, 'li');
li.parentNode.removeChild(li);
},
chooserGridInit: function (grid) {
//grid.reloadParams = {'selected[]':this.chooserSelectedItems.keys()};
},
chooserGridRowInit: function (grid, row) {
if (!grid.reloadParams) {
grid.reloadParams = {
'selected[]': this.chooserSelectedItems.keys()
};
}
},
chooserGridRowClick: function (grid, event) {
var trElement = Event.findElement(event, 'tr');
var isInput = Event.element(event).tagName == 'INPUT';
if (trElement) {
var checkbox = Element.select(trElement, 'input');
if (checkbox[0]) {
var checked = isInput ? checkbox[0].checked : !checkbox[0].checked;
grid.setCheckboxChecked(checkbox[0], checked);
}
}
},
chooserGridCheckboxCheck: function (grid, element, checked) {
if (checked) {
if (!element.up('th')) {
this.chooserSelectedItems.set(element.value, 1);
}
} else {
this.chooserSelectedItems.unset(element.value);
}
grid.reloadParams = {
'selected[]': this.chooserSelectedItems.keys()
};
this.updateElement.value = this.chooserSelectedItems.keys().join(', ');
}
};
return VarienRulesForm;
});