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

С помощью VBS можно легко автоматизировать загрузку CSV по FTP на сервер. А можно без захода в заднюю дверь Joomla и ползания по менюшкам автоматизировать импорт CSV в базу VirtueMart?
Т.е. в идеале менеждер импортировал данные из 1С, кликнул раз по иконке, а дальше все на автомате: конвертирование данных в правильный CSV, его upload на сервер и импорт в базу. Не знаю, как сделать последнее.
*

tug

  • Захожу иногда
  • 333
  • 40 / 4
Re: Автоматизировать импорт CSV
« Ответ #1 : 01.05.2006, 02:55:45 »
Вижу только решение с применением Веб сервисов. Такое решение тянет на серьёзную модификацию, хотя тема конечно инетересная.

Re: Автоматизировать импорт CSV
« Ответ #2 : 02.05.2006, 15:52:09 »
Мне казалось, что должно существовать более простое решение, потому и спросил. Я пока первый сайт на Joomla делаю. Вернее заканчиваю делать.
Задачу можно решить тем же VBS. Создать им объект IE (можно невидимый) и послать его на страницу входа, ввести логин и пароль и в поля формы, войти, перейти на нужную страницу, ввести там нужное в поля и запустить импорт. И только потом показать IE, чтобы юзер увидел результат импорта.
Жалко, что нельзя сразу запустить импорт передав в URL пароль и все нужные параметры.
*

tug

  • Захожу иногда
  • 333
  • 40 / 4
Re: Автоматизировать импорт CSV
« Ответ #3 : 02.05.2006, 18:03:57 »
Вам и карты в руки.
*

h2lord

  • Осваиваюсь на форуме
  • 31
  • 3 / 0
Re: Автоматизировать импорт CSV
« Ответ #4 : 02.05.2006, 22:14:57 »
С помощью VBS можно легко автоматизировать загрузку CSV по FTP на сервер. А можно без захода в заднюю дверь Joomla и ползания по менюшкам автоматизировать импорт CSV в базу VirtueMart?
Т.е. в идеале менеждер импортировал данные из 1С, кликнул раз по иконке, а дальше все на автомате: конвертирование данных в правильный CSV, его upload на сервер и импорт в базу. Не знаю, как сделать последнее.
возми код импорта и перепиши чтобы он импортировал по расписанию твой csv файл на сервере.

Re: Автоматизировать импорт CSV
« Ответ #5 : 03.05.2006, 10:59:36 »
Тут есть проблема. Я с PHP имею дело пару недель. И если в целом я ухватываю структуру готовой программы, и могу править мелочи (напрмер, чтобы изменить вид страниц), но писать и вынимать куски в отдельную прогу не могу. Садиться за учебник тоже вроде ни к чему. Я не профи, и после этого сайта, хрен знает, пригодится ли мне это еще когда-нибудь.
Я тут подумал. Установка магазина ведь ставит пример базы из SQL файла. Если по аналогии сгенерить не CSV, а SQL файл с товарами, то его можно было бы прямо сувать в базу, как это делает уставнока, да? Или процедура импорта сложнее?
Может есть готовый пример, в котором достаточно подставить свои пути и пароли? Например, менеджер, открывает некую спец. страницу сайта и тем запускает импорт аплодированного туда CSV или SQL, получая сообщение "Ok".
*

tug

  • Захожу иногда
  • 333
  • 40 / 4
Re: Автоматизировать импорт CSV
« Ответ #6 : 03.05.2006, 23:41:42 »
Это потенциальная дыра, но если Вас это не волнует, то можно и так сделать.
Для всего этого дела удобно пользоваться средствами самого VM и Жумлы (для работы с бд имеется ввиду)
Хотя мне оба варианта кажутся плохими...

Re: Автоматизировать импорт CSV
« Ответ #7 : 05.05.2006, 09:53:01 »
Почему ж дыра?
Оба варианта плохие в сравнении с чем?
*

