* @copyright 2007-2011 PrestaShop SA
* @version Release: $Revision: 8783 $
* @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 SimpleXMLExtended extends SimpleXMLElement
{
public function addCData($nodename, $cdata_text)
{
$node = $this->addChild($nodename);
$node = dom_import_simplexml($node);
$no = $node->ownerDocument;
$node->appendChild($no->createCDATASection($cdata_text));
}
}
class Treepodia extends Module
{
private $allowed_extensions = array('.png','.gif','.jpg');
function __construct()
{
$this->name = 'treepodia';
$this->tab = 'front_office_features';
$this->version = '1.6.1';
$this->displayName = 'Treepodia';
parent::__construct();
$this->description = $this->l('Cover your entire catalog with product videos in 24 hours.');
if ($this->active && !Configuration::get('TREEPODIA_ACCOUNT_CODE'))
$this->warning = $this->l('You have not set your Treepodia configuration.');
}
function install()
{
if (!parent::install())
return false;
$this->registerHook('extraLeft');
$this->registerHook('footer');
$this->registerHook('orderConfirmation');
$token = Configuration::get('TREEPODIA_TOKEN') ? Configuration::get('TREEPODIA_TOKEN') : Tools::passwdGen(16);
$type = Configuration::get('TREEPODIA_INTEGRATION_TYPE') ? Configuration::get('TREEPODIA_INTEGRATION_TYPE') : 0;
$logo = Configuration::get('TREEPODIA_PLAY_LOGO') ? Configuration::get('TREEPODIA_PLAY_LOGO') : '4-7.png';
$position = Configuration::get('TREEPODIA_POSITION') ? Configuration::get('TREEPODIA_POSITION') : 1;
$hook = Configuration::get('TREEPODIA_HOOK') ? Configuration::get('TREEPODIA_HOOK') : 0;
Configuration::updateValue('TREEPODIA_TOKEN', $token);
Configuration::updateValue('TREEPODIA_INTEGRATION_TYPE', $type);
Configuration::updateValue('TREEPODIA_PLAY_LOGO', $logo);
Configuration::updateValue('TREEPODIA_POSITION', $position);
Configuration::updateValue('TREEPODIA_HOOK', $hook);
return true;
}
private function _getShopURL()
{
if (!($domain = Configuration::get('PS_SHOP_DOMAIN')))
$domain = $_SERVER['HTTP_HOST'];
$host = ((Configuration::get('PS_SSL_ENABLED') || (!empty($_SERVER['HTTPS']) && strtolower($_SERVER['HTTPS']) != 'off')) ? 'https://'.$domain : 'http://'.$domain).__PS_BASE_URI__;
return $host;
}
public function generateXmlFlow()
{
global $cart, $cookie;
$cookie->id_lang = (int)Configuration::get('PS_LANG_DEFAULT'); // url rewriting case
$cart = new Cart();
$link = new Link();
$defaultCurrencyIsoCode = strtoupper(Db::getInstance()->getValue('SELECT c.iso_code FROM '._DB_PREFIX_.'currency c WHERE c.id_currency = '.(int)Configuration::get('PS_CURRENCY_DEFAULT')));
$defaultIdLang = (int)Configuration::get('PS_LANG_DEFAULT');
$sqlLangs = Db::getInstance()->ExecuteS('SELECT l.id_lang, l.iso_code FROM '._DB_PREFIX_.'lang l');
foreach ($sqlLangs AS $sqlLang)
$langs[$sqlLang['id_lang']] = $sqlLang['iso_code'];
$xmlString = <<
XML;
$products = new SimpleXMLExtended($xmlString);
$infos = $products->addChild('infos');
$infos->addCData('url', $this->_getShopURL());
$infos->addCData('logo', $this->_getShopURL());
$languages = Db::getInstance()->ExecuteS('
SELECT l.iso_code
FROM '._DB_PREFIX_.'lang l
WHERE l.active = 1');
foreach ($languages AS $language)
$infos->addChild('lang', $language['iso_code']);
$limit_sql = '';
$limit_start = (int)Tools::getValue('limit_start');
$limit_end = (int)Tools::getValue('limit_end');
if ($limit_start > 0)
{
if ($limit_end < $limit_start)
$limit_end = $limit_start + 10;
$limit_sql = ' LIMIT '.(int)$limit_start.','.(int)$limit_end;
}
$sqlProducts = Db::getInstance()->ExecuteS('
SELECT p.id_product, p.reference, p.weight, m.name manufacturer, s.name supplier, p.on_sale, p.id_manufacturer, pd.id_product_download
FROM '._DB_PREFIX_.'product p
LEFT JOIN '._DB_PREFIX_.'manufacturer m ON (m.id_manufacturer = p.id_manufacturer)
LEFT JOIN '._DB_PREFIX_.'supplier s ON (s.id_supplier = p.id_supplier)
LEFT JOIN '._DB_PREFIX_.'product_download pd ON (pd.id_product = p.id_product)
WHERE p.active = 1'.$limit_sql);
foreach ($sqlProducts AS $sqlProduct)
{
$id_product = $sqlProduct['id_product'] ;
$product = $products->addChild('product') ;
$product->addChild('sku', (int)($sqlProduct['id_product']));
$product->addCData('manufacturer', $sqlProduct['manufacturer']);
if (file_exists(dirname(__FILE__).'/../../img/m/'.(int)($sqlProduct['id_manufacturer']).'jpg'))
$product->addCData('manufacturer-logo', $_SERVER['HTTP_HOST'].__PS_BASE_URI__.'img/m/'.(int)($sqlProduct['id_manufacturer']).'jpg');
$product->addChild('weight', (float)($sqlProduct['weight']));
$product->addChild('weight_unit', strtolower(Configuration::get('PS_WEIGHT_UNIT')));
$product->addCData('supplier', $sqlProduct['supplier']);
$name = $product->addChild('name');
$languageVariant = $name->addChild('language-variant');
$texts = Db::getInstance()->ExecuteS('
SELECT pl.name, pl.description_short, pl.link_rewrite, l.iso_code, l.id_lang
FROM '._DB_PREFIX_.'product_lang pl
LEFT JOIN '._DB_PREFIX_.'lang l ON (l.id_lang = pl.id_lang)
WHERE pl.id_product = '.(int)$sqlProduct['id_product']);
foreach ($texts AS $text)
{
$variant = $languageVariant->addChild('variant');
$variant->addChild('locale', $text['iso_code']);
$variant->addCData('value', $text['name']);
if ($text['id_lang'] == $defaultIdLang)
{
$productName = $text['name'];
$productLinkRewrite = $text['link_rewrite'];
}
}
$product->addCData('page-url', $link->getProductLink((int)$sqlProduct['id_product'], $productLinkRewrite));
$shortDescription = $product->addChild('short-description');
$languageVariant = $shortDescription->addChild('language-variant');
foreach ($texts AS $text)
{
$variant = $languageVariant->addChild('variant');
$variant->addChild('locale', $text['iso_code']);
$variant->addCData('value', Tools::htmlentitiesDecodeUTF8(strip_tags($text['description_short'])));
}
$accessories = Db::getInstance()->ExecuteS('
SELECT a.id_product_2
FROM '._DB_PREFIX_.'accessory a
WHERE a.id_product_1 = '.(int)$sqlProduct['id_product']);
foreach ($accessories AS $accessory)
$product->addChild('accessory-sku', (int)($accessory['id_product_2']));
$price = $product->addChild('price');
$price->addChild('currency', $defaultCurrencyIsoCode);
$price->addChild('retail-price-with-tax', Product::getPriceStatic((int)$sqlProduct['id_product'], true, NULL, 6, NULL, false, false));
$price->addChild('retail-price-without-tax', Product::getPriceStatic((int)$sqlProduct['id_product'], false, NULL, 6, NULL, false, false));
$price->addChild('final-retail-price-with-tax', Product::getPriceStatic((int)$sqlProduct['id_product'], true));
if (version_compare(_PS_VERSION_, '1.4') < 0)
{
$price->addChild('final-retail-price-without-tax', Product::getPriceStatic(intval($sqlProduct['id_product']), false));
$price->addChild('reduction_percent', floatval($sqlProduct['reduction_percent']));
$price->addChild('reduction_price', floatval($sqlProduct['reduction_price']));
}
else
{
$price->addChild('final-retail-price-without-tax', Product::getPriceStatic((int)$sqlProduct['id_product'], false, NULL, 6, NULL, false, true, 1, false, NULL, NULL, NULL, $specificPrice));
$price->addChild('reduction_percent', ($specificPrice AND $specificPrice['reduction_type'] == 'percentage') ? $specificPrice['reduction'] * 100 : 0.00);
$price->addChild('reduction_price', ($specificPrice AND $specificPrice['reduction_type'] == 'amount') ? (float)$specificPrice['reduction'] : 0.00);
}
$price->addChild('display-on-sale', (int)$sqlProduct['on_sale']);
$product->addChild('downloadable', $sqlProduct['id_product_download'] >= 1 ? 1 : 0);
$pack = Db::getInstance()->ExecuteS('
SELECT p.id_product, pp.quantity
FROM '._DB_PREFIX_.'pack pp
LEFT JOIN '._DB_PREFIX_.'product p ON (p.id_product = pp.id_product_item)
WHERE pp.id_product_pack = '.(int)$sqlProduct['id_product']);
if (sizeof($pack))
{
$pack = $product->addChild('pack');
foreach ($pack AS $p)
{
$packItem = $pack->addChild('pack-item');
$packItem->addChild('quantity', (int)$p['quantity']);
$packItem->addChild('sku', (int)$p['id_product']);
}
}
$images = Db::getInstance()->ExecuteS('
SELECT i.id_image, il.legend, l.iso_code
FROM '._DB_PREFIX_.'image i
LEFT JOIN '._DB_PREFIX_.'image_lang il ON (il.id_image = i.id_image)
LEFT JOIN '._DB_PREFIX_.'lang l ON (l.id_lang = il.id_lang)
WHERE i.id_product = '.(int)$sqlProduct['id_product']);
$imagesLegends = array();
foreach ($images AS $image)
{
$imagesLegends[(int)$image['id_image']][$image['iso_code']]['legend'] = $image['legend'];
$imagesLegends[(int)$image['id_image']][$image['iso_code']]['iso_code'] = $image['iso_code'];
}
$imagesAlreadyDone = array();
foreach ($images AS $imageSQL)
{
if (isset($imagesAlreadyDone[$imageSQL['id_image']]))
continue;
$imagesAlreadyDone[(int)$imageSQL['id_image']] = 1;
$image = $product->addChild('image');
$image->addAttribute('id',$imageSQL['id_image']);
$image->addCData('image-url', $link->getImageLink($productLinkRewrite, (int)($sqlProduct['id_product']).'-'.(int)($imageSQL['id_image']), 'large'));
if (isset($imagesLegends[$imageSQL['id_image']]) AND sizeof($imagesLegends[$imageSQL['id_image']]))
{
$imageCaption = $image->addChild('image-caption');
$languageVariant = $imageCaption->addChild('language-variant');
foreach ($imagesLegends[(int)($imageSQL['id_image'])] AS $legend)
{
$variant = $languageVariant->addChild('variant');
$variant->addChild('locale', $legend['iso_code']);
$variant->addCData('value', $legend['legend']);
}
}
}
if (version_compare(_PS_VERSION_, '1.4') < 0)
{
$quantityDiscounts = Db::getInstance()->ExecuteS('
SELECT dq.quantity, dq.value, dq.id_discount_type
FROM '._DB_PREFIX_.'discount_quantity dq
WHERE dq.id_product = '.intval($sqlProduct['id_product']));
foreach ($quantityDiscounts AS $quantityDiscount)
{
$discount = $product->addChild('discount');
$discount->addChild('discount-quantity', intval($quantityDiscount['quantity']));
$discount->addChild('discount-value', floatval($quantityDiscount['value']));
$discount->addChild('discount-type', ($quantityDiscount['id_discount_type'] == 1 ? $defaultCurrencyIsoCode : '%'));
}
}
else
{
$quantityDiscounts = SpecificPrice::getQuantityDiscounts((int)$sqlProduct['id_product'], (int)Shop::getCurrentShop(), 0, 0, 0);
foreach ($quantityDiscounts AS $quantityDiscount)
{
$discount = $product->addChild('discount');
$discount->addChild('discount-quantity', (int)($quantityDiscount['from_quantity']));
$discount->addChild('discount-value', ((float)($quantityDiscount['price']) AND $quantityDiscount['reduction_type'] == 'amount') ? (float)($quantityDiscount['price']) : $quantityDiscount['reduction'] * 100);
$discount->addChild('discount-type', ($quantityDiscount['reduction_type'] == 'amount' ? $defaultCurrencyIsoCode : '%'));
}
}
$categories = Db::getInstance()->ExecuteS('
SELECT cl.name, l.iso_code
FROM '._DB_PREFIX_.'category_product cp
LEFT JOIN '._DB_PREFIX_.'category_lang cl ON (cl.id_category = cp.id_category)
LEFT JOIN '._DB_PREFIX_.'lang l ON (l.id_lang = cl.id_lang)
WHERE cp.id_product = '.(int)$sqlProduct['id_product']);
if (sizeof($categories))
{
$category = $product->addChild('category');
$languageVariant = $category->addChild('language-variant');
foreach ($categories AS $category)
{
$variant = $languageVariant->addChild('variant');
$variant->addChild('locale', $category['iso_code']);
$variant->addCData('value', $category['name']);
}
}
$tags = Db::getInstance()->ExecuteS('
SELECT pt.id_product, pt.id_tag, l.iso_code, t.name
FROM '._DB_PREFIX_.'product_tag pt
LEFT JOIN '._DB_PREFIX_.'tag t ON (t.id_tag = pt.id_tag)
LEFT JOIN '._DB_PREFIX_.'lang l ON (l.id_lang = t.id_lang)
WHERE pt.id_product = '.(int)$sqlProduct['id_product']);
if (!empty($tags) && sizeof($tags) > 0)
{
$tagsTexts = array();
$tagsIso = array();
foreach ($tags AS $tag)
{
if (!in_array($tag['iso_code'], $tagsIso))
$tagsIso[] = $tag['iso_code'];
$tagsTexts[$tag['iso_code']][] = $tag['name'];
}
$tags_item = $product->addChild('tags');
foreach ($tagsIso AS $iso)
{
$languageVariant = $tags_item->addChild('language-variant');
$languageVariant->addChild('locale', $iso);
$languageVariant->addCData('value', implode(',', $tagsTexts[$iso]));
}
}
$groupAttributes = Db::getInstance()->ExecuteS('
SELECT DISTINCT agl.id_attribute_group, agl.name, l.iso_code, a.id_attribute, al.name as attribute_name, al.id_lang, pa.id_product_attribute
FROM '._DB_PREFIX_.'attribute_group_lang agl
LEFT JOIN '._DB_PREFIX_.'attribute a ON (a.id_attribute_group = agl.id_attribute_group)
LEFT JOIN '._DB_PREFIX_.'attribute_lang al ON (al.id_attribute = a.id_attribute)
LEFT JOIN '._DB_PREFIX_.'lang l ON (l.id_lang = al.id_lang)
LEFT JOIN '._DB_PREFIX_.'product_attribute_combination pac ON (pac.id_attribute = a.id_attribute)
LEFT JOIN '._DB_PREFIX_.'product_attribute pa ON (pa.id_product_attribute = pac.id_product_attribute)
WHERE pa.id_product = '.(int)$sqlProduct['id_product'].'
GROUP BY a.id_attribute, l.iso_code');
$groups = array();
foreach ($groupAttributes AS $groupAttribute)
{
$id_group_attribute = $groupAttribute[ 'id_attribute_group' ] ;
$id_attribute = $groupAttribute[ 'id_attribute' ] ;
$id_product_attribute = $groupAttribute[ 'id_product_attribute' ] ;
$groups[$id_group_attribute]['name'][$groupAttribute['iso_code']] = $groupAttribute['name'] ;
$groups[$id_group_attribute]['attributes'][$groupAttribute['id_attribute']][$groupAttribute['iso_code']] = $groupAttribute['attribute_name'];
}
if (!empty($groups))
{
foreach ($groups AS $id_group => $group)
{
$xml_group = $product->addChild('attribute-group');
$xml_group->addAttribute('id', $id_group);
if (!empty($group[ 'name' ]))
{
$nameGroup = $xml_group->addChild('name');
$languageVariant = $nameGroup->addChild('language-variant');
foreach ($group['name'] AS $iso2 => $name_group)
{
$variant = $languageVariant->addChild('variant');
$variant->addChild('locale', $iso2);
$variant->addCData('value', $name_group);
}
}
if (!empty($group['attributes']))
{
foreach ($group['attributes'] AS $id_attribute => $attribute)
{
$xml_attribute = $xml_group->addChild('attribute');
$xml_attribute->addAttribute('id', $id_attribute);
$languageVariant = $xml_attribute->addChild('language-variant');
foreach ($attribute AS $iso2 => $name_attribute)
{
$variant = $languageVariant->addChild('variant');
$variant->addChild('locale', $iso2);
$variant->addCData('value', $name_attribute);
}
}
}
}
}
$groupAttributes = Db::getInstance()->ExecuteS('
SELECT agl.id_attribute_group, agl.name, l.iso_code, a.id_attribute, al.name attribute_name, al.id_lang, pa.id_product_attribute
FROM '._DB_PREFIX_.'attribute_group_lang agl
LEFT JOIN '._DB_PREFIX_.'lang l ON (l.id_lang = agl.id_lang)
LEFT JOIN '._DB_PREFIX_.'attribute a ON (a.id_attribute_group = agl.id_attribute_group)
LEFT JOIN '._DB_PREFIX_.'attribute_lang al ON (al.id_attribute = a.id_attribute)
LEFT JOIN '._DB_PREFIX_.'product_attribute_combination pac ON (pac.id_attribute = a.id_attribute)
LEFT JOIN '._DB_PREFIX_.'product_attribute pa ON (pa.id_product_attribute = pac.id_product_attribute)
WHERE pa.id_product = '.(int)$sqlProduct['id_product']);
$combinaison = array();
foreach ($groupAttributes AS $groupAttribute)
{
$id_group_attribute = $groupAttribute['id_attribute_group'];
$id_attribute = $groupAttribute['id_attribute'];
$id_product_attribute = $groupAttribute['id_product_attribute'];
$combinaison[$id_product_attribute][$id_group_attribute] = $id_attribute;
}
$productAttributes = Db::getInstance()->ExecuteS('
SELECT pa.id_product_attribute, pa.weight, pa.quantity, pi.id_image
FROM '._DB_PREFIX_.'product_attribute pa
LEFT JOIN '._DB_PREFIX_.'product_attribute_image pi ON (pa.id_product_attribute = pi.id_product_attribute)
WHERE pa.id_product = '.(int)$sqlProduct['id_product']);
if (!empty($productAttributes))
{
foreach ($productAttributes AS $productAttribute)
{
$id_product_attribute = (int)$productAttribute['id_product_attribute'];
$attributeCombination = $product->addChild('attribute-combination');
$attributeCombination->addAttribute('id', $id_product_attribute);
$attributeCombination->addChild('weight', (float)($sqlProduct['weight'] + $productAttribute['weight']));
$attributeCombination->addChild('final-retail-price-with-tax', Product::getPriceStatic((int)($sqlProduct['id_product']), true, $id_product_attribute));
$attributeCombination->addChild('final-retail-price-without-tax', Product::getPriceStatic((int)($sqlProduct['id_product']), false, $id_product_attribute));
$attributeCombination->addChild('quantity', $productAttribute['quantity']);
if (isset($productAttribute['id_image']) && !empty($productAttribute['id_image']))
{
$image = $attributeCombination->addChild('image');
$image->addAttribute('ref-id', $productAttribute['id_image']);
}
if (isset($combinaison[$id_product_attribute]) && !empty($combinaison[$id_product_attribute]))
{
foreach ($combinaison[$id_product_attribute] AS $id_group_attribute => $id_attribute)
{
$attribute = $attributeCombination->addChild('attribute');
$attribute->addAttribute('group-ref-id', $id_group_attribute);
$attribute->addAttribute('ref-id', $id_attribute);
}
}
}
}
}
echo $products->asXML();
}
private function _displayCSSAndJS()
{
return '
';
}
private function _displayImageSelector()
{
$max_width = 60;
$max_height = 60;
$dir = _PS_MODULE_DIR_.$this->name.'/logos/';
$out = ''.
$this->l('Select a picture below or upload a new one.').'
'.$this->l('New logo:').'
';
if (is_dir($dir) AND $dh = opendir($dir))
{
while (($file = readdir($dh)) !== false)
{
$filename = $dir.$file;
if (is_file($filename) AND in_array(substr($filename, -4), $this->allowed_extensions))
{
list($width, $height) = getimagesize($filename);
if ($width > $height)
{
if ($width > $max_width)
{
$ratio = $width / $max_width;
$width = $max_width;
$height = $height / $ratio;
}
}
elseif ($height > $max_height)
{
$ratio = $height / $max_height;
$height = $max_height;
$width = $width / $ratio;
}
$out .= '
';
}
}
closedir($dh);
}
$out .= '
';
return $out;
}
public function displayForm()
{
global $cookie;
$lang = new Language((int)($cookie->id_lang));
$output = $this->_displayCSSAndJS().''.$this->displayName.'
'.$this->l('It is well known that product videos increase sales, customer engagement and loyalty, and enhance your shoppers experience dramatically. They also enhance your shoppers\' overall experience and have a strong positive effect on your search engine visibility.').'. '.$this->l('Learn more').'
';
$output .= '
'.$this->l('My Treepodia account').' ';
if (!Configuration::get('TREEPODIA_ACCOUNT_CODE'))
{
$output .= '
'.$this->l('You are not yet registered for a Treepodia video account. Please register with Treepodia.').'
';
}
else
{
$output .= '
'.$this->l('Video Account Code').'
'
.$this->l('Your video account code uniquely identifies your store and was assigned to you automatically.').'
'.$this->l('Sign in to your video account to change your preferences, settings and see your business performance reports.').'
';
}
$output .= ' ';
if (Configuration::get('TREEPODIA_ACCOUNT_CODE'))
{
$output .= '
'.$this->l('Settings').'
'.$this->_displayImageSelector().'
'.$this->l('Or, implement your own integration').'
'.$this->l('Use this option if you wish to implement the Treepodia integration code on your own. The built-in integration code will be deactivated if you choose this option.').' '.$this->l('Read here how to implement Treepodia integration code on your own.').'
';
}
return $output;
}
public function getContent()
{
$out = '';
if (Tools::isSubmit('submitTreepodia'))
{
$errors = $this->_validateForm();
$out .= (empty($errors) ? $this->_postProcess() : $errors);
}
$out .= $this->displayForm();
return $out;
}
private function _validateForm()
{
$errors = '';
if (Tools::getValue('trpd_integration_type') != 0 AND Tools::getValue('trpd_integration_type') != 1)
$errors .= $this->displayError('Invalid Integration Type');
$file = $_FILES['trpd_logo_file'];
if ($file AND !empty($file['name']))
{
if ($file['error'])
{
switch ($file['error'])
{
case 1:
$errors .= $this->displayError('The file is too large.');
break;
case 2:
$errors .= $this->displayError('The file is too large.');
break;
case 3:
$errors .= $this->displayError('The file was partialy uploaded');
break;
case 4:
$errors .= $this->displayError('The file is empty');
break;
}
}
if (!in_array(substr($file['name'], -4), $this->allowed_extensions))
$errors .= $this->displayError($this->l('Invalid file type'));
}
elseif (!is_file(_PS_MODULE_DIR_.$this->name.'/logos/'.Tools::getValue('trpd_play_logo')))
$errors .= $this->displayError('Invalid logo');
return $errors;
}
private function _postProcess()
{
Configuration::updateValue('TREEPODIA_INTEGRATION_TYPE', (int)(Tools::getValue('trpd_integration_type')));
$position = Tools::getValue('trpd_position');
if ($position < 0 || $position > 2) $position = 0;
Configuration::updateValue('TREEPODIA_POSITION', $position);
$file = $_FILES['trpd_logo_file'];
if ($file AND $file['name'])
{
$name = time().'-'.$_FILES['trpd_logo_file']['name'];
move_uploaded_file($_FILES['trpd_logo_file']['tmp_name'], _PS_MODULE_DIR_.$this->name.'/logos/'.$name);
Configuration::updateValue('TREEPODIA_PLAY_LOGO', $name);
}
else
Configuration::updateValue('TREEPODIA_PLAY_LOGO', Tools::getValue('trpd_play_logo'));
$this->_sendUpdate();
if (Tools::getValue('trpd_hook_position') == 0)
{
Configuration::updateValue('TREEPODIA_HOOK', 0);
$this->unregisterHook(Hook::get('productFooter'));
$this->registerHook('extraLeft');
}
else
{
Configuration::updateValue('TREEPODIA_HOOK', 1);
$this->unregisterHook(Hook::get('extraLeft'));
$this->registerHook('productFooter');
}
$dataSync = ' ';
return $this->displayConfirmation($this->l('Settings updated').$dataSync);
}
private function _sendUpdate()
{
$host = 'www.treepodia.com';
$uri = '/prestashop/api/account-settings-set';
if (!ini_get('allow_url_fopen'))
return false;
if ($socket = fsockopen('ssl://'.$host, 443, $errno, $errstr, 30))
{
$params = 'prestashop-api='._PS_BASE_URL_._MODULE_DIR_.$this->name.'/api'.
'&account-code='.Configuration::get('TREEPODIA_ACCOUNT_CODE').
'&integration='.(Configuration::get('TREEPODIA_INTEGRATION_TYPE') == 0 ? 'built-in' : 'custom').
'&watch-video-image-url='._PS_BASE_URL_._MODULE_DIR_.$this->name.'/logos/'.Configuration::get('TREEPODIA_PLAY_LOGO').
'&watch-video-image-location=top-left';
$header = 'GET '.$uri.'?'.$params.' HTTP/1.1'."\r\n";
$header .= 'Host: '.$host."\r\n";
$header .= 'Content-Type: application/x-www-form-urlencoded' . "\r\n";
$header .= 'Content-Length: '.strlen($params)."\r\n".
$header .= 'Connection: Close'."\r\n\r\n";
fputs($socket, $header.$params);
$result = '';
while (!feof($socket))
$result .= trim(fgets($socket, 1024));
fclose($socket);
}
}
private function _isAccountCode($accountCode)
{
return ereg('^[A-Z]+[0-9]+$', $accountCode);
}
public function hookExtraLeft($params)
{
global $smarty;
$id_product = Tools::getValue('id_product');
if (!Configuration::get('TREEPODIA_ACCOUNT_CODE') OR Configuration::get('TREEPODIA_INTEGRATION_TYPE') != 0)
return '';
switch(Configuration::get('TREEPODIA_POSITION'))
{
case 0:
$position = 'left';
break;
case 1:
$position = 'center';
break;
case 2:
$position = 'right';
break;
default:
$position = 'left';
}
$smarty->assign(array('position' => $position, 'img_src' => _MODULE_DIR_.$this->name.'/logos/'.Configuration::get('TREEPODIA_PLAY_LOGO'), 'account_id' => Configuration::get('TREEPODIA_ACCOUNT_CODE'), 'product_sku' => (int)($id_product)));
return $this->display(__FILE__, 'product.tpl');
}
public function hookProductFooter($params)
{
return $this->hookExtraLeft($params);
}
public function hookFooter($params)
{
global $smarty;
if (!Configuration::get('TREEPODIA_ACCOUNT_CODE') OR Configuration::get('TREEPODIA_INTEGRATION_TYPE') != 0)
return;
if (!(int)Tools::getValue('id_product'))
return;
$smarty->assign(array('account_id' => Configuration::get('TREEPODIA_ACCOUNT_CODE'), 'product_sku' => (int)Tools::getValue('id_product')));
return $this->display(__FILE__, 'footer.tpl');
}
public function hookProductDescription($params)
{
return $this->hookExtraLeft($params);
}
public function hookOrderConfirmation($params)
{
$order = $params['objOrder'];
$products = $order->getProducts();
global $smarty;
$smarty->assign(array('account_id' => Configuration::get('TREEPODIA_ACCOUNT_CODE'), 'products' => $products));
return $this->display(__FILE__, 'tracking.tpl');
}
}