Skip to content

Latest commit

 

History

History
104 lines (73 loc) · 4.55 KB

File metadata and controls

104 lines (73 loc) · 4.55 KB

IMI StoreSwitch

Latest Stable Version License

This Magento module extends the default store switcher and displays all store views, regardless of the store or website they're associated to. The default magento store switcher only show the store views which are associated to the currently active store.

It extends the core store switch Magento\Store\Block\Switcher.
By passing \IMI\StoreSwitch\ViewModel\StoreSwitchModel as an argument to the Switcher Block and using the IMI_StoreSwitch::switch/languages.phtml template you can switch between all stores of all websites.

It is possible to enable or disabled the switcher in default, website and store scope. The corresponding acl resource is IMI_StoreSwitch::config.

The switcher is disabled by default, it can be enabled with the config value imi_store_switch/general/enable or in the admin configuration on Stores > iMi > Store Switch.

Show country code only or country code and name

By default the store switcher looks like this:

There is also an option to only show the country code in the store view. If enabled, the available options will only display the country code, otherwise the name and country code are shown.

With the option enabled, it looks like this:

Restrict switching between websites

You can configure the store switcher to allow switching only between some websites instead of all. To do this, you need to set the imi_store_switch/general/available_web_sites config variable to the ids of the website you want to allow.

For example:

n98-magerun2 config:store:set --scope websites --scope-id 1 imi_store_switch/general/available_web_sites 1,2
n98-magerun2 config:store:set --scope websites --scope-id 2 imi_store_switch/general/available_web_sites 1,2
n98-magerun2 config:store:set --scope websites --scope-id 3 imi_store_switch/general/available_web_sites 3  

This would allow switching between store views of websites with the id 1 and 2, but not 3 (store views within 3 will still work).

By default (if the configuration variable is not set), you can switch to all other websites. Set it to an empty string or null to disallow switching to another website.

Use direct links instead of redirects

You can configure the switcher to use direct links instead of the redirect method. This however only works with stores that do not share an url. You can enable this feature either via the adminpanel under Stores > Settings > Configuration > IMI > Store Switch > General > Use direct Links or by cli:

n98-magerun2 config:store:set imi_store_switch/general/use_direct_links 1

Installing

The easiest way to install the module is from packagist by running

composer require imi/magento2-store-switch-all-store-views
bin/magento module:enable IMI_StoreSwitch
bin/magento setup:upgrade
bin/magento cache:flush

If you're running this on a shop in production mode, run

bin/magento setup:static-content:deploy
bin/magento cache:flush

Porto Theme

This has partial support for the Porto Theme, without warranty.

You might want to try this layout update in default.xml of your child theme:

<page xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../../../../../../../lib/internal/Magento/Framework/View/Layout/etc/page_configuration.xsd">
    <body>
        <referenceContainer name="porto_header">
            <block class="Magento\Store\Block\Switcher" name="store_language" as="store_language" template="IMI_StoreSwitch::switch/languages-porto.phtml">
                <arguments>
                    <argument name="view_model" xsi:type="object">IMI\StoreSwitch\ViewModel\StoreSwitchModel</argument>
                </arguments>
                <action method="setTemplate" ifconfig="imi_store_switch/general/use_direct_links">
                    <argument name="template" xsi:type="string">IMI_StoreSwitch::switch/direct/languages-porto.phtml</argument>
                </action>
            </block>
        </referenceContainer>
    </body>
</page>

Hyvä Theme

This has partial support for the Hyvä Theme, without warranty.

License

© 2020 iMi digital GmbH. Licensed under MIT.