Новости Joomla

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6.2PageBuilder Toolkit - это специализированный плагин для конструктора страниц Yootheme Pro, содержит набор различных утилит для ускорения процесса работы и отладки макета, множественные улучшения в интерфейсе, включая поддержку dark mode, подсказки, быстрая смена разрешения в окне просмотра и много чего еще.v.1.6.2 Что нового?- Индикатор статусов: теперь не просто показывает состояние запросов, но и делает автоматические попытки их отправки при кратковременных сбоях в сети, а если это не помогло, то переводит конструктор в ручной режим, что позволяет сохранит макет и настройки темы прежде чем вы потеряете все, что было сделано с момента последнего сохранения- Подсветка ошибок в макете: плагин анализирует код страницы и может автоматически подсвечивать data атрибуты с кучей мусора, которые попадают в код страницы при копипасте из Figma в TinyMCE (пригодится для старых макетов, в текущей работе плагин сам очищает код мусора). Также есть подсветка семантических ошибок сборки - дубли h1 тега на странице и вложенных друг в друга заголовков.- Улучшена поддержка будущего релиза Yootheme Pro 5 и редактора CodeMirror 6Плагин для русскоязычных пользователей доступен в каталоге расширений SovMart и распространяется за символическую плату (100р). Разработчики Joomla расширений и партнеры автора могут получить плагин бесплатно.Для работы плагина необходим конструктор страниц Yootheme Pro.Разработчик плагина - участник нашего сообщества Александр Судьбинов (@alexrevo), член официальной группы поддержки Yootheme Pro. Страница расширенияОписание на сайте автора@joomlafeed#joomla #yootheme

WT IndexNow плагин для Joomla - отправка страниц сайта на переиндексацию в поисковые системы

WT IndexNow плагин для Joomla - отправка страниц сайта на переиндексацию в поисковые системы

👩‍💻 WT IndexNow плагин для Joomla - отправка страниц сайта на переиндексацию в поисковые системы.Пакет плагинов, обеспечивающий ручную и автоматическую отправку url адресов Joomla в поисковые системы на переиндексацию по протоколу IndexNow. Согласно документации протокол поддерживают все крупнейшие поисковые системы, кроме Google. Протокол служит для получения от сайтов URL, которые нужно переиндексировать заново или проиндексировать в первый раз как можно быстрее. Отправка адресов сайта таким образом существенно ускорит индексацию нового или изменённого контента поисковыми системами.Поисковые системы по этому протоколу обмениваются друг с другом данными, поэтому отправив URL в одну из них вы сообщаете их сразу всем. Протокол IndexNow поддерживают:- Amazon- Microsoft Bing- Naver- Seznam.cz- Yandex - YepСуточный лимит URL - 10000 в сутки. Возможна отправка вручную и автоматически. Поддерживаются:- материалы и категории материалов Joomla- контакты и категории контактов Joomla- SW JProjects - компонент каталога расширений для Joomla- JoomShopping - компонент интернет-магазина для Joomla- Phoca Download - компонент каталога файлоа для Joomla- Phoca Cart - компонент интернет-магазина для Joomla- RadicalMart - компонент интернет-магазина для JoomlaПакет плагинов работает с Joomla 4.3+. Тестировался на Joomla 5 и Joomla 6.Смотреть видео:- ВК Видео- RuTubeСсылки:Страница расширенияGitHub расширенияРаздел Поддержка протокола IndexNow в справке Яндекса@joomlafeed#joomla #seo #indexnow

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

donpekc

  • Новичок
  • 3
  • 0 / 0
Всем привет. У меня есть форма, данные из нее по кнопке попадают в контроллер с заданием add
Код
function addRender()
{

    var renderName = $('.js-input-greeting').val();
    var catId = $('.js-input-greeting').val();
    var stage = $('.js-input-greeting').val();
 
  console.log('rendername:' + renderName );
 jQuery.ajax({
        url:"index.php?option=com_helloworld&task=default.add",
        type:'POST',
        data: {name : renderName},


        success:function()
       
        {
            console.log('success ajax');
        }
    });
}

Контроллер default.php в функции add() принимает Post запрос

Код
class HelloWorldControllersDefault extends JControllerLegacy
{

