Pages

Wednesday, 31 December 2014

Magento:: checkout as guest enable/disable

By default, in Magento guests can shop without creating a customer account on your site. If you want to, you can disable guest checkout and allow only registered users to purchase products from your store. You can do this from the admin panel of your Magento.

After you log in go to System menu>Configuration>Checkout button in the Sales section on the left>Checkout Options panel on the right. After you expand the Checkout Options panel you'll see a drop-down menu Allow Guest Checkout; just set it to No. Once you do that a drop-down menu will appear under it labeled Require Customer To Be Logged in To Checkout; set it to Yes and click on the Save Config button in the upper right corner.

Tuesday, 30 December 2014

Magento:: How to remove all catalog products

Reset all product tables. Beware, below script will delete ALL your product data so do it carefully.


To remove all product go to the database and run the following query
SET FOREIGN_KEY_CHECKS = 0;

TRUNCATE TABLE `catalog_product_bundle_option`;
TRUNCATE TABLE `catalog_product_bundle_option_value`;
TRUNCATE TABLE `catalog_product_bundle_selection`;
TRUNCATE TABLE `catalog_product_entity_datetime`;
TRUNCATE TABLE `catalog_product_entity_decimal`;
TRUNCATE TABLE `catalog_product_entity_gallery`;
TRUNCATE TABLE `catalog_product_entity_int`;
TRUNCATE TABLE `catalog_product_entity_media_gallery`;
TRUNCATE TABLE `catalog_product_entity_media_gallery_value`;
TRUNCATE TABLE `catalog_product_entity_text`;
TRUNCATE TABLE `catalog_product_entity_tier_price`;
TRUNCATE TABLE `catalog_product_entity_varchar`;
TRUNCATE TABLE `catalog_product_link`;
TRUNCATE TABLE `catalog_product_link_attribute`;
TRUNCATE TABLE `catalog_product_link_attribute_decimal`;
TRUNCATE TABLE `catalog_product_link_attribute_int`;
TRUNCATE TABLE `catalog_product_link_attribute_varchar`;
TRUNCATE TABLE `catalog_product_link_type`;
TRUNCATE TABLE `catalog_product_option`;
TRUNCATE TABLE `catalog_product_option_price`;
TRUNCATE TABLE `catalog_product_option_title`;
TRUNCATE TABLE `catalog_product_option_type_price`;
TRUNCATE TABLE `catalog_product_option_type_title`;
TRUNCATE TABLE `catalog_product_option_type_value`;
TRUNCATE TABLE `catalog_product_super_attribute`;
TRUNCATE TABLE `catalog_product_super_attribute_label`;
TRUNCATE TABLE `catalog_product_super_attribute_pricing`;
TRUNCATE TABLE `catalog_product_super_link`;
TRUNCATE TABLE `catalog_product_enabled_index`;
TRUNCATE TABLE `catalog_product_website`;
TRUNCATE TABLE `catalog_product_entity`;

TRUNCATE TABLE `cataloginventory_stock`;
TRUNCATE TABLE `cataloginventory_stock_item`;
TRUNCATE TABLE `cataloginventory_stock_status`;
SET FOREIGN_KEY_CHECKS = 1;
INSERT  INTO `catalog_product_link_type`(`link_type_id`,`code`) VALUES (1,'relation'),(2,'bundle'),(3,'super'),(4,'up_sell'),(5,'cross_sell');
INSERT  INTO `catalog_product_link_attribute`(`product_link_attribute_id`,`link_type_id`,`product_link_attribute_code`,`data_type`) VALUES (1,2,'qty','decimal'),(2,1,'position','int'),(3,4,'position','int'),(4,5,'position','int'),(6,1,'qty','decimal'),(7,3,'position','int'),(8,3,'qty','decimal');
INSERT  INTO `cataloginventory_stock`(`stock_id`,`stock_name`) VALUES (1,'Default');
Note: Then you may require re-indexing all your indexes after running above query.
for that go to System > Index Management > Reindex all.

Magento:: Difference between Mage::getSingleton() and Mage::getModel()

Mage::getSingleton()


Mage::getSingleton() will first check the same class instance is exits or not in memory. If the instance is created then it will return the same object from memory. So Mage::getSingleton() faster then Mage::getModel().
$product1 = Mage::getSingleton('catalog/product');
$product2 = Mage::getSingleton('catalog/product');
$product1 and $product2 both will share same memory of OS and return only one instance each time.

Mage::getgetModel()


Mage::getModel() will create a new instance of an object each time even such object exists in configuration.
$product1 = Mage::getModel('catalog/product');
$product2 = Mage::getModel('catalog/product');
$product1 and $product2 both have different instant of same object and also occupy different memory .

Wednesday, 24 December 2014

Magento:: Get Current Url

<?php

     $GetUrl=Mage::helper('core/url')->getCurrentUrl();
     echo "Current Url".$GetUrl;
?>

Tuesday, 23 December 2014

Magento:: Get all Cms Pages Link

<?php $collection = Mage::getModel('cms/page')->getCollection()->addStoreFilter(Mage::app()->getStore()->getId());?>

<?php  $collection->getSelect()
->where('is_active = 1'); ?>
<ul id="nav">
<?php foreach ($collection as $page): ?>
<?php $PageData = $page->getData(); ?>
<?php// print_r($PageData);?>
<?php if($PageData['identifier']!='no-route' && $PageData['identifier']!='enable-cookies' && $PageData['identifier']!='home2') { ?>
<li>
<a href="<?php echo $this->getUrl('').$PageData['identifier']?>"><span><?php echo $PageData['title'] ?></span></a>
</li>
<?php } ?>
<?php endforeach; ?>
</ul>

Monday, 22 December 2014

Magento:: Custom Login Logout With Email Address

1- For Login Logut
<?php if (! Mage::getSingleton('customer/session')->isLoggedIn()): ?>

   <a href="<?php echo Mage::helper('customer')->getLoginUrl(); ?>" title="Log In" class="login"><?php echo $this->__('Log In') ?></a>
<?php else: ?>
   <a href="<?php echo Mage::helper('customer')->getLogoutUrl(); ?>" title="Log Out" class="login"><?php echo $this->__('Log Out') ?></a>
    <?php endif; ?>
2- For Email Address.

<div class="email">
  <?php  $customer = Mage::getSingleton('customer/session')->getCustomer();
     $customerData = Mage::getModel('customer/customer')->load($customer->getId())->getData();
     $email = $customerData['email'];
     echo $email;
   ?>
</div>

Social Plugin-Facebook

1-Facebook like box
<div id="fb-root"></div>

