This update guide only applies to our WHMCS Templates that are using the WHMCS Six client area template as a base. If you're using v2+ then this update does not apply to your template, please refer to the update announcement for more information. Find Template Version
Update Service
Save yourself time by using our professional update service. Your update to WHMCS v7.7 will be completed in-house by our team who will ensure everything goes smoothly with no loss of customizations.
In this tutorial you will learn how to update your WHMCS Template to support WHMCS v7.7.
Is This Update Required?
This update needs to be applied to your template to add support for WHMCS v7.7. If you purchased your template after the launch of WHMCS v7.7 (22nd January 2019) you do not need to follow this update as it will already be applied to your version.
How To Update
You will need to follow every step below to update to WHMCS v7.7.
1. Update WHMCS
To begin you will need to update WHMCS to v7.7 following WHMCS's documentation or you can hire us to update your WHMCS.
2. Complete Earlier Template Updates
If you updated from WHMCS v7.6.1 to v7.7 you can skip this section and move onto step 3.
If you updated from an earlier version of WHMCS you will need to apply the missing template updates before completing this one:
3. Upload The Files
Want to save time? You can hire us to update your template.
The next step is to upload the files from the update ZIP we have carefully prepared. The files contained within this update are unlikely to have been modified by most users as they are core client area files. If there are changes required to files that are more likely to have been edited (such as header.tpl, template.css, english.php) they will be listed as manual edits in step 4 to ensure that any edits made to these files will not be lost.
Steps To Upload
1. Make a full backup of your WHMCS files & database for safety
2. Download the update files >> Download WHMCS v7.7 Update (.zip)
3. Extract the ZIP file to your desktop
4. Rename the /upload/templates/your_active_template/ to the name of your active Zomex template you'd updating (e.g stellar, universe, eco-net etc)
5. Upload the contents of the upload directory using an FTP client to:
/whmcs_path/
Ensure that your FTP client does not replace directories and instead adds/overrides the new files within the existing directory. We recommend FileZilla which is free and will work correctly out of the box.
If you have made customisations to any files contained in the ZIP we recommend comparing your version and the updated version so you can re-apply your customisations manually.
4. Apply Manual File Edits
The final step is to make manual edits to some files. These edits are made manually as there is a higher chance that the files may have been customized. Manually applying the WHMCS v7.7 edits ensures that any prior customisations are safe.
Open: /whmcs_path/templates/your_active_template/includes/hook-head.tpl (or functions.tpl depending on your template).
Find the following code (it may look slightly different but that is fine as we are replacing the whole section):
<script>
var csrfToken = '{$token}',
markdownGuide = '{lang key="markdown.title"}',
locale = '{if !empty($mdeLocale)}{$mdeLocale}{else}en{/if}',
saved = '{lang key="markdown.saved"}',
saving = '{lang key="markdown.saving"}',
whmcsBaseUrl = "{\WHMCS\Utility\Environment\WebHelper::getBaseUrl()}",
recaptchaSiteKey = "{$recaptchaSiteKey}";
</script>
And replace with the following:
<link href="{$WEB_ROOT}/assets/css/fontawesome-all.min.css" rel="stylesheet">
<script>
var csrfToken = '{$token}',
markdownGuide = '{lang key="markdown.title"}',
locale = '{if !empty($mdeLocale)}{$mdeLocale}{else}en{/if}',
saved = '{lang key="markdown.saved"}',
saving = '{lang key="markdown.saving"}',
whmcsBaseUrl = "{\WHMCS\Utility\Environment\WebHelper::getBaseUrl()}",
requiredText = '{lang key="orderForm.required"}',
recaptchaSiteKey = "{if $captcha}{$captcha->recaptcha->getSiteKey()}{/if}";
</script>
Open: /whmcs_path/templates/your_active_template/login.tpl
Find the following code:
{if $incorrect}
{include file="$template/includes/alert.tpl" type="error" msg=$LANG.loginincorrect textcenter=true}
{elseif $verificationId && empty($transientDataName)}
{include file="$template/includes/alert.tpl" type="error" msg=$LANG.verificationKeyExpired textcenter=true}
{elseif $ssoredirect}
{include file="$template/includes/alert.tpl" type="info" msg=$LANG.sso.redirectafterlogin textcenter=true}
{/if}
And replace with the following:
{if $incorrect}
{include file="$template/includes/alert.tpl" type="error" msg=$LANG.loginincorrect textcenter=true}
{elseif $verificationId && empty($transientDataName)}
{include file="$template/includes/alert.tpl" type="error" msg=$LANG.verificationKeyExpired textcenter=true}
{elseif $ssoredirect}
{include file="$template/includes/alert.tpl" type="info" msg=$LANG.sso.redirectafterlogin textcenter=true}
{elseif $invalid}
{include file="$template/includes/alert.tpl" type="error" msg=$LANG.googleRecaptchaIncorrect textcenter=true}
{/if}
Find the following code:
<div class="row">
<div class="col-sm-{if $linkableProviders}7{else}12{/if}">
<form method="post" action="{$systemurl}dologin.php" class="login-form" role="form">
<div class="form-group">
<label for="inputEmail">{$LANG.clientareaemail}</label>
<input type="email" name="username" class="form-control" id="inputEmail" placeholder="{$LANG.enteremail}" autofocus>
</div>
<div class="form-group">
<label for="inputPassword">{$LANG.clientareapassword}</label>
<input type="password" name="password" class="form-control" id="inputPassword" placeholder="{$LANG.clientareapassword}" autocomplete="off" >
</div>
<div class="checkbox">
<label>
<input type="checkbox" name="rememberme" /> {$LANG.loginrememberme}
</label>
</div>
<div align="center">
<input id="login" type="submit" class="btn btn-primary" value="{$LANG.loginbutton}" />{* <a href="pwreset.php" class="btn btn-default">{$LANG.forgotpw}</a>*}
</div>
</form>
</div>
<div class="col-sm-5{if !$linkableProviders} hidden{/if}">
{include file="$template/includes/linkedaccounts.tpl" linkContext="login" customFeedback=true}
</div>
</div>
</div>
And replace with the following:
<div class="row">
<div class="col-sm-{if $linkableProviders}7{else}12{/if}">
<form method="post" action="{$systemurl}dologin.php" class="login-form" role="form">
<div class="form-group">
<label for="inputEmail">{$LANG.clientareaemail}</label>
<input type="email" name="username" class="form-control" id="inputEmail" placeholder="{$LANG.enteremail}" autofocus>
</div>
<div class="form-group">
<label for="inputPassword">{$LANG.clientareapassword}</label>
<input type="password" name="password" class="form-control" id="inputPassword" placeholder="{$LANG.clientareapassword}" autocomplete="off" >
</div>
<div class="checkbox">
<label>
<input type="checkbox" name="rememberme" /> {$LANG.loginrememberme}
</label>
</div>
{if $captcha->isEnabled()}
<div class="text-center margin-bottom">
{include file="$template/includes/captcha.tpl"}
</div>
{/if}
<div align="center">
<input id="login" type="submit" class="btn btn-primary{$captcha->getButtonClass($captchaForm)}" value="{$LANG.loginbutton}" /> <a href="{$systemurl}pwreset.php" class="btn btn-default">{$LANG.forgotpw}</a>
</div>
</form>
</div>
<div class="col-sm-5{if !$linkableProviders} hidden{/if}">
{include file="$template/includes/linkedaccounts.tpl" linkContext="login" customFeedback=true}
</div>
</div>
</div>
Open: /whmcs_path/templates/your_active_template/viewinvoice.tpl
Find the following code:
<p>{$payto}</p>
And replace with the following:
<p>{$payto}</p>
{if $taxCode}<p>{$taxIdLabel}: {$taxCode}</p>{/if}
Find the following code:
<p>
{if $clientsdetails.companyname}{$clientsdetails.companyname}<br />{/if}
{$clientsdetails.firstname} {$clientsdetails.lastname}<br />
{$clientsdetails.address1}, {$clientsdetails.address2}<br />
{$clientsdetails.city}, {$clientsdetails.state}, {$clientsdetails.postcode}<br />
{$clientsdetails.country}
{if $customfields}
<br /><br />
{foreach from=$customfields item=customfield}
{$customfield.fieldname}: {$customfield.value}<br />
{/foreach}
{/if}
</p>
And replace with the following:
<p>
{if $clientsdetails.companyname}{$clientsdetails.companyname}<br />{/if}
{$clientsdetails.firstname} {$clientsdetails.lastname}<br />
{$clientsdetails.address1}, {$clientsdetails.address2}<br />
{$clientsdetails.city}, {$clientsdetails.state}, {$clientsdetails.postcode}<br />
{$clientsdetails.country}
{if $clientsdetails.tax_id}
<br />{$taxIdLabel}: {$clientsdetails.tax_id}
{/if}
{if $customfields}
<br /><br />
{foreach from=$customfields item=customfield}
{$customfield.fieldname}: {$customfield.value}<br />
{/foreach}
{/if}
</p>
Open: /whmcs_path/templates/your_active_template/contact.tpl
Find the following code:
<div class="row">
<div class="col-sm-offset-3 col-sm-9">
{include file="$template/includes/captcha.tpl"}
</div>
</div>
And replace with the following:
{if $captcha}
<div class="text-center margin-bottom">
{include file="$template/includes/captcha.tpl"}
</div>
{/if}
Find the following code:
<button type="submit" class="btn btn-primary">{$LANG.contactsend}</button>
And replace with the following:
<button type="submit" class="btn btn-primary{$captcha->getButtonClass($captchaForm)}">{$LANG.contactsend}</button>
5. Update Completed
You have now finished updating your template to support WHMCS v7.7. If you see any miss alignment when viewing your website you may need to clear your browser cache to force the updated files to be rendered. If you run into any issues, submit a ticket and we will be happy to assist you.
Comments
If you have any questions please leave a comment below or contact our support.