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

suba050

  • Новичок
  • 5
  • 0 / 0
Как завести галерею?
« : 19.05.2016, 23:46:02 »
Всем привет!есть код галереи, но я не знаю как ее привязать к Joomla и запустить!у кого есть в этом опыт подскажите, т.к я еще не достиг нужного уровня.
Заранее благодарю.
*

umbabaraumba

  • Живу я здесь
  • 2415
  • 153 / 1
  • если помог можете поставить +
Re: Как завести галерею?
« Ответ #1 : 19.05.2016, 23:52:47 »
Если хотите чтоб она управлялась из админки то вам придется делать из нее модуль или компонент .
Errare humanum est
Ubuntu по-русски
Пишу не сложные модули и компоненты, не дорого но не срочно
*

suba050

  • Новичок
  • 5
  • 0 / 0
Re: Как завести галерею?
« Ответ #2 : 19.05.2016, 23:59:22 »
Да, вот код
;
jQuery(document).ready(function($) {
    $(".price-con-item").heightEqules();
    $(".gallery-item-page").gallerySdm();
   
    $(".exp-docs-wrap ul li .img a").fancybox({"autoResize":false});
    $(".news-images-wrap ul li a").fancybox({"autoResize":false});
    $(".price-table-wrap table").priceTable();
   
    $(".exp-docs-wrap ul li").expDocs();
});


(function($) {

    "use strict";
   
    Number.prototype.isInt=function(){
        return (Math.round(this)==this);
    }
    Number.prototype.roundTo=function(n){
        var x = 0;
        if (typeof(n) == 'number')
            if (n.isInt()) {           
                if (n >= -6 && n <= 6) {
                    x = n;
                }
            }
        x = Math.pow(10,x);
        return Math.round(this*x) / x;
    }
    Math.roundTo=function(i,n) {
        if (typeof(i) == 'number') {
            return i.roundTo(n);
        } else {
            return false;
        }
    }
   
    $.fn.heightEqules = function(options) {
        if (!this.length) {
            return;
        }
        var defaults        = {}
        var settings        = $.extend({}, defaults, options);
       
        var maxHeight = 0;
       
        this.each(function () {
            var h = $(this).height();
            if (h > maxHeight) {
                maxHeight = h;
            }
        });
        this.height(maxHeight);
       
    }
   
    $.fn.expDocs = function(options) {
        if (!this.length) {
            return;
        }
        var defaults        = {}
        var settings        = $.extend({}, defaults, options);
               
        this.each(function () {
            var $this = $(this); //li
            var $a = $this.find(".img a");
            if ($a.length > 1) {
                $a.css("display","none");
                var $first = $a.first();
                $first.css("display","");
                $a.parent().addClass("many-docs");
            }
        });
       
    }
   
    $.fn.priceTable = function(options) {
        if (!this.length) {
            return;
        }
        var defaults        = {}
        var settings        = $.extend({}, defaults, options);
       
        var maxHeight = 0;
       
        var $table = this;
       
            console.log(11);
        $table.find("tr").each(function () {
            var $tr = $(this);
            var $firstTd = $tr.children("td:first");
            if (!$firstTd.length) {
                return;
            }
            if ($firstTd.html() == "") {
                $tr.addClass("subtitle");
            } else if ($firstTd.html() == "---") {
                $tr.addClass("subsubtitle");
                $firstTd.html("");
            }
        });
       
    }
   
    $.fn.gallerySdm = function(options) {
        if (!this.length) {
            return;
        }
        var defaults        = {
            duration: 600
        }
        var settings        = $.extend({}, defaults, options);
       
        var $galleryWrap = this;
        var moveFlag = 0;
       
        var $mainImg = $galleryWrap.find(".main-picture img");
        var $toPrev = $galleryWrap.find(".pic-list-wrap .to-prev");
        var $toNext = $galleryWrap.find(".pic-list-wrap .to-next");
        var $list = $galleryWrap.find(".pic-list-wrap .list-contaner ul");
        var step = $list.children("li").height();
        var galHeight = $galleryWrap.find(".pic-list-wrap .list-contaner").height();
       
        startSetting();
       
        function startSetting() {
            var $first = $list.find("a").first();
            $first.parent().addClass("active");
            $mainImg.attr("src", $first.attr("href"));
        }
       
        $list.find("a").click(function () {
            var $this = $(this);
            var href = $this.attr("href");
            $mainImg.attr("src", href);
            $list.children("li").removeClass("active");
            $this.parent().addClass("active");
            return false;
        });
       
        $toPrev.click(move);
        $toNext.click(move);
       
        function move () {
            var $this = $(this);
            var curTop = parseInt($list.css("top"));
            var curTop = (curTop)? (curTop) : (0) ;
           
            if ($this.attr("class").search("to-prev")!=-1) {
                var newPos = curTop + step;
            } else {
                var newPos = curTop - step;
            }
           
           
            var kray = galHeight - $list.height();
            if (newPos > 0) {
                newPos = kray;
            }
            if (newPos < kray) {
                newPos = 0;
            }
            $list.animate({top:newPos}, settings.duration, function () {});
        }
       
    }
   
})(jQuery);

Как теперь все это залить и запустить на Joomla?))И если есть алгоритм как все это превратить в модуль, чтобы я смог сам его редактировать.
Заранее спасибо)
*

umbabaraumba

  • Живу я здесь
  • 2415
  • 153 / 1
  • если помог можете поставить +
Re: Как завести галерею?
« Ответ #3 : 20.05.2016, 00:16:04 »
Как теперь все это залить и запустить на Joomla?))И если есть алгоритм как все это превратить в модуль, чтобы я смог сам его редактировать.
Вот
Errare humanum est
Ubuntu по-русски
Пишу не сложные модули и компоненты, не дорого но не срочно
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как удалить галерею со страницы?

Автор prioritet

Ответов: 3
Просмотров: 1035
Последний ответ 28.08.2021, 22:30:39
от gartes
Модуль/компонент/галерею

Автор |-MOHAX-|

Ответов: 1
Просмотров: 1082
Последний ответ 03.06.2020, 22:26:18
от AlexB
Создать галерею из поля repeatable

Автор Merk

Ответов: 3
Просмотров: 998
Последний ответ 27.01.2019, 18:09:14
от Merk
Как установить JS tracking code в Piwigo галерею?

Автор abrodski

Ответов: 0
Просмотров: 917
Последний ответ 17.07.2017, 02:17:40
от abrodski
Посоветуйте адаптивную галерею с классными спецэффектами

Автор neogod

Ответов: 7
Просмотров: 773
Последний ответ 10.12.2016, 19:04:46
от effrit