Добавить новые поля продукта Prestashop 1.5

Как программно добавить новые поля продукта в PRESTASHOP 1.5?

Я создал эти поля на SQL, но не знаю, как их сохранить?

Поля 3 bool, и я хочу сохранить их в опции переключателя.


person rocanroldani    schedule 24.08.2012    source источник


Ответы (3)


Вы должны посмотреть на Product.php и ObjectModel.php, которые соответствуют классу Product и классу ObjectModel.

Если вы хотите добавить поля в Product, вам нужно добавить атрибуты в класс и обновить переменную $definition в классе, добавив определение добавленных вами атрибутов.

Что касается переключателя, он является частью контроллера, взгляните на AdminProductsController.php.

Надеюсь, поможет,

Br,

person Brice    schedule 24.08.2012
comment
Хорошо, но... например: мне нужно сохранить переключатель с выбором имени и тремя вариантами: Да, Нет, Возможно. И я создал 3 поля в классе sql и Product (переменная определения $), и мне нужно сохранить TRUE (1) или FALSE (0) в зависимости от выбора переключателя. Как я могу это сделать? - person rocanroldani; 24.08.2012
comment
Вы должны посмотреть AdminProductsController, $this-›fields_list. Например: 'активный' => массив (...) - person Brice; 24.08.2012

Может быть, вы добавите новое поле с помощью модуля? (Это только для ПРИМЕРА)

Если у вас есть поля в созданных базах данных (в моем примере я использую таблицу "product_lang").

Когда у вас есть модуль skieleton:

Создайте «ProductField.php» в моделях/

<?php

class ProductField extends ObjectModel
{
/** @var string Name */
public $id_product_field;

/** @var integer */
public $id_product;

/** @var string */
public $new_field;

/**
 * @see ObjectModel::$definition
 */
public static $definition = array(
    'table' => 'product_lang',
    'primary' => 'id_product',
    'multilang' => false,
    'fields' => array(
        'id_product' => array('type' => self::TYPE_INT, 'validate' => 'isInt', 'required' => TRUE),
        'new_field' => array('type' => self::TYPE_STRING, 'validate' => 'isString'),
    ),
);

public function __construct($ID_PRODUCT) {
    $result = Db::getInstance()->getRow('SELECT * FROM '._DB_PREFIX_.'product_lang WHERE id_product = '. (int) $ID_PRODUCT );
    $this->id_product = $ID_PRODUCT;
    $this->new_field = $result['new_field'];
}

public function update() {
    Db::getInstance()->update( 'product_lang', array( 'new_field' => $this->new_field ),  'id_product = ' . $this->id_product );
}

}
?>

НЕ ЗАБУДЬТЕ ВКЛЮЧИТЬ МОДЕЛЬ В ОСНОВНОЙ ФАЙЛ.

В основной файл модуля добавить метод:

public function hookDisplayAdminProductsExtra($params) {
$Fields = new ProductField( Tools::getValue('id_product') );
if( !empty( $Fields ) && isset( $Fields->id_product ) ) {
    $this->context->smarty->assign(array(
        'new_field' => $Fields->new_field,
    ) );
}
return $this->display(__FILE__, 'views/admin/admin.tpl');
}

Создать представление/admin/admin.tpl

<!-- New Field MODULE -->
<input type="hidden" name="submitted_tabs[]" value="productfields" />
<h4>{l s='Additional Fields' mod='productfields'}</h4>
<div class="separation"></div>
<fieldset style="border:none;">
    <table cellspacing="0" cellpadding="5" border="0">
        <tbody>
        <tr>
            <td class="col-left">
                <label>{l s='New field' mod='productfields'}<br></label>
                <p class="product_description">{l s='description of new field' mod='productfields'}</p>
            </td>
            <td style="padding-bottom:5px;">
                <input type="text" name="new_field" value="{if isset($new_field)}{$new_field}{/if}" />
            </td>
        <tr>
        </tbody>
    </table>
</fieldset>
<div class="separation"></div>
<!-- END New Field MODULE -->

Надеюсь, я ничего не забыл. Подходит только для ваших нужд.

person Rafał Łempa    schedule 16.10.2013

Посмотрите здесь: https://gist.github.com/kpodemski/21a37617b6b488590dc1

Это пример из PrestaShop 1.5.4, но если вы загрузите 1.5.6 и измените файл informations.tpl на более новую версию, все должно работать нормально.

person Krystian Podemski    schedule 18.10.2013