| Server IP : 54.36.91.62 / Your IP : 216.73.217.112 Web Server : Apache System : Linux webm013.cluster127.gra.hosting.ovh.net 5.15.206-ovh-vps-grsec-zfs-classid #1 SMP Fri May 15 02:41:25 UTC 2026 x86_64 User : coopiak ( 151928) PHP Version : 8.3.23 Disable Function : _dyuweyrj4,_dyuweyrj4r,dl MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/coopiak/amisdesseniors-fr/nice/components/com_djcatalog2/views/itemform/ |
Upload File : |
<?php
/**
* @package DJ-Catalog2
* @copyright Copyright (C) DJ-Extensions.com, All rights reserved.
* @license http://www.gnu.org/licenses GNU/GPL
* @author url: http://dj-extensions.com
* @author email contact@dj-extensions.com
*/
defined('_JEXEC') or die;
use Joomla\CMS\MVC\View\HtmlView;
use Joomla\CMS\Factory;
use Joomla\CMS\Language\Text;
jimport('joomla.application.component.view');
class Djcatalog2ViewItemform extends HtmlView {
protected $itemId;
protected $groupId;
public function display($tpl = null)
{
$app = Factory::getApplication();
$this->itemId = (int)$app->input->getInt('itemId',0);
$groupIds = $app->input->getString('groupId','');
$groupIds = explode(',',$groupIds);
if (!empty($groupIds)) {
Joomla\Utilities\ArrayHelper::toInteger($groupIds);
$groupIds = array_unique($groupIds);
foreach($groupIds as $k=>$v) {
if ($v === '' || (int)$v == 0) {
unset($groupIds[$k]);
}
}
}
$groupIds[] = 0;
$this->groupId = $groupIds;
$db = Factory::getDbo();
if (!empty($this->groupId)){
$query = $db->getQuery(true);
$query->select('f.*');
$query->from('#__djc2_items_extra_fields AS f');
$query->select('CASE '
.'WHEN (f.type=\'text\' OR f.type=\'textarea\' OR f.type=\'html\') '
.'THEN vt.value '
.'WHEN (f.type=\'calendar\') '
.'THEN vd.value '
.'WHEN (f.type=\'checkbox\' OR f.type=\'select\' OR f.type=\'bool\' OR f.type=\'multiselect\' OR f.type=\'radio\' OR f.type=\'color\' OR f.type=\'multicolor\') '
.'THEN GROUP_CONCAT(vi.value SEPARATOR \'|\')'
.'ELSE "" END AS field_value');
$query->join('LEFT','#__djc2_items_extra_fields_values_text AS vt ON f.id=vt.field_id AND vt.item_id='.(int)$this->itemId);
$query->join('LEFT','#__djc2_items_extra_fields_values_int AS vi ON f.id=vi.field_id AND vi.item_id='.(int)$this->itemId);
$query->join('LEFT','#__djc2_items_extra_fields_values_date AS vd ON f.id=vd.field_id AND vd.item_id='.(int)$this->itemId);
//$query->where('f.group_id='.(int)$this->groupId.' OR f.group_id=0');
$query->where('f.group_id IN ('.implode(',', $this->groupId).')');
$query->group('f.id');
$query->order('f.group_id asc, f.ordering asc');
//echo str_replace('#_', 'jos', (string)$query);die();
$db->setQuery($query);
$this->fields = ($db->loadObjectList('id'));
if (count($this->fields)) {
$fieldIds = array_keys($this->fields);
$db->setQuery('SELECT * FROM #__djc2_items_extra_fields_options WHERE field_id IN ('.implode(',', $fieldIds).') ORDER BY field_id ASC, ordering ASC');
$optionList = $db->loadObjectList();
foreach($this->fields as $field_id => $field) {
foreach ($optionList as $optionRow) {
if ($optionRow->field_id == $field_id) {
if (empty($field->optionlist)) {
$this->fields[$field_id]->optionlist = array();
}
$this->fields[$field_id]->optionlist[] = $optionRow;
}
}
}
} else {
echo Text::_('COM_DJCATALOG2_NO_FIELDS_IN_GROUP');
return;
}
} else {
//echo Text::_('COM_DJCATALOG2_CHOOSE_FIELDGROUP_FIRST');
return;
}
parent::display($tpl);
}
}
?>