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

Dimir

  • Захожу иногда
  • 426
  • 13 / 1
Код
JInstaller::install: Ошибка SQL DB function failed with error number 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'TYPE=MyISAM' at line 41 SQL=CREATE TABLE IF NOT EXISTS jos_alpha_userpoints ( `id` int(11) NOT NULL auto_increment, `userid` int(11) NOT NULL default '0', `referreid` varchar(160) NOT NULL default '', `upnid` varchar(25) NOT NULL default '', `points` int(11) NOT NULL default '0', `max_points` int(11) NOT NULL default '0', `last_update` datetime NOT NULL default '0000-00-00 00:00:00', `referraluser` varchar(160) NOT NULL default '', `referrees` int(11) NOT NULL default '0', `blocked` tinyint(1) NOT NULL default '0', `birthdate` date NOT NULL default '0000-00-00', `avatar` varchar(255) NOT NULL default '', `levelrank` int(11) NOT NULL default '0', `leveldate` date NOT NULL default '0000-00-00', `gender` tinyint(1) NOT NULL default '0', `aboutme` varchar(250) NOT NULL default '', `website` varchar(150) NOT NULL default '', `phonehome` varchar(30) NOT NULL default '', `phonemobile` varchar(30) NOT NULL default '', `address` varchar(150) NOT NULL default '', `zipcode` varchar(10) NOT NULL default '', `city` varchar(50) NOT NULL default '', `country` varchar(30) NOT NULL default '', `education` varchar(30) NOT NULL default '', `graduationyear` char(4) NOT NULL default '', `job` VARCHAR( 50 ) NOT NULL DEFAULT '', `facebook` varchar(150) NOT NULL default '', `twitter` varchar(150) NOT NULL default '', `icq` varchar(50) NOT NULL default '', `aim` varchar(50) NOT NULL default '', `yim` varchar(50) NOT NULL default '', `msn` varchar(50) NOT NULL default '', `skype` varchar(50) NOT NULL default '', `gtalk` varchar(50) NOT NULL default '', `xfire` varchar(50) NOT NULL default '', `profileviews` int(11) NOT NULL default '0', PRIMARY KEY (`id`), INDEX (referreid), UNIQUE KEY `userid` (`userid`) ) TYPE=MyISAM;
SQL =
CREATE TABLE IF NOT EXISTS jos_alpha_userpoints (
  `id` int(11) NOT NULL auto_increment,
  `userid` int(11) NOT NULL default '0',
  `referreid` varchar(160) NOT NULL default '',
  `upnid` varchar(25) NOT NULL default '',
  `points` int(11) NOT NULL default '0',
  `max_points` int(11) NOT NULL default '0',
  `last_update` datetime NOT NULL default '0000-00-00 00:00:00',
  `referraluser` varchar(160) NOT NULL default '',
  `referrees` int(11) NOT NULL default '0',
  `blocked` tinyint(1) NOT NULL default '0',
  `birthdate` date NOT NULL default '0000-00-00',
  `avatar` varchar(255) NOT NULL default '',
  `levelrank` int(11) NOT NULL default '0',
  `leveldate` date NOT NULL default '0000-00-00',
  `gender` tinyint(1) NOT NULL default '0',
  `aboutme` varchar(250) NOT NULL default '',
  `website` varchar(150) NOT NULL default '',
  `phonehome` varchar(30) NOT NULL default '',
  `phonemobile` varchar(30) NOT NULL default '',
  `address` varchar(150) NOT NULL default '',
  `zipcode` varchar(10) NOT NULL default '',
  `city` varchar(50) NOT NULL default '',
  `country` varchar(30) NOT NULL default '',
  `education` varchar(30) NOT NULL default '',
  `graduationyear` char(4) NOT NULL default '',
  `job` VARCHAR( 50 ) NOT NULL DEFAULT '',
  `facebook` varchar(150) NOT NULL default '',
  `twitter` varchar(150) NOT NULL default '',
  `icq` varchar(50) NOT NULL default '',
  `aim` varchar(50) NOT NULL default '',
  `yim` varchar(50) NOT NULL default '',
  `msn` varchar(50) NOT NULL default '',
  `skype` varchar(50) NOT NULL default '',
  `gtalk` varchar(50) NOT NULL default '',
  `xfire` varchar(50) NOT NULL default '',
  `profileviews` int(11) NOT NULL default '0',
  PRIMARY KEY  (`id`),
  INDEX (referreid),
  UNIQUE KEY `userid` (`userid`)
) TYPE=MyISAM;
Компонент Установить: Ошибка SQL или нечитаемый файл SQL. DB function failed with error number 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'TYPE=MyISAM' at line 41 SQL=CREATE TABLE IF NOT EXISTS jos_alpha_userpoints ( `id` int(11) NOT NULL auto_increment, `userid` int(11) NOT NULL default '0', `referreid` varchar(160) NOT NULL default '', `upnid` varchar(25) NOT NULL default '', `points` int(11) NOT NULL default '0', `max_points` int(11) NOT NULL default '0', `last_update` datetime NOT NULL default '0000-00-00 00:00:00', `referraluser` varchar(160) NOT NULL default '', `referrees` int(11) NOT NULL default '0', `blocked` tinyint(1) NOT NULL default '0', `birthdate` date NOT NULL default '0000-00-00', `avatar` varchar(255) NOT NULL default '', `levelrank` int(11) NOT NULL default '0', `leveldate` date NOT NULL default '0000-00-00', `gender` tinyint(1) NOT NULL default '0', `aboutme` varchar(250) NOT NULL default '', `website` varchar(150) NOT NULL default '', `phonehome` varchar(30) NOT NULL default '', `phonemobile` varchar(30) NOT NULL default '', `address` varchar(150) NOT NULL default '', `zipcode` varchar(10) NOT NULL default '', `city` varchar(50) NOT NULL default '', `country` varchar(30) NOT NULL default '', `education` varchar(30) NOT NULL default '', `graduationyear` char(4) NOT NULL default '', `job` VARCHAR( 50 ) NOT NULL DEFAULT '', `facebook` varchar(150) NOT NULL default '', `twitter` varchar(150) NOT NULL default '', `icq` varchar(50) NOT NULL default '', `aim` varchar(50) NOT NULL default '', `yim` varchar(50) NOT NULL default '', `msn` varchar(50) NOT NULL default '', `skype` varchar(50) NOT NULL default '', `gtalk` varchar(50) NOT NULL default '', `xfire` varchar(50) NOT NULL default '', `profileviews` int(11) NOT NULL default '0', PRIMARY KEY (`id`), INDEX (referreid), UNIQUE KEY `userid` (`userid`) ) TYPE=MyISAM;
SQL =
CREATE TABLE IF NOT EXISTS jos_alpha_userpoints (
  `id` int(11) NOT NULL auto_increment,
  `userid` int(11) NOT NULL default '0',
  `referreid` varchar(160) NOT NULL default '',
  `upnid` varchar(25) NOT NULL default '',
  `points` int(11) NOT NULL default '0',
  `max_points` int(11) NOT NULL default '0',
  `last_update` datetime NOT NULL default '0000-00-00 00:00:00',
  `referraluser` varchar(160) NOT NULL default '',
  `referrees` int(11) NOT NULL default '0',
  `blocked` tinyint(1) NOT NULL default '0',
  `birthdate` date NOT NULL default '0000-00-00',
  `avatar` varchar(255) NOT NULL default '',
  `levelrank` int(11) NOT NULL default '0',
  `leveldate` date NOT NULL default '0000-00-00',
  `gender` tinyint(1) NOT NULL default '0',
  `aboutme` varchar(250) NOT NULL default '',
  `website` varchar(150) NOT NULL default '',
  `phonehome` varchar(30) NOT NULL default '',
  `phonemobile` varchar(30) NOT NULL default '',
  `address` varchar(150) NOT NULL default '',
  `zipcode` varchar(10) NOT NULL default '',
  `city` varchar(50) NOT NULL default '',
  `country` varchar(30) NOT NULL default '',
  `education` varchar(30) NOT NULL default '',
  `graduationyear` char(4) NOT NULL default '',
  `job` VARCHAR( 50 ) NOT NULL DEFAULT '',
  `facebook` varchar(150) NOT NULL default '',
  `twitter` varchar(150) NOT NULL default '',
  `icq` varchar(50) NOT NULL default '',
  `aim` varchar(50) NOT NULL default '',
  `yim` varchar(50) NOT NULL default '',
  `msn` varchar(50) NOT NULL default '',
  `skype` varchar(50) NOT NULL default '',
  `gtalk` varchar(50) NOT NULL default '',
  `xfire` varchar(50) NOT NULL default '',
  `profileviews` int(11) NOT NULL default '0',
  PRIMARY KEY  (`id`),
  INDEX (referreid),
  UNIQUE KEY `userid` (`userid`)
) TYPE=MyISAM;
Невозможно удалить выбранный файл: 'tick.png'
-==Dimir==-
*

migus

  • Moderator
  • 992
  • 144 / 0
  • OPEN THE BOX
Re: ошибка при установке v 1.5.13
« Ответ #1 : 11.08.2012, 20:54:57 »
Попробуйте в скрипте все
Код: php
TYPE=MyISAM
заменить на
Код: php
ENGINE=MyISAM
- удачи ;)
"The Lord Of A SandBox"
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

AlphaUserPoints - Ошибка

Автор Alexander_Fyodorov

Ответов: 0
Просмотров: 3249
Последний ответ 25.11.2019, 13:55:17
от Alexander_Fyodorov
Обнаружена ошибка

Автор Сergei

Ответов: 6
Просмотров: 5347
Последний ответ 31.07.2016, 08:22:24
от SolopoV
Ошибка при загрузке авы

Автор Katya

Ответов: 3
Просмотров: 1567
Последний ответ 21.05.2015, 12:48:12
от migus
alpha userpoints ошибка при установке правил 1136

Автор terveg

Ответов: 1
Просмотров: 2134
Последний ответ 29.09.2014, 10:15:37
от migus
AlphaUserPoints ошибка

Автор Argin

Ответов: 3
Просмотров: 2239
Последний ответ 11.06.2013, 10:00:38
от migus