Новости 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 Гость просматривают эту тему.
  • 5 Ответов
  • 887 Просмотров
*

artemnaum

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Здравсвуйте, подскажите пожалуйста.

Чтобы не делал, вставляю в базу данных запись на русском, русские буквы отображаются вопросами.

Код
$body = $body . "<p><strong>Итого: </strong>" . number_format("15205", 0, '', ' '). " тг.</p>";
$query = $db->getQuery(true);
$columns = array('main_tel', 'body');
$values = array($db->quote($main_tel),$db->quote($body));
$query->insert($db->quoteName('#__orders'))
->columns($db->quoteName($columns))
->values(implode(',', $values));
$db->setQuery($query);
$db->execute();

- echo $body - всё нормально отображается
- после этого $body отправляется почтой, в письме всё нормально отображается
- добавляемые статьи через админку нормально читаются
- на локальном сервере всё нормально работает

Пробовал перед вставкой:
- изменить кодировку таблицы с utf-8 на cp1251
- mb_convert_encoding($body, "utf-8", "windows-1251"))
- mb_convert_encoding($body, "windows-1251", "utf-8"))
- utf8_encode($body)
- изменить кодировку самого файла с скриптом на utf-8 с бом, без бом, ansi и т.п. всё равно вставляются одни вопросы.
- установить в htaccess кодировку по умолчанию utf-8
« Последнее редактирование: 27.10.2020, 09:44:14 от artemnaum »
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Re: Вставка записи в базу данных
« Ответ #1 : 27.10.2020, 10:00:28 »
Посмотрите как выглядит сам запрос
Код: php
echo $query;
или в базу записывайте только число, а текст добавляйте в места для вывода
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

artemnaum

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Re: Вставка записи в базу данных
« Ответ #2 : 27.10.2020, 10:27:47 »
Посмотрите как выглядит сам запрос
Код: php
echo $query;
или в базу записывайте только число, а текст добавляйте в места для вывода


Сам запрос с русскими буквами. В базу только число, к сожалению не вариант записывать, потому что потом нужно будет ещё вставить фио и адрес, а они на русском
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Re: Вставка записи в базу данных
« Ответ #3 : 27.10.2020, 10:30:58 »
В базу только число, к сожалению не вариант записывать, потому что потом нужно будет ещё вставить фио и адрес, а они на русском
Ну как знаете....

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

artemnaum

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Re: Вставка записи в базу данных
« Ответ #4 : 27.10.2020, 10:47:29 »
Ну как знаете....

Какой тип для столбца body используете (посмотрите это в структуре таблицы в MySQL)

Спасибо огромное Вам. На уровне таблицы стояло сравнение utf8, а на уровне столбца что-то левое совсем, поставил на уровне столбца utf-8, всё заработало.
*

artima

  • Новичок
  • 1
  • 0 / 0
Re: Вставка записи в базу данных
« Ответ #5 : 28.10.2020, 13:06:26 »
Действительно легко играть на сайте онлайн
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Все изменения появляются в старой базе данных и ftp после смены хостинга

Автор makena0606

Ответов: 2
Просмотров: 2108
Последний ответ 09.02.2024, 10:21:47
от Vastriet
Пропала база данных в phpMyAdmin

Автор kazbec

Ответов: 3
Просмотров: 1413
Последний ответ 16.11.2023, 22:59:54
от Vastriet
Перенос отдельных таблиц из одной базы данных в другую для обновления Joomla

Автор alex-nosov1980

Ответов: 3
Просмотров: 1301
Последний ответ 13.09.2021, 08:58:55
от alex-nosov1980
Полностью запретить редактирование профиля и учётных данных

Автор vityushka

Ответов: 7
Просмотров: 1589
Последний ответ 15.02.2021, 09:20:27
от sivers
Перенос базы данных меню

Автор EvaLifeTime

Ответов: 6
Просмотров: 1258
Последний ответ 25.05.2020, 12:56:05
от EvaLifeTime