Responsive Magento Theme - A new approach to ecommerce website

Responsive web design is a new approach of web designing in which website break down its whole layout in such a way that it looks nice and more readable on all mobile devices and all web browser of any resolutions. In the world of iPhone and iPad, mobile plays an important role for online product selling website. A recent survey on mobile usage shows that if store owner does not adopt new technologies of keeping their website mobile friendly, they will loose a giant segment of their product consumers.Almost 79%of smart phone users use their mobile for online shopping. they either prefer iPhone apps for purchasing their items of browse mobile friendly website for placing their order. so as a being a store owner, you have two choice to make your store mobile friendly. Either hire iPhone application developer from India and develop iPhone apps for your products or convert your current website into responsive.Compare to developing mobile apps for each technologies like iPhone, android, windows or blackberry, responsive web design is far better solutions. It will be more cheaper and device independent solutions compare to developing apps for each type of smartphone.As magento is a leading open source for ecommerce store, its easy to get developed responsive theme for your magento store. There are so many responsive magento theme designing company available which can helps you to convert your existing website into mobile compatible version. There are also many ready made free responsive magento theme and commercial theme are now available in market place with easy plug and play installation. There are so many advantage of using responsive design compare to traditional designYou can get advantage of your mobile user as your website looks more user friendly compare to desktop website on mobile device.Readability of your website on mobile device is better then non-responsive website.As responsive design adjust their layout as per mobile screen and web browser, it looks great in almost all type of smartphone. its a device independent solutions.In terms of search engine, Its a prefered solution of developing mobile compatible website as you do not have to maintain multiple urls for same product. It gives charming look and credits to your business when user find nice website on their mobile. Creative glance is leading magento theme designing company who has robust experience of developing responsive magento theme for your ecommerce store. hire php programmer for ongoing magento theme designing and customization work. 

Posted on: 9 July 2012 | 12:42 pm

Important tips about Magento Template Development and Magento web solutions

Creative glance technologies offers effective web solutions with expert web developers. You can get perfect web services and solutions like design, develop, integrate and maintain web applications that enable enterprises to solve complex and critical business problems.In a very short span of time, Creative glance technologies has the opportunity to work with a diverse range of industries and clients. Company implements modern web development approach to designs and developer a useful website. If you are looking for ecommerce solutions with Magento template development then you can find correct solutions related to your requirement from creative glance technologies.In the field of website development, many new open source tools are creating by expert web developer and companies and people use them through online. Magento theme customization and template design is new systems, which is used to build ecommerce website applications based on Magento platform. Magento programmers provide resource hiring facility to complete your Magento Integration including theme design, programming, payment gateway integration and customization of Magento ecommerce platform.Creative glance technologies believe in offering quality service and developing long lasting relationship with clients, at the end of the day, relationship and quality services are the backbone of any company. Company has team of experts website developers to get perfect solutions for their clients. Within the era of ecommerce development, Magento may bring about a whole lot inside a internet site simply by improving the rate associated with traffic. This open sources technologies helps to clients to understand internet portal systems for online services provider website .Being a strong free software, Magento has brought robust origins across the internet.Visit Creative Glance for details of magento template and theme development services.

Posted on: 10 January 2011 | 4:38 am

Why Magento website development is useful for Ecommerce websites?

Ecommerce website development is very popular and important part for any company, business that based on online services. Website developers use open source technology to customize website projects for clients. Mainly outsourcing magento development company in India implements Magento website development to develop ecommerce web projects.Magento is an open source technology, which is used to create ecommerce platform for businessperson. If you are providing online trading facilities for your customers, clients then you can use Magento templates to develop flexible website solutions for business.With the help of Magento you can develop your e-Commerce store and can display your services through internet. Magento is very much flexible over other components, which helps to build a good, customized easy to use and very demanding ecommerce store. Magento platform also gives flexible solutions to users to get information, tips from ecommerce platform. This platform helps you to manage product browsing, payments, and managing catalog.Magento website development add system that is more useful your ecommerce store. If you want to change your existing ecommerce store then with Magento theme you can easily get ecommerce customization solutions to add more services with your website/ecommerce stores.When you give any web development task to any website developer then you can get information about the special tips from web programmer to make user-friendly website and more attractive. Website with dynamic pages should be handling careful because sometimes the problem occurs about website development.You can also hire Magento programmer for getting a professional outputs from your ecommerce website. Magento experts provide modern web services and solutions based on web2.0 properties to your business.

Posted on: 1 January 2011 | 7:02 am

Special tips about Magento Customization and Magento Theme Development

This post is all about Magento customization and Magento theme development with website applications development. Today web services are growing very fast and many new programming language and framework used to create dynamic websites.Many business persons use ecommerce website to provide unique web solutions to their customers. People can buy or sell product online through ecommerce web site and get response through the website. Website developer use Magento software to develop ecommerce website.Magento is an open source web applications software used to develop ecommerce projects and shopping cart solution. Website programmers develop themes for the Magento ecommerce platform, which provide flexible web solutions to create new projects.If you want to develop ecommerce magento based website and want to boost your business returns, then it is mandatory to build up an e-commerce website. Magento e-Commerce is the new technology arrives for ecommerce development and shopping cart solution, and the latest technology available. Magento will help you to create online store, online shopping cart with Magento CMS and customization.Magento theme development used to get complete ecommerce solutions for online shopping cart web services. You can easily understand functionality of an Online Store with Magento development. The Magento Commerce Platform combines the flexibility of open-source technology with industry leading features to provide merchants unprecedented control over online store operations and get the online sales booming

Posted on: 22 December 2010 | 5:39 am

Hire PHP Programmer – Web Development – Website Design Company

PHP is one of the fastest growing web scripting languages on the Internet today, and for this reason this languages is globally used to develop website.Web Development in PHP is becoming increasingly popular in website development industry because of PHP is open source language. Open source technology is used to make CMS web development and e-commerce website solutions. PHP web programming is easily under-stable and easy to run on any OS platform.In this time, many business services are based on ecommerce system and they need to build a online sells management system and this systems can be easily developed in PHP. Magento, Joomla, Wordpress, OsCommerce etc. are most popular CMS platforms, which are totally based on PHP.If you have business, which is related to online services, then you need to hire PHP programmer to build your ecommerce website. In India many website design company provide web development services but you have to select perfect web Development Company that make accurate website for your business.PHP web development company in India offer several web applications services like web design, web development PSD conversion and search engine optimization services to help your business. Web Applications Development Company associated with dedicated PHP developer, web designer and SEO experts to perform unique web solutions according to clients’ requirement.Online selling web portal need well web applications systems, which makes flexible environment on internet for user. PHP has all major parameters, which are used to develop data driven web applications, and due to this reason, PHP is highly popular in the world. If you are going to make new ecommerce web applications they you can make it easily with PHP.

Posted on: 14 December 2010 | 10:59 pm

