sima-land / delivery-calculator
Delivery calculator for sima-land.ru
Installs: 4 043
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 8
Forks: 2
Open Issues: 0
Requires
- php: >=7.0
Requires (Dev)
- dev-master
- 2.1.0-rc6
- 2.1.0-rc5
- 2.1.0-rc4
- 2.1.0-rc3
- 2.1.0-rc2
- 2.1.0-rc1
- 2.0.1
- 2.0.0
- 2.0.0-rc1
- 1.0.1
- 1.0.0
- 1.0.0-rc1
- dev-SL-8022
- dev-SL-7442
- dev-SL-7441
- dev-analysis-87L4pj
- dev-bugfix/SL-7538-in_box-product_volume
- dev-pastuhov-patch-4
- dev-SL-7517
- dev-pastuhov-patch-3
- dev-SL-7231
- dev-pastuhov-patch-1
- dev-pastuhov-patch-2
- dev-SL-6809-2
- dev-analysis-qJb0RE
- dev-SL-6809
- dev-analysis-Xl0bpw
- dev-analysis-XkEwjG
- dev-analysis-Xl0MKW
- dev-first-version
This package is not auto-updated.
Last update: 2024-12-21 21:36:42 UTC
README
Основным способом расчета стоимости доставки является использование API https://www.sima-land.ru/api/v3/help/#Стоимость-доставки
Однако в ряду случаев предпочтительно рассчитывать стоимость доставки без использования API. Например:
- Количество запросов к API не укладывается в установленные лимиты.
- Требуемая скорость работы не позволяет ожидать ответа от API.
В описанных выше случаях рекомендуется использовать данный компонент, который позволяет вычислять стоимость доставки "на лету".
Для расчета стоимости доставки товара необходимо три сущности:
- Точка доставки - объект, реализующий PointInterface
- Товар - объект, реализующий ItemInterface
- Источник данных о коэффициентах упаковки - объект, реализующий VolumeFactorSourceInterface
Для того, чтобы произвести расчёт стоимости доставки товара, необходимо создать объект класса калькулятора с указанием точки доставки и коэффициентов упаковки.
$calc = new Calculator($defaultVolumeFactor, $point, false)
Третий аргумент обозначает признак "локальности" точки по отношению к складу. Если true
, то доставка будет
считаться бесплатной для всех товаров кроме тех, у которых метод isPaidDeliveryLocal()
возвращает true
Для добавления товара к расчёту стоимости доставки используется функция addItem($item, $qty)
,
для получения результатов - getResult()
. Для того, чтобы обнулить результат, используйте reset()
.
В случае ошибки метод addItem($item, $qty)
вернет false. Информацию об ошибках после этого можно
посмотреть с помощью метода getErrors()
.
Пример:
$calc->addItem($item1, 10) $calc->addItem($item2, 1000) echo $calc->getResult(); // вывод стоимости доставки item1 10 шт. и item2 1000 шт. $calc->reset(); $calc->addItem($item3, 1) echo $calc->getResult(); // вывод стоимости доставки item3 1 шт. // $item4->getWeight() = 0 if (!$calc->addItem($item4, 1000)) { return $calc->getErrors() // ['Weight must be positive, weight=0'] }
Точка доставки
Точку доставки представляет объект, реализующий PointInterface, данные по большинству городов доставки можно получить по API https://www.sima-land.ru/api/v3/help/#Города-доставки
Особые случаи:
- Расчёт стоимости доставки до пункта самовывоза в г. Москва осуществляется с помощью класса MoscowPointAbstract.
Нужно расширить этот класс, переопределив метод
hasDiscount
- При расчёте доставки в г. Екатеринбург признак "локальности" должен быть
true
Товар
Все данные для реализации ItemInterface можно получить по API https://www.sima-land.ru/api/v3/help/#Товар
Данные о коэффициентах упаковки
Данные о коэффициентах упаковки представляет объект, реализующий VolumeFactorSourceInterface. Можно воспользоваться готовой реализацией модели DefaultVolumeFactorSource