{"id":6373,"date":"2018-01-10T11:26:13","date_gmt":"2018-01-10T10:26:13","guid":{"rendered":"https:\/\/eurotext-ecommerce.com\/en\/?p=6373"},"modified":"2024-09-30T08:49:16","modified_gmt":"2024-09-30T06:49:16","slug":"how-does-internationalization-work-with-magento-part-1","status":"publish","type":"post","link":"https:\/\/eurotext.de\/en\/blog\/how-does-internationalization-work-with-magento-part-1\/","title":{"rendered":"How does internationalization work with Magento? \u2013 Part 1"},"content":{"rendered":"
The technical implementation of internationalization in e-commerce:<\/strong> What is the best way to go about it? What possibilities do the various shop and content management systems<\/strong> have to offer when it comes to organizing content and products in multiple languages? And what are the potential pitfalls?<\/p>\n In the first part of this series we are focusing on Magento<\/strong><\/a>. This shop system is aimed primarily at medium to large-sized companies and enjoys widespread distribution thanks to its free software and highly dedicated community. Magento expert Rico Neitzel from B\u00fcro 71a kindly agreed to discuss the shop system with us. Having worked as a developer and adviser in the Magento scene since 2006, he has a wealth of experience and background knowledge to share. In this article we discuss both the benefits and the drawbacks of Magento-based shop solutions.<\/p>\n <\/p>\n <\/div> <\/div> Magento shops are structured in clearly defined layers. While this can be a challenge for inexperienced users, it provides the perfect conditions for retailers who want to offer different country or language versions<\/strong> of their shop. In principal there are 3 layers, or so-called scopes<\/strong>: global, website<\/em> and store view<\/em>. These are hierarchically structured, with lower levels inheriting the properties of the levels above.<\/p>\n The Global<\/em><\/strong> scope acts as the basis for all Magento installations and is where the default config is made. Where the shop is to be operated is specified here i.e. the legal basis of the shop. The admin area language can also be set globally. And this of course is where all of the products are created and managed.<\/p>\n The next scope, the website<\/em><\/strong>, is where the structure of the shop is created and various things concerning taxes and prices. A classic application is to create separate B2B<\/strong> and B2C<\/strong> websites at this level. The default settings for the prices (net\/gross) can then be set separately for the two websites<\/em><\/strong>. In international shops, websites <\/em>can be used to define base currencies<\/strong>. You can, for example, set up one website for the European market which calculates in Euros, and one for the American market which calculates in US Dollars. The shipping and payment options<\/strong> and taxes<\/strong> can then also be set at the website<\/em> scope.<\/p>\n One layer that does not belong to the configuration levels (scopes) is the store.<\/em><\/strong> This is primarily used to assign categories to the different websites. It is therefore possible to set up different stores with different product ranges or structures.<\/p>\n The final layer is the so-called store view,<\/strong> which is responsible for managing the presentation<\/strong> of the shop. This is where it gets interesting for internationalization, because the presentation of the shop includes the output language, currency<\/strong>, the theme<\/strong> and a number of other features through which the various country and language versions of the shop differ.<\/p>\n By the way, it’s no mistake that currency<\/strong> can be configured at both the website<\/em> and the store view<\/em> scope. If you create an online shop that calculates in Euros<\/strong> at the website<\/em> scope, that doesn’t necessarily mean that all store views<\/em> should display Euros<\/strong> only. You may want to set up a store view<\/em> for the Swiss market within the Euro website<\/em>. The store view<\/em> would then automatically convert the Euro prices into Swiss Francs. This way, customers see the relevant currency for their country, but in the background the calculations are being made in the base currency of the website \u2013 making life a whole lot easier for the retailer.<\/p>\n It’s when we get to pricing that Magento shows just how flexible it is in terms of catering to multiple countries. You can simply set the same net price for all countries and Magento will convert into the local currencies. The resulting gross price will depend on the value added tax rate<\/strong> in the respective country. Since Magento 1.9<\/strong>, you can also work in the opposite direction. You can set a fixed retail price and the software will calculate the net price required to achieve this gross value according to the value added tax. If neither of these options works for you, you can simply set the prices for each website manually and adjust them to the purchasing power<\/strong> of the various markets.<\/div> Magento is similarly versatile when it comes to calculating shipping costs.<\/strong> The shop system offers a large range of options as standard: free shipping if the value of the goods<\/strong> exceeds a certain value, free shipping if the quantity of goods<\/strong> exceeds a certain value or free shipping in general<\/strong>. Alternatively, a fixed price<\/strong> can be set for all shipments or the shipping costs can be calculated according to the value of the goods, weight, quantity<\/strong> or target country<\/strong>. This allows you to take into account the fact that shipping to Switzerland is considerably more expensive than shipping to the Netherlands, for example. Simply create tables with individual values and Magento makes the calculations.<\/p>\n The advantages of the hierarchical structure become very apparent when translating a Magento online shop<\/strong>. This is because when displaying content such as products or categories, the system goes through all levels of content one by one. The first level is the store view<\/em>. If Magento finds a language file<\/strong> stored here, it displays it. But what if there is no entry for a particular text in the language file due to an incomplete translation or a technical error? Many shop or content management systems would display an error message<\/strong> or simply display nothing at all.<\/p>\n Magento, however, goes to the next level and searches for the corresponding entry. It finds what it is looking for by the global scope at the latest, because all texts are usually stored here in English. It is obviously not ideal if German customers stumble across English text in the German shop, but at least they can continue shopping. An error message or no output at all poses a much larger problem.<\/p>\n Translating user interface texts is even simpler. Simple CSV files \u2013 spreadsheet-like files that contain the original texts and their corresponding translations and can be edited with spreadsheet calculation software such as Excel or OpenCalc \u2013 are used for this purpose. These files can be found both in the theme and Magento’s core code. This means that you can customize the user interface texts however you like.<\/p>\n The same principle applies to images<\/strong> and other graphic elements such as buttons<\/strong> and forms.<\/strong> If there is no element stored in the selected language version, Magento uses the next one up in the hierarchy. This not only serves as a fallback solution<\/strong> for missing data, it also simplifies processing and saves resources<\/strong>. You only need to translate and manage those elements that are actually used.<\/p>\n
\n\n
\n
\n<\/h2>\n
<\/span>Magento’s Layer Structure<\/h2>\n
 <\/em><\/strong><\/p>\n
<\/em><\/strong><\/p>\n
<\/span>Setting Prices<\/h2>\n
\n <\/a>Our interview partner Rico Neitzel<\/strong> implements websites and PHP projects at B\u00fcro 71a<\/a>. He provides Magento training in the field of e-commerce, advises companies and agencies on e-commerce projects and works as an author.<\/div>
<\/a>Our interview partner Rico Neitzel<\/strong> implements websites and PHP projects at B\u00fcro 71a<\/a>. He provides Magento training in the field of e-commerce, advises companies and agencies on e-commerce projects and works as an author.<\/div><\/span>Calculating Shipping Costs Is (Not) an Art Form<\/h2>\n
 But Magento wouldn’t be Magento if it stopped there. Modules like ShipperHQ<\/strong><\/a> from WebShopApps<\/strong><\/a> allow you to customize shipping cost calculations even further. You can, for example, specify that certain items are to be transported by forwarding agents<\/strong> only, that certain items are to be delivered to certain countries<\/strong> only or that goods must surpass a certain value-to-weight ratio in order to qualify for free shipping. E.g. a shopping cart with 5 kg worth of goods must have a value of at least EUR 50 to qualify for free shipping, whereas 10 kg worth of goods must have a value of at least EUR 100. All of this can be configured completely freely.<\/p>\n
But Magento wouldn’t be Magento if it stopped there. Modules like ShipperHQ<\/strong><\/a> from WebShopApps<\/strong><\/a> allow you to customize shipping cost calculations even further. You can, for example, specify that certain items are to be transported by forwarding agents<\/strong> only, that certain items are to be delivered to certain countries<\/strong> only or that goods must surpass a certain value-to-weight ratio in order to qualify for free shipping. E.g. a shopping cart with 5 kg worth of goods must have a value of at least EUR 50 to qualify for free shipping, whereas 10 kg worth of goods must have a value of at least EUR 100. All of this can be configured completely freely.<\/p>\n<\/span>Translations with a Safety Net<\/h2>\n
 \n
\n<\/span>Fallback Solution for Images and Control Elements<\/h2>\n
\n<\/h2>\n
Part 2 \u2013 Problems and Conclusion<\/a><\/h2>\n