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

sir-bakh

  • Новичок
  • 6
  • 0 / 0
Я на форуме поискал, не нащел  ответ.
Сильно не пинайте пожалуйста добрые люди.
Сделал сайт на Joomla 2.5. Сайт работал нормально. Я его дорабатывал.
Надо было создать ещё сайт, создал в phpMyAdmin новый data base, дал привилегии и после этого ни сайт(первый) ни MySQL не работает. при переходе по ссылке localhost/tools/phpmyadmin/ мне выдаётся сообщение

phpMyAdmin попытался соединиться с сервером MySQL, но сервер отверг соединение. Проверьте имя хоста, пользователя и пароль в config.inc.php.
                   |_ #1130 - Host 'localhost' is not allowed to connect to this MySQL server


не могу ничего сделать, а сайт выдаёт сообщение

"Database connection error (2): Could not connect to MySQL."

банальный вопрос что делать, учитывая что я не шарю в программировании? :(
ну вот сам собственно  config в полной красе. стоит "root" пользователь, что ещё хочет?
Спойлер
[свернуть]
« Последнее редактирование: 27.12.2012, 02:44:18 от sir-bakh »
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
А зачем надо было лезть в базу данных, чтоб установить еще один движок Joomla?
Когда работаете на Денвере, это не надо делать, т.к. нужная база создается при инсталляции движка при вводе имени базы данных.
Попробуйте переустановить Денвер, но сначала сделайте бэкап созданного сайта:
1. Найдите файловую структуру сайта и сделайте копию.
Это папка в каталоге c:\WebServers\home
2. Найдите файлы базы данных сайта и сделайте копию.
Это папка в каталоге c:\WebServers\usr\local\mysql-5.1\data

Когда переставите Денвер, то скопируйте назад бэкапы и сделайте рестарт Денвера.
Все должно заработать.
*

sir-bakh

  • Новичок
  • 6
  • 0 / 0
Спойлер
[свернуть]

Когда переставите Денвер, то скопируйте назад бэкапы и сделайте рестарт Денвера.
Все должно заработать. "Database connection error (2): Could not connect to MySQL."



Заработал phpMyAdmin, видится база данных. но сайт выдаёт то же сообщение
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Если при запуске сайта выводится сообщение, типа "Database connection error (2): Could not connect to MySQL.", значит неправильно подключаетесь к базе этого сайта.
Смотрите файл configuration.php
В нем прописаны название базы, префикс таблицы, имя и пароль пользователя базы.
Если работаете на Денвере, то имя пользователя базы "root" и без пароля.
*

sir-bakh

  • Новичок
  • 6
  • 0 / 0
Если при запуске сайта выводится сообщение, типа "Database connection error (2): Could not connect to MySQL.", значит неправильно подключаетесь к базе этого сайта.
Смотрите файл configuration.php
В нем прописаны название базы, префикс таблицы, имя и пароль пользователя базы.
Если работаете на Денвере, то имя пользователя базы "root" и без пароля.
ну да, так и есть вот config

$cfg['Servers'][$i]['auth_type']     = 'config';    // Authentication method (config, http or cookie based)?
$cfg['Servers'][$i]['user']          = 'root';      // MySQL user
$cfg['Servers'][$i]['password']      = '';          // MySQL password (only needed


но не может всёравно подключится.
*

Lex

  • Завсегдатай
  • 1615
  • 274 / 1
$cfg['Servers'][$i]['host'] = 'localhost';
замени на
$cfg['Servers'][$i]['host'] = '127.0.0.1';
Жизнь заставила учиться.
В личке на вопросы не отвечаю.
*

sir-bakh

  • Новичок
  • 6
  • 0 / 0
$cfg['Servers'][$i]['host'] = 'localhost';
замени на
$cfg['Servers'][$i]['host'] = '127.0.0.1';
я обновил  PHP до 5.3.13, у меня сейчас поменялся config.inc.php.
почему-то уже прописано "127.0.0.1" вместо "localhost", а проблема осталась та же.
у меня мозг ща лопнет :) с этим confog-ом.
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
sir-bakh, читайте внимательно, что Вам пишу.
Если у Вас MySQL работает, т.е. phpMyAdmin открывает базу, а при открытии сайта появляется ошибка "Database connection error (2): Could not connect to MySQL", то смотреть надо не файл config.inc.php, а файл configuration.php, который находится в корне сайта.
А в этом файле в первую очередь эти параметры:
public $host = 'localhost';
public $user = 'root';
public $password = '';
public $db = 'имя вашей базы';
public $dbprefix = 'префикс таблиц вашей базы;
*

