Новости Joomla

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+)

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+)

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+). При отображении форм компонента в админке раньше разработчикам нужно было описывать скрытые поля в лейаутах. И выглядело это так:

<?php     // Это файл в /layouts/components/com_component/your_layout.php?><input type="hidden" name="task" value=""><input type="hidden" name="return" value="<?php echo $input->getBase64('return'); ?>"><input type="hidden" name="forcedLanguage" value="<?php echo $input->get('forcedLanguage', '', 'cmd'); ?>"><?php echo HTMLHelper::_('form.token'); ?>
Начиная с Joomla 5.3 добавлен новый способ добавления таких полей (их называют control fields) - программно. И теперь это можно сделать просто в Controller / View.
// В Controller/View добавляем поля$this->form  ->addControlField('task', '')  ->addControlField('return', $input->getBase64('return', ''))  ->addControlField('forcedLanguage', $forcedLanguage);
А в layout'е просто используем метод
renderControlFields()
// В layout формыecho $this->form->renderControlFields();
Многие компоненты ядра уже используют этот подход. Соответствующий PR был принят в Joomla 5.3 осенью 2024г.Смотреть
Pull Request@joomlafeed#joomla #разработка #php

JoomGallery 4.1.0 - компонент галереи изображений для Joomla

JoomGallery 4.1.0 - компонент галереи изображений для Joomla

Новая итерация компонента продолжает развиваться, ведь с v.4.x компонент был переписан практически с нуля.

v.4.1.0. Что нового?

Редактирование метаданных изображений. Теперь метаданные можно не только читать, но и напрямую редактировать и записывать обратно в изображение JPG. Поддерживаются данные EXIF ​​и IPTC.

Полная совместимость с Joomla! 4.x, 5.x и 6.x. Компонент почистили от устаревших методов в коде.

Заметно ускорили загрузку больших галерей. Списки в админке, особенно для очень больших галерей ( >30 000 изображений), теперь загружаются значительно быстрее.

Несколько сеток lightGallery на одной странице. Будь то плагины контента или модули изображений: теперь вы можете отображать несколько галерей или категорий на одной странице без каких-либо ограничений.

Множество мелких исправлений ошибок и оптимизаций.

Сайт проекта

GitHub расширения

Скачать

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

Lemonez

  • Захожу иногда
  • 225
  • 2 / 2
Стилизация checkbox в форме
« : 09.10.2019, 22:07:09 »
Здравствуйте! Как мне стилизовать checkbox? Вот здесь: https://cbsystems.ru/raschjot-stoimosti-sajta (если выбрать любой пункт, то появятся чекбоксы)
Хотелось бы их увеличить перекрасить и т.п. Подскажите, пожалуйста.
*

Lemonez

  • Захожу иногда
  • 225
  • 2 / 2
Re: Стилизация checkbox в форме
« Ответ #1 : 09.10.2019, 22:37:47 »
Вот есть такая конструкция:
/* прячем input checkbox */
input[type="checkbox"] {
  display: none;
}

/* стили для метки */
label {
  color: #000;
  cursor: default;
  font-weight: normal;
  line-height: 30px;
  padding: 10px 0;
  vertical-align: middle;
}

/* формируем внешний вид чекбокса в псевдоэлементе before */
label:before {
  content: " ";
  color: #000;
  display: inline-block;
  font: 20px/30px Arial;
  margin-right: 15px;
  position: relative;
  text-align: center;
  text-indent: 0px;
  width: 30px;
  height: 30px;
  background: #FFF;
  border: 1px solid #e3e3e3;
  border-image: initial;
  vertical-align: middle;
}

/* вариации внешнего вида в зав-ти от статуса checkbox */
/* checked */
input:checked + label:before {
  content: "x";
}
/* disabled */
input:disabled + label:before {
  background: #eee;
  color: #aaa;
}
Но она почему-то не отмечает отмеченный чекбокс. Т.е. это input:checked + label:before {
  content: "x";
} почему-то не работает.
*

sivers

  • Живу я здесь
  • 2589
  • 359 / 0
Re: Стилизация checkbox в форме
« Ответ #2 : 09.10.2019, 22:46:04 »
почему-то не работает.
чтоб работало <input> должен быть перед <label>
Код
<div>
   <input...>
   <label...>
</div>

Вот решение на бутстрапе, но у вас работать не будет, потому что это для 4-й версии. Но можете посмотреть как там сделано:
Спойлер
[свернуть]
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Lemonez

  • Захожу иногда
  • 225
  • 2 / 2
Re: Стилизация checkbox в форме
« Ответ #3 : 09.10.2019, 22:58:40 »
чтоб работало <input> должен быть перед <label>
Код
<div>
   <input...>
   <label...>
</div>

Вот решение на бутстрапе, но у вас работать не будет, потому что это для 4-й версии. Но можете посмотреть как там сделано:
Спойлер
[свернуть]
Спасибо за совет, но я не силен в php))). Как тут поменять их местами (input и label)? Вот код формы:
  if ($pos) {
            $html .= '<label class="qf3label qfempty"></label>';
        } else {
            $html .= $this->getLabel($field, $rand, 'qf3label qfbefore');
        }

        $html .= '<div class="qfchkbx"><input class="checkbox" id="' . $rand . '" type="checkbox" name="chbx"' . $this->attr(array('class', 'custom', 'checked', 'required'), $field);
*

sivers

  • Живу я здесь
  • 2589
  • 359 / 0
Re: Стилизация checkbox в форме
« Ответ #4 : 09.10.2019, 23:08:37 »
Вот так, вероятно...
Код
          $html .= '<div class="qfchkbx"><input class="checkbox" id="' . $rand . '" type="checkbox" name="chbx"' . $this->attr(array('class', 'custom', 'checked', 'required'), $field);

  if ($pos) {
            $html .= '<label class="qf3label qfempty"></label>';
        } else {
            $html .= $this->getLabel($field, $rand, 'qf3label qfbefore');
        }
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Lemonez

  • Захожу иногда
  • 225
  • 2 / 2
Re: Стилизация checkbox в форме
« Ответ #5 : 10.10.2019, 00:11:10 »
Вот так, вероятно...
Код
          $html .= '<div class="qfchkbx"><input class="checkbox" id="' . $rand . '" type="checkbox" name="chbx"' . $this->attr(array('class', 'custom', 'checked', 'required'), $field);

  if ($pos) {
            $html .= '<label class="qf3label qfempty"></label>';
        } else {
            $html .= $this->getLabel($field, $rand, 'qf3label qfbefore');
        }
Спасибо. Но так не работает.
*

Lemonez

  • Захожу иногда
  • 225
  • 2 / 2
Re: Стилизация checkbox в форме
« Ответ #6 : 10.10.2019, 00:12:19 »
Тему можно закрывать, в форме присутствовал измененный чекбокс - он красивый и удобный в отличие от оригинального. Так, что решение не понадобилось.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

По форме FOXCONTACT !

Автор aleminov

Ответов: 0
Просмотров: 1359
Последний ответ 16.10.2014, 14:42:30
от aleminov
Заставить в FormCalc работать checkbox

Автор Phoenix-ann

Ответов: 2
Просмотров: 1879
Последний ответ 12.10.2013, 21:21:18
от kozhenevsky
Прикрепление файла в форме?

Автор uniqcle

Ответов: 1
Просмотров: 2419
Последний ответ 04.03.2010, 00:21:48
от ZyX