163 lines
4.7 KiB
JavaScript
163 lines
4.7 KiB
JavaScript
/**
|
|
* 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)
|
|
*/
|
|
|
|
import TranslationSettingsMap from './TranslationSettingsMap';
|
|
|
|
const {$} = window;
|
|
|
|
const $coreType = $(TranslationSettingsMap.exportCoreType);
|
|
const $themesType = $(TranslationSettingsMap.exportThemesType);
|
|
const $modulesType = $(TranslationSettingsMap.exportModulesType);
|
|
|
|
const $coreValues = $(TranslationSettingsMap.exportCoreValues).closest('.form-group');
|
|
const $themesValues = $(TranslationSettingsMap.exportThemesValues).closest('.form-group');
|
|
const $modulesValues = $(TranslationSettingsMap.exportModulesValues).closest('.form-group');
|
|
|
|
const $coreCheckboxes = $(TranslationSettingsMap.exportCoreValues);
|
|
const $themesSelect = $(TranslationSettingsMap.exportThemesValues);
|
|
const $modulesSelect = $(TranslationSettingsMap.exportModulesValues);
|
|
|
|
const $exportButton = $(TranslationSettingsMap.exportLanguageButton);
|
|
|
|
/**
|
|
* Toggles show/hide for the selectors of subtypes (in case of Core type), theme or module when a Type is selected
|
|
*
|
|
* Example : If Core type is selected, the subtypes checkboxes are shown,
|
|
* Theme and Module types are unselected and their value selector are hidden
|
|
*/
|
|
export default class ExportFormFieldToggle {
|
|
constructor() {
|
|
$coreType.on('change', this.coreTypeChanged.bind(this));
|
|
$themesType.on('change', this.themesTypeChanged.bind(this));
|
|
$modulesType.on('change', this.modulesTypeChanged.bind(this));
|
|
|
|
$coreCheckboxes.on('change', this.subChoicesChanged.bind(this));
|
|
$themesSelect.on('change', this.subChoicesChanged.bind(this));
|
|
$modulesSelect.on('change', this.subChoicesChanged.bind(this));
|
|
|
|
this.check($coreType);
|
|
}
|
|
|
|
coreTypeChanged() {
|
|
if (!$coreType.is(':checked')) {
|
|
return;
|
|
}
|
|
|
|
$coreType.prop('disabled', false);
|
|
this.uncheck($themesType, $modulesType);
|
|
this.show($coreValues);
|
|
this.hide($themesValues, $modulesValues);
|
|
this.subChoicesChanged();
|
|
}
|
|
|
|
themesTypeChanged() {
|
|
if (!$themesType.is(':checked')) {
|
|
return;
|
|
}
|
|
|
|
$themesType.prop('disabled', false);
|
|
this.uncheck($coreType, $modulesType);
|
|
this.show($themesValues);
|
|
this.hide($coreValues, $modulesValues);
|
|
this.subChoicesChanged();
|
|
}
|
|
|
|
modulesTypeChanged() {
|
|
if (!$modulesType.is(':checked')) {
|
|
return;
|
|
}
|
|
|
|
$modulesValues.prop('disabled', false);
|
|
this.uncheck($themesType, $coreType);
|
|
this.show($modulesValues);
|
|
this.hide($themesValues, $coreValues);
|
|
this.subChoicesChanged();
|
|
}
|
|
|
|
subChoicesChanged() {
|
|
if (
|
|
($coreType.prop('checked') && $coreCheckboxes.find(':checked').size() > 0)
|
|
|| ($themesType.prop('checked') && $themesSelect.val() !== null)
|
|
|| ($modulesType.prop('checked') && $modulesSelect.val() !== null)
|
|
) {
|
|
$exportButton.prop('disabled', false);
|
|
|
|
return;
|
|
}
|
|
|
|
$exportButton.prop('disabled', true);
|
|
}
|
|
|
|
/**
|
|
* Make all given selectors hidden
|
|
*
|
|
* @param $selectors
|
|
* @private
|
|
*/
|
|
hide(...$selectors) {
|
|
Object.values($selectors).forEach((el) => {
|
|
el.addClass('d-none');
|
|
el.find('select, input').prop('disabled', 'disabled');
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Make all given selectors visible
|
|
*
|
|
* @param $selectors
|
|
* @private
|
|
*/
|
|
show(...$selectors) {
|
|
Object.values($selectors).forEach((el) => {
|
|
el.removeClass('d-none');
|
|
el.find('select, input').prop('disabled', false);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Make all given selectors unchecked
|
|
*
|
|
* @param $selectors
|
|
* @private
|
|
*/
|
|
uncheck(...$selectors) {
|
|
Object.values($selectors).forEach((el) => {
|
|
el.prop('checked', false);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Make all given selectors checked
|
|
*
|
|
* @param $selectors
|
|
* @private
|
|
*/
|
|
check(...$selectors) {
|
|
Object.values($selectors).forEach((el) => {
|
|
el.prop('checked', true);
|
|
});
|
|
}
|
|
}
|