viewcart.tpl 52 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898
  1. {if $smarty.post.onepageorder == "1"}
  2. {if $action eq 'checkout'}
  3. {include file="orderforms/{$carttpl}/checkout.tpl"}
  4. {else}
  5. <div class="cartsummary_cont">
  6. <div class="heading">
  7. <ul>
  8. <li>
  9. {$LANG.orderdesc}
  10. </li>
  11. <li>
  12. {$LANG.orderprice}
  13. </li>
  14. </ul>
  15. </div>
  16. <div class="summary_body">
  17. {if $errormessage}
  18. <div class="errorbox" style="display:block;">
  19. {$errormessage|replace:'<li>':' &nbsp;#&nbsp; '} &nbsp;#&nbsp;
  20. </div>
  21. {elseif $promotioncode && $rawdiscount eq "0.00"}
  22. <div class="errorbox" style="display:block;">
  23. {$LANG.promoappliedbutnodiscount}
  24. </div>
  25. {/if}
  26. <div class="cart-contents collapse" id="CartContents">
  27. {if $cartitems == 0}
  28. <div class="emptycart">
  29. {$LANG.cartempty}
  30. </div>
  31. {/if}
  32. {foreach $products as $num => $product}
  33. <div class="summary_products">
  34. <ul>
  35. <li>
  36. <span class="product-group">{$product.productinfo.groupname}</span>
  37. <span class="product-name">{$product.productinfo.name}</span>
  38. {if $product.domain}<span class="product-domain text-muted">{$product.domain}</span>{/if}
  39. </li>
  40. <li>{$product.pricing.baseprice}{if $product.proratadate}<br />({$LANG.orderprorata} {$product.proratadate}){/if}</li>
  41. </ul>
  42. {if $product.configoptions}
  43. <div class="configurableoptions">
  44. {foreach key=confnum item=configoption from=$product.configoptions}
  45. <div class="clearfix">
  46. <span class="pull-left float-left">&nbsp;&raquo; {$configoption.name}: {$configoption.optionname}</span>
  47. <span class="pull-right float-right">{$configoption.recurring} {* {if $configoption.setup} + {$configoption.setup} {$LANG.ordersetupfee}{/if} *}</span>
  48. </div>
  49. {/foreach}
  50. </div>
  51. {/if}
  52. {foreach $product.addons as $addonnum => $addon}
  53. <div class="clearfix">
  54. <span class="pull-left float-left">+ {$addon.name}</span></li>
  55. <span class="pull-right float-right">{$addon.recurring}</span></li>
  56. </div>
  57. {/foreach}
  58. </div>
  59. {/foreach}
  60. {foreach $addons as $num => $addon}
  61. <div class="summary_addons">
  62. <div class="clearfix">
  63. <span class="pull-left float-left">+ {$addon.name}<br />{$addon.productname}{if $addon.domainname} - {$addon.domainname}<br />{/if}</span>
  64. <span class="pull-right float-right">{$addon.recurring}</span>
  65. </div>
  66. </div>
  67. {/foreach}
  68. {foreach $domains as $num => $domain}
  69. <div class="summary_domains">
  70. <div class="clearfix">
  71. <span class="pull-left float-left">
  72. {if $domain.type eq "register"}{$LANG.orderdomainregistration}{else}{$LANG.orderdomaintransfer}{/if} - <br /><strong>{$domain.domain}</strong> - {$domain.regperiod} {$LANG.orderyears}<br />
  73. {if $domain.dnsmanagement}&nbsp;&raquo; {$LANG.domaindnsmanagement}<br />{/if}
  74. {if $domain.emailforwarding}&nbsp;&raquo; {$LANG.domainemailforwarding}<br />{/if}
  75. {if $domain.idprotection}&nbsp;&raquo; {$LANG.domainidprotection}<br />{/if}
  76. </span>
  77. <span class="pull-right float-right">{$domain.price}</span>
  78. </div>
  79. </div>
  80. {/foreach}
  81. {foreach $renewals as $num => $domain}
  82. <div class="summary_domains">
  83. <ul>
  84. <li>
  85. <strong>{$LANG.domainrenewal}</strong><br /><i>{$domain.domain} - {$domain.regperiod} {$LANG.orderyears}</i><br />
  86. {if $domain.dnsmanagement}&nbsp;&raquo; {$LANG.domaindnsmanagement}<br />{/if}
  87. {if $domain.emailforwarding}&nbsp;&raquo; {$LANG.domainemailforwarding}<br />{/if}
  88. {if $domain.idprotection}&nbsp;&raquo; {$LANG.domainidprotection}<br />{/if}
  89. </li>
  90. <li>{$domain.price}</li>
  91. </ul>
  92. </div>
  93. {/foreach}
  94. {if $product.pricing.setup || $product.pricing.recurring || $product.pricing.addons}
  95. <div class="subtotal">
  96. {if $product.pricing.setup}
  97. <div class="clearfix">
  98. <span class="pull-left float-left">{$LANG.cartsetupfees}:</span>
  99. <span class="pull-right float-right">{$product.pricing.setup}</span>
  100. </div>
  101. {/if}
  102. {foreach from=$product.pricing.recurringexcltax key=cycle item=recurring}
  103. <div class="clearfix">
  104. <span class="pull-left float-left text-muted">{$cycle}:</span>
  105. <span class="pull-right float-right text-muted">{$recurring}</span>
  106. </div>
  107. {/foreach}
  108. </div>
  109. {/if}
  110. <div class="subtotal">
  111. <ul>
  112. <li>{$LANG.ordersubtotal}</li>
  113. <li>{$subtotal}</li>
  114. </ul>
  115. </div>
  116. {if $promotioncode}
  117. <div class="promotion">
  118. <ul>
  119. <li>{$promotiondescription}</li>
  120. <li>- {$discount}</li>
  121. </ul>
  122. </div>
  123. {/if}
  124. <div class="subtotal">
  125. {if $taxrate}
  126. <ul>
  127. <li>{$taxname} @ {$taxrate}%</li>
  128. <li>{$taxtotal}</li>
  129. </ul>
  130. {/if}
  131. {if $taxrate2}
  132. <ul>
  133. <li>{$taxname2} @ {$taxrate2}%</li>
  134. <li>{$taxtotal2}</li>
  135. </ul>
  136. {/if}
  137. </div>
  138. </div>
  139. <div class="total">
  140. <div class="d-flex align-items-center">
  141. <button type="button" class="btn btn-cart-contents"><i class="fas fa-chevron-up"></i></button>
  142. </div>
  143. <ul>
  144. <li><span class="text-muted total-text">{$LANG.ordertotalduetoday}</span></li>
  145. <li>{$total}</li>
  146. </ul>
  147. </div>
  148. <div class="cart-loader">
  149. <i class="fad fa-circle-notch fa-spin fa-2x"></i>
  150. </div>
  151. </div>
  152. </div>
  153. {/if}
  154. {else}
  155. {if $checkout} {else}
  156. <script>
  157. // Define state tab index value
  158. var statesTab = 10;
  159. var stateNotRequired = true;
  160. </script>
  161. {include file="orderforms/{$carttpl}/common.tpl"}
  162. <script type="text/javascript" src="{$orderform.assetPath.js}/StatesDropdown.js"></script>
  163. {/if}
  164. {if $cartitems > 0}
  165. {if file_exists("templates/orderforms/{$carttpl}/layouts/head.tpl")}
  166. {include file="templates/orderforms/{$carttpl}/layouts/head.tpl"}
  167. {/if}
  168. {/if}
  169. <div id="order-standard_cart">
  170. {if $cartitems > 0}
  171. <div class="row">
  172. <div class="col-md-12">
  173. {if file_exists("templates/orderforms/{$carttpl}/layouts/head.tpl")}
  174. {else}
  175. <div class="header-lined">
  176. <h1>{if !$checkout}{$LANG.cartreviewcheckout}{else}{$LANG.orderForm.checkout}{/if}</h1>
  177. </div>
  178. {/if}
  179. {include file="orderforms/{$carttpl}/sidebar-categories-collapsed.tpl"}
  180. </div>
  181. <div class="col-md-12">
  182. <div class="row ajaxcart_cont">
  183. <div class="col-md-8 col-lg-9">
  184. {if $checkout} {else}
  185. {if $promoerrormessage}
  186. <div class="alert alert-warning text-center" role="alert">
  187. {$promoerrormessage}
  188. </div>
  189. {elseif $errormessage}
  190. <div class="alert alert-danger" role="alert">
  191. <p>{$LANG.orderForm.correctErrors}:</p>
  192. <ul>
  193. {$errormessage}
  194. </ul>
  195. </div>
  196. {elseif $promotioncode && $rawdiscount eq "0.00"}
  197. <div class="alert alert-info text-center" role="alert">
  198. {$LANG.promoappliedbutnodiscount}
  199. </div>
  200. {elseif $promoaddedsuccess}
  201. <div class="alert alert-success text-center" role="alert">
  202. {$LANG.orderForm.promotionAccepted}
  203. </div>
  204. {/if}
  205. {if $bundlewarnings}
  206. <div class="alert alert-warning" role="alert">
  207. <strong>{$LANG.bundlereqsnotmet}</strong><br />
  208. <ul>
  209. {foreach from=$bundlewarnings item=warning}
  210. <li>{$warning}</li>
  211. {/foreach}
  212. </ul>
  213. </div>
  214. {/if}
  215. <form method="post" action="{$smarty.server.PHP_SELF}?a=view">
  216. <div class="panel panel-default cart-item">
  217. <div class="panel-heading">
  218. <div class="row">
  219. <div class="{if $showqtyoptions}col-sm-5{else}col-sm-7{/if} col-xs-7">
  220. <strong>{$LANG.orderForm.productOptions}</strong>
  221. </div>
  222. {if $showqtyoptions}
  223. <div class="col-sm-2 hidden-xs d-none d-sm-block text-center">
  224. <strong>{$LANG.orderForm.qty}</strong>
  225. </div>
  226. {/if}
  227. <div class="col-sm-4 col-xs-5 col-5 text-right">
  228. <strong>{$LANG.orderForm.priceCycle}</strong>
  229. </div>
  230. </div>
  231. </div>
  232. <div class="no-border no-margin">
  233. {foreach $products as $num => $product}
  234. <div class="panel-body">
  235. <div class="row">
  236. <div class="{if $showqtyoptions}col-sm-5{else}col-sm-7{/if} col-xs-7 col-7">
  237. <span class="item-group">
  238. {$product.productinfo.groupname}
  239. </span>
  240. <span class="item-title">
  241. {$product.productinfo.name}
  242. <a href="{$smarty.server.PHP_SELF}?a=confproduct&i={$num}" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.edit}">
  243. <i class="fas fa-edit"></i>
  244. </a>
  245. <span class="visible-xs-inline d-inline d-sm-none">
  246. <button type="button" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.remove}" onclick="removeItem('p', '{$num}')">
  247. <i class="fas fa-trash-alt"></i>
  248. </button>
  249. </span>
  250. </span>
  251. {if $product.domain}
  252. <span class="item-domain">
  253. <i>{$product.domain}</i>
  254. </span>
  255. {/if}
  256. {if $product.configoptions}
  257. <div class="item-configoption">
  258. <small>
  259. {foreach key=confnum item=configoption from=$product.configoptions}
  260. &nbsp;&raquo; {$configoption.name}: {if $configoption.type eq 1 || $configoption.type eq 2}{$configoption.option}{elseif $configoption.type eq 3}{if $configoption.qty}{$configoption.option}{else}{$LANG.no}{/if}{elseif $configoption.type eq 4}{$configoption.qty} x {$configoption.option}{/if}<br />
  261. {/foreach}
  262. </small>
  263. </div>
  264. {/if}
  265. {if $product.customfields}
  266. <div>
  267. <small>
  268. &nbsp;&raquo; {$product.customfields|@print_r}<br />
  269. </small>
  270. </div>
  271. {/if}
  272. </div>
  273. {if $showqtyoptions}
  274. <div class="col-sm-2 item-qty">
  275. {if $product.allowqty}
  276. <input type="number" name="qty[{$num}]" value="{$product.qty}" class="form-control text-center" min="0" />
  277. <button type="submit" class="btn btn-xs btn-default">
  278. {$LANG.orderForm.update}
  279. </button>
  280. {/if}
  281. </div>
  282. {/if}
  283. <div class="col-sm-4 item-price">
  284. <span>{$product.pricing.totalTodayExcludingTaxSetup}</span>
  285. <span class="cycle">{$product.billingcyclefriendly}</span>
  286. {if $product.pricing.productonlysetup}
  287. {$product.pricing.productonlysetup->toPrefixed()} {$LANG.ordersetupfee}
  288. {/if}
  289. {if $product.proratadate}<br />({$LANG.orderprorata} {$product.proratadate}){/if}
  290. </div>
  291. <div class="col-sm-1 hidden-xs d-none d-sm-block">
  292. <button type="button" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.remove}" onclick="removeItem('p', '{$num}')">
  293. <i class="fas fa-trash-alt"></i>
  294. </button>
  295. </div>
  296. </div>
  297. {foreach $product.addons as $addonnum => $addon}
  298. <div class="item-addons">
  299. <div class="row">
  300. <div class="{if $showAddonQtyOptions}col-sm-5{else}col-sm-7{/if}">
  301. <span class="item-group">
  302. {$LANG.orderaddon}
  303. </span>
  304. <span class="item-title">
  305. {$addon.name}
  306. </span>
  307. {if $addon.setup}
  308. <span class="item-setup">
  309. {$addon.setup} {$LANG.ordersetupfee}
  310. </span>
  311. {/if}
  312. </div>
  313. {if $showAddonQtyOptions}
  314. <div class="col-sm-2 item-qty">
  315. {if $addon.allowqty === 2}
  316. <input type="number" name="paddonqty[{$num}][{$addonnum}]" value="{$addon.qty}" class="form-control text-center" min="0" />
  317. <button type="submit" class="btn btn-xs">
  318. {$LANG.orderForm.update}
  319. </button>
  320. {/if}
  321. </div>
  322. {/if}
  323. <div class="col-sm-4 item-price">
  324. <span>{$addon.totaltoday}</span>
  325. <span class="cycle">{$addon.billingcyclefriendly}</span>
  326. </div>
  327. </div>
  328. </div>
  329. {/foreach}
  330. </div>
  331. {/foreach}
  332. {foreach $addons as $num => $addon}
  333. <div class="panel-body">
  334. <div class="row">
  335. <div class="{if $showAddonQtyOptions}col-sm-5{else}col-sm-7{/if}">
  336. <span class="item-title">
  337. {$addon.name}
  338. <span class="visible-xs-inline d-inline d-sm-none">
  339. <button type="button" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.remove}" onclick="removeItem('a', '{$num}')">
  340. <i class="fas fa-trash-alt"></i>
  341. </button>
  342. </span>
  343. </span>
  344. <span class="item-group">
  345. {$addon.productname}
  346. </span>
  347. {if $addon.domainname}
  348. <span class="item-domain">
  349. {$addon.domainname}
  350. </span>
  351. {/if}
  352. {if $addon.setup}
  353. <span class="item-setup">
  354. {$addon.setup} {$LANG.ordersetupfee}
  355. </span>
  356. {/if}
  357. </div>
  358. {if $showAddonQtyOptions}
  359. <div class="col-sm-2 item-qty">
  360. {if $addon.allowqty === 2}
  361. <input type="number" name="addonqty[{$num}]" value="{$addon.qty}" class="form-control text-center" min="0" />
  362. <button type="submit" class="btn btn-xs">
  363. {$LANG.orderForm.update}
  364. </button>
  365. {/if}
  366. </div>
  367. {/if}
  368. <div class="col-sm-4 item-price">
  369. <span>{$addon.pricingtext}</span>
  370. <span class="cycle">{$addon.billingcyclefriendly}</span>
  371. </div>
  372. <div class="col-sm-1 hidden-xs d-none d-sm-block">
  373. <button type="button" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.remove}" onclick="removeItem('a', '{$num}')">
  374. <i class="fas fa-trash-alt"></i>
  375. </button>
  376. </div>
  377. </div>
  378. </div>
  379. {/foreach}
  380. {foreach $domains as $num => $domain}
  381. <div class="panel-body">
  382. <div class="row">
  383. <div class="col-sm-7">
  384. <span class="item-title">
  385. {if $domain.type eq "register"}{$LANG.orderdomainregistration}{else}{$LANG.orderdomaintransfer}{/if}
  386. <a href="{$smarty.server.PHP_SELF}?a=confdomains" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.edit}">
  387. <i class="fas fa-edit"></i>
  388. </a>
  389. <span class="visible-xs-inline d-inline d-sm-none">
  390. <button type="button" class="btn btn-icon btn-xs" data-placement="top" data-trigger="manual" title="{$LANG.cartremove}" onclick="removeItem('d', '{$num}')">
  391. <i class="fas fa-trash-alt"></i>
  392. </button>
  393. </span>
  394. </span>
  395. {if $domain.domain}
  396. <span class="item-domain">
  397. {$domain.domain}
  398. </span>
  399. {/if}
  400. <div class="item-addons">
  401. {if $domain.dnsmanagement}{$LANG.domaindnsmanagement}<br />{/if}
  402. {if $domain.emailforwarding}{$LANG.domainemailforwarding}<br />{/if}
  403. {if $domain.idprotection}{$LANG.domainidprotection}<br />{/if}
  404. </div>
  405. </div>
  406. <div class="col-sm-4 item-price">
  407. {if count($domain.pricing) == 1 || $domain.type == 'transfer'}
  408. <span name="{$domain.domain}Price">{$domain.price}</span>
  409. <span class="cycle">{$domain.regperiod} {$domain.yearsLanguage}</span>
  410. <span class="renewal cycle">
  411. {if isset($domain.renewprice)}{lang key='domainrenewalprice'} <span class="renewal-price cycle">{$domain.renewprice->toPrefixed()}{$domain.shortRenewalYearsLanguage}{/if}</span>
  412. </span>
  413. {else}
  414. <span name="{$domain.domain}Price">{$domain.price}</span>
  415. <div class="dropdown">
  416. <button class="btn btn-default btn-xs dropdown-toggle" type="button" id="{$domain.domain}Pricing" name="{$domain.domain}Pricing" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true">
  417. {$domain.regperiod} {$domain.yearsLanguage}
  418. <span class="caret"></span>
  419. </button>
  420. <ul class="dropdown-menu dropdown-menu dropdown-caret dropdown-checkboxes dropdown-menu-right dropdown-close" aria-labelledby="{$domain.domain}Pricing">
  421. {foreach $domain.pricing as $years => $price}
  422. <li>
  423. <a class="dropdown-item" href="#" onclick="selectDomainPeriodInCart('{$domain.domain}', '{$price.register}', {$years}, '{if $years == 1}{lang key='orderForm.year'}{else}{lang key='orderForm.years'}{/if}');return false;">
  424. {$years} {if $years == 1}{lang key='orderForm.year'}{else}{lang key='orderForm.years'}{/if} @ {$price.register}
  425. </a>
  426. </li>
  427. {/foreach}
  428. </ul>
  429. </div>
  430. <span class="renewal cycle">
  431. {lang key='domainrenewalprice'} <span class="renewal-price cycle">{if isset($domain.renewprice)}{$domain.renewprice->toPrefixed()}{$domain.shortRenewalYearsLanguage}{/if}</span>
  432. </span>
  433. {/if}
  434. </div>
  435. <div class="col-sm-1 hidden-xs d-none d-sm-block">
  436. <button type="button" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.remove}" onclick="removeItem('d', '{$num}')">
  437. <i class="fas fa-trash-alt"></i>
  438. </button>
  439. </div>
  440. </div>
  441. </div>
  442. {/foreach}
  443. {foreach $renewals as $num => $domain}
  444. <div class="panel-body">
  445. <div class="row">
  446. <div class="col-sm-7">
  447. <span class="item-title">
  448. {$LANG.domainrenewal}
  449. <span class="visible-xs-inline d-block d-sm-none">
  450. <button type="button" class="btn btn-icon btn-xs" data-placement="top" data-trigger="manual" title="{$LANG.cartremove}" onclick="removeItem('r', '{$num}')">
  451. <i class="fas fa-trash-alt"></i>
  452. </button>
  453. </span>
  454. </span>
  455. <span class="item-domain">
  456. {$domain.domain}
  457. </span>
  458. <div class="item-addons">
  459. {if $domain.dnsmanagement}{$LANG.domaindnsmanagement}<br />{/if}
  460. {if $domain.emailforwarding}{$LANG.domainemailforwarding}<br />{/if}
  461. {if $domain.idprotection}{$LANG.domainidprotection}<br />{/if}
  462. </div>
  463. </div>
  464. <div class="col-sm-4 item-price">
  465. <span>{$domain.price}</span>
  466. <span class="cycle">{$domain.regperiod} {$LANG.orderyears}</span>
  467. </div>
  468. <div class="col-sm-1 hidden-xs d-block d-sm-none">
  469. <button type="button" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.remove}" onclick="removeItem('r', '{$num}')">
  470. <i class="fas fa-trash-alt"></i>
  471. </button>
  472. </div>
  473. </div>
  474. </div>
  475. {/foreach}
  476. {foreach $upgrades as $num => $upgrade}
  477. <div class="panel-body">
  478. <div class="row">
  479. <div class="{if $showUpgradeQtyOptions}col-sm-5{else}col-sm-7{/if}">
  480. <span class="item-title">
  481. {$LANG.upgrade}
  482. </span>
  483. <span class="item-group">
  484. {if $upgrade->type == 'service'}
  485. {$upgrade->originalProduct->productGroup->name}<br>{$upgrade->originalProduct->name} => {$upgrade->newProduct->name}
  486. {elseif $upgrade->type == 'addon'}
  487. {$upgrade->originalAddon->name} => {$upgrade->newAddon->name}
  488. {/if}
  489. </span>
  490. <span class="item-domain">
  491. {if $upgrade->type == 'service'}
  492. {$upgrade->service->domain}
  493. {/if}
  494. </span>
  495. </div>
  496. {if $showUpgradeQtyOptions}
  497. <div class="col-sm-2 item-qty">
  498. {if $upgrade->allowMultipleQuantities}
  499. <input type="number" name="upgradeqty[{$num}]" value="{$upgrade->qty}" class="form-control text-center" min="{$upgrade->minimumQuantity}" />
  500. <button type="submit" class="btn btn-xs">
  501. {$LANG.orderForm.update}
  502. </button>
  503. {/if}
  504. </div>
  505. {/if}
  506. <div class="col-sm-4 item-price">
  507. <span>{$upgrade->newRecurringAmount}</span>
  508. <span class="cycle">{$upgrade->localisedNewCycle}</span>
  509. </div>
  510. <div class="col-sm-1">
  511. <button type="button" class="btn btn-icon btn-xs" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{$LANG.orderForm.remove}" onclick="removeItem('u', '{$num}')">
  512. <i class="fas fa-trash-alt"></i>
  513. </button>
  514. </div>
  515. </div>
  516. {if $upgrade->totalDaysInCycle > 0}
  517. <div class="row row-upgrade-credit">
  518. <div class="col-sm-7">
  519. <span class="item-group">
  520. {$LANG.upgradeCredit}
  521. </span>
  522. <div class="upgrade-calc-msg">
  523. {lang key="upgradeCreditDescription" daysRemaining=$upgrade->daysRemaining totalDays=$upgrade->totalDaysInCycle}
  524. </div>
  525. </div>
  526. <div class="col-sm-4 item-price">
  527. <span>-{$upgrade->creditAmount}</span>
  528. </div>
  529. </div>
  530. {/if}
  531. </div>
  532. {/foreach}
  533. {if $cartitems == 0}
  534. <div class="view-cart-empty">
  535. {$LANG.cartempty}
  536. </div>
  537. {/if}
  538. </div>
  539. {if $cartitems > 0}
  540. <div class="panel-footer light">
  541. <div class=" d-flex align-items-center space-between">
  542. <a href="cart.php" class="btn btn-default btn-xs" id="continueShopping">
  543. <i class="fas fa-reply"></i>
  544. <span>{$LANG.orderForm.continueShopping}</span>
  545. </a>
  546. <button type="button" class="btn btn-default btn-xs" id="btnEmptyCart">
  547. <i class="fas fa-trash-alt"></i>
  548. <span>{$LANG.emptycart}</span>
  549. </button>
  550. </div>
  551. </div>
  552. {/if}
  553. </div>
  554. </form>
  555. {foreach $hookOutput as $output}
  556. <div>
  557. {$output}
  558. </div>
  559. {/foreach}
  560. {foreach $gatewaysoutput as $gatewayoutput}
  561. <div class="view-cart-gateway-checkout">
  562. {$gatewayoutput}
  563. </div>
  564. {/foreach}
  565. {* Promocode & Steuertab -> entfernt von Thurdata auf Wunsch von Andy (Anfang)
  566. <div class="view-cart-tabs">
  567. <ul class="nav nav-tabs" role="tablist">
  568. <li role="presentation" class="active"><a href="#applyPromo" class="nav-link active" aria-controls="applyPromo" role="tab" data-toggle="tab">{$LANG.orderForm.applyPromoCode}</a></li>
  569. {if $taxenabled && !$loggedin}
  570. <li role="presentation"><a href="#calcTaxes" class="nav-link" aria-controls="calcTaxes" role="tab" data-toggle="tab">{$LANG.orderForm.estimateTaxes}</a></li>
  571. {/if}
  572. </ul>
  573. <div class="tab-content">
  574. <div role="tabpanel" class="tab-pane active promo" id="applyPromo">
  575. {if $promotioncode}
  576. <div class="view-cart-promotion-code">
  577. {$promotioncode} - {$promotiondescription}
  578. </div>
  579. <div class="text-center">
  580. <a href="{$smarty.server.PHP_SELF}?a=removepromo" class="btn btn-default btn-sm">
  581. {$LANG.orderForm.removePromotionCode}
  582. </a>
  583. </div>
  584. {else}
  585. <form method="post" action="cart.php?a=view">
  586. <div class="form-group prepend-icon">
  587. <div class="row">
  588. <div class="col-md-7 col-lg-8 col-xl-9">
  589. <label for="cardno" class="field-icon">
  590. <i class="fas fa-ticket-alt"></i>
  591. </label>
  592. <input type="text" name="promocode" id="inputPromotionCode" class="form-coontrol field" placeholder="{lang key="orderPromoCodePlaceholder"}" required="required" style="width: 100%;">
  593. </div>
  594. <div class="col-md-5 col-lg-4 col-xl-3">
  595. <span class="input-group-btn">
  596. <button type="submit" name="validatepromo" class="btn btn-primary btn-block " value="{$LANG.orderpromovalidatebutton}">
  597. {$LANG.orderpromovalidatebutton}
  598. </button>
  599. </span>
  600. </div>
  601. </div>
  602. </div>
  603. </form>
  604. {/if}
  605. </div>
  606. <div role="tabpanel" class="tab-pane" id="calcTaxes">
  607. <form method="post" action="cart.php?a=setstateandcountry">
  608. <div class="form-group">
  609. <label for="inputState" class="control-label">{$LANG.orderForm.state}</label>
  610. <input type="text" name="state" id="inputState" value="{$clientsdetails.state}" class="form-control"{if $loggedin} disabled="disabled"{/if} />
  611. </div>
  612. <div class="form-group">
  613. <label for="inputCountry" class="control-label">{$LANG.orderForm.country}</label>
  614. <select name="country" id="inputCountry" class="form-control">
  615. {foreach $countries as $countrycode => $countrylabel}
  616. <option value="{$countrycode}"{if (!$country && $countrycode == $defaultcountry) || $countrycode eq $country} selected{/if}>
  617. {$countrylabel}
  618. </option>
  619. {/foreach}
  620. </select>
  621. </div>
  622. <div class="form-group text-center">
  623. <button type="submit" class="btn btn-primary">
  624. {$LANG.orderForm.updateTotals}
  625. </button>
  626. </div>
  627. </form>
  628. </div>
  629. </div>
  630. </div>
  631. Promocode & Steuertab -> entfernt von Thurdata auf Wunsch von Andy (Ende)*}
  632. {/if}
  633. {if !$checkout}{else}
  634. {include file="orderforms/$carttpl/checkout.tpl"}
  635. {if $servedOverSsl}
  636. <div class="alert alert-warning" style="margin-top: 30px; font-size: 90%;">
  637. {$LANG.ordersecure} (<strong>{$ipaddress}</strong>) {$LANG.ordersecure2}
  638. </div>
  639. {/if}
  640. {/if}
  641. </div>
  642. <div class="col-md-4 col-lg-3">
  643. <div id="sidebar">
  644. <div class="sidebar__inner blocks cartsummary">
  645. <div class="order-summary">
  646. <div class="loader w-hidden" id="orderSummaryLoader">
  647. <i class="fas fa-fw fa-sync fa-spin"></i>
  648. </div>
  649. <h2>{$LANG.ordersummary}</h2>
  650. <div class="summary-container">
  651. <div class="subtotal clearfix">
  652. <span class="pull-left float-left">{$LANG.ordersubtotal}</span>
  653. <span id="subtotal" class="pull-right float-right">{$subtotal}</span>
  654. </div>
  655. {if $promotioncode || $taxrate || $taxrate2}
  656. <div class="bordered-totals">
  657. {if $promotioncode}
  658. <div class="clearfix">
  659. <span class="pull-left float-left">{$promotiondescription}</span>
  660. <span id="discount" class="pull-right float-right">{$discount}</span>
  661. </div>
  662. {/if}
  663. {if $taxrate}
  664. <div class="clearfix">
  665. <span class="pull-left float-left">{$taxname} @ {$taxrate}%</span>
  666. <span id="taxTotal1" class="pull-right float-right">{$taxtotal}</span>
  667. </div>
  668. {/if}
  669. {if $taxrate2}
  670. <div class="clearfix">
  671. <span class="pull-left float-left">{$taxname2} @ {$taxrate2}%</span>
  672. <span id="taxTotal2" class="pull-right float-right">{$taxtotal2}</span>
  673. </div>
  674. {/if}
  675. </div>
  676. {/if}
  677. <div class="recurring-totals clearfix">
  678. <span class="pull-left float-left">{$LANG.orderForm.totals}</span>
  679. <span id="recurring" class="pull-right float-right recurring-charges">
  680. <span id="recurringMonthly" {if !$totalrecurringmonthly}style="display:none;"{/if}>
  681. <span class="cost">{$totalrecurringmonthly}</span> {$LANG.orderpaymenttermmonthly}<br />
  682. </span>
  683. <span id="recurringQuarterly" {if !$totalrecurringquarterly}style="display:none;"{/if}>
  684. <span class="cost">{$totalrecurringquarterly}</span> {$LANG.orderpaymenttermquarterly}<br />
  685. </span>
  686. <span id="recurringSemiAnnually" {if !$totalrecurringsemiannually}style="display:none;"{/if}>
  687. <span class="cost">{$totalrecurringsemiannually}</span> {$LANG.orderpaymenttermsemiannually}<br />
  688. </span>
  689. <span id="recurringAnnually" {if !$totalrecurringannually}style="display:none;"{/if}>
  690. <span class="cost">{$totalrecurringannually}</span> {$LANG.orderpaymenttermannually}<br />
  691. </span>
  692. <span id="recurringBiennially" {if !$totalrecurringbiennially}style="display:none;"{/if}>
  693. <span class="cost">{$totalrecurringbiennially}</span> {$LANG.orderpaymenttermbiennially}<br />
  694. </span>
  695. <span id="recurringTriennially" {if !$totalrecurringtriennially}style="display:none;"{/if}>
  696. <span class="cost">{$totalrecurringtriennially}</span> {$LANG.orderpaymenttermtriennially}<br />
  697. </span>
  698. </span>
  699. </div>
  700. <div class="total-due-today total-due-today-padded">
  701. <span id="totalDueToday" class="amt">{$total}</span>
  702. <span>{$LANG.ordertotalduetoday}</span>
  703. </div>
  704. <div class="express-checkout-buttons">
  705. {foreach $expressCheckoutButtons as $checkoutButton}
  706. {$checkoutButton}
  707. <div class="separator">
  708. - {$LANG.or|strtoupper} -
  709. </div>
  710. {/foreach}
  711. </div>
  712. <div class="text-right">
  713. {if $checkout}{else}<a href="cart.php?a=checkout&e=false" class="btn btn-primary btn-lg btn-checkout{if $cartitems == 0} disabled{/if}" id="checkout">
  714. {$LANG.orderForm.checkout}
  715. <i class="fas fa-arrow-right"></i>
  716. </a>{/if}
  717. </div>
  718. </div>
  719. </div>
  720. </div>
  721. </div>
  722. </div>
  723. </div>
  724. </div>
  725. </div>
  726. {else}
  727. <div class="mw-928 mx-auto">
  728. <div class="alert-lg no-data no-border">
  729. <div class="icon">
  730. <i class="fas fa-trash-alt"></i>
  731. </div>
  732. <div class="text">
  733. <h4>{$LANG.cartempty}</h4>
  734. </div>
  735. <a href="{if $themesettings.orderform.orderopc != ""}order{else}cart{/if}.php" class="btn btn-default" id="continueShopping">
  736. {$LANG.navservicesorder}
  737. </a>
  738. </div>
  739. </div>
  740. {/if}
  741. </div>
  742. {if file_exists("templates/orderforms/{$carttpl}/layouts/foot.tpl")}
  743. {include file="templates/orderforms/{$carttpl}/layouts/foot.tpl"}
  744. {/if}
  745. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/ResizeSensor.js"></script>
  746. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/jquery.sticky-sidebar.min.js"></script>
  747. <script>
  748. jQuery('#sidebar').stickySidebar({
  749. topSpacing: 60,
  750. bottomSpacing: 60,
  751. minWidth: 992,
  752. containerSelector: '.ajaxcart_cont',
  753. innerWrapperSelector: '.sidebar__inner'
  754. });
  755. </script>
  756. <form method="post" action="cart.php">
  757. <input type="hidden" name="a" value="remove" />
  758. <input type="hidden" name="r" value="" id="inputRemoveItemType" />
  759. <input type="hidden" name="i" value="" id="inputRemoveItemRef" />
  760. <div class="modal fade modal-remove-item" id="modalRemoveItem" tabindex="-1" role="dialog">
  761. <div class="modal-dialog" role="document">
  762. <div class="modal-content">
  763. <div class="modal-header d-block">
  764. <h4 class="modal-title">
  765. <button type="button" class="close" data-dismiss="modal" aria-label="{$LANG.orderForm.close}">
  766. <span aria-hidden="true">&times;</span>
  767. </button>
  768. <span>{lang key='orderForm.removeItem'}</span>
  769. </h4>
  770. </div>
  771. <div class="modal-body">
  772. {$LANG.cartremoveitemconfirm}
  773. </div>
  774. <div class="modal-footer">
  775. <button type="button" class="btn btn-default" data-dismiss="modal">{$LANG.no}</button>
  776. <button type="submit" class="btn btn-primary">{$LANG.yes}</button>
  777. </div>
  778. </div>
  779. </div>
  780. </div>
  781. </form>
  782. <form method="post" action="cart.php">
  783. <input type="hidden" name="a" value="empty" />
  784. <div class="modal fade modal-remove-item" id="modalEmptyCart" tabindex="-1" role="dialog">
  785. <div class="modal-dialog" role="document">
  786. <div class="modal-content">
  787. <div class="modal-header d-block">
  788. <h4 class="modal-title">
  789. <button type="button" class="close" data-dismiss="modal" aria-label="{$LANG.orderForm.close}">
  790. <span aria-hidden="true">&times;</span>
  791. </button>
  792. <span>{$LANG.emptycart}</span>
  793. </h4>
  794. </div>
  795. <div class="modal-body">
  796. {$LANG.cartemptyconfirm}
  797. </div>
  798. <div class="modal-footer">
  799. <button type="button" class="btn btn-default" data-dismiss="modal">{$LANG.no}</button>
  800. <button type="submit" class="btn btn-primary">{$LANG.yes}</button>
  801. </div>
  802. </div>
  803. </div>
  804. </div>
  805. </form>
  806. {/if}