Новости Joomla

Свои типы полей в Joomla.

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

Это большая тема, о которой можно говорить очень много. Самое главное, что возможности применения ограничиваются только вашей больной фантазией. Вы строите интерфейс своего модуля или плагина и вам нужно подтянуть данные из сторонней системы (список чего-нибудь по какому-нибудь API), чтобы сохранить выбранный id в Joomla. Или сделать какую-то проверку и в зависимости от неё показать то или иное сообщение пользователю. Для этого подойдут свои пользовательские типы полей. Интерфейс Joomla по большей части описан в XML-файлах. У каждого из них свои параметры. Некоторые не описаны в документации (manual.joomla.org), поэтому самым любопытным будет полезно заглянуть в собственно файлы фреймворка по пути

libraries/src/Form/FormField.php, а так же в
libraries/src/Form/Fields. У каждого класса поля перечислены его специфические свойства, которые можно описывать в XML. А в своём типе поля вы можете устанавливать эти значения программно. В моём модуле WT Quick links под капотом происходят изменения. Теперь для работы (в админке) ему нужен вспомогательный плагин. А в самом модуле нам бы проверить, а не выключен ли он? В Joomla есть тип поля Note - заметка. Его можно использовать для вывода примечаний.

<field type="note" name="your_note_for_user" label="Заголовок примечания" title="Альтернативный способ для заголовка" description="Текст примечания" class="col-12 alert alert-info" heading="h1" close="true" />

heading - указывать уровень заголовка.
close - позволяет закрыть это примечание. В классе поля
libraries/src/Form/Field/NoteField.php описана логика вывода. И в принципе оно нам подходит для нашей задачи. Но оно будет выводить сообщение всегда, а нам нужно только тогда, когда плагин отключён. Поэтому берём и создаём свой класс поля, который мы унаследуем от
NoteField. Это значит, что у нас в руках будет весь инструментарий стандартного поля
Note + то, что мы сами добавим. В XML-манифест добавляем наше поле

<field type="systempluginstatus" name="systempluginstatus" addfieldprefix="Joomla\Module\Wtquicklinks\Site\Fields"/>

-

type - имя файла и класса,-
addfieldprefix - указываем namespace к нашему классу, может быть любой нам нужный-
name - нельзя полю без имени...Это означает, что Joomla будет использовать класс поля из файла
modules/mod_wt_quick_links/src/Fields/SystempluginstatusField.php.А в классе поля будет написано следующее:

<?php // namespace для атрибута addfieldprefix namespace Joomla\Module\Wtquicklinks\Site\Fields; // нельзя напрямую обращаться к этому файлу defined('_JEXEC') or die; // подключаем родительский класс для переопределения use Joomla\CMS\Form\Field\NoteField; use Joomla\CMS\Language\Text; use Joomla\CMS\Plugin\PluginHelper; // имя класса и имя файла точь-в-точь class SystempluginstatusField extends NoteField { protected $type = 'Systempluginstatus'; protected function getLabel() { // если плагин не включён if(PluginHelper::isEnabled('system','wtquicklinks')) { // меняем свойства родительского класса $this->class = 'alert alert-danger w-100'; $this->element['label'] = '⚠️ А-а-а-а!'; $this->element['description'] = 'Плагин не включён!!'; // и просто рендерим его с нашими свойствами return parent::getLabel(); } // А иначе всё хорошо, скрываем поле из виду. $this->parentclass = 'd-none'; return ''; } }

Просто и удобно. И людям приятно, что о них позаботились и рассказали почему что-то не работает. @webtolkru#joomla #php #webdev #разработка

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

Ishti39

  • Захожу иногда
  • 152
  • 8 / 1
 Уважаемые Форумчане и гуру, подскажите, как правильно сделать запрос в бд Аdsmanager 2.9.13.Суть в том, что я сделал в Аdsmanagerе, чтобы объявления делались вип по этой теме http://joomlaforum.ru/index.php/topic,266590.0.html , в одной теме нашёл, как через прямой запрос к бд поднять объявление вверх, он выглядит так:
