123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Sales\Model\Order\Status;
- use Magento\Framework\Api\AttributeValueFactory;
- use Magento\Sales\Api\Data\OrderStatusHistoryInterface;
- use Magento\Sales\Model\AbstractModel;
- /**
- * Order status history comments
- *
- * @api
- * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
- * @since 100.0.2
- */
- class History extends AbstractModel implements OrderStatusHistoryInterface
- {
- const CUSTOMER_NOTIFICATION_NOT_APPLICABLE = 2;
- /**
- * Order instance
- *
- * @var \Magento\Sales\Model\Order
- */
- protected $_order;
- /**
- * @var string
- */
- protected $_eventPrefix = 'sales_order_status_history';
- /**
- * @var string
- */
- protected $_eventObject = 'status_history';
- /**
- * @var \Magento\Store\Model\StoreManagerInterface
- */
- protected $_storeManager;
- /**
- * @param \Magento\Framework\Model\Context $context
- * @param \Magento\Framework\Registry $registry
- * @param \Magento\Framework\Api\ExtensionAttributesFactory $extensionFactory
- * @param AttributeValueFactory $customAttributeFactory
- * @param \Magento\Store\Model\StoreManagerInterface $storeManager
- * @param \Magento\Framework\Model\ResourceModel\AbstractResource $resource
- * @param \Magento\Framework\Data\Collection\AbstractDb $resourceCollection
- * @param array $data
- * @SuppressWarnings(PHPMD.ExcessiveParameterList)
- */
- public function __construct(
- \Magento\Framework\Model\Context $context,
- \Magento\Framework\Registry $registry,
- \Magento\Framework\Api\ExtensionAttributesFactory $extensionFactory,
- AttributeValueFactory $customAttributeFactory,
- \Magento\Store\Model\StoreManagerInterface $storeManager,
- \Magento\Framework\Model\ResourceModel\AbstractResource $resource = null,
- \Magento\Framework\Data\Collection\AbstractDb $resourceCollection = null,
- array $data = []
- ) {
- parent::__construct(
- $context,
- $registry,
- $extensionFactory,
- $customAttributeFactory,
- $resource,
- $resourceCollection,
- $data
- );
- $this->_storeManager = $storeManager;
- }
- /**
- * Initialize resource model
- *
- * @return void
- */
- protected function _construct()
- {
- $this->_init(\Magento\Sales\Model\ResourceModel\Order\Status\History::class);
- }
- /**
- * Set order object and grab some metadata from it
- *
- * @param \Magento\Sales\Model\Order $order
- * @return $this
- */
- public function setOrder(\Magento\Sales\Model\Order $order)
- {
- $this->_order = $order;
- $this->setStoreId($order->getStoreId());
- return $this;
- }
- /**
- * Notification flag
- *
- * @param mixed $flag OPTIONAL (notification is not applicable by default)
- * @return $this
- */
- public function setIsCustomerNotified($flag = null)
- {
- if ($flag === null) {
- $flag = self::CUSTOMER_NOTIFICATION_NOT_APPLICABLE;
- }
- return $this->setData('is_customer_notified', $flag);
- }
- /**
- * Customer Notification Applicable check method
- *
- * @return boolean
- */
- public function isCustomerNotificationNotApplicable()
- {
- return $this->getIsCustomerNotified() == self::CUSTOMER_NOTIFICATION_NOT_APPLICABLE;
- }
- /**
- * Retrieve order instance
- *
- * @codeCoverageIgnore
- *
- * @return \Magento\Sales\Model\Order
- */
- public function getOrder()
- {
- return $this->_order;
- }
- /**
- * Retrieve status label
- *
- * @return string|null
- */
- public function getStatusLabel()
- {
- if ($this->getOrder()) {
- return $this->getOrder()->getConfig()->getStatusLabel($this->getStatus());
- }
- return null;
- }
- /**
- * Get store object
- *
- * @return \Magento\Store\Model\Store
- */
- public function getStore()
- {
- if ($this->getOrder()) {
- return $this->getOrder()->getStore();
- }
- return $this->_storeManager->getStore();
- }
- /**
- * Set order again if required
- *
- * @return $this
- */
- public function beforeSave()
- {
- parent::beforeSave();
- if (!$this->getParentId() && $this->getOrder()) {
- $this->setParentId($this->getOrder()->getId());
- }
- return $this;
- }
- //@codeCoverageIgnoreStart
- /**
- * Returns comment
- *
- * @return string
- */
- public function getComment()
- {
- return $this->getData(OrderStatusHistoryInterface::COMMENT);
- }
- /**
- * Returns created_at
- *
- * @return string
- */
- public function getCreatedAt()
- {
- return $this->getData(OrderStatusHistoryInterface::CREATED_AT);
- }
- /**
- * {@inheritdoc}
- */
- public function setCreatedAt($createdAt)
- {
- return $this->setData(OrderStatusHistoryInterface::CREATED_AT, $createdAt);
- }
- /**
- * Returns entity_id
- *
- * @return int
- */
- public function getEntityId()
- {
- return $this->getData(OrderStatusHistoryInterface::ENTITY_ID);
- }
- /**
- * Returns entity_name
- *
- * @return string
- */
- public function getEntityName()
- {
- return $this->getData(OrderStatusHistoryInterface::ENTITY_NAME);
- }
- /**
- * Returns is_customer_notified
- *
- * @return int
- */
- public function getIsCustomerNotified()
- {
- return $this->getData(OrderStatusHistoryInterface::IS_CUSTOMER_NOTIFIED);
- }
- /**
- * Returns is_visible_on_front
- *
- * @return int
- */
- public function getIsVisibleOnFront()
- {
- return $this->getData(OrderStatusHistoryInterface::IS_VISIBLE_ON_FRONT);
- }
- /**
- * Returns parent_id
- *
- * @return int
- */
- public function getParentId()
- {
- return $this->getData(OrderStatusHistoryInterface::PARENT_ID);
- }
- /**
- * Returns status
- *
- * @return string
- */
- public function getStatus()
- {
- return $this->getData(OrderStatusHistoryInterface::STATUS);
- }
- /**
- * {@inheritdoc}
- */
- public function setParentId($id)
- {
- return $this->setData(OrderStatusHistoryInterface::PARENT_ID, $id);
- }
- /**
- * {@inheritdoc}
- */
- public function setIsVisibleOnFront($isVisibleOnFront)
- {
- return $this->setData(OrderStatusHistoryInterface::IS_VISIBLE_ON_FRONT, $isVisibleOnFront);
- }
- /**
- * {@inheritdoc}
- */
- public function setComment($comment)
- {
- return $this->setData(OrderStatusHistoryInterface::COMMENT, $comment);
- }
- /**
- * {@inheritdoc}
- */
- public function setStatus($status)
- {
- return $this->setData(OrderStatusHistoryInterface::STATUS, $status);
- }
- /**
- * {@inheritdoc}
- */
- public function setEntityName($entityName)
- {
- return $this->setData(OrderStatusHistoryInterface::ENTITY_NAME, $entityName);
- }
- /**
- * {@inheritdoc}
- *
- * @return \Magento\Sales\Api\Data\OrderStatusHistoryExtensionInterface|null
- */
- public function getExtensionAttributes()
- {
- return $this->_getExtensionAttributes();
- }
- /**
- * {@inheritdoc}
- *
- * @param \Magento\Sales\Api\Data\OrderStatusHistoryExtensionInterface $extensionAttributes
- * @return $this
- */
- public function setExtensionAttributes(
- \Magento\Sales\Api\Data\OrderStatusHistoryExtensionInterface $extensionAttributes
- ) {
- return $this->_setExtensionAttributes($extensionAttributes);
- }
- //@codeCoverageIgnoreEnd
- }
|