sir-bakh

  • Новичок
  • 6
  • 0 / 0
sir-bakh, читайте внимательно, что Вам пишу.
Если у Вас MySQL работает, т.е. phpMyAdmin открывает базу, а при открытии сайта появляется ошибка "Database connection error (2): Could not connect to MySQL", то смотреть надо не файл config.inc.php, а файл configuration.php, который находится в корне сайта.

А в этом файле в первую очередь эти параметры:
public $host = 'localhost';
public $user = 'root';
public $password = '';
public $db = 'имя вашей базы';
public $dbprefix = 'префикс таблиц вашей базы;
Cпасибо за ответ SK
У меня всё прописано. При открытии "configuration.php" всё на месте оказалось. Но сайт всё равно  выдаёт то же самое.
Думал префикс не тот после переуставновки Denwer, нет с преффиксом всё в порядке.

public $dbtype = 'mysqli';
          public $host = 'localhost';
          public $user = '*****';
          public $password = '*********';
          public $db = '*****';
          public $dbprefix = 'oon3c_';


кстати, часть преффикса  идёт по "oon3c" а часть "r74lh"

Структура oon3c_weblinks
Структура oon3c_widgetkit_widget
Структура r74lh_assets
Структура r74lh_...


Это нормально?
« Последнее редактирование: 28.12.2012, 12:59:47 от sir-bakh »
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Cпасибо за ответ SK
У меня всё прописано. При открытии "configuration.php" всё на месте оказалось. Но сайт всё равно  выдаёт то же самое.
Думал префикс не тот после переуставновки Denwer, нет с преффиксом всё в порядке.
кстати, часть преффикса  идёт по "oon3c" а часть "r74lh"

Структура oon3c_weblinks
Структура oon3c_widgetkit_widget
Структура r74lh_assets
Структура r74lh_...


Это нормально?
Это не нормально.
Что-то Вы намудрили.
Один сайт на Joomla - один префикс.
Видимо при установке второго сайта умудрились указать имя той базы, на которой делали основной сайт.
Честно говоря, теперь не понятно как Вам помочь на словах.
Надо смотреть таблицы и т.д.
Если сайт так дорог, то ищите более опытного человека.
Не найдете, обращайтесь в коммерческий раздел этого форума.

Кстати, если сделали именно так, то второй сайт должен открываться.
*

sir-bakh

  • Новичок
  • 6
  • 0 / 0
Это не нормально.
Что-то Вы намудрили.
Один сайт на Joomla - один префикс.
Видимо при установке второго сайта умудрились указать имя той базы, на которой делали основной сайт.
Честно говоря, теперь не понятно как Вам помочь на словах.
Надо смотреть таблицы и т.д.
Если сайт так дорог, то ищите более опытного человека.
Не найдете, обращайтесь в коммерческий раздел этого форума.

Кстати, если сделали именно так, то второй сайт должен открываться.
2 сайт я только начал устанавливать, в смысле Joomla начал устанавливать, ну пришло время создавать и указывать data base, от сюда и начались проблемы.
Ну, придётся заново делать сайт :(
Во всяком случае спасибо Lex и SK что попытались помочь. можете тему закрывать.  Да благословит вас Бил Гейтс и Марк Цукерберг :)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Получение кол-во записей в таблице MySQL

Автор motokraft

Ответов: 17
Просмотров: 2235
Последний ответ 31.10.2019, 18:36:37
от rsn
Ошибка 500 Internal Server Error. Что это такое и как это решить

Автор sargiusz

Ответов: 2
Просмотров: 1080
Последний ответ 20.03.2017, 12:12:47
от Septdir
Ошибка на сайте и MySQL 500

Автор Shadiw

Ответов: 8
Просмотров: 1066
Последний ответ 15.03.2017, 22:39:44
от Shadiw
При вхоже на сайт Fatal error: Allowed memory size

Автор kz.mamaev

Ответов: 1
Просмотров: 1111
Последний ответ 04.06.2016, 13:41:07
от draff
Как загрузить сайт из бэкапа на localhost?

Автор TrueArsenalFan

Ответов: 28
Просмотров: 9845
Последний ответ 23.02.2016, 12:39:29
от 12mv