params = $params; } public function array(): array { $result = [[ '商品ID', '商品名称', '市场', '店铺', '售价(元)', '采购价(元)', '下单时间', '销量(单)', '补贴(元)', ]]; $data = $this->getData($this->params); $markets = MarketModel::getMarketArray(); $stores = StoreModel::getStoreArray(); foreach ($data as $value){ $createdAt = $value['created_at']??0; $item = [ $value['goods_id'], $value['name']??'', $markets[$value['market_id']]??'', $stores[$value['store_id']]??'', $value['price']??0, $value['purchase_price']??0, date('Y-m-d H:i:s',$createdAt), $value['total']??0, $value['subsidy_total']??0 ]; $result[] = $item; } return $result; } /** * 获取数据 */ public function getData($option = []) { $params = $option; $repository = new GoodsActivityReport(); $selects = OrderGoodsModel::$tableName.'.number as total,('.GoodsActivityModel::TABLE_NAME.'.purchase_price-'.GoodsActivityModel::TABLE_NAME.'.price)*'.OrderGoodsModel::$tableName.'.number as subsidy_total,'.GoodsActivityModel::TABLE_NAME.'.price,'.GoodsActivityModel::TABLE_NAME.'.purchase_price,'.OrderGoodsModel::$tableName.'.goods_id,'.OrderGoodsModel::$tableName.'.name,'.OrderGoodsModel::$tableName.'.cover_img,'.OrderGoodsModel::$tableName.'.created_at,'.OrderMainModel::$tableName.'.market_id,'.OrderModel::$tableName.'.store_id'; $orderGoodsActivity = $repository->getDataModel($selects,$params); $list = $orderGoodsActivity->orderBy('total','desc')->get()->toArray(); return $list; } }