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

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Допускаю, что не в этот раздел, сорри.
Нужен скрипт (допускаю, что это будет js, где я 0 полный), прокручивающий страницу в самый низ, и образец ссылки на него.
« Последнее редактирование: 17.03.2014, 22:30:14 от b2z »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #2 : 17.03.2014, 13:06:29 »
В модуле пишу:

Код: php
echo '
<script ype="text/javascript">
  var delay = 2;
  var scroll_amount = 10;
  var interval;
  function animatedScroll()
  {
    if(window.pageYOffset >= document.body.scrollHeight)
    {
      clearInterval(interval);
    }
    else
    {
      window.scrollBy(0,scroll_amount);
    }
  }
  function scrollToBottom()
  {
    interval = setInterval(\'animatedScroll()\',delay);
  }
</script>';

echo '<a href="javascript:scrollToBottom()">Смотрите ниже</a>';

По идее, clearInterval должен остановить анимацию, но она не останавливается - страница при попытке прокрутить наверх опять вниз норовит прокрутиться. Или я что-то не так делаю?
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Re: Прокрутить страницу вниз
« Ответ #3 : 17.03.2014, 13:13:19 »
Ну тут я, к сожалению, не помощник - в JS слабо разбираюсь.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #4 : 17.03.2014, 13:25:48 »
b2z, Спасибо.
Пока просто указал <a href="javascript:window.scrollTo(0,document.body.scrollHeight);">, подожду, пока кто-нибудь поможет с анимацией, - я тоже с js не дружу.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Прокрутить страницу вниз
« Ответ #5 : 17.03.2014, 14:13:03 »
Если вам нужно просто 1 раз прокрутиться к концу страницы, то следуйте ссылке, данной b2z.
Условие
Код: php-brief
window.pageYOffset >= document.body.scrollHeight
не выполняется, поэтому код срабатывает по второму сценарию.
« Последнее редактирование: 17.03.2014, 15:55:56 от robert »
Не будь паразитом, сделай что-нибудь самостоятельно!
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Прокрутить страницу вниз
« Ответ #6 : 17.03.2014, 14:31:44 »
Попробуйте такое условие, не уверен, правда что оно кроссбраузерное:
Код: javascript
if(document.body.clientHeight+document.body.scrollTop >= document.body.scrollHeight)
интернет-блог: http://websiteprog.ru
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Прокрутить страницу вниз
« Ответ #7 : 17.03.2014, 15:55:14 »
Код: php-brief
if(window.pageYOffset >= (document.body.scrollHeight - window.innerHeight))
Не будь паразитом, сделай что-нибудь самостоятельно!
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Прокрутить страницу вниз
« Ответ #8 : 17.03.2014, 16:27:47 »
pageYOffset не поддерживается в explorer ниже 9 версии
интернет-блог: http://websiteprog.ru
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #9 : 17.03.2014, 17:12:11 »
Если вам нужно просто 1 раз прокрутиться к концу страницы, то следуйте ссылке, данной b2z.
Вышеуказанный пример именно оттуда.

Попробуйте такое условие, не уверен, правда что оно кроссбраузерное:
Код: javascript
if(document.body.clientHeight+document.body.scrollTop >= document.body.scrollHeight)
Тот же эффект: не дает прокрутить наверх.

Код: php-brief
if(window.pageYOffset >= (document.body.scrollHeight - window.innerHeight))
Работает в лисе, Chrome, ие10. Не работает вообще в опере12. В ие8 не дает прокрутить наверх.


Код: javascript
if ((document.body.clientHeight + document.body.scrollTop) >= (document.body.scrollHeight - window.innerHeight))
не дает прокрутить вверх
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Re: Прокрутить страницу вниз
« Ответ #10 : 17.03.2014, 17:13:58 »
pageYOffset не поддерживается в explorer ниже 9 версии
Извините за оффтоп - в топку IE 6-8! Нафига до сих пор поддерживать это... ? Лично я сразу их выкидываю из разряда поддерживаемых. Ну тут уж как AlekVolsk решит, но я бы отказался =) AlekVolsk - есть статистика посещений по бразуерам? Если IE 6-8 меньше 10%, думать про них забудьте =))
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #11 : 17.03.2014, 17:20:24 »
Есть статистика, печальная весьма:
ie6 - 2%
ie7 - 0.8%
ie8 - 16.4%
opera9-12 - 7%
Подразумеваю, что это компы областного минобра, где техника до сих пор не айс...
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Прокрутить страницу вниз
« Ответ #12 : 17.03.2014, 17:25:03 »
Вышеуказанный пример именно оттуда.
Не знаю, куда вы зашли, но для этого достаточно одной строки
Код: javascript
window.scrollTo(0,document.body.scrollHeight);

