Новости Joomla

Модификация WT JShopping products anywhere - Uikit макетИтак, дано: музыкальный журнал, в котором...

Модификация WT JShopping products anywhere - Uikit макетИтак, дано: музыкальный журнал, в котором...

Модификация WT JShopping products anywhere - Uikit макетИтак, дано: музыкальный журнал, в котором представлены новости, интервью, рецензии и есть небольшой магазин на JoomShopping. Возникла необходимость внутри Joomla статей вставлять упоминание релиза и кнопочку «добавить в корзину». Я взял плагин WT JShopping products anywhere Сергея Толкачева (@webtolkru). Плагин отображает название товара и ссылку. При помощи напильника, ИИ и навыков вёрстки появился Uikit макет для шаблонов на базе Yootheme Pro.Учитываается мобильная версия - телефоны и ipad.Кнопка добавления в корзину работает по Ajax и появляется всплывающее окно (Notification Bar от Uikit) с информацией.Пока это базовый вариант, требующий доведения до лоска, однако он уже работает и его можно применять на проектах.Взять макет можно здесь.А плагин вставки товаров в материалы можно забрать здесь.Приветствуется доведение до ума и оформление в виде PR.

WT Content Image Gallery v.1.2.3 - плагин галереи изображений для Joomla

WT Content Image Gallery v.1.2.3 - плагин галереи изображений для Joomla

👩‍💻 WT Content Image Gallery v.1.2.3 - плагин галереи изображений для Joomla.Пакет плагинов галереи изображений и видео для вставки в материалы и модули Joomla, а так же везде, где работают плагины группы content. Поддержка собственных макетов вывода для галерей. Смешанные фото+видео галереи. Плагин создан как замена Simple Image Gallery и поддерживает синтаксис {gallery}{/gallery}.👩‍💻 v.1.2.3. Что нового?- Обработка вступительного и полного текста для материалов Joomla. Добавлена обработка шорткодов в полном и вступительном текстах материалов Joomla.- Системные требования. Повышены минимальные требования до Joomla 5 и PHP 8.1.- Мелкие правки. Исправлена ошибка работы макета по умолчанию в плагине контента.- Joomla 6. Пакет плагинов успешно протестирован на Joomla 6.Страница расширения.GitHub расширенияJoomla Extensions Directory@joomlafeed#joomla #расширения

Совет по Joomla: несколько значений по умолчанию в XML-формах для стандартных полей типа list

👩‍💻 Совет по Joomla: несколько значений по умолчанию в XML-формах для стандартных полей типа list.При работе над плагином возникла необходимость указать стандартный набор из нескольких элементов стандартного поля списка. И хотелось указать их в стандартном же атрибуте default для полей. Когда это нужно?Когда Ваши пользователи устанавливают плагин и НЕ заходят в настройки - в коде вы можете использовать значения по умолчанию с помощью класса Registry (писал об этом ранее) и всегда быть уверенным, что хоть какие-то жизненно необходимые параметры к вам придут всегда. 🧐 Но как сделать то же самое для интерфейса админки?Пользователя нужно направлять, предлагать очевидный работоспособный сценарий для начала, а дальше он уже сам разберется. Когда человек заходит в параметры свежеустановленного плагина в Form ещё нет данных и параметры по умолчанию выставляются из атрибутов default в xml-полях.
<field name="showdesc" type="radio"                       label="PLG_CFI_PARAM_SHOWDESC"                       class="btn-group btn-group-yesno"                       default="1">                    <option value="0">JNO</option>                    <option value="1">JYES</option>                </field>
Здесь по умолчанию будет включено "Да". И если пользователь не переключит параметр, то при сохранении мы ожидаемо получим "да" в params плагина.Для поля списков type=&quot;list&quot; можно указать значение по умолчанию и многие знают, что его можно указать только одно.
<field type="list"                       name="article_fields"                       label="article_fields"                       description="article_fields_desc"                       layout="joomla.form.field.list-fancy-select"                       multiple="true"                       default="id"                >                    <option value="id">id</option>                    <option value="title">title</option>                    <option value="alias">alias</option>                    <option value="introtext">introtext</option>                    <option value="fulltext">fulltext</option>                    <option value="state">state</option></field>
Но у нас поле с множественным выбором (атрибут multiple) и хотелось бы указать несколько значений по умолчанию...Оказывается, так можно сделать. Для этого в атрибуте default нужно указать json с нужными параметрами в виде {int}key : {string} value.Например, default='{"0":"id","1":"title"}'.
<field type="list"                       name="article_fields"                       label="article_fields"                       description="article_fields_desc"                       layout="joomla.form.field.list-fancy-select"                       multiple="true"                       default='{"0":"id","1":"title"}'                >                    <option value="id">id</option>                    <option value="title">title</option>                    <option value="alias">alias</option>                    <option value="introtext">introtext</option>                    <option value="fulltext">fulltext</option>                    <option value="state">state</option></field>
⚠️ Обратите внимание на кавычки! Поскольку json_decode не понимает одинарные кавычки собственно json нужно писать с двойными, а значение для атрибута default писать в одинарные.🙏 За подсказанное решение огромное спасибо участникам нашего сообщества - разработчикам Дмитрию Васюкову (@fictionlabs) и Игорю Бердичевскому (@septdir).@joomlafeed#joomla #разработка #webdev #development

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

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Помогите при создании компонента.

