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

busik

  • Захожу иногда
  • 186
  • 7 / 0
Никак не могу вывести три модуля в одну строку внизу сайта (так, чтобы были посередине и равной ширины). Перепробовал все варианты.

Сейчас стоит код

<div id="bottomwide">
      <div id="bottom" class="clearfix">
         <div class="pos14"><jdoc:include type="modules" name="position-14" style="xhtml" /></div>
         <div class="pos15"><jdoc:include type="modules" name="position-15" style="xhtml" /></div>
         <div class="pos16"><jdoc:include type="modules" name="position-16" style="xhtml" /></div>
      </div>
</div>

Для них в CSS прописано следующее

#bottomwide {width:100%; margin: auto; position: relative; background-color:#333;}
#bottom {max-width:980px; margin: auto; height:100%; padding-bottom:10px;  position: relative; background: none;}
#bottom:before,#bottom:after {content:"";display:table;}
.pos14  h3, .pos15  h3, .pos16  h3 {color:#fff; font-weight:bold; font-family: 'tahoma', sans-serif; font-size:16px; margin:0px; text-shadow:none;}
.pos14, .pos15, .pos16 { background:none; color:#fff; border:0; border-radius:5px; float: left; padding-left: 3%;width: 30%; text-shadow: 0 1px #555;}

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

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
.pos14, .pos15, .pos16 {float:left;}
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
.pos14, .pos15, .pos16 {float:left;}

Чего-то не помогло
*

Ilhom666

  • Завсегдатай
  • 1384
  • 184 / 0
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
Забыл уточнить - модули нужны для вывода в футере
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
да без разницы, где
не помогло - смотреть конкретно уже надо, ссылку
*

darkghost

  • Живу я здесь
  • 2212
  • 97 / 0
Цитировать
... padding-left: 3%;width: 30%;
Если сложить и умножить на *3, то получится 99, в принципе должно работать. Вот только не вижу отступы между .pos14, .pos15, .pos16 . Без ссылки никак не разобраться 
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
Ну вот перепрописал все заново, и все равно модули стоят друг под другом, а не в строку. Вроде бы все правильно, уже и не знаю что и думать

вот код

<?php if($this->countModules('bottom1 or bottom2 or bottom3')) : ?>
   <div id="bottom123">
      <?php if($this->countModules('bottom1')) : ?>
         <div id="bottom1">
              <jdoc:include type="modules" name="bottom1" style="xhtml" />
         </div>
      <?php endif; ?>         
      <?php if($this->countModules('bottom2')) : ?>
         <div id="bottom2">
              <jdoc:include type="modules" name="bottom2" style="xhtml" />
         </div>
      <?php endif; ?>         
      <?php if($this->countModules('bottom3')) : ?>
         <div id="bottom3">
              <jdoc:include type="modules" name="bottom3" style="xhtml" />
         </div>
      <?php endif; ?>         
   </div>               
<?php endif; ?>   

Вот CSS

#bottom123 {
   width: 100%;
   display: inline-block;
   margin: 15px 0;
   padding: 0;
   height: auto;
}

#bottom1, #bottom2, #bottom3,
{
   float:left;
   width: 31.2%;
   margin: 0 1%;
   padding: 0;
}

Ну что же тут не так? :(

*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
#bottom123 {
   width: 100%;
   display: inline-block;
   margin: 15px 0;
   padding: 0;
   height: auto;
}

#bottom1, #bottom2, #bottom3,
{
   float:left;
   width: 31.2%;
   margin: 0 1%;
   padding: 0;
}
выделенное - лишнее.
сайт смотреть надо, чтобы дать более точный ответ
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
#bottom123 {
   width: 100%;
   display: inline-block;
   margin: 15px 0;
   padding: 0;
   height: auto;
}

#bottom1, #bottom2, #bottom3,
{
   float:left;
   width: 31.2%;
   margin: 0 1%;
   padding: 0;
}
выделенное - лишнее.
сайт смотреть надо, чтобы дать более точный ответ

Попробовал - что то не вышло
*

midav

  • Давно я тут
  • 926
  • 115 / 1
И первый и второй вариант кода работают . Во втором просто надо убрать запятую после #bottom3 . И свойство inline-block , хотя и с ним будет работать .
ссылка
Ответы на вопросы по CSS . Откройте для себя Firebug
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
Спасибо. Отвлекся на ловлю вирусов. Буду пробовать.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывести дочерние товары в самой карточке родительского товар VirtueMart

Автор aliallaxverdiev91

Ответов: 2
Просмотров: 2583
Последний ответ 03.03.2024, 11:32:49
от gtiosx
Как вывести Alt картинки в описание Lightbox?

Автор art22

Ответов: 2
Просмотров: 2509
Последний ответ 14.05.2023, 09:21:39
от sivers
Съезжают модули на странице материала

Автор sibdes

Ответов: 3
Просмотров: 2970
Последний ответ 24.04.2023, 12:50:21
от beliyadm
Через модуль html надо вставить три изображения в одну линию (горизонтально)

Автор dionisimuss

Ответов: 10
Просмотров: 1451
Последний ответ 21.12.2022, 20:59:52
от dionisimuss
Переопределенные модули подтягиваются из другого шаблона

Автор Vlad1

Ответов: 3
Просмотров: 853
Последний ответ 11.11.2021, 21:57:51
от Vlad1