<script>(function(d, s, id) {
  var js, fjs = d.getElementsByTagName(s)[0];
  if (d.getElementById(id)) return;
  js = d.createElement(s); js.id = id;
  js.src = "//connect.facebook.net/en_US/sdk.js#xfbml=1&version=v2.0";
  fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>
<div class="fb-like-box" data-href="https://www.facebook.com/FacebookDevelopers" data-colorscheme="light" data-show-faces="true" data-header="true" data-stream="false" data-show-border="true"></div>
2-Facebook follow button
top script+
<div class="fb-follow" data-href="https://www.facebook.com/zuck" data-colorscheme="light" data-layout="standard" data-show-faces="true"></div>
3-Facebook send message button
top script+
<div class="fb-send" data-href="https://developers.facebook.com/docs/plugins/" data-width="200" data-height="200" data-colorscheme="dark"></div>
4-Facebook share button
top script+
<div class="fb-share-button" data-href="https://developers.facebook.com/docs/plugins/" data-width="200"></div>
5- Facebook like share button
top script+
<div class="fb-like" data-href="https://developers.facebook.com/docs/plugins/" data-width="200" data-layout="standard" data-action="like" data-show-faces="true" data-share="true"></div>
6- Facebook comment box
top script+
<div class="fb-comments" data-href="http://example.com/comments" data-numposts="3" data-colorscheme="light"></div>

Tuesday, 16 December 2014

Magento:: How To call a static block inside phtml

A static block in phtml file of magento, sometimes we need to do this kind of functionallity. For instance whenever you want to add one banner image on right side of callout block.
<?php echo $this->getLayout()->createBlock('cms/block')->setBlockId('banner_image_block_id')->toHtml() ?>
banner_image_block_id is the identifier you have created with static block in magento

Magento:: Call .phtml file in cms page

{{block type="core/template" template="custompage/home.phtml"}}
The custompage is a custom folder inside tamplate directory.
and the home.phtml is the file name.

Monday, 15 December 2014

Magento:: Popup search box on right sidebar

1-Copy the form.mini.phtml make some changes and create a new file form.mini_popup.phtml as follow:
<div class="search">

<form id="search_mini_form_sidebar" action="<?php echo $catalogSearchHelper->getResultUrl() ?>" method="get">

<div class="form-search_sidebar">

<input id="search_sidebar" type="text" name="<?php echo $catalogSearchHelper->getQueryParamName() ?>" value="<?php echo $catalogSearchHelper->getEscapedQueryText() ?>" class="input-text search_sidebar" maxlength="<?php echo $catalogSearchHelper->getMaxQueryLength();?>" />

<button type="submit" title="<?php echo $this->__('Search') ?>" class="button srch_btn"><span><span><i class="fa fa-search_sidebar"></i></span></span></button>

<i id="searchRemove" title="Close" class="fa fa-times"></i>

<div id="search_autocomplete_sidebar" class="search-autocomplete"></div>

<script type="text/javascript">

//<![CDATA[

var searchForm = new Varien.searchForm('search_mini_form_sidebar', 'search', '<?php echo $this->__('Search entire store here') ?>');

searchForm.initAutocomplete('<?php echo $catalogSearchHelper->getSuggestUrl() ?>', 'search_autocomplete_sidebar');

//]]>

</script>

</div>

</form>

</div>

<script type="text/javascript">

jQuery(window).load(function(){

jQuery(function() {

jQuery('.popup-tool .search').hover(function(){

jQuery('.popup-tool #search_sidebar').animate({

width : '800px'

}, 300 );

jQuery('.popup-tool #search_sidebar').animate({

'marginLeft' : "-=285px" //moves left

});

}, function() {

jQuery('.popup-tool #search_sidebar').animate({width:'580px'}, 300);

jQuery('.popup-tool #search_sidebar').animate({

'marginLeft' : "+=285px" //moves left

});

});

});

});

</script>
2-write down following code in catalogsearch.xml
<block type="core/template" name="top.search_sidebar" as="Search_sidebar" template="catalogsearch/form.mini_popup.phtml"/>
3-call it on header.phtml as follow
getChildHtml('Search_sidebar')?>

Magento:: Minicart on right sidebar


1- First Create a copy of orignal minicart as follow inside the same folder and rename or change the classes
<?php if ($this->getIsNeedToDisplaySideBar()):?>

<div class="sidebar_cart">

<?php

$cart_text='Cart';    

$_cartQty = $this->getSummaryCount() ?>

<div class="block-content_pan">

<div class="summary">

<span class="f-left cart-icon"><i class="fa fa-shopping-cart"></i></span>

<h2 class="classy f-left"><span class="my-cart"><?php echo $this->__('My Cart')?></span>

<?php /*<?php if ($_cartQty==0): ?>

<?php echo $this->__('<a href="%s">0</a><span class="Itext"> %s</span>', $this->getUrl('checkout/cart'), $this->__('item')) ?>

<?php endif ?>

<?php if ($_cartQty>0): ?>

<?php if ($_cartQty==1): ?>

<?php echo $this->__('<a href="%s">1</a><span class="Itext"> %s</span>', $this->getUrl('checkout/cart'), $this->__('item')) ?>

<?php else: ?>

<?php echo $this->__('<a href="%s">%s</a><span class="Itext"> %s</span>', $this->getUrl('checkout/cart'), $_cartQty, $this->__('items')) ?>

<?php endif ?>

<?php endif ?>

*/ ?>

<?php

$count = $this->helper('checkout/cart')->getSummaryCount();  //get total items in cart



if($count==0)

{

echo $this->__('<span class="Itext">0 item</span>',$count)  ;

}

if($count==1)

{

echo $this->__('<span class="Itext">1 item</span>',$count);

}

if($count>1)

{

echo $this->__('<span class="Itext">%s items</span>',$count);

}

?>

</h2>

<!--<em class="bag f-right"><i class="fa fa-angle-down"></i></em>-->

</div>



<div class="remain_cart" id="sidecart" style="display: none;">

<div class="sidecartInner">

<?php if($_cartQty && $this->isPossibleOnepageCheckout()): ?>



<?php endif ?>

<?php $_items = $this->getRecentItems() ?>

<?php if(count($_items)): ?>

<div class="shopping-bag f-block">

<?php if ($_cartQty==1): ?>    

<p class="empty f-left"><?php echo $this->__('Shopping Bag (1 items)') ?></p>

<?php else:?>

<p class="empty f-left"><?php echo $this->__('Shopping Bag (%s items)',$_cartQty) ?></p>

<?php endif?>

<p class="subtotal f-right">

<?php if ($this->canApplyMsrp()): ?>

<span class="map-cart-sidebar-total"><?php echo $this->__('ORDER TOTAL WILL BE DISPLAYED BEFORE YOU SUBMIT THE ORDER');?></span>

<?php else: ?>

<span class="label"><?php echo $this->__('Total:') ?></span> <?php echo Mage::helper('checkout')->formatPrice($this->getSubtotal()) ?>

<?php if ($_subtotalInclTax = $this->getSubtotalInclTax()): ?>

<br />(<?php echo Mage::helper('checkout')->formatPrice($_subtotalInclTax) ?> <?php echo Mage::helper('tax')->getIncExcText(true) ?>)

<?php endif; ?>

<?php endif; ?>

</p>

</div>

<ol id="cart-sidebar" class="mini-products-list">

<?php foreach($_items as $_item): ?>

<?php echo $this->getItemHtml($_item) ?>

<?php endforeach; ?>

</ol>

<script type="text/javascript">decorateList('cart-sidebar', 'none-recursive')</script>

<div class="actions_checkout">

<?php echo $this->getChildHtml('extra_actions') ?>

<button type="button" title="<?php echo $this->__('View Cart') ?>" class="button" onclick="setLocation('<?php echo $this->getUrl('checkout/cart')?>')"><span><span><?php echo $this->__('View Cart') ?></span></span></button>

<button type="button" title="<?php echo $this->__('Checkout') ?>" class="button" onclick="setLocation('<?php echo $this->getCheckoutUrl() ?>')"><span><span><?php echo $this->__('Checkout') ?></span></span></button>

</div>

<?php else: ?>

<div class="shopping-bag f-block"><p class="empty"><?php echo $this->__('You have no items in your shopping cart.') ?></p></div>

<?php endif ?>

</div>

</div>

</div>

</div>

<?php endif;?>

<script type="text/javascript">

jQuery(document).ready(function() {

jQuery(function() {

jQuery(".sidebar_cart").hover(function() {

jQuery(this).addClass('active');

jQuery("#sidecart").stop(true, true).delay(300).slideDown(200, "easeInSine");

},  

function() {

jQuery("#sidecart").stop(true, true).delay(300).fadeOut(100, "easeInCubic");

});



});

});

</script>
2- open the checkout.xml and copy the following block
<block type="checkout/cart_sidebar" name="cart_header" template="checkout/cart/sidebar_header.phtml" after="-">

<action method="addItemRender">

<type>simple</type>

<block>checkout/cart_item_renderer</block>

<template>checkout/cart/sidebar/default.phtml</template>

</action>

<action method="addItemRender">

<type>grouped</type>

<block>checkout/cart_item_renderer_grouped</block>

<template>checkout/cart/sidebar/default.phtml</template>

</action>

<action method="addItemRender">

<type>configurable</type>

<block>checkout/cart_item_renderer_configurable</block>

<template>checkout/cart/sidebar/default.phtml</template>

</action>

<block type="core/text_list" name="cart_sidebar.extra_actions" as="extra_actions" translate="label" module="checkout">

<label>Shopping Cart Sidebar Extra Actions</label>

</block>

</block>
3-Make the following cahanges as follow: and paste it in page.xml inside the block as follow:
<block type="page/html_header" name="header" as="header">

<!--            custom code for minicart                    -->

<block type="checkout/cart_sidebar" name="cart_header" template="checkout/cart/sidebar_cart.phtml" as="sidecart">

<action method="addItemRender">

<type>simple</type>

<block>checkout/cart_item_renderer</block>

<template>checkout/cart/sidebar/default.phtml</template>

</action>

<action method="addItemRender">

<type>grouped</type>

<block>checkout/cart_item_renderer_grouped</block>

<template>checkout/cart/sidebar/default.phtml</template>

</action>

<action method="addItemRender">

<type>configurable</type>

<block>checkout/cart_item_renderer_configurable</block>

<template>checkout/cart/sidebar/default.phtml</template>

</action>

<block type="core/text_list" name="cart_sidebar.extra_actions" as="extra_actions" translate="label" module="checkout">

<label>Shopping Cart Sidebar Extra Actions</label>

</block>

</block>

<!--            custom code for minicart end -->
4-After that call it in header.phtml as follow:
<?php echo $this->getChildHtml('sidecart'); ?>
An example screen of look::

Magento:: Insert a class in foreach loop for every 5th li element

1- Take a variable and assign to 0. like
<?php $counter=0; ?>
2- And give the condition in the li tag as follows.
<li class="product <?php if($counter%5==4): echo "last";  endif;?>"> // for fifth element

Tuesday, 9 December 2014

Magento: How to get product stock quantity & other stock information?

Here is a quick code to get any productâ��s stock information like quantity (qty), minimum quantity (min_qty), stock availability (is_in_stock), minimum and maximum sale quantity (min_sale_qty and max_sale_qty), etc.

First load the product. Product can be loaded in different ways. Here are the two different ways to load any product in Magento:-

1. Load product by product ID
$id = 52;

$_product = Mage::getModel('catalog/product')->load($id);
2. Load product by SKU
$sku = "microsoftnatural";

$_product = Mage::getModel('catalog/product')->loadByAttribute('sku', $sku);
Now, get stock information for the loaded product.
$stock = Mage::getModel('cataloginventory/stock_item')->loadByProduct($_product);
You can check stock data in this way:-
echo "
"; print_r($stock->getData()); echo "
";
Or, you can print individually like this:-
echo $stock->getQty();
echo $stock->getMinQty();
echo $stock->getMinSaleQty();

Magento:: Quantity Box in the Category Products Listing Page

Your Magento product ordering might seem a long process to some business owners, so we thought of making it simple, so that users can directly enter the quantity in the products listing area and click on ADD TO CART and checkout.

So, here is how you can do that.

Goto /app/design/frontend/default/your-theme/template/catalog/product/list.phtml

Open the file on a code editor and find this line,
<button type="button" title="<?php echo $this->__('Add to Cart') ?>" class="button btn-cart" onclick="setLocation('<?php echo $this->getAddToCartUrl($_product) ?>')"><span><span><?php echo $this->__('Add to Cart') ?></span></span></button>
Just replace it with
<form action="<?php echo $this->getAddToCartUrl($_product) ?>" method="post" id="product_addtocart_form_<?php echo $_product->getId()?>"<?php if($_product->getOptions()): ?> enctype="multipart/form-data"<?php endif; ?>>

  <?php if(!$_product->isGrouped()): ?>

  <label for="qty"><?php echo $this->__('Qty') ?>:</label>

  <input type="text" name="qty" id="qty" maxlength="12" value="<?php echo ($this->getMinimalQty($_product)?$this->getMinimalQty($_product):1) ?>" />

  <?php endif; ?>

  <button type="button" class="button btn-cart" onClick="this.form.submit()"><span><span><span><?php echo $this->__('Add to Cart') ?></span></span></span></button>

</form>

Monday, 8 December 2014

Remove Trailing Slash From Magento URLs – Duplicate Content Issue

Due to SEO reasons, a common problem that Magento has is that it indexes two URLs of the same page which causes issues with duplicate content when it comes to Google crawling. For example it will index both of these URLs.
http://www.magentosite.com/category.html/
and
http://www.magentosite.com/category.html
Ideally, we would like to stop Magento adding trailing slashes to the end of the URLs and then redirect it to the page without the trailing slash, and here’s how.

Lets begin

To start with we need to edit the getURL() method to stop it generating URLs with trailing slashes, so copy the following file from:
app/code/core/Mage/Core/Block/Abstract.php 
To
app/code/local/Mage/Core/Block/Abstract.php
Now open Abstract.php and find the following line of code:
return $this->_getUrlModel()->getUrl($route, $params);
Replace that line with the following:
$return_url = $this->_getUrlModel()->getUrl($route, $params);

if ($return_url != $this->getBaseUrl() && substr($return_url, -1) == '/' && !Mage::getSingleton('admin/session')->isLoggedIn()):

    return substr($return_url, 0, -1);

else:

    return $return_url;

endif;
Now copy the file app/code/core/Mage/Core/Model/Url.php
to
app/code/local/Mage/Core/Model/Url.php.
Once you’ve done that open it and find the following code:
if ($noSid !== true) {

    $this->_prepareSessionUrl($url);

}
Change ($noSid !== true) to ($noSid == false)

Edit your .HTACCESS file

Find the following line of code:
RewriteRule .* – [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
Add the following immediately underneath it:
RewriteCond %{request_method} ^GET$
RewriteCond %{REQUEST_URI} !^/downloader.*$
RewriteCond %{REQUEST_URI} ^(.+)/$
RewriteRule ^(.+)$ %1 [L,R=301]

All done!

 

Magento How to remove index.php from Any URLs in Magento

  1. Go to Magento Dashboard.
  2. Under System->Configuration.
  3. In left menu section under GENERAL tab select web.
  4. under web section open Search Engines Optimization.
  5. And Use Web Server Rewrites option to yes
Example::

Magento:: Non WWW to WWW

Open .htaccess file in Your Root Folder and copy and paste the following code.
#non www to www
RewriteCond %{HTTP_HOST} ^(?!www\.)(.+) [NC]
RewriteRule ^(.*) http://www.%1/$1 [R=301,NE,L]

Thursday, 4 December 2014

Magento:: Override Core Files – Simplest Way

There are several methods used for overriding magento core files, Here I’m going to explain one of simplest method to override core files in magento.

In this method to override magento core files, you don’t need to create your own module and write some xml in config.xml. Instead you can simply copy core file (which you want to override) and paste it in ‘app/code/local/Mage’ maintaining the same path of that php file. Then you can start editing this file, magento will read your file instead of the core file.
Below is an example :
=> If you would like to override ‘app/code/core/Mage/Catalog/Block/Product.php’ you need simply need it to put Product.php in ‘app/code/local/Mage/Catalog/Block/Product.php’. Doing only this will let magento read this file from local folder instead of core folder.

Reason for such behavior of reading from local folder to core folder is :
This process is called overriding Magento core functionality and is based on the fact that Magento sets its PHP include paths to first look in app/code/local/ then app/code/community/ and finally in app/code/core/. This has the effect that any files of the same name placed under the local or community name space will take precedence in loading, hence, we can override almost any core file in this way.

Demerits of Using Above Approach :

1. For one thing, we must override the complete core file and copy all the class functions. Once the overridden file is in place, this will be the file will be used instead of magento core file always. Given that most core classes contain several and many times a large number of methods it means that we are effectively overriding all those methods in our file.

2. This approach is not magento upgrade friendly, because of the above reasons.

3. This approach doesn’t work for controllers.

This approach is only useful while your testing/developing your module. Instead of writing a whole module, you can quickly override the core class see if things work well.
- See more at: http://excellencemagentoblog.com/blog/2014/03/03/override-magento-core-files-simplest-way/#sthash.6XNrTrxj.dpuf

Magento:: Product Collection with specific ids

<?php

$productIds = array(1,2);

$_productCollection = Mage::getModel('catalog/product')->getCollection();                              

$_productCollection->addAttributeToFilter('status', 1); //enabled

$_productCollection->addAttributeToFilter('visibility', 4); //catalog, search

$_productCollection->addAttributeToFilter('entity_id', array('in' => $productIds));

?>

<?php  

foreach ($_productCollection as $_product)

{

       $model = Mage::getModel('catalog/product');

       $product_id = $_product->getId();

       $_product = $model->load($product_id);

       //echo $_product->getPrice()."";

       //echo $_product->getName()."";

       $_image=Mage::getModel('catalog/product')->load($product_id);

       //echo Mage::helper('catalog/image')->init($_image, 'image')."";

       ?>

        <div class="feature-product">

            <div class="feature-product-price"><?php echo $_product->getPrice(); ?></div>

            <div class="feature-product-name"><?php echo $_product->getName(); ?></div>

            <div class="feature-product-image"><a href="<?php echo $_product->getProductUrl() ?>"><img src="<?php echo Mage::helper('catalog/image')->init($_image, 'image')->resize(200,200); ?>"></a></div>

        </div>

   <?php    

}                                       

?>

Tuesday, 2 December 2014

Magento Displaying CMS Static Block based on Category ID

1- open developer log to check the listing page layout.
2- In my case i found that it is 3columns.phtml
app/design/frontend/default/your-theme-name/template/page/3columns.phtml
Now in the Magento back end create a new Static Block. I will assume that you are already familiar with creating a Static Block in Magento so will not go into how to do this. If you are not familiar with creating Static Blocks please go to the Magento Knowledge Base
"http://www.magentocommerce.com/knowledge-base/entry/how-do-i-create-and-edit-static-blocks"
Decide where you would like your banner to be displayed in my case after the breadcrumbs then add this code.
<?php $category = Mage::getModel('catalog/layer')->getCurrentCategory();?>
<?php 
$myValidIds = array(3,6);
if(in_array($category->getId(), $myValidIds)):
?>
<?php
echo $this->getLayout()->createBlock('cms/block')->setBlockId('my-sidebar-1')->toHtml();
echo $this->getLayout()->createBlock('cms/block')->setBlockId('my-sidebar-2')->toHtml();
?>
<?php endif; ?>
Firstly you will need to change the numbers in the $myvalidid variable array. Here you will need to add the ID’s of the categories that you would like the Static Block to be visible in separated by comma. Your category ID’s can be found in the Magento back end.
Catalog > Manage Categories
Finally add the identifier for the Static Block you wish to be called into the page.
Save and upload the template file back into your Magento installation.

Friday, 28 November 2014

Magento Category image resize

1-Copy category folder from base/default/template/catalog/category and paste it in your theme before modification.
2-copy and paste the following code in your-theme/default/template/catalog/category/view.phtml
$_file_name = $_category->getThumbnail();             
$_media_dir = Mage::getBaseDir('media') . DS . 'catalog' . DS . 'category' . DS;
$cache_dir = $_media_dir . 'resize' . DS;

if (file_exists($cache_dir . $_file_name)) {
$_categoryImg =Mage::getBaseUrl('media') .  'catalog' . DS . 'category' . DS . 'resize' . DS . $_file_name;
} elseif (file_exists($_media_dir . $_file_name)) {
if (!is_dir($cache_dir)) {
mkdir($cache_dir);
}

$_image = new Varien_Image($_media_dir . $_file_name);
$_image->constrainOnly(true);
$_image->keepAspectRatio(false);
$_image->keepFrame(false);
$_image->keepTransparency(true);
$_image->resize(500, 500); // change image height, width
$_image->save($cache_dir . $_file_name);
$_categoryImg = Mage::getBaseUrl('media') . 'catalog' . DS . 'category' . DS . 'resize' . DS . $_file_name;
}
//echo  $_categoryImg ; // display resize category thumbnail imagename

Thursday, 27 November 2014

Magento Remove all Customers with Reset Id

Run Below Query in your database.please make a backup your db
SET FOREIGN_KEY_CHECKS=0;
-- reset customers
TRUNCATE customer_address_entity;
TRUNCATE customer_address_entity_datetime;
TRUNCATE customer_address_entity_decimal;
TRUNCATE customer_address_entity_int;
TRUNCATE customer_address_entity_text;
TRUNCATE customer_address_entity_varchar;
TRUNCATE customer_entity;
TRUNCATE customer_entity_datetime;
TRUNCATE customer_entity_decimal;
TRUNCATE customer_entity_int;
TRUNCATE customer_entity_text;
TRUNCATE customer_entity_varchar;
TRUNCATE log_customer;
TRUNCATE log_visitor;
TRUNCATE log_visitor_info;

ALTER TABLE customer_address_entity AUTO_INCREMENT=1;
ALTER TABLE customer_address_entity_datetime AUTO_INCREMENT=1;
ALTER TABLE customer_address_entity_decimal AUTO_INCREMENT=1;
ALTER TABLE customer_address_entity_int AUTO_INCREMENT=1;
ALTER TABLE customer_address_entity_text AUTO_INCREMENT=1;
ALTER TABLE customer_address_entity_varchar AUTO_INCREMENT=1;
ALTER TABLE customer_entity AUTO_INCREMENT=1;
ALTER TABLE customer_entity_datetime AUTO_INCREMENT=1;
ALTER TABLE customer_entity_decimal AUTO_INCREMENT=1;
ALTER TABLE customer_entity_int AUTO_INCREMENT=1;
ALTER TABLE customer_entity_text AUTO_INCREMENT=1;
ALTER TABLE customer_entity_varchar AUTO_INCREMENT=1;
ALTER TABLE log_customer AUTO_INCREMENT=1;
ALTER TABLE log_visitor AUTO_INCREMENT=1;
ALTER TABLE log_visitor_info AUTO_INCREMENT=1;
SET FOREIGN_KEY_CHECKS=1;

Tuesday, 25 November 2014

Magento add custom field in newsletter module.

Step 1 : Open file: root/app/design/frontend/your-package-name/your-theme/template/newsletter/subscribe.phtml

Add input field for ‘Name’ before ‘Email’ Field : 
 

Step 2 : Open file: root/app/code/core/Mage/Newsletter/controllers/SubscriberController.php

A. Search:
 $status = Mage::getModel('newsletter/subscriber')->subscribe($email);
Replace with:
 if ($this->getRequest()->getPost('subscriber_name'))
{
$subscriber = Mage::getModel('newsletter/subscriber')->loadByEmail($email);
$subscriber_name     = (string) $this->getRequest()->getPost('subscriber_name');
$subscriber->setsubscriber_name($subscriber_name);
}
$status = Mage::getModel('newsletter/subscriber')->subscribe($email,$subscriber_name);
Step 3 : Open file : root/app/code/core/Mage/Newsletter/Model/Subscriber.php

A. Search:
 public function subscribe($email)
Replace with:
 public function subscribe($email,$subscriber_name=null)
B. Search:
 $this->setSubscriberEmail($email);
Add after it:
 $this->setsubscriber_name($subscriber_name);
C. Search:
 public function setEmail($value)
{
return $this->setSubscriberEmail($value);
}
Add after it:
 public function setsubscriber_name($value)
{
return $this->setSubscriberName($value);
}
Step 4 : Open file : root/app/code/core/Mage/Adminhtml/Block/Newsletter/Subscriber/Grid.php
A. Search:
 $this->addColumn('email', array(
'header'    => Mage::helper('newsletter')->__('Email'),
'index'     => 'subscriber_email'
));
Add before it:
 $this->addColumn('subscriber_name', array(
'header'    => Mage::helper('newsletter')->__('Subscriber Name'),
'index'     => 'subscriber_name',
'default'   =>    '----'
));
Step 5 : Open your database.
 Create a field ‘subscriber_name’ in table “Newsletter Subscriber”.
Step 6 : Clear the caches ............ and reindex

Wednesday, 19 November 2014

Magento change the newsletter validation message

1- In your root folder\js\prototype\validation.js

2-Open the above file and find it (validate-email) in magento 1.9 near line 526 change it according to your requirement.

Wednesday, 12 November 2014

Magento To get the total product under the particular category(product count)

<?php
    $prodCollection = Mage::getResourceModel('catalog/product_collection')->addCategoryFilter($child);
    
    echo $prodCollection->count(); ?>

Magento subcategory from a particular category

<?php
    $_categoryModel = new Mage_Catalog_Model_Category();
    
    $_subCategoryList = $_categoryModel->load(3)->getChildrenCategories();
    
    foreach ($_subCategoryList as $category)
    {
        $cat=$_categoryModel->load($category->getId());
?>
        <li><div><img src="<?php echo Mage::getBaseUrl('media').'catalog/category/'.$cat->getImage()?>"/><a href="#"><?php echo $cat->getName()?></a></div></li>
<?php
        print_r($category);
    }
?>

Magento subcategory from the parent category

<?php
        $allCats = Mage::getModel('catalog/category')->getCollection()->addAttributeToSelect('*');
        
        foreach($allCats as $category)
        {
            if($category->getParentId() ==  Mage::app()->getStore()->getRootCategoryId() && $category->getIsActive()) // it'll check the root category
            {
                $subcats = $category->getChildren();
                $total_cat_array=explode(',',$subcats);
                foreach($total_cat_array as $subId)
                {
                    $child = Mage::getModel('catalog/category')->load($subId);
                    echo $child->getName();
                }
            }
        }      
  ?>

Magento Add to cart button on upsell products in product detail page

To add a Add to Cart button on upsell products in product detail pages, first open the upsell.phtml file located in app/design/frontend/your_package/your_theme/template/catalog/product/list/ that caused for these upsell products list.

Then add a new form with Add to Cart button & quantity input box inside the loop that generate upsell products.
<form action="<?php echo $this->getAddToCartUrl($_link) ?>" method="post" id="product_addtocart_form_<?php echo $_link->getId()?>"<?php if($_link->getOptions()): ?> enctype="multipart/form-data"<?php endif; ?>>

      <?php if(!$_link->isGrouped()): ?>
      <input type="text" name="qty" id="qty" maxlength="12" value="<?php echo ($this->getMinimalQty($_link)?$this->getMinimalQty($_link):20) ?>" />
      <label for="qty"><?php echo $this->__('Qty') ?>:</label>
      <?php endif; ?>
      <button type="button" onclick="this.form.submit()"><span><span><span><?php echo $this->__('Add to Cart') ?></span></span></span></button>

</form>

Magento Category listing under default category

<?php
$category = Mage::getModel('catalog/category')->getCategories(2);
    foreach($category as $_category){

    $currentCat = Mage::getModel('catalog/category')->load($_category->getId()); ?>
     <a href="<?php echo $currentCat->getUrl(); ?>"><span><?php echo $currentCat->getName()?></span></a><br/>
         <?php
        }
?>

Magento Left Category with jquery

<div class="left-category"><?php echo $this-> __('CATEGORIES')?></div>



<div class="maincategory">
<?php

    $_helper = Mage::helper('catalog/category'); 
    $_categories = $_helper->getStoreCategories(); 
    $currentCategory = Mage::registry('current_category') ;
    
    $rootCategoryId = Mage::app()->getStore()->getRootCategoryId();
    $rootCategory = Mage::getModel('catalog/category')->load($rootCategoryId);
    
    $childIds = explode(',',$rootCategory->getChildren());
    
    if (count($childIds) > 0):

?>
    
    <?php foreach($childIds as $_category):
    $_category = Mage::getModel('catalog/category')->load($_category);
    ?>
    

    
<div class="maincatdiv">
    <div class="catheader">
<span class="category_name">
<a href="<?php echo $_helper->getCategoryUrl($_category) ?>">
<?php echo $_category->getName() ?></a></span>
<?php if ($_category->getChildren() != ''){?><span class="caticon">+</span><?php } ?>
    </div>
    <div class="catcontent" style="display:none;"><?php
    
if ($_category->getChildren() != ''): 
    
$allsubchild = explode(',',$_category->getChildren());
    ?>
<ul>
<?php foreach($allsubchild as $_sub):
$_subcategory = Mage::getModel('catalog/category')->load($_sub);
?>
    <li>

<a href="<?php echo $_helper->getCategoryUrl($_subcategory) ?>">
<?php echo $_subcategory->getName() ?>
</a>
    </li>
<?php endforeach; ?>
</ul>
    <?php endif; ?></div>
</div>
    
    <?php endforeach; ?>
    
<?php endif; ?>
</div>

<script type="text/javascript">
jQuery(window).load(function(){
    jQuery('.caticon').click(function(){
var str = jQuery(this).closest('.maincatdiv').find('.catcontent').html().split(' ');
if(str[0] != '')
{
    if(jQuery(this).attr('class').indexOf('active') != -1)
    {
jQuery('.catcontent').slideUp();
jQuery('.caticon').removeClass('active');
jQuery('.caticon').html('+');
    }
    else{

jQuery('.catcontent').slideUp();
jQuery('.caticon').removeClass('active');
jQuery('.caticon').html('+');
jQuery(this).addClass('active');
jQuery(this).html('-');
jQuery(this).closest('.maincatdiv').find('.catcontent').slideDown();
    
    }
}

    });
})
</script> 

Magento product slider

1-place the jquery.bxslider folder in magento root js folder.
From: http://bxslider.com/examples/carousel-dynamic-number-slides
2-And place the following code. in your product collection page For jquery:
-----------------------------------------------------------------------------------------------------------------------
<link rel="stylesheet" href="<?php echo $this->getJsUrl()?>jquery.bxslider/jquery.bxslider.css" type="text/css" />
<script src="<?php echo $this->getJsUrl()?>jquery.bxslider/jquery.bxslider.js"></script>
<script type="text/javascript">
jQuery(window).load(function(){
jQuery('.bxslider').bxSlider({
pager:false,
minSlides: 3,
maxSlides: 5,
slideWidth: 240,
slideMargin:10
});
})
</script> 
--------------------------------------------------------------------------------------
For product collection:
<!-- for related product-->    
<div class="block block-related block-related-thumbnails">
<div class="also-bought"><h2 class="section-title padding-right "><?php echo $this->__('CUSTOMER WHO BOUGHT THIS ITEAM ALSO BOUGHT'); ?></h2></div>

<ul class="bxslider">    
<?php
$_productCollection = Mage::getModel('catalog/product')->getCollection();                              
$_productCollection->addAttributeToFilter('status', 1); //enabled
$_productCollection->addAttributeToFilter('visibility', 4); //catalog, search
$_productCollection->getSelect()->order(new Zend_Db_Expr('RAND()'));
$_productCollection->setOrder('name', 'ASC');
$_productCollection->getSelect()->limit(10);

?>
<?php  
foreach ($_productCollection as $_product)
{
$model = Mage::getModel('catalog/product');
$product_id = $_product->getId();
$_product = $model->load($product_id);
//echo $_product->getPrice()."<br>";
//echo $_product->getName()."<br>";
$_image=Mage::getModel('catalog/product')->load($product_id);
//echo Mage::helper('catalog/image')->init($_image, 'image')."<br>";
?>
<li><div class="also-bought-product">
<div class="also-bought-product-image"><a href="<?php echo $_product->getProductUrl() ?>"><img src="<?php echo Mage::helper('catalog/image')->init($_image, 'image')->resize(200,150); ?>"></a></div>
<div class="also-bought-product-name"><?php echo $_product->getName(); ?></div>
<?php $actualprice= Mage::helper('core')->currency($_product->getPrice(),true,false);//with currency symbol
$specialprice= Mage::helper('core')->currency($_product->getSpecialPrice(),true,false);//with currency symbol
$actual_Price = $_product->getPrice();
$special_price = Mage::getModel('catalog/product')->load($_product->getId())->getSpecialPrice(); // Get the Special Price without currency
$specialPriceFromDate = Mage::getModel('catalog/product')->load($_product->getId())->getSpecialFromDate();// Get the Special Price FROM date
$specialPriceToDate = Mage::getModel('catalog/product')->load($_product->getId())->getSpecialToDate();// Get the Special Price TO date
$today =  time();// Get Current date ?>
<?php
if ($special_price): ?>
<div class="custom-product-div">
<?php
if ($special_price):
if($today >= strtotime( $specialPriceFromDate) && $today <= strtotime($specialPriceToDate) || $today >= strtotime( $specialPriceFromDate) && is_null($specialPriceToDate)): ?>
<div class="special-price"><?php echo $specialprice; ?></div>
<?php  
endif;
endif;?>        
<div class="actual-price"><?php echo $actualprice; ?></div>
<?php
if ($special_price):
if($today >= strtotime( $specialPriceFromDate) && $today <= strtotime($specialPriceToDate) || $today >= strtotime( $specialPriceFromDate) && is_null($specialPriceToDate)): ?>
<?php // Discount percents output start ?>
<?php if($special_price < $actual_Price ): ?>
<?php $_savePercent = 100 - round(($special_price / $actual_Price)*100); ?>
<p class="special-price yousave">
<span class="price"><?php echo $_savePercent; ?>% <span>OFF</span></span>
</p>
<?php endif; ?>
<?php // Discount percent output end ?>
<?php  
endif;
endif;?>
</div>
<?php else :?>
<div class="custom-product-div"><div class="actualprice"><?php echo $actualprice; ?></div></div>
<?php endif;?>
</div></li>
<?php    
}                                     
?>
</ul>
</div>

Social Plugin facebook like, twitter , pintrest, google+

<!-- facebook like button start -->
<iframe src="//www.facebook.com/plugins/like.php?href=<?php echo Mage::helper('core/url')->getCurrentUrl(); ?>&amp;width&amp;layout=button_count&amp;action=like&amp;show_faces=false&amp;share=false&amp;height=21&amp;appId=<?php //echo Mage::getStoreConfig('facebookfree/settings/appid'); ?>" scrolling="no" frameborder="0" style="border:none; overflow:hidden; height:21px;" allowTransparency="true"></iframe>
<!-- facebook like button end -->

<!-- twitter button script start-->
<script type="text/javascript">
window.twttr=(function(d,s,id){var t,js,fjs=d.getElementsByTagName(s)[0];if(d.getElementById(id)){return}js=d.createElement(s);js.id=id;js.src="https://platform.twitter.com/widgets.js";fjs.parentNode.insertBefore(js,fjs);return window.twttr||(t={_e:[],ready:function(f){t._e.push(f)}})}(document,"script","twitter-wjs"));
</script>
<!-- twitter button script end-->
<!-- twitter share button start -->
<a class="twitter-share-button" href="https://twitter.com/share" data-count="none">Tweet</a>
<!-- twitter share button end -->

<!-- google + start    -->
<span class="googleplus">
<a href="https://plus.google.com/share?url=<?php echo $_product->getProductUrl(); ?>" target="_blank" >
<img src="<?php echo $this->getSkinUrl(); ?>images/gplus.jpg" alt="Google+" title="Google+"/>
</a>
</span>
<!-- google + end    -->

<!-- pintrest start-->
<?php
$_pinlink['url'] = $_product->getProductUrl();                      
$_pinlink['media'] = $this->helper('catalog/image')->init($_product, 'image')->__toString() ;
$_pinlink['description'] = $_helper->productAttribute($_product, $_product->getName(), 'name') . " - " . strip_tags($_product->getDescription());                                                                                   
?>
<a href="http://pinterest.com/pin/create/button/?<?php echo http_build_query($_pinlink) ?>" class="pin-it-button" count-layout="horizontal"></a>                    
<script type="text/javascript" src="//assets.pinterest.com/js/pinit.js"></script>
<!-- pintrest end→

Magento Pincode varification to add to cart.

1- Take the html layout where you want to the html layout.
<div class="pincode">
<input type="text" name="pincode" id='pincode1'  placeholder="Enter pincode to check dilivery option">
<div id='pincode'></div>
<input class="verify-button" type='button' onclick="checkForm()" value='Verify'>
</div>

2- The jquery for validation.
<script type="text/javascript">
function checkForm()
{
    //fetching value from input field pincode  and storing it in a variable
    var pincode = document.getElementById("pincode1").value;
    //alert(pincode);
    //Check input Fields Should not be blanks.
    if (pincode == '' )  
    {
        jQuery('#pincode').html('<div style="color:red;">Enter The Pincode</div>');
    }
    else
    {
        jQuery.ajax({
            url: "<?php echo $this->getBaseUrl();?>ajax/pincode_verify.php",
            type: "POST",
            data:'pincode='+pincode,
            success: function(abc){
            //alert(abc);
                if(abc==1){
                    jQuery(".add-to-box").show();
                    jQuery('#pincode').html('<div style="color:green;">This pincod is available</div>');
                }
                else{
                    jQuery(".add-to-box").hide();
                    jQuery('#pincode').html('<div style="color:red;">This pincod is not available</div>');
    
                }  
            }
        });
    }
}
</script>

3- create a folder name ajax in magento root directory and the inside it the pincode_verify.php for validation.
<?php
require_once '../app/Mage.php';
Mage::app('default');

extract($_REQUEST);
$read = Mage::getSingleton( 'core/resource' )->getConnection( 'core_read' );
$available_pincodes = Mage::getSingleton( 'core/resource' )->getTableName( 'available_pincodes' );
$query = "SELECT * FROM " . $available_pincodes." WHERE pincode_value = '".$pincode."'" ;
$result = $read->fetchAll( $query );

if(count($result) > 0)
echo 1;
else
echo 0;
?>

Magento custom sql Query

$read = Mage::getSingleton( 'core/resource' )->getConnection( 'core_read' );
        $pincode = Mage::getSingleton( 'core/resource' )->getTableName( 'available_pincodes' );
        $query = "SELECT * FROM " . $pincode ;
        $result = $read->query( $query );
        while ( $row = $result->fetch() ) {
        echo 'Pincode ID: ' . $row['pincode_value'] . '<br>';
        }
        ?>

Magento product status (in stock/out of stock)

$stock = $product->getStockItem();
if ($stock->getIsInStock()) {
   echo "product is in stock";
} else {
   echo "product is not in stock";
}

Magento Class For Every 5th element

1- Take a variable and assign to 0. like
<?php $counter=0; ?>
2- And give the condition in the li tag as follows.
<li class="product <?php if($counter%5==4): echo "last";  endif;?>"> // for fifth element

Magento On sale product listing by category

1-Create a new CMS page with content set to…
{{block type="catalog/product_list" template="onsale/sale.phtml"}}

2- and a template for listing your products
 app/design/frontend/default/YOUR_THEME/template/inchoo/onsale/sale.phtml
<?php
$_productCollection = Mage::getModel('catalog/product')->getCollection();
$_productCollection->addAttributeToSelect(array(
                                   'image',
                                   'name',
                                   'short_description'
                   ))
                   ->addFieldToFilter('visibility', array(
                               Mage_Catalog_Model_Product_Visibility::VISIBILITY_BOTH,
                               Mage_Catalog_Model_Product_Visibility::VISIBILITY_IN_CATALOG
                   )) //showing just products visible in catalog or both search and catalog
                   ->addFinalPrice()
//                        ->addAttributeToSort('price', 'asc') //in case we would like to sort products by price
                   ->getSelect()
                   ->where('price_index.final_price < price_index.price')
//                        ->limit(30) //we can specify how many products we want to show on this page
//                        ->order(new Zend_Db_Expr('RAND()')) //in case we would like to sort products randomly
                   ;
 
Mage::getModel('review/review')->appendSummary($_productCollection);
 
$_helper = $this->helper('catalog/output');
?>
//
<?php if(!$_productCollection->count()): ?>
    <p class="note-msg"><?php echo $this->__('There are no products matching the selection.') ?></p>
<?php else: ?>
    <div class="category-products">
        <?php // List mode ?>
            <?php $_iterator = 0; ?>
            <ol class="products-list" id="products-list">
                <?php foreach ($_productCollection as $_product): ?>
                    <li class="item<?php if( ++$_iterator == sizeof($_productCollection) ): ?> last<?php endif; ?>">
                        <?php // Product Image ?>
                        <a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" class="product-image"><img src="<?php echo $_product->getImageUrl(); ?>" width="135" height="135" alt="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" /></a>
                        <?php // Product description ?>
                        <div class="product-shop">
                            <div class="f-fix">
                                <?php $_productNameStripped = $this->stripTags($_product->getName(), null, true); ?>
                                <h2 class="product-name"><a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $_productNameStripped; ?>"><?php echo $_helper->productAttribute($_product, $_product->getName() , 'name'); ?></a></h2>
                                <?php if($_product->getRatingSummary()): ?>
                                    <?php echo $this->getReviewsSummaryHtml($_product) ?>
                                <?php endif; ?>
                                <?php echo $this->getPriceHtml($_product, true) ?>
                                <?php if($_product->isSaleable()): ?>
                                    <p><button type="button" title="<?php echo $this->__('Add to Cart') ?>" class="button btn-cart" onclick="setLocation('<?php echo $this->getAddToCartUrl($_product) ?>')"><span><span><?php echo $this->__('Add to Cart') ?></span></span></button></p>
                                <?php else: ?>
                                    <p class="availability out-of-stock"><span><?php echo $this->__('Out of stock') ?></span></p>
                                <?php endif; ?>
                                <div class="desc std">
                                    <?php echo $_helper->productAttribute($_product, $_product->getShortDescription(), 'short_description') ?>
                                    <a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $_productNameStripped ?>" class="link-learn"><?php echo $this->__('Learn More') ?></a>
                                </div>
                                <ul class="add-to-links" style="margin:0; padding-left:0; list-style: none;">
                                    <?php if ($this->helper('wishlist')->isAllow()) : ?>
                                        <li><a href="<?php echo $this->helper('wishlist')->getAddUrl($_product) ?>" class="link-wishlist"><?php echo $this->__('Add to Wishlist') ?></a></li>
                                    <?php endif; ?>
                                    <?php if($_compareUrl=$this->getAddToCompareUrl($_product)): ?>
                                        <li><span class="separator">|</span> <a href="<?php echo $_compareUrl ?>" class="link-compare"><?php echo $this->__('Add to Compare') ?></a></li>
                                    <?php endif; ?>
                                </ul>
                            </div>
                        </div>
                    </li>
                <?php endforeach; ?>
            </ol>
            <script type="text/javascript">decorateList('products-list', 'none-recursive')</script>
    </div>
<?php endif; ?>

3-Create a Category(On Sale) and call the static block in the category. 
1- create category on sale.
2- inside category go to Display setting select display mode to static block only.
3-And select the on sale cms block you created.
 

Magento Get custom textarea attribute field if available

<?php if ($_product->getWhatsincluded()): ?>// what is included is custom textarea attribute.
  <?php echo $_helper->productAttribute($_product, $_product->getwhatsincluded(), 'whatsincluded') ?>
  <?php endif;?>

Magento Get Product Msrp if available.

<?php if ($_product->getMsrp()):  ?>
<div class="mrp"><span class="mrp-price"><?php echo $this->__('MRP'); ?>:</span><span class="mrsp-price"><?php echo $mrp; ?></span></div>
<?php endif; ?>

Monday, 10 November 2014

Magento Remove Decimals from product price


For this, you need to edit /app/code/core/Mage/Directory/Model/Currency.php

Note:- Do not change core functionality beside override the function in local folder
Find the following :- code
public function format($price, $options=array(), $includeContainer = true, $addBrackets = false)
    {
return $this->formatPrecision($price, 2, $options, $includeContainer, $addBrackets);
    }
change this code to:-
public function format($price, $options=array(), $includeContainer = true, $addBrackets = false)
    {
return $this->formatPrecision($price, 0, $options, $includeContainer, $addBrackets);
    }

Magento Sale icon if special price available

Open app/design/frontend/YourPackage/YourTheme/template/catalog/list.phtml Find (around line 96)
<a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" class="product-image">

<img src="<?php echo $this->helper('catalog/image')->init($_product, 'small_image')->resize(135); ?>" width="135" height="135" alt="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" />

</a>
change to
<a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" class="product-image">

<img src="<?php echo $this->helper('catalog/image')->init($_product, 'small_image')->resize(135); ?>" width="135" height="135" alt="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" />

<?php 

    // Get the Special Price

    $specialprice = Mage::getModel('catalog/product')->load($_product->getId())->getSpecialPrice(); 

    // Get the Special Price FROM date

    $specialPriceFromDate = Mage::getModel('catalog/product')->load($_product->getId())->getSpecialFromDate();

    // Get the Special Price TO date

    $specialPriceToDate = Mage::getModel('catalog/product')->load($_product->getId())->getSpecialToDate();

    // Get Current date

    $today =  time();

    if ($specialprice):

        if($today >= strtotime( $specialPriceFromDate) && $today <= strtotime($specialPriceToDate) || $today >= strtotime( $specialPriceFromDate) && is_null($specialPriceToDate)):

?>

        <img src="path/to/sale-icon.png" width="50" height="50" class="onsaleicon" />

<?php  

        endif;

    endif;

?>

</a>
Next open style.css (skin/frontend/YourPackage/YourTheme/css/style.css)Find
.products-grid .product-image { display:block; width:135px; height:135px; margin:0 0 10px; }
change to
.products-grid .product-image { display:block; width:135px; height:135px; margin:0 0 10px; position:relative;}
Below this add
.onsaleicon{position:absolute; top:0; right:0;}

Magento: How to get actual price and special price of a product?

Loading Product
$_productId = 52;
$_product = Mage::getModel('catalog/product')->load($_productId);
Get Actual Price
// without currency sign
$_actualPrice = $_product->getPrice();
// with currency sign
$_formattedActualPrice = Mage::helper('core')->currency($_product->getPrice(),true,false);
Get Special Price
// without currency sign
$_specialPrice = $_product->getFinalPrice();
// with currency sign
$_formattedSpecialPrice =Mage::helper('core')->currency($_product->getFinalPrice(),true,false);

Magento Product Discount percent in Magento

Open app/design/frontend/yourpackage/yourtheme/template/catalog/product/price.phtml Find:
<?php endif; /* if ($_finalPrice == $_price): */ ?>
Add above it: place this custom code
<?php // Discount percents output start ?>
    <?php if($_finalPrice < $_price): ?>
    <?php $_savePercent = 100 - round(($_finalPrice / $_price)*100); ?>
        <p class="special-price yousave">
            <span class="label"><?php echo $this->__('You Save:') ?></span>
            <span class="price">
                <?php echo $_savePercent; ?>%
            </span>
        </p>
    <?php endif; ?>
<?php // Discount percent output end ?>

Magento Product Collection all filter codes

Load Product Collection
$collection = Mage::getModel('catalog/product')->getCollection();
or
$collection = Mage::getResourceModel('catalog/product_collection');
Add Attributes To Collection The product model is an enormous data set, and the more attributes we include in the load the longer it will take. By default, Magento will only load the basic data found in the ‘catalog_product_entity’ table (ID, SKU, Entity Type ID etc…) Add All Product Attributes
$collection->getAttributeToSelect('*');
Add Individual Product Attributes
$collection->addAttributeToSelect('name', 'description', 'brand');
Add Specific Price Attributes
$collection->addMinimalPrice();
$collection->addFinalPrice();
$collection->addTaxPercents();
Add Category IDs to Products
$collection->addCategoryIds();
Add Tier Pricing Info
$collection->addTierPriceData();
Add Product URL Rewrites
$collection->addUrlRewrite();
Filter Collection Being an EAV entity type means that we have access to the wonderful ‘addAttributeToFilter()’ method in addition to the standard ‘addFieldToFilter()’, which can take a larger range of arguments. The following are basic conditional filters, like you’d use in a MySQL query: Is Equal To
$collection->addAttributeToFilter('status', array('eq' => 1));
Is Not Equal To
$collection->addAttributeToFilter('visibility', array('neq' => 1));
Greater Than
$collection->addAttributeToFilter('price', array('gt' => 3));
Less Than
$collection->addAttributeToFilter('price', array('lt' => 3));
Greater Than or Equal To
$collection->addAttributeToFilter('price', array('gteq' => 4));
Less Than or Equal To
$collection->addAttributeToFilter('price', array('lteq' => 4));
Contains – with % wildcards
$collection->addAttributeToFilter('sku', array('like' => 'DVD%'));
Does Not Contain – with % wildcards
$collection->addAttributeToFilter('sku', array('nlike' => 'ABC%'));
Not In Array
$collection->addAttributeToFilter('entity_id', array('nin' => array(1,2,12)));
Is NULL
$collection->addAttributeToFilter('description', 'null');
Is Not NULL
$collection->addAttributeToFilter('description', 'notnull');
Further Filtering There are also more general filters that can be applied: Filter by Product IDs
$collection->addIdFilter(array(4,5,6));
Filter by Current Store
$collection->addStoreFilter();
Filter by Current Website
$collection->addWebsiteFilter();
Filter by Category
$collection->setStoreId($id)->addCategoryFilter($category);
Sort Collection Again, as with MySQL you can sort your collection by a chosen attribute in either ascending or descending order. Order by Attribute Ascending
$collection->setOrder('price', 'ASC');
Order by Attribute Descending
$collection->setOrder('name', 'DESC');
Random Order
$collection->setOrder('rand()');
Limit Collection If you’re in a situation where you want your product collection, but want to limit the number of results to a certain amount you can use the ‘setPageSize()’ method, and simply pass in your limit.
$collection->setPageSize(10);
$collection->getSelect()->limit(15);
Randomly Collection
$_productCollection->getSelect()->order(new Zend_Db_Expr('RAND()'));
Count Results Always useful when checking if any results have been returned.
$collection->count();
Return Only Product IDs Sometimes you’ll just need to get product IDs from your collection, rather than the rest of the product data. By Using ‘getAllIds’ you will receive a nice little array of product IDs for you to do with as you wish!
$collection->getAllIds();
Debug Collection Want to know why your collection keeps returning results? Using the ‘getSelect()’ method on your collection you can print the MySQL query that is getting sent to the database.
$collection->getSelect();