Код: javascript
if(window.pageYOffset >= (document.body.scrollHeight - window.innerHeight))
Работает в лисе, Chrome, ие10. Не работает вообще в опере12.
Неправда. Сам тестировал на Opera 12. В IE ниже 9 - да, не работает. Поменяйте pageYOffset на что-нибудь deprecated или
про них забудьте =))
Не будь паразитом, сделай что-нибудь самостоятельно!
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Re: Прокрутить страницу вниз
« Ответ #13 : 17.03.2014, 17:32:21 »
Есть статистика, печальная весьма:
ie6 - 2%
ie7 - 0.8%
ie8 - 16.4%
opera9-12 - 7%
Подразумеваю, что это компы областного минобра, где техника до сих пор не айс...
Мдаа... 20% с IE 6-8. Ну тогда надо крутиться.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #14 : 17.03.2014, 17:33:36 »
window.scrollTo(0,document.body.scrollHeight); - это работает, но без анимации, вышеприведенный пример именно анимацию реализовывает.

Opera 12.15, надстроек нет - голая. Может там чего включить дополнительно надо?

Цитировать
Поменяйте pageYOffset на что-нибудь deprecated
На что, например? Я ноль в js

Цитировать
Ну тогда надо крутиться.
Что-то уже юлой себя чувствую...
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Прокрутить страницу вниз
« Ответ #15 : 17.03.2014, 17:43:58 »
по идее document.body.scrollTop и есть замена. Беда с этим javascript в плане кроссбраузерности, можете попробовать воспользоватся jquery.
вот здесь еще можете почитать http://learn.javascript.ru/metrics-window
интернет-блог: http://websiteprog.ru
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #16 : 17.03.2014, 18:10:03 »
Код: javascript
  var delay = 2;
  var scroll_amount = 10;
  var interval;
  function animatedScroll()
  {
    var scrollTop = document.documentElement.scrollTop || document.body && document.body.scrollTop || 0;
    scrollTop -= document.documentElement.clientTop;
    scrollBottom = scrollTop + document.documentElement.clientHeight;
    if (scrollBottom >= document.body.scrollHeight)
    {
      clearInterval(interval);
    }
    else
    {
      window.scrollBy(0,scroll_amount);
    }
  }
  function scrollToBottom()
  {
    interval = setInterval(\'animatedScroll()\',delay);
  }
в ие8 не дает крутить вверх (
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Прокрутить страницу вниз
« Ответ #17 : 17.03.2014, 18:41:58 »
вы можете использовать console.log() для контроля переменных. К примеру console.log(scrollTop) или console.log(scrollTop+' '+document.body.scrollHeight). посмотрите как у вас будут меняться значения на скролах в разных браузерах. Бывают глюки что несколько пикселов не хватает..
интернет-блог: http://websiteprog.ru
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #18 : 17.03.2014, 18:53:09 »
как этот лог потом просматривать?
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Прокрутить страницу вниз
« Ответ #19 : 17.03.2014, 19:18:50 »
в консоле, откройте консоль и смотрите.
интернет-блог: http://websiteprog.ru
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #21 : 17.03.2014, 22:12:53 »
Хмм, а в ие8? в других браузерах-то работает
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Прокрутить страницу вниз
« Ответ #22 : 17.03.2014, 22:25:00 »
Хмм, а в ие8? в других браузерах-то работает
Хмм, господин, а не слишком ли много хотите? Я смотрю, весь день целая команда уже работала на вас. Понятно, что все пришли сюда за халявой, но всему есть предел.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Прокрутить страницу вниз
« Ответ #23 : 17.03.2014, 22:27:04 »
Нашел, где в ie, смотрю плохо...
Рабочий вариант:
Код: javascript
 var delay = 2;
  var scroll_amount = 10;
  var interval;
  function animatedScroll() {
    var scrollTop = document.documentElement.scrollTop || document.body && document.body.scrollTop || 0;
    scrollTop -= document.documentElement.clientTop;
    scrollBottom = scrollTop + document.documentElement.clientHeight;
    if (scrollBottom >= document.body.scrollHeight) {
      clearInterval(interval);
    } else {
      console.log(scrollTop + \', \' + document.body.scrollHeight);
      window.scrollBy(0,scroll_amount);
    }
  }
  function scrollToBottom() {
    interval = setInterval(\'animatedScroll()\', delay);
  }
Код: html4strict
<a href="javascript:scrollToBottom();">Смотрите ниже</a>

Решено. zomby6888, +
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Переход по ссылки и запуск функции? [РЕШЕНО]

Автор warlocksp

Ответов: 19
Просмотров: 1385
Последний ответ 21.02.2020, 12:06:24
от warlocksp
[РЕШЕНО] Скроллинг страницы вниз?

Автор warlocksp

Ответов: 3
Просмотров: 896
Последний ответ 02.02.2020, 15:56:55
от warlocksp
Разобраться с небольшим кодом PHP (РЕШЕНО)

Автор Шмайсер

Ответов: 18
Просмотров: 1285
Последний ответ 16.01.2020, 21:47:56
от sivers
Как изнутри iframe вызвать внешнюю функцию? [РЕШЕНО]

Автор dm-krv

Ответов: 6
Просмотров: 1144
Последний ответ 25.08.2019, 20:41:07
от dm-krv
Как получить объект с полной информацией о материале через API Joomla? [РЕШЕНО]

Автор dm-krv

Ответов: 4
Просмотров: 1188
Последний ответ 03.08.2019, 16:30:51
от dm-krv