How to add new layout template for Magento

Many times we need to add new layout skeleton rather then 2colums-left, 2columns-right, 1column and 3columns. Here is the way how we can add more layout structures.You can make modification directly in app/code/core/Page/etc/config.xml but if you don’t want to touch core file, I recommend you to follow these steps:Create config.xml under app/code/local/Magestore/Page/etc<?xml version="1.0" encoding="utf-8"?><config><modules><Magestore_Page><version>0.1.0</version></Magestore_Page></modules><global><page><layouts><three_columns_cms module="page" translate="label"><label>3 columns for cms page</label><template>page/3columns-cms.phtml</template><layout_handle>page_three_columns_cms</layout_handle></three_columns_cms></layouts></page></global></config>Now, open app/etc/modules and create file Magestore_Page.xml<?xml version="1.0"?><config><modules><Magestore_Page><active>true</active><codePool>local</codePool></Magestore_Page></modules></config> You have to create a file named '3columns-cms.phtml' under app/design/frontend/[YOUR_PACKAGE]/[YOUR_THEME]/template/page.Now, log in your admin, go to Cms -> Manage pages, click Add new page. In Custom Design tab, you can find new layout you just created:

Posted on: 1 July 2010 | 9:57 am

Whats New in Magento

ImprovementsAdded ability to use static URLs for media in WYSIWYG or image browser. Added ability to enable parsing store, skin and media directives on catalog frontend.URL rewrites history: ability to auto-generate custom rewrite with redirect from old to new URL when changing product URL-keyAdded ability to exclude a category from navigation menuVarious improvements in system configuration UI. Introduced ability to make actual configuration structure to be independent on the system.xml structureAdded "Only X left" inventory featureImplemented Centinel functionality in iphone themeUpgraded TinyMCE to v.3.3.2Improved PayPal integration, includes:* Recurring payment profiles entity and purchasing of "subscription" products. In checkout they are treated as "nominal" items.* Billing agreements* "Pending Review" order state, "Pending Review" and "Suspected Fraud" order statuses and logic related with this. Triggers by PayPal IPR, FMF and Unilateral payments.* Functionality of transactions listing/searching and fetching from gateway* Fetching PayPal settlement reports via SFTP* Various improvements of PayPal integration on the frontend and admin UIAdded notice about creating offline creditmemo from order view page.Added getter for recurring payment methods in payment helper.Implemented abstract block ability to have arbitrary groups of child blocks and a method that returns such a group. Implemented a method that fetches data from child block by specified alias.Implemented ability to specify "sort_order" instead of "before" and "after" in the totals declaration. All nominal totals declaration utilize "sort_order"Added getter for specified object data by key in core/template block: method getObjectData()Defined payment methods grouping, implemented getter for payment method list (with option to group them). Added ability to render grouped options in the "select" grid filter.Moneybookers: utilized the payment methods grouping for all its methods; removed redundant "translate" attribute in the methods definition in config.Utilized payment methods grouping for PayPal peyment methods.Added more verbosity to PayPal NVP and IPN debuggingChangesSales module database structure changed from EAV into flat tablesProduct custom URL rewrites redirect to SEF URL, rather than to catalog/product/view/id/Reimplemented frontend top menu rendering logic (cross-browser and usability improvements)Reviewed logic of the sales reports: Orders, Tax, Invoiced, Shipping, Refunds, CouponsReimplemented bestsellers reportImplemented 3D Secure validation for Maestro International and JCB cardsChanged Shopping cart methods output (top + bottom): removed Moved the Payflow Pro payment method to PayPal moduleRefactored sales/service_quote model: instead of submit() method the submitAll() should be used. It can submit nominal items separately from the order. The methods for submitting nominal items and order separately - are available as well.Refactored onepage checkout model to use the new method sales/service_quote::submitAll(), added recurring profiles and billing agreements passing through the process until the success pageUtilized child blocks grouping to improve flexibility of rendering additional information in catalog/product/view template. The group is called "detailed_info"; any block from layout may insert itself to this group.Removed redundant wrappers hard-coded into some catalog templates. Template of parent block is responsible for wrapping.Refactored onepage checkout success block and template: simplified fetching related checkout information, added ability to render billing agreement and recurring profiles that might be created with the payment placement.

Posted on: 20 June 2010 | 1:29 am

Google Analytics code bug in Magento

We just released a site based on the latest community release of Magento All went well until the point when we enabled Google Analytics for the site.Firebug was showing an error: _gaq is not definedSo there was a variable issue with the extra javascript analytics code inserted by Magento. A quick google search revealed that this issue was already reported in the Magento bug tracker and a solution/workaround provided.The problem is in file: app/code/core/Mage/GoogleAnalytics/Block/Ga.php around line 170. Adding: var _gaq = _gaq || []; fixes the issue.Easy fix, however, this sort of bug is something that shouldn’t have slipped through testing and quality control.

Posted on: 5 June 2010 | 4:26 am

CSS In Magento

The first thing that you need to do with Magento is famililarise yourself with the CSS files, as you will be using these an awful lot. There are 7 different files in total, so you need to know what is located where and the things you will need to edit.Most of the editing is done in the "boxes.css" file. All of the css files are located in ".../skin/frontend/YOUR_THEME/YOUR_THEME/css". If you have not changed the name of the theme or created a new one then it will be called "default" (".../skin/frontend/default/default/css") If you wish to change the colours or settings of any forms, tables, menus, buttons, error messages; then this is the place to be.

Posted on: 29 May 2010 | 1:40 am

Ten Tips for Keeping your Magento Store Secure

