На форуме часто спрашивают, как в форму комментария добавить дополнительное поле, в которое пользователи смогли бы вводить некоторую информацию. Делать из компонента комментариев кухонный комбайн не хочется, но раз вопрос такой популярный - объясню, как это сделать малой кровью.
Давайте добавим два дополнительных поля в форму комментариев: Town (Город) и AcceptTerms (Согласен с правилами). Первое поле будет обычным текстовым, а второе будет принимать значения 1 или 0, т.е. пользователю нужно будет поставить галочку.
- Добавляем новые поля в таблицу jos_jcomments следующими SQL-запросами:
ALTER TABLE jos_jcomments ADD COLUMN `town` varchar(255);
и
ALTER TABLE jos_jcomments ADD COLUMN `acceptterms` tinyint(1) DEFAULT 0;
- Открываем файл jcomments.class.php и добавляем данные поля в класс JCommentsDB, например после строчки:
var $editor = '';
т.е. у нас получится вот так:
var $editor = '';
var $town = '';
var $acceptterms = '';
- Открываем файл jcomments.ajax.php и после строчки:
$comment->userid = $my->id ? $my->id : 0;
добавляем еще 2:
$comment->town = isset($values['town']) ? $values['town'] : '';
$comment->acceptterms = isset($values['acceptterms']) ? $values['acceptterms'] : 0;
- Открываем файл /tpl/default/tpl_form.php и перед строчками:
<p>
<textarea id="comments-form-comment" name="comment" cols="65" rows="8" tabindex="5"></textarea>
</p>
Добавляем наши новые поля:
<p>
<input type="text" name="town" value="" id="comments-form-town" />
<label for="comments-form-town">Town</label>
</p>
<p>
<input type="checkbox" name="acceptterms" value="1" id="comments-form-acceptterms" />
<label for="comments-form-acceptterms">Accept Terms of Use</label>
</p>
Все, на этом первая (и основная) часть процесса добавления двух дополнительных полей решена. В результате проделанной модификации в форме добавления комментариев появятся 2 новых поля, которые после отправки комментария будут сохраняться в БД.
В принципе на этом этапе можно было бы и остановиться. Но ведь сразу же возникнет вопрос - поля-то мы добавили, в базу они сохраняются, но как их увидеть в списке комментариев? Поэтому переходим ко второй части...
- Открываем файл jcomments.php, находим в нем строчку:
$query = "SELECT c.id, c.object_id, c.object_group, c.userid, c.name, c.username, c.title, c.comment"
и заменяем ее на:
$query = "SELECT c.id, c.object_id, c.object_group, c.userid, c.name, c.username, c.title, c.comment, c.town, c.acceptterms"
Этим самым мы добавляем выборку информации по данным полям из БД.
- Теперь открываем файл шаблона: /tpl/default/tpl_comment.php и допустим после строчки:
<span class="comment-date"><?php echo date( 'Y-m-d H:i', $comment->datetime); ?></span>
добавляем вывод нашей информации:
<span class="comment-town"><?php echo $comment->town; ?></span>
<span class="comment-accept"><?php echo $comment->acceptterms ? 'Accepted' : 'Not accepted'; ?></span>
Вот собственно и все. Ничего сложного, как видите, здесь нет. Единственная проблема — при каждом обновлении компонента вам придется повторять данную процедуру. |