    public function add() {

        $app = JFactory::getApplication();
        $jinput = JFactory::getApplication()->input;

        $rdata = $jinput->post->get('name', '');


        $model = $this->getModel('add', 'add') ;

        $model->setState('name', $rdata);



           
    }

В модель add.php отправляет состояние с данными из post запроса. Модель получает состояние и записывает данные в таблицу __helloworld в колонку greeting
Код
class HelloWorldModelAdd extends JModelItem
{



public function store(){

$rdata = $this->getState('name');
        $db = JFactory::getDbo();       
$query = $db->getQuery(true);


$query
    ->insert($db->quoteName('#__helloworld'))
    ->columns('greeting')
    ->values($rdata);

$db->setQuery($query);
$db->execute();
}
}

Только что-то в базе ничего не происходит. Мне кажется я поплыл на моменте передачи данных в модель, а может вообще поплыл с момента отправки данных AJAX в контроллер. Помогите пожалуйста, бьюсь с этим уже третий день. Форум весь облазил, много интересного нашел, но все равно данные не добавляются
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
А у тебя выполняется функция store?
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
Потому что вы
1. неправильно получаете модель:
2. Зачем то устанавливаете состояние модели
3. Не вызываете метод store

Контроллер
Код: php
public function add() {
  $model = $this->getModel('add', 'HelloWorldModel') ;
  $model->store($this->input->post->get('name'));
}

Модель:

Код: php
public function store($name){
$query = $this->getDbo()->getQuery(true)
->insert($db->quoteName('#__helloworld'))
->columns('greeting')
->values($name);
$this->getDbo()->setQuery($query)->execute();
}
« Последнее редактирование: 23.04.2017, 18:37:39 от Aleks.Denezh »
*

donpekc

  • Новичок
  • 3
  • 0 / 0
Потому что вы
1. неправильно получаете модель:
2. Зачем то устанавливаете состояние модели
3. Не вызываете метод store

Контроллер
Код: php
public function add() {
  $model = $this->getModel('add', 'HelloWorldModel') ;
  $model->store($this->input->post->get('name'));
}

Модель:

Код: php
public function store($name){
$query = $this->getDbo()->getQuery(true)
->insert($db->quoteName('#__helloworld'))
->columns('greeting')
->values($name);
$this->getDbo()->setQuery($query)->execute();
}


Спасибо! но что-то зараза все равно не выполняется.. Как проверить вообще срабатывает ли контроллер к которому я обращаюсь через task=controller_name.task_name
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
вбиваете в строке браузера: ваш_сайт/index.php?option=com_helloworld&task=default.add и смотрите что выдаст.. можете расставить echo в контроллерах что бы посмотреть срабатывает что то или нет!
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
*

donpekc

  • Новичок
  • 3
  • 0 / 0
HelloWorldControllersDefault - ошибка в названии класса. HelloWorldControllerDefault правильно.

Спасибо! в этом была проблема, теперь мне пишет, что Column count doesn't match value count at row 1 SQL=INSERT INTO . Но это уже прогресс, значит модель срабатывает, видно я в sql запросе накосячил

Всем огромное спасибо! Теперь все получилось и работает! Я даже не верю, что это сделал, зато теперь хоть немного понимаю, как делать свой компонент. Ошибку в INSERT запросе исправил и дополнил данными. Сделал, как написано в документации Joomla, если кому понадобится то вот тут https://docs.joomla.org/Inserting,_Updating_and_Removing_data_using_JDatabase

Код
$columns = array('greeting', 'catid', 'stage', 'created', 'render_intro');
$values = array($db->quote($name), $db->quote($catid), $db->quote($stage), $db->quote($date), $db->quote($path));
  $query = $this->getDbo()->getQuery(true);
$query->insert($db->quoteName('#__helloworld'))
->columns($db->quoteName($columns))
->values(implode(',', $values));
$this->getDbo()->setQuery($query)->execute();

Теперь все работает. Спасибо еще раз
« Последнее редактирование: 24.04.2017, 14:08:47 от donpekc »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Отправка файлов через ajax в модуль Joomla

Автор hemicide

Ответов: 19
Просмотров: 2341
Последний ответ 11.04.2022, 08:44:33
от sivers
Применение ajax (Аякс) в модуле Joomla

Автор tm2010

Ответов: 34
Просмотров: 5430
Последний ответ 26.09.2020, 09:38:35
от b2z
ajax проверку на вход. В стандартном модуле входа?

Автор Dolphin4ik_1

Ответов: 4
Просмотров: 795
Последний ответ 23.07.2020, 15:03:57
от sivers
Обработка AJAX в компоненте Joomla!3

Автор balancer

Ответов: 33
Просмотров: 12067
Последний ответ 23.07.2020, 07:45:53
от Dolphin4ik_1
Модель для представления, которое показывает списки данных разных типов

Автор borro

Ответов: 27
Просмотров: 1298
Последний ответ 06.05.2020, 11:57:12
от Septdir