h2lord

  • Осваиваюсь на форуме
  • 31
  • 3 / 0
Re: Автоматизировать импорт CSV
« Ответ #8 : 13.05.2006, 23:52:11 »
Тут есть проблема. Я с PHP имею дело пару недель. И если в целом я ухватываю структуру готовой программы, и могу править мелочи (напрмер, чтобы изменить вид страниц), но писать и вынимать куски в отдельную прогу не могу. Садиться за учебник тоже вроде ни к чему. Я не профи, и после этого сайта, хрен знает, пригодится ли мне это еще когда-нибудь.
Я тут подумал. Установка магазина ведь ставит пример базы из SQL файла. Если по аналогии сгенерить не CSV, а SQL файл с товарами, то его можно было бы прямо сувать в базу, как это делает уставнока, да? Или процедура импорта сложнее?
Может есть готовый пример, в котором достаточно подставить свои пути и пароли? Например, менеджер, открывает некую спец. страницу сайта и тем запускает импорт аплодированного туда CSV или SQL, получая сообщение "Ok".

а вчем разница передавать и парсить csv файл и ложить в базу, или передавать sql файл и опять же его парсить и ложить в базу, можно тоже самое делать и с xml?

Re: Автоматизировать импорт CSV
« Ответ #9 : 19.05.2006, 15:22:34 »
я сейчас пытаюсь сделать импорт из 1с. подключением к базе через АДО драйвер одбс.
небольшая проблема возникает, если товар в базе есть то его я редактирую на ура.
при добавлении он в базу добавляется, но не отображается в магазине. что нужно еще добавить, может что то пропустил.


Re: Автоматизировать импорт CSV
« Ответ #10 : 22.05.2006, 20:14:28 »
Кстати никаких проблем не возникает. правда много нюансов есть. ну а в общем из 1с даются звпросы прям в мускул. довести идею бы еще до полной реализации. было бы неплохо.
*

h2lord

  • Осваиваюсь на форуме
  • 31
  • 3 / 0
Re: Автоматизировать импорт CSV
« Ответ #11 : 22.05.2006, 22:32:35 »
я сейчас пытаюсь сделать импорт из 1с. подключением к базе через АДО драйвер одбс.
небольшая проблема возникает, если товар в базе есть то его я редактирую на ура.
при добавлении он в базу добавляется, но не отображается в магазине. что нужно еще добавить, может что то пропустил.

если ты добавил в jos_vm_product, то надо добавить в jos_vm_product_category_xref ссылки на parent category для товара, ну и product_publish='Y' незабудь.
*

airdm

  • Осваиваюсь на форуме
  • 14
  • 0 / 0
Re: Автоматизировать импорт CSV
« Ответ #12 : 30.05.2006, 15:45:00 »
Кстати никаких проблем не возникает. правда много нюансов есть. ну а в общем из 1с даются запросы прям в мускул. довести идею бы еще до полной реализации. было бы неплохо.
Очень даже неплохо было бы :-)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Импорт из CSV товаров с типами и свойствами из

Автор Gruz

Ответов: 499
Просмотров: 149080
Последний ответ 23.02.2017, 15:15:42
от orchanin
импорт товаров в YML Яндекс маркет

Автор zmeyx

Ответов: 5
Просмотров: 11180
Последний ответ 14.07.2016, 18:34:28
от Berzerker
Общие вопросы по j1.5.26+vm1.1.9+импорт из 1С

Автор alexzhimuk

Ответов: 2
Просмотров: 3171
Последний ответ 06.05.2016, 15:28:04
от alexzhimuk
CSVI импорт экспорт

Автор Vasja555

Ответов: 0
Просмотров: 3417
Последний ответ 05.02.2015, 15:40:45
от Vasja555
FAQ. Импорт товаров с типами через CSV для virtuemart 1.1.3

Автор Motor

Ответов: 350
Просмотров: 134156
Последний ответ 04.12.2014, 18:44:15
от Vladimir