* @link https://www.tassos.gr * @copyright Copyright © 2024 Tassos All Rights Reserved * @license GNU GPLv3 or later */ defined('_JEXEC') or die; use Joomla\CMS\HTML\HTMLHelper; use Joomla\CMS\Language\Text; require_once dirname(__DIR__) . '/helpers/groupfield.php'; class JFormFieldNR_Content extends NRFormGroupField { public $type = 'Content'; public function getCategories() { $extension = isset($this->element['extension']) ? (string) $this->element['extension'] : 'com_content'; $query = $this->db->getQuery(true) ->select('COUNT(c.id)') ->from('#__categories AS c') ->where('c.extension = ' . $this->db->quote($extension)) ->where('c.parent_id > 0') ->where('c.published > -1'); $this->db->setQuery($query); $total = $this->db->loadResult(); $options = array(); if ($this->get('show_ignore')) { if (in_array('-1', $this->value)) { $this->value = array('-1'); } $options[] = HTMLHelper::_('select.option', '-1', '- ' . Text::_('NR_IGNORE') . ' -', 'value', 'text', 0); $options[] = HTMLHelper::_('select.option', '-', ' ', 'value', 'text', 1); } $query->clear('select') ->select('c.id, c.title as name, c.level, c.published, c.language') ->order('c.lft'); $this->db->setQuery($query); $list = $this->db->loadObjectList(); $options = array_merge($options, $this->getOptionsByList($list, array('language'), -1)); return $options; } public function getItems() { $query = $this->db->getQuery(true) ->select('COUNT(i.id)') ->from('#__content AS i') ->where('i.access > -1'); $this->db->setQuery($query); $total = $this->db->loadResult(); $query->clear('select') ->select('i.id, i.title as name, i.language, c.title as cat, i.access as published') ->join('LEFT', '#__categories AS c ON c.id = i.catid') ->order('i.title, i.ordering, i.id'); $this->db->setQuery($query); $list = $this->db->loadObjectList(); return $this->getOptionsByList($list, array('language', 'cat', 'id')); } }