| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- <?php
- namespace App\Services;
- use App\Logistic;
- use App\OracleActAllocationDetails;
- use App\OracleBasCustomer;
- use App\OracleDOCASNHeader;
- use App\OracleDOCOrderDetail;
- use App\OracleDOCOrderHeader;
- use App\Order;
- use App\OrderItems;
- use App\OrderPackage;
- use App\OrderPackageCommodities;
- use App\Owner;
- use App\RejectedBill;
- use App\Shop;
- class OrderService
- {
- public function __construct()
- {
- app()->bind("orderPackageService", OrderPackageService::class);
- }
- public function findOrCreateByClientCode($clientCode)
- {
- $order = Order::where('client_code', $clientCode)->first();
- $orderHeader = OracleDOCOrderHeader::where('SOREFERENCE1', $clientCode)->first();
- if ($orderHeader == null) {
- return null;
- }
- $orderHeadAttr = $orderHeader->toArray();
- if ($order == null) {
- $customer_name = $orderHeadAttr['oracleBASCustomer_descr_c'];
- $owner = Owner::where('code', $orderHeadAttr['customerid'])->first();
- if (!$owner) {
- $owner = Owner::create(['code' => $orderHeadAttr['customerid'], 'name' => $customer_name]);
- }
- $owner_id = $owner['id'];
- $shop_name = $orderHeadAttr['issuepartyname'];
- $shop_Id = null;
- if ($shop_name) {
- $shop = Shop::firstOrCreate(['name' => $shop_name, 'owner_id' => $owner_id]);
- $shop_Id = $shop['id'];
- }
- $logistics = Logistic::where(['code' => $orderHeadAttr['carrierid']])->first();
- $logistics_id = null;
- if ($logistics) {
- $logistics_id = $logistics['id'];
- } else {
- $logistics = Logistic::create(['name'=>$orderHeadAttr['carriername'],'code'=>$orderHeadAttr['carrierid']]);
- $logistics_id = $logistics['id'];
- }
- $arr = [
- 'code' => $orderHeadAttr['orderno'],
- 'owner_id' => $owner_id,
- 'wms_status' => $orderHeadAttr['oracleBASCode_codename_c'],
- 'created_at' => $orderHeadAttr['addtime'],
- 'logistic_id' => $logistics_id,
- 'shop_id' => $shop_Id,
- 'consignee_name' => $orderHeadAttr['c_contact'],
- 'consignee_phone' => $orderHeadAttr['c_tel2'],
- 'province' => $orderHeadAttr['c_province'],
- 'city' => $orderHeadAttr['c_city'],
- 'district' => $orderHeadAttr['c_district'],
- 'address' => $orderHeadAttr['c_address1'],
- 'client_code' => $orderHeadAttr['soreference1'],
- ];
- $order = Order::create($arr);
- $orderPackageService = app('orderPackageService');
- $orderPackageService->createdByOrder($order);
- }
- return $this->getOrderInfo($order['id']);
- }
- public function getOrderInfo($orderId)
- {
- return Order::with(['packages' => function ($query) {
- return $query->with(['commodities' => function ($query) {
- return $query->with(['commodity']);
- }]);
- }])->where('id', $orderId)->first();
- }
- public function getRejectedBillOfClientCode($clientCode)
- {
- $orderHeader = OracleDOCOrderHeader::where('SOReference1', $clientCode)->first();
- if (!$orderHeader) {
- return null;
- }
- $ASNHeader = OracleDOCASNHeader::where('ASNReference2', $orderHeader->soreference2)->first();
- if (!$ASNHeader) {
- return null;
- }
- return RejectedBill::with(['owner', 'logistic', 'items'])->where('logistic_number_return', $ASNHeader->asnreference2)->first();
- }
- public function findOrCreteByLogisticNumberReturn($logisticNumberReturn)
- {
- $ASNHeader = OracleDOCASNHeader::where('ASNReference3', $logisticNumberReturn)->first();
- if (!$ASNHeader) {
- return null;
- }
- $orderHeader = OracleDOCOrderHeader::where('SOReference1', $ASNHeader->ASNReference2);
- if (!$orderHeader) {
- return null;
- }
- return $this->findOrCreateByClientCode($orderHeader[soreference1]);
- }
- }
|