Are you worried about the security of your Magento store? Magento has a number of built-in security features aimed at keeping you safe, but there are some steps you can take to make your site even more secure. Follow this ten-point security policy to protect your site from hackers and security breaches.1. Choose a secure passwordWhen you're choosing your Magento site's administrator passwords, choose wisely. Depending on your configuration and permissions, this password may give access to customer information and credit card data. This is probably review for most readers, but here are some guidelines for creating a really secure password:Bigger is better. Use at least 10 characters.Mix upper and lower case, punctuation, and numbers.Making your password phonetic can make it easier to remember and type quickly.2. Require HTTPS/SSL for all pages with loginsEach time you send data over an unencrypted connection you run a risk of this data being intercepted by an unwanted third-party. Login credentials are no exception. To minimize the risk of your username and password landing in unscrupulous hands, always send it over a secure connection. By always sending your login information over an encrypted connection, hackers are limited to expensive and extremely difficult brute-force attacks.How to require HTTPS/SLL in MagentoIn Magento you can require secure logins by selecting "yes" for both "Use Secure URLs in Frontend" and "Use Secure URLs in Admin" by going to the "Secure" section of the "Web" tab in the system configuration. In order to access the system configuration, go to the "System" menu and select "Configuration."Set "Use Secure URLs" to "yes" for both the frontend and admin3. Don't use your Magento password for anything elseDo not use your Magento password with any other web services (such as email) or any other sites (such as Twitter, Facebook, Flickr, etc.). Third-party sites may not require or even support HTTPS/SSL to login, breaking rule number two. In the event that a third-party website is hacked, your password may be vulnerable.4. Use a custom admin pathBy default, you access your Magento admin panel by going to Having the path to your admin panel path easily guessable means that someone or something (i.e. a password-guessing robot) can snoop around and try to guess your password. By having your admin path be a secret code word instead of the default /admin, you can prevent users from guessing your password or using it if they do somehow get a hold of your password.How NOT to change your Magento admin pathTucked in the "admin" section of the system configuration, the "Admin Base URL" setting looks like it offers the ability to set a custom admin URL and choose whether to use that custom URL or not. But BEWARE: this setting will break Magento by preventing you from accessing the admin panel (I've tested this and found this to be true as of Magento and earlier).BEWARE: Do not use the admin base URL settings; it will break your site.How to change your Magento admin pathAlthough the setting does not work, there is an easy way to change your Magento admin path.Locate /app/etc/local.xmlFind <![CDATA[admin]]> and replace 'admin' with the path you would like to useSo if your local.xml file says <![CDATA[drawbridge]]>, your admin path will be /drawbridge.5. Close email loopholesMagento has a really convenient feature that allows administrators to reset their password if forgotten. In order to reset your password, you need to know the email account associated with the account. Then you need access to that email account to retrieve the new password. First, choose an email address that is not publicly known. Second, make sure the password for your email account is secure. Third, make sure that if your email account has a security question that allows you to reset your password, you choose a question and answer that is so obscure that it would be impossible to guess.6. Use secure FTPGuessing or intercepting FTP passwords is probably one of the number one ways sites get "hacked." In order to prevent unauthorized access to your sites FTP, use secure passwords and use SFTP (SSH File Transfer Protocol) or FTP-SSL (Explicit AUTH TLS). With SFTP, you can use Public Key Authentication to increase security even more by requiring a private key file and an optional de-encryption password to authenticate the FTP access.7. Limit unsecured FTP accessIf you do have to connect through regular (non-secure) FTP for some accounts (i.e. to upload photos), limit access for these accounts to a narrow set of directories. You can then use .htaccess and httpd.conf files to prevent scripts from running in these directories that can change other files and directories on the server that should not not be accessible through that FTP account.If you have access to the httpd.conf file on your server, this is the best method to preventing scripts from running in a specific directory. Place this code in your httpd.conf file:<directory path-to-directory-you-want-to-restrict=""> AddHandler cgi-script .php .pl .py .jsp .asp .htm .shtml .sh .cgi Options -ExecCGI</directory> If you don't have access to httpd.conf, you'll have to use.htaccess. Include the following code in the .htaccess file of the directory you want to restrict:AddHandler cgi-script .php .pl .py .jsp .asp .htm .shtml .sh .cgiOptions -ExecCGIBecause .htaccess does not support the tags, the .htaccess file must be placed in the directory you want to effect. Because of this, you need to set the permissions of the .htaccess file to 444 (read-only) to prevent modifications to the .htaccess file. You may also want to chown the file so the permissions cannot be changed. This method isn't fool-proof, but it's a good start to preventing naughty scripts from wreaking havoc. Important: placing this code in a directory's .htaccess file will prevent scripts from running in that directory and all sub-directories.8. Don't save passwords on your computer Most modern computers and browsers offer the option to save passwords as a convenience so you don't have to enter your password every time. This is great most of the time, but can be a security problem because often saved passwords can be easily revealed in plain text. Anybody with access to the computer has access to the sensitive data. Even worse, someone could steal the computer and then use the saved passwords to access the sensitive data. To avoid unintended access to your Magento password or data, simply set your computer or browser to never save it— this might be a bit inconvenient, but it's a great security policy.9. Keep up-to-date anti-virus software Computer viruses and trojans can steal your data and log your key strokes. To minimize the risk of this happening, be sure to invest in reputable anti-virus software. Free anti-virus software like AVG may be great for home and personal use, but if you want indemnification or a warranty, you may want to look at commercial anti-virus software.10. Restrict admin access to only approved IP addresses You can use .htaccess to limit access to your admin area. In the .htaccess file for your admin directory, place the following code in order to block access to all IP addresses except those specifically listed:AuthName "Protected Area" AuthType Basic order deny,allow deny from all allow from allow from 22.2</limit>"allow from" blocks the specific IP address"allow from 22.2" blocks a range of IP addresses beginning with 22.2There is a downside to restricting access based on IP: if you travel a lot you may find this method very inconvenient as you'd have to manually add each new IP address or IP range to the .htaccess file in order to gain access.

Posted on: 28 May 2010 | 6:19 am

How to remove index.php from Magento URLs

Hi, if you are using Magento and your store urls are looking this way,, you must be looking , how to remove that index.php from the middle, as thats not good for Search Engine Indexing at all. So, here is the trick.1. Goto your site root folder and you can find the .htaccess file. Just edit that. Open it on a text editor and find this line,  #Rewrite Base /magento/ . Just replace it with Rewrite Base / .2. Then goto your Admin Panel and enable the Web Server Rewrites. You can find it at System > Configuration > Web > Search Engine Optimization.3. Then goto your Cache Management page ( System > Cache Management) and refresh your Cache and also refresh the Web Redirects.Thats all. Test at Frontend now..

Posted on: 21 May 2010 | 4:39 am

Magento-Moving Upselling products from content to right column

A simple solution to display upselling products in right column rather than at content part by default. Follow this steps. step 1:go to catalog.xmlHide this block as<!–<block type=”catalog/product_list_upsell” name=”” as=”upsell_products” template=”catalog/product/list/upsell.phtml”><action method=”setColumnCount”><columns>4</columns></action><action method=”setItemLimit”><type>upsell</type><limit>4</limit></action></block>–> step 2:Add the following code<block type=”catalog/product_list_upsell” name=”” before=”-” template=”catalog/product/list/upsellright.phtml” />after this code<block type=”catalog/product_list_related” name=”catalog.product.related” before=”-” template=”catalog/product/list/related.phtml”/> step 3:go to catalog/product/view.phtmlthen remove the following line or commend it<?php echo $this->getChildHtml(‘upsell_products’) ?>like this <?php //echo $this->getChildHtml(‘upsell_products’) ?> step 4:create upsellright.phtml in catalog/product/list folderand paste the following code fully<?php if(count($this->getItemCollection()->getItems())): ?><div class=”box base-mini mini-related-items”><div class=”head”><h4><?php echo $this->__(‘Upselling Products’) ?></h4></div><div class=”content”><ol><?php foreach($this->getItems() as $_item): ?><li<?php if($_item->isComposite() || !$_item->isSaleable()): ?> class=”super-products”<?php endif; ?>><div class=”product-images”><a href=”<?php echo $_item->getProductUrl()?>” style=”margin-left:0px;”><img src=”<?php echo $this->helper(‘catalog/image’)->init($_item, ‘thumbnail’)->resize(50) ?>” alt=”<?php echo $this->htmlEscape($_item->getName()) ?>” width=”50″ height=”50″ /></a></div><div class=”product-details” style=”margin-left:70px;”><a href=”<?php echo $_item->getProductUrl() ?>”><?php echo $this->htmlEscape($_item->getName()) ?></a><?php echo $this->getPriceHtml($_item, true) ?><?php if ($this->helper(‘wishlist’)->isAllow()) : ?><a href=”<?php echo $this->getAddToWishlistUrl($_item) ?>” class=”link-cart”><?php echo $this->__(‘Add to Wishlist’) ?></a><?php endif; ?></div></li><?php endforeach ?></ol></div></div><?php endif ?>

