| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- <?php
- namespace App\Services;
- use App\OracleDocOrderDeliveryInfo;
- use App\OracleDOCOrderHeader;
- use App\OwnerLogisticPrintTemplate;
- use App\Services\Interfaces\DeliveryInterface;
- use App\Traits\DrawImage;
- use Illuminate\Database\Query\Builder;
- use Illuminate\Support\Str;
- class JDDeliveryService implements DeliveryInterface
- {
- use DrawImage;
- function getDeliveryInfo($logistic_number)
- {
- return OracleDOCOrderHeader::query()->whereIn('deliveryno',$logistic_number)
- ->where('consigneeId',"JD")
- ->get()->map(function($item){
- return [
- // TODO 需要动态获取面单获取的组件 TYPE
- 'type' => 'JD',
- 'is_process' => false,
- 'task_id' => Str::uuid(),
- 'data' => '',
- 'component_type' => 'JD',
- 'owner_code' => $item->customerid ?? '',
- 'logistic_code' => $item->userdefine1 ?? '',
- 'logistic_number' => $item['deliveryno'],
- 'delivery' => null,
- 'base64' => $this->getBase64($item),
- ];
- })->toArray();
- }
- public function getBase64($item): string
- {
- $item = OwnerLogisticPrintTemplate::query()->with('printTemplate')->where('owner_id', function(Builder $query)use($item){
- $query->from("owners")->where("code",$item['owner_code']);
- })->where('logistic_id', function(Builder $query)use($item){
- $query->from("logistic")->where("code",$item['logistic_code']);
- })->first();
- $image = $this->draw($item['delivery'],$item,null);
- $path = '';
- $this->saveImage($image,$path);
- return $this->readImageBase64($path);
- }
- function getDelivery($item)
- {
- return null;
- }
- function processing(&$params)
- {
- }
- }
|