- 优化预先订单购物车信息列表的搜索功能,增加按店铺名称搜索 - 优化仓库订单列表的搜索条件,增加按订单ID搜索 - 修复仓库订单逻辑中获取订单类型的问题 - 在 API 控制器中添加 XpsdkPrintApi 服务的引用
306 lines
11 KiB
PHP
306 lines
11 KiB
PHP
<?php
|
|
|
|
namespace app\api\controller;
|
|
|
|
use app\admin\logic\beforehand_order\BeforehandOrderLogic;
|
|
use app\admin\logic\store_branch_product\StoreBranchProductLogic;
|
|
use app\common\logic\StoreFinanceFlowLogic;
|
|
use app\admin\logic\store_product\StoreProductLogic;
|
|
use app\admin\validate\tools\GenerateTableValidate;
|
|
use app\admin\logic\tools\GeneratorLogic;
|
|
use app\api\logic\order\OrderLogic as OrderOrderLogic;
|
|
use app\common\logic\PayNotifyLogic;
|
|
use app\common\logic\store_order\StoreOrderLogic;
|
|
use app\common\model\beforehand_order_record\BeforehandOrderRecord;
|
|
use app\common\model\Config as ModelConfig;
|
|
use app\common\model\store_branch_product\StoreBranchProduct;
|
|
use app\common\model\store_finance_flow\StoreFinanceFlow;
|
|
use app\common\model\store_order\StoreOrder;
|
|
use app\common\model\store_order_cart_info\StoreOrderCartInfo;
|
|
use app\common\model\store_product\StoreProduct;
|
|
use app\common\model\system_store\SystemStore;
|
|
use app\common\model\system_store_storage\SystemStoreStorage;
|
|
use app\common\model\user\User;
|
|
use app\common\model\warehouse_product\WarehouseProduct;
|
|
use app\common\service\Curl;
|
|
use app\common\service\pay\PayService;
|
|
use app\common\service\PushService;
|
|
use app\common\service\wechat\WechatTemplate;
|
|
use app\common\service\xpyun\XpsdkPrintApi;
|
|
use app\statistics\logic\OrderLogic;
|
|
use Exception;
|
|
use Overtrue\EasySms\EasySms;
|
|
use Overtrue\EasySms\Exceptions\NoGatewayAvailableException;
|
|
use support\Cache;
|
|
use think\facade\Db;
|
|
use Webman\Config;
|
|
use support\Log;
|
|
use Yansongda\Pay\Exception\InvalidSignException;
|
|
use Monolog\Handler\RotatingFileHandler;
|
|
use Webman\RedisQueue\Redis;
|
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
|
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
|
|
use PhpOffice\PhpSpreadsheet\Style\Alignment;
|
|
use PhpOffice\PhpSpreadsheet\Style\Border;
|
|
use PhpOffice\PhpWord\TemplateProcessor;
|
|
use PhpOffice\PhpWord\Settings;
|
|
use PhpOffice\PhpWord\IOFactory;
|
|
use PhpOffice\PhpWord\Shared\Converter;
|
|
use PhpOffice\PhpWord\Style\Font;
|
|
|
|
class IndexController extends BaseApiController
|
|
{
|
|
public $notNeedLogin = ['index', 'app_update', 'express_list', 'province', 'city', 'area', 'street', 'village', 'brigade', 'config', 'push', 'view_beforehand_order_record', 'view_beforehand_order_record_enter'];
|
|
|
|
public function index()
|
|
{
|
|
d(1);
|
|
$arr=Db::name('ceshi_copy')->select();
|
|
foreach ($arr as $k => $v) {
|
|
$data = [
|
|
|
|
'cost' => $v['cost'],
|
|
'purchase' => $v['purchase'],
|
|
'price' => $v['price'],
|
|
'vip_price' => $v['price'],
|
|
|
|
];
|
|
$rose = 0;
|
|
//零售-供货
|
|
$rose_price = bcsub($v['price'], $v['purchase'], 2);
|
|
if ($rose_price > 0) {
|
|
//利润除于零售
|
|
$price_div = bcdiv($rose_price, $v['price'], 2);
|
|
$rose=bcmul($price_div, 100, 2);
|
|
}
|
|
$data['rose']=$rose;
|
|
StoreProduct::update($data, ['id' => $v['product_id']]);
|
|
//修改
|
|
StoreBranchProduct::where('product_id', $v['product_id'])->whereNotIn('store_id', [17, 18])->update([
|
|
'price' => $v['price'],
|
|
'vip_price' => $v['price'],
|
|
'cost' => $v['cost'],
|
|
'purchase' => $v['purchase'],
|
|
'rose' => $rose
|
|
|
|
]);
|
|
}
|
|
d(11);
|
|
$pay_price=StoreOrder::where('store_id',3)->where('id','>=',1867)->where('id','<=',4826)->where('paid',1)->sum('pay_price');
|
|
$refund_price=StoreOrder::where('store_id',3)->where('id','>=',1867)->where('id','<=',4826)->where('paid',1)->sum('refund_price');
|
|
d($pay_price,$refund_price);
|
|
$arr=StoreOrder::where('store_id',3)->where('id','>',551)->where('paid',1)->field('id,pay_price,deduction_price,refund_price')->select()->toArray();
|
|
$data=[];
|
|
foreach ($arr as $k => $v) {
|
|
$total_price=StoreOrderCartInfo::where('oid', $v['id'])->sum('total_price');
|
|
if($total_price != $v['pay_price']){
|
|
$s=$v;
|
|
$s['total_price']=$total_price;
|
|
$data[] = $s;
|
|
}
|
|
}
|
|
d($data);
|
|
|
|
|
|
$url = 'https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=b538e44b-940b-445f-afe0-97320942d959';
|
|
|
|
$arr = ["msgtype" => "template_card", "template_card" => [
|
|
'card_type' => 'text_notice',
|
|
'main_title' => [
|
|
'title' => '测试标题',
|
|
'desc' => '分单'
|
|
],
|
|
'card_action' => [
|
|
'type' => 1,
|
|
'url' => 'https://admin-multi-store.lihaink.cn/admin'
|
|
]
|
|
]];
|
|
$a = (new Curl())->postJson($url, json_encode($arr, true));
|
|
d($a);
|
|
return json(1);
|
|
|
|
$financeFlow = new StoreFinanceFlow();
|
|
$financeFlowLogic = new StoreFinanceFlowLogic();
|
|
$select_1 = $financeFlow->where('id', 16197)->select();
|
|
|
|
foreach ($select_1 as $k => $v) {
|
|
if ($v['other_uid'] > 0) {
|
|
$financeFlowLogic->updateStatusUser($v['id'], $v['other_uid'], $v['number'], $v['order_id']);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* @notes 下载文件
|
|
*/
|
|
public function download()
|
|
{
|
|
$params = (new GenerateTableValidate())->goCheck('download');
|
|
$result = GeneratorLogic::download($params['file']);
|
|
if (false === $result) {
|
|
return $this->fail(GeneratorLogic::getError() ?: '下载失败');
|
|
}
|
|
return response()->download($result, 'webman-curd.zip');
|
|
}
|
|
|
|
/**
|
|
* @notes 获取app更新信息
|
|
*/
|
|
public function app_update()
|
|
{
|
|
$find = Db::name('app_update')->where('type', 2)->order('id', 'desc')->findOrEmpty();
|
|
return $this->success('ok', $find);
|
|
}
|
|
|
|
|
|
/**
|
|
* @notes 获取省列表
|
|
*/
|
|
public function province()
|
|
{
|
|
$list = Db::name('geo_province')->select()->toArray();
|
|
return $this->success('ok', $list);
|
|
}
|
|
/**
|
|
* @notes 获取市列表
|
|
*/
|
|
public function city()
|
|
{
|
|
$province_code = $this->request->get('province_code');
|
|
$list = Db::name('geo_city')->where('province_code', $province_code)->select()?->toArray();
|
|
return $this->success('ok', $list);
|
|
}
|
|
/**
|
|
* @notes 获取区列表
|
|
*/
|
|
public function area()
|
|
{
|
|
$city_code = $this->request->get('city_code');
|
|
$list = Db::name('geo_area')->where('city_code', $city_code)->select()?->toArray();
|
|
return $this->success('ok', $list);
|
|
}
|
|
/**
|
|
* @notes 获取街道列表
|
|
*/
|
|
public function street()
|
|
{
|
|
$area_code = $this->request->get('area_code');
|
|
$list = Db::name('geo_street')->where('area_code', $area_code)->select()?->toArray();
|
|
return $this->success('ok', $list);
|
|
}
|
|
|
|
/**
|
|
* @notes 获取村列表
|
|
*/
|
|
public function village()
|
|
{
|
|
$area_code = $this->request->get('street_code');
|
|
$list = Db::name('geo_village')->where('street_code', $area_code)->select()?->toArray();
|
|
return $this->success('ok', $list);
|
|
}
|
|
/**
|
|
* @notes 获取队列表
|
|
*/
|
|
public function brigade()
|
|
{
|
|
$list = Db::name('geo_brigade')->select()?->toArray();
|
|
return $this->success('ok', $list);
|
|
}
|
|
|
|
/**
|
|
* @notes 获取队列表
|
|
*/
|
|
public function config()
|
|
{
|
|
//处理返回最近的店铺
|
|
$params = $this->request->get();
|
|
if ((isset($params['lat']) && $params['lat'] != '') && (isset($params['long']) && $params['long'] != '')) {
|
|
$latitude = $params['lat'];
|
|
$longitude = $params['long'];
|
|
// 计算距离的SQL表达式
|
|
$distanceExpr = "6371 * 2 * ASIN(SQRT(POWER(SIN(({$latitude} - abs(latitude)) * pi()/180 / 2), 2) + COS({$latitude} * pi()/180) * COS(abs(latitude) * pi()/180) * POWER(SIN(({$longitude} - longitude) * pi()/180 / 2), 2)))";
|
|
$find = SystemStore::field("id, name,abbreviation, {$distanceExpr} AS distance")
|
|
->where('is_show', '=', 1)
|
|
->where('latitude', '<>', '')
|
|
->where('longitude', '<>', '')
|
|
->order('distance', 'asc') // 根据距离排序
|
|
->find();
|
|
if (!$find) {
|
|
$store_id = getenv('STORE_ID') ?? 1;
|
|
$find = SystemStore::where('id', $store_id)->find();
|
|
}
|
|
} else {
|
|
$store_id = getenv('STORE_ID') ?? 1;
|
|
$find = SystemStore::where('id', $store_id)->find();
|
|
}
|
|
$list = [
|
|
'id' => $find['id'],
|
|
'store_name' => $find['name'],
|
|
'abbreviation' => $find['abbreviation'],
|
|
];
|
|
return $this->success('ok', $list);
|
|
}
|
|
|
|
public function push()
|
|
{
|
|
$name = $this->request->get('name'); //用户名
|
|
$uid = $this->request->get('uid'); //用户id
|
|
$type = $this->request->get('type', 'INDUSTRYMEMBERS'); //类型
|
|
$a = PushService::push($name, $uid, ['type' => $type, 'msg' => '支付超时,订单已被取消,请重新提交订单', 'data' => ['id' => 5]]);
|
|
return $this->success('ok', ['data' => $a]);
|
|
}
|
|
|
|
public function view_beforehand_order_record()
|
|
{
|
|
$id = $this->request->get('id');
|
|
$is_xlsx = $this->request->get('is_xlsx');
|
|
if ($is_xlsx == 1) {
|
|
$xlsx_name = '清单';
|
|
} elseif ($is_xlsx == 2) {
|
|
$xlsx_name = '分单';
|
|
} elseif ($is_xlsx == 3) {
|
|
$xlsx_name = '采购';
|
|
} elseif ($is_xlsx == 4) {
|
|
$xlsx_name = '出库';
|
|
}
|
|
return view('beforehand_order/record', ['id' => $id, 'is_xlsx' => $is_xlsx, 'xlsx_name' => $xlsx_name]);
|
|
}
|
|
public function view_beforehand_order_record_enter()
|
|
{
|
|
$id = $this->request->post('id');
|
|
$check = $this->request->post('check');
|
|
$is_xlsx = $this->request->post('is_xlsx', 0);
|
|
if ($is_xlsx) {
|
|
if ($is_xlsx == 1) {
|
|
$file_path = BeforehandOrderLogic::OrderList(['id' => $id]);
|
|
return $this->success('导出成功', ['url' => $file_path]);
|
|
} elseif ($is_xlsx == 2) {
|
|
$file_path = BeforehandOrderLogic::OrderAllocation(['id' => $id]);
|
|
return $this->success('导出成功', ['url' => $file_path]);
|
|
} elseif ($is_xlsx == 3) {
|
|
$file_path = BeforehandOrderLogic::OrderInfo(['id' => $id]);
|
|
return $this->success('导出成功', ['url' => $file_path]);
|
|
} elseif ($is_xlsx == 4) {
|
|
$file_path = BeforehandOrderLogic::OrderOutbound(['id' => $id]);
|
|
return $this->success('导出成功', ['url' => $file_path]);
|
|
} else {
|
|
return $this->fail('导出失败');
|
|
}
|
|
}
|
|
$check_id = 0;
|
|
if ($check == '001') {
|
|
$check_id = 14;
|
|
}
|
|
if ($check == '002') {
|
|
$check_id = 6;
|
|
}
|
|
$res = BeforehandOrderRecord::where(['id' => $id])->update(['check_user_id' => $check_id, 'status' => 1]);
|
|
if ($res) {
|
|
return $this->success('审核通过');
|
|
} else {
|
|
return $this->fail('审核失败');
|
|
}
|
|
}
|
|
}
|