Your IP : 216.73.216.65


Current Path : /home/ataenra/www/libraries/regularlabs/src/Form/Field/
Upload File :
Current File : /home/ataenra/www/libraries/regularlabs/src/Form/Field/UserGroupsField.php

<?php
/**
 * @package         Regular Labs Library
 * @version         23.12.1338
 * 
 * @author          Peter van Westen <info@regularlabs.com>
 * @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 RegularLabs\Library\DB as RL_DB;
use RegularLabs\Library\Form\FormField as RL_FormField;

class UserGroupsField extends RL_FormField
{
    static      $options;
    public bool $is_select_list  = true;
    public bool $use_tree_select = true;

    //    public bool $use_ajax        = true;

    public function getNamesByIds(array $values, array $attributes): array
    {
        $query = $this->db->getQuery(true)
            ->select('a.title')
            ->from('#__usergroups AS a')
            ->where(RL_DB::is('a.id', $values))
            ->order('a.lft ASC');

        $this->db->setQuery($query);

        return $this->db->loadColumn();
    }

    protected function getOptions()
    {
        if ( ! empty(self::$options))
        {
            return self::$options;
        }

        $query = $this->db->getQuery(true)
            ->select('a.id as value, a.title as text, a.parent_id AS parent')
            ->from('#__usergroups AS a')
            ->select('COUNT(DISTINCT b.id) AS level')
            ->join('LEFT', '#__usergroups AS b ON a.lft > b.lft AND a.rgt < b.rgt')
            ->group('a.id')
            ->order('a.lft ASC');
        $this->db->setQuery($query);

        self::$options = $this->db->loadObjectList();

        return self::$options;
    }
}