Добавление дополнительного поля при регистрации пользователя
Автор Aleks_El_Dia   
Вывод автора страныВо время создания очередного интернет-проекта ввиду его интернациональности родилась следующая идея - возле вывода автора статьи вывести его страну. После нескольких манипуляций и хаков парочки файлов CMS Joomla! поставленая цель была достигнута.
Итак эта тема поможет вам:
1. Научится добавлять дополнительные поля при регистрации пользователя.
2. Выводить значение этого поля в любом нужном месте.
Для решения данного вопроса я руководствовался статьей "Добавляем в форму регистрации поле Дата рождения"

Итак что необходимо сделать:
1.Для начала необходимо добавить такое поле в таблицу jos_users, чтобы можно было хранить введенную пользователем информацию. Для этого выполним в phpMyAdmin следующий запрос:
 
ALTER TABLE `jos_users` ADD `country` VARCHAR(255) NOT NULL DEFAULT '';

2.После этого расширим набор полей класса mosUser, чтобы данные о стране автоматически попадали в базу при регистрации пользователя:
2.1 Открываем файл /includes/joomla.php
2.2 Находим в нем следующие строчки:
  var $params      = null;
 
  /**
  * @param database A database connector object
  */
 
  function mosUser( &$database ) {
2.3 Заменяем их на:
        var $params                = null;
        var $country            = null;
 
        /**
        * @param database A database connector object
        */
 
        function mosUser( &$database ) {
       
2.4 Для того, чтобы страна пользователя была доступна из глобальной переменной $my необходимо сделать еще одну правку. Находим:
$query = "SELECT id, name, email, block, sendEmail, registerDate,
 lastvisitDate, activation, params"
(Внимание! Это одна неразрывная строка!)
2.5 Заменяем на:
$query = "SELECT id, name, email, block, sendEmail, registerDate,
 lastvisitDate, activation, params, country"
(Внимание! Это одна неразрывная строка!)
2.6 Ниже находим строчку:
$user->activation    = $my->activation;

2.7 И после! нее добавляем:
$user->country       = $my->country;

Первая часть подготовки выполнена, теперь необходимо добавить непосредственно поле на форму, и подправить функцию сохранения нового пользователя.

3. Открываем файл /components/com_registration/registration.html.php
3.1 Находим в нем строчки:

<input type="text" name="name" size="40" value="" class="inputbox" maxlength="50" />
        </td>
    </tr>
3.2 Вставляем после! них код:

<td>
        Ваша страна    
  </td>
      <td>
              <select name="country">
          <option value="Украина">Украина</option>
      <option value="Россия">Россия</option>
        <option value="Беларусь">Беларусь</option>
         <option value="Молдавия">Молдавия</option>
            </select>              
 
      </td>

      Дополнительное поле при регистрации пользователей
При необходимости можно изменить список или дополнить его. Значение атрибута value будет записыватся в базу данных.

4.Теперь исправляем непосредственно функцию сохранения нового пользователя, добавляя в нее сохранение введенной страны пользователя.
Открываем файл /components/com_registration/registration.php
4.1 Находим в нем строчку:

$row->registerDate   = date( 'Y-m-d H:i:s' );


4.2 Вставляем после! нее следующий код:
$row->country     = mosGetParam($_POST, 'country', '');

Данные введенные пользователем получены и записаны в базу данных. Теперь можно их выводить в любом нужном нам месте. Выведем страну пользователя сразу после его ника, при указании автора статьи.

5. Для этого необходимо открыть файл /components/com_content/content.html.php
5.1 Находим следующие строчки:

/**
    * Writes Author name
    */
 
    function Author( &$row, &$params ) {
        if ( ( $params->get( 'author' ) ) && ( $row->author != '' ) ) {
        ?>
        <tr>
            <td width="70%" align="left" valign="top" colspan="2">
            <span class="small">
<?php echo _WRITTEN_BY . ' '.
( $row->created_by_alias ? $row->created_by_alias : $row->author ); ?>
            </span>
            &nbsp;&nbsp;
            </td>
        </tr>
        <?php
        }
    }
(Внимание! Строка  <?php echo _WRITTEN_BY . ' '. ( $row->.......  - неразрывная )
5.2 Меняем их на:

/** 
  * Writes Author name
   */
    function Author( &$row, &$params ) {
        global $my;
        if ( ( $params->get( 'author' ) ) && ( $row->author != '' ) ) {
        global $database;
        $query = "SELECT country"
        . "\n FROM #__users"
        . "\n WHERE id = " . (int) $row->created_by
        ;
        $database->setQuery( $query    );
        $row->country = $database->loadResult();
        ?>
        <tr>
            <td width="70%" align="left" valign="top" colspan="2">
            <span class="small">
            <?php echo _WRITTEN_BY . ' '.( $row->created_by_alias
? $row->created_by_alias : $row->author ).', '.$row->country;
?>
            </span>
            &nbsp;&nbsp;
            </td>
        </tr>
        <?php
        }
    }

P.S.: Хак опробован на CMS Joomla! 1.0.15  и CMS Joomla! 1.0.15 RE
P.P.S.: Если вам лень проделывать эти махинации, Вы можете скачать с файлового архива готовые хакнутые файлы, заменить ими оригинальные (предварительно сделав резервную копию!) и выполнить запрос с п.1 в phpMyAdmin
 

Добавить комментарий

:D:lol::-);-)8):-|:-*:oops::sad::cry::o:-?:-x:eek::zzz:P:roll::sigh:


Защитный код
Обновить

След. »
© 2009 AEDStudio Joomla! Direction - Статьи о CMS Joomla!