* @license GNU General Public License version 2 or later; see LICENSE.txt */ namespace Joomla\Component\Plugins\Administrator\Controller; use Joomla\CMS\MVC\Controller\FormController; use Joomla\CMS\MVC\Model\BaseDatabaseModel; use Joomla\CMS\Router\Route; // phpcs:disable PSR1.Files.SideEffects \defined('_JEXEC') or die; // phpcs:enable PSR1.Files.SideEffects /** * Plugin controller class. * * @since 1.6 */ class PluginController extends FormController { /** * Method to cancel an edit. * * @param string $key The name of the primary key of the URL variable. * * @return boolean True if access level checks pass, false otherwise. * * @since 5.1.0 */ public function cancel($key = null) { $result = parent::cancel($key); // When editing in modal then redirect to modalreturn layout if ($result && $this->input->get('layout') === 'modal') { $id = $this->input->get('extension_id'); $return = 'index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend($id, 'extension_id') . '&layout=modalreturn&from-task=cancel'; $this->setRedirect(Route::_($return, false)); } return $result; } /** * Function that allows child controller access to model data * after the data has been saved. * * @param BaseDatabaseModel $model The data model object. * @param array $validData The validated data. * * @return void * * @since 5.1.0 */ protected function postSaveHook(BaseDatabaseModel $model, $validData = []) { parent::postSaveHook($model, $validData); // When editing in modal then redirect to modalreturn layout if ($this->input->get('layout') === 'modal' && $this->task === 'save') { $id = $model->getState('plugin.id', ''); $return = 'index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend($id, 'extension_id') . '&layout=modalreturn&from-task=save'; $this->setRedirect(Route::_($return, false)); } } }