Новости Joomla

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+)

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+)

При отображении форм компонента в админке раньше разработчикам нужно было описывать скрытые поля в лейаутах. И выглядело это так:

<?php // Это файл в /layouts/components/com_component/your_layout.php ?> <input type="hidden" name="task" value=""> <input type="hidden" name="return" value="<?php echo $input->getBase64('return'); ?>"> <input type="hidden" name="forcedLanguage" value="<?php echo $input->get('forcedLanguage', '', 'cmd'); ?>"> <?php echo HTMLHelper::_('form.token'); ?>

Начиная с Joomla 5.3 добавлен новый способ добавления таких полей (их называют control fields) - программно. И теперь это можно сделать просто в Controller / View.

<?php // В Controller/View добавляем поля $this->form ->addControlField('task', '') ->addControlField('return', $input->getBase64('return', '')) ->addControlField('forcedLanguage', $forcedLanguage);

А в layout'е просто используем метод

renderControlFields()

<?php // В layout формы echo $this->form->renderControlFields();

Многие компоненты ядра уже используют этот подход. Соответствующий PR был принят в Joomla 5.3 осенью 2024г.

Смотреть Pull Request

JoomGallery 4.1.0 - компонент галереи изображений для Joomla

JoomGallery 4.1.0 - компонент галереи изображений для Joomla

Новая итерация компонента продолжает развиваться, ведь с v.4.x компонент был переписан практически с нуля.

v.4.1.0. Что нового?

Редактирование метаданных изображений. Теперь метаданные можно не только читать, но и напрямую редактировать и записывать обратно в изображение JPG. Поддерживаются данные EXIF ​​и IPTC.

Полная совместимость с Joomla! 4.x, 5.x и 6.x. Компонент почистили от устаревших методов в коде.

Заметно ускорили загрузку больших галерей. Списки в админке, особенно для очень больших галерей ( >30 000 изображений), теперь загружаются значительно быстрее.

Несколько сеток lightGallery на одной странице. Будь то плагины контента или модули изображений: теперь вы можете отображать несколько галерей или категорий на одной странице без каких-либо ограничений.

Множество мелких исправлений ошибок и оптимизаций.

Сайт проекта

GitHub расширения

Скачать

0 Пользователей и 1 Гость просматривают эту тему.
  • 6 Ответов
  • 2453 Просмотров
*

donpekc

  • Новичок
  • 3
  • 0 / 0
Всем привет. У меня есть форма, данные из нее по кнопке попадают в контроллер с заданием add
Код
function addRender()
{

    var renderName = $('.js-input-greeting').val();
    var catId = $('.js-input-greeting').val();
    var stage = $('.js-input-greeting').val();
 
  console.log('rendername:' + renderName );
 jQuery.ajax({
        url:"index.php?option=com_helloworld&task=default.add",
        type:'POST',
        data: {name : renderName},


        success:function()
       
        {
            console.log('success ajax');
        }
    });
}

Контроллер default.php в функции add() принимает Post запрос

Код
class HelloWorldControllersDefault extends JControllerLegacy
{

    public function add() {

        $app = JFactory::getApplication();
        $jinput = JFactory::getApplication()->input;

        $rdata = $jinput->post->get('name', '');


        $model = $this->getModel('add', 'add') ;

        $model->setState('name', $rdata);



           
    }

В модель add.php отправляет состояние с данными из post запроса. Модель получает состояние и записывает данные в таблицу __helloworld в колонку greeting
Код
class HelloWorldModelAdd extends JModelItem
{



public function store(){

$rdata = $this->getState('name');
        $db = JFactory::getDbo();       
$query = $db->getQuery(true);


$query
    ->insert($db->quoteName('#__helloworld'))
    ->columns('greeting')
    ->values($rdata);

$db->setQuery($query);
$db->execute();
}
}

Только что-то в базе ничего не происходит. Мне кажется я поплыл на моменте передачи данных в модель, а может вообще поплыл с момента отправки данных AJAX в контроллер. Помогите пожалуйста, бьюсь с этим уже третий день. Форум весь облазил, много интересного нашел, но все равно данные не добавляются
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
А у тебя выполняется функция store?
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

Aleks.Denezh

