Advertisement
freakhouse

product.tpl

Oct 21st, 2013
453
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 40.24 KB | None | 0 0
  1. {*
  2. * 2007-2013 PrestaShop
  3. *
  4. * NOTICE OF LICENSE
  5. *
  6. * This source file is subject to the Academic Free License (AFL 3.0)
  7. * that is bundled with this package in the file LICENSE.txt.
  8. * It is also available through the world-wide-web at this URL:
  9. * http://opensource.org/licenses/afl-3.0.php
  10. * If you did not receive a copy of the license and are unable to
  11. * obtain it through the world-wide-web, please send an email
  12. * to license@prestashop.com so we can send you a copy immediately.
  13. *
  14. * DISCLAIMER
  15. *
  16. * Do not edit or add to this file if you wish to upgrade PrestaShop to newer
  17. * versions in the future. If you wish to customize PrestaShop for your
  18. * needs please refer to http://www.prestashop.com for more information.
  19. *
  20. * @author PrestaShop SA <contact@prestashop.com>
  21. * @copyright 2007-2013 PrestaShop SA
  22. * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0)
  23. * International Registered Trademark & Property of PrestaShop SA
  24. *}
  25.  
  26. {include file="$tpl_dir./errors.tpl"}
  27. {if $errors|@count == 0}
  28. <script type="text/javascript">
  29. // <![CDATA[
  30.  
  31. // PrestaShop internal settings
  32. var currencySign = '{$currencySign|html_entity_decode:2:"UTF-8"}';
  33. var currencyRate = '{$currencyRate|floatval}';
  34. var currencyFormat = '{$currencyFormat|intval}';
  35. var currencyBlank = '{$currencyBlank|intval}';
  36. var taxRate = {$tax_rate|floatval};
  37. var jqZoomEnabled = {if $jqZoomEnabled}true{else}false{/if};
  38.  
  39. //JS Hook
  40. var oosHookJsCodeFunctions = new Array();
  41.  
  42. // Parameters
  43. var id_product = '{$product->id|intval}';
  44. var productHasAttributes = {if isset($groups)}true{else}false{/if};
  45. var quantitiesDisplayAllowed = {if $display_qties == 1}true{else}false{/if};
  46. var quantityAvailable = {if $display_qties == 1 && $product->quantity}{$product->quantity}{else}0{/if};
  47. var allowBuyWhenOutOfStock = {if $allow_oosp == 1}true{else}false{/if};
  48. var availableNowValue = '{$product->available_now|escape:'quotes':'UTF-8'}';
  49. var availableLaterValue = '{$product->available_later|escape:'quotes':'UTF-8'}';
  50. var productPriceTaxExcluded = {$product->getPriceWithoutReduct(true)|default:'null'} - {$product->ecotax};
  51. var productBasePriceTaxExcluded = {$product->base_price} - {$product->ecotax};
  52. var reduction_percent = {if $product->specificPrice AND $product->specificPrice.reduction AND $product->specificPrice.reduction_type == 'percentage'}{$product->specificPrice.reduction*100}{else}0{/if};
  53. var reduction_price = {if $product->specificPrice AND $product->specificPrice.reduction AND $product->specificPrice.reduction_type == 'amount'}{$product->specificPrice.reduction|floatval}{else}0{/if};
  54. var specific_price = {if $product->specificPrice AND $product->specificPrice.price}{$product->specificPrice.price}{else}0{/if};
  55. var product_specific_price = new Array();
  56. {foreach from=$product->specificPrice key='key_specific_price' item='specific_price_value'}
  57. product_specific_price['{$key_specific_price}'] = '{$specific_price_value}';
  58. {/foreach}
  59. var specific_currency = {if $product->specificPrice AND $product->specificPrice.id_currency}true{else}false{/if};
  60. var group_reduction = '{$group_reduction}';
  61. var default_eco_tax = {$product->ecotax};
  62. var ecotaxTax_rate = {$ecotaxTax_rate};
  63. var currentDate = '{$smarty.now|date_format:'%Y-%m-%d %H:%M:%S'}';
  64. var maxQuantityToAllowDisplayOfLastQuantityMessage = {$last_qties};
  65. var noTaxForThisProduct = {if $no_tax == 1}true{else}false{/if};
  66. var displayPrice = {$priceDisplay};
  67. var productReference = '{$product->reference|escape:'htmlall':'UTF-8'}';
  68. var productAvailableForOrder = {if (isset($restricted_country_mode) AND $restricted_country_mode) OR $PS_CATALOG_MODE}'0'{else}'{$product->available_for_order}'{/if};
  69. var productShowPrice = '{if !$PS_CATALOG_MODE}{$product->show_price}{else}0{/if}';
  70. var productUnitPriceRatio = '{$product->unit_price_ratio}';
  71. var idDefaultImage = {if isset($cover.id_image_only)}{$cover.id_image_only}{else}0{/if};
  72. var stock_management = {$stock_management|intval};
  73. {if !isset($priceDisplayPrecision)}
  74. {assign var='priceDisplayPrecision' value=2}
  75. {/if}
  76. {if !$priceDisplay || $priceDisplay == 2}
  77. {assign var='productPrice' value=$product->getPrice(true, $smarty.const.NULL, $priceDisplayPrecision)}
  78. {assign var='productPriceWithoutReduction' value=$product->getPriceWithoutReduct(false, $smarty.const.NULL)}
  79. {elseif $priceDisplay == 1}
  80. {assign var='productPrice' value=$product->getPrice(false, $smarty.const.NULL, $priceDisplayPrecision)}
  81. {assign var='productPriceWithoutReduction' value=$product->getPriceWithoutReduct(true, $smarty.const.NULL)}
  82. {/if}
  83.  
  84.  
  85. var productPriceWithoutReduction = '{$productPriceWithoutReduction}';
  86. var productPrice = '{$productPrice}';
  87.  
  88. // Customizable field
  89. var img_ps_dir = '{$img_ps_dir}';
  90. var customizationFields = new Array();
  91. {assign var='imgIndex' value=0}
  92. {assign var='textFieldIndex' value=0}
  93. {foreach from=$customizationFields item='field' name='customizationFields'}
  94. {assign var="key" value="pictures_`$product->id`_`$field.id_customization_field`"}
  95. customizationFields[{$smarty.foreach.customizationFields.index|intval}] = new Array();
  96. customizationFields[{$smarty.foreach.customizationFields.index|intval}][0] = '{if $field.type|intval == 0}img{$imgIndex++}{else}textField{$textFieldIndex++}{/if}';
  97. customizationFields[{$smarty.foreach.customizationFields.index|intval}][1] = {if $field.type|intval == 0 && isset($pictures.$key) && $pictures.$key}2{else}{$field.required|intval}{/if};
  98. {/foreach}
  99.  
  100. // Images
  101. var img_prod_dir = '{$img_prod_dir}';
  102. var combinationImages = new Array();
  103.  
  104. {if isset($combinationImages)}
  105. {foreach from=$combinationImages item='combination' key='combinationId' name='f_combinationImages'}
  106. combinationImages[{$combinationId}] = new Array();
  107. {foreach from=$combination item='image' name='f_combinationImage'}
  108. combinationImages[{$combinationId}][{$smarty.foreach.f_combinationImage.index}] = {$image.id_image|intval};
  109. {/foreach}
  110. {/foreach}
  111. {/if}
  112.  
  113. combinationImages[0] = new Array();
  114. {if isset($images)}
  115. {foreach from=$images item='image' name='f_defaultImages'}
  116. combinationImages[0][{$smarty.foreach.f_defaultImages.index}] = {$image.id_image};
  117. {/foreach}
  118. {/if}
  119.  
  120. // Translations
  121. var doesntExist = '{l s='This combination does not exist for this product. Please select another combination.' js=1}';
  122. var doesntExistNoMore = '{l s='This product is no longer in stock' js=1}';
  123. var doesntExistNoMoreBut = '{l s='with those attributes but is available with others.' js=1}';
  124. var uploading_in_progress = '{l s='Uploading in progress, please be patient.' js=1}';
  125. var fieldRequired = '{l s='Please fill in all the required fields before saving your customization.' js=1}';
  126.  
  127. {if isset($groups)}
  128. // Combinations
  129. {foreach from=$combinations key=idCombination item=combination}
  130. var specific_price_combination = new Array();
  131. var available_date = new Array();
  132. specific_price_combination['reduction_percent'] = {if $combination.specific_price AND $combination.specific_price.reduction AND $combination.specific_price.reduction_type == 'percentage'}{$combination.specific_price.reduction*100}{else}0{/if};
  133. specific_price_combination['reduction_price'] = {if $combination.specific_price AND $combination.specific_price.reduction AND $combination.specific_price.reduction_type == 'amount'}{$combination.specific_price.reduction}{else}0{/if};
  134. specific_price_combination['price'] = {if $combination.specific_price AND $combination.specific_price.price}{$combination.specific_price.price}{else}0{/if};
  135. specific_price_combination['reduction_type'] = '{if $combination.specific_price}{$combination.specific_price.reduction_type}{/if}';
  136. specific_price_combination['id_product_attribute'] = {if $combination.specific_price}{$combination.specific_price.id_product_attribute|intval}{else}0{/if};
  137. available_date['date'] = '{$combination.available_date}';
  138. available_date['date_formatted'] = '{dateFormat date=$combination.available_date full=false}';
  139. addCombination({$idCombination|intval}, new Array({$combination.list}), {$combination.quantity}, {$combination.price}, {$combination.ecotax}, {$combination.id_image}, '{$combination.reference|addslashes}', {$combination.unit_impact}, {$combination.minimal_quantity}, available_date, specific_price_combination);
  140. {/foreach}
  141. {/if}
  142.  
  143. {if isset($attributesCombinations)}
  144. // Combinations attributes informations
  145. var attributesCombinations = new Array();
  146. {foreach from=$attributesCombinations key=id item=aC}
  147. tabInfos = new Array();
  148. tabInfos['id_attribute'] = '{$aC.id_attribute|intval}';
  149. tabInfos['attribute'] = '{$aC.attribute}';
  150. tabInfos['group'] = '{$aC.group}';
  151. tabInfos['id_attribute_group'] = '{$aC.id_attribute_group|intval}';
  152. attributesCombinations.push(tabInfos);
  153. {/foreach}
  154. {/if}
  155. //]]>
  156. </script>
  157.  
  158. {include file="$tpl_dir./breadcrumb.tpl"}
  159. <div id="primary_block" class="clearfix">
  160. {if isset($adminActionDisplay) && $adminActionDisplay}
  161. <div id="admin-action">
  162. <p>{l s='This product is not visible to your customers.'}
  163. <input type="hidden" id="admin-action-product-id" value="{$product->id}" />
  164. <input type="submit" value="{l s='Publish'}" class="exclusive" onclick="submitPublishProduct('{$base_dir}{$smarty.get.ad|escape:'htmlall':'UTF-8'}', 0, '{$smarty.get.adtoken|escape:'htmlall':'UTF-8'}')"/>
  165. <input type="submit" value="{l s='Back'}" class="exclusive" onclick="submitPublishProduct('{$base_dir}{$smarty.get.ad|escape:'htmlall':'UTF-8'}', 1, '{$smarty.get.adtoken|escape:'htmlall':'UTF-8'}')"/>
  166. </p>
  167. <p id="admin-action-result"></p>
  168. </p>
  169. </div>
  170. {/if}
  171. {if isset($confirmation) && $confirmation}
  172. <p class="confirmation">
  173. {$confirmation}
  174. </p>
  175. {/if}
  176. <!--ADD CUSTOM CLOUD ZOOM!!!-->
  177. <!-- Call quick start function. -->
  178. <!-- right infos-->
  179. <div class="row">
  180. <div id="pb-right-column" class="span4">
  181. <h1 class="pb-right-colum-h">{$product->name|escape:'htmlall':'UTF-8'}</h1>
  182. <!-- product img-->
  183. <div id="image-block">
  184. {if $have_image}
  185. <span id="view_full_size">
  186. {if $jqZoomEnabled}<a id="zoom1" rel="position: 'inside' , showTitle: false, adjustX:0, adjustY:0" class="cloud-zoom" href="{$link->getImageLink($product->link_rewrite, $cover.id_image,'thickbox_default')}">
  187. <img id="mousetrap_img" alt="{$product->name|escape:'htmlall':'UTF-8'}" width="106" height="106" title="{$product->name|escape:'htmlall':'UTF-8'}" src="{$link->getImageLink($product->link_rewrite, $cover.id_image, 'thickbox_default')}" >
  188. <img id="bigpic" alt="{$product->name|escape:'htmlall':'UTF-8'}" title="{$product->name|escape:'htmlall':'UTF-8'}" src="{$link->getImageLink($product->link_rewrite, $cover.id_image, 'large_default')}" /><span class="mask"></span>
  189. </a>
  190. {else}
  191. <img id="bigpic" alt="{$product->name|escape:'htmlall':'UTF-8'}" title="{$product->name|escape:'htmlall':'UTF-8'}" src="{$link->getImageLink($product->link_rewrite, $cover.id_image, 'large_default')}" />
  192.  
  193. {/if}
  194. </span>
  195. {else}
  196. <span id="view_full_size">
  197. <img src="{$img_prod_dir}{$lang_iso}-default-large_default.jpg" id="bigpic" alt="" title="{$product->name|escape:'htmlall':'UTF-8'}" width="{$largeSize.width}" height="{$largeSize.height}" />
  198. <span class="span_link">{l s='Maximize'}</span>
  199. </span>
  200. {/if}
  201. </div>
  202.  
  203. {if isset($images) && count($images) > 0}
  204. <!-- thumbnails -->
  205. <div id="views_block" class=" {if isset($images) && count($images) < 2}hidden{/if}">
  206. {if isset($images) && count($images) > 4}<a id="view_scroll_left" title="{l s='Other views'}" href="javascript:{ldelim}{rdelim}">{l s='Previous'}</a>{/if}
  207. <div id="thumbs_list">
  208. <ul id="thumbs_list_frame">
  209. {if isset($images)}
  210.  
  211. {foreach from=$images item=image name=thumbnails}
  212.  
  213. {assign var=imageIds value="`$product->id`-`$image.id_image`"}
  214. <li id="thumbnail_{$image.id_image}">
  215. {if $jqZoomEnabled}
  216. <a href="{$link->getImageLink($product->link_rewrite, $imageIds, 'thickbox_default')}" class="cloud-zoom-gallery" title="{$image.legend|htmlspecialchars}" rel="useZoom: 'zoom1', smallImage: '{$link->getImageLink($product->link_rewrite, $imageIds, 'large_default')}'">
  217. <img id="thumb_{$image.id_image}" src="{$link->getImageLink($product->link_rewrite, $imageIds, 'medium_default')}" alt="{$image.legend|htmlspecialchars}" />
  218. </a>
  219. {else}
  220. <a href="{$link->getImageLink($product->link_rewrite, $imageIds, 'thickbox_default')}" rel="other-views" class="thickbox {if $smarty.foreach.thumbnails.first}shown{/if}" title="{$image.legend|htmlspecialchars}">
  221. <img id="thumb_{$image.id_image}" src="{$link->getImageLink($product->link_rewrite, $imageIds, 'medium_default')}" alt="{$image.legend|htmlspecialchars}" />
  222. </a>
  223. {/if}
  224. </li>
  225. {/foreach}
  226. {/if}
  227. </ul>
  228. </div>
  229. {if isset($images) && count($images) > 4}<a id="view_scroll_right" title="{l s='Other views'}" href="javascript:{ldelim}{rdelim}">{l s='Next'}</a>{/if}
  230. </div>
  231. {/if}
  232. {if isset($images) && count($images) > 1}
  233. <p class="resetimg">
  234. <span id="wrapResetImages" style="display: none;">
  235. <i class="icon-reply"></i>
  236. <a id="resetImages" href="{$link->getProductLink($product)}" onclick="$('span#wrapResetImages').hide('slow');return (false);">{l s='Display all pictures'}</a></span></p>
  237. {/if}
  238. <ul id="usefull_link_block" class="clearfix" >
  239. {if $HOOK_EXTRA_LEFT}{$HOOK_EXTRA_LEFT}{/if}
  240. <li class="print"><a href="javascript:print();"><i class="icon-print"></i>{l s='Print'}</a></li>
  241. </ul>
  242. </div>
  243. <!-- left infos-->
  244. <div id="pb-left-column" class="span5">
  245. <h1>{$product->name|escape:'htmlall':'UTF-8'}</h1>
  246. {if $product->description_short OR $packItems|@count > 0}
  247. <div id="short_description_block">
  248. {if $product->description_short}
  249. <div id="short_description_content" class="rte align_justify">{$product->description_short}</div>
  250. {/if}
  251. {if $product->description}
  252. {* <p class="buttons_bottom_block"><a href="javascript:{ldelim}{rdelim}" class="button">{l s='More details'}</a></p>*}
  253. {/if}
  254. <!--{if $packItems|@count > 0}
  255. <div class="short_description_pack">
  256. <h3>{l s='Pack content'}</h3>
  257. {foreach from=$packItems item=packItem}
  258. <div class="pack_content">
  259. {$packItem.pack_quantity} x <a href="{$link->getProductLink($packItem.id_product, $packItem.link_rewrite, $packItem.category)}">{$packItem.name|escape:'htmlall':'UTF-8'}</a>
  260. <p>{$packItem.description_short}</p>
  261. </div>
  262. {/foreach}
  263. </div>
  264. {/if}-->
  265. </div>
  266. {/if}
  267.  
  268. {*{if isset($colors) && $colors}
  269. <!-- colors -->
  270. <div id="color_picker">
  271. <p>{l s='Pick a color:' js=1}</p>
  272. <div class="clear"></div>
  273. <ul id="color_to_pick_list" class="clearfix">
  274. {foreach from=$colors key='id_attribute' item='color'}
  275. <li><a id="color_{$id_attribute|intval}" class="color_pick" style="background: {$color.value};" onclick="updateColorSelect({$id_attribute|intval});$('#wrapResetImages').show('slow');" title="{$color.name}">{if file_exists($col_img_dir|cat:$id_attribute|cat:'.jpg')}<img src="{$img_col_dir}{$id_attribute}.jpg" alt="{$color.name}" width="20" height="20" />{/if}</a></li>
  276. {/foreach}
  277. </ul>
  278. <div class="clear"></div>
  279. </div>
  280. {/if}*}
  281.  
  282. {if ($product->show_price AND !isset($restricted_country_mode)) OR isset($groups) OR $product->reference OR (isset($HOOK_PRODUCT_ACTIONS) && $HOOK_PRODUCT_ACTIONS)}
  283. <!-- add to cart form-->
  284. <form id="buy_block" {if $PS_CATALOG_MODE AND !isset($groups) AND $product->quantity > 0}class="hidden"{/if} action="{$link->getPageLink('cart')}" method="post">
  285.  
  286. <!-- hidden datas -->
  287. <p class="hidden">
  288. <input type="hidden" name="token" value="{$static_token}" />
  289. <input type="hidden" name="id_product" value="{$product->id|intval}" id="product_page_product_id" />
  290. <input type="hidden" name="add" value="1" />
  291. <input type="hidden" name="id_product_attribute" id="idCombination" value="" />
  292. </p>
  293. <div class="product_attributes">
  294.  
  295. <div class="row-3">
  296.  
  297.  
  298. <!-- availability -->
  299. <p id="availability_statut"{if ($product->quantity <= 0 && !$product->available_later && $allow_oosp) OR ($product->quantity > 0 && !$product->available_now) OR !$product->available_for_order OR $PS_CATALOG_MODE} style="display: none;"{/if}>
  300. <span id="availability_label">{l s='Availability:'}</span>
  301. <span id="availability_value"{if $product->quantity <= 0} class="warning_inline"{/if}>
  302. {if $product->quantity <= 0}{if $allow_oosp}{$product->available_later}{else}{l s='This product is no longer in stock'}{/if}{else}{$product->available_now}{/if}
  303. </span>
  304. </p>
  305.  
  306. <!-- number of item in stock -->
  307. {if ($display_qties == 1 && !$PS_CATALOG_MODE && $product->available_for_order)}
  308. <p id="pQuantityAvailable"{if $product->quantity <= 0} style="display: none;"{/if}>
  309. <span id="quantityAvailable">{$product->quantity|intval}</span>
  310. <span {if $product->quantity > 1} style="display: none;"{/if} id="quantityAvailableTxt">{l s='item in stock'}</span>
  311. <span {if $product->quantity == 1} style="display: none;"{/if} id="quantityAvailableTxtMultiple">{l s='items in stock'}</span>
  312. </p>
  313. {/if}
  314.  
  315. <p class="warning_inline" id="last_quantities"{if ($product->quantity > $last_qties OR $product->quantity <= 0) OR $allow_oosp OR !$product->available_for_order OR $PS_CATALOG_MODE} style="display: none"{/if} >{l s='Warning: Last items in stock!'}</p>
  316.  
  317.  
  318.  
  319. <p id="product_reference" {if isset($groups) OR !$product->reference}style="display: none;"{/if}>
  320. <label for="product_reference">{l s='Reference:'} </label>
  321. <span class="editable">{$product->reference|escape:'htmlall':'UTF-8'}</span>
  322. </p>
  323. {if $product->online_only}
  324. <span class="online_only">{l s='Online only'}</span>
  325. {/if}
  326. </div>
  327.  
  328. {if isset($groups)}
  329. <!-- attributes -->
  330. <div id="attributes">
  331. {foreach from=$groups key=id_attribute_group item=group}
  332. {if $group.attributes|@count}
  333. <fieldset class="attribute_fieldset">
  334. <label class="attribute_label" for="group_{$id_attribute_group|intval}">{$group.name|escape:'htmlall':'UTF-8'} :&nbsp;</label>
  335. {assign var="groupName" value="group_$id_attribute_group"}
  336. <div class="attribute_list">
  337. {if ($group.group_type == 'select')}
  338. <select name="{$groupName}" id="group_{$id_attribute_group|intval}" class="attribute_select" onchange="findCombination();getProductAttribute();">
  339. {foreach from=$group.attributes key=id_attribute item=group_attribute}
  340. <option value="{$id_attribute|intval}"{if (isset($smarty.get.$groupName) && $smarty.get.$groupName|intval == $id_attribute) || $group.default == $id_attribute} selected="selected"{/if} title="{$group_attribute|escape:'htmlall':'UTF-8'}">{$group_attribute|escape:'htmlall':'UTF-8'}</option>
  341. {/foreach}
  342. </select>
  343. {elseif ($group.group_type == 'color')}
  344. <ul id="color_to_pick_list" class="clearfix">
  345. {assign var="default_colorpicker" value=""}
  346. {foreach from=$group.attributes key=id_attribute item=group_attribute}
  347. <li{if $group.default == $id_attribute} class="selected"{/if}>
  348. <a id="color_{$id_attribute|intval}" class="color_pick{if ($group.default == $id_attribute)} selected{/if}" style="background: {$colors.$id_attribute.value};" title="{$colors.$id_attribute.name}" onclick="colorPickerClick(this);getProductAttribute();">
  349. {if file_exists($col_img_dir|cat:$id_attribute|cat:'.jpg')}
  350. <img src="{$img_col_dir}{$id_attribute}.jpg" alt="{$colors.$id_attribute.name}" width="25" height="25" /><br />
  351. {/if}
  352. </a>
  353. </li>
  354. {if ($group.default == $id_attribute)}
  355. {$default_colorpicker = $id_attribute}
  356. {/if}
  357. {/foreach}
  358. </ul>
  359. <input type="hidden" class="color_pick_hidden" name="{$groupName}" value="{$default_colorpicker}" />
  360. {elseif ($group.group_type == 'radio')}
  361. <ul>
  362. {foreach from=$group.attributes key=id_attribute item=group_attribute}
  363. <li>
  364. <div class="list-radio"><input type="radio" class="attribute_radio" name="{$groupName}" value="{$id_attribute}" {if ($group.default == $id_attribute)} checked="checked"{/if} onclick="findCombination();getProductAttribute();" />
  365. {$group_attribute|escape:'htmlall':'UTF-8'}</div>
  366. </li>
  367. {/foreach}
  368. </ul>
  369. {/if}
  370. </div>
  371. </fieldset>
  372. {/if}
  373. {/foreach}
  374. </div>
  375. {/if}
  376.  
  377.  
  378. <!-- minimal quantity wanted -->
  379. <p id="minimal_quantity_wanted_p"{if $product->minimal_quantity <= 1 OR !$product->available_for_order OR $PS_CATALOG_MODE} style="display: none;"{/if}>
  380. {l s='This product is not sold individually. You must select at least'} <b id="minimal_quantity_label">{$product->minimal_quantity}</b> {l s='quantity for this product.'}
  381. </p>
  382. {if $product->minimal_quantity > 1}
  383. <script type="text/javascript">
  384. checkMinimalQuantity();
  385. </script>
  386. {/if}
  387. <p class="warning_inline" id="last_quantities"{if ($product->quantity > $last_qties OR $product->quantity <= 0) OR $allow_oosp OR !$product->available_for_order OR $PS_CATALOG_MODE} style="display: none"{/if} >{l s='Warning: Last items in stock!'}</p>
  388. </div>
  389. <div class="content_prices clearfix">
  390. <!-- prices -->
  391. {if $product->show_price AND !isset($restricted_country_mode) AND !$PS_CATALOG_MODE}
  392.  
  393.  
  394. <div class="row-2" {if !$product->specificPrice} style="display:none;"{/if}>
  395.  
  396.  
  397. <p id="reduction_percent" {if !$product->specificPrice OR $product->specificPrice.reduction_type != 'percentage'} style="display:none;"{/if}><span id="reduction_percent_display" class="price">{if $product->specificPrice AND $product->specificPrice.reduction_type == 'percentage'}-{$product->specificPrice.reduction*100}%{/if}</span></p>
  398. <p id="reduction_amount" {if !$product->specificPrice OR $product->specificPrice.reduction_type != 'amount' || $product->specificPrice.reduction|intval ==0} style="display:none"{/if}><span id="reduction_amount_display" class="price">{if $product->specificPrice AND $product->specificPrice.reduction_type == 'amount' && $product->specificPrice.reduction|intval !=0}-{convertPrice price=$product->specificPrice.reduction|floatval}{/if}</span></p>
  399. {if $product->specificPrice AND $product->specificPrice.reduction && $product->specificPrice.reduction > 0}
  400. <p id="old_price"><span class="price">
  401. {if $priceDisplay >= 0 && $priceDisplay <= 2}
  402. {if $productPriceWithoutReduction > $productPrice}
  403. <span id="old_price_display price">{convertPrice price=$productPriceWithoutReduction}</span>
  404. <!-- {if $tax_enabled && $display_tax_label == 1}
  405. {if $priceDisplay == 1}{l s='tax excl.'}{else}{l s='tax incl.'}{/if}
  406. {/if} -->
  407. {/if}
  408. {/if}
  409. </span>
  410. </p>
  411. {/if}
  412. {if $product->on_sale}
  413. <img src="{$img_dir}onsale_{$lang_iso}.gif" alt="{l s='On sale'}" class="on_sale_img"/>
  414. <span class="on_sale">{l s='On sale!'}</span>
  415. {elseif $product->specificPrice AND $product->specificPrice.reduction AND $productPriceWithoutReduction > $productPrice}
  416. <span class="discount">{l s='Reduced price!'}</span>
  417. {/if}
  418. </div>
  419. <div class="row_1">
  420. <p class="our_price_display">
  421. {if $priceDisplay >= 0 && $priceDisplay <= 2}
  422. <span id="our_price_display">{convertPrice price=$productPrice}</span>
  423. <!--{if $tax_enabled && ((isset($display_tax_label) && $display_tax_label == 1) OR !isset($display_tax_label))}
  424. {if $priceDisplay == 1}{l s='tax excl.'}{else}{l s='tax incl.'}{/if}
  425. {/if}-->
  426. {/if}
  427. </p>
  428.  
  429. {if (!$allow_oosp && $product->quantity <= 0) OR !$product->available_for_order OR (isset($restricted_country_mode) AND $restricted_country_mode) OR $PS_CATALOG_MODE}
  430. <span class="exclusive">
  431. <span></span>
  432. {l s='Add to cart'}
  433. </span>
  434. {else}
  435. <p id="add_to_cart" class="buttons_bottom_block">
  436.  
  437. <a class="exclusive button btn_add_cart" href="javascript:document.getElementById('add2cartbtn').click();"> <span>{l s='Add to cart'} </span></a>
  438. <input id="add2cartbtn" type="submit" name="Submit" value="{l s='Add to cart'}" />
  439. <!--show when "This product is no longer in stock with those attributes but is available with others"-->
  440. <span class="exclusive" style="display:none;">
  441. <span></span>
  442. {l s='Add to cart'}
  443. </span>
  444. </p>
  445. {/if}
  446. <!-- quantity wanted -->
  447. <p id="quantity_wanted_p"{if (!$allow_oosp && $product->quantity <= 0) OR $virtual OR !$product->available_for_order OR $PS_CATALOG_MODE} style="display: none;"{/if}>
  448.  
  449. <input type="text" name="qty" id="quantity_wanted" class="text" value="{if isset($quantityBackup)}{$quantityBackup|intval}{else}{if $product->minimal_quantity > 1}{$product->minimal_quantity}{else}1{/if}{/if}" size="2" maxlength="3" {if $product->minimal_quantity > 1}onkeyup="checkMinimalQuantity({$product->minimal_quantity});"{/if} />
  450. <label>{l s='Quantity:'}</label>
  451. </p>
  452. </div>
  453.  
  454. <div class="other-prices">
  455.  
  456. {if $priceDisplay == 2}
  457. <span id="pretaxe_price"><span id="pretaxe_price_display">{convertPrice price=$product->getPrice(false, $smarty.const.NULL)}</span>&nbsp;{l s='tax excl.'}</span>
  458. {/if}
  459. {if $packItems|@count && $productPrice < $product->getNoPackPrice()}
  460. <p class="pack_price">{l s='Instead of'} <span class="price" style="text-decoration: line-through;">{convertPrice price=$product->getNoPackPrice()}</span></p>
  461. {/if}
  462. {if $product->ecotax != 0}
  463. <p class="price-ecotax">{l s='include'} <span id="ecotax_price_display">{if $priceDisplay == 2}{$ecotax_tax_exc|convertAndFormatPrice}{else}{$ecotax_tax_inc|convertAndFormatPrice}{/if}</span> {l s='for green tax'}
  464. {if $product->specificPrice AND $product->specificPrice.reduction}
  465. <br />{l s='(not impacted by the discount)'}
  466. {/if}
  467. </p>
  468. {/if}
  469. {if !empty($product->unity) && $product->unit_price_ratio > 0.000000}
  470. {math equation="pprice / punit_price" pprice=$productPrice punit_price=$product->unit_price_ratio assign=unit_price}
  471. <p class="unit-price"><span id="unit_price_display">{convertPrice price=$unit_price}</span> {l s='per'} {$product->unity|escape:'htmlall':'UTF-8'}</p>
  472. {/if}
  473. </div>
  474. {/if}
  475. </div>
  476.  
  477. <!-- Out of stock hook -->
  478. <p id="oosHook"{if $product->quantity > 0} style="display: none;"{/if}>
  479. {$HOOK_PRODUCT_OOS}
  480. </p>
  481.  
  482. {if isset($HOOK_PRODUCT_ACTIONS) && $HOOK_PRODUCT_ACTIONS}{$HOOK_PRODUCT_ACTIONS}{/if}
  483.  
  484. </form>
  485. {/if}
  486. {if isset($HOOK_EXTRA_RIGHT) && $HOOK_EXTRA_RIGHT}{$HOOK_EXTRA_RIGHT}{/if}
  487. </div>
  488. </div>
  489.  
  490. </div>
  491. <!-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------->
  492. <div class="clear"></div>
  493.  
  494.  
  495. <div class="extra-box-product">
  496.  
  497. {if isset($HOOK_PRODUCT_FOOTER) && $HOOK_PRODUCT_FOOTER}{$HOOK_PRODUCT_FOOTER}{/if}
  498.  
  499. {if (isset($quantity_discounts) && count($quantity_discounts) > 0)}
  500. <script type="text/javascript">
  501. $(function() {
  502. $('#quantityDiscount table').footable();
  503. breakpoints: {
  504. phone: 480
  505. }
  506. });
  507. </script>
  508. <section id="quantityDiscount" class="page_product_box toggle_frame">
  509. <h3 class="toggle">{l s='Sliding scale pricing'}<i class="icon-toggle icon-minus-sign-alt"></i></h3>
  510. <div class="toggle_content">
  511. <table class=" std shop_table footable ">
  512. <thead>
  513. <tr>
  514. <th data-class="expand">{l s='Product'}</th>
  515. <th data-hide="phone">{l s='From (qty)'}</th>
  516. <th data-hide="phone">{l s='Discount'}</th>
  517. </tr>
  518. </thead>
  519. <tbody>
  520. {foreach from=$quantity_discounts item='quantity_discount' name='quantity_discounts'}
  521. <tr id="quantityDiscount_{$quantity_discount.id_product_attribute}">
  522. <td>
  523. {if (isset($quantity_discount.attributes) && ($quantity_discount.attributes))}
  524. {$product->getProductName($quantity_discount.id_product, $quantity_discount.id_product_attribute)}
  525. {else}
  526. {$product->getProductName($quantity_discount.id_product)}
  527. {/if}
  528. </td>
  529. <td>{$quantity_discount.quantity|intval}</td>
  530. <td>
  531. {if $quantity_discount.price >= 0 OR $quantity_discount.reduction_type == 'amount'}
  532. -{convertPrice price=$quantity_discount.real_value|floatval}
  533. {else}
  534. -{$quantity_discount.real_value|floatval}%
  535. {/if}
  536. </td>
  537. </tr>
  538. {/foreach}
  539. </tbody>
  540. </table>
  541. </div>
  542. </section>
  543. {/if}
  544.  
  545. {if (isset($product) && $product->description) || (isset($features) && $features) || (isset($accessories) && $accessories) || (isset($HOOK_PRODUCT_TAB) && $HOOK_PRODUCT_TAB) || (isset($attachments) && $attachments)}
  546.  
  547. {if $product->description}
  548. <section class="page_product_box toggle_frame more_info_inner">
  549. <h3 class="toggle">{l s='More info'}<i class="icon-toggle icon-minus-sign-alt"></i></h3>
  550. {if isset($product) && $product->description}
  551. <div class="toggle_content">
  552. {$product->description}
  553. </div>
  554. {/if}
  555. </section>
  556. {/if}
  557.  
  558. {if $features}
  559. <section class="page_product_box toggle_frame datasheet">
  560. <h3 class="toggle">{l s='Data sheet'}<i class="icon-toggle icon-minus-sign-alt"></i></h3>
  561. <div class="toggle_content">
  562. {if isset($features) && $features}
  563. <ul class="bullet">
  564. {foreach from=$features item=feature}
  565. {if isset($feature.value)}
  566. <li><i class="icon-angle-right"></i> <span>{$feature.name|escape:'htmlall':'UTF-8'} - </span> {$feature.value|escape:'htmlall':'UTF-8'}</li>
  567. {/if}
  568. {/foreach}
  569. </ul>
  570. {/if}
  571. </div>
  572. </section>
  573. {/if}
  574. {if $attachments}
  575. <section class="page_product_box toggle_frame attachment_product">
  576. <h3 class="toggle">{l s='Download'}<i class="icon-toggle icon-minus-sign-alt"></i></h3>
  577. <div class="toggle_content">
  578. {if isset($attachments) && $attachments}
  579. <ul class="bullet">
  580. {foreach from=$attachments item=attachment}
  581. <li>
  582. <a href="{$link->getPageLink('attachment', true, NULL, "id_attachment={$attachment.id_attachment}")}">
  583. <i class="icon-angle-right"></i> {$attachment.name|escape:'htmlall':'UTF-8'}
  584. </a>
  585. {$attachment.description|escape:'htmlall':'UTF-8'}
  586. </li>
  587. {/foreach}
  588. </ul>
  589. {/if}
  590. </div>
  591. </section>
  592. {/if}
  593.  
  594. {if isset($accessories) AND $accessories}
  595. <section class="page_product_box toggle_frame more_info_inner4">
  596. <h3 class="toggle">{l s='Accessories'}<i class="icon-toggle icon-minus-sign-alt"></i></h3>
  597. {if isset($accessories) AND $accessories}
  598. <ul id="idTab4" class="toggle_content">
  599. {foreach from=$accessories item=accessory name=accessories_list}
  600. {if ($accessory.allow_oosp || (isset($accessory.quantity_all_versions) && $accessory.quantity_all_versions > 0) || $accessory.quantity > 0) AND $accessory.available_for_order AND !isset($restricted_country_mode)}
  601. {assign var='accessoryLink' value=$link->getProductLink($accessory.id_product, $accessory.link_rewrite, $accessory.category)}
  602. <li class="ajax_block_product bordercolor {if $smarty.foreach.accessories_list.first}first_item{elseif $smarty.foreach.accessories_list.last}last_item{else}item{/if} product_accessories_description">
  603. <div class="accessories_desc bordercolor">
  604. <a href="{$accessoryLink|escape:'htmlall':'UTF-8'}" title="{$accessory.legend|escape:'htmlall':'UTF-8'}" class="accessory_image product_img_link bordercolor">
  605. <img src="{$link->getImageLink($accessory.link_rewrite, $accessory.id_image, 'medium_default')}" alt="{$accessory.legend|escape:'htmlall':'UTF-8'}" /></a>
  606. <h5><a class="product_link" href="{$accessoryLink|escape:'htmlall':'UTF-8'}">{$accessory.name|truncate:22:'...':true|escape:'htmlall':'UTF-8'}</a></h5>
  607. <p class="product_descr" class="product_description">{$accessory.description_short|strip_tags|truncate:170:'...'}</p>
  608. </div>
  609. <div class="accessories_price">
  610. {if $accessory.show_price AND !isset($restricted_country_mode) AND !$PS_CATALOG_MODE}<span class="price">{if $priceDisplay != 1}{displayWtPrice p=$accessory.price}{else}{displayWtPrice p=$accessory.price_tax_exc}{/if}</span>{/if}
  611.  
  612. {if !$PS_CATALOG_MODE && ($accessory.allow_oosp || $accessory.quantity > 0)}
  613. <a class="exclusive button ajax_add_to_cart_button btn_add_cart" href="{$link->getPageLink('cart', true, NULL, "qty=1&amp;id_product={$accessory.id_product|intval}&amp;token={$static_token}&amp;add")}" rel="ajax_id_product_{$accessory.id_product|intval}" title="{l s='Add to cart'}"><span>{l s='Add to cart'}</span></a>
  614. {else}
  615. <span class="exclusive">{l s='Add to cart'}</span>
  616. <span class="availability">
  617. {if (isset($accessory.quantity_all_versions) && $accessory.quantity_all_versions > 0)}{l s='Product available with different options'}{else}{l s='Out of stock'}{/if}
  618. </span>
  619. {/if}
  620. </div>
  621. </li>
  622. {/if}
  623. {/foreach}
  624. </ul>
  625. {/if}
  626. </section>
  627. {/if}
  628.  
  629. {if isset($product) && $product->customizable}
  630. <section class="page_product_box toggle_frame">
  631. <h3>{l s='Product customization'}<i class="icon-toggle icon-minus-sign-alt"></i></h3>
  632. <div class="customization_block toggle_content">
  633. <form method="post" action="{$customizationFormTarget}" enctype="multipart/form-data" id="customizationForm" class="clearfix">
  634. <p class="infoCustomizable">
  635. {l s='After saving your customized product, remember to add it to your cart.'}
  636. {if $product->uploadable_files}<br />{l s='Allowed file formats are: GIF, JPG, PNG'}{/if}
  637. </p>
  638. {if $product->uploadable_files|intval}
  639. <div class="customizableProductsFile titled_box clearfix">
  640. <h2><span>{l s='Pictures'}</span></h2>
  641. <ul id="uploadable_files" >
  642. {counter start=0 assign='customizationField'}
  643. {foreach from=$customizationFields item='field' name='customizationFields'}
  644. {if $field.type == 0}
  645. <li class="customizationUploadLine{if $field.required} required{/if}">{assign var='key' value='pictures_'|cat:$product->id|cat:'_'|cat:$field.id_customization_field}
  646. {if isset($pictures.$key)}
  647. <div class="customizationUploadBrowse">
  648. <img src="{$pic_dir}{$pictures.$key}_small" alt="" />
  649. <a class="btn btn-danger" href="{$link->getProductDeletePictureLink($product, $field.id_customization_field)}" title="{l s='Delete'}" ><i class="icon-trash icon-large"></i>{l s='Delete'}
  650. </a>
  651. </div>
  652. {/if}
  653. <div class="customizationUploadBrowse">
  654. <label class="customizationUploadBrowseDescription">{if !empty($field.name)}{$field.name}{else}{l s='Please select an image file from your computer'}{/if}{if $field.required}<sup>*</sup>{/if}</label>
  655. <input type="file" name="file{$field.id_customization_field}" id="img{$customizationField}" class="customization_block_input {if isset($pictures.$key)}filled{/if}" />
  656. </div>
  657. </li>
  658. {counter}
  659. {/if}
  660. {/foreach}
  661. </ul>
  662. </div>
  663. {/if}
  664. {if $product->text_fields|intval}
  665. <div class="customizableProductsText titled_box clearfix">
  666. <h2><span>{l s='Text'}</span></h2>
  667. <ul id="text_fields">
  668. {counter start=0 assign='customizationField'}
  669. {foreach from=$customizationFields item='field' name='customizationFields'}
  670. {if $field.type == 1}
  671. <li class="customizationUploadLine{if $field.required} required{/if}">
  672. <label for ="textField{$customizationField}">{assign var='key' value='textFields_'|cat:$product->id|cat:'_'|cat:$field.id_customization_field} {if !empty($field.name)}{$field.name}{/if}{if $field.required}<sup>*</sup>{/if}</label>
  673. <textarea type="text" name="textField{$field.id_customization_field}" id="textField{$customizationField}" rows="1" cols="40" class="customization_block_input" >{if isset($textFields.$key)}{$textFields.$key|stripslashes}{/if}</textarea>
  674. </li>
  675. {counter}
  676. {/if}
  677. {/foreach}
  678. </ul>
  679. </div>
  680. {/if}
  681. <p id="customizedDatas">
  682. <input type="hidden" name="quantityBackup" id="quantityBackup" value="" />
  683. <input type="hidden" name="submitCustomizedDatas" value="1" />
  684. <input type="button" class="button" value="{l s='Save'}" onclick="javascript:saveCustomization()" />
  685. <span id="ajax-loader" style="display:none"><img src="{$img_ps_dir}loader.gif" alt="loader" /></span>
  686. </p><p class="required"><sup>*</sup> {l s='required fields'}</p>
  687. </form>
  688. </div>
  689. </section>
  690. {/if}
  691.  
  692.  
  693. <section id="last_page_product" class="page_product_box toggle_frame">
  694. {$HOOK_PRODUCT_TAB}
  695. <div id="more_info_sheets" class="toggle_content toggle_content_comment">
  696. {if isset($HOOK_PRODUCT_TAB_CONTENT) && $HOOK_PRODUCT_TAB_CONTENT}{$HOOK_PRODUCT_TAB_CONTENT}{/if}
  697. </div>
  698. </section>
  699. {/if}
  700. </div>
  701. {if isset($packItems) && $packItems|@count > 0}
  702. <section id="blockpack" class="page_product_box toggle_frame">
  703. <h3 class="toggle">{l s='Pack content'}<i class="icon-toggle icon-minus-sign-alt"></i></h3>
  704. <div class="toggle_content">
  705. {include file="$tpl_dir./product-list.tpl" products=$packItems}
  706. </div>
  707. </section>
  708. {/if}
  709. {/if}
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement