mirror of
https://github.com/retailcrm/prestashop-module.git
synced 2025-03-02 19:33:14 +03:00
61 lines
3.5 KiB
Markdown
61 lines
3.5 KiB
Markdown
[data:image/s3,"s3://crabby-images/b7ee1/b7ee1af4e7b252f9694f3ac63b7df79898dbbe67" alt="Build Status"](https://github.com/retailcrm/prestashop-module/actions)
|
|
[data:image/s3,"s3://crabby-images/2877d/2877df421ac5f746048b35dcf87617e2694ecff9" alt="Coverage"](https://codecov.io/gh/retailcrm/prestashop-module)
|
|
[data:image/s3,"s3://crabby-images/3a060/3a060cf97da0d3ced5d07a7f6a19a4d2b5b78613" alt="GitHub release"](https://github.com/retailcrm/prestashop-module/releases)
|
|
[data:image/s3,"s3://crabby-images/46884/468848289639cb3bdedf680c242037043c07cfab" alt="PHP version"](https://php.net/)
|
|
|
|
Prestashop module.
|
|
=================
|
|
|
|
Module allows integrate CMS Prestashop with [Simla.com](https://www.retailcrm.pro) ([Documentation](https://docs.retailcrm.ru/Users/Integration/SiteModules/PrestaShop) page)
|
|
|
|
#### Features:
|
|
|
|
* Export orders to Simla.com & fetch changes back
|
|
* Export product catalog into [ICML](https://help.retailcrm.pro/Developers/ICML) format
|
|
|
|
#### Setup
|
|
|
|
* Go to module setup page
|
|
* Fill you api url & api key
|
|
* Specify directories matching
|
|
|
|
#### Notice
|
|
|
|
* This release contains an experimental feature "corporate customers". Use at your own risk.
|
|
* This release only supports Simla.com API v5.
|
|
|
|
#### Customization
|
|
|
|
##### Filters
|
|
|
|
If you want to modify data, sent between CRM and CMS you can use custom filters.
|
|
There are list of available filters:
|
|
|
|
* *RetailcrmFilterProcessOrder* - order array, which will be sent to CRM
|
|
* *RetailcrmFilterProcessCustomer* - customer array, which will be sent to CRM
|
|
* *RetailcrmFilterProcessCustomerCorporate* - corporate customer array, which will be sent to CRM
|
|
* *RetailcrmFilterProcessAddress* - address array, which will be sent to CRM
|
|
* *RetailcrmFilterProcessOffer* - offer array, which will be sent to CRM (saved into Icml file)
|
|
|
|
* *RetailcrmFilterCustomersHistory* - array with assembled history for customer, loaded from CRM
|
|
* *RetailcrmFilterOrdersHistory* - array with assembled history for order, loaded from CRM
|
|
|
|
* *RetailcrmFilterSaveCustomer* - built customer object, which will be saved to CMS
|
|
* *RetailcrmFilterSaveCustomerAddress* - built customer address object, which will be saved to CMS
|
|
* *RetailcrmFilterSaveCorporateCustomer* - built corporate customer object, which will be saved to CMS
|
|
* *RetailcrmFilterSaveCorporateCustomerAddress* - built corporate customer address object, which will be saved to CMS
|
|
|
|
To use filters you should define a new class in `<prestashop-root>/modules/retailcrm/custom/hooks`. Filename and classname must match the filter name.
|
|
Filter class should implement interface *RetailcrmFilterInterface*. In filter class you must define *filter()* function, which will take initial `$object` and return customized `$object`.
|
|
|
|
##### Classes
|
|
|
|
If you want to change the default behavior of a module classes and be sure that these changes won't be overwritten during the module upgrade process, you should **copy the original classes** that you are going to customize to the `<prestashop-root>/modules/retailcrm/custom/classes` directory.
|
|
|
|
From here you can modify the methods of the classes for your own purposes, and they will not be affected during the module upgrade process.
|
|
|
|
Keep in mind that:
|
|
|
|
* If the logic and classes of the module have changed a lot after an upgrade, your customized logic may cause the module to malfunction. **You should always check for changes after an upgrade and update your customized classes if needed.**
|
|
* This feature does not allow to customize the base class (file `retailcrm.php`). For this you can use the standard Prestashop override feature.
|