Skip to content

Commit

Permalink
Merge pull request #660 from magento-vanilla/MAGETWO-42700-DEVELOP
Browse files Browse the repository at this point in the history
[Vanilla] Bugfixes
  • Loading branch information
Korshenko, Olexii(okorshenko) committed Oct 2, 2015
2 parents b4d2cb5 + 401955e commit f8cc46a
Show file tree
Hide file tree
Showing 8 changed files with 664 additions and 383 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@

/** @var $block \Magento\Eav\Block\Adminhtml\Attribute\Edit\Options\Options */
?>
<fieldset class="fieldset">
<fieldset class="fieldset ignore-validate">
<legend class="legend"><span><?php /* @escapeNotVerified */ echo __('Manage Options (values of your attribute)') ?></span></legend>
<div id="manage-options-panel">
<table class="admin__control-table">
Expand Down Expand Up @@ -67,110 +67,21 @@
</td>
</tr>
</script>
<script>
require([
'jquery',
'mage/template',
'jquery/ui',
'prototype'
], function(jQuery, mageTemplate){

var optionDefaultInputType = 'radio';

var attributeOption = {
table: $('attribute-options-table'),
itemCount: 0,
totalItems: 0,
isReadOnly: <?php echo (int)$block->getReadOnly(); ?>,
add: function(data) {
this.template = mageTemplate('#row-template');
var isNewOption = false;
if (typeof data.id == 'undefined') {
data = {
'id': 'option_' + this.itemCount,
'sort_order': this.itemCount + 1
};
isNewOption = true;
}
if (!data.intype) {
data.intype = optionDefaultInputType;
}

Element.insert($$('[data-role=options-container]')[0], this.template({data: data}));
if (isNewOption && !this.isReadOnly) {
this.enableNewOptionDeleteButton(data.id);
}
this.itemCount++;
this.totalItems++;
this.updateItemsCountField();
},
remove: function(event) {
var element = $(Event.findElement(event, 'tr')); // !!! Button already have table parent in safari
// Safari workaround
element.ancestors().each(function(parentItem) {
if (parentItem.hasClassName('option-row')) {
element = parentItem;
throw $break;
} else if (parentItem.hasClassName('box')) {
throw $break;
}
});

if (element) {
var elementFlags = element.getElementsByClassName('delete-flag');
if (elementFlags[0]) {
elementFlags[0].value = 1;
}

element.addClassName('no-display');
element.addClassName('template');
element.hide();
this.totalItems--;
this.updateItemsCountField();
}
},
updateItemsCountField: function() {
$('option-count-check').value = this.totalItems > 0 ? '1' : '';
},
enableNewOptionDeleteButton: function(id) {
$$('#delete_button_container_' + id + ' button').each(function(button) {
button.enable();
button.removeClassName('disabled');
});
},
};

if ($('add_new_option_button')) {
Event.observe('add_new_option_button', 'click', attributeOption.add.bind(attributeOption));
<?php
$values = [];
foreach($block->getOptionValues() as $value) {
array_push($values, $value->getData());
}

$('manage-options-panel').on('click', '.delete-option', function(event, element) {
attributeOption.remove(event);
});

<?php foreach ($block->getOptionValues() as $_value): ?>
attributeOption.add(<?php /* @escapeNotVerified */ echo $_value->toJson() ?>);
<?php endforeach; ?>
<?php if (!$block->getReadOnly() && !$block->canManageOptionDefaultOnly()):?>
jQuery(function($) {
$('[data-role=options-container]').sortable({
distance: 8,
tolerance: "pointer",
cancel: 'input, button',
axis: 'y',
update: function() {
$('[data-role=options-container] [data-role=order]').each(function(index, element) {
$(element).val(index + 1);
});
?>
<script type="text/x-magento-init">
{
"*": {
"Magento_Catalog/js/options": {
"attributesData": <?php /* @escapeNotVerified */ echo json_encode($values); ?>,
"isSortable": <?php echo (int)(!$block->getReadOnly() && !$block->canManageOptionDefaultOnly()) ?>,
"isReadOnly": <?php echo (int)$block->getReadOnly(); ?>
}
}
});
});
<?php endif; ?>

window.attributeOption = attributeOption;
window.optionDefaultInputType = optionDefaultInputType;
//]]>

});
</script>
}
</script>
</fieldset>
168 changes: 168 additions & 0 deletions app/code/Magento/Catalog/view/adminhtml/web/js/options.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,168 @@
/**
* Copyright © 2015 Magento. All rights reserved.
* See COPYING.txt for license details.
*/

/* eslint-disable no-undef */
// jscs:disable jsDoc

define([
'jquery',
'mage/template',
'uiRegistry',
'jquery/ui',
'prototype'
], function (jQuery, mageTemplate, rg) {
'use strict';

return function (config) {
var optionDefaultInputType = 'radio',
attributeOption = {
table: $('attribute-options-table'),
itemCount: 0,
totalItems: 0,
rendered: 0,
template: mageTemplate('#row-template'),
isReadOnly: config.idReadOnly,
add: function (data, render) {
var isNewOption = false,
element;

if (typeof data.id == 'undefined') {
data = {
'id': 'option_' + this.itemCount,
'sort_order': this.itemCount + 1
};
isNewOption = true;
}

if (!data.intype) {
data.intype = optionDefaultInputType;
}
element = this.template({
data: data
});

if (isNewOption && !this.isReadOnly) {
this.enableNewOptionDeleteButton(data.id);
}
this.itemCount++;
this.totalItems++;
this.elements += element;

if (render) {
this.render();
}
},
remove: function (event) {
var element = $(Event.findElement(event, 'tr')),
elementFlags; // !!! Button already have table parent in safari

// Safari workaround
element.ancestors().each(function (parentItem) {
if (parentItem.hasClassName('option-row')) {
element = parentItem;
throw $break;
} else if (parentItem.hasClassName('box')) {
throw $break;
}
});

if (element) {
elementFlags = element.getElementsByClassName('delete-flag');

if (elementFlags[0]) {
elementFlags[0].value = 1;
}

element.addClassName('no-display');
element.addClassName('template');
element.hide();
this.totalItems--;
this.updateItemsCountField();
}
},
updateItemsCountField: function () {
$('option-count-check').value = this.totalItems > 0 ? '1' : '';
},
enableNewOptionDeleteButton: function (id) {
$$('#delete_button_container_' + id + ' button').each(function (button) {
button.enable();
button.removeClassName('disabled');
});
},
bindRemoveButtons: function () {
jQuery('#swatch-visual-options-panel').on('click', '.delete-option', this.remove.bind(this));
},
render: function () {
Element.insert($$('[data-role=options-container]')[0], this.elements);
this.elements = '';
},
renderWithDelay: function (data, from, step, delay) {
var arrayLength = data.length,
len;

for (len = from + step; from < len && from < arrayLength; from++) {
this.add(data[from]);
}
this.render();

if (from === arrayLength) {
this.updateItemsCountField();
this.rendered = 1;
jQuery('body').trigger('processStop');

return true;
}
setTimeout(this.renderWithDelay.bind(this, data, from, step, delay), delay);
},
ignoreValidate: function () {
var ignore = '.ignore-validate input, ' +
'.ignore-validate select, ' +
'.ignore-validate textarea';

jQuery('#edit_form').data('validator').settings.forceIgnore = ignore;
}
};

if ($('add_new_option_button')) {
Event.observe('add_new_option_button', 'click', attributeOption.add.bind(attributeOption, {}, true));
}

$('manage-options-panel').on('click', '.delete-option', function (event) {
attributeOption.remove(event);
});

jQuery('#manage-options-panel').on('render', function () {
attributeOption.ignoreValidate();

if (attributeOption.rendered) {
return false;
}
jQuery('body').trigger('processStart');
attributeOption.renderWithDelay(config.attributesData, 0, 100, 300);
attributeOption.bindRemoveButtons();
});

if (config.isSortable) {
jQuery(function ($) {
$('[data-role=options-container]').sortable({
distance: 8,
tolerance: 'pointer',
cancel: 'input, button',
axis: 'y',
update: function () {
$('[data-role=options-container] [data-role=order]').each(function (index, element) {
$(element).val(index + 1);
});
}
});
});
}

window.attributeOption = attributeOption;
window.optionDefaultInputType = optionDefaultInputType;

rg.set('manage-options-panel', attributeOption);
};
});
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@

?>
<script>
require(["jquery", "collapsable", "prototype"], function(jQuery){
require(["jquery", 'uiRegistry', "collapsable", "prototype"], function(jQuery, rg){

function toggleApplyVisibility(select) {
if ($(select).value == 1) {
Expand Down Expand Up @@ -38,6 +38,9 @@ function checkOptionsPanelVisibility(){

if($('frontend_input') && ($('frontend_input').value=='select' || $('frontend_input').value=='multiselect')){
panel.show();
rg.get('manage-options-panel', function() {
jQuery('#manage-options-panel').trigger('render');
});
}
else {
panel.hide();
Expand All @@ -48,6 +51,9 @@ function checkOptionsPanelVisibility(){

if($('frontend_input') && $('frontend_input').value=='swatch_visual') {
panel.show();
rg.get('swatch-visual-options-panel', function() {
jQuery('#swatch-visual-options-panel').trigger('render');
});
}
else {
panel.hide();
Expand All @@ -58,6 +64,9 @@ function checkOptionsPanelVisibility(){

if($('frontend_input') && $('frontend_input').value=='swatch_text') {
panel.show();
rg.get('swatch-text-options-panel', function() {
jQuery('#swatch-text-options-panel').trigger('render');
});
}
else {
panel.hide();
Expand Down
Loading

0 comments on commit f8cc46a

Please sign in to comment.