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

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Пропали базы данных
« : 07.10.2016, 11:39:50 »
Error displaying the error page: Application Instantiation Error: No database selected SQL=SELECT `session_id` FROM `#__session` WHERE `session_id` = '0f181qqfitko0f74onuk4jg0h6' LIMIT 1   в настройках опен сервера поменял open server->настройки->модули на апачи с 2.2 на 2.4. и php на 5.6 в папке modules  все позиции  для обновлений есть. менял настройки на прежние, но базы так и не появились
« Последнее редактирование: 07.10.2016, 12:23:38 от doro45 »
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Re: Пропали базы данных
« Ответ #1 : 07.10.2016, 12:14:05 »
Так база то есть?
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #2 : 07.10.2016, 12:20:42 »
Так база то есть?
в phpMyAdmin нигде не нахожу. по пути OpenServer\userdata\MySQL-5.5 есть базы данных, но как их загрузить обратно на phpMyAdmin ?
« Последнее редактирование: 07.10.2016, 12:37:08 от doro45 »
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Пропали базы данных
« Ответ #3 : 07.10.2016, 12:37:37 »
обновление опенсервера делали? после этого базы "пропали"?
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #4 : 07.10.2016, 12:42:55 »
обновление опенсервера делали? после этого базы "пропали"?
получается, что так.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Пропали базы данных
« Ответ #5 : 07.10.2016, 12:46:59 »
ну что сказать... инструкцию уже читать поздно... насколько я знаю, бекапов опенсервер не делает при обновлении, просто распаковывается поверх.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #6 : 07.10.2016, 13:01:33 »
ну что сказать... инструкцию уже читать поздно... насколько я знаю, бекапов опенсервер не делает при обновлении, просто распаковывается поверх.
на другом форуме читал, что так можно, но про бекапы там ничего не говорилось.просто переустановить настройки и всё.в MySQL есть какие то данные.но и есть же базы в userdata. заново сайт делать?
*

Olg

  • Завсегдатай
  • 1181
  • 90 / 2
Re: Пропали базы данных
« Ответ #7 : 07.10.2016, 13:05:54 »
Вы вняно скажите, что вы делали: переустановили OpenServer (скачали дистрибутив, запустили exe-файл и т.д.) или просто поменяли настройки OpenServer в панели его управления.
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #8 : 07.10.2016, 13:09:50 »
Вы вняно скажите, что вы делали: переустановили OpenServer (скачали дистрибутив, запустили exe-файл и т.д.) или просто поменяли настройки OpenServer в панели его управления.
скачивал и запускал ехе файл.опен сервер не переустанавливал.просто поменял настройки в панели управления.
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #9 : 07.10.2016, 13:10:19 »
скачивал дистр. и запускал ехе файл.опен сервер не переустанавливал.просто поменял настройки в панели управления.
скачал php7mod ( папки modules и userdata ) и запускал ехе. всё работало. базы пропали, когда сменил настройки
« Последнее редактирование: 07.10.2016, 13:17:35 от doro45 »
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Re: Пропали базы данных
« Ответ #10 : 07.10.2016, 13:56:16 »
в phpMyAdmin нигде не нахожу. по пути OpenServer\userdata\MySQL-5.5 есть базы данных, но как их загрузить обратно на phpMyAdmin ?
Не люблю локальные сервы... слишком много рисков потерять данные. Ну да ладно. Не вдавать в подробности.
1. Поднять страый сервак с бэкапа винды или же поднять и копируть базы
2. Сделать экспорт базы
3. Обновить.
4. Созадть базу.
5. Импортировать.

P.S а на кой вообще локальных серв обновлять пока все работает?
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: Пропали базы данных
« Ответ #11 : 07.10.2016, 14:53:32 »
Зайдите в папку userdata, найдите версию MySQL, в которой лежат папки вашей БД. Зайдите в настройки сервера и проверьте, та ли версия базы выбрана. Если папки баз данных целые, можете для надежности сохранить их. ОпенСервер их при переустановке не перезаписывает и потеряться они не могли.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #12 : 07.10.2016, 15:17:05 »
Зайдите в папку userdata, найдите версию MySQL, в которой лежат папки вашей БД. Зайдите в настройки сервера и проверьте, та ли версия базы выбрана. Если папки баз данных целые, можете для надежности сохранить их. ОпенСервер их при переустановке не перезаписывает и потеряться они не могли.
ну человечище-огромное спасибо.я был уверен, что всё будет ок.всего лишь 1 кнопочку нажать.апаче 2.4. PHP 5.5 .какую лучше апачи выбрать и PHP? там их много. апчи+пшп и т.д.
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: Пропали базы данных
« Ответ #13 : 07.10.2016, 15:44:14 »
какую лучше апачи выбрать и PHP? там их много. апчи+пшп и т.д.
Какая работает, такая пусть и стоит. Если сайт на Joomla 3.6, то ставьте апач 2.2 и рнр 5.6 (оптимально), если есть старые сайты на сервере, то апач 2.1 и рнр 5.4, как то так. Все от ваших потребностей зависит.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #14 : 07.10.2016, 16:35:32 »
Какая работает, такая пусть и стоит. Если сайт на Joomla 3.6, то ставьте апач 2.2 и рнр 5.6 (оптимально), если есть старые сайты на сервере, то апач 2.1 и рнр 5.4, как то так. Все от ваших потребностей зависит.
cпасибо большое
*

Mihanja80

  • Завсегдатай
  • 1918
  • 168 / 4
  • Всю жизнь учусь...
Re: Пропали базы данных
« Ответ #15 : 07.10.2016, 21:44:19 »
Это хорошо что жизнь уже начинает учить делать бекапы! Лишь бы научило!

Всегда все работы начинайте с бекапа!
Я с мобильного, в основном...
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Пропали базы данных
« Ответ #16 : 07.10.2016, 22:23:47 »
насколько я знаю, бекапов опенсервер не делает при обновлении, просто распаковывается поверх.
вот все грешат на денвер - а он такой пакости не делает, обновления идут поверх с сохранением БД
В общем денвер рулит, а админы делятся на две категории: что уже делают бекапы и что еще не делают бекапы
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: Пропали базы данных
« Ответ #17 : 08.10.2016, 14:38:34 »
вот все грешат на денвер - а он такой пакости не делает, обновления идут поверх с сохранением БД
В общем денвер рулит, а админы делятся на две категории: что уже делают бекапы и что еще не делают бекапы
Какой пакости? ОпенСервер не удаляет старые базы, он так же заливает свои файлы поверх. Ситуация была в том, что ТС в настройках выбрал не ту базу, которая была. А все файлы баз у него были на месте, но в другом каталоге.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

doro45

  • Захожу иногда
  • 106
  • 0 / 0
Re: Пропали базы данных
« Ответ #18 : 09.10.2016, 09:09:57 »
Это хорошо что жизнь уже начинает учить делать бекапы! Лишь бы научило!

Всегда все работы начинайте с бекапа!
а как создать бэкап на опен сервере?
*

KKAAZZOO

  • Живу я здесь
  • 2288
  • 118 / 9
Re: Пропали базы данных
« Ответ #19 : 09.10.2016, 11:52:28 »
Так же как и на любом хостинге
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться