order.tpl 80 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500
  1. <script src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/select2.min.js"></script>
  2. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/main.min.js?v={$versionHash}"></script>
  3. <script>
  4. window.cartempty = "{lang key='cartempty'}";
  5. window.domainrequired = "{lang key='domaincheckerchoosedomain'}";
  6. window.productrequired = "{lang key='upgradedowngradechooseproduct'}";
  7. window.domainLengthRequirements = "{lang key='ordererrordomaininvalid'}";
  8. window.isrequired = "&nbsp;{lang key='clientareaerrorisrequired'}";
  9. </script>
  10. {if $ordertype == 'global'}
  11. <script>
  12. jQuery(document).ready(function () {
  13. recalcsummary();
  14. if (jQuery('#hiddenpromo').val().trim() != '') {
  15. jQuery('#promocode').val(jQuery('#hiddenpromo').val());
  16. jQuery('.applypromo').trigger('click');
  17. jQuery('.promo_form').show();
  18. jQuery('.promo_text').remove();
  19. setTimeout(function(){ recalcheckout(); }, 1000);
  20. }else{
  21. recalcheckout();
  22. }
  23. {if $pid}jQuery('#pid_{$pid}').trigger('click');{/if}
  24. {if $pid}jQuery('#apid_{$pid}').removeClass('hidden');{/if}
  25. {if $domainorder == 'transfer'}jQuery(".domain-trans").trigger("click");{/if}
  26. });
  27. var ccdordertype = 'all';
  28. {if $domainorder == 'register'}
  29. ccdordertype = 'register';
  30. {/if}
  31. {if $domainorder == 'transfer'}
  32. ccdordertype = 'transfer';
  33. {/if}
  34. </script>
  35. {if $themesettings.orderform.opcnoheader}
  36. <div class="hero spc">
  37. <div class="container">
  38. <div class="logo-section">
  39. <a class="logo" href="{if $themesettings.headersetting.CustomLogoLink}{$themesettings.headersetting.CustomLogoLink}{else}{$WEB_ROOT}/{/if}">
  40. {if $themesettings.general.enablelogo}
  41. <img src="{$themesettings.general.logourl}" alt="{$companyname}" class="logo-light" />
  42. {if $themesettings.general.darklogo}
  43. <img src="{$themesettings.general.darklogo}" alt="{$companyname}" class="logo-dark" />
  44. {else}
  45. <span class="logo-dark">{$companyname}</span>
  46. {/if}
  47. {else}
  48. <span class="logo-light">{$companyname}</span>
  49. {/if}
  50. </a>
  51. </div>
  52. </div>
  53. </div>
  54. {else}
  55. {if $themesettings.general.bannerstyle}
  56. <div{if $themesettings.general.bsbgstyle eq "1"} class="small-header header-banner-styled bg-primary position-relative mb-5"{else} class="hero-bg-wrap small-header header-banner-styled inverse bg-opacity mb-5"{if $themesettings.general.bheaderbg} style="background-image:url('{$themesettings.general.bheaderbg}');"{/if}{/if}>
  57. {if $themesettings.general.bsbgstyle eq "1"}
  58. <div class="cros-bg-shapes-right"></div>
  59. <div class="cros-bg-shapes-left"></div>
  60. {/if}
  61. <div class="container">
  62. <div class="page-title position-relative">
  63. <div class="header-lined">
  64. {if $domainorder == 'register'}
  65. <div>
  66. <h1 class="fw-900">{lang key="registerdomain"}</h1>
  67. <span class="d-none d-sm-block">{lang key="registerdomaindesc"}</span>
  68. </div>
  69. {elseif $domainorder == 'transfer'}
  70. <div>
  71. <h1 class="fw-900">{lang key="transferdomain"}</h1>
  72. <span class="d-none d-sm-block">{lang key="orderForm.transferExtend"}</span>
  73. </div>
  74. {else}
  75. <h1 class="fw-900">{lang key="carttitle"}</h1>
  76. {/if}
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. {else}
  82. <div class="hero d-flex align-items-center no-padding-bottom">
  83. <div class="container">
  84. <div class="page-title">
  85. <div class="header-lined">
  86. {if $domainorder == 'register'}
  87. <div>
  88. <h1 class="fw-900">{lang key="registerdomain"}</h1>
  89. </div>
  90. <div>
  91. <p class="d-none d-sm-block">{lang key="registerdomaindesc"}</p>
  92. </div>
  93. {elseif $domainorder == 'transfer'}
  94. <div>
  95. <h1 class="fw-900">{lang key="transferdomain"}</h1>
  96. </div>
  97. <div>
  98. <p class="d-none d-sm-block">{lang key="orderForm.transferExtend"}</p>
  99. </div>
  100. {else}
  101. <h1 class="fw-900">{lang key="carttitle"}</h1>
  102. {/if}
  103. </div>
  104. </div>
  105. </div>
  106. </div>
  107. {/if}
  108. {/if}
  109. <div id="order-standard_cart">
  110. <input type="hidden" value="{$promocode}" id="hiddenpromo"/>
  111. <div class="cat-loader" style="display: none;">
  112. <div class="loader-icon">
  113. <i class="fad fa-circle-notch fa-spin fa-3x"></i>
  114. </div>
  115. </div>
  116. <div class="container">
  117. <div class="onepage_cart" id="onepage_cart">
  118. <div class="row ajaxcart_cont">
  119. <div class="col-lg-8 col-xl-9">
  120. <span class="d-block d-lg-none float-right">
  121. <a href="{$WEB_ROOT}/order.php{if $domainorder == 'register'}?domainaction=register{elseif $domainorder == 'transfer'}?domainaction=transfer{/if}" onclick="emptyCart()" class="btn btn-link btn-emptycart" data-toggle="tooltip" data-placement="top" title="{$LANG.emptycart}"><i class="fas fa-trash"></i> {$LANG.emptycart}</a>
  122. </span>
  123. <div class="clearfix"></div>
  124. <form id="coniguration_form" onsubmit="return false;">
  125. <div class="p_error" style="display: none;"></div>
  126. {if $domainorder == 'all'}
  127. <div class="TM-card blocks products{if $themesettings.orderform.opcpab}{if $smarty.get.pid || $smarty.get.billingcycle} hidden{/if}{/if}">
  128. <div class="blocks_heading">
  129. <div>
  130. <label>
  131. <input class="no-icheck ortype no-radio" {if $ordertype != 'domain'}checked="checked"{/if} name="ortype" type="radio" value="productdomain">
  132. <span class="scheck no-icon"><h6 class="h4 fw-500">&nbsp;{$LANG.orderchooseapackage}</h6></span>
  133. </label>
  134. </div>
  135. {if $themesettings.orderform.opcnoheader || $themesettings.headersetting.accountactionbtn && !$loggedin}
  136. {if $languagechangeenabled && count($locales) > 1 || $currencies}
  137. <div class="lang-btn text-lg-right">
  138. <button type="button" class="text-base btn px-1 py-0" data-toggle="modal" data-target="#modalChooseLanguage">
  139. {if $languagechangeenabled && count($locales) > 1}
  140. <div class="d-inline-block align-middle">
  141. <div class="iti-flag {if $activeLocale.countryCode === '001'}us{else}{$activeLocale.countryCode|lower}{/if}"></div>
  142. </div>
  143. {$activeLocale.localisedName}{/if}{if $languagechangeenabled && count($locales) > 1 && $currencies && !$loggedin}&nbsp;|&nbsp;{/if}{if !$loggedin && $currencies}{$activeCurrency.prefix} {$activeCurrency.code}{/if}
  144. </button>
  145. </div>
  146. {/if}
  147. {/if}
  148. </div>
  149. <div class="blocks_body productsbody" {if $ordertype == 'domain'}style="display:none;"{/if}>
  150. <div class="padding-all no-padding-bottom">
  151. <div class="groups_sec">
  152. <select name="gid" onchange="getProducts()" id="gid" class="form-control select2-single">
  153. <optgroup label="{$LANG.ordercategories}">
  154. {foreach from=$productgroups key=num item=group}
  155. {if !$group.hidden}
  156. <option value="{$group.id}" {if $gid eq $group.id}selected="selected"{/if}>{$group.name}</option>
  157. {/if}
  158. {/foreach}
  159. </optgroup>
  160. </select>
  161. </div>
  162. </div>
  163. <div class="space-16"></div>
  164. {if $smarty.get.pid}
  165. <div class="product_list border-top" id="product_body">
  166. <div class="plan-list-slider row row-eq-height flex-nowrap mx-0">
  167. {foreach from=$products key=num item=product}
  168. <div class="{if $num eq 0}empty_p {/if}col-12 px-1 tns-item hidden" id="apid_{$product.id}">
  169. <label for="pid_{$product.id}">
  170. <input type="radio" data-availableorder='{if $product.extra.stockcontrol == '1' && $product.extra.qty == '0'}0{else}1{/if}' {if $product.extra.freedomain !== ''}data-freedomain='{$product.extra.freedomain}'{/if} {if isset($product['ismarketconnect']) && $product['ismarketconnect'] !== ''}data-ismarketconnect='1'{else}data-ismarketconnect='0'{/if} data-havedomain='{if $product.showdomainoptions}1{else}0{/if}' {if $product.extra.subdomain != ''}data-havesubdomain='1' data-subdomains='{$product.extra.subdomain}'{else}data-havesubdomain='0' {/if} class="no-icheck no-radio domaincheckhaveit" name="pid" {if $pid eq $product.id}checked="checked"{/if} value="{$product.id}" id="pid_{$product.id}" onclick="addToCart(); triggerProduct();"/>
  171. <span class="scheck products-radio">
  172. <h6 class="h5">{$product.name}</h6>
  173. {if $themesettings.orderform.opcproductdesc}
  174. {if $product.extra.description}
  175. {if $product.extra.description.features|@count > '0'}
  176. {if $product.extra.description.featuresdesc}
  177. <div class="smalldesc">
  178. {$product.extra.description.featuresdesc}
  179. </div>
  180. {/if}
  181. <ul class="features">
  182. {foreach from=$product.extra.description.features key=desckey item=descvalue}
  183. <li><b>{$descvalue}</b> {$desckey}</li>
  184. {/foreach}
  185. </ul>
  186. {else}
  187. {if $product.extra.description.original}
  188. <div class="description">
  189. {$product.extra.description.original}
  190. </div>
  191. {/if}
  192. {/if}
  193. {/if}
  194. {/if}
  195. </span>
  196. </label>
  197. {if $product.extra.freedomainpaymentterms !== ''}
  198. <input type="hidden" name="freedomainpaymentterms" id="freedomainpaymentterms{$product.id}" value="{$product.extra.freedomainpaymentterms}">
  199. {assign var=freedomainpaymentterms value=$product.extra.freedomainpaymentterms}
  200. {/if}
  201. {if $product.extra.freedomaintlds !== ''}
  202. <input type="hidden" name="freedomaintlds" id="freedomaintlds{$product.id}" value="{$product.extra.freedomaintlds}">
  203. {assign var=freedomaintlds value=$product.extra.freedomaintlds}
  204. {/if}
  205. {if $product.extra.freedomaintlds !==''}
  206. {assign var=freedomainvar value=$product.extra.freedomain}
  207. {/if}
  208. </div>
  209. {/foreach}
  210. </div>
  211. </div>
  212. {else}
  213. <div class="product_list border-top" id="product_body">
  214. <div class="swiper-nav">
  215. <div class="swiper-button-prev"></div>
  216. <div class="swiper-pagination"></div>
  217. <div class="swiper-button-next"></div>
  218. </div>
  219. <div class="plan-list-slider swiper">
  220. <div class="swiper-wrapper row row-eq-height flex-nowrap mx-0">
  221. {foreach from=$products key=num item=product}
  222. {if $product.extra.hidden neq "0" || $product.extra.retired neq "0"}
  223. {else}
  224. <div class="col-12 col-md-6 col-lg-6 col-xl-4 px-1 tns-item products-slide{if $num eq 0} empty_p{/if}">
  225. <label for="pid_{$product.id}">
  226. <input type="radio" {if isset($product['ismarketconnect']) && $product['ismarketconnect'] !== ''}data-ismarketconnect='1'{else}data-ismarketconnect='0'{/if} {if $product.extra.freedomain !== ''}data-freedomain='{$product.extra.freedomain}'{/if} data-havedomain='{if $product.showdomainoptions}1{else}0{/if}' {if $product.extra.subdomain != ''}data-havesubdomain='1' data-subdomains='{$product.extra.subdomain}'{else}data-havesubdomain='0' {/if} class="no-icheck no-radio domaincheckhaveit" name="pid" {if $pid eq $product.id}checked="checked"{/if} value="{$product.id}" id="pid_{$product.id}" data-availableorder='{if $product.extra.stockcontrol == '1' && $product.extra.qty == '0'}0{else}1{/if}' onclick="addToCart(); triggerProduct();"/>
  227. <span class="scheck products-radio justify-content-start h-100">
  228. <h6 class="h5">{$product.name}</h6>
  229. {if $themesettings.orderform.opcproductdesc}
  230. {if $product.extra.description}
  231. {if count($product.extra.description.features) > 0}
  232. {if $product.extra.description.featuresdesc}
  233. <div class="smalldesc">
  234. {$product.extra.description.featuresdesc}
  235. </div>
  236. {/if}
  237. <ul class="features">
  238. {foreach from=$product.extra.description.features key=desckey item=descvalue}
  239. <li><b>{$descvalue}</b> {$desckey}</li>
  240. {/foreach}
  241. </ul>
  242. {else}
  243. {if $product.extra.description.original}
  244. <div class="description">
  245. {$product.extra.description.original}
  246. </div>
  247. {/if}
  248. {/if}
  249. {/if}
  250. {/if}
  251. </span>
  252. </label>
  253. {if $product.extra.freedomainpaymentterms !== ''}
  254. <input type="hidden" name="freedomainpaymentterms" id="freedomainpaymentterms{$product.id}" value="{$product.extra.freedomainpaymentterms}">
  255. {assign var=freedomainpaymentterms value=$product.extra.freedomainpaymentterms }
  256. {/if}
  257. {if $product.extra.freedomaintlds !== ''}
  258. <input type="hidden" name="freedomaintlds" id="freedomaintlds{$product.id}" value="{$product.extra.freedomaintlds}">
  259. {assign var=freedomaintlds value=$product.extra.freedomaintlds }
  260. {/if}
  261. {if $product.extra.freedomaintlds !==''}
  262. {assign var=freedomainvar value=$product.extra.freedomain }
  263. {/if}
  264. </div>
  265. {/if}
  266. {/foreach}
  267. </div>
  268. </div>
  269. </div>
  270. {/if}
  271. </div>
  272. </div>
  273. <div class="alert alert-danger" style="margin: 5px;display: none" id="outofstock">
  274. {lang key='outofstockdescription'}
  275. </div>
  276. <div class="blocks products_billingcycle{if $themesettings.orderform.opcpab}{if $smarty.get.billingcycle} hidden{/if}{/if}" id="products-billingcycle" style="display:none;">
  277. <div class="blocks_body productsbody products_billing_block">
  278. <div class="no-padding-bottom" style="font-size: 0;">
  279. {foreach from=$products key=num item=product}
  280. {if $product.paytype eq 'onetime' || $product.paytype eq 'free' || $product.pricing|@count <= '1'}
  281. <input type="hidden" name="billingcycle[{$product.id}]" value="monthly">
  282. {else}
  283. <div class="row div_billingcyle" style="display:none;" id="billingcycle_{$product.id}">
  284. {foreach from=$product.pricing item=pricing}
  285. {if isset($smarty.get.billingcycle)}
  286. {$BACKCART['products'][0]['billingcycle'] = ""}
  287. {$pricing.checked = ""}
  288. {/if}
  289. {if $pricing.monthly}
  290. <div class="col-sm-4">
  291. <div class="form-group">
  292. <label>
  293. <input type="radio" class="cros-checkbox no-icheck" id="monthly{$product.id}" name="billingcycle[{$product.id}]" value="monthly" onclick="addToCart();triggerBillingCycle();" {if $BACKCART['products'][0]['pid'] == $product.id && $BACKCART['products'][0]['billingcycle'] == 'monthly'} checked='checked'{elseif $smarty.get.billingcycle=='monthly'} checked='checked'{elseif $pricing.checked} checked='checked'{/if}>
  294. <span class="pcb xs">
  295. <span class="c-name">{$LANG.orderpaymenttermmonthly}</span>
  296. <span class="c-price{if $pricing.rawmonthly eq "0"} d-none{/if}">{$pricing.monthly}</span>
  297. </span>
  298. </label>
  299. </div>
  300. </div>
  301. {elseif $pricing.quarterly}
  302. <div class="col-sm-4">
  303. <div class="form-group">
  304. <label>
  305. <input type="radio" class="cros-checkbox no-icheck" id="quarterly{$product.id}" name="billingcycle[{$product.id}]" value="quarterly" onclick="addToCart();triggerBillingCycle();" {if $BACKCART['products'][0]['pid'] == $product.id && $BACKCART['products'][0]['billingcycle'] == 'quarterly'} checked='checked'{elseif $smarty.get.billingcycle=='quarterly'} checked='checked'{elseif $pricing.checked} checked='checked'{/if}>
  306. <span class="pcb xs">
  307. <span class="c-name">{$LANG.orderpaymenttermquarterly}</span>
  308. <span class="c-price{if $pricing.rawquarterly eq "0"} d-none{/if}">{if $CONFIG.ProductMonthlyPricingBreakdown eq "on"}{$pricing.textprice}{else}{$pricing.quarterly}{/if}</span>
  309. {if $pricing.savetext}<span class="c-save">{$pricing.savetext}</span>{/if}
  310. </span>
  311. </label>
  312. </div>
  313. </div>
  314. {elseif $pricing.semiannually}
  315. <div class="col-sm-4">
  316. <div class="form-group">
  317. <label>
  318. <input type="radio" class="cros-checkbox no-icheck" id="semiannually{$product.id}" name="billingcycle[{$product.id}]" value="semiannually" onclick="addToCart();triggerBillingCycle();" {if $BACKCART['products'][0]['pid'] == $product.id && $BACKCART['products'][0]['billingcycle'] == 'semiannually'} checked='checked'{elseif $smarty.get.billingcycle=='semiannually'} checked='checked'{elseif $pricing.checked} checked='checked'{/if}>
  319. <span class="pcb xs">
  320. <span class="c-name">{$LANG.orderpaymenttermsemiannually}</span>
  321. <span class="c-price{if $pricing.rawsemiannually eq "0"} d-none{/if}">{if $CONFIG.ProductMonthlyPricingBreakdown eq "on"}{$pricing.textprice}{else}{$pricing.semiannually}{/if}</span>
  322. {if $pricing.savetext}<span class="c-save">{$pricing.savetext}</span>{/if}
  323. </span>
  324. </label>
  325. </div>
  326. </div>
  327. {elseif $pricing.annually}
  328. <div class="col-sm-4">
  329. <div class="form-group">
  330. <label>
  331. <input type="radio" class="cros-checkbox no-icheck" id="annually{$product.id}" name="billingcycle[{$product.id}]" value="annually" onclick="addToCart();triggerBillingCycle();" {if $BACKCART['products'][0]['pid'] == $product.id && $BACKCART['products'][0]['billingcycle'] == 'annually'} checked='checked'{elseif $smarty.get.billingcycle=='annually'} checked='checked'{elseif $pricing.checked} checked='checked'{/if}>
  332. <span class="pcb xs">
  333. <span class="c-name">{$LANG.orderpaymenttermannually}</span>
  334. <span class="c-price{if $pricing.rawannually eq "0"} d-none{/if}">{if $CONFIG.ProductMonthlyPricingBreakdown eq "on"}{$pricing.textprice}{else}{$pricing.annually}{/if}</span>
  335. {if $pricing.savetext}<span class="c-save">{$pricing.savetext}</span>{/if}
  336. </span>
  337. </label>
  338. </div>
  339. </div>
  340. {elseif $pricing.biennially}
  341. <div class="col-sm-4">
  342. <div class="form-group">
  343. <label>
  344. <input type="radio" class="cros-checkbox no-icheck" id="biennially{$product.id}" name="billingcycle[{$product.id}]" value="biennially" onclick="addToCart();triggerBillingCycle();" {if $BACKCART['products'][0]['pid'] == $product.id && $BACKCART['products'][0]['billingcycle'] == 'biennially'} checked='checked'{elseif $smarty.get.billingcycle=='biennially'} checked='checked'{elseif $pricing.checked} checked='checked'{/if}>
  345. <span class="pcb xs">
  346. <span class="c-name">{$LANG.orderpaymenttermbiennially}</span>
  347. <span class="c-price{if $pricing.rawbiennially eq "0"} d-none{/if}">{if $CONFIG.ProductMonthlyPricingBreakdown eq "on"}{$pricing.textprice}{else}{$pricing.biennially}{/if}</span>
  348. {if $pricing.savetext}<span class="c-save">{$pricing.savetext}</span>{/if}
  349. </span>
  350. </label>
  351. </div>
  352. </div>
  353. {elseif $pricing.triennially}
  354. <div class="col-sm-4">
  355. <div class="form-group">
  356. <label>
  357. <input type="radio" class="cros-checkbox no-icheck" id="triennially{$product.id}" name="billingcycle[{$product.id}]" value="triennially" onclick="addToCart();triggerBillingCycle();" {if $BACKCART['products'][0]['pid'] == $product.id && $BACKCART['products'][0]['billingcycle'] == 'triennially'} checked='checked'{elseif $smarty.get.billingcycle=='triennially'} checked='checked'{elseif $pricing.checked} checked='checked'{/if}>
  358. <span class="pcb xs">
  359. <span class="c-name">{$LANG.orderpaymenttermtriennially}</span>
  360. <span class="c-price{if $pricing.rawtriennially eq "0"} d-none{/if}">{if $CONFIG.ProductMonthlyPricingBreakdown eq "on"}{$pricing.textprice}{else}{$pricing.triennially}{/if}</span>
  361. {if $pricing.savetext}<span class="c-save">{$pricing.savetext}</span>{/if}
  362. </span>
  363. </label>
  364. </div>
  365. </div>
  366. {/if}
  367. {/foreach}
  368. </div>
  369. {/if}
  370. {/foreach}
  371. </div>
  372. </div>
  373. </div>
  374. {/if}
  375. <div class="domain_error" style="display: none;"></div>
  376. {if $CONFIG.AllowRegister == 'on' || $CONFIG.AllowTransfer == 'on' || $CONFIG.AllowOwnDomain == 'on'}
  377. <div class="TM-card blocks domain_cont domainareadata" {if $domainorder == 'all'} style="display: none;" {else}style="display: block;"{/if}>
  378. <div class="blocks_heading">
  379. <div>
  380. <h2>{$LANG.cartproductdomainchoose}{if $domainorder != 'all'}<a href="order.php" class="btn btn-xs small text-danger">{$LANG.cartdomainsnohosting}</a>{/if}</h2>
  381. </div>
  382. {if $domainorder == 'register' || $domainorder == 'transfer'}
  383. {if $themesettings.orderform.opcnoheader || $themesettings.headersetting.accountactionbtn && !$loggedin}
  384. {if $languagechangeenabled && count($locales) > 1 || $currencies}
  385. <div class="lang-btn text-lg-right">
  386. <button type="button" class="text-base btn px-1 py-0" data-toggle="modal" data-target="#modalChooseLanguage">
  387. {if $languagechangeenabled && count($locales) > 1}
  388. <div class="d-inline-block align-middle">
  389. <div class="iti-flag {if $activeLocale.countryCode === '001'}us{else}{$activeLocale.countryCode|lower}{/if}"></div>
  390. </div>
  391. {$activeLocale.localisedName}{/if}{if $languagechangeenabled && count($locales) > 1 && $currencies && !$loggedin}&nbsp;|&nbsp;{/if}{if !$loggedin && $currencies}{$activeCurrency.prefix} {$activeCurrency.code}{/if}
  392. </button>
  393. </div>
  394. {/if}
  395. {/if}
  396. {/if}
  397. </div>
  398. {assign var=freedomaindisplay value='none' }
  399. {if $freedomainpaymentterms|strstr:$BACKCART['products'][0]['billingcycle']}
  400. {assign var=freedomaindisplay value='block' }
  401. {/if}
  402. {if ($CONFIG.AllowRegister == 'on' || $CONFIG.AllowTransfer == 'on') && $freedomainvar}
  403. <div class="domain_spcl_offer" style="display:{$freedomaindisplay};">
  404. <p>
  405. <span class="bold">Get a free <span class="terms-once">1 year</span> {$LANG.orderdomainregonly}</span>{if $CONFIG.AllowTransfer == 'on'} or <span class="bold">{$LANG.orderdomaintransfer}</span>{/if}
  406. </p>
  407. {if $freedomaintlds}
  408. <p><small>{$LANG.orderfreedomainappliesto}: <span id="freetlds">{$freedomaintlds}</span></small></p>
  409. {/if}
  410. </div>
  411. {/if}
  412. <div class="blocks_body domains">
  413. <div class="domain-section-tabs{if $domainorder != 'all'} hidden{/if}">
  414. {if $CONFIG.AllowRegister == 'on'}
  415. <a href="javascript:void(0)" {if $domainorder != 'all' && $domainorder == 'transfer'}style="display: none"{/if} class="domain_sec domain-register {if !isset($BACKCART['domains'][0]['type']) && (!isset($BACKCART['products'][0]['domain']) || $BACKCART['products'][0]['domain'] == '')}domain_sec_active{/if} {if $BACKCART['domains'][0]['type'] == 'register'}domain_sec_active{/if}">
  416. <input type="radio" class="no-radio no-icheck" name="domaintype" value="register" id="register" {if !isset($BACKCART['domains'][0]['type']) && (!isset($BACKCART['products'][0]['domain']) || $BACKCART['products'][0]['domain'] == '') && $domainorder !== 'transfer' }checked="checked"{/if} {if $BACKCART['domains'][0]['type'] == 'register'}checked="checked"{/if} />&nbsp;{$LANG.navdomainsearch}
  417. </a>
  418. {/if}
  419. {if $CONFIG.AllowTransfer == 'on'}
  420. <a href="javascript:void(0)" {if $domainorder != 'all' && $domainorder == 'register'}style="display: none"{/if} class="domain_sec domain-trans {if $BACKCART['domains'][0]['type'] == 'transfer'}domain_sec_active{/if}">
  421. <input type="radio" class="no-radio no-icheck" name="domaintype" {if $BACKCART['domains'][0]['type'] == 'transfer'}checked='checked'{/if} value="transfer" id="transfer"/>&nbsp;{$LANG.domaintransfer}
  422. </a>
  423. {/if}
  424. {if $domainorder == 'all'}
  425. {if $CONFIG.AllowOwnDomain == 'on'}
  426. <a href="javascript:void(0)" class="domain_sec domain-own {if $BACKCART['products'][0]['domain'] != '' && !empty($BACKCART['domains']) <= 0}domain_sec_active{/if}">
  427. <input type="radio" class="no-radio no-icheck" name="domaintype" {if $owndomainmarket || ($BACKCART['products'][0]['domain'] != '' && !empty($BACKCART['domains']) <= 0)}checked='checked'{/if} value="owndomain" id="owndomain"/>&nbsp;<span style="display:inline" class="owndomaintext">{$LANG.domaincheckerhostingonly}</span><span class="marketconnecttext" style="display:none">{$LANG.store.domainAlreadyOwned}</span>
  428. </a>
  429. {/if}
  430. {/if}
  431. <a href="javascript:void(0)" class="hidden domain_sec domain-subdomain">
  432. <input type="radio" class="no-radio no-icheck" name="domaintype" value="subdomain" id="subdomain"/>&nbsp;{$LANG.orderusesubdomain}
  433. </a>
  434. </div>
  435. <div class="domain-input clearfix hidden" id="domainsubdomain">
  436. <div class="sd-desc">
  437. {$LANG.cartsubdomainchoice|sprintf2:$companyname}
  438. </div>
  439. <div class="row">
  440. <div class="col-sm-10">
  441. <div class="row domains-row">
  442. <div class="col-xs-7 col-7">
  443. <div class="input-group">
  444. <span class="input-group-prepend">
  445. <span class="input-group-text">https://</span>
  446. </span>
  447. <input type="text" name="subdomainvaltext" id="subdomainsld" value="" placeholder="yourname" class="form-control" autocapitalize="none" onkeyup="$(this).val($(this).val().toLowerCase())" onblur="this.value=removeSpaces(this.value);" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{lang key='orderForm.enterDomain'}" />
  448. </div>
  449. </div>
  450. <div class="col-xs-5 col-5">
  451. <select id="subdomaintld" name="subdomainval" class="form-control">
  452. </select>
  453. </div>
  454. </div>
  455. </div>
  456. <div class="col-sm-2">
  457. <button type="button" onclick="checksubdomain()" class="btn btn-primary btn-block">
  458. {$LANG.orderForm.check}
  459. </button>
  460. </div>
  461. </div>
  462. <div class="domainloaderi loader-img" style="display: none;margin: 25px;"><i class="fad fa-circle-notch fa-spin fa-2x"></i></div>
  463. <div class="domain-msg1" id="domain_msg1" style="display: none;"></div>
  464. </div>
  465. <div class="domain-input">
  466. <div class="dr-desc {if $domainorder != 'all' && $domainorder == 'transfer'}hidden{/if}">
  467. {$LANG.cartregisterdomainchoice|sprintf2:$companyname}
  468. </div>
  469. <div class="dt-desc {if $domainorder != 'all' && $domainorder == 'transfer'}{else}hidden{/if}">
  470. {$LANG.carttransferdomainchoice|sprintf2:$companyname}
  471. </div>
  472. <div class="do-desc hidden">
  473. {$LANG.cartexistingdomainchoice|sprintf2:$companyname}
  474. </div>
  475. <div class="domain-inputs-sec">
  476. <div class="domain-input-col">
  477. <div class="input-group">
  478. <span class="input-group-prepend">
  479. <span class="input-group-text">www.</span>
  480. </span>
  481. <input type="text" value="{if $owndomainmarket}{$owndomainmarket}{else}{if !empty($BACKCART['domains'][0]['domain_cart']) && $BACKCART['domains'][0]['type'] != 'owndomain'}{$BACKCART['domains'][0]['domain_cart'][0]}{elseif !empty($BACKCART['domains'][0]['domain_cart']) <= 0 && $BACKCART['products'][0]['domain'] != ''}{$BACKCART['products'][0]['domain']}{/if}{/if}" name="domain" id="domainname" class="form-control" data-toggle="tooltip" data-placement="top" onblur="this.value=removeSpaces(this.value);" onkeyup="$(this).val($(this).val().toLowerCase())" data-trigger="manual" title="{lang key='orderForm.enterDomain'}" />
  482. <input type="hidden" value="" name="hiddendomain" id="hiddendomainname"/>
  483. </div>
  484. </div>
  485. <div class="tld">
  486. <select class="form-control select2-single" id="tldepp" name="tld">
  487. {foreach from=$tlds key=num item=tld}
  488. <option value="{$tld.extension}" data-epp="{$tld.eppcode}" {if !empty($BACKCART['domains'][0]['domain_cart']) && $BACKCART['domains'][0]['domain_cart'][1] == $tld.extension}selected='selected'{/if}>{$tld.extension}</option>
  489. {/foreach}
  490. </select>
  491. </div>
  492. <div class="authcode" style="display: none;">
  493. <input type="text" name="eppcode" value="" id="eppcode" class="form-control" placeholder="{lang key='orderForm.authCodePlaceholder'}" data-toggle="tooltip" data-placement="top" data-trigger="manual" title="{lang key='orderForm.authCodeTooltip'}" />
  494. </div>
  495. <div class="domain_search">
  496. <button class="btn btn-primary btn-block" onclick="domainSearch();">{$LANG.search}</button>
  497. </div>
  498. </div>
  499. <div class="domainloaderi loader-img" style="display: none;margin: 25px;"><i class="fad fa-circle-notch fa-spin fa-2x"></i></div>
  500. <div class="domain-msg" id="domain_msg" style="display: none;">
  501. {foreach from=$existingdomains item=edomain}
  502. {if !$edomain.domain} {continue} {/if}
  503. <div data-domain="{$edomain.domain}" class="alert domainresuc domain_success"><strong>{$edomain.domain}</strong>, {$LANG.orderForm.domainAddedToCart}<a href="#" class="close btn-add-to-cart2 btn-domain-remove" data-domain="{$edomain.domain}" aria-label="close"><i class="fas fa-times"></i></a></div>
  504. {/foreach}
  505. </div>
  506. <div class="suggested-domains{if !$showSuggestionsContainer} hidden{/if}">
  507. <div class="panel-heading">
  508. {lang key='orderForm.suggestedDomains'}
  509. </div>
  510. <div id="suggestionsLoader" class="panel-body domain-lookup-loader domain-lookup-suggestions-loader">
  511. <i class="fas fa-spinner fa-spin"></i> {lang key='orderForm.generatingSuggestions'}
  512. </div>
  513. <ul id="domainSuggestionsbackup" style="display: none"><li class="domain-suggestion list-group-item hidden">
  514. <span class="domain"></span><span class="extension"></span>
  515. <span class="promo hidden">
  516. <span class="sales-group-hot hidden">{lang key='domainCheckerSalesGroup.hot'}</span>
  517. <span class="sales-group-new hidden">{lang key='domainCheckerSalesGroup.new'}</span>
  518. <span class="sales-group-sale hidden">{lang key='domainCheckerSalesGroup.sale'}</span>
  519. </span>
  520. <div class="actions">
  521. <span class="price"></span>
  522. <button type="button" class="btn btn-add-to-cart2" data-whois="1" data-domain="">
  523. <span class="to-add">{$LANG.addtocart}</span>
  524. <span class="added"><i class="far fa-shopping-cart"></i>{$LANG.domaincheckeradded} - <span class="removedd">{$LANG.cartremove}?</span></span>
  525. <span class="unavailable">{$LANG.domaincheckertaken}</span>
  526. </button>
  527. <button type="button" class="btn btn-primary domain-contact-support hidden">
  528. {lang key='domainChecker.contactSupport'}
  529. </button>
  530. </div>
  531. </li>
  532. </ul>
  533. <ul id="domainSuggestions" class="domain-lookup-result list-group hidden">
  534. <li class="domain-suggestion list-group-item hidden">
  535. <span class="domain"></span><span class="extension"></span>
  536. <span class="promo hidden">
  537. <span class="sales-group-hot hidden">{lang key='domainCheckerSalesGroup.hot'}</span>
  538. <span class="sales-group-new hidden">{lang key='domainCheckerSalesGroup.new'}</span>
  539. <span class="sales-group-sale hidden">{lang key='domainCheckerSalesGroup.sale'}</span>
  540. </span>
  541. <div class="actions">
  542. <span class="price"></span>
  543. <button type="button" class="btn btn-add-to-cart2" data-whois="1" data-domain="">
  544. <span class="to-add">{$LANG.addtocart}</span>
  545. <span class="added"><i class="far fa-shopping-cart"></i>{$LANG.domaincheckeradded} - <span class="removedd">{$LANG.cartremove}?</span></span>
  546. <span class="unavailable">{$LANG.domaincheckertaken}</span>
  547. </button>
  548. <button type="button" class="btn btn-primary domain-contact-support hidden">
  549. {lang key='domainChecker.contactSupport'}
  550. </button>
  551. </div>
  552. </li>
  553. </ul>
  554. <div class="panel-footer more-suggestions hidden text-center">
  555. <a id="moreSuggestions" href="#" onclick="loadMoreSuggestions();
  556. return false;">{lang key='domainsmoresuggestions'}</a>
  557. <span id="noMoreSuggestions" class="no-more small hidden">{lang key='domaincheckernomoresuggestions'}</span>
  558. </div>
  559. <div class="text-center text-muted domain-suggestions-warning">
  560. <p>{lang key='domainssuggestionswarnings'}</p>
  561. </div>
  562. </div>
  563. </div>
  564. </div>
  565. </div>
  566. <div class="domain_config" style="display: none;">
  567. <div class="TM-card blocks domainconfig">
  568. <div class="blocks_heading">
  569. <h2>{$LANG.cartdomainsconfig}</h2>
  570. </div>
  571. <div class="blocks_body" id="domain_config"></div>
  572. </div>
  573. </div>
  574. {/if}
  575. <div class="product_config" style="display: none;">
  576. <div class="p_config_error" style="display: none;"></div>
  577. <div class="blocks_body" id="product_config"></div>
  578. </div>
  579. </form>
  580. <div id="ws-ajax-order-form">
  581. </div>
  582. </div>
  583. <div class="col-lg-4 col-xl-3">
  584. {include file="$template/core/includes/sidebarspc.tpl"}
  585. </div>
  586. </div>
  587. </div>
  588. </div>
  589. </div>
  590. {elseif $ordertype == 'domainrenewals'}
  591. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/domainrenewal.min.js?v={$versionHash}"></script>
  592. <script>
  593. jQuery(document).ready(function () {
  594. recalcsummary();
  595. recalcheckout();
  596. {if $pid}jQuery('#pid_{$pid}').trigger('click');{/if}
  597. });
  598. var ccdordertype = 'domainrenewals';
  599. </script>
  600. {if $themesettings.orderform.opcnoheader}
  601. <div class="hero spc">
  602. <div class="container">
  603. <div class="logo-section">
  604. <a class="logo" href="{if $themesettings.headersetting.CustomLogoLink}{$themesettings.headersetting.CustomLogoLink}{else}{$WEB_ROOT}/{/if}">
  605. {if $themesettings.general.enablelogo}
  606. <img src="{$themesettings.general.logourl}" alt="{$companyname}" class="logo-light" />
  607. {if $themesettings.general.darklogo}
  608. <img src="{$themesettings.general.darklogo}" alt="{$companyname}" class="logo-dark" />
  609. {else}
  610. <span class="logo-dark">{$companyname}</span>
  611. {/if}
  612. {else}
  613. <span class="logo-light">{$companyname}</span>
  614. {/if}
  615. </a>
  616. </div>
  617. </div>
  618. </div>
  619. {else}
  620. {if $themesettings.general.bannerstyle}
  621. <div{if $themesettings.general.bsbgstyle eq "1"} class="small-header header-banner-styled bg-primary position-relative mb-5"{else} class="hero-bg-wrap small-header header-banner-styled inverse bg-opacity mb-5"{if $themesettings.general.bheaderbg} style="background-image:url('{$themesettings.general.bheaderbg}');"{/if}{/if}>
  622. {if $themesettings.general.bsbgstyle eq "1"}
  623. <div class="cros-bg-shapes-right"></div>
  624. <div class="cros-bg-shapes-left"></div>
  625. {/if}
  626. <div class="container">
  627. <div class="page-title position-relative">
  628. <div class="header-lined">
  629. <div>
  630. <h1>
  631. {if $totalResults > 1}{lang key='navrenewdomains'}{else}{lang key='domainrenewal'}{/if}
  632. </h1>
  633. {if count($renewals) > 3}
  634. <div class="search-group">
  635. <input id="domainRenewalFilter" type="search" class="form-control" placeholder="{lang key='searchenterdomain'}">
  636. </div>
  637. {/if}
  638. </div>
  639. <div>
  640. {include file="$template/includes/breadcrumb.tpl"}
  641. </div>
  642. </div>
  643. </div>
  644. </div>
  645. </div>
  646. {else}
  647. <div class="hero d-flex align-items-center no-padding-bottom">
  648. <div class="container">
  649. <div class="page-title">
  650. <div class="header-lined">
  651. <div>
  652. <h1 class="fw-900">
  653. {if count($renewals) > 1}{lang key='domainrenewals'}{else}{lang key='domainrenewal'}{/if}
  654. </h1>
  655. {if count($renewals) > 3}
  656. <div class="search-group">
  657. <input id="domainRenewalFilter" type="search" class="form-control" placeholder="{lang key='searchenterdomain'}">
  658. </div>
  659. {/if}
  660. </div>
  661. </div>
  662. </div>
  663. </div>
  664. </div>
  665. {/if}
  666. {/if}
  667. {if count($renewals) == 0}
  668. <div class="container">
  669. <div id="no-domains" class="alert alert-warning text-center" role="alert">
  670. {lang key='domainRenewal.noDomains'}
  671. </div>
  672. <p class="text-center">
  673. <a href="clientarea.php" class="btn btn-default">
  674. <i class="fas fa-arrow-circle-left"></i>
  675. {$LANG.orderForm.returnToClientArea}
  676. </a>
  677. </p>
  678. </div>
  679. {else}
  680. <div id="order-standard_cart">
  681. <input type="hidden" value="{$promocode}" id="hiddenpromo"/>
  682. <div class="cat-loader" style="display: none;">
  683. <div class="loader-icon">
  684. <i class="fad fa-circle-notch fa-spin fa-3x"></i>
  685. </div>
  686. </div>
  687. <div class="container">
  688. <div class="onepage_cart" id="onepage_cart">
  689. <div class="row ajaxcart_cont">
  690. <div class="col-lg-8 col-xl-9">
  691. <span class="d-block d-lg-none float-right">
  692. <a href="{$WEB_ROOT}/order.php?ordertype=domain_renewal" onclick="emptyCart()" class="btn btn-link btn-emptycart" data-toggle="tooltip" data-placement="top" title="{$LANG.emptycart}"><i class="fas fa-trash"></i> {$LANG.emptycart}</a>
  693. </span>
  694. <div class="clearfix"></div>
  695. <div class="domain_error" style="display: none;"></div>
  696. {if $themesettings.orderform.opcnoheader}
  697. {if count($renewals) > 5}
  698. <div class="search-group mb-3">
  699. <input id="domainRenewalFilter" type="search" class="form-control" placeholder="{lang key='searchenterdomain'}">
  700. </div>
  701. {/if}
  702. {/if}
  703. <form method="post" id="coniguration_form" action="cart.php?a=add&renewals=true">
  704. <div id="domainRenewals" class="domain-renewals">
  705. {foreach from=$renewals item=renewal}
  706. {if $smarty.get.domain eq $renewal.domain}
  707. <div class="card renewals" data-domain="{$renewal.domain}">
  708. <div class="card-body p-3">
  709. <div class="d-flex flex-column flex-sm-row justify-content-between">
  710. <h4 class="m-0">{$renewal.domain}</h4>
  711. <div>
  712. {if !$renewal.eligibleForRenewal}
  713. <span class="label label-info">
  714. {if $renewal.freeDomainRenewal}
  715. {lang key='domainRenewal.freeWithService'}
  716. {else}
  717. {lang key='domainRenewal.unavailable'}
  718. {/if}
  719. </span>
  720. {elseif ($renewal.pastGracePeriod && $renewal.pastRedemptionGracePeriod)}
  721. <span class="label label-info">
  722. {lang key='domainrenewalspastgraceperiod'}
  723. </span>
  724. {elseif !$renewal.beforeRenewLimit && $renewal.daysUntilExpiry > 0}
  725. <span class="label label-{if $renewal.daysUntilExpiry > 30}success{else}warning{/if}">
  726. {lang key='domainRenewal.expiringIn' days=$renewal.daysUntilExpiry}
  727. </span>
  728. {elseif $renewal.daysUntilExpiry === 0}
  729. <span class="label label-grey">
  730. {lang key='expiresToday'}
  731. </span>
  732. {elseif $renewal.beforeRenewLimit}
  733. <span class="label label-info">
  734. {lang key='domainRenewal.maximumAdvanceRenewal' days=$renewal.beforeRenewLimitDays}
  735. </span>
  736. {else}
  737. <span class="label label-danger">
  738. {lang key='domainRenewal.expiredDaysAgo' days=$renewal.daysUntilExpiry*-1}
  739. </span>
  740. {/if}
  741. </div>
  742. </div>
  743. <p class="small text-muted">{lang key='clientareadomainexpirydate'}: {$renewal.expiryDate->format('j M Y')} ({$renewal.expiryDate->diffForHumans()})</p>
  744. {if $renewal.freeDomainRenewal}
  745. <p class="small text-muted domain-renewal-desc">{lang key='domainRenewal.freeWithServiceDesc'}</p>
  746. {/if}
  747. <div class="domain-renewal-form">
  748. {if ($renewal.pastGracePeriod && $renewal.pastRedemptionGracePeriod) || !count($renewal.renewalOptions)}
  749. {else}
  750. <div class="domain-renewal-period">
  751. <select class="form-control input-lg select-renewal-pricing" name="renewalperiod[{$renewal.id}]" id="renewalPricing{$renewal.id}" data-domain-id="{$renewal.id}">
  752. {foreach $renewal.renewalOptions as $renewalOption}
  753. <option value="{$renewalOption.period}">
  754. {$renewalOption.period} {lang key='orderyears'} @ {$renewalOption.rawRenewalPrice}
  755. {if $renewalOption.gracePeriodFee && $renewalOption.gracePeriodFee->toNumeric() != 0.00}
  756. + {$renewalOption.gracePeriodFee} {lang key='domainRenewal.graceFee'}
  757. {/if}
  758. {if $renewalOption.redemptionGracePeriodFee && $renewalOption.redemptionGracePeriodFee->toNumeric() != 0.00}
  759. + {$renewalOption.redemptionGracePeriodFee} {lang key='domainRenewal.redemptionFee'}
  760. {/if}
  761. </option>
  762. {/foreach}
  763. </select>
  764. </div>
  765. {/if}
  766. {if !$renewal.eligibleForRenewal || $renewal.beforeRenewLimit || ($renewal.pastGracePeriod && $renewal.pastRedemptionGracePeriod)}
  767. {else}
  768. <div class="domain-renewal-action">
  769. <label class="m-0">
  770. <input type="checkbox" class="no-icheck nocheck domainrenewald" name="renewalids[]" value="{$renewal.id}" />
  771. <span class="scheck btn btn-primary btn-sm pl-3 pr-2 py-0"><h6 class="h5 small">{lang key='addtocart'}</h6></span>
  772. </label>
  773. </div>
  774. {/if}
  775. </div>
  776. </div>
  777. </div>
  778. {elseif !$smarty.get.domain}
  779. <div class="card renewals" data-domain="{$renewal.domain}">
  780. <div class="card-body p-3">
  781. <div class="d-flex flex-column flex-sm-row justify-content-between">
  782. <h4 class="m-0">{$renewal.domain}</h4>
  783. <div>
  784. {if !$renewal.eligibleForRenewal}
  785. <span class="label label-info">
  786. {if $renewal.freeDomainRenewal}
  787. {lang key='domainRenewal.freeWithService'}
  788. {else}
  789. {lang key='domainRenewal.unavailable'}
  790. {/if}
  791. </span>
  792. {elseif ($renewal.pastGracePeriod && $renewal.pastRedemptionGracePeriod)}
  793. <span class="label label-info">
  794. {lang key='domainrenewalspastgraceperiod'}
  795. </span>
  796. {elseif !$renewal.beforeRenewLimit && $renewal.daysUntilExpiry > 0}
  797. <span class="label label-{if $renewal.daysUntilExpiry > 30}success{else}warning{/if}">
  798. {lang key='domainRenewal.expiringIn' days=$renewal.daysUntilExpiry}
  799. </span>
  800. {elseif $renewal.daysUntilExpiry === 0}
  801. <span class="label label-grey">
  802. {lang key='expiresToday'}
  803. </span>
  804. {elseif $renewal.beforeRenewLimit}
  805. <span class="label label-info">
  806. {lang key='domainRenewal.maximumAdvanceRenewal' days=$renewal.beforeRenewLimitDays}
  807. </span>
  808. {else}
  809. <span class="label label-danger">
  810. {lang key='domainRenewal.expiredDaysAgo' days=$renewal.daysUntilExpiry*-1}
  811. </span>
  812. {/if}
  813. </div>
  814. </div>
  815. <p class="small text-muted">{lang key='clientareadomainexpirydate'}: {$renewal.expiryDate->format('j M Y')} ({$renewal.expiryDate->diffForHumans()})</p>
  816. {if $renewal.freeDomainRenewal}
  817. <p class="small text-muted domain-renewal-desc">{lang key='domainRenewal.freeWithServiceDesc'}</p>
  818. {/if}
  819. <div class="domain-renewal-form">
  820. {if ($renewal.pastGracePeriod && $renewal.pastRedemptionGracePeriod) || !count($renewal.renewalOptions)}
  821. {else}
  822. <div class="domain-renewal-period">
  823. <select class="form-control input-lg select-renewal-pricing" name="renewalperiod[{$renewal.id}]" id="renewalPricing{$renewal.id}" data-domain-id="{$renewal.id}">
  824. {foreach $renewal.renewalOptions as $renewalOption}
  825. <option value="{$renewalOption.period}">
  826. {$renewalOption.period} {lang key='orderyears'} @ {$renewalOption.rawRenewalPrice}
  827. {if $renewalOption.gracePeriodFee && $renewalOption.gracePeriodFee->toNumeric() != 0.00}
  828. + {$renewalOption.gracePeriodFee} {lang key='domainRenewal.graceFee'}
  829. {/if}
  830. {if $renewalOption.redemptionGracePeriodFee && $renewalOption.redemptionGracePeriodFee->toNumeric() != 0.00}
  831. + {$renewalOption.redemptionGracePeriodFee} {lang key='domainRenewal.redemptionFee'}
  832. {/if}
  833. </option>
  834. {/foreach}
  835. </select>
  836. </div>
  837. {/if}
  838. {if !$renewal.eligibleForRenewal || $renewal.beforeRenewLimit || ($renewal.pastGracePeriod && $renewal.pastRedemptionGracePeriod)}
  839. {else}
  840. <div class="domain-renewal-action">
  841. <label class="m-0">
  842. <input type="checkbox" class="no-icheck nocheck domainrenewald" name="renewalids[]" value="{$renewal.id}" />
  843. <span class="scheck btn btn-primary btn-sm pl-3 pr-2 py-0"><h6 class="h5 small">{lang key='addtocart'}</h6></span>
  844. </label>
  845. </div>
  846. {/if}
  847. </div>
  848. </div>
  849. </div>
  850. {/if}
  851. <div class="text-center">
  852. <small>
  853. {if $hasDomainsInGracePeriod}
  854. * {lang key='domainRenewal.graceRenewalPeriodDescription'}
  855. {/if}
  856. </small>
  857. </div>
  858. {foreachelse}
  859. <div class="alert alert-info">
  860. {$LANG.domainrenewalsnoneavailable}
  861. </div>
  862. {/foreach}
  863. </div>
  864. </form>
  865. <div id="ws-ajax-order-form">
  866. </div>
  867. </div>
  868. <div class="col-lg-4 col-xl-3">
  869. {include file="$template/core/includes/sidebarspc.tpl"}
  870. </div>
  871. </div>
  872. </div>
  873. </div>
  874. </div>
  875. {/if}
  876. <script>
  877. jQuery(document).ready(function() {
  878. jQuery(function() {
  879. jQuery('#domainRenewalFilter').on('keyup', function() {
  880. var rex = new RegExp($(this).val(), 'i');
  881. $('.renewals').hide();
  882. $('.renewals').filter(function() {
  883. return rex.test($(this).text());
  884. }).show();
  885. });
  886. });
  887. });
  888. </script>
  889. {elseif $ordertype == 'servicerenewals'}
  890. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/servicerenewal.js?v={$versionHash}"></script>
  891. <script>
  892. jQuery(document).ready(function () {
  893. recalcsummary();
  894. recalcheckout();
  895. {if $pid}jQuery('#pid_{$pid}').trigger('click');{/if}
  896. });
  897. var ccdordertype = 'servicerenewals';
  898. </script>
  899. {if $themesettings.orderform.opcnoheader}
  900. <div class="hero spc">
  901. <div class="container">
  902. <div class="logo-section">
  903. <a class="logo" href="{if $themesettings.headersetting.CustomLogoLink}{$themesettings.headersetting.CustomLogoLink}{else}{$WEB_ROOT}/{/if}">
  904. {if $themesettings.general.enablelogo}
  905. <img src="{$themesettings.general.logourl}" alt="{$companyname}" class="logo-light" />
  906. {if $themesettings.general.darklogo}
  907. <img src="{$themesettings.general.darklogo}" alt="{$companyname}" class="logo-dark" />
  908. {else}
  909. <span class="logo-dark">{$companyname}</span>
  910. {/if}
  911. {else}
  912. <span class="logo-light">{$companyname}</span>
  913. {/if}
  914. </a>
  915. </div>
  916. </div>
  917. </div>
  918. {else}
  919. {if $themesettings.general.bannerstyle}
  920. <div{if $themesettings.general.bsbgstyle eq "1"} class="small-header header-banner-styled bg-primary position-relative mb-5"{else} class="hero-bg-wrap small-header header-banner-styled inverse bg-opacity mb-5"{if $themesettings.general.bheaderbg} style="background-image:url('{$themesettings.general.bheaderbg}');"{/if}{/if}>
  921. {if $themesettings.general.bsbgstyle eq "1"}
  922. <div class="cros-bg-shapes-right"></div>
  923. <div class="cros-bg-shapes-left"></div>
  924. {/if}
  925. <div class="container">
  926. <div class="page-title position-relative">
  927. <div class="header-lined">
  928. <div>
  929. <h1>
  930. {if $totalResults > 1}{lang key='renewService.titlePlural'}{else}{lang key='renewService.titleSingular'}{/if}
  931. </h1>
  932. {if $totalResults > 3}
  933. <div class="search-group">
  934. <input id="serviceRenewalFilter" type="search" class="form-control" placeholder="{lang key='renewService.searchPlaceholder'}">
  935. </div>
  936. {/if}
  937. </div>
  938. <div>
  939. {include file="$template/includes/breadcrumb.tpl"}
  940. </div>
  941. </div>
  942. </div>
  943. </div>
  944. </div>
  945. {else}
  946. <div class="hero d-flex align-items-center no-padding-bottom">
  947. <div class="container">
  948. <div class="page-title">
  949. <div class="header-lined">
  950. <div>
  951. <h1 class="fw-900">
  952. {if $totalResults > 1}{lang key='renewService.titlePlural'}{else}{lang key='renewService.titleSingular'}{/if}
  953. </h1>
  954. {if $totalResults > 3}
  955. <div class="search-group">
  956. <input id="serviceRenewalFilter" type="search" class="form-control" placeholder="{lang key='renewService.searchPlaceholder'}">
  957. </div>
  958. {/if}
  959. </div>
  960. </div>
  961. </div>
  962. </div>
  963. </div>
  964. {/if}
  965. {/if}
  966. {if $totalServiceCount == 0}
  967. <div class="container">
  968. <div id="no-domains" class="alert alert-warning text-center" role="alert">
  969. {lang key='renewService.noServices'}
  970. </div>
  971. <p class="text-center">
  972. <a href="clientarea.php" class="btn btn-default">
  973. <i class="fas fa-arrow-circle-left"></i>
  974. {$LANG.orderForm.returnToClientArea}
  975. </a>
  976. </p>
  977. </div>
  978. {else}
  979. <div id="order-standard_cart">
  980. <input type="hidden" value="{$promocode}" id="hiddenpromo"/>
  981. <div class="cat-loader" style="display: none;">
  982. <div class="loader-icon">
  983. <i class="fad fa-circle-notch fa-spin fa-3x"></i>
  984. </div>
  985. </div>
  986. <div class="container">
  987. <div class="onepage_cart" id="onepage_cart">
  988. <div class="row ajaxcart_cont">
  989. <div class="col-lg-8 col-xl-9">
  990. <span class="d-block d-lg-none float-right">
  991. <a href="{$WEB_ROOT}/order.php?ordertype=service_renewal" onclick="emptyCart()" class="btn btn-link btn-emptycart" data-toggle="tooltip" data-placement="top" title="{$LANG.emptycart}"><i class="fas fa-trash"></i> {$LANG.emptycart}</a>
  992. </span>
  993. <div class="clearfix"></div>
  994. <div class="service_error" style="display: none;"></div>
  995. {if $themesettings.orderform.opcnoheader}
  996. {if $totalResults > 5}
  997. <div class="search-group mb-3">
  998. <input id="serviceRenewalFilter" type="search" class="form-control" placeholder="{lang key='renewService.searchPlaceholder'}">
  999. </div>
  1000. {/if}
  1001. {/if}
  1002. <form method="post" id="coniguration_form" action="cart.php?a=add&renewals=true">
  1003. <div id="serviceRenewals" class="domain-renewals">
  1004. {foreach from=$renewableServices item=renewableService}
  1005. <div class="card renewals" data-product-name="{$renewableService.product.name}" data-service-id="{$renewableService.serviceId}" data-service-domain="{$renewableService.domain}">
  1006. <div class="card-body p-3">
  1007. <div class="d-flex flex-column flex-sm-row justify-content-between">
  1008. <h4 class="m-0">{$renewableService.product.name}</h4>
  1009. <div>
  1010. <span class="label label-warning">
  1011. {lang key='renewService.renewingIn' days=$renewableService.nextDueDate->diffInDays()}
  1012. </span>
  1013. </div>
  1014. </div>
  1015. <p class="small text-muted">{$renewableService.domain}</p>
  1016. <p>
  1017. {if is_null($renewableService.nextDueDate)}
  1018. {lang key='renewService.serviceNextDueDateBasic' nextDueDate={lang key='na'}}
  1019. {else}
  1020. {lang key='renewService.serviceNextDueDateExtended' nextDueDate=$renewableService.nextDueDate->toClientDateFormat() nextDueDateFormatted=$renewableService.nextDueDate->diffForHumans()}
  1021. {/if}
  1022. </p>
  1023. </div>
  1024. <div class="card-footer">
  1025. <div class="domain-renewal-form d-flex space-between flex-column flex-md-row align-items-md-center">
  1026. <div class="domain-renewal-period">
  1027. <div class="div-renewal-period-label">
  1028. {lang key='renewService.renewalPeriodLabel'}
  1029. </div>
  1030. <div>
  1031. {lang key='renewService.renewalPeriod' nextDueDate=$renewableService.nextDueDate->toClientDateFormat() nextPayUntilDate=$renewableService.nextPayUntilDate->toClientDateFormat() renewalPrice=$renewableService.price}
  1032. </div>
  1033. </div>
  1034. <div class="domain-renewal-action mt-md-0 mt-3">
  1035. <label class="m-0">
  1036. <input type="checkbox" class="no-icheck nocheck servicerenewald" name="renewalids[]" value="{$renewableService.serviceId}" />
  1037. <span class="scheck btn btn-primary btn-sm pl-3 pr-2 py-0"><h6 class="h5 small">{lang key='addtocart'}</h6></span>
  1038. </label>
  1039. </div>
  1040. </div>
  1041. </div>
  1042. {if !empty($renewableService.addons)}
  1043. <div class="addon-renewals m-3" {if $renewableService.renewableCount <= 0}style="display: none;" data-is-renewable="false" {else}data-is-renewable="true"{/if}>
  1044. <h4><strong>{lang key='cartaddons'}</strong></h4>
  1045. <div>
  1046. {foreach from=$renewableService.addons item=$renewableAddon}
  1047. <div class="card renewals" data-product-name="{$renewableAddon.product.name}" data-service-id="{$renewableAddon.serviceId}" data-service-domain="{$renewableAddon.domain}">
  1048. <div class="card-body p-3">
  1049. <div class="d-flex flex-column flex-sm-row justify-content-between">
  1050. <h4 class="m-0">{$renewableAddon.product.name}</h4>
  1051. <div>
  1052. <span class="label label-warning">
  1053. {lang key='renewService.renewingIn' days=$renewableAddon.nextDueDate->diffInDays()}
  1054. </span>
  1055. </div>
  1056. </div>
  1057. <p class="small text-muted">{$renewableAddon.domain}</p>
  1058. <p>
  1059. {if is_null($renewableAddon.nextDueDate)}
  1060. {lang key='renewService.serviceNextDueDateBasic' nextDueDate={lang key='na'}}
  1061. {else}
  1062. {lang key='renewService.serviceNextDueDateExtended' nextDueDate=$renewableAddon.nextDueDate->toClientDateFormat() nextDueDateFormatted=$renewableAddon.nextDueDate->diffForHumans()}
  1063. {/if}
  1064. </p>
  1065. </div>
  1066. <div class="card-footer">
  1067. <div class="domain-renewal-form d-flex space-between flex-column flex-md-row align-items-md-center">
  1068. <div class="domain-renewal-period">
  1069. <div class="div-renewal-period-label">
  1070. {lang key='renewService.renewalPeriodLabel'}
  1071. </div>
  1072. <div>
  1073. {lang key='renewService.renewalPeriod' nextDueDate=$renewableAddon.nextDueDate->toClientDateFormat() nextPayUntilDate=$renewableAddon.nextPayUntilDate->toClientDateFormat() renewalPrice=$renewableAddon.price}
  1074. </div>
  1075. </div>
  1076. <div class="domain-renewal-action mt-md-0 mt-3">
  1077. <label class="m-0">
  1078. <input type="checkbox" class="no-icheck nocheck addonrenewald" name="renewalaids[]" value="{$renewableAddon.serviceId}" />
  1079. <span class="scheck btn btn-primary btn-sm pl-3 pr-2 py-0"><h6 class="h5 small">{lang key='addtocart'}</h6></span>
  1080. </label>
  1081. </div>
  1082. </div>
  1083. </div>
  1084. </div>
  1085. {/foreach}
  1086. </div>
  1087. </div>
  1088. {/if}
  1089. </div>
  1090. {/foreach}
  1091. {foreach $nonRenewableServices as $nonRenewableService}
  1092. <div class="card renewals no-shadow" data-product-name="{$nonRenewableService.product.name}" data-service-id="{$nonRenewableService.serviceId}" data-service-domain="{$nonRenewableService.domain}">
  1093. <div class="card-body p-3">
  1094. <div class="d-flex flex-column flex-sm-row justify-content-between">
  1095. <h4 class="m-0">{$nonRenewableService.product.name}</h4>
  1096. <div>
  1097. <span class="label label-info">
  1098. {lang key='renewService.renewalUnavailable'}
  1099. </span>
  1100. </div>
  1101. </div>
  1102. <p class="small text-muted">{$nonRenewableService.domain}</p>
  1103. <p>
  1104. {if is_null($nonRenewableService.nextDueDate)}
  1105. {lang key='renewService.serviceNextDueDateBasic' nextDueDate={lang key='na'}}
  1106. {else}
  1107. {lang key='renewService.serviceNextDueDateExtended' nextDueDate=$nonRenewableService.nextDueDate->toClientDateFormat() nextDueDateFormatted=$nonRenewableService.nextDueDate->diffForHumans()}
  1108. {/if}
  1109. </p>
  1110. </div>
  1111. <div class="card-footer">
  1112. <div class="domain-renewal-form">
  1113. <div class="domain-renewal-action">
  1114. <label class="m-0">
  1115. <i class="fas fa-info-circle fa-fw"></i>{$nonRenewableService.reason}
  1116. </label>
  1117. </div>
  1118. </div>
  1119. </div>
  1120. </div>
  1121. {/foreach}
  1122. </div>
  1123. </form>
  1124. <div id="ws-ajax-order-form">
  1125. </div>
  1126. </div>
  1127. <div class="col-lg-4 col-xl-3">
  1128. {include file="$template/core/includes/sidebarspc.tpl"}
  1129. </div>
  1130. </div>
  1131. </div>
  1132. </div>
  1133. </div>
  1134. {/if}
  1135. <script>
  1136. jQuery(document).ready(function() {
  1137. jQuery(function() {
  1138. jQuery('#serviceRenewalFilter').on('keyup', function() {
  1139. var rex = new RegExp($(this).val(), 'i');
  1140. $('.renewals').hide();
  1141. $('.renewals').filter(function() {
  1142. return rex.test($(this).text());
  1143. }).show();
  1144. });
  1145. });
  1146. });
  1147. </script>
  1148. {elseif $ordertype == 'addons'}
  1149. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/addons.min.js?v={$versionHash}"></script>
  1150. <script>
  1151. jQuery(document).ready(function () {
  1152. recalcsummary();
  1153. recalcheckout();
  1154. {if $pid}jQuery('#pid_{$pid}').trigger('click');{/if}
  1155. });
  1156. var ccdordertype = 'addons';
  1157. </script>
  1158. {if $themesettings.orderform.opcnoheader}
  1159. <div class="hero spc">
  1160. <div class="container">
  1161. <div class="logo-section">
  1162. <a class="logo" href="{if $themesettings.headersetting.CustomLogoLink}{$themesettings.headersetting.CustomLogoLink}{else}{$WEB_ROOT}/{/if}">
  1163. {if $themesettings.general.enablelogo}
  1164. <img src="{$themesettings.general.logourl}" alt="{$companyname}" class="logo-light" />
  1165. {if $themesettings.general.darklogo}
  1166. <img src="{$themesettings.general.darklogo}" alt="{$companyname}" class="logo-dark" />
  1167. {else}
  1168. <span class="logo-dark">{$companyname}</span>
  1169. {/if}
  1170. {else}
  1171. <span class="logo-light">{$companyname}</span>
  1172. {/if}
  1173. </a>
  1174. </div>
  1175. </div>
  1176. </div>
  1177. {else}
  1178. {if $themesettings.general.bannerstyle}
  1179. <div{if $themesettings.general.bsbgstyle eq "1"} class="small-header header-banner-styled bg-primary position-relative mb-5"{else} class="hero-bg-wrap small-header header-banner-styled inverse bg-opacity mb-5"{if $themesettings.general.bheaderbg} style="background-image:url('{$themesettings.general.bheaderbg}');"{/if}{/if}>
  1180. {if $themesettings.general.bsbgstyle eq "1"}
  1181. <div class="cros-bg-shapes-right"></div>
  1182. <div class="cros-bg-shapes-left"></div>
  1183. {/if}
  1184. <div class="container">
  1185. <div class="page-title position-relative">
  1186. <div class="header-lined">
  1187. <div>
  1188. <h1>{$LANG.cartproductaddons}</h1>
  1189. </div>
  1190. <div>
  1191. {include file="$template/includes/breadcrumb.tpl"}
  1192. </div>
  1193. </div>
  1194. </div>
  1195. </div>
  1196. </div>
  1197. {else}
  1198. <div class="hero d-flex align-items-center no-padding-bottom">
  1199. <div class="container">
  1200. <div class="page-title">
  1201. <div class="header-lined">
  1202. <div>
  1203. <h1 class="fw-900">{$LANG.cartproductaddons}</h1>
  1204. </div>
  1205. </div>
  1206. </div>
  1207. </div>
  1208. </div>
  1209. {/if}
  1210. {/if}
  1211. {if count($addons) == 0}
  1212. <div class="container">
  1213. <div id="noAddons" class="alert alert-warning text-center" role="alert">
  1214. {$LANG.cartproductaddonsnone}
  1215. </div>
  1216. <p class="text-center">
  1217. <a href="clientarea.php" class="btn btn-default">
  1218. <i class="fas fa-arrow-circle-left"></i>
  1219. {$LANG.orderForm.returnToClientArea}
  1220. </a>
  1221. </p>
  1222. </div>
  1223. {else}
  1224. <div id="order-standard_cart">
  1225. <input type="hidden" value="{$promocode}" id="hiddenpromo"/>
  1226. <div class="cat-loader" style="display: none;">
  1227. <div class="loader-icon">
  1228. <i class="fad fa-circle-notch fa-spin fa-3x"></i>
  1229. </div>
  1230. </div>
  1231. <div class="container">
  1232. <div class="onepage_cart" id="onepage_cart">
  1233. <div class="row ajaxcart_cont">
  1234. <div class="col-lg-8 col-xl-9">
  1235. <span class="d-block d-lg-none float-right">
  1236. <a href="{$WEB_ROOT}/order.php?ordertype=addons" onclick="emptyCart()" class="btn btn-link btn-emptycart" data-toggle="tooltip" data-placement="top" title="{$LANG.emptycart}"><i class="fas fa-trash"></i> {$LANG.emptycart}</a>
  1237. </span>
  1238. <div class="clearfix"></div>
  1239. <div class="products">
  1240. <div class="domain_error" style="display: none;"></div>
  1241. <form method="post" id="coniguration_form" action="cart.php?gid=addons=true">
  1242. <div class="row row-eq-height">
  1243. {foreach $addons as $num => $addon}
  1244. <div class="col-md-6">
  1245. <div class="product bg-white" id="product{$num}">
  1246. <input type="hidden" name="aid" value="{$addon.id}" />
  1247. <div class="product-addon-header">
  1248. <h4>{$addon.name}</h4>
  1249. {if $product.qty}
  1250. <span class="qty">
  1251. {$product.qty} {$LANG.orderavailable}
  1252. </span>
  1253. {/if}
  1254. </div>
  1255. <div class="product-body">
  1256. <p class="text-muted">{$addon.description}</p>
  1257. </div>
  1258. <div class="product-options">
  1259. <div class="form-group">
  1260. <select name="selpro[{$addon.id}]" id="inputProductId{$num}" class="form-control field">
  1261. {foreach $addon.productids as $product}
  1262. <option value="{$product.id}">
  1263. {$product.product}{if $product.domain} - {$product.domain}{/if}
  1264. </option>
  1265. {/foreach}
  1266. </select>
  1267. </div>
  1268. </div>
  1269. <div class="product-addon-footer d-block">
  1270. <div class="product-pricing p-3 bg-light border rounded">
  1271. {if $addon.free}
  1272. {$LANG.orderfree}
  1273. {else}
  1274. <span class="price"><strong class="fw-500">{$addon.recurringamount}</strong> {$addon.billingcycle}</span>
  1275. {if $addon.havesetup}<br />+ {$addon.setupfee} {$LANG.ordersetupfee}{/if}
  1276. {/if}
  1277. </div>
  1278. <div class="product-actions w-100 mt-1">
  1279. <label class="m-0 w-100">
  1280. <input type="checkbox" class="no-icheck nocheck adaddons" name="adaddons[]" {if $smarty.get.aid==$addon.id} checked="checked" {/if} value="{$addon.id}" />
  1281. <span class="scheck btn btn-primary"><h6 class="h5">{$LANG.addtocart}</h6></span>
  1282. </label>
  1283. </div>
  1284. </div>
  1285. </div>
  1286. </div>
  1287. {if $num % 2 != 0}
  1288. </div>
  1289. <div class="row row-eq-height">
  1290. {/if}
  1291. {/foreach}
  1292. </div>
  1293. </form>
  1294. </div>
  1295. <div id="ws-ajax-order-form">
  1296. </div>
  1297. </div>
  1298. <div class="col-lg-4 col-xl-3">
  1299. {include file="$template/core/includes/sidebarspc.tpl"}
  1300. </div>
  1301. </div>
  1302. </div>
  1303. </div>
  1304. </div>
  1305. {/if}
  1306. {/if}
  1307. <script type="text/javascript" src="{$BASE_PATH_JS}/jquery.payment.js"></script>
  1308. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/ResizeSensor.js"></script>
  1309. <script type="text/javascript" src="{$WEB_ROOT}/templates/orderforms/{$carttpl}/js/jquery.sticky-sidebar.min.js"></script>
  1310. <script>
  1311. jQuery('#sidebar').stickySidebar({
  1312. topSpacing: 90,
  1313. bottomSpacing: 90,
  1314. minWidth: 992,
  1315. containerSelector: '.ajaxcart_cont',
  1316. innerWrapperSelector: '.sidebar__inner'
  1317. });
  1318. jQuery(document).on('click', '.btn-cart-contents', function (e) {
  1319. if (jQuery(window).width() <= 991) {
  1320. jQuery('.cartsummary_cont .summary_body >.cart-contents').slideToggle();
  1321. }
  1322. });
  1323. var hideCvcOnCheckoutForExistingCard = '{if $canUseCreditOnCheckout && $applyCredit && ($creditBalance->toNumeric() >= $total->toNumeric())}1{else}0{/if}';
  1324. function loadMoreSuggestions()
  1325. {
  1326. return true;
  1327. }
  1328. $('#moreSuggestions').click(function() {
  1329. var suggestions = jQuery('#domainSuggestions'),
  1330. suggestionCount;
  1331. var furtherSuggestions = suggestions.find('li.domain-suggestion.clone.hidden').length;
  1332. for (suggestionCount = 1; suggestionCount <= 10; suggestionCount++) {
  1333. if (furtherSuggestions > 0) {
  1334. suggestions.find('li.domain-suggestion.hidden.clone:first').not().hide().removeClass('hidden').slideDown();
  1335. furtherSuggestions = suggestions.find('li.domain-suggestion.clone.hidden').length;
  1336. jQuery('div.more-suggestions').find('a').addClass('hidden').end().find('span.no-more').addClass('hidden');
  1337. jQuery('#moreSuggestions').removeClass('hidden');
  1338. } else {
  1339. jQuery('div.more-suggestions').find('a').addClass('hidden').end().find('span.no-more').removeClass('hidden');
  1340. return;
  1341. }
  1342. }
  1343. });
  1344. jQuery('.select2-single').select2();
  1345. {if $domainorder == 'all'}
  1346. {if $smarty.get.pid} {else}
  1347. jQuery(document).ready(function () {
  1348. var slider = new Swiper(".plan-list-slider", {
  1349. slidesPerView: 1,
  1350. slideClass: "products-slide",
  1351. pagination: {
  1352. el: ".swiper-pagination",
  1353. type: "fraction",
  1354. },
  1355. navigation: {
  1356. nextEl: ".swiper-button-next",
  1357. prevEl: ".swiper-button-prev",
  1358. },
  1359. breakpoints: {
  1360. 0: {
  1361. slidesPerView: 1
  1362. },
  1363. 768: {
  1364. slidesPerView: 2
  1365. },
  1366. 992: {
  1367. slidesPerView: 2
  1368. },
  1369. 1200: {
  1370. slidesPerView: 3
  1371. },
  1372. },
  1373. on: {
  1374. init: function () {
  1375. this.allowTouchMove = this.slides.length > this.params.slidesPerView;
  1376. },
  1377. resize: function () {
  1378. this.allowTouchMove = this.slides.length > this.params.slidesPerView;
  1379. }
  1380. }
  1381. });
  1382. });
  1383. {/if}
  1384. {/if}
  1385. function removeSpaces(string) {
  1386. return string.split(' ').join('');
  1387. }
  1388. {if !$owndomainmarket}
  1389. function Epp()
  1390. {
  1391. var tldepp = $("#tldepp option:selected").attr("data-epp");
  1392. if(tldepp=='0')
  1393. {
  1394. $('.authcode').css('display','none');
  1395. $(".authcode #eppcode").val('');
  1396. $('#eppcode').attr('id','none');
  1397. }
  1398. else
  1399. {
  1400. {if $domainorder == 'transfer'}
  1401. $('.authcode').css('display','block');
  1402. {/if}
  1403. $('.authcode').focus();
  1404. $('[name=\"eppcode\"]').attr('id','eppcode');
  1405. }
  1406. }
  1407. jQuery(document).ready(function() {
  1408. Epp();
  1409. });
  1410. jQuery("#tldepp").change(function() {
  1411. Epp();
  1412. });
  1413. {/if}
  1414. jQuery(".promo_text").on("click", function() {
  1415. jQuery('.promo_text').remove();
  1416. jQuery('.promo_form').show();
  1417. });
  1418. </script>
  1419. {if $stripejs}
  1420. <script type="text/javascript" src="https://js.stripe.com/v3/"></script>
  1421. {/if}