Модель: OpFieldsProduct
Класс Models_OpFieldsProduct реализует логику взаимодействия с дополнительными полями товаров.
array|string | get() |
Позволяет получить дополнительные поля прикрепленные к товару
// выборка всех данных |
void | fill() |
Заполняет значения дополнительных полей переданным массивом данных
// заполнение одного поля |
void | save() |
Сохраняет текущее состояние объекта в базу данных, обычно используется после метода fill для фиксации изменений
// заполнение одного поля |
array | getFields() |
Получает список доступных дополнительных полей
$data = Models_OpFieldsProduct::getFields(); |
void | saveFields() |
Метод для редактирования доступных дополнительных полей Принимает список полей, которые нужно сохранить, если существующие поля не были указаны, то они будут удалены
$data = array( |
Метод
array|string get ()
Параметры
Описание
Позволяет получить дополнительные поля прикрепленные к товару
// выборка всех данных
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$data = $opFieldsM->get();
viewData($data);
// выборка конкретного поля
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$fieldId = 1;
$data = $opFieldsM->get($fieldId);
viewData($data);
// выборка значения поля и названия
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$fieldId = 1;
$name = $opFieldsM->get($fieldId, 'name');
$value = $opFieldsM->get($fieldId, 'value');
viewData($name);
viewData($value);
// выборка вариантов
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$fieldId = 1;
$variants = $opFieldsM->get($fieldId, 'variant');
viewData($variants);
// по аналогии можно достать любой интересующий эллемент массива
Метод
void fill ($data)
Параметры
Описание
Заполняет значения дополнительных полей переданным массивом данных
// заполнение одного поля
$data = array(
'id' => 1,
'value' => 'test',
);
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$opFieldsM->fill($data);
$opFieldsM->save();
// заполнение одного поля с вариантами
$data = array(
'id' => 1,
'variant' => array(
array(
'id' => 1,
'value' => 'test'
),
array(
'id' => 2,
'value' => 'test2'
)
)
);
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$opFieldsM->fill($data);
$opFieldsM->save();
// сохранение нескольких полей одновременно
$data = array(
array(
'id' => 1,
'value' => 'test',
),
array(
'id' => 2,
'value' => 'test2',
),
);
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$opFieldsM->fill($data);
$opFieldsM->save();
Метод
void save ()
Описание
Сохраняет текущее состояние объекта в базу данных, обычно используется после метода fill для фиксации изменений
// заполнение одного поля
$data = array(
'id' => 1,
'value' => 'test',
);
$productId = 16;
$opFieldsM = new Models_OpFieldsProduct($productId);
$opFieldsM->fill($data);
$opFieldsM->save();
Метод
array getFields ($prefix)
Описание
Получает список доступных дополнительных полей
$data = Models_OpFieldsProduct::getFields();
viewData($data);
Метод
void saveFields ($data)
Параметры
Описание
Метод для редактирования доступных дополнительных полей
Принимает список полей, которые нужно сохранить, если существующие поля не были указаны, то они будут удалены
$data = array(
Array(
'id' => 7, // идентификатор поля
'name' => 'test', // название поля
'isPrice' => 0, // добавляет возможность создания оптовой цены из этого поля
'sort' => 0, // порядок сортировки
),
// далее аналогично
Array(
'id' => 8,
'name' => 'test2',
'isPrice' => 1,
'sort' => 1,
),
Array(
'id' => 9,
'name' => 'test3',
'isPrice' => 0,
'sort' => 2,
)
);
Models_OpFieldsProduct::saveFields($data);