76 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php 
 | |
| 
 | |
| /**
 | |
|  * @author          Tassos Marinos <info@tassos.gr>
 | |
|  * @link            https://www.tassos.gr
 | |
|  * @copyright       Copyright © 2024 Tassos All Rights Reserved
 | |
|  * @license         GNU GPLv3 <http://www.gnu.org/licenses/gpl.html> 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'));
 | |
| 	}
 | |
| }
 |