order.tpl 80 KB

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