AbstractSidebar.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Sales\Block\Adminhtml\Order\Create\Sidebar;
  7. use Magento\Framework\Pricing\PriceCurrencyInterface;
  8. /**
  9. * Adminhtml sales order create sidebar block
  10. *
  11. * @api
  12. * @author Magento Core Team <core@magentocommerce.com>
  13. * @since 100.0.2
  14. */
  15. class AbstractSidebar extends \Magento\Sales\Block\Adminhtml\Order\Create\AbstractCreate
  16. {
  17. /**
  18. * Default Storage action on selected item
  19. *
  20. * @var string
  21. */
  22. protected $_sidebarStorageAction = 'add';
  23. /**
  24. * Sales config
  25. *
  26. * @var \Magento\Sales\Model\Config
  27. */
  28. protected $_salesConfig;
  29. /**
  30. * @param \Magento\Backend\Block\Template\Context $context
  31. * @param \Magento\Backend\Model\Session\Quote $sessionQuote
  32. * @param \Magento\Sales\Model\AdminOrder\Create $orderCreate
  33. * @param PriceCurrencyInterface $priceCurrency
  34. * @param \Magento\Sales\Model\Config $salesConfig
  35. * @param array $data
  36. */
  37. public function __construct(
  38. \Magento\Backend\Block\Template\Context $context,
  39. \Magento\Backend\Model\Session\Quote $sessionQuote,
  40. \Magento\Sales\Model\AdminOrder\Create $orderCreate,
  41. PriceCurrencyInterface $priceCurrency,
  42. \Magento\Sales\Model\Config $salesConfig,
  43. array $data = []
  44. ) {
  45. parent::__construct($context, $sessionQuote, $orderCreate, $priceCurrency, $data);
  46. $this->_salesConfig = $salesConfig;
  47. }
  48. /**
  49. * Return name of sidebar storage action
  50. *
  51. * @return string
  52. */
  53. public function getSidebarStorageAction()
  54. {
  55. return $this->_sidebarStorageAction;
  56. }
  57. /**
  58. * Retrieve display block availability
  59. *
  60. * @return bool
  61. */
  62. public function canDisplay()
  63. {
  64. return $this->getCustomerId();
  65. }
  66. /**
  67. * Retrieve display item qty availability
  68. *
  69. * @return false
  70. */
  71. public function canDisplayItemQty()
  72. {
  73. return false;
  74. }
  75. /**
  76. * Retrieve availability removing items in block
  77. *
  78. * @return true
  79. */
  80. public function canRemoveItems()
  81. {
  82. return true;
  83. }
  84. /**
  85. * Retrieve identifier of block item
  86. *
  87. * @param \Magento\Framework\DataObject $item
  88. * @return int
  89. */
  90. public function getIdentifierId($item)
  91. {
  92. return $item->getProductId();
  93. }
  94. /**
  95. * Retrieve item identifier of block item
  96. *
  97. * @param \Magento\Framework\DataObject $item
  98. * @return int
  99. */
  100. public function getItemId($item)
  101. {
  102. return $item->getId();
  103. }
  104. /**
  105. * Retrieve product identifier linked with item
  106. *
  107. * @param \Magento\Framework\DataObject $item
  108. * @return int
  109. */
  110. public function getProductId($item)
  111. {
  112. return $item->getId();
  113. }
  114. /**
  115. * Retrieve item count
  116. *
  117. * @return int
  118. */
  119. public function getItemCount()
  120. {
  121. $count = $this->getData('item_count');
  122. if ($count === null) {
  123. $count = count($this->getItems());
  124. $this->setData('item_count', $count);
  125. }
  126. return $count;
  127. }
  128. /**
  129. * Retrieve all items
  130. *
  131. * @return array
  132. * @SuppressWarnings(PHPMD.CyclomaticComplexity)
  133. */
  134. public function getItems()
  135. {
  136. $items = [];
  137. $collection = $this->getItemCollection();
  138. if ($collection) {
  139. $productTypes = $this->_salesConfig->getAvailableProductTypes();
  140. if (is_array($collection)) {
  141. $items = $collection;
  142. } else {
  143. $items = $collection->getItems();
  144. }
  145. /*
  146. * Filtering items by allowed product type
  147. */
  148. foreach ($items as $key => $item) {
  149. if ($item instanceof \Magento\Catalog\Model\Product) {
  150. $type = $item->getTypeId();
  151. } elseif ($item instanceof \Magento\Sales\Model\Order\Item) {
  152. $type = $item->getProductType();
  153. } elseif ($item instanceof \Magento\Quote\Model\Quote\Item) {
  154. $type = $item->getProductType();
  155. } else {
  156. $type = '';
  157. // Maybe some item, that can give us product via getProduct()
  158. if ($item instanceof \Magento\Framework\DataObject || method_exists($item, 'getProduct')) {
  159. $product = $item->getProduct();
  160. if ($product && $product instanceof \Magento\Catalog\Model\Product) {
  161. $type = $product->getTypeId();
  162. }
  163. }
  164. }
  165. if (!in_array($type, $productTypes)) {
  166. unset($items[$key]);
  167. }
  168. }
  169. }
  170. return $items;
  171. }
  172. /**
  173. * Retrieve item collection
  174. *
  175. * @return false
  176. */
  177. public function getItemCollection()
  178. {
  179. return false;
  180. }
  181. /**
  182. * Retrieve display price availability
  183. *
  184. * @return true
  185. */
  186. public function canDisplayPrice()
  187. {
  188. return true;
  189. }
  190. /**
  191. * Get item qty
  192. *
  193. * @param \Magento\Framework\DataObject $item
  194. * @return int
  195. */
  196. public function getItemQty(\Magento\Framework\DataObject $item)
  197. {
  198. return $item->getQty() * 1 ? $item->getQty() * 1 : 1;
  199. }
  200. /**
  201. * Check whether product configuration is required before adding to order
  202. *
  203. * @param string|int|null $productType
  204. * @return false
  205. * @SuppressWarnings(PHPMD.UnusedFormalParameter)
  206. */
  207. public function isConfigurationRequired($productType)
  208. {
  209. return false;
  210. }
  211. }