Jump to content

Please help need to change the order of currencies in the top drop down


vtifu

Recommended Posts

Hi vtifu,

What PS version do you use? 

Default Theme, or different one?

 

If you use PS 1.5.x,

Check if you have the file:

themes/<your theme folder>/modules/blockcurrencies/blockcurrencies.tpl    (if so, make backup!!)

 

(if not, copy file /modules/blockcurrencies/blockcurrencies.tpl to themes/<your theme folder>/modules/blockcurrencies/blockcurrencies.tpl)

 

In the file, you should have some line like this:

  {foreach from=$currencies key=k item=f_currency}
 

Add the red code just before this blue line: (Sample code from PS 1.5.5.0)

 

<div id="currencies_block_top">
  <form id="setCurrency" action="{$request_uri}" method="post">
  <p>
    <input type="hidden" name="id_currency" id="id_currency" value=""/>
    <input type="hidden" name="SubmitCurrency" value="" />
    {l s='Currency' mod='blockcurrencies'} : {$blockcurrencies_sign}
  </p>
  <ul id="first-currencies" class="currencies_ul">
 
  {$curr_temp     = $currencies[0]} {* example: swap 1st with 2nd item *}
  {$currencies[0] = $currencies[1]}
  {$currencies[1] = $curr_temp}
  {foreach from=$currencies key=k item=f_currency}
    <li {if $cookie->id_currency == $f_currency.id_currency}class="selected"{/if}>
      <a href="javascript:setCurrency({$f_currency.id_currency});" title="{$f_currency.name}" rel="nofollow">{$f_currency.sign}</a>
    </li>
  {/foreach}
...
 
The red code is an example how to swap the items in the $currencies array (i.e. the currencies list). Not sure how many currency items you have, and what order you want them. If you need help with writing these swaps, let me know the original and the desired order.
 
 
 
If you use PS 1.6.x:
edit the same file (copy first if it doesn't exist. Don't forget to backup!)
 
Then add the red lines almost at the top, just after the blue line: (Sample code from 1.6.0.8)
 
<!-- Block currencies module -->
{if count($currencies) > 1}
  {$curr_temp     = $currencies[0]} {* example: swap 1st with 2nd item *}
  {$currencies[0] = $currencies[1]}
  {$currencies[1] = $curr_temp}
 
  <div id="currencies-block-top">
    <form id="setCurrency" action="{$request_uri}" method="post">
 
 
Save the file and refresh the front page. See if it works.
Hope this helps
Pascal.
Link to comment
Share on other sites

  • 2 years later...

Hello,

 

I'm looking to do the same to change the order of currencies in the drop-down menu.

The version is 1.6.1.10

 

Here's the code of my blockcurrencies.tpl:

 

{*
* 2007-2016 PrestaShop
*
* NOTICE OF LICENSE
*
* This source file is subject to the Academic Free License (AFL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to [email protected] so we can send you a copy immediately.
*
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
* versions in the future. If you wish to customize PrestaShop for your
* needs please refer to http://www.prestashop.com for more information.
*
*  @author PrestaShop SA <[email protected]>
*  @copyright  2007-2016 PrestaShop SA
*  @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
*  International Registered Trademark & Property of PrestaShop SA
*}
 
<!-- Block currencies module -->
<script type="text/javascript">
$(document).ready(function () {
$("#setCurrency").mouseover(function(){
$(this).addClass("countries_hover");
$(".currencies_ul").addClass("currencies_ul_hover");
});
$("#setCurrency").mouseout(function(){
$(this).removeClass("countries_hover");
$(".currencies_ul").removeClass("currencies_ul_hover");
});
 
$('ul#first-currencies li:not(.selected)').css('opacity', 0.3);
$('ul#first-currencies li:not(.selected)').hover(function(){
$(this).css('opacity', 1);
}, function(){
$(this).css('opacity', 0.3);
});
});
</script>
 
<div id="currencies_block_top">
<form id="setCurrency" action="{$request_uri}" method="post">
<p>
<input type="hidden" name="id_currency" id="id_currency" value=""/>
<input type="hidden" name="SubmitCurrency" value="" />
{l s='Currency' mod='blockcurrencies'} : {$blockcurrencies_sign}
</p>
<ul id="first-currencies" class="currencies_ul">
{foreach from=$currencies key=k item=f_currency}
<li {if $cookie->id_currency == $f_currency.id_currency}class="selected"{/if}>
<a href="javascript:setCurrency({$f_currency.id_currency});" title="{$f_currency.name}" rel="nofollow">{$f_currency.sign}</a>
</li>
{/foreach}
</ul>
</form>
</div>
<!-- /Block currencies module -->
 
 
How can I make the needed changes in the code?
 
I have 4 curencies in the drop-down.
 
they are displayed as follows:
 
1. USD
2. EUR
3. YEN
4. GBP
 
I would like to make them as follows:
 
1. YEN
2. EUR
3. USD
4. GBP
 
 
Thanks for any help.
Edited by Franklabre (see edit history)
Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...