Ibnab release new Magento 2 extension for Paytabs , This extends Magento2 to accepts money/payments through PayTabs . PayTabs is a Middle East based Payment GatewayRead more
The search use 3 request name in magento 2 :
'quick_search_container' when you search from the small field text in the top
'advanced_search_container' when you use the advanced search page
'catalog_view_container' when you entre to category page or use filter in category page it's work by default
inside class Magento\Framework\Search\Search the function search(SearchCriteriaInterface $searchCriteria) build a request with class Magento\Framework\Search\Request\Builder; it's start by puched in object $this→requestBuilder the query name example 'quick_search_container'Read more
For customize behavior of search you need know the mechanism of how Magento 2 stock and collect infos and how used it, Now in Magento 2 we have in database catalogsearch_fulltext_scope1 and catalogsearch_fulltext_scope2 related to how many scope you have let's imagine you have 2 store one for English and other for Arabic , the system create 2 scope . And stock the map of search inside this tables , bot how ? Yeah let's go and see the structure of table ,this table have 3columns entity_id and atrribute_id and data_indexRead more
After see many frontend developers peoples search for how call gallery in product list page , we decide to write small course (tutorial) for how done this task .Ok first you need create class helper inside your module , for example Ibnab/Common/Helper/Data.php and push the codeRead more
The checkout process in Magento 2 it's more practice and more abstracted with new generation ideas of user experience , in this course ibnab try to give you some key for customize the checkout page .
Saw the system use component for create and manage the page checkout, it's start from the layout checkout_index_index.xml in path vendor/magento/module-checkout/view/frontend/layoutRead more
Ok the new generation of ui grid in magento 2 give you the ability to create or change grid with xml file, this xml use extern php file for getting all part needed .
Our example here is the grid action like edit in catalog product grid or delete preview in page cms grid ,
ok we want add custom action .
Ok the xml responsible for ui grid of product list in backend is vendor/magento/module-catalog/view/adminhtml/ui_component/product_listing.xml , and for action you will inside this file :Read more
Without high technical knowledge , Easy Mega Menu give you the ability to create an organized menu ,
You have a lot of products , give a best user experience to customer :
Manual installation :
download from store
past in your folder app/code
enable extension in app/etc/config.php by adding 'Ibnab_MegaMenu' => 1,
and execute the command php bin/magento setup:upgrade
and execute the command rm -rf var/view_preprocessed/ pub/static
and execute the command php bin/magento setup:static-content:deployRead more
In the world of the big business appear Oracle ATG Commerce , in many statistic It occupies an advanced position , yes the Magento 1 It has several elements to accommodate large-scale projects and it needs , But it lacks the tools by which tasks are separated, and the removal of conflict, the user experience in admin, default unit test tool , it's real and flexible system but with old mechanism , In Ibnab we think the Magento 2 is here for taking advanced position in this domain of big business and large-scale projects .Read more
In magento 2 paypal is implemented with module Payal , in case if the customer choose payapl as method of payment M2 use Magento\Paypal\Model\Cart in place of \Magento\Payment\Model\Cart , it used for collect items and amount and validate the infos collected before sending to paypal ,
The model have more additional methods as (it extend from parent Magento\Paypal\Model\Cart) :
getAmounts() : Get shipping, tax, subtotal and discount amounts all together
_validate( ) : Check the line items and totals according to PayPal business logic limitations
_importItemsFromSalesModel() : Import items from sales model with workarounds for PayPal
Yeah after collecting the amounts and validate let's consider we choose Paypal express , the checkout redirect the function Paypal/Controller/Express/Start Action but inside this action it use the global Api class Model/Api/Nvp.phpRead more
Magento 2 have some difficult for speed up workshop in frontend developement , the community try to find a solution for that this tutorials is introduction for using gulp with magento 2 .Read more
Magento 2 comes with many technique already exist in version 1 but with new way for implementing , one of this flexible tables (grids) in the system configuration.
We imagine you have created module , we started from system.xml inside Ibnab/Table/etc/adminhtml/system.xmlRead more
This course of series give you the ability for creating your own model resource and collection , ok let's imagine you want create a simple module for persist some data like brand infos for example .
1 – Create :
First we need create our table inside our database for that you need create the Setup folder ,The path complete of module is Ibnab/Brand , inside Setup folder create file InstallSchema.php and fill with :Read more
Magento 2 import export module give you the ability to implement it behavior(standard system export import) with simple xml and general adapter . Some point before stated :
A – For import you need create import.xml inside etc of your module
B : You can create just import without export
C : Standard place to show of your import module is form menu system→export or system→ import .
Magento 2 allow you to add custom field form as type image , for example when you click in edit link inisde grid you have edit page you can add from fields .Read more
EAV system in Magento 2 almost similar to Magento 1 but many function and technique is changed , in this tutorials we give you 2 example of how adding custom eav attribute to category or customer .
1 – Create custom attribute for category :
Go to your model and create Setup folder , inside it create file InstallData.php and push this full code :Read more
M2 system use for read and execute (scriptSelector = 'script[type="text/x-magento-init"]' and dataAttr = 'data-mage-init' ) many js file like vendor/magento/magento2-base/lib/web/mage/apply/main.js and scripts.js and vendor/magento/magento2-base/lib/web/mage /mage.js
you can find vendor/magento/magento2-base/lib/web/mage
in normal case you can declare as virtual :
1 - Infos About Store
Get Current store Id :
inject \Magento\Store\Model\StoreManagerInterface $storeManage
$this->storeManager = $storeManager;
and get the id with :
$id = $this->storeManager->getStore()->getId();
get base Url :
$baseUrl = $this->storeManager->getStore()->getBaseUrl();
Magento 2 Action allow the developers using $request $response and $resultRedirectFactory objects without injecting (DI) by hand .
By extending \Magento\Backend\App\Action for backend action case or \Magento\Framework\App\Action\Action for global case , you have $request $response and $resultRedirectFactory .
1 – Request :
the top level parent class of action is Magento\Framework\App\Action\AbstractAction , AbstractAction injected by di with \Magento\Framework\App\Action\Context $context .Read more
Magento 2 have flexible technique for manage Ui , have by default jQuery included , the teams of M2 include requirejs too on core , we call js with asynchronous method .
This tutorial give you in practice the ability of :
- - call js with requirejs
- - create custom js for manage ui .
- - use jquery widgets
- - create requrejs-config.js
- - additional technique like work with frontend_model button_url and attribute tags ,pass params between frontend_model and .phtml
In first tutorial we introduce the creation of system configuration , in this course we explain how set and get the value (play with configuration).
1 – Set Value Configuration :
You can set the value of specific field inside stores configuration , by using the interface \ \Magento\Framework\App\Config\MutableScopeConfigInterface , (magento2 by calling this interface with technique of preference give you as result a MutableScopeConfig class instance)
inject the class to controller or helper or block or anywhere :
in Magento2 the global architecture of system configuration is changed but the vision is the same !
Add global configuration by website store or store view and use inside you code for enable disable or other choices .
In the first course we introduce the creation if system configuration.
“knockoutjs” , yes observe and change data with easy and structured way (HTML data bindings). In this tutorial will be introduce "Virtual elements" <!-- ko --> <!-- /ko -->.
knockoutjs work with two type of element Normal node and Comment node '"Virtual elements" is an abstraction on top of the usual DOM API which understands the notion that comment nodes' , The point of all this is to support containerless templates (e.g., <!-- ko foreach:someCollection -->blah<!-- /ko -->)
if you play inside .phtml files you will finding <!-- ko --> anywhere , but in this tutorial we want analyze <!-- ko template: getTemplate() --> .
Many Magento users search to change attribute set of product to other targer attribute set ,Now you can use mass function for done this operation just with few click .
- mass operation
- guard configurable product (you can define from system configuration if you want add automaticly the mised configurable attirbute to taget attribute set or ignore operation )
- dynamic TreeMassAction (get attribute set list from db)
Our new Extension Magento 2Change Attribute Set and work perfectly (Free and Open Source) , you can select in grid all products wanted andd apply mass action to change ….
Wooow we like inside our team Ibnab this new technique of magento2 MassAction and TreeMassAction just with few lines inside XML you have as result the massaction injected , flexible and configurable technique .
Ok how use massaction ? you can find The response inside official Magento2 doc for example this link for MassAction:
And other for TreeMassAction:
Official documentation explain to you what is it and how use …. but for the static case =
you enter all actions with your hand … in inverse imagine you have collections of customers you want setting him to specific group , and as you know the customer group inside magento is dynamic, how you can do? This is real case in magento, go to grid of customer and click on top MassAction
Magento 2 give you the ability of starting your theme on top of existing theme or start from scratch , Magento 2 now use the technique of .less and processed it for give you the css result here you will find:
- Create you theme on base of blank theme
- How create your custom home page
- Where is magento 2 stock all theme in db
- Change logo
- Change color with variable less (and small explain of how structured)
- Use layout
command for creating the files :
php bin/magento setup:static-content:deploy
your _theme.less for ovirride the clolor exict inside this path :