diff --git a/administrator/components/com_content/controller.php b/administrator/components/com_content/controller.php index 065a54952d5f0..0795409348d67 100644 --- a/administrator/components/com_content/controller.php +++ b/administrator/components/com_content/controller.php @@ -17,8 +17,10 @@ class ContentController extends JControllerLegacy { /** - * @var string The default view. - * @since 1.6 + * The default view. + * + * @var string + * @since 1.6 */ protected $default_view = 'articles'; @@ -28,7 +30,7 @@ class ContentController extends JControllerLegacy * @param boolean $cachable If true, the view output will be cached * @param array $urlparams An array of safe url parameters and their variable types, for valid values see {@link JFilterInput::clean()}. * - * @return JController This object to support chaining. + * @return ContentController This object to support chaining. * * @since 1.5 */ diff --git a/administrator/components/com_content/controllers/article.php b/administrator/components/com_content/controllers/article.php index 3ce74d4b211b7..e8618ebee9162 100644 --- a/administrator/components/com_content/controllers/article.php +++ b/administrator/components/com_content/controllers/article.php @@ -14,9 +14,7 @@ /** * The article controller * - * @package Joomla.Administrator - * @subpackage com_content - * @since 1.6 + * @since 1.6 */ class ContentControllerArticle extends JControllerForm { @@ -65,10 +63,8 @@ protected function allowAdd($data = array()) // In the absense of better information, revert to the component permissions. return parent::allowAdd(); } - else - { - return $allow; - } + + return $allow; } /** @@ -110,7 +106,7 @@ protected function allowEdit($data = array(), $key = 'id') } // Grant if current user is owner of the record - return $user->get('id') == $record->created_by; + return $user->id == $record->created_by; } return false; @@ -130,6 +126,7 @@ public function batch($model = null) JSession::checkToken() or jexit(JText::_('JINVALID_TOKEN')); // Set the model + /** @var ContentModelArticle $model */ $model = $this->getModel('Article', '', array()); // Preset the redirect @@ -137,20 +134,4 @@ public function batch($model = null) return parent::batch($model); } - - /** - * Function that allows child controller access to model data after the data has been saved. - * - * @param JModelLegacy $model The data model object. - * @param array $validData The validated data. - * - * @return void - * - * @since 3.1 - */ - protected function postSaveHook(JModelLegacy $model, $validData = array()) - { - - return; - } } diff --git a/administrator/components/com_content/controllers/articles.php b/administrator/components/com_content/controllers/articles.php index 4a3e838820d8a..e09d293812d47 100644 --- a/administrator/components/com_content/controllers/articles.php +++ b/administrator/components/com_content/controllers/articles.php @@ -23,7 +23,7 @@ class ContentControllerArticles extends JControllerAdmin * * @param array $config An optional associative array of configuration settings. * - * @see JController + * @see JControllerLegacy * @since 1.6 */ public function __construct($config = array()) @@ -76,6 +76,7 @@ public function featured() else { // Get the model. + /** @var ContentModelArticle $model */ $model = $this->getModel(); // Publish the items. @@ -113,7 +114,7 @@ public function featured() * @param string $prefix The class prefix. Optional. * @param array $config The array of possible config values. Optional. * - * @return JModel + * @return JModelLegacy * * @since 1.6 */ @@ -121,19 +122,4 @@ public function getModel($name = 'Article', $prefix = 'ContentModel', $config = { return parent::getModel($name, $prefix, $config); } - - /** - * Function that allows child controller access to model data - * after the item has been deleted. - * - * @param JModelLegacy $model The data model object. - * @param integer $ids The array of ids for items being deleted. - * - * @return void - * - * @since 12.2 - */ - protected function postDeleteHook(JModelLegacy $model, $ids = null) - { - } } diff --git a/administrator/components/com_content/controllers/featured.php b/administrator/components/com_content/controllers/featured.php index 458026fdcbc7b..eb8af65bbfb14 100644 --- a/administrator/components/com_content/controllers/featured.php +++ b/administrator/components/com_content/controllers/featured.php @@ -51,6 +51,7 @@ public function delete() else { // Get the model. + /** @var ContentModelFeature $model */ $model = $this->getModel(); // Remove the items. @@ -84,7 +85,7 @@ public function publish() * @param string $prefix The class prefix. Optional. * @param array $config Configuration array for model. Optional. * - * @return object The model. + * @return JModelLegacy The model. * * @since 1.6 */ diff --git a/administrator/components/com_content/helpers/html/contentadministrator.php b/administrator/components/com_content/helpers/html/contentadministrator.php index e1e73675e4edb..644f6025150e3 100644 --- a/administrator/components/com_content/helpers/html/contentadministrator.php +++ b/administrator/components/com_content/helpers/html/contentadministrator.php @@ -23,9 +23,11 @@ abstract class JHtmlContentAdministrator /** * Render the list of associated items * - * @param int $articleid The article item id + * @param integer $articleid The article item id * * @return string The language HTML + * + * @throws Exception */ public static function association($articleid) { @@ -60,7 +62,7 @@ public static function association($articleid) } catch (RuntimeException $e) { - throw new Exception($e->getMessage(), 500); + throw new Exception($e->getMessage(), 500, $e); } if ($items) @@ -70,7 +72,9 @@ public static function association($articleid) $text = strtoupper($item->lang_sef); $url = JRoute::_('index.php?option=com_content&task=article.edit&id=' . (int) $item->id); $tooltipParts = array( - JHtml::_('image', 'mod_languages/' . $item->image . '.gif', + JHtml::_( + 'image', + 'mod_languages/' . $item->image . '.gif', $item->language_title, array('title' => $item->language_title), true @@ -101,8 +105,8 @@ public static function association($articleid) /** * Show the feature/unfeature links * - * @param int $value The state value - * @param int $i Row number + * @param integer $value The state value + * @param integer $i Row number * @param boolean $canChange Is user allowed to change? * * @return string HTML code diff --git a/administrator/components/com_content/models/article.php b/administrator/components/com_content/models/article.php index fb9a489d6db65..428df86c19c59 100644 --- a/administrator/components/com_content/models/article.php +++ b/administrator/components/com_content/models/article.php @@ -22,24 +22,26 @@ class ContentModelArticle extends JModelAdmin { /** - * @var string The prefix to use with controller messages. - * @since 1.6 + * The prefix to use with controller messages. + * + * @var string + * @since 1.6 */ protected $text_prefix = 'COM_CONTENT'; /** * The type alias for this content type (for example, 'com_content.article'). * - * @var string - * @since 3.2 + * @var string + * @since 3.2 */ public $typeAlias = 'com_content.article'; /** * The context used for the associations table * - * @var string - * @since 3.4.4 + * @var string + * @since 3.4.4 */ protected $associationsContext = 'com_content.item'; @@ -60,7 +62,7 @@ protected function batchCopy($value, $pks, $contexts) $newIds = array(); - if (!parent::checkCategoryId($categoryId)) + if (!$this->checkCategoryId($categoryId)) { return false; } @@ -122,7 +124,7 @@ protected function batchCopy($value, $pks, $contexts) return false; } - parent::createTagsHelper($this->tagsObserver, $this->type, $pk, $this->typeAlias, $this->table); + $this->createTagsHelper($this->tagsObserver, $this->type, $pk, $this->typeAlias, $this->table); // Store the row. if (!$this->table->store()) @@ -174,9 +176,7 @@ protected function canDelete($record) return false; } - $user = JFactory::getUser(); - - return $user->authorise('core.delete', 'com_content.article.' . (int) $record->id); + return JFactory::getUser()->authorise('core.delete', 'com_content.article.' . (int) $record->id); } return false; @@ -200,16 +200,15 @@ protected function canEditState($record) { return $user->authorise('core.edit.state', 'com_content.article.' . (int) $record->id); } + // New article, so check against the category. - elseif (!empty($record->catid)) + if (!empty($record->catid)) { return $user->authorise('core.edit.state', 'com_content.category.' . (int) $record->catid); } + // Default to component settings if neither article nor category known. - else - { - return parent::canEditState('com_content'); - } + return parent::canEditState(); } /** @@ -224,8 +223,6 @@ protected function canEditState($record) protected function prepareTable($table) { // Set the publish date to now - $db = $this->getDbo(); - if ($table->state == 1 && (int) $table->publish_up == 0) { $table->publish_up = JFactory::getDate()->toSql(); @@ -233,7 +230,7 @@ protected function prepareTable($table) if ($table->state == 1 && intval($table->publish_down) == 0) { - $table->publish_down = $db->getNullDate(); + $table->publish_down = $this->getDbo()->getNullDate(); } // Increment the content version number. @@ -301,7 +298,6 @@ public function getItem($pk = null) } // Load associated content items - $app = JFactory::getApplication(); $assoc = JLanguageAssociations::isEnabled(); if ($assoc) @@ -328,7 +324,7 @@ public function getItem($pk = null) * @param array $data Data for the form. * @param boolean $loadData True if the form is to load its own data (default case), false if not. * - * @return mixed A JForm object on success, false on failure + * @return JForm|boolean A JForm object on success, false on failure * * @since 1.6 */ @@ -344,16 +340,11 @@ public function getForm($data = array(), $loadData = true) $jinput = JFactory::getApplication()->input; - // The front end calls this model and uses a_id to avoid id clashes so we need to check for that first. - if ($jinput->get('a_id')) - { - $id = $jinput->get('a_id', 0); - } - // The back end uses id so we use that the rest of the time and set it to 0 by default. - else - { - $id = $jinput->get('id', 0); - } + /* + * The front end calls this model and uses a_id to avoid id clashes so we need to check for that first. + * The back end uses id so we use that the rest of the time and set it to 0 by default. + */ + $id = $jinput->get('a_id', $jinput->get('id', 0)); // Determine correct permissions to check. if ($this->getState('article.id')) @@ -602,7 +593,6 @@ public function save($data) if (parent::save($data)) { - if (isset($data['featured'])) { $this->featured($this->getState($this->getName() . '.id'), $data['featured']); @@ -641,9 +631,9 @@ public function featured($pks, $value = 0) { $db = $this->getDbo(); $query = $db->getQuery(true) - ->update($db->quoteName('#__content')) - ->set('featured = ' . (int) $value) - ->where('id IN (' . implode(',', $pks) . ')'); + ->update($db->quoteName('#__content')) + ->set('featured = ' . (int) $value) + ->where('id IN (' . implode(',', $pks) . ')'); $db->setQuery($query); $db->execute(); @@ -652,8 +642,8 @@ public function featured($pks, $value = 0) // Adjust the mapping table. // Clear the existing features settings. $query = $db->getQuery(true) - ->delete($db->quoteName('#__content_frontpage')) - ->where('content_id IN (' . implode(',', $pks) . ')'); + ->delete($db->quoteName('#__content_frontpage')) + ->where('content_id IN (' . implode(',', $pks) . ')'); $db->setQuery($query); $db->execute(); } @@ -681,7 +671,6 @@ public function featured($pks, $value = 0) if (count($tuples)) { - $db = $this->getDbo(); $columns = array('content_id', 'ordering'); $query = $db->getQuery(true) ->insert($db->quoteName('#__content_frontpage')) @@ -717,10 +706,7 @@ public function featured($pks, $value = 0) */ protected function getReorderConditions($table) { - $condition = array(); - $condition[] = 'catid = ' . (int) $table->catid; - - return $condition; + return array('catid = ' . (int) $table->catid); } /** @@ -732,7 +718,7 @@ protected function getReorderConditions($table) * * @return void * - * @since 3.0 + * @since 3.0 */ protected function preprocessForm(JForm $form, $data, $group = 'content') { diff --git a/administrator/components/com_content/models/articles.php b/administrator/components/com_content/models/articles.php index 3452d9e7ba20a..8d364cef09726 100644 --- a/administrator/components/com_content/models/articles.php +++ b/administrator/components/com_content/models/articles.php @@ -24,7 +24,7 @@ class ContentModelArticles extends JModelList * @param array $config An optional associative array of configuration settings. * * @since 1.6 - * @see JController + * @see JControllerLegacy */ public function __construct($config = array()) { @@ -168,7 +168,6 @@ protected function getListQuery() $db = $this->getDbo(); $query = $db->getQuery(true); $user = JFactory::getUser(); - $app = JFactory::getApplication(); // Select the required fields from the table. $query->select( @@ -251,9 +250,7 @@ protected function getListQuery() } elseif (is_array($categoryId)) { - $categoryId = ArrayHelper::toInteger($categoryId); - $categoryId = implode(',', $categoryId); - $query->where('a.catid IN (' . $categoryId . ')'); + $query->where('a.catid IN (' . implode(',', ArrayHelper::toInteger($categoryId)) . ')'); } // Filter on the level. @@ -305,7 +302,8 @@ protected function getListQuery() { $query->where($db->quoteName('tagmap.tag_id') . ' = ' . (int) $tagId) ->join( - 'LEFT', $db->quoteName('#__contentitem_tag_map', 'tagmap') + 'LEFT', + $db->quoteName('#__contentitem_tag_map', 'tagmap') . ' ON ' . $db->quoteName('tagmap.content_item_id') . ' = ' . $db->quoteName('a.id') . ' AND ' . $db->quoteName('tagmap.type_alias') . ' = ' . $db->quote('com_content.article') ); @@ -339,7 +337,7 @@ protected function getListQuery() /** * Build a list of authors * - * @return JDatabaseQuery + * @return stdClass * * @since 1.6 */ @@ -377,8 +375,7 @@ public function getItems() if (JFactory::getApplication()->isSite()) { - $user = JFactory::getUser(); - $groups = $user->getAuthorisedViewLevels(); + $groups = JFactory::getUser()->getAuthorisedViewLevels(); for ($x = 0, $count = count($items); $x < $count; $x++) { diff --git a/administrator/components/com_content/models/feature.php b/administrator/components/com_content/models/feature.php index 7a12a1f876284..e9c5d4aa4909c 100644 --- a/administrator/components/com_content/models/feature.php +++ b/administrator/components/com_content/models/feature.php @@ -45,8 +45,6 @@ public function getTable($type = 'Featured', $prefix = 'ContentTable', $config = */ protected function getReorderConditions($table) { - $condition = array(); - - return $condition; + return array(); } } diff --git a/administrator/components/com_content/models/featured.php b/administrator/components/com_content/models/featured.php index f41cbb406f2b4..41400bb4c62c8 100644 --- a/administrator/components/com_content/models/featured.php +++ b/administrator/components/com_content/models/featured.php @@ -14,7 +14,7 @@ JLoader::register('ContentModelArticles', __DIR__ . '/articles.php'); /** - * About Page Model + * Methods supporting a list of featured article records. * * @since 1.6 */ @@ -25,7 +25,7 @@ class ContentModelFeatured extends ContentModelArticles * * @param array $config An optional associative array of configuration settings. * - * @see JController + * @see JControllerLegacy * @since 1.6 */ public function __construct($config = array()) @@ -65,13 +65,11 @@ public function __construct($config = array()) /** * Build an SQL query to load the list data. * - * @param boolean $resolveFKs True to join selected foreign information - * - * @return string + * @return JDatabaseQuery * * @since 1.6 */ - protected function getListQuery($resolveFKs = true) + protected function getListQuery() { // Create a new query object. $db = $this->getDbo(); @@ -145,8 +143,7 @@ protected function getListQuery($resolveFKs = true) } elseif (is_array($categoryId)) { - $categoryId = ArrayHelper::toInteger($categoryId); - $categoryId = implode(',', $categoryId); + $categoryId = implode(',', ArrayHelper::toInteger($categoryId)); $query->where('a.catid IN (' . $categoryId . ')'); } @@ -198,7 +195,8 @@ protected function getListQuery($resolveFKs = true) { $query->where($db->quoteName('tagmap.tag_id') . ' = ' . (int) $tagId) ->join( - 'LEFT', $db->quoteName('#__contentitem_tag_map', 'tagmap') + 'LEFT', + $db->quoteName('#__contentitem_tag_map', 'tagmap') . ' ON ' . $db->quoteName('tagmap.content_item_id') . ' = ' . $db->quoteName('a.id') . ' AND ' . $db->quoteName('tagmap.type_alias') . ' = ' . $db->quote('com_content.article') ); diff --git a/administrator/components/com_content/models/fields/modal/article.php b/administrator/components/com_content/models/fields/modal/article.php index 499d15acf4d2d..b968b79eb4b30 100644 --- a/administrator/components/com_content/models/fields/modal/article.php +++ b/administrator/components/com_content/models/fields/modal/article.php @@ -19,8 +19,8 @@ class JFormFieldModal_Article extends JFormField /** * The form field type. * - * @var string - * @since 1.6 + * @var string + * @since 1.6 */ protected $type = 'Modal_Article'; diff --git a/administrator/components/com_content/views/article/view.html.php b/administrator/components/com_content/views/article/view.html.php index 99ca55b2672bc..71fb29d74cdbc 100644 --- a/administrator/components/com_content/views/article/view.html.php +++ b/administrator/components/com_content/views/article/view.html.php @@ -16,12 +16,34 @@ */ class ContentViewArticle extends JViewLegacy { + /** + * The JForm object + * + * @var JForm + */ protected $form; + /** + * The active item + * + * @var object + */ protected $item; + /** + * The model state + * + * @var object + */ protected $state; + /** + * The actions the user is authorised to perform + * + * @var JObject + */ + protected $canDo; + /** * Execute and display a template script. * @@ -36,14 +58,11 @@ public function display($tpl = null) if ($this->getLayout() == 'pagebreak') { // TODO: This is really dogy - should change this one day. - $input = JFactory::getApplication()->input; - $eName = $input->getCmd('e_name'); - $eName = preg_replace('#[^A-Z0-9\-\_\[\]]#i', '', $eName); - $document = JFactory::getDocument(); - $document->setTitle(JText::_('COM_CONTENT_PAGEBREAK_DOC_TITLE')); + $eName = JFactory::getApplication()->input->getCmd('e_name'); + $eName = preg_replace('#[^A-Z0-9\-\_\[\]]#i', '', $eName); + $this->document->setTitle(JText::_('COM_CONTENT_PAGEBREAK_DOC_TITLE')); $this->eName = &$eName; - parent::display($tpl); - return; + return parent::display($tpl); } $this->form = $this->get('Form'); @@ -81,7 +100,8 @@ public function display($tpl = null) } $this->addToolbar(); - parent::display($tpl); + + return parent::display($tpl); } /** @@ -95,7 +115,7 @@ protected function addToolbar() { JFactory::getApplication()->input->set('hidemainmenu', true); $user = JFactory::getUser(); - $userId = $user->get('id'); + $userId = $user->id; $isNew = ($this->item->id == 0); $checkedOut = !($this->item->checked_out == 0 || $this->item->checked_out == $userId); diff --git a/administrator/components/com_content/views/articles/view.html.php b/administrator/components/com_content/views/articles/view.html.php index f72919292456a..fadaf69bb57f1 100644 --- a/administrator/components/com_content/views/articles/view.html.php +++ b/administrator/components/com_content/views/articles/view.html.php @@ -16,18 +16,61 @@ */ class ContentViewArticles extends JViewLegacy { + /** + * The item authors + * + * @var stdClass + */ + protected $authors; + + /** + * An array of items + * + * @var array + */ protected $items; + /** + * The pagination object + * + * @var JPagination + */ protected $pagination; + /** + * The model state + * + * @var object + */ protected $state; + /** + * Form object for search filters + * + * @var JForm + */ + public $filterForm; + + /** + * The active search filters + * + * @var array + */ + public $activeFilters; + + /** + * The sidebar markup + * + * @var string + */ + protected $sidebar; + /** * Display the view * * @param string $tpl The name of the template file to parse; automatically searches through the template paths. * - * @return void + * @return mixed A string if successful, otherwise a Error object. */ public function display($tpl = null) { @@ -51,20 +94,19 @@ public function display($tpl = null) return false; } - // Levels filter. - $options = array(); - $options[] = JHtml::_('select.option', '1', JText::_('J1')); - $options[] = JHtml::_('select.option', '2', JText::_('J2')); - $options[] = JHtml::_('select.option', '3', JText::_('J3')); - $options[] = JHtml::_('select.option', '4', JText::_('J4')); - $options[] = JHtml::_('select.option', '5', JText::_('J5')); - $options[] = JHtml::_('select.option', '6', JText::_('J6')); - $options[] = JHtml::_('select.option', '7', JText::_('J7')); - $options[] = JHtml::_('select.option', '8', JText::_('J8')); - $options[] = JHtml::_('select.option', '9', JText::_('J9')); - $options[] = JHtml::_('select.option', '10', JText::_('J10')); - - $this->f_levels = $options; + // Levels filter - Used in Hathor. + $this->f_levels = array( + JHtml::_('select.option', '1', JText::_('J1')), + JHtml::_('select.option', '2', JText::_('J2')), + JHtml::_('select.option', '3', JText::_('J3')), + JHtml::_('select.option', '4', JText::_('J4')), + JHtml::_('select.option', '5', JText::_('J5')), + JHtml::_('select.option', '6', JText::_('J6')), + JHtml::_('select.option', '7', JText::_('J7')), + JHtml::_('select.option', '8', JText::_('J8')), + JHtml::_('select.option', '9', JText::_('J9')), + JHtml::_('select.option', '10', JText::_('J10')), + ); // We don't need toolbar in the modal window. if ($this->getLayout() !== 'modal') @@ -90,7 +132,7 @@ public function display($tpl = null) } } - parent::display($tpl); + return parent::display($tpl); } /** diff --git a/administrator/components/com_content/views/featured/view.html.php b/administrator/components/com_content/views/featured/view.html.php index d47b64a54b258..46eabc55fbc92 100644 --- a/administrator/components/com_content/views/featured/view.html.php +++ b/administrator/components/com_content/views/featured/view.html.php @@ -16,18 +16,61 @@ */ class ContentViewFeatured extends JViewLegacy { + /** + * The item authors + * + * @var stdClass + */ + protected $authors; + + /** + * An array of items + * + * @var array + */ protected $items; + /** + * The pagination object + * + * @var JPagination + */ protected $pagination; + /** + * The model state + * + * @var object + */ protected $state; + /** + * Form object for search filters + * + * @var JForm + */ + public $filterForm; + + /** + * The active search filters + * + * @var array + */ + public $activeFilters; + + /** + * The sidebar markup + * + * @var string + */ + protected $sidebar; + /** * Display the view * * @param string $tpl The name of the template file to parse; automatically searches through the template paths. * - * @return void + * @return mixed A string if successful, otherwise a Error object. */ public function display($tpl = null) { @@ -48,24 +91,24 @@ public function display($tpl = null) return false; } - // Levels filter. - $options = array(); - $options[] = JHtml::_('select.option', '1', JText::_('J1')); - $options[] = JHtml::_('select.option', '2', JText::_('J2')); - $options[] = JHtml::_('select.option', '3', JText::_('J3')); - $options[] = JHtml::_('select.option', '4', JText::_('J4')); - $options[] = JHtml::_('select.option', '5', JText::_('J5')); - $options[] = JHtml::_('select.option', '6', JText::_('J6')); - $options[] = JHtml::_('select.option', '7', JText::_('J7')); - $options[] = JHtml::_('select.option', '8', JText::_('J8')); - $options[] = JHtml::_('select.option', '9', JText::_('J9')); - $options[] = JHtml::_('select.option', '10', JText::_('J10')); - - $this->f_levels = $options; + // Levels filter - Used in Hathor. + $this->f_levels = array( + JHtml::_('select.option', '1', JText::_('J1')), + JHtml::_('select.option', '2', JText::_('J2')), + JHtml::_('select.option', '3', JText::_('J3')), + JHtml::_('select.option', '4', JText::_('J4')), + JHtml::_('select.option', '5', JText::_('J5')), + JHtml::_('select.option', '6', JText::_('J6')), + JHtml::_('select.option', '7', JText::_('J7')), + JHtml::_('select.option', '8', JText::_('J8')), + JHtml::_('select.option', '9', JText::_('J9')), + JHtml::_('select.option', '10', JText::_('J10')), + ); $this->addToolbar(); $this->sidebar = JHtmlSidebar::render(); - parent::display($tpl); + + return parent::display($tpl); } /**