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

mikeles

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Не знаю почему, но мне так и не встретился нормальный вариант с решением данной задачи. Посему, решил прибегнуть к собственным силам и изобрел наверное велосипед, а может и нет.
К сожалению, нет времени сейчас подробно все расписать, но поделиться хочу.

В результате моих стараний у меня получилось:

http://files.mail.ru/K3U8FL?t=1


http://files.mail.ru/DE2WSB?t=1

http://files.mail.ru/ALIJTN?t=1

http://files.mail.ru/NGBV73?t=1

http://files.mail.ru/OS2P8G?t=1

В базе данных нужно создать в таблице vm_vendor следующие столбцы:

http://files.mail.ru/E1G374?t=1



 Скопируйте и замените файлы:
http://files.mail.ru/T7YIJO

« Последнее редактирование: 28.10.2011, 18:47:34 от mikeles »
*

flyingspook

  • Moderator
  • 3590
  • 247 / 9
а как на счет разбивки на страницы у Товарной накладной?
*

maxles

  • Новичок
  • 8
  • 0 / 0
Сделал необходимые опреации. Спасибо вам огромное, но есть одно НО.
Никак не получается выводить информацию о покупателе (грузополучателе). Если делать все так же с продавцом, все отлично работает. Итак:
1) Создаем запрос. (таблица _orders (заказы), order_id (id заказа), vendor_id (id продавца):

Код: php
$dbc = new ps_DB;
$q = "SELECT * FROM #__{vm}_orders WHERE order_id=$order_id and vendor_id = $ps_vendor_id";
$db->query($q);
$db->next_record();

2) Создаем запрос к таблице _vendor (продавец).

Код: php
$dbt = new ps_DB;
$qt = "SELECT * FROM #__{vm}_vendor WHERE vendor_id='$ps_vendor_id'";
$dbt->query($qt); 

3) Выполняем цикл и соответсвенно выводим необходимые данные из таблицы _vendor:

Код: php
while ($dbt->next_record()){
$organizaciya = ''.$dbt->f("vendor_name").'';

Все отлично выводится, в нужную мне строку выводится имя продавца. Форма заполняется. Но продавца можно и вручную вбить так как он один. Нужно чтобы автоматически подставлялась информация о покупателе. Казалось бы ничего сложного:

1) Создаем запрос. (таблица _orders (заказы), order_id (id заказа), user_id (id продавца):

Код: php
$dbc = new ps_DB;
$q = "SELECT * FROM #__{vm}_orders WHERE order_id=$order_id and user_id = $ps_user_id";
$db->query($q);
$db->next_record();

2) Создаем запрос к таблице _user_info (информация о пользователе).

Код: php
$dbt = new ps_DB;
$qt = "SELECT * FROM #__{vm}_user_info WHERE user_id='$ps_user_id'";
$dbt->query($qt);


3) Выполняем цикл и соответсвенно выводим необходимые данные из таблицы _user_info:

Код: php
while ($dbt->next_record()){
$organizaciya = ''.$dbt->f("last_name").'';

Все должно работать, но не работает. Совсем застрял. Помогите пожалуйста. Спасибо.
*

ZeRa

  • Новичок
  • 9
  • 0 / 0
Решение найдено.
В файле order.order_printdetails_order.php
песле номера чека а именно после:
Код
<form id="check_form" method="post" action="/blanks/check_gt/pdf/" target="_blank" rel="print">
    <div style="width: 100%; font-size: 11pt; font-weight: bold; text-align: center; background-color: transparent; border-bottom:1px solid #000;"><span style="width: 100%; text-align: center; font-size: 8pt;  background-color: transparent; ">ТОВАРНЫЙ ЧЕК № <b><?php printf("%08d", $db->f("order_id")); ?></b> от <b><?php echo date("d.m.Y"); ?></b></span></div>
надо вставить (заменив на свои данные конечно)
Код
    <table width="100%" border="0">
  <tr>
    <td><div style=""> <?php echo $vendor_image; ?></div></td>
    <td><div style="padding: 13px; "><span style="color: #666; font-size: 6pt;">    ИНН: 503502582231
    ОГРНИП: 311503521400024<BR>
Vizhivai.ru <BR>
    Москва, 926300<BR>
    Телефоны: +7(499) 755-69-22 или +7(925) 755-69-22<BR>
    Email: vizhivai@mail.ru<BR>
</span><br />
   <span style="font-weight: bold; color: #333; font-size: 16pt;"></span><br />Магазин Выживальщиков "Выживай.рф"&nbsp;&nbsp;<BR>Покупатель: Частное лицо</div></td>
     
<td> <!-- Begin BillTo --><div style="padding: 13px; "><span style="color: #666; font-size: 6pt;">  <?php
    // Get bill_to information
    $dbbt = new ps_DB;
    $q  = "SELECT * FROM #__{vm}_order_user_info WHERE user_id='" . $db->f("user_id"). "'  AND order_id='$order_id' ORDER BY address_type ASC";
    $dbbt->query($q);
    $dbbt->next_record();
    $user = $dbbt->record;
  ?>
      <table width="100%" cellspacing="0" cellpadding="2" border="0">
        <tr>
          <td colspan="2"><strong><CENTER>Покупатель</CENTER></strong></td>
        </tr>
        <?php
foreach( $registrationfields as $field ) {
if( $field->name == 'email') $field->name = 'user_email';
if($field->type == 'captcha') continue;
?>
  <tr>
<td align="right"><?php echo $VM_LANG->_($field->title)? $VM_LANG->_($field->title) : $field->title ?>:</td>
<td><?php
switch($field->name) {
          case 'country':
          require_once(CLASSPATH.'ps_country.php');
          $country = new ps_country();
          $dbc = $country->get_country_by_code($dbbt->f($field->name));
          if( $dbc !== false ) echo $dbc->f('country_name');
          break;
          default:
          echo $dbbt->f($field->name);
          break;
          }
          ?>
</td>
  </tr>
  <?php
}
   ?>
      </table>
      <!-- End BillTo --></div></span> </td> </td>
  </tr>

</table>
*

LDP

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Спасибо!
Подскажите, пожалуйста а можно сделать чтобы при формировании torg12 учитывалась скидка?
*

AlexNN

  • Новичок
  • 1
  • 0 / 0
To mikeles

Перезалейте, пожалуйста, картинки из своего первого поста.

Спасибо!
*

kungurskiy

  • Осваиваюсь на форуме
  • 34
  • 1 / 0
RE: Товарная накладная и товарный чек
« Ответ #6 : 21.09.2019, 19:48:12 »
Доброго времени суток, ситуация в следующем, нужно распечатывать из VM 3.6 весь пакет документов  счет, счет-фактуру, товарную накладную соответствующие законам РФ. в данный момент менеджер распечатывает форму которая была по умолчанию и затем перебивает ее в бизнес паке, что бы предоставить покупателю, хотел бы автоматизировать данный процесс.
Помогите осуществить задуманное.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] Чебокс "Показывать только товары, которые есть в наличии"

Автор artMelnikov

Ответов: 20
Просмотров: 7644
Последний ответ 28.06.2017, 11:19:51
от OutLaw1
Скидка на категорию [почти решено]

Автор baloon

Ответов: 4
Просмотров: 2487
Последний ответ 06.04.2016, 20:00:27
от Ejov
[Решено] Скидки на зависимые товары

Автор Serpent19

Ответов: 4
Просмотров: 1675
Последний ответ 04.06.2014, 15:47:15
от One
[Решено] Категорий при добавлении товара больше 200...

Автор mobiland

Ответов: 6
Просмотров: 1924
Последний ответ 22.11.2013, 12:41:26
от El_nik
Сортировка в админке по производителю. РЕШЕНО

Автор igoryk

Ответов: 4
Просмотров: 2138
Последний ответ 20.10.2013, 17:07:26
от AnatolyW