Posted on: 20 May 2010 | 2:35 am

Analysis & Usage of Collections in Magento

As a Magento Programmer I am fascinated by the use & simplicity of collection used in Magento. Simplicity, does not really mean being simple (it is rather complex structured) but easy to use. With the help of one of my colleague, I got down to understand how collection really represents the “collection” of data we are actually trying to get from database. Here is what I found drilling down into the Magento’s Core. I may be “not quite right” with the analysis, you can always comment.Almost all the collections found inside app/code/codepool/Namespace/Module/Model/Mysql4/model/Collection.php are the child of parent Class Mage_Core_Model_Mysql4_Collection_Abstract. Primary thing done in the class constructor is initializing its resource and Model. If you look into one of the Collection class you can see in its constructor./**    * @class Mage_Checkout_Model_Mysql4_Agreement_Collection    * Initialize resource    *    */    protected function _construct()    {      $this->_init('checkout/agreement');    } And this _init function has been implemented in its parent class as/**         * Standard resource collection initalization         *         * @param string $model         * @return Mage_Core_Model_Mysql4_Collection_Abstract         */        protected function _init($model, $resourceModel=null)        {            $this->setModel($model);            if (is_null($resourceModel)) {                $resourceModel = $model;            }            $this->setResourceModel($resourceModel);            return $this;        } The resource class can be found in app/code/codepool/Namespace/Module/Model/Mysql4/model.php. And this resource class in turn initializes the database table to be used in the Module along with the table’s primary key.class Mage_Checkout_Model_Mysql4_Agreement extends Mage_Core_Model_Mysql4_Abstract        {             protected function _construct()        {            $this->_init('checkout/agreement', 'agreement_id');        }        ......        } It is this resource class that actually works out the database connections, read/write adapters and performs transactions. So this is the basic deduction about the link of collection with the database and its tables. But how are those collection formed still remains a mystery, not anymore! In this section of the post I will try to explain how are the collections really formed.If I can, “collection” can be defined as collection or array of its resource. And in Magento case, most of the resources are database’s query results. Simply you can visualize “collection” to be array of your model’s resource. If a “query” in Magento returns a collection of all the products then it would mean that the very collection is an array of all the individual product’s object. But one question still remains how will the database query’s result transform into a Magento “collection“. To understand that we need to understand the collection class and its parents.The class Structure for Mage_Core_Model_Mysql4_Collection_Abstract is like this.Mage_Core_Model_Mysql4_Collection_Abstract|__ Varien_Data_Collection_Db (C)|__ Varien_Data_Collection (C)|__ IteratorAggregate (I)|__ Countable (I)You can see that all collection implements two Interfaces IteratorAggregate & Countable.IteratorAggregate is predefined in Standard PHP Library that extends Abstract Base Class Traversable. On using this Interface you can then Iterate Through Object using “foreach” construct. Countable returns the size of the Collection Object.Among the two Interfaces, IteratorAggregate is particularly important. As you can see in Class Hierarchy both the interfaces are implemented by Varien_Data_Collection concrete class. IteratorAggregate has abstract public method getIterator() which returns the Iterator interface and the concrete Class has to implement the method on its own. It is this Iterator that provides the real iteration functionality.So if you look into the Varien_Data_Collection you will find the getIterator() implemented like this./**         * @class Varien_Data_Collection         * Implementation of IteratorAggregate::getIterator()         */        public function getIterator()        {            $this->load();            return new ArrayIterator($this->_items);        } As you can see that it first loads the “items” (I will get back to this Items) and instanciates the value to an internal Class ArrayIterator. And the Iterator returned by this function can then be iterated using foreach construct.Looks like it is going to be a looonnnnng post, let be summarize what I’ve tried to point out until now. I’ve tried to show the link between the collection class or rather object with the database table and explain the iteration behavior of the collection object. But one question still remains how will the database query’s result transform into a Magento’s “collection“. This is where the “items” explanation need to be done.“Items” are actually array if individual object (item) of the collection which represents the array of tuple of the database query result. As you see in the snippet above the ArrayIterator takes $this->_items are parameter. But $this->_items are not populated here on Varien_Data_Collection but rather on is child class Varien_Data_Collection_Db. Here’s the snippet from Varien_Data_Collection_Db./**         * Load data         * @class Varien_Data_Collection_Db         * @return  Varien_Data_Collection_Db         */        public function load($printQuery = false, $logQuery = false)        {            if ($this->isLoaded()) {                return $this;            }                $this->_renderFilters()                 ->_renderOrders()                 ->_renderLimit();                $this->printLogQuery($printQuery, $logQuery);                // Getting Data from DB            $data = $this->getData();                $this->resetData();                if (is_array($data)) {                    // Looping on each result row                foreach ($data as $row) {                    // Creating Empty "item" Varien_Object's object                    $item = $this->getNewEmptyItem();                        if ($this->getIdFieldName()) {                        $item->setIdFieldName($this->getIdFieldName());                    }                        // Setting Varien_Object's values to that of the row                    $item->addData($row);                        /**                    * Adding the "item" to the collection @class Varien_Data_Collection                    * So while referring to $this->_items @class Varien_Data_Collection it will return array of this "item"                    */                    $this->addItem($item);                }                }                $this->_setIsLoaded();            $this->_afterLoad();            return $this;        }            /**         * Get all data array for collection         * @class Varien_Data_Collection_Db         * @return array         */        public function getData()        {            if ($this->_data === null) {                $this->_renderFilters()                     ->_renderOrders()                     ->_renderLimit();                    // Fetching all the row with the Select query set                $this->_data = $this->_fetchAll($this->_select);                $this->_afterLoadData();            }            return $this->_data;        } You can go through the inline comments I’ve added. This is it, I’ve finally worked out the explanation of structure & creation of Magento’s Collection and its iterative behavior. I’ve tried to show pictorially (below) what I have just described. Confused! Plz comment and of course please do comment if I am wrong, because there are “times” when you try to understand things even though they actually aren’t just like you think. I’d like to quote Paulo :“I see the world in terms of what I would like to see happen, not what actually does”!

Posted on: 19 May 2010 | 4:22 am

How To Setup Conversion Tracking In Magento

3rd Party Conversion TrackingMagento Commerce has the ability to track eCommerce sale with Google Analytics out of the box (more on that in a future post). Something that a lot of merchants struggle with is how to set up conversion tracking for other tracking software or comparison shopping engines.How ToHere is an easy hack to track conversions for Shopzilla, PriceGrabber and the likes:Open the file: app\design\frontend\XXXX\XXXX\template\checkout\success.phtmlAt the end of the file, add the following code, this will create two variables with the order number and the order total:1    <?php2        //Get Order Number & Order Total3        $order = Mage::getModel('sales/order')->loadByIncrementId(Mage::getSingleton('checkout/session')->getLastRealOrderId());4        $amount = number_format($order->getGrandTotal(),2);5    ?>After the above code snippet, copy and paste the tracking code from the third party analytics software of comparison shopping engine. Insert the following variable where they suggest placing the order ID and the order total:1    <?php echo $amount; ?> // Order Total2    <?php echo $this->getOrderId() ?> // Order NumberHere is a code example for the Shopzilla conversion tracking tool:1    <script language="javascript">2        var mid            = 'XXXXX'; // Your Shopzilla Merchant ID3        var cust_type      = '';4        var order_value    = '<?php echo $amount; ?>'; // Order Amount5        var order_id       = '<?php echo $this->getOrderId() ?>'; //Order Number6        var units_ordered  = '';7    </script>8    <script language="javascript" src=""></script>9    <script language="JavaScript" src="" type="text/javascript"></script>

Posted on: 18 May 2010 | 2:56 am

How to Add Video to Products in Magento

Adding a video to a product greatly enhances the online shopping experience. The out-of-the-box Magento package doesn’t support video. This How-To shows just how to do that. We’ll be able to either (1) drop in HTML embed code from sites like YouTube, or (2) use an FLV file that we provide. This article assumes you have the jQuery Javascript library installed and have “jQuery.noConflict()”‘ set up.  If you don’t have jQuery.noConflict(), then simply replace instances of “jQuery” with “$”.  If you don’t have this library, download jQuery here.Here’s the sequence of steps we’re going to take:Create a product attribute for the video codeAssign the newly created attribute to an attribute setModify the template filesObtain and upload a copy of the free JWPlayerAdd video to a product using HTML embed code or using an FLV file1. Create a product attribute for the video code.Log in to your Magento Admin Panel. Navigate to Catalog > Attributes > Manage Attributes. Click on the “Add New Attribute” button found close to the top-right hand corner of the screen. The first tab that’s open is the *Properties* tab. You are presented with lots of textboxes and dropdowns. Here’s what to fill them in with :Attribute Properties- Attribute Code: video- Scope: Global- Catalog Input Type of Store Owner: Text Area- Default Value: [leave blank]- Unique Value: No- Values Required: No- Input Validation for Store Owner: None- Apply To: All Product TypesFrontend Properties- Use in quick search: No- Use in advanced search: No- Comparable on Front-end: No- Use in Layered Navigation: No- Use in Search Results Layered Navigation: No- Use for Price Rule Conditions: No- Position: 0- Allow HTML-tags on Front-end: Yes- Visible on Product View Page on Front-end: No- Used in product listing: No- Used for sorting in product listing: NoThen navigate to the *Manage Label / Options* tab. You only have to fill in the “Admin” value, and for this use “Video“. This can be changed later if you need to.Click the “Save Attribute” button to save the attribute.2. Assign the newly created attribute to an attribute set (likely Default)While still in the Admin Panel, navigate to Catalog > Attributes > Manage Attribute Sets. From the right-hand column, labeled “Unassigned Attributes”, drag our new video attribute to the “General” group found in the middle column.Click “Save Attribute Set” button to save the attribute set.3. Modify the template filesYou’ll need to use a text-editor and FTP client.3a. video.phtmlCreate a file with these contents:<?php$_product = $this->getProduct();?><?php if( $video = $_product->getVideo() ){ ?><h2>Product Video</h2><div class="products"><?php if( file_exists( getcwd() .'/skin/frontend/[your-package]/[your-theme]/videos/'. $video ) ){ ?><div id="mediaspace">&nbsp;</div><script>jQuery( document ).ready( function(){jQuery.getScript( '<?php echo $this->getSkinUrl('videos/mediaplayer/swfobject.js'); ?>', function(){var so = new SWFObject('/skin/frontend/[your-package]/[your-theme]/videos/mediaplayer/player.swf','ply','470','320','9','#ffffff');so.addParam('allowfullscreen','true');so.addParam('allowscriptaccess','always');so.addParam('wmode','opaque');so.addVariable('file','<?php echo Mage::getBaseUrl(); ?>/skin/frontend/[your-package]/[your-theme]/videos/<?php echo $video; ?>');so.write('mediaspace');} );} );</script><?php } else { ?><?php echo $video; ?><?php } ?></div><?php } ?>And save the file as /app/design/frontend/[your-package]/[your-theme]/template/catalog/product/view/video.phtml3b. catalog.xmlOpen up /app/design/frontend/[your-package]/[your-theme]/layout/catalog.xml and add this line:<block type="catalog/product_view" name="product_video" as="product_video" template="catalog/product/view/video.phtml"/>as a child anywhere inside this node:<block type="catalog/product_view" name="" template="catalog/product/view.phtml">… and save the file.3c. catalog/product/view.phtmlOpen up /app/design/frontend/[your-package]/[your-theme]/catalog/product/view.phtml and add this line:<?php echo $this->getChildHtml('product_video'); ?> wherever you want the video to appear on the page. Save the file.4. Obtain and upload a copy of the free JWPlayerDownload the playerAfter you download the ZIP file, extract and upload the files using an FTP client to: /skin/frontend/[your-package]/[your-theme]/videos/*With the FTP client, rename the “mediaplayer-viral” folder to “mediaplayer”5. Add video to a productIn the Magento Admin Panel, navigate to Catalog > Manage Products and click on the product you’d like to add video to. You should see a textarea labeled “Video”.5a. Use HTML embed codeIn the “Video” textarea, simply drop in the HTML code you’ve received (such as from YouTube) and click “Save” to save the product.5b. OR use an FLV file- Upload your FLV file to /skin/frontend/[your-package]/[your-theme]/videos/- In the “Video” textarea, specify the filename of the FLV you’ve just uploaded.Repeat Step 5 for all of the products you want to add video to. Congratulations, you’ve added video to your products.* This method is tested and working for Magento v

Posted on: 17 May 2010 | 4:24 am

Magento Admin Grid: how to change number of rows

We had a request from our client, that we change default number of items in Magento admin grid. Now, this is very simple, when we know how to change it. Below you can see an example which uses magento observer model and event hocking “core_block_abstract_prepare_layout_before”.First of all, make backup copies of your files.Step 1.This is example of event hocking, put it in config.xml 01.<adminhtml>02. <events>03. <core_block_abstract_prepare_layout_before>04. <observers>05. <reward>06. <class>grid/observer</class>07. <method>applyLimitToGrid</method>08. </reward>09. </observers>10. </core_block_abstract_prepare_layout_before>11.12. </events>13. </adminhtml>Step 2.Create model class observer.php 01.class Inchoo_Grid_Model_Observer02.{03.04. public function applyLimitToGrid(Varien_Event_Observer $observer)05. {06. $block = $observer->getEvent()->getBlock();07. if(($block instanceof Mage_Adminhtml_Block_Widget_Grid) &amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;&amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp;amp; !($block instanceof Mage_Adminhtml_Block_Dashboard_Grid))08. $block->setDefaultLimit(200);09.10. }11.12.}It would be good that you make your own module and all put in it. I hope that you know how to make magento module.

Posted on: 14 May 2010 | 4:15 am

Magento Layout / Structural Block How to?

1. Layout your Structural BlocksWhen you begin the implementation process, first ask yourself this question: What are the layout needs of my store?What this simply means is: “Will my store always have a left column? Or will some pages have a left, main and a right column? Or perhaps some of the pages will just one column?”. These questions are imperative because the variations of page structure will directly determine the number of skeleton templates you will need to create – For instance, if you have a one column and a 3 column layout, you will need to create two skeleton template accordingly. But before we go further, let’s first look at what a skeleton template looks like.<div class="header">getChildHtml('header')?&gt;</div><div class="middle"><div class="col-left">getChildHtml('left')?&gt;</div><div class="col-main">getChildHtml('content')?&gt;</div></div><div class="footer">getChildHtml('footer')?&gt;</div>Pretty straight forward. This type of templates are what we call “skeleton templates” because it exists for the purpose of positioning structural blocks within a page. Such templates are located in app/design/frontend/default/default/template/page/, and you can name it anything you want – mycolumns.phtml, 2columns-left.phtml, whatever suits your fancy. “Wait a minute!!! What is all this getChildHtml(”)?> business?” you say. Ok, let’s move along.If you examine the method getChildHtml(’header’)?>, you will see that there’s an identifier called “header” being assigned to the area encased by the XHTML. What getChildHtml does, is it grabs all the content blocks(see step 2 below) that is assigned to “header” via something called a layout (see step 3 below), and places it inside2. Distribute your Content Blocks (aka Let’s cut up some real meat of the page)Content blocks are the ones that actually parse your store’s data into visually appealing format using XHTML. Unlike other eCommerce solutions you may be used to, Magento supplies separate content blocks per separate functionalities. What this means is, your col_left.tpl (or whatever else you may be used to working with), no longer contains ALL the XHTML to be shown in the left column but rather, the functionality used in the left column will recruit its own template for use. Let’s take the demo Magento as an example. If you open a category page on your browser, you will see in the right column the following functionalities: mini-cart, compare products, newsletter and community poll. Each of these content blocks comes with its own template file. Because mini-cart is a separate functionality, as is the compare products, newsletter…etc, mini-cart has it’s own template file, compare products has its own template file, and newsletter has its own template file. The XHTMLyou create should be cut up accordingly on per functionality basis.3. Let’s recap and comprehendIn this step, let’s take a breather and do a quick recap.When working in the visual aspect of a store running on Magento, there’re three things you will use to visually parse your store data.Structural BlocksStructural blocks are the visual skeleton of a store page. These blocks exist for the sole reason of creating visual structure. Example structural blocks are header, left column, main column, footer…etc.Content BlocksContent blocks are the blocks that constructs the makeup of a structural block. Each content block represents distinct functionalities such as Mini-cart, mini-wishlist, compare products, newsletter signup…etc, and they comes with it’s own template.LayoutsLocated in app/design/frontend/your_package/your_theme/layout, layout is the one that puts all the pieces together. When a page loads in your store, the following things happen:a. The layout first grabs the base skeleton template of the site.b. It grabs all the content blocks that are assigned to the structural blocks of a page, and loads them.Basically the layout says “Grab these content blocks and nest them inside these structural blocks.” The layout can be updated on a per page basis, so you can conveniently change the functionalities being loaded into each page of you store with just one file.This is the absolute quick idea of how the templates work in Magento. We’re working on a full documentation and it will be released with the stable version of Magento. In the mean time, the best thing to do is read through the threads of the forum, stay active in the community and ask a lot of questions! I hope this reply gave you some understanding of how things work in Magento.

Posted on: 13 May 2010 | 2:26 am

Quick script to batch create Magento categories

A site we administer with a reasonable amount of SKUs (far in excess of 100,000), needed some quick category manipulation for a series of new data to be dropped in. The new information had a desired category tree that had to be built up quick, but with over 600 categories to be created, human effort wouldn’t be suitable.So, using the Magento category ID export script to help manipulate the CSV – we were able to quickly make a script to batch create our categories.First off, create your CSV with 2 columns, the parent ID for the category and the category name – you could easily add more columns for extra options, but it wasn’t necessary for us.The CSV file should be something like this:3,subcat4,subcat26,subcat3Then it should be saved in ./var/import/importCats.csvThen save the following in ./quickCatCreate.php<?php     define('MAGENTO', realpath(dirname(__FILE__)));    require_once MAGENTO . '/app/Mage.php';     umask(0);    Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);        $count = 0;     $file = fopen('./var/import/importCats.csv', 'r');    while (($line = fgetcsv($file)) !== FALSE) { $count++;      //$line is an array of the csv elements       if (!empty($line[0]) && !empty($line[1])) {            $data['general']['path'] = $line[0];          $data['general']['name'] = $line[1];          $data['general']['meta_title'] = "";          $data['general']['meta_description'] = "";          $data['general']['is_active'] = "";          $data['general']['url_key'] = "";          $data['general']['display_mode'] = "PRODUCTS";          $data['general']['is_anchor'] = 0;           $data['category']['parent'] = $line[0]; // 3 top level          $storeId = 0;           createCategory($data,$storeId);          sleep(0.5);          unset($data);        }     }      function createCategory($data,$storeId) {       echo "Starting {$data['general']['name']} [{$data['category']['parent']}] ...";       $category = Mage::getModel('catalog/category');      $category->setStoreId($storeId);       # Fix must be applied to run script      #                if (is_array($data)) {              $category->addData($data['general']);               if (!$category->getId()) {                   $parentId = $data['category']['parent'];                  if (!$parentId) {                      if ($storeId) {                          $parentId = Mage::app()->getStore($storeId)->getRootCategoryId();                      }                      else {                          $parentId = Mage_Catalog_Model_Category::TREE_ROOT_ID;                      }                  }                  $parentCategory = Mage::getModel('catalog/category')->load($parentId);                  $category->setPath($parentCategory->getPath());               }                     /**                     * Check "Use Default Value" checkboxes values                     */                    if ($useDefaults = $data['use_default']) {                        foreach ($useDefaults as $attributeCode) {                            $category->setData($attributeCode, null);                        }                    }                             $category->setAttributeSetId($category->getDefaultAttributeSetId());               if (isset($data['category_products']) &&                  !$category->getProductsReadonly()) {                  $products = array();                  parse_str($data['category_products'], $products);                  $category->setPostedProducts($products);              }               try {                  $category->save();                  echo "Suceeded <br /> ";              }              catch (Exception $e){                      echo "Failed <br />";               }          }         }Then it is just a matter of visiting the link in your browser to create the categories – customise to your hearts content, any further expansion should be very easy (such as product association etc.)Uh oh – I’m getting errors after the first record!Fatal error: Call to a member function getPath() on a non-object in app\code\core\Mage\Catalog\Model\Resource\Eav\Mysql4\Category.php on line 385There is a small NB though, there is a bug with Magento’s original code that will cause a problem with the above script, a quick fix is outlined here. It is just a matter of commenting out 2 lines to force the variable to be re-set.In ./app/code/core/Mage/Catalog/Model/Resource/Eav/Mysql4/Category.php line #110protected function _getTree()    {        //if (!$this->_tree) {            $this->_tree = Mage::getResourceModel('catalog/category_tree')                ->load();        //}        return $this->_tree;    }

