403Webshell
Server IP : 172.67.191.97  /  Your IP : 104.23.243.196
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/pregrados/contaduria-publica/libraries/regularlabs/src/Form/Field/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /var/www/html/pregrados/contaduria-publica/libraries/regularlabs/src/Form/Field/FieldField.php
<?php
/**
 * @package         Regular Labs Library
 * @version         23.12.10783
 * 
 * @author          Peter van Westen <[email protected]>
 * @link            https://regularlabs.com
 * @copyright       Copyright © 2023 Regular Labs All Rights Reserved
 * @license         GNU General Public License version 2 or later
 */

namespace RegularLabs\Library\Form\Field;

defined('_JEXEC') or die;

use Joomla\CMS\HTML\HTMLHelper as JHtml;
use Joomla\CMS\Language\Text as JText;
use RegularLabs\Library\ArrayHelper as RL_Array;
use RegularLabs\Library\DB as RL_DB;
use RegularLabs\Library\Form\Form;
use RegularLabs\Library\Form\FormField as RL_FormField;

class FieldField extends RL_FormField
{
    static      $fields;
    public bool $is_select_list = true;

    public function getNameById(string $value, array $attributes): string
    {
        return RL_Array::implode($this->getNamesByIds([$value], $attributes));
    }

    public function getNamesByIds(array $values, array $attributes): array
    {
        $db    = RL_DB::get();
        $query = RL_DB::getQuery()
            ->select('DISTINCT a.id, a.type, a.title as name')
            ->from('#__fields AS a')
            ->where('a.state = 1')
            ->where(RL_DB::is('a.id', $values))
            ->order('a.title');

        $db->setQuery($query);
        $fields = $db->loadObjectList();

        return Form::getNamesWithExtras($fields, ['type']);
    }

    protected function getOptions()
    {
        $fields = $this->getFields();

        $options = [];

        $options[] = JHtml::_('select.option', '', '- ' . JText::_('RL_SELECT_FIELD') . ' -');

        foreach ($fields as $field)
        {
            $key       = $field->{$this->get('key', 'id')} ?? $field->id;
            $options[] = JHtml::_('select.option', $key, ($field->title . ' [' . $field->type . ']'));
        }

        if ($this->get('show_custom'))
        {
            $options[] = JHtml::_('select.option', 'custom', '- ' . JText::_('RL_CUSTOM') . ' -');
        }

        return $options;
    }

    private function getFields(): array
    {
        if ( ! is_null(self::$fields))
        {
            return self::$fields;
        }

        $db    = RL_DB::get();
        $query = RL_DB::getQuery()
            ->select('DISTINCT a.id, a.type, a.name, a.title')
            ->from('#__fields AS a')
            ->where('a.state = 1')
            ->where('a.only_use_in_subform = 0')
            ->where(RL_DB::isNot('a.type', ['subform', 'repeatable']))
            ->order('a.title');

        $db->setQuery($query);

        self::$fields = $db->loadObjectList();

        return self::$fields;
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit