Новости Joomla

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

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

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

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

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

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

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

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

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

Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5

👩‍💻 Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5.В Joomla для выполнения внешних запросов из PHP к сторонним API используется класс Joomla\Http\Http напрямую или же Joomla\Http\HttpFactory, который возвращает для работы преднастроенный по умолчанию класс Http. О работе с HTTP-запросами подробно рассказывалось в статье 2021 года Создание внешних запросов с использованием HttpFactory (Joomla). Некоторые изменения касаются работы с ответами на запросы. Например, наш запрос:
use Joomla\Http\HttpFactory;$http = (new HttpFactory)->getHttp($options, ['curl', 'stream']);$response = $http->get('https://any-url.ru/api/any/endpoint');
Раньше можно было получить код ответа или тело ответа как свойство $response - $response->code или $response->body. Однако, Joomla, начиная с Joomla 4 во многом переходит на стандарты PSR. В частности для работы с HTTP-ответами - на PSR-7. Также хорошая статья на Хабре о PSR-7: PSR-7 в примерах.
Прямое обращение к свойствам code, headers, body объявлено устаревшим в Joomla 6.0.0 и обещают удалить в Joomla 7.0.0.
Вместо этого нужно работать с HTTP-ответом по стандартам PSR-7. Код ответа.Было $response->code. Стало $response->getStatusCode().Заголовки ответа.Было $response->headers. Стало $response->getHeaders().Тело ответа.Было $response->body. Стало (string)$response->getContents().В тело ответа теперь приходит не строка, а поток - объект класса Laminas\Diactoros\Stream. Поэтому его нужно привести к строке (если это json, к примеру): (string)$response->getContents(). Чаще всего в коде Joomla встречается именно такой вариант. Однако, есть и вариант с перемещением указателя чтения на начало потока:
// Получили ответ в виде потока$stream = $response->getBody();// "перемотали" на начало$stream->rewind();// Получили строковый ответ$json = $stream->getContents();
В итоге результат одинаковый.@joomlafeed#joomla #разработка #php

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

Dgikar

  • Захожу иногда
  • 192
  • 3 / 0
  • Я только учусь
Надумал я поставить на самописный шаблон кнопочки плавной прокрутки вверх, вниз и к прочтению. Порывшись в Инете, нашел одно (устраивающее меня) решение. Поставил на сайт, но кнопка "вниз" почему-то постоянно в display: none...

Что сделано:
1) в index.php, перед </body> прописал это:
Спойлер
[свернуть]

2) в отдельный JS файл прописал это:
Спойлер
[свернуть]

3) в CSS, вот это:
Спойлер
[свернуть]

Кнопки "Вверх" и "Продолжить просмотр", работают как часики, а вот кнопка "Вниз" никак (ни при какой высоте промотанного материала на сайте) не хочет появляться...

Подскажите плз что не так в коде? В JS - очень слаб

Заранее благодарю за ответы!
« Последнее редактирование: 22.11.2018, 00:12:38 от Dgikar »
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Потому что у вас вот этот код

Код
   if ((jQuery(window).scrollTop() + document.body.clientHeight + 250) >= jQuery(window).height()) {
        jQuery("#ToBottom").fadeOut("slow");
    }

При высоте окна больше чем 250 пкс кнопка ToBottom что делает? Правильно, fadeOut, скрывается.

Возьмите любой плагин квери, к примеру мой любимый https://github.com/kswedberg/jquery-smooth-scroll
Указываете ID у нужного элемента и параметр href у ссылки и прокрутка работает
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Dgikar

  • Захожу иногда
  • 192
  • 3 / 0
  • Я только учусь
Возьмите любой плагин квери, к примеру мой любимый https://github.com/kswedberg/jquery-smooth-scroll
Т. е. к тому коду прикрутить часть кода который Вы советуете?

Просто хотелось бы уже остановиться на коде, который я показал выше... Вы можете поправить этот код?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
В вашем случае проще отказаться от кастомного кода и использовать плагин, инструкция к нему есть по ссылке, он прост и работает. Если вы не понимаете в JS (без обид) то проще использовать готовое и на 100% рабочее решение
Указываете ID объектов куда нужно прокручивать, указываете у ссылки на этот объект нужный href, у всех ссылок указываете единый класс и его прописываете в JS
Код
$('.scroll').smoothScroll({
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Dgikar

  • Захожу иногда
  • 192
  • 3 / 0
  • Я только учусь
В вашем случае проще отказаться от кастомного кода ...
Если вы не понимаете в JS (без обид)...
Да какие обиды! Я же сказал что очень слаб в JS! Поэтому, когда что-то делаю, не просто кпопипастю, а пытаюсь понять, что, где, да как и почему...

Просто код (точнее то, что получается на морде сайта) который я выложил выше, очень подходит мне + я немного в нем разобрался + сам код JS короткий...

Одним словом, очень прошу Вас помочь мне ИМЕННО с этим кодом... Если можете! Спасибо!
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Одним словом, очень прошу Вас помочь мне ИМЕННО с этим кодом... Если можете! Спасибо!
Так я уже указал на ошибку в этом коде, не зная сайта трудно добавить что еще
При прокрутке ссылка на боттом скрывается, я это прописал выше.
Дальше читайте документацию и более ничем помочь не могу, если хотите разбираться самостоятельно (что очень похвально)

Грубо говоря - вам не нужно скрывать ссылку на боттом при прокрутке (код выше) чтобы сработало событие
jQuery("#ToBottom").click(function () {
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Dgikar

  • Захожу иногда
  • 192
  • 3 / 0
  • Я только учусь
Я изменил код указанный Вами
Код
if ((jQuery(window).scrollTop() + document.body.clientHeight + 250) >= jQuery(window).height()) {
        jQuery("#ToBottom").fadeOut("slow");
    }
на этот:
Код
    if ((jQuery(window).scrollTop() + document.body.clientHeight) >= jQuery(window).height()) {
        jQuery("#ToBottom").fadeIn("slow");
    }   else {
        jQuery("#ToBottom").fadeOut("slow");
    }
Кнопка появилась, но достигая дна сайта, она не исчезает...
*

Dgikar

  • Захожу иногда
  • 192
  • 3 / 0
  • Я только учусь
В общем, методом научного тыка, получилось у меня решить эту задачу!

JS код выглядит вот так:
Спойлер
[свернуть]
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Ну и отлично, вместо готового решения сами написали себе рабочий костыль (в хорошем смысле этого слова).
Абсолютно правильный подход к разработке.
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[РЕШЕНО]Скрыть пункт меню на мобильных устройствах

Автор lexxbry

Ответов: 16
Просмотров: 7416
Последний ответ 23.05.2023, 07:22:49
от geral
Не сворачивается Offcanvas Menu Helix3, якорная ссылка. Landing Page - РЕШЕНО

Автор alekshavan

Ответов: 21
Просмотров: 4438
Последний ответ 15.10.2022, 10:18:46
от forsight
[Решено] Модули шаблона Helix 3

Автор Egoritch

Ответов: 3
Просмотров: 1006
Последний ответ 27.05.2021, 13:26:52
от Egoritch
[Решено] CSS-класс заголовка модуля

Автор schel4ok

Ответов: 36
Просмотров: 18859
Последний ответ 06.04.2021, 23:35:20
от Wak
[РЕШЕНО]Обернуть в тег &lt;a&gt;

Автор AlexB

Ответов: 4
Просмотров: 787
Последний ответ 21.11.2020, 20:11:51
от AlexB