first commit
This commit is contained in:
122
classes/Contact.php
Normal file
122
classes/Contact.php
Normal file
@@ -0,0 +1,122 @@
|
||||
<?php
|
||||
/**
|
||||
* Copyright since 2007 PrestaShop SA and Contributors
|
||||
* PrestaShop is an International Registered Trademark & Property of PrestaShop SA
|
||||
*
|
||||
* NOTICE OF LICENSE
|
||||
*
|
||||
* This source file is subject to the Open Software License (OSL 3.0)
|
||||
* that is bundled with this package in the file LICENSE.md.
|
||||
* It is also available through the world-wide-web at this URL:
|
||||
* https://opensource.org/licenses/OSL-3.0
|
||||
* 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 https://devdocs.prestashop.com/ for more information.
|
||||
*
|
||||
* @author PrestaShop SA and Contributors <contact@prestashop.com>
|
||||
* @copyright Since 2007 PrestaShop SA and Contributors
|
||||
* @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
|
||||
*/
|
||||
|
||||
/**
|
||||
* Class ContactCore.
|
||||
*/
|
||||
class ContactCore extends ObjectModel
|
||||
{
|
||||
public $id;
|
||||
|
||||
/** @var array<string> Name */
|
||||
public $name;
|
||||
|
||||
/** @var string E-mail */
|
||||
public $email;
|
||||
|
||||
/** @var array<string> Detailed description */
|
||||
public $description;
|
||||
|
||||
/** @var bool */
|
||||
public $customer_service;
|
||||
|
||||
/**
|
||||
* @see ObjectModel::$definition
|
||||
*/
|
||||
public static $definition = [
|
||||
'table' => 'contact',
|
||||
'primary' => 'id_contact',
|
||||
'multilang' => true,
|
||||
'fields' => [
|
||||
'email' => [
|
||||
'type' => self::TYPE_STRING,
|
||||
'validate' => 'isEmail',
|
||||
'size' => 255,
|
||||
],
|
||||
'customer_service' => [
|
||||
'type' => self::TYPE_BOOL,
|
||||
'validate' => 'isBool',
|
||||
],
|
||||
|
||||
/* Lang fields */
|
||||
'name' => [
|
||||
'type' => self::TYPE_STRING,
|
||||
'lang' => true,
|
||||
'validate' => 'isGenericName',
|
||||
'required' => true,
|
||||
'size' => 255,
|
||||
],
|
||||
'description' => [
|
||||
'type' => self::TYPE_STRING,
|
||||
'lang' => true,
|
||||
'validate' => 'isString',
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
/**
|
||||
* Return available contacts.
|
||||
*
|
||||
* @param int $idLang Language ID
|
||||
*
|
||||
* @return array Contacts
|
||||
*/
|
||||
public static function getContacts($idLang)
|
||||
{
|
||||
$shopIds = Shop::getContextListShopID();
|
||||
$sql = 'SELECT *
|
||||
FROM `' . _DB_PREFIX_ . 'contact` c
|
||||
' . Shop::addSqlAssociation('contact', 'c', false) . '
|
||||
LEFT JOIN `' . _DB_PREFIX_ . 'contact_lang` cl ON (c.`id_contact` = cl.`id_contact`)
|
||||
WHERE cl.`id_lang` = ' . (int) $idLang . '
|
||||
AND contact_shop.`id_shop` IN (' . implode(', ', array_map('intval', $shopIds)) . ')
|
||||
GROUP BY c.`id_contact`
|
||||
ORDER BY `name` ASC';
|
||||
|
||||
return Db::getInstance(_PS_USE_SQL_SLAVE_)->executeS($sql);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return available categories contacts.
|
||||
*
|
||||
* @return array Contacts
|
||||
*/
|
||||
public static function getCategoriesContacts()
|
||||
{
|
||||
$shopIds = Shop::getContextListShopID();
|
||||
|
||||
return Db::getInstance()->executeS('
|
||||
SELECT cl.*
|
||||
FROM ' . _DB_PREFIX_ . 'contact ct
|
||||
' . Shop::addSqlAssociation('contact', 'ct', false) . '
|
||||
LEFT JOIN ' . _DB_PREFIX_ . 'contact_lang cl
|
||||
ON (cl.id_contact = ct.id_contact AND cl.id_lang = ' . (int) Context::getContext()->language->id . ')
|
||||
WHERE ct.customer_service = 1
|
||||
AND contact_shop.`id_shop` IN (' . implode(', ', array_map('intval', $shopIds)) . ')
|
||||
GROUP BY ct.`id_contact`
|
||||
');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user