JDDeliveryService.php 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. namespace App\Services;
  3. use App\OracleDocOrderDeliveryInfo;
  4. use App\OracleDOCOrderHeader;
  5. use App\OwnerLogisticPrintTemplate;
  6. use App\Services\Interfaces\DeliveryInterface;
  7. use App\Traits\DrawImage;
  8. use Illuminate\Database\Query\Builder;
  9. use Illuminate\Support\Str;
  10. class JDDeliveryService implements DeliveryInterface
  11. {
  12. use DrawImage;
  13. function getDeliveryInfo($logistic_number)
  14. {
  15. return OracleDOCOrderHeader::query()->whereIn('deliveryno',$logistic_number)
  16. ->where('consigneeId',"JD")
  17. ->get()->map(function($item){
  18. return [
  19. // TODO 需要动态获取面单获取的组件 TYPE
  20. 'type' => 'JD',
  21. 'is_process' => false,
  22. 'task_id' => Str::uuid(),
  23. 'data' => '',
  24. 'component_type' => 'JD',
  25. 'owner_code' => $item->customerid ?? '',
  26. 'logistic_code' => $item->userdefine1 ?? '',
  27. 'logistic_number' => $item['deliveryno'],
  28. 'delivery' => null,
  29. 'base64' => $this->getBase64($item),
  30. ];
  31. })->toArray();
  32. }
  33. public function getBase64($item): string
  34. {
  35. $item = OwnerLogisticPrintTemplate::query()->with('printTemplate')->where('owner_id', function(Builder $query)use($item){
  36. $query->from("owners")->where("code",$item['owner_code']);
  37. })->where('logistic_id', function(Builder $query)use($item){
  38. $query->from("logistic")->where("code",$item['logistic_code']);
  39. })->first();
  40. $image = $this->draw($item['delivery'],$item,null);
  41. $path = '';
  42. $this->saveImage($image,$path);
  43. return $this->readImageBase64($path);
  44. }
  45. function getDelivery($item)
  46. {
  47. return null;
  48. }
  49. function processing(&$params)
  50. {
  51. }
  52. }