модель
Код
<?php
Defined ('_JEXEC')  or  die();
jimport( 'joomla.application.component.model' );
 
class TecdocModelArticle extends JModel
{
  
        function getArticle()
        {
 
                $option = array(); //prevent problems
                $option['driver']   = 'mysql';            // Database driver name
                $option['host']     = 'localhost';    // Database host name
                $option['user']     = '***';       // User for database authentication
                $option['password'] = '****';   // Password for database authentication
                $option['database'] = '****';      // Database name
                $option['prefix']   = '';             // Database prefix (may be empty)
                $db = & JDatabase::getInstance( $option );
                $ordering       = 'LA_ART_ID';
                if    (isset($_GET['strid']) and isset($_GET['typida']))
                {
                $STR_ID = $_GET['strid'];
                $TYP_ID = $_GET['typida'];
                }
                $lngid = 16;
                $query = 'SELECT LA_ART_ID'
                                . ' FROM LINK_GA_STR'
                                . ' WHERE LGS_STR_ID ='.$STR_ID
                                . ' ORDER BY '.$ordering
                                ;
                $db->setQuery( $query );
                $LA_ART_ID = $db->loadResult();
                
                
                $ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;              
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();
                
                return $articlelist;
        }
}

сечас при етом коде выводитса одно значение из базы  ARTICLES  а надо щоб било много. Тоисть здесь
Код
$LA_ART_ID = $db->loadResult();
надо прописать loadObjectList и етот код
Код
$ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;              
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();

записать в цыкле пример
Код
foreach($LA_ART_ID as $LA_ART_ID) 
{
$ART_ID = $LA_ART_ID
}

чтобы переменная $ART_ID изменялась при каждом наступном
Код
$ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;              
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();


и в $articlelist попал весь масив





я понимаю как прописать на РНР час покажу НО не понимаю как вивести дание масива в joomla
Код
<? 
 