  • Живу я здесь
  • 3404
  • 428 / 4
Потому что вы
1. неправильно получаете модель:
2. Зачем то устанавливаете состояние модели
3. Не вызываете метод store

Контроллер
Код: php
public function add() {
  $model = $this->getModel('add', 'HelloWorldModel') ;
  $model->store($this->input->post->get('name'));
}

Модель:

Код: php
public function store($name){
$query = $this->getDbo()->getQuery(true)
->insert($db->quoteName('#__helloworld'))
->columns('greeting')
->values($name);
$this->getDbo()->setQuery($query)->execute();
}
« Последнее редактирование: 23.04.2017, 18:37:39 от Aleks.Denezh »
*

donpekc

  • Новичок
  • 3
  • 0 / 0
Потому что вы
1. неправильно получаете модель:
2. Зачем то устанавливаете состояние модели
3. Не вызываете метод store

Контроллер
Код: php
public function add() {
  $model = $this->getModel('add', 'HelloWorldModel') ;
  $model->store($this->input->post->get('name'));
}

Модель:

Код: php
public function store($name){
$query = $this->getDbo()->getQuery(true)
->insert($db->quoteName('#__helloworld'))
->columns('greeting')
->values($name);
$this->getDbo()->setQuery($query)->execute();
}


Спасибо! но что-то зараза все равно не выполняется.. Как проверить вообще срабатывает ли контроллер к которому я обращаюсь через task=controller_name.task_name
*

Aleks.Denezh

  • Живу я здесь
  • 3404
  • 428 / 4
вбиваете в строке браузера: ваш_сайт/index.php?option=com_helloworld&task=default.add и смотрите что выдаст.. можете расставить echo в контроллерах что бы посмотреть срабатывает что то или нет!
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
*

donpekc

  • Новичок
  • 3
  • 0 / 0
HelloWorldControllersDefault - ошибка в названии класса. HelloWorldControllerDefault правильно.

Спасибо! в этом была проблема, теперь мне пишет, что Column count doesn't match value count at row 1 SQL=INSERT INTO . Но это уже прогресс, значит модель срабатывает, видно я в sql запросе накосячил

Всем огромное спасибо! Теперь все получилось и работает! Я даже не верю, что это сделал, зато теперь хоть немного понимаю, как делать свой компонент. Ошибку в INSERT запросе исправил и дополнил данными. Сделал, как написано в документации Joomla, если кому понадобится то вот тут https://docs.joomla.org/Inserting,_Updating_and_Removing_data_using_JDatabase

Код
$columns = array('greeting', 'catid', 'stage', 'created', 'render_intro');
$values = array($db->quote($name), $db->quote($catid), $db->quote($stage), $db->quote($date), $db->quote($path));
  $query = $this->getDbo()->getQuery(true);
$query->insert($db->quoteName('#__helloworld'))
->columns($db->quoteName($columns))
->values(implode(',', $values));
$this->getDbo()->setQuery($query)->execute();

Теперь все работает. Спасибо еще раз
« Последнее редактирование: 24.04.2017, 14:08:47 от donpekc »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Отправка файлов через ajax в модуль Joomla

Автор hemicide

Ответов: 19
Просмотров: 1868
Последний ответ 11.04.2022, 08:44:33
от sivers
Применение ajax (Аякс) в модуле Joomla

Автор tm2010

Ответов: 34
Просмотров: 4905
Последний ответ 26.09.2020, 09:38:35
от b2z
ajax проверку на вход. В стандартном модуле входа?

Автор Dolphin4ik_1

Ответов: 4
Просмотров: 708
Последний ответ 23.07.2020, 15:03:57
от sivers
Обработка AJAX в компоненте Joomla!3

Автор balancer

Ответов: 33
Просмотров: 11402
Последний ответ 23.07.2020, 07:45:53
от Dolphin4ik_1
Модель для представления, которое показывает списки данных разных типов

Автор borro

Ответов: 27
Просмотров: 1221
Последний ответ 06.05.2020, 11:57:12
от Septdir