261 lines
8.6 KiB
PHP
261 lines
8.6 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
* 2007-2011 PrestaShop
|
||
|
*
|
||
|
* NOTICE OF LICENSE
|
||
|
*
|
||
|
* This source file is subject to the Academic Free License (AFL 3.0)
|
||
|
* that is bundled with this package in the file LICENSE.txt.
|
||
|
* It is also available through the world-wide-web at this URL:
|
||
|
* http://opensource.org/licenses/afl-3.0.php
|
||
|
* If you did not receive a copy of the license and are unable to
|
||
|
* obtain it through the world-wide-web, please send an email
|
||
|
* to license@prestashop.com so we can send you a copy immediately.
|
||
|
*
|
||
|
* DISCLAIMER
|
||
|
*
|
||
|
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
|
||
|
* versions in the future. If you wish to customize PrestaShop for your
|
||
|
* needs please refer to http://www.prestashop.com for more information.
|
||
|
*
|
||
|
* @author PrestaShop SA <contact@prestashop.com>
|
||
|
* @copyright 2007-2011 PrestaShop SA
|
||
|
* @version Release: $Revision: 9115 $
|
||
|
* @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0)
|
||
|
* International Registered Trademark & Property of PrestaShop SA
|
||
|
*/
|
||
|
|
||
|
if (!defined('_PS_VERSION_'))
|
||
|
exit;
|
||
|
|
||
|
class ProductComment extends ObjectModel
|
||
|
{
|
||
|
public $id;
|
||
|
|
||
|
/** @var integer Product's id */
|
||
|
public $id_product;
|
||
|
|
||
|
/** @var integer Customer's id */
|
||
|
public $id_customer;
|
||
|
|
||
|
/** @var integer Guest's id */
|
||
|
public $id_guest;
|
||
|
|
||
|
|
||
|
/** @var integer Customer name */
|
||
|
public $customer_name;
|
||
|
|
||
|
/** @var string Title */
|
||
|
public $title;
|
||
|
|
||
|
/** @var string Content */
|
||
|
public $content;
|
||
|
|
||
|
/** @var integer Grade */
|
||
|
public $grade;
|
||
|
|
||
|
/** @var boolean Validate */
|
||
|
public $validate = 0;
|
||
|
|
||
|
public $deleted = 0;
|
||
|
|
||
|
/** @var string Object creation date */
|
||
|
public $date_add;
|
||
|
|
||
|
protected $fieldsRequired = array('id_product', 'id_customer', 'content');
|
||
|
protected $fieldsSize = array('content' => 65535);
|
||
|
protected $fieldsValidate = array('id_product' => 'isUnsignedId', 'id_customer' => 'isUnsignedId', 'content' => 'isMessage',
|
||
|
'grade' => 'isFloat', 'validate' => 'isBool');
|
||
|
|
||
|
protected $table = 'product_comment';
|
||
|
protected $identifier = 'id_product_comment';
|
||
|
|
||
|
public function getFields()
|
||
|
{
|
||
|
parent::validateFields(false);
|
||
|
$fields['id_product'] = (int)($this->id_product);
|
||
|
$fields['id_customer'] = (int)($this->id_customer);
|
||
|
$fields['id_guest'] = (int)($this->id_guest);
|
||
|
$fields['customer_name'] = pSQL($this->customer_name);
|
||
|
$fields['title'] = pSQL($this->title);
|
||
|
$fields['content'] = pSQL($this->content);
|
||
|
$fields['grade'] = (float)($this->grade);
|
||
|
$fields['validate'] = (int)($this->validate);
|
||
|
$fields['deleted'] = (int)($this->deleted);
|
||
|
$fields['date_add'] = pSQL($this->date_add);
|
||
|
return ($fields);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get comments by IdProduct
|
||
|
*
|
||
|
* @return array Comments
|
||
|
*/
|
||
|
public static function getByProduct($id_product, $p = 1, $n = null)
|
||
|
{
|
||
|
if (!Validate::isUnsignedId($id_product))
|
||
|
die(Tools::displayError());
|
||
|
$validate = Configuration::get('PRODUCT_COMMENTS_MODERATE');
|
||
|
$p = (int)($p);
|
||
|
$n = (int)($n);
|
||
|
if ($p <= 1)
|
||
|
$p = 1;
|
||
|
if ($n != null AND $n <= 0)
|
||
|
$n = 5;
|
||
|
return Db::getInstance(_PS_USE_SQL_SLAVE_)->ExecuteS('
|
||
|
SELECT pc.`id_product_comment`, IF(c.id_customer, CONCAT(c.`firstname`, \' \', LEFT(c.`lastname`, 1)), pc.customer_name) customer_name, pc.`content`, pc.`grade`, pc.`date_add`, pc.title
|
||
|
FROM `'._DB_PREFIX_.'product_comment` pc
|
||
|
LEFT JOIN `'._DB_PREFIX_.'customer` c ON c.`id_customer` = pc.`id_customer`
|
||
|
WHERE pc.`id_product` = '.(int)($id_product).($validate == '1' ? ' AND pc.`validate` = 1' : '').'
|
||
|
ORDER BY pc.`date_add` DESC
|
||
|
'.($n ? 'LIMIT '.(int)(($p - 1) * $n).', '.(int)($n) : ''));
|
||
|
}
|
||
|
|
||
|
public static function getByCustomer($id_product, $id_customer, $last = false, $id_guest = false)
|
||
|
{
|
||
|
$results = Db::getInstance()->ExecuteS('
|
||
|
SELECT *
|
||
|
FROM `'._DB_PREFIX_.'product_comment` pc
|
||
|
WHERE pc.`id_product` = '.(int)$id_product.' AND '.(!$id_guest ? 'pc.`id_customer` = '.(int)$id_customer : 'pc.`id_guest` = '.(int)$id_guest).'
|
||
|
ORDER BY pc.`date_add` DESC '.($last ? ' LIMIT 1' : ''));
|
||
|
|
||
|
if (!$results)
|
||
|
return false;
|
||
|
elseif ($last)
|
||
|
return array_shift($results);
|
||
|
else
|
||
|
return $results;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get Grade By product
|
||
|
*
|
||
|
* @return array Grades
|
||
|
*/
|
||
|
public static function getGradeByProduct($id_product, $id_lang)
|
||
|
{
|
||
|
if (!Validate::isUnsignedId($id_product) ||
|
||
|
!Validate::isUnsignedId($id_lang))
|
||
|
die(Tools::displayError());
|
||
|
$validate = Configuration::get('PRODUCT_COMMENTS_MODERATE');
|
||
|
|
||
|
return (Db::getInstance(_PS_USE_SQL_SLAVE_)->ExecuteS('
|
||
|
SELECT pc.`id_product_comment`, pcg.`grade`, pccl.`name`, pcc.`id_product_comment_criterion`
|
||
|
FROM `'._DB_PREFIX_.'product_comment` pc
|
||
|
LEFT JOIN `'._DB_PREFIX_.'product_comment_grade` pcg ON (pcg.`id_product_comment` = pc.`id_product_comment`)
|
||
|
LEFT JOIN `'._DB_PREFIX_.'product_comment_criterion` pcc ON (pcc.`id_product_comment_criterion` = pcg.`id_product_comment_criterion`)
|
||
|
LEFT JOIN `'._DB_PREFIX_.'product_comment_criterion_lang` pccl ON (pccl.`id_product_comment_criterion` = pcg.`id_product_comment_criterion`)
|
||
|
WHERE pc.`id_product` = '.(int)($id_product).'
|
||
|
AND pccl.`id_lang` = '.(int)($id_lang).
|
||
|
($validate == '1' ? ' AND pc.`validate` = 1' : '')));
|
||
|
}
|
||
|
|
||
|
public static function getAveragesByProduct($id_product, $id_lang)
|
||
|
{
|
||
|
/* Get all grades */
|
||
|
$grades = ProductComment::getGradeByProduct((int)($id_product), (int)($id_lang));
|
||
|
$total = ProductComment::getGradedCommentNumber((int)($id_product));
|
||
|
if (!sizeof($grades) OR (!$total))
|
||
|
return array();
|
||
|
|
||
|
/* Addition grades for each criterion */
|
||
|
$criterionsGradeTotal = array();
|
||
|
for ($i = 0; $i < count($grades); ++$i)
|
||
|
if (array_key_exists($grades[$i]['id_product_comment_criterion'], $criterionsGradeTotal) === false)
|
||
|
$criterionsGradeTotal[$grades[$i]['id_product_comment_criterion']] = (int)($grades[$i]['grade']);
|
||
|
else
|
||
|
$criterionsGradeTotal[$grades[$i]['id_product_comment_criterion']] += (int)($grades[$i]['grade']);
|
||
|
|
||
|
/* Finally compute the averages */
|
||
|
$averages = array();
|
||
|
foreach ($criterionsGradeTotal AS $key => $criterionGradeTotal)
|
||
|
$averages[(int)($key)] = (int)($total) ? ((int)($criterionGradeTotal) / (int)($total)) : 0;
|
||
|
return $averages;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return number of comments and average grade by products
|
||
|
*
|
||
|
* @return array Info
|
||
|
*/
|
||
|
public static function getCommentNumber($id_product)
|
||
|
{
|
||
|
if (!Validate::isUnsignedId($id_product))
|
||
|
die(Tools::displayError());
|
||
|
$validate = (int)(Configuration::get('PRODUCT_COMMENTS_MODERATE'));
|
||
|
if (($result = Db::getInstance(_PS_USE_SQL_SLAVE_)->getRow('
|
||
|
SELECT COUNT(`id_product_comment`) AS "nbr"
|
||
|
FROM `'._DB_PREFIX_.'product_comment` pc
|
||
|
WHERE `id_product` = '.(int)($id_product).($validate == '1' ? ' AND `validate` = 1' : ''))) === false)
|
||
|
return false;
|
||
|
return (int)($result['nbr']);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return number of comments and average grade by products
|
||
|
*
|
||
|
* @return array Info
|
||
|
*/
|
||
|
public static function getGradedCommentNumber($id_product)
|
||
|
{
|
||
|
if (!Validate::isUnsignedId($id_product))
|
||
|
die(Tools::displayError());
|
||
|
$validate = (int)(Configuration::get('PRODUCT_COMMENTS_MODERATE'));
|
||
|
|
||
|
$result = Db::getInstance(_PS_USE_SQL_SLAVE_)->getRow('
|
||
|
SELECT COUNT(pc.`id_product`) AS nbr
|
||
|
FROM `'._DB_PREFIX_.'product_comment` pc
|
||
|
WHERE `id_product` = '.(int)($id_product).($validate == '1' ? ' AND `validate` = 1' : '').'
|
||
|
AND `grade` > 0');
|
||
|
return (int)($result['nbr']);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get comments by Validation
|
||
|
*
|
||
|
* @return array Comments
|
||
|
*/
|
||
|
public static function getByValidate($validate = '0', $deleted = false)
|
||
|
{
|
||
|
global $cookie;
|
||
|
|
||
|
return (Db::getInstance()->ExecuteS('
|
||
|
SELECT pc.`id_product_comment`, pc.`id_product`, IF(c.id_customer, CONCAT(c.`firstname`, \' \', c.`lastname`), pc.customer_name) customer_name, pc.`content`, pc.`grade`, pc.`date_add`, pl.`name`
|
||
|
FROM `'._DB_PREFIX_.'product_comment` pc
|
||
|
LEFT JOIN `'._DB_PREFIX_.'customer` c ON (c.`id_customer` = pc.`id_customer`)
|
||
|
LEFT JOIN `'._DB_PREFIX_.'product_lang` pl ON (pl.`id_product` = pc.`id_product`)
|
||
|
WHERE pc.`validate` = '.(int)($validate).'
|
||
|
AND pl.`id_lang` = '.(int)($cookie->id_lang).'
|
||
|
ORDER BY pc.`date_add` DESC'));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Validate a comment
|
||
|
*
|
||
|
* @return boolean succeed
|
||
|
*/
|
||
|
public function validate($validate = '1')
|
||
|
{
|
||
|
if (!Validate::isUnsignedId($this->id))
|
||
|
die(Tools::displayError());
|
||
|
return (Db::getInstance()->Execute('
|
||
|
UPDATE `'._DB_PREFIX_.'product_comment` SET
|
||
|
`validate` = '.(int)($validate).'
|
||
|
WHERE `id_product_comment` = '.(int)($this->id)));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Delete Grades
|
||
|
*
|
||
|
* @return boolean succeed
|
||
|
*/
|
||
|
public static function deleteGrades($id_product_comment)
|
||
|
{
|
||
|
if (!Validate::isUnsignedId($id_product_comment))
|
||
|
die(Tools::displayError());
|
||
|
return (Db::getInstance()->Execute('
|
||
|
DELETE FROM `'._DB_PREFIX_.'product_comment_grade`
|
||
|
WHERE `id_product_comment` = '.(int)($id_product_comment)));
|
||
|
}
|
||
|
};
|