Спойлер
[свернуть]
в этом запросе обновляется дата объявления и естественно оно поднимается вверх.Вопрос и просьба, как в этот запрос вставить, чтоб ещё и значение поля vip c 0 заменялось на 1? :( Плюсик в репу гарантирую.
« Последнее редактирование: 23.12.2015, 21:59:54 от Ishti39 »
*

Grendy

  • Захожу иногда
  • 247
  • 26 / 0
Что это за уродство? Для таких задач существуют контроллеры и модели!

Если у вас уже есть объект объявления, незачем инсёртить, просто обновляйте в базе существующую строку! Вместо

Код
$query = 'INSERT into beqpm_adsmanager_ads' . ' SET id = ' . $id . ',  date_created = "'.$newdate.'" ON DUPLICATE KEY UPDATE  date_created = "'.$newdate.'"';

Пишите

Код
$query = "UPDATE `beqpm_adsmanager_ads` SET `date_created` = '$newdate', `vip` = 1 WHERE `id` = $id";
Плюс в репутацию больше говорит о благодарности, чем слово "Спасибо" в теме, которую повторно, возможно, никогда уже не посетишь.
*

Ishti39

  • Захожу иногда
  • 152
  • 8 / 1
Что это за уродство? Для таких задач существуют контроллеры и модели!

Если у вас уже есть объект объявления, незачем инсёртить, просто обновляйте в базе существующую строку! Вместо

Код
$query = 'INSERT into beqpm_adsmanager_ads' . ' SET id = ' . $id . ',  date_created = "'.$newdate.'" ON DUPLICATE KEY UPDATE  date_created = "'.$newdate.'"';

Пишите

Код
$query = "UPDATE `beqpm_adsmanager_ads` SET `date_created` = '$newdate', `vip` = 1 WHERE `id` = $id";
Заменил по вашему исправлению запроса, получилось так
Спойлер
[свернуть]
но почему то не срабатывает, и дата не меняеться и объявление не становиться випом :( хотя кнопочка появилась,в том запросе дата изменялась
« Последнее редактирование: 17.12.2015, 21:05:03 от Ishti39 »
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Интересно SQL запрос выполняется правильно? И что вы хотите побиться с помощью его??
Я бы его не так прописал... И поместил в форму не только кнопку, но все содержимое страницы...

Я бы подсказал как правильно это сделать, но у меня нет возможности проверить..
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

Ishti39

  • Захожу иногда
  • 152
  • 8 / 1
Интересно SQL запрос выполняется правильно? И что вы хотите побиться с помощью его??
Я бы его не так прописал... И поместил в форму не только кнопку, но все содержимое страницы...

Я бы подсказал как правильно это сделать, но у меня нет возможности проверить..
первый запрос он дату объявления обновлял, ну и таким методом пользователь может поднять объявление в топ, а про этот запрос, пользователь нажимает на кнопку и делает своё объявление вип и дата тоже должна обновляться, не обязательно всё в целую страницу помещать в пост, я этот запрос вставляю в майадс, кнопочка появляеться рядом с кнопками Обновить и Удалить
*

Ishti39

  • Захожу иногда
  • 152
  • 8 / 1
Интересно SQL запрос выполняется правильно?
первый запрос нормально выполнялся, дата обновляется
*

Ishti39

  • Захожу иногда
  • 152
  • 8 / 1
Я бы подсказал как правильно это сделать, но у меня нет возможности проверить..
Напишите как вы считаете нужно, я проверю у себя, сайт пока локально на денвере ещё делаю
*

Grendy

  • Захожу иногда
  • 247
  • 26 / 0
Окей! Допишите обновление ячейки vip в найденное на форуме безобразие.

Вместо

Код
$query = 'INSERT into beqpm_adsmanager_ads' . ' SET id = ' . $id . ',  date_created = "'.$newdate.'" ON DUPLICATE KEY UPDATE  date_created = "'.$newdate.'"';

получится

Код
$query = 'INSERT into beqpm_adsmanager_ads' . ' SET id = ' . $id . ',  date_created = "'.$newdate.'" ON DUPLICATE KEY UPDATE  date_created = "'.$newdate.'", vip = "1"';
Плюс в репутацию больше говорит о благодарности, чем слово "Спасибо" в теме, которую повторно, возможно, никогда уже не посетишь.
*

Ishti39

  • Захожу иногда
  • 152
  • 8 / 1
Окей! Допишите обновление ячейки vip в найденное на форуме безобразие.

Вместо

Код
$query = 'INSERT into beqpm_adsmanager_ads' . ' SET id = ' . $id . ',  date_created = "'.$newdate.'" ON DUPLICATE KEY UPDATE  date_created = "'.$newdate.'"';

получится

Код
$query = 'INSERT into beqpm_adsmanager_ads' . ' SET id = ' . $id . ',  date_created = "'.$newdate.'" ON DUPLICATE KEY UPDATE  date_created = "'.$newdate.'", vip = "1"';
не хочет не дату обновлять, не випом сделать  :(   

Всё разобрался,надо было его с $id= $this->content->id; в подробный вид объявления поместить,там объявление через этот запрос делается випом и дата обновляется, + в репу поставил :).Но тут ещё вот одна проблема с $id= $content->id в list(в списке)фигня происходит,захожу в мои объявления,нажимаю "Сделать VIP" и почему то сколько там есть моих объявлений,то они все одновременно делаются випом  :(   подскажите в чём может быть дело? вот такой код вставляю
<?php
if($_POST){
$id= $content->id;//Id объявления /Детальный вид: $this->content->id/ /Список: $content->id/
$newdate = date("Y-m-d H:i:s"); //Получаем текущие дату и время
$db = JFactory::getDbo();
$query = "UPDATE `beqpm_adsmanager_ads` SET `date_created` = '$newdate', `vip` = 1 WHERE `id` = $id";
$db->setQuery($query);
$db->query();
}
  ?>
<form method="post">
   <input type="submit" name="newdate" value="Сделать VIP">
</form>
« Последнее редактирование: 19.12.2015, 01:28:36 от Ishti39 »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено]Дублирования ссылки "объвления" в breadcrumb, в компоненте AdsManager

Автор nicklas

Ответов: 4
Просмотров: 3361
Последний ответ 25.04.2024, 23:13:18
от Rinat abzyi
Вывод данных

Автор FlexNL

Ответов: 0
Просмотров: 2386
Последний ответ 06.11.2021, 12:37:54
от FlexNL
[Решено] Похожие объявления в AdsManager 2.9.13

Автор Ishti39

Ответов: 17
Просмотров: 5065
Последний ответ 06.06.2017, 22:08:18
от gremeru777
[Решено] IP адрес разместившего объявление в ADS 2.5 Как ?

Автор semo777

Ответов: 20
Просмотров: 5077
Последний ответ 15.03.2017, 22:22:15
от lustoff
(решено) re captcha не работала на AdsManager

Автор zvi

Ответов: 3
Просмотров: 2633
Последний ответ 10.01.2017, 08:41:57
от svoyak70