| Server IP : 172.67.191.97 / Your IP : 104.23.243.197 Web Server : Apache/2.4.63 (Ubuntu) System : Linux adminpruebas-Virtual-Machine 6.14.0-37-generic #37-Ubuntu SMP PREEMPT_DYNAMIC Fri Nov 14 22:10:32 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 8.4.5 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /var/www/html/pts/modules/mod_latestnewsenhanced/src/Field/ |
Upload File : |
<?php
/**
* @copyright Copyright (C) 2011 Simplify Your Web, Inc. All rights reserved.
* @license GNU General Public License version 3 or later; see LICENSE.txt
*/
namespace SYW\Module\LatestNewsEnhanced\Site\Field;
defined('_JEXEC') or die;
use Joomla\CMS\Factory;
use Joomla\CMS\Form\Field\ListField;
use Joomla\Database\Exception\ExecutionFailureException;
/**
* Author selection
*/
class AuthorselectField extends ListField
{
public $type = 'Authorselect';
protected $option;
protected function getOptions()
{
$options = array();
$db = Factory::getDbo();
$query = $db->getQuery(true);
$query->select($db->quoteName('id', 'value'));
$query->select($db->quoteName('name', 'text'));
$query->from($db->quoteName('#__users'));
$query->where('id IN (select distinct(created_by) from #__content)');
$query->order('name', 'ASC');
// $query = $db->getQuery(true)
// ->select('u.id AS value, u.name AS text')
// ->from('#__users AS u')
// ->join('INNER', '#__content AS c ON c.created_by = u.id')
// ->group('u.id, u.name')
// ->order('u.name');
$db->setQuery($query);
try {
$authors = $db->loadObjectList();
} catch (ExecutionFailureException $e) {
$authors = array();
}
$options = array_merge($options, $authors);
// Merge any additional options in the XML definition.
$options = array_merge(parent::getOptions(), $options);
return $options;
}
public function setup(\SimpleXMLElement $element, $value, $group = null)
{
$return = parent::setup($element, $value, $group);
if ($return) {
$this->option = isset($this->element['option']) ? $this->element['option'] : '';
}
return $return;
}
}
?>