Posted on: 12 May 2010 | 7:18 am

Magento - Yahoo Analytics Conversion Code

Unlike other tracking codes, we need to put Yahoo Analytics Conversion code between <HEAD> and </HEAD> tags.Yahoo’s Instructions for the following code are:Copy the HTML code below and insert it between the <HEAD> and </HEAD> tags on your site’s conversion page(s). To pass a dynamic revenue value in the tag, you must modify your web pages accordingly.To add the Yahoo conversion tracking code in the Head tags, we need to look at the checkout layout configuration file:/app/design/frontend/your_interface/your_theme/layout/checkout.xmlFind out which page layout it uses when an order is completed.i.e.) For one page checkout, look for this code:<checkout_onepage_success><reference name="root"><action method="setTemplate"><template>page/2columns-right.phtml</template></action></reference>You can edit the Head section of ‘2columns-right.phtml’ to add the Yahoo tracking code. But if this template, 2columns-right.phtml is being used for other pages, I would make a copy of it and name it ‘2columns-right-success.phtml’ and add the tracking code there. This way, it will track it only when there is a successful conversion.<html xmlns="" xml:lang="<?php echo $this->getLang() ?>" lang="<?php echo $this->getLang() ?>"><head><?php echo $this->getChildHtml('head') ?><SCRIPT language=”JavaScript” type=”text/javascript”><!– Yahoo! Inc.window.ysm_customData = new Object();window.ysm_customData.conversion = “transId=,currency=,amount=”;var ysm_accountid = “—–YAHOO_ACCOUNT_ID—–”;document.write(”<SCR” + “IPT language=’JavaScript’ type=’text/javascript’ ”+ “SRC=//” + “” + “/script/ScriptServlet” + “?aid=” + ysm_accountid+ “></SCR” + “IPT>”);// –></SCRIPT>

Posted on: 11 May 2010 | 6:40 am

How to Import Products into Magento

There’s a little confusion among some on how to import products into a Magento ecommerce store. I spent some time today researching and trying to find the best method on doing this. The reason for my research is because there was no simple documentation anywhere that I could find on how to import products. Magento actually has built a pretty robust import/export mechanism into the ecommerce cms that has a ton of flexibility to do many things. I’m not going to cover all of those. This is just for those of you who simply just want to import products into their Magento cart.Step 1 – Add a new product manually
add a new product manually to the catalog, assign it to a category, and fill out all fields that will be necessary to your store. The obvious ones are price, description, quantity etc. It’s important that you fill out all fields that you know you are going to need for all the products you import.Step 2 – Export Your Products
Now we want to export your product to a .csv file so that we can view the fields that are required to import. Go to System >> Import/Export >> Profiles. Now click on Export All Products then Run Profile. Click on the “Run Profile in Popup” button. Once the export is completed, go to your var/export directory on your Magento install and you will find the .csv file there for you to download.Step 3 – Analyze The .CSV File
Now if you look at your .csv export file you will see the field names that you need to match up. Now just start filling yours in and creating your csv file ready for import. This step is extremely important. Otherwise Magento cannot match what you are trying to import and the importing will fail. At a most basic level, here are the fields that I imported:    •    store    •    attribute_set    •    type    •    sku    •    category_ids    •    status    •    visibility    •    tax_class_id    •    weight    •    price    •    name    •    descriptionStep 4 – Import Your New .CSV File
Now go to System >> Import/Export >> Profiles. Now click on Import All Products. Change “Type” under Data Format to CSV/Tab Seperated. Now click on Upload File, and browse for your .csv file and click “Save and Continue Editing”. Now go to “Run Profile” and select your file from the dropdown menu. Click the button underneath to run the import. And whalllah. All your products should now be imported.

Posted on: 4 May 2010 | 6:28 am

Creating Block From the Code in Magento

Here are some methods of creating block by code in Magento. This type of code can be used directly in template, not need to create a layout file or add a child node inside already existing layout file. You can use this to echo a different type of block inside already loading block and template.// Directly in the PHTML where you want to show the block<?phpecho $this->getLayout()->createBlock("module/block")->setTemplate("module/page.phtml")->toHtml();?>What we have actually done is just load the layout and create an instance of a block class defined inside its paramerter, then assigned a template to the block and finally echoed as html. Simple! The code above will be equivalent to what we do as following in layout and in template file.// In layout<block type="module/block" name="" template="module/page.html"/><?php// In parent PHTML$this->getChildHtml("");?>

Posted on: 27 April 2010 | 4:21 am

How To install Magento In Wamp Server

Magento is an open-source ecommerce web application launched on March 31, 2008. It was created by Varien, building on components of the Zend Framework.Magento is available under the Open Software License version 3.0. Since version 1.1.7 some parts are licensed under the Academic Free License version 3.0.To Download Magento In Wamp, Follow below steps.1. Download latest stable version of Magento from (Requires free registration), Unzip in www directory and Also create Mysql database and User from your phpmyadmin panel, which can be accessed by http://localhost/phpmyadmin.2. Now start installing Magento by http://localhost/magento. If not accessible, please check the folder name of your folder.3. Now Installation Wizard will be start, Step 2 is to enter your mysql details. It will take a while as it creates some tables.4. Next Step will ask you about Admin login/Pass, So Create your admin/pass and save them.Well, thats all. Go Open your store and Enjoy

Posted on: 26 April 2010 | 4:22 am

Magento Commerce 1.4: How To Fix ‘Unable to submit your request. Please, try again later’ on the Contact Us form

If you’ve upgraded your Magento Commerce site to 1.4.x you may have run in to the problem where any attempt to send a response via your ‘Contact Us’ page fails with  “Unable to submit your request.  Please try again later”.Contact Us Form - Error: Unable to submit your request, please try again laterIf you look at the code /app/code/core/Mage/Contacts/controllers/IndexController.phppublic function postAction()    {        $post = $this->getRequest()->getPost();        if ( $post ) {            $translate = Mage::getSingleton('core/translate');            /* @var $translate Mage_Core_Model_Translate */            $translate->setTranslateInline(false);            try {                $postObject = new Varien_Object();                $postObject->setData($post);                $error = false;                if (!Zend_Validate::is(trim($post['name']) , 'NotEmpty')) {                    $error = true;                }                if (!Zend_Validate::is(trim($post['comment']) , 'NotEmpty')) {                    $error = true;                }                         if (!Zend_Validate::is(trim($post['email']), 'EmailAddress')) {                    $error = true;                }                if (Zend_Validate::is(trim($post['hideit']), 'NotEmpty')) {                    $error = true;                }                if ($error) {                    throw new Exception();                }      (...snip...)            } catch (Exception $e) {                $translate->setTranslateInline(true);                Mage::getSingleton('customer/session')->addError(Mage::helper('contacts')->__('Unable to submit your request. Please, try again later'));                $this->_redirect('*/*/');                return;            }The Contact Us form requires the Name, Comment, Email not be empty or NULL.  We do expect the “hideit” field to (a) exist and (b) be empty/NULL.  The “hideit” field is new in 1.4 and is designed to help prevent spam.  Automated bots would complete this field and this is how we can detect bots.  It’s best to implement a Captcha system as well on your Contact Us page to further improve your spam protection.If any of the above checks fail, the function throws an exception and we get the “Unable to submit your request. Please, try again later” message.  The message would be more descriptive if it read “Unable to submit your request, please verify all required fields have been completed”.  You can change the message in the locale translation file if you want.  This will also future proof you against updates.The best thing to do is examine the code on your site.  Those site’s I’ve looked at have the following:<div class="button-set">        <p class="required">* Required Fields</p>        <button type="submit" class="form-button"><span>Submit</span></button>    </div>The correct code should be:<div class="buttons-set">        <p class="required">* Required Fields</p>        <input type="text" style="display: none ! important;" value="" id="hideit" name="hideit">        <button class="button" title="Submit" type="submit"><span><span>Submit</span></span></button>    </div>Either something went wrong with the upgrade and the underlying files didn’t get upgraded, or you’re overriding the files within your theme directory.The Contact Us form is generated by /app/design/frontend/base/default/template/contacts/form.phtml.  The code from a working environment looks like this:<div class="buttons-set">        <p class="required"><?php echo Mage::helper('contacts')->__('* Required Fields') ?></p>        <input type="text" name="hideit" id="hideit" value="" style="display:none !important;" />        <button type="submit" title="<?php echo Mage::helper('contacts')->__('Submit') ?>" class="button"><span><span><?php echo Mage::helper('contacts')->__('Submit') ?></span></span></button>    </div>Remember to backup any files you edit, before editingYou can choose either to edit the file directly or better yet, replace it with the correct file.

Posted on: 17 April 2010 | 1:12 am

Upgrading To Magento 1.4

With the recent release of Magento version 1.4, many people are having trouble upgrading their current Magento installation, or installing their template on a fresh Magento 1.4 installation. A quick search online and you’ll find countless entries and posts stating that Magento 1.4 is buggy, not working, horrible, etc. Particularly when you browse through the Magento forums.In fact Magento 1.4 is different than the last previous stable version ( but you should definitely be able to upgrade your installation, or install your custom template on a Magento 1.4 installation! Here are the most common issues and how to fix them!Magento modern theme 1.4This relates to the following issues:    * Can’t install Modern Theme through Magento Connect          o Get error “magento-core/Interface_Frontend_Default_Modern requires package “magento-core/Mage_Core_Modules” (version >=, version <= 1.3.3, excluded versions: 1.3.3), installed version is            Install Errors            No valid packages found            PEAR ERROR: install failed    * Can’t upgrade Modern Theme through Magento Connect          o Get similar error as above    * etcAs of now, there is no good way to install or upgrade the Modern Theme via Magento Connect. BUT you should definitely be able to get it by installing a fresh Magento 1.4 installation.Magento 1.4 comes by default with the default theme, the modern theme, and the iphone optimized theme. However, you’d have to install Magento manually and NOT use the downloader (as this will include the default theme only). Here is one way to install Magento 1.4 manually:   1. Download all the files on your computer and upload them on your server   2. Create a database and a database user and grant that user all permissions to the database. Make sure to write down your database name, database user name, and database user password.   3. Go to the URL that points to your server and follow the instructions to complete Magento installationCan’t access admin, blank page, products won’t load, error, etcMost issues will be resolved once you reindex Magento data and refresh all Magento cache. To reindex Magento data follow these quick steps:   1. Go to System>Index Management   2. Click on “select all” in the upper left corner   3. Under “Action” select “Reindex Data” and click submitTo refresh all Magento cache following these quick steps:   1. Go to System>Configuration and   2. Click on “select all” in the upper left corner   3. Under “action” click on “refresh” and click submit   4. Then click on these buttons:         1. Flush Magento Cache         2. Flush Cache Storage         3. Fluch Catalog Images Cache         4. Flush JavaScript/CSS CacheUpgrading your existing theme (modern or else)Obviously I cannot cover here all the possible problems and issues that may arise when upgrading your particular template to be compatible with Magento 1.4. However, I found that the most common issue is “Categories not working after upgrading to 1.4″. This relates to the error people get when clicking on some categories: “Error processing your request” followed by a number.To fix that, you’ll need to do 2 things:1. First, edit your toolbar.phtml file located under app/design/frontend/default/yourthemename/template/catalog/product/list. Take the updated toolbar.phtml from the new 1.4 default theme (located under app/design/frontend/base/default/template/catalog/product/list) and use it in your theme. Then edit that file to apply any styling you had in your original toolbar.phtml file. Another way of doing it is editing your toolbar.phml file to use the right class names and code (you can compare with the default one and take it from there).2. Second, open catalog.xml located under app/design/frontend/default/yourthemename/layout/ and find this line:<block type=”catalog/product_list_toolbar” name=”product_list_toolbar” template=”catalog/product/list/toolbar.phtml”>And underneath insert this code:<block type=”page/html_pager” name=”product_list_toolbar_pager”/>And that should do it!

Posted on: 16 April 2010 | 1:47 am

How to show error description in Magento 1.4

Simply go to your magento installation folder, locate the errors folder and you will find local.xml.sample, simply duplicate the file and rename it local.xml

Posted on: 15 April 2010 | 6:16 am