Новости Joomla

Свои типы полей в 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 для атрибута addfieldprefixnamespace 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 #разработка

Обновлена информация в Плане развития Joomla

👩‍💻 Обновлена информация в Плане развития Joomla.Здесь собрана информация о датах релизов, описаны принципы версионирования, указаны ответственные за релизы, а так же даты окончания поддержки релизов. Опираясь на эту информацию вы можете планировать развитие ваших интернет-проектов.👩‍💻 Что нового?⛔️ Joomla 4.Дата окончания исправления ошибок безопасности в версии 4.x - 14 октября 2025г. ⚠️ После этой даты Joomla 4 прекратит получать какие-либо обновления, в том числе безопасности - вообще. Рекомендуем обновить ваши сайты до актуальной Joomla 5.✅ Joomla 5.- Дата окончания исправления ошибок в версии 5.x - 13 октября 2026г.- Дата окончания исправления ошибок безопасности в версии 5.x - 12 октября 2027 года.- Текущая актуальная (на момент написания заметки) версия - 5.3.1.- Опубликовано расписание выхода релизов Joomla 5.4. Стабильный релиз ожидается 14 октября 2025 года.✅ Joomla 6.- Дата окончания исправления ошибок в версии 6.x - 17 октября 2028г.- Дата окончания исправления ошибок безопасности в версии 6.x - 16 октября 2029г.- Опубликовано расписание выхода релизов Joomla 6.0. Стабильный релиз ожидается 14 октября 2025 года.- Для разработчиков уже доступна Joomla 6.0.0-alpha1.✅ Joomla! Framework.Обновлена информация о Joomla! Framework - полноценном PHP-фреймворке для разработки. Он в версиях 1.х и 2.х был самостоятельным параллельным проектом, однако начиная с версии Joomla 4.0 стал её основой. Добавлена информация о Joomla! Framework 3.x, который вышел 6 октября 2023 года. Его можно использовать в тех случаях, когда вам в проекте не нужна CMS Joomla целиком.Подробнее на сайте Joomla-сообщества Joomlaportal.ru#joomla #community

Компания JetBrains рассказала о своей поддержке Joomla

Компания JetBrains рассказала о своей поддержке Joomla

JetBrains - один из мировых лидеров в разработке программного обеспечения для разработчиков. Её программные продукты - это IDE - профессиональные среды разработки, которые отличаются от простого блокнота/редактора с плагинами набором всевозможных инструментов для разработчиков, глубоким анализом кодовой базы, подсказками по ней и по языку программирования, отладкой ошибок и многим-многим другим. Одним из самых известных продуктов компании является IDE PHP Storm, который можно назвать отраслевым стандартом PHP-разработчика.

В статье How PhpStorm Helps Maintain PHP Open-Source Projects: Interviews and Real-World Examples в блоге компании описываются Open Source проекты, которым JetBrains оказывает поддержку (это могут быть бесплатные лицензии для разработчиков для некоммерческих проектов).

В список попали:

  • PHPUnit - фреймворк для unit-тестирования в PHP
  • Doctrine DBAL - библиотека для PHP, которая предоставляет лёгкий и гибкий слой для коммуникации с базой данных. Она поддерживает различные базы данных через единый и согласованный API.
  • CodeIgniter — популярный MVC-фреймворк для разработки на PHP
  • Joomla! - наша любимая CMS.

Эти названия (кроме "Joomla") чаще всего не слышат вебмастера и разработчики обычных сайтов и интернет-магазинов. Но эти названия хорошо знакомы PHP-разработчикам, которые создают сложные и высоконагруженные проекты и микросервисы. То, что Joomla оказалась в одном ряду с такими программными инструментами - делает ей честь.

🙏 За ссылку спасибо участнику нашего сообщества Ринату Кажетову (@rkazhet).

Подпишитесь на @joomlafeed

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

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Здравствуйте! )
Проблема такая:
На Joomla!3 Сделал сайт. Делал сразу на хостинге. Всё работало отлично до недавних пор. Пару дней назад зашел на свой сайт и мне пишет: "Error displaying the error page: Application Instantiation Error". Данное сообщение выходит и при входе на сайт и при входе в панель управления. Не могу понять с чего это. Перед этим я пытался вставить на сайт погодный информер от Гисметео, но навряд-ли это имеет значение, поскольку я это делал через создание новой статьи и последующим вставкой его в виде модуля в отдельной позиции (встало криво).
Как сделать, чтобы опять всё заработало?

