update
This commit is contained in:
203
iadmin/themes/new-theme/js/pages/import/FormFieldToggle.js
Normal file
203
iadmin/themes/new-theme/js/pages/import/FormFieldToggle.js
Normal file
@@ -0,0 +1,203 @@
|
||||
/**
|
||||
* Copyright since 2007 PrestaShop SA and Contributors
|
||||
* PrestaShop is an International Registered Trademark & Property of PrestaShop SA
|
||||
*
|
||||
* NOTICE OF LICENSE
|
||||
*
|
||||
* This source file is subject to the Open Software License (OSL 3.0)
|
||||
* that is bundled with this package in the file LICENSE.md.
|
||||
* It is also available through the world-wide-web at this URL:
|
||||
* https://opensource.org/licenses/OSL-3.0
|
||||
* If you did not receive a copy of the license and are unable to
|
||||
* obtain it through the world-wide-web, please send an email
|
||||
* to license@prestashop.com so we can send you a copy immediately.
|
||||
*
|
||||
* DISCLAIMER
|
||||
*
|
||||
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
|
||||
* versions in the future. If you wish to customize PrestaShop for your
|
||||
* needs please refer to https://devdocs.prestashop.com/ for more information.
|
||||
*
|
||||
* @author PrestaShop SA and Contributors <contact@prestashop.com>
|
||||
* @copyright Since 2007 PrestaShop SA and Contributors
|
||||
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
|
||||
*/
|
||||
|
||||
const {$} = window;
|
||||
|
||||
const entityCategories = 0;
|
||||
const entityProducts = 1;
|
||||
const entityCombinations = 2;
|
||||
const entityCustomers = 3;
|
||||
const entityAddresses = 4;
|
||||
const entityBrands = 5;
|
||||
const entitySuppliers = 6;
|
||||
const entityAlias = 7;
|
||||
const entityStoreContacts = 8;
|
||||
|
||||
export default class FormFieldToggle {
|
||||
constructor() {
|
||||
$('.js-entity-select').on('change', () => this.toggleForm());
|
||||
|
||||
this.toggleForm();
|
||||
}
|
||||
|
||||
toggleForm() {
|
||||
const selectedOption = $('#entity').find('option:selected');
|
||||
const selectedEntity = parseInt(selectedOption.val(), 10);
|
||||
const entityName = selectedOption.text().toLowerCase();
|
||||
|
||||
this.toggleEntityAlert(selectedEntity);
|
||||
this.toggleFields(selectedEntity, entityName);
|
||||
this.loadAvailableFields(selectedEntity);
|
||||
}
|
||||
|
||||
/**
|
||||
* Toggle alert warning for selected import entity
|
||||
*
|
||||
* @param {int} selectedEntity
|
||||
*/
|
||||
toggleEntityAlert(selectedEntity) {
|
||||
const $alert = $('.js-entity-alert');
|
||||
|
||||
if ([entityCategories, entityProducts].includes(selectedEntity)) {
|
||||
$alert.show();
|
||||
} else {
|
||||
$alert.hide();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Toggle available options for selected entity
|
||||
*
|
||||
* @param {int} selectedEntity
|
||||
* @param {string} entityName
|
||||
*/
|
||||
toggleFields(selectedEntity, entityName) {
|
||||
const $truncateFormGroup = $('.js-truncate-form-group');
|
||||
const $matchRefFormGroup = $('.js-match-ref-form-group');
|
||||
const $regenerateFormGroup = $('.js-regenerate-form-group');
|
||||
const $forceIdsFormGroup = $('.js-force-ids-form-group');
|
||||
const $entityNamePlaceholder = $('.js-entity-name');
|
||||
|
||||
if (entityStoreContacts === selectedEntity) {
|
||||
$truncateFormGroup.hide();
|
||||
} else {
|
||||
$truncateFormGroup.show();
|
||||
}
|
||||
|
||||
if ([entityProducts, entityCombinations].includes(selectedEntity)) {
|
||||
$matchRefFormGroup.show();
|
||||
} else {
|
||||
$matchRefFormGroup.hide();
|
||||
}
|
||||
|
||||
if ([
|
||||
entityCategories,
|
||||
entityProducts,
|
||||
entityBrands,
|
||||
entitySuppliers,
|
||||
entityStoreContacts,
|
||||
].includes(selectedEntity)
|
||||
) {
|
||||
$regenerateFormGroup.show();
|
||||
} else {
|
||||
$regenerateFormGroup.hide();
|
||||
}
|
||||
|
||||
if ([
|
||||
entityCategories,
|
||||
entityProducts,
|
||||
entityCustomers,
|
||||
entityAddresses,
|
||||
entityBrands,
|
||||
entitySuppliers,
|
||||
entityStoreContacts,
|
||||
entityAlias,
|
||||
].includes(selectedEntity)
|
||||
) {
|
||||
$forceIdsFormGroup.show();
|
||||
} else {
|
||||
$forceIdsFormGroup.hide();
|
||||
}
|
||||
|
||||
$entityNamePlaceholder.html(entityName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Load available fields for given entity
|
||||
*
|
||||
* @param {int} entity
|
||||
*/
|
||||
loadAvailableFields(entity) {
|
||||
const $availableFields = $('.js-available-fields');
|
||||
|
||||
$.ajax({
|
||||
url: $availableFields.data('url'),
|
||||
data: {
|
||||
entity,
|
||||
},
|
||||
dataType: 'json',
|
||||
}).then((response) => {
|
||||
this.removeAvailableFields($availableFields);
|
||||
|
||||
for (let i = 0; i < response.length; i += 1) {
|
||||
this.appendAvailableField(
|
||||
$availableFields,
|
||||
response[i].label + (response[i].required ? '*' : ''),
|
||||
response[i].description,
|
||||
);
|
||||
}
|
||||
|
||||
$availableFields.find('[data-toggle="popover"]').popover();
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove available fields content from given container.
|
||||
*
|
||||
* @param {jQuery} $container
|
||||
* @private
|
||||
*/
|
||||
removeAvailableFields($container) {
|
||||
$container.find('[data-toggle="popover"]').popover('hide');
|
||||
$container.empty();
|
||||
}
|
||||
|
||||
/**
|
||||
* Append a help box to given field.
|
||||
*
|
||||
* @param {jQuery} $field
|
||||
* @param {String} helpBoxContent
|
||||
* @private
|
||||
*/
|
||||
appendHelpBox($field, helpBoxContent) {
|
||||
const $helpBox = $('.js-available-field-popover-template').clone();
|
||||
|
||||
$helpBox.attr('data-content', helpBoxContent);
|
||||
$helpBox.removeClass('js-available-field-popover-template d-none');
|
||||
$field.append($helpBox);
|
||||
}
|
||||
|
||||
/**
|
||||
* Append available field to given container.
|
||||
*
|
||||
* @param {jQuery} $appendTo field will be appended to this container.
|
||||
* @param {String} fieldText
|
||||
* @param {String} helpBoxContent
|
||||
* @private
|
||||
*/
|
||||
appendAvailableField($appendTo, fieldText, helpBoxContent) {
|
||||
const $field = $('.js-available-field-template').clone();
|
||||
|
||||
$field.text(fieldText);
|
||||
|
||||
if (helpBoxContent) {
|
||||
// Append help box next to the field
|
||||
this.appendHelpBox($field, helpBoxContent);
|
||||
}
|
||||
|
||||
$field.removeClass('js-available-field-template d-none');
|
||||
$field.appendTo($appendTo);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user