Новости Joomla

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

👩‍💻 Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях. На старте его сайт на Joomla 3 вообще не смог обновиться на Joomla 5. Пришлось делать экспорт/импорт материалов. Проделав всё это он запустил-таки этот объём данных на Joomla 5. Тестовый скрипт грузил 200 материалов из этого объёма всего за 94 секунды ))) А главная страница с категориями грузилась 20 секунд. Добавив индекс для таблицы #__content

CREATE INDEX idx_catid_state ON #__content (catid, state);
он сократил время загрузки категорий до 1 секунды. Затем наш герой решил поковырять SQL-запрос в ArticleModel, который отвечает за выборку материалов. И решил заменить тип JOIN на STRAIGHT_JOIN для категорий.
// ->from($db->quoteName('#__content', 'a'))->from(    $db->quoteName('#__content', 'a')    . ' STRAIGHT_JOIN ' . $db->quoteName('#__categories', 'c')    . ' ON ' . $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))// ->join('LEFT', $db->quoteName('#__categories', 'c'), $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))
Что сократило загрузку 200 материалов из 150к с 94 секунд до 5. К слову сказать, боевой сайт на Joomla 3 крутится на 12CPU 64GB рамы. А все манипуляции с кодом он делает на базовом 1CPU 1GB сервере и замеры скорости даны именно для базового сервера. Но это всё в дискуссии, хотя в идеале должно вылиться в Pull Requests. Мы - Open Source сообщество, где никто никому ничего не должен. Джунгли. Но человек ищет пути оптимизации Joomla и предлагает решения. Если оказать поддержку и предложить помощь хотя бы с тестированием самых разнообразных сценариев, то возможно эти улучшения смогут войти в ядро. Пусть не быстро, пусть через несколько лет, пусть не все, но войдут. Достаточно предложить руку помощи и приложить немного усилий.
Дискуссию на GitHub можно почитать здесь.@joomlafeed#joomla #community #php

Перевод и публикация интервью с Joomla евангелистом на греческом портале Joomla

Перевод и публикация интервью на греческом портале Joomla 🇬🇷

Утро, просматриваешь входящие письма и изучаешь новости и внезапно обнаруживаешь, что инициатива, которую ты начал, подхватывается другими людьми. 🎉

Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции. Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉

До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊

Смотрю на греческий алфавит и тут же рисуются картины белоснежных зданий в окружении винограда и амфор, красивых женщин в сандалиях и мужественных воинов, охраняющих покой полисов, в которых ученые мужи работают над трудами, позже вошедшими в века. Красиво! 😇Но вернемся к интервью.

Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент.

🌐 Оригинальное интервью (на английском)
🇬🇷 Интервью на греческом портале (joomla.gr)

Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

0 Пользователей и 1 Гость просматривают эту тему.
  • 53 Ответов
  • 10275 Просмотров
*

beagler

  • Moderator
  • 3276
  • 392 / 4
  • https://alorisman.ru/
Уважаемые владельцы интернет-магазинов.
Многие из Вас отправляют товары своим покупателям Почтой России.
Для отправки посылки необходимо заполнить как минимум формы Ф113 и Ф7.
Многие заполняют эти формы в Excel, например - read.kamensky.ru/files/post.xls (Кстати, для того чтобы проверить, примет ли Ваша почта напечатанные формы - скачайте эти шаблоны, заполните руками и попробуйте отправить.)

Предлагаю доработку VirtueMart 1.1.x, позволяющую автоматически заполнять эти формы данными заказа и получать готовый xls файл, который нужно только распечатать.
Информацию об отправителе берем из настроек магазина. Файлы формируются на основе файла-шаблона. Вообще, по этому принципу, можно получать любые другие формы.

up от 26 января 2012г. Добавлена форма 116 (Сопроводительный адрес к посылке)
По просьбе заказчика сделан варинт решения, когда кнопки печати не в списке заказов, а в самом заказе.


up от 19 марта 2013г. Добавлена форма 116 и форма 113 для почты Украины

Для демодоступа на полигон обращайтесь в личку.

Как всё это работает?

В админке в списке заказа повляются 2 дополнительные кнопки - каждая на свою форму.



нажимаем на одну из них - открываем файл



и получаем в екселе заполненную форму, печатаем её



потом нажимаем на вторую кнопку - и получаем вторую.



В VirtueMart меняется всего один файл - order.order_list.php

Стоимость решения с самостоятельной установкой - 1000 WMR
Стоимость решения и внедрения - 2000 WMR


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

Класс обработки Excel достаточно ресурсоемкий, минимальное ограничение memory_limit должно быть 64M
*

gum777

  • Осваиваюсь на форуме
  • 13
  • 1 / 0
Все хорошо только одно замечание у вас только две формы Ф113 и Ф7, а нужно еще Ф116 и Ф112
*

Yoko

  • Новичок
  • 1
  • 0 / 0
*

anton21585

  • Новичок
  • 1
  • 0 / 0
Не могу написать в личку, хочу приобрести данный модуль, напишите мне на почту info@altaibalzam.ru , или напишите свой № телефона, я отзвонюсь. Антон
*

mastergaz

  • Новичок
  • 1
  • 0 / 0
Не могу написать в личку в асе тоже. Интересует данная доработка. Ася 59476008ноль
*

Sedoy

  • Давно я тут
  • 897
  • 87 / 10
  • Интересно,в какой кодировке пишут врачи?
>В списке заказа повляются 2 дополнительные кнопки - каждая на свою форму.

т.е. это заказчик заходит в свои заказы и печатает себе или админ печатает и отсылает?
что-то я не понял алгоритм техпроцесса
Что б правильно задать вопрос - нужно знать на него ответ!
FAQ по Joomla!
Где скачать шаблоны Joomla Статьи и обзоры Желаю Вам здоровья в личной жизни - живите долго и часто :)
*

Sedoy

  • Давно я тут
  • 897
  • 87 / 10
  • Интересно,в какой кодировке пишут врачи?
тогда вопрос - а админу это зачем?
ну... с точки зрения техпроцесса?
я понимаю клиент заказ оформил, тут ему предложение распечатать - жмет кнопку....
каков алгоритм - не могу вписать сюда админа?
 
Что б правильно задать вопрос - нужно знать на него ответ!
FAQ по Joomla!
Где скачать шаблоны Joomla Статьи и обзоры Желаю Вам здоровья в личной жизни - живите долго и часто :)
*

Sedoy

  • Давно я тут
  • 897
  • 87 / 10
  • Интересно,в какой кодировке пишут врачи?
Что б правильно задать вопрос - нужно знать на него ответ!
FAQ по Joomla!
Где скачать шаблоны Joomla Статьи и обзоры Желаю Вам здоровья в личной жизни - живите долго и часто :)
*

sergej.p

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
*

beagler

  • Moderator
  • 3276
  • 392 / 4
  • https://alorisman.ru/
а не просил никто. Если нужно - нарисуем.
Теперь по делу.
По опыту работы - удобнее сначала напечатать обратные стороны, а потом на них печатать лицевые.
*

sergej.p

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Интересует данная доработка!
1. При обновлении Joomla или VirtueMart она слетит или нет?
2. Сумму прописью сможете сделать?
3. Индекс вписывается?
4. Этикетку на посылку так же надо сделать!
5. Колонка "Почта России" - это в стандартном виде "Печатать этикетку"? Это поле заменится при доработке?
*

beagler

  • Moderator
  • 3276
  • 392 / 4
  • https://alorisman.ru/
1. Слетит - замена в одном файле (шаблон вывода заказ)
2. Есть.
3. Есть.
4. Делал. В какой форме?
5. Есть два варианта - вывод печатных форм в списке заказов или в самом заказе. Кому как удобно.
Проще показать - выслал демовход.
*

sergej.p

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Посмотрел! Вроде бы всё нормально! Суммы прописью не увидел(если можно сделайте на полигоне)? У меня VirtueMart 1.1.9 - не будет проблем?
1. При обновлении надо будет заливать старый файл?
4. Дают на почте(наклейку) От кого - кому (индекс, адрес, сумма объвленной ценности, сумма наложенного платежа) Могу выслать скан этикетки.
5. А можно оба варианта? :) Удобнее всё же из списка заказов! Не ответили на 5 пункт "Колонка "Почта России" - это в стандартном виде "Печатать этикетку"? Это поле заменится при доработке?"
6. Как оформим сделку? Как оплатить? Ставить буду сам! Если договоримся!
*

beagler

  • Moderator
  • 3276
  • 392 / 4
  • https://alorisman.ru/
Сумма прописью на полигоне не включена. С 1.1.9 проблем не будет.
1. При обновлении нужно будет сделать такие же изменения в одном файле. Я напишу.
4. Давайте скан. Заполненный.
5. - как захотите - можно ещё одну колонку, можно вместо печатать этикетку.
Единственный нюанс - мне нужно знать какие поля заполняют у Вас пользователи - какие куда выводить.
Какие именно формы Вам нужны? оптимально было бы сканы примеров заполнения. Везде требуют по-разному.
Оба варианта - изменения в 2 файлах. Давайте ориентироваться на список.

Я подгоняю формы под Ваши сканы, готовлю Вам архив с файлами и описаниями. Вы оплачиваете 100% на WMR. Я отправляю Вам архив.
*

sergej.p

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Хорошо. Я всё подготовлю. Дайте адрес эл. почты или скайп.
*

pichlance

  • Осваиваюсь на форуме
  • 20
  • 0 / 0
Интересный хак! Видел немного другое решение, но оно мне не понравилось - дело в том, что из файла order.order_list.php запрос пересылался в другой файл "blank.php" и он уже обращался к базе данных и формировал xls файл. Этот способ мне не понравился тем, что любой пользователь мог получить доступ ко всей истории заказов интернет магазина. Надеюсь у вас не так!

В связи с этим несколько вопросов:

1) Единственное что надо будет заменить это order.order_list.php?
2) Какие поля нужны для отправки наложенным платежом бандероли?
*

SolopoV

  • Давно я тут
  • 576
  • 16 / 0
  • зеленею...
Все таки, как вывести в печатные формы регион (область) не цифрами, а текстом (не "74", а Челябинская область)?
В админке использован хак из данной темы: http://joomlaforum.ru/index.php/topic,167971.0.html
Области, соответственно, в админке и в управлении учетной записью,  регионы выводятся нормально.

Полагаю, "склеивать" нужно в order.order_print.php ?
*

SolopoV

  • Давно я тут
  • 576
  • 16 / 0
  • зеленею...
нужно название региона выдергивать дополнительным запросом в order.order_print.php
Оплачу готовое решение.
P.S. Подключил ещё пару бланков за сегодня.
*

beagler

  • Moderator
  • 3276
  • 392 / 4
  • https://alorisman.ru/
В order.order_print.php вместо
Код
$q = "SELECT a.*, #__{vm}_order_user_info.user_email, #__{vm}_order_user_info.first_name, #__{vm}_order_user_info.last_name, #__{vm}_order_user_info.middle_name, #__{vm}_order_user_info.address_1, #__{vm}_order_user_info.city, #__{vm}_order_user_info.zip, #__{vm}_order_user_info.state, #__{vm}_order_user_info.country
FROM #__{vm}_orders a , #__{vm}_order_user_info
WHERE a.order_id=#__{vm}_order_user_info.order_id
AND a.order_id='$order_id'";
$db->query($q);
пишем
Код
$q = "SELECT a.*, #__{vm}_order_user_info.user_email, #__{vm}_order_user_info.first_name, #__{vm}_order_user_info.last_name, #__{vm}_order_user_info.middle_name, #__{vm}_order_user_info.address_1, #__{vm}_order_user_info.city, #__{vm}_order_user_info.zip, #__{vm}_order_user_info.state, #__{vm}_order_user_info.country
FROM #__{vm}_orders a , #__{vm}_order_user_info
WHERE a.order_id=#__{vm}_order_user_info.order_id
AND a.order_id='$order_id'";
$db->query($q);
$dbstl = new ps_DB();
$q = "SELECT state_name FROM #__{vm}_state WHERE #__{vm}_state.country_id = ";
$q .= "(SELECT country_id FROM #__{vm}_country WHERE #__{vm}_country.country_3_code = '".$db->f('country')."') ";
$q .= "AND #__{vm}_state.state_2_code = '".$db->f('state')."' ";
$dbstl->query($q);
$dbstl->next_record();
и вместо
Код
<input type="hidden" name="state" value="'.$db->f('state').'" /> 
пишем
Код
<input type="hidden" name="state" value="'.$dbstl->f( 'state_name' ).'" /> 
*

vov4ik082

  • Новичок
  • 2
  • 0 / 0
Интересует возможность приобретения для VirtueMart 1.1.8 и Joomla 1.5 в личку написать не удалось, если возможно сообщите контакты на info собака kroha61.ru спасибо.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Модуль новой почты с новым API для VirtueMart 3x

Автор boraah

Ответов: 0
Просмотров: 3699
Последний ответ 19.11.2019, 09:22:53
от boraah
Универсальный плагин трэкинга посылок почты России (joomshopping, VM 1-2-3)

Автор beagler

Ответов: 16
Просмотров: 4820
Последний ответ 10.03.2017, 19:53:41
от beagler
Скрипт 1cx: обмен данными 1С8 <-> VirtueMart 2

Автор Pavel.Br

Ответов: 65
Просмотров: 8884
Последний ответ 22.05.2016, 11:44:00
от Pavel.Br
VM2-3 Плагин вывода списка товаров на странице производителя

Автор beagler

Ответов: 0
Просмотров: 1537
Последний ответ 27.08.2014, 10:27:04
от beagler
Модуль доставки почты России 1.1.X (международный)

Автор esmark

Ответов: 24
Просмотров: 1876
Последний ответ 06.08.2012, 13:13:54
от SolopoV