![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/app/code/Cnc/Sales/Ui/Component/Listing/Column/ |
<?php /** * Copyright (c) 2022 Kaliop Digital Commerce (https://digitalcommerce.kaliop.com) All Rights Reserved. * https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) * Cnc * Radosław Stępień <[email protected]> <[email protected]> */ namespace Cnc\Sales\Ui\Component\Listing\Column; use Magento\Framework\App\ResourceConnection; use Magento\Framework\View\Element\UiComponent\ContextInterface; use Magento\Framework\View\Element\UiComponentFactory; use Magento\Ui\Component\Listing\Columns\Column; class Sku extends Column { /** * @var ResourceConnection */ private $resourceConnection; /** * @param ContextInterface $context * @param UiComponentFactory $uiComponentFactory * @param ResourceConnection $resourceConnection * @param array $components * @param array $data */ public function __construct( ContextInterface $context, UiComponentFactory $uiComponentFactory, ResourceConnection $resourceConnection, array $components = [], array $data = [] ) { parent::__construct($context, $uiComponentFactory, $components, $data); $this->resourceConnection = $resourceConnection; } /** * @param array $dataSource * @return array */ public function prepareDataSource(array $dataSource) { if (isset($dataSource['data']['items'])) { foreach ($dataSource['data']['items'] as & $item) { $skus = $this->resourceConnection ->getConnection() ->fetchOne(' SELECT GROUP_CONCAT(`sku` SEPARATOR " & ") FROM `sales_order_item` LEFT JOIN `sales_order` ON `sales_order_item`.`order_id` = `sales_order`.`entity_id` WHERE `sales_order_item`.`order_id` = '.$item['entity_id'].' GROUP BY `sales_order_item`.`order_id` '); $item[$this->getData('name')] = $skus ?: ''; } } return $dataSource; } }