P.S. В создании сайтов я лол. Это мой первый опыт в этом деле. Поэтому буду рад более-менее подробным объяснениям и советам, а также ссылкам на материалы, которые помогут мне решить мою проблему. Спасибо.
« Последнее редактирование: 26.06.2013, 11:57:18 от b2z »
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Сначала спросите у хостера не делал ли он что-то на хостинге.
Особенно в плане работы базы данных MySQL
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Такой вопрос отсылал, но ответа не получил...
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Наберите в Поиске на форуме фразу "Application Instantiation Error" и почитайте варианты.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Это я тоже сделал - ничего не подошло, поэтому и решил создать новую тему.  
« Последнее редактирование: 18.06.2013, 09:35:18 от VicNG »
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Поиск в Google по вашим данным так же говорит о том, что скорее всего проблемы с базой данных, в частности с правами пользователя базы.
Так что копайте в этом направлении.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
в файле configuration.php в полях

public $user = '****';
public $password = ****'';
public $db = ****'

тоже всё нормально...
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Кстати, в configurstion.php  в поле "public $host" пишет   "= 'localhost';"

public $host = 'localhost';

Это нормально? При условии, что сайт находиться на хосте и в локальной версии никогда не делался?
*

SDKiller

  • Живу я здесь
  • 2706
  • 329 / 5
  • ...ergo sum
public $host = 'localhost';
Это нормально? При условии, что сайт находиться на хосте и в локальной версии никогда не делался?

Зависит от хостинга - где-то мускул на localhost, где-то может быть на отдельном сервере.
В таком случае вам у вас в данных аккаунта должна быть эта информация, что-то вроде

Цитировать
сервер:       mysql38.1gb.ru
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Вот ещё. При проверке базы данных MySQL выдает

"Error    : Table '****' doesn't exist
status   : Operation failed".

И это во всех строчках.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #10 : 18.06.2013, 09:52:33 »
В "Управление привилегиями пользователей" стоит галочка на "ALL PRIVILEGES".
*

SDKiller

  • Живу я здесь
  • 2706
  • 329 / 5
  • ...ergo sum
Re: Error displaying the error page: Application Instantiation Error
« Ответ #11 : 18.06.2013, 10:00:32 »
Так
"Error    : Table '****' doesn't exist

Так у вас реально звёздочки в конфиге?
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #12 : 18.06.2013, 10:11:13 »
Так
Так у вас реально звёздочки в конфиге?
Хотел задать такой же вопрос
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #13 : 18.06.2013, 10:16:30 »
Не ) это я хотел обозначить, что во всех строчках так )
*

SDKiller

  • Живу я здесь
  • 2706
  • 329 / 5
  • ...ergo sum
Re: Error displaying the error page: Application Instantiation Error
« Ответ #14 : 18.06.2013, 10:21:50 »
Ну зайдите в phpMyAdmin да посмотрите - существует вообще база и таблицы в ней
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #15 : 18.06.2013, 10:22:05 »
Попросите у хостера старый бэкап базы данных и залейте его.
У правильного хостера такой бэкап имеется.
Или сами гляньте свою файловую структуру и поищите файл бэкапа в папках типа backup
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #16 : 18.06.2013, 10:31:49 »
В phpMyAdmin база существует. Вроде нормально всё. Файла бэкапа не нашел, хостер до сих пор молчит.
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #17 : 18.06.2013, 10:55:32 »
В phpMyAdmin база существует. Вроде нормально всё. Файла бэкапа не нашел, хостер до сих пор молчит.
Но как же всё нормально, если вы написали
Цитировать
"Error    : Table '****' doesn't exist
Что за таблица?
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #18 : 19.06.2013, 09:45:13 »
Но как же всё нормально, если вы написали Что за таблица?

Это в базе данных MySQL.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #19 : 26.06.2013, 10:29:26 »
Всем спасибо, всё разрешилось! ) Хостер по запросу сделал бэкап.)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] Вывод значений из custom fields материала в модуле по имени поля

Автор goga_pgasovav

Ответов: 3
Просмотров: 963
Последний ответ 30.12.2024, 13:22:11
от goga_pgasovav
[Решено] Получить category description image в index.php шаблона

Автор goga_pgasovav

Ответов: 6
Просмотров: 1005
Последний ответ 12.07.2024, 17:06:14
от goga_pgasovav
[Решено] Перестали работать переходы по меню сайта

Автор AlexP750

Ответов: 12
Просмотров: 1606
Последний ответ 06.02.2024, 12:42:26
от AlexP750
[Решено] Ссылка на домен и текущий шаблон в блоге категории

Автор goga_pgasovav

Ответов: 2
Просмотров: 721
Последний ответ 06.03.2023, 16:30:23
от goga_pgasovav
[Решено] Не добавляется CSS-класс страницы

Автор Strelok760

Ответов: 16
Просмотров: 1687
Последний ответ 02.03.2023, 16:14:47
от Танита Сар