/** * 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 * @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) */ import {Grid} from '@js/types/grid'; import GridMap from '@components/grid/grid-map'; const {$} = window; /** * This extension enables submit functionality of the choice fields in grid. * * Usage of the extension: * * const myGrid = new Grid('myGrid'); * myGrid.addExtension(new ChoiceExtension()); * */ export default class ChoiceExtension { lockArray: Array; constructor() { this.lockArray = []; } extend(grid: Grid): void { const $choiceOptionsContainer = grid .getContainer() .find(GridMap.bulks.choiceOptions); $choiceOptionsContainer.find(GridMap.dropdownItem).on('click', (e) => { e.preventDefault(); const $button = $(e.currentTarget); const $parent = $button.closest(GridMap.bulks.choiceOptions); const url = $parent.data('url'); this.submitForm(url, $button); }); } /** * Submits the form. * @param {string} url * @param {jQuery} $button * @private */ private submitForm(url: string, $button: JQuery) { const selectedStatusId = $button.data('value'); if (this.isLocked(url)) { return; } const $form = $('
', { action: url, method: 'POST', }).append( $('', { name: 'value', value: selectedStatusId, type: 'hidden', }), ); $form.appendTo('body'); $form.submit(); this.lock(url); } /** * Checks if current url is being used at the moment. * * @param url * @return {boolean} * * @private */ private isLocked(url: string): boolean { return this.lockArray.includes(url); } /** * Locks the current url so it cant be used twice to execute same request * @param url * @private */ private lock(url: string): void { this.lockArray.push(url); } }