toutpratique/classes/shop/ShopGroup.php

171 lines
4.8 KiB
PHP
Raw Normal View History

2015-07-06 16:58:50 +02:00
<?php
/*
* 2007-2015 PrestaShop
*
* 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.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/osl-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-2015 PrestaShop SA
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
/**
* @since 1.5.0
*/
class ShopGroupCore extends ObjectModel
{
2015-09-22 18:22:11 +02:00
public $name;
public $active = true;
public $share_customer;
public $share_stock;
public $share_order;
public $deleted;
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
/**
* @see ObjectModel::$definition
*/
public static $definition = array(
'table' => 'shop_group',
'primary' => 'id_shop_group',
'fields' => array(
'name' => array('type' => self::TYPE_STRING, 'validate' => 'isGenericName', 'required' => true, 'size' => 64),
'share_customer' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'),
'share_order' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'),
'share_stock' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'),
'active' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'),
'deleted' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'),
),
);
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
/**
* @see ObjectModel::getFields()
* @return array
*/
public function getFields()
{
if (!$this->share_customer || !$this->share_stock) {
$this->share_order = false;
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
return parent::getFields();
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
public static function getShopGroups($active = true)
{
$groups = new PrestaShopCollection('ShopGroup');
$groups->where('deleted', '=', false);
if ($active) {
$groups->where('active', '=', true);
}
return $groups;
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
/**
* @return int Total of shop groups
*/
public static function getTotalShopGroup($active = true)
{
return count(ShopGroup::getShopGroups($active));
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
public function haveShops()
{
return (bool)$this->getTotalShops();
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
public function getTotalShops()
{
$sql = 'SELECT COUNT(*)
2015-07-06 16:58:50 +02:00
FROM '._DB_PREFIX_.'shop s
WHERE id_shop_group='.(int)$this->id;
2015-09-22 18:22:11 +02:00
return (int)Db::getInstance()->getValue($sql);
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
public static function getShopsFromGroup($id_group)
{
$sql = 'SELECT s.`id_shop`
2015-07-06 16:58:50 +02:00
FROM '._DB_PREFIX_.'shop s
WHERE id_shop_group='.(int)$id_group;
2015-09-22 18:22:11 +02:00
return Db::getInstance()->executeS($sql);
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
/**
* Return a group shop ID from group shop name
*
* @param string $name
* @return int
*/
public static function getIdByName($name)
{
$sql = 'SELECT id_shop_group
2015-07-06 16:58:50 +02:00
FROM '._DB_PREFIX_.'shop_group
WHERE name = \''.pSQL($name).'\'';
2015-09-22 18:22:11 +02:00
return (int)Db::getInstance()->getValue($sql);
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
/**
* Detect dependency with customer or orders
*
* @param int $id_shop_group
* @param string $check all|customer|order
* @return bool
*/
public static function hasDependency($id_shop_group, $check = 'all')
{
$list_shops = Shop::getShops(false, $id_shop_group, true);
if (!$list_shops) {
return false;
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
if ($check == 'all' || $check == 'customer') {
$total_customer = (int)Db::getInstance()->getValue('
2015-07-06 16:58:50 +02:00
SELECT count(*)
FROM `'._DB_PREFIX_.'customer`
WHERE `id_shop` IN ('.implode(', ', $list_shops).')'
2015-09-22 18:22:11 +02:00
);
if ($total_customer) {
return true;
}
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
if ($check == 'all' || $check == 'order') {
$total_order = (int)Db::getInstance()->getValue('
2015-07-06 16:58:50 +02:00
SELECT count(*)
FROM `'._DB_PREFIX_.'orders`
WHERE `id_shop` IN ('.implode(', ', $list_shops).')'
2015-09-22 18:22:11 +02:00
);
if ($total_order) {
return true;
}
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
return false;
}
2015-07-06 16:58:50 +02:00
2015-09-22 18:22:11 +02:00
public function shopNameExists($name, $id_shop = false)
{
return Db::getInstance()->getValue('
2015-07-06 16:58:50 +02:00
SELECT id_shop
FROM '._DB_PREFIX_.'shop
WHERE name = "'.pSQL($name).'"
AND id_shop_group = '.(int)$this->id.'
'.($id_shop ? 'AND id_shop != '.(int)$id_shop : '')
2015-09-22 18:22:11 +02:00
);
}
}