$result = mysql_query("
SELECT LA_ART_ID
FROM LINK_GA_STR
WHERE LGS_STR_ID = '$STR_ID' ",$db);
do {

$ART_ID = $myrow["LA_ART_ID"];
$LNG_ID = 16;

$result2= mysql_query("
SELECT ART_ARTICLE_NR, SUP_BRAND,
FROM ARTICLES
WHERE ART_ID = '$ART_ID' ",$db);

do {

printf ("", $myrow2["SUP_BRAND"] , $myrow2["ART_ARTICLE_NR"]);
}
while ($myrow2 = mysql_fetch_array($result2));
}

while ($myrow = mysql_fetch_array($result));

?>

Помогите пожалуйста.



*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #1 : 23.02.2011, 11:01:27 »
1. Ваш код потенциально подвержен SQL инъекции. Советую фильтровать переменные, которые Вы получаете  из $_GET и пользоваться при этом встроенными Joomla методами:
http://docs.joomla.org/Retrieving_data_from_GET_and_POST_requests

2. Честно, мне непонятна логика построения Вашей базы данных. Из того, что я вижу - она некорректна.

Из таблицы LINK_GA_STR Вы выбираете ОДИН конкртеный ID статьи LA_ART_ID, который принадлежит какой-то LGS_STR_ID. Затем Вы по этой LA_ART_ID выбираете из таблицы статей ARTICLES эту статью. Логично, что так будет делаться выборка только одной статьи и никак по другому тут не сделаешь.

3. То, что Вы предлагаете делать - это делать SELECT в цикле, и это в корне неверно. Вам нужно поменть логику построения базы данных, связей между таблицами.
*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #2 : 23.02.2011, 11:31:21 »
Из таблицы LINK_GA_STR Вы выбираете ОДИН конкртеный ID статьи LA_ART_ID, который принадлежит какой-то LGS_STR_ID. Затем Вы по этой LA_ART_ID выбираете из таблицы статей ARTICLES эту статью. Логично, что так будет делаться выборка только одной статьи и никак по другому тут не сделаешь.

Вы все правильно поняли! Только мне нужно из таблицы LINK_GA_STR
выбрать много ID. Если прописать $ db-> loadObjectList (); я получаю массив. Здесь все хорошо!

Теперь мне нужно по этому массиву который я получил, из таблицы артикулов товара ARTICLES по LA_ART_ID равное ART_ID
выбрать также массив уже немножко других артикулов с названиями товара и описанием.

если прописать
Код
$query = 'SELECT LA_ART_ID'
                                . ' FROM LINK_GA_STR'
                                . ' WHERE LGS_STR_ID ='.$STR_ID
                                . ' ORDER BY '.$ordering
                                ;
                $db->setQuery( $query );
                $LA_ART_ID = [b]$db->loadResult();[/b]
             
                $ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;               
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();                 
                return $articlelist;

то выводится только один артикул с описанием товара. А должно быть много!
я понимаю что нужно из таблицы LINK_GA_STR выбрать массив с помощью $ db-> loadObjectList ()

но как потом по массиву пройти чтобы выполнить второй запрос и чтобы он также вытащил массив.
где уже $ART_ID = $LA_ART_ID а $LA_ART_ID по очереди перебраные елементи масыва из первова запроса.
Код
$ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;               
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();

*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #3 : 23.02.2011, 11:36:26 »
я не могу изменить структуру базы. Я ее не создавал я ее только купил! На сайте на РНР это все я реализовал. хотелось создать компонент для Joomla
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #4 : 23.02.2011, 12:51:25 »
Вообщем, если Вы хотите делать так криво, тогда вот:

Код
$db->setQuery($query);
$LA_ART_ID = $db->loadObjectList();

// проход по массиву
foreach ($LA_ART_ID as $lartId)
{
               $query = 'SELECT ... WHERE ART_ID = '.$lartId->id;
}
$db->setQuery($query);
$articlelist = $db->loadObjectList();                
return $articlelist;

Но это конечно жестокий метод - это просто убийца базы.

Наверное можно ещё решить с помощью вложенных запросов

Код
$query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
. ' FROM ARTICLES'
. ' WHERE ART_ID = (SELECT LA_ART_ID'
. ' FROM LINK_GA_STR'
. ' WHERE LGS_STR_ID ='.$STR_ID)
. ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
. ' ORDER BY '.$ordering
;  

За точность и правильность не отчечаю, но идея должна быть понятна. В любом случае это все очень плохое программирование.
*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #5 : 23.02.2011, 14:44:13 »
Выводит только один элемент (артикул).
в $ articlelist попадает лишь один артикул. потому что foreach () проходит массив $ LA_ART_ID и в конце в переменную $ query попадает строка где $ lartId-> id имеет последний элемент из массива $ LA_ART_ID.

нужно взять код
$ db-> setQuery ($ query);
$ articlelist = $ db-> loadObjectList ();

также в цикл или прописать чтобы в $ articlelist в цикле дописовались элементы
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #6 : 23.02.2011, 16:13:46 »
Хе, тогда так:


foreach ($LA_ART_ID as $lartId)
{
$query 'SELECT ... WHERE ART_ID = '.$lartId->id;
$db->setQuery($query);
$article $db->loadObject();
$articlelist[]['SUP_BRAND'] = $article->SUP_BRAND;
$articlelist[]['ART_ARTICLE_NR'] = $article->ART_ARTICLE_NR;
}


Извращение не знает границ  ;D
*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #7 : 23.02.2011, 18:58:30 »
Всьоравно плохо ((
код файла default.php
Код
<?php  
defined('_JEXEC') or die('Restricted access');
?>
<table width="100%" cellspacing="0" cellpadding="0" border="0" style="margin-bottom:15px;">
<tr align="left" class="sectiontableheader">
        <td width="16%"><?php echo JText::_( 'NUMBER' ); ?></td>
        <td width="10%"><?php echo JText::_( 'DESCRIPTION' );?></td>
</tr>
<? foreach($this->article as $article)
{
?>

<tr id="tableheader_tr">
        <td><?php echo $article['ART_ARTICLE_NR']; ?></td>
        <td><?php echo $article['ART_COMPLETE_DES_TEXT']; ?></td>
</tr>

<? } ?>
</table>

и фрагмент кода как виводить!
Код
<table width="100%" cellspacing="0" cellpadding="0" border="0" style="margin-bottom:15px;">

<tr align="left" class="sectiontableheader">

        <td width="16%"> Номер</td>

        <td width="10%"> Опис</td>

</tr>



<tr id="tableheader_tr">

        <td></td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td>1433G</td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td></td>

        <td>Амортизатор</td>

</tr>





<tr id="tableheader_tr">

        <td></td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td>3358DG</td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td></td>

        <td>Амортизатор</td>

</tr>

может я не так вивожу в дефаулте переменные.
Виглядит так проходт цикл ы в шаблон подставляет только одну переменною. потом снова толька подставляэт другую ((( может запись в масив $articlelist както поменять ??
Спасибо!






Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Валидация форм средствами Joomla

Автор VETERINAR

Ответов: 29
Просмотров: 48725
Последний ответ 09.10.2013, 15:14:44
от digitalheart
Как написать системный плагин для Joomla 1.5

Автор Sergey2

Ответов: 2
Просмотров: 38651
Последний ответ 23.06.2013, 15:28:38
от l-key
[how to] Красота JHTML, или создание элементов формы с

Автор Professor

Ответов: 11
Просмотров: 24203
Последний ответ 27.12.2012, 18:14:38
от BaR
Плагин рейтинга чего угодно для Joomla 1.5

Автор Obmor

Ответов: 54
Просмотров: 31304
Последний ответ 18.12.2012, 15:01:55
от Raimonds
Как вы "въехали" в создание расширений?

Автор aanvale

Ответов: 4
Просмотров: 2621
Последний ответ 13.10.2012, 21:44:25
от passer