/** * Method to publish an element. * * @access public * @return void */ public function publish() { CkJSession::checkToken() or CkJSession::checkToken('get') or jexit(JText::_('JINVALID_TOKEN')); $this->_result = $result = parent::publish(); $model = $this->getModel(); //Define the redirections switch ($this->getLayout() . '.' . $this->getTask()) { case 'default.publish': $this->applyRedirection($result, array('stay', 'com_rtiprint.operatingsystems.default'), array('cid[]' => null)); break; case 'default.unpublish': $this->applyRedirection($result, array('stay', 'com_rtiprint.operatingsystems.default'), array('cid[]' => null)); break; case 'default.archive': $this->applyRedirection($result, array('stay', 'com_rtiprint.operatingsystems.default'), array('cid[]' => null)); break; case 'default.trash': $this->applyRedirection($result, array('stay', 'com_rtiprint.operatingsystems.default'), array('cid[]' => null)); break; default: $this->applyRedirection($result, array('stay', 'stay')); break; } }
/** * Method to save an element. * * @access public * @return void */ public function save() { CkJSession::checkToken() or CkJSession::checkToken('get') or jexit(JText::_('JINVALID_TOKEN')); //Check the ACLs $model = $this->getModel(); $item = $model->getItem(); $result = false; if ($model->canEdit($item, true)) { $result = parent::save(); //Get the model through postSaveHook() if ($this->model) { $model = $this->model; $item = $model->getItem(); } } else { JError::raiseWarning(403, JText::sprintf('ACL_UNAUTORIZED_TASK', JText::_('RTIPRINT_JTOOLBAR_SAVE'))); } $this->_result = $result; //Define the redirections switch ($this->getLayout() . '.' . $this->getTask()) { case 'changelog.apply': $this->applyRedirection($result, array('stay', 'com_rtiprint.changelog.rochangelog'), array('cid[]' => $model->getState('changelog.id'))); break; case 'changelog.save': $this->applyRedirection($result, array('stay', 'com_rtiprint.changelogs.changelogs'), array('cid[]' => null)); break; case 'changelog.save2new': $this->applyRedirection($result, array('stay', 'com_rtiprint.changelog.rochangelog'), array('cid[]' => null)); break; case 'changelog.save2copy': $this->applyRedirection($result, array('stay', 'com_rtiprint.changelog.rochangelog'), array('cid[]' => $model->getState('changelog.id'))); break; default: $this->applyRedirection($result, array('stay', 'com_rtiprint.changelogs.default')); break; } }
/** * Method to delete an element. * * @access public * @return void */ public function delete() { CkJSession::checkToken() or CkJSession::checkToken('get') or jexit(JText::_('JINVALID_TOKEN')); $this->_result = $result = parent::delete(); $model = $this->getModel(); //Define the redirections switch ($this->getLayout() . '.' . $this->getTask()) { case 'default.delete': $this->applyRedirection($result, array('stay', 'com_rtiprint.favourites.default'), array('cid[]' => null)); break; default: $this->applyRedirection($result, array('stay', 'com_rtiprint.favourites.default')); break; } }
/** * Method to save a record. * * @access public * @param string $key The name of the primary key of the URL variable. * @param string $urlVar The name of the URL variable if different from the primary key (sometimes required to avoid router collisions). * * @return boolean True if successful, false otherwise. * * @since Cook 2.5 */ public function save($key = null, $urlVar = null) { // Check for request forgeries. CkJSession::checkToken() or CkJSession::checkToken('get') or jexit(JText::_('JINVALID_TOKEN')); $app = JFactory::getApplication(); $lang = JFactory::getLanguage(); $model = $this->getModel(); $table = $model->getTable(); $data = $app->input->post->get('jform', array(), 'array'); $checkin = property_exists($table, 'checked_out'); $context = "{$this->option}.edit.{$this->context}"; $task = $this->getTask(); // Determine the name of the primary key for the data. if (empty($key)) { $key = $table->getKeyName(); } // To avoid data collisions the urlVar may be different from the primary key. if (empty($urlVar)) { $urlVar = $key; } $recordId = $app->input->getInt($urlVar); if (!$this->checkEditId($context, $recordId)) { // Somehow the person just went to the form and tried to save it. We don't allow that. $this->setError(JText::sprintf('JLIB_APPLICATION_ERROR_UNHELD_ID', $recordId)); $this->setMessage($this->getError(), 'error'); $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_list . $this->getRedirectToListAppend(), false)); return false; } // Populate the row id from the session. $data[$key] = $recordId; // The save2copy task needs to be handled slightly differently. if ($task == 'save2copy') { // Check-in the original row. if ($checkin && $model->checkin($data[$key]) === false) { // Check-in failed. Go back to the item and display a notice. $this->setError(JText::sprintf('JLIB_APPLICATION_ERROR_CHECKIN_FAILED', $model->getError())); $this->setMessage($this->getError(), 'error'); $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend($recordId, $urlVar), false)); return false; } // Reset the ID and then treat the request as for Apply. $data[$key] = 0; //Cook override $model->setState($model->getName() . '.id', 0); $task = 'apply'; } // Access check. if (!$this->allowSave($data, $key)) { $this->setError(JText::_('JLIB_APPLICATION_ERROR_SAVE_NOT_PERMITTED')); $this->setMessage($this->getError(), 'error'); $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_list . $this->getRedirectToListAppend(), false)); return false; } // Validate the posted data. // Sometimes the form needs some posted data, such as for plugins and modules. $form = $model->getForm($data, false); if (!$form) { $app->enqueueMessage($model->getError(), 'error'); return false; } // Test whether the data is valid. $validData = $model->validate($form, $data); // Check for validation errors. if ($validData === false) { // Get the validation messages. $errors = $model->getErrors(); // Push up to three validation messages out to the user. for ($i = 0, $n = count($errors); $i < $n && $i < 3; $i++) { if ($errors[$i] instanceof Exception) { $app->enqueueMessage($errors[$i]->getMessage(), 'warning'); } else { $app->enqueueMessage($errors[$i], 'warning'); } } // Save the data in the session. $app->setUserState($context . '.data', $data); // Redirect back to the edit screen. $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend($recordId, $urlVar), false)); return false; } // Attempt to save the data. if (!$model->save($validData)) { // Save the data in the session. $app->setUserState($context . '.data', $validData); // Redirect back to the edit screen. $this->setError(JText::sprintf('JLIB_APPLICATION_ERROR_SAVE_FAILED', $model->getError())); $this->setMessage($this->getError(), 'error'); $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend($recordId, $urlVar), false)); return false; } // Save succeeded, so check-in the record. if ($checkin && $model->checkin($validData[$key]) === false) { // Save the data in the session. $app->setUserState($context . '.data', $validData); // Check-in failed, so go back to the record and display a notice. $this->setError(JText::sprintf('JLIB_APPLICATION_ERROR_CHECKIN_FAILED', $model->getError())); $this->setMessage($this->getError(), 'error'); $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend($recordId, $urlVar), false)); return false; } $this->setMessage(JText::_(($lang->hasKey($this->text_prefix . ($recordId == 0 && $app->isSite() ? '_SUBMIT' : '') . '_SAVE_SUCCESS') ? $this->text_prefix : 'JLIB_APPLICATION') . ($recordId == 0 && $app->isSite() ? '_SUBMIT' : '') . '_SAVE_SUCCESS')); // Redirect the user and adjust session state based on the chosen task. switch ($task) { case 'apply': // Set the record data in the session. $recordId = $model->getState($this->context . '.id'); $this->holdEditId($context, $recordId); $app->setUserState($context . '.data', null); $model->checkout($recordId); // Redirect back to the edit screen. $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend($recordId, $urlVar), false)); break; case 'save2new': // Clear the record id and data from the session. $this->releaseEditId($context, $recordId); $app->setUserState($context . '.data', null); // Redirect back to the edit screen. $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_item . $this->getRedirectToItemAppend(null, $urlVar), false)); break; default: // Clear the record id and data from the session. $this->releaseEditId($context, $recordId); $app->setUserState($context . '.data', null); // Redirect to the list screen. $this->setRedirect(JRoute::_('index.php?option=' . $this->option . '&view=' . $this->view_list . $this->getRedirectToListAppend(), false)); break; } // Invoke the postSave method to allow for the child class to access the model. $this->postSaveHook($model, $validData); return true; }