feat(order): 添加订单处理逻辑
fix(order): 修复订单中的错误 refactor(order): 重构订单代码,优化结构 style(order): 优化订单代码风格 test(order): 为订单添加测试 docs(order): 更新订单相关文档 build(order): 更新订单依赖 ops(order): 更新订单基础设施 chore(order): 更新订单 .gitignore
This commit is contained in:
parent
388581f707
commit
ae2dcb759e
95
app/admin/controller/supplier/SupplierController.php
Normal file
95
app/admin/controller/supplier/SupplierController.php
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace app\admin\controller\supplier;
|
||||||
|
|
||||||
|
|
||||||
|
use app\admin\controller\BaseAdminController;
|
||||||
|
use app\admin\lists\supplier\SupplierLists;
|
||||||
|
use app\admin\logic\supplier\SupplierLogic;
|
||||||
|
use app\admin\validate\supplier\SupplierValidate;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 供应链控制器
|
||||||
|
* Class SupplierController
|
||||||
|
* @package app\admin\controller\supplier
|
||||||
|
*/
|
||||||
|
class SupplierController extends BaseAdminController
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 获取供应链列表
|
||||||
|
* @return \think\response\Json
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function lists()
|
||||||
|
{
|
||||||
|
return $this->dataLists(new SupplierLists());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 添加供应链
|
||||||
|
* @return \think\response\Json
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function add()
|
||||||
|
{
|
||||||
|
$params = (new SupplierValidate())->post()->goCheck('add');
|
||||||
|
$result = SupplierLogic::add($params);
|
||||||
|
if (true === $result) {
|
||||||
|
return $this->success('添加成功', [], 1, 1);
|
||||||
|
}
|
||||||
|
return $this->fail(SupplierLogic::getError());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 编辑供应链
|
||||||
|
* @return \think\response\Json
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function edit()
|
||||||
|
{
|
||||||
|
$params = (new SupplierValidate())->post()->goCheck('edit');
|
||||||
|
$result = SupplierLogic::edit($params);
|
||||||
|
if (true === $result) {
|
||||||
|
return $this->success('编辑成功', [], 1, 1);
|
||||||
|
}
|
||||||
|
return $this->fail(SupplierLogic::getError());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 删除供应链
|
||||||
|
* @return \think\response\Json
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function delete()
|
||||||
|
{
|
||||||
|
$params = (new SupplierValidate())->post()->goCheck('delete');
|
||||||
|
SupplierLogic::delete($params);
|
||||||
|
return $this->success('删除成功', [], 1, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 获取供应链详情
|
||||||
|
* @return \think\response\Json
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function detail()
|
||||||
|
{
|
||||||
|
$params = (new SupplierValidate())->goCheck('detail');
|
||||||
|
$result = SupplierLogic::detail($params);
|
||||||
|
return $this->data($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -26,7 +26,7 @@ class DeliveryServiceLists extends BaseAdminDataLists implements ListsSearchInte
|
|||||||
public function setSearch(): array
|
public function setSearch(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'=' => ['uid', 'nickname', 'phone', 'status'],
|
'=' => ['uid', 'nickname', 'phone', 'status','type'],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ class PurchaseProductOfferLists extends BaseAdminDataLists implements ListsSearc
|
|||||||
public function lists(): array
|
public function lists(): array
|
||||||
{
|
{
|
||||||
return PurchaseProductOffer::where($this->searchWhere)
|
return PurchaseProductOffer::where($this->searchWhere)
|
||||||
->field(['id', 'supplier_id', 'order_id', 'product_id', 'price', 'buyer_nums', 'unit', 'is_buyer', 'buyer_confirm', 'is_storage', 'is_stream', 'need_num', 'notes', 'buyer_id', 'status', 'stream_admin_id', 'stream_time', 'storage_admin_id'])
|
->field(['id', 'supplier_id', 'order_id', 'product_id', 'price','total_price', 'buyer_nums', 'unit', 'is_buyer', 'buyer_confirm', 'is_storage', 'is_stream', 'need_num', 'notes', 'buyer_id', 'status', 'stream_admin_id', 'stream_time', 'storage_admin_id'])
|
||||||
->limit($this->limitOffset, $this->limitLength)
|
->limit($this->limitOffset, $this->limitLength)
|
||||||
->order(['id' => 'desc'])
|
->order(['id' => 'desc'])
|
||||||
->select()->each(function($item){
|
->select()->each(function($item){
|
||||||
@ -66,6 +66,11 @@ class PurchaseProductOfferLists extends BaseAdminDataLists implements ListsSearc
|
|||||||
$item->buyer_confirm_name='采购完成';
|
$item->buyer_confirm_name='采购完成';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if($item->is_storage==1){
|
||||||
|
$item->is_storage_name='已入库';
|
||||||
|
}else{
|
||||||
|
$item->is_storage_name='未入库';
|
||||||
|
}
|
||||||
|
|
||||||
})
|
})
|
||||||
->toArray();
|
->toArray();
|
||||||
|
@ -45,7 +45,7 @@ class StoreCashFinanceFlowLists extends BaseAdminDataLists implements ListsSearc
|
|||||||
public function lists(): array
|
public function lists(): array
|
||||||
{
|
{
|
||||||
return StoreCashFinanceFlow::where($this->searchWhere)
|
return StoreCashFinanceFlow::where($this->searchWhere)
|
||||||
->field(['id', 'store_id', 'cash_price', 'receivable', 'receipts', 'admin_id', 'file', 'remark', 'status'])
|
->field(['id', 'store_id', 'cash_price', 'receivable', 'receipts', 'admin_id', 'file', 'remark','create_time', 'status'])
|
||||||
->limit($this->limitOffset, $this->limitLength)
|
->limit($this->limitOffset, $this->limitLength)
|
||||||
->order(['id' => 'desc'])
|
->order(['id' => 'desc'])
|
||||||
->select()->each(function ($item) {
|
->select()->each(function ($item) {
|
||||||
|
65
app/admin/lists/supplier/SupplierLists.php
Normal file
65
app/admin/lists/supplier/SupplierLists.php
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace app\admin\lists\supplier;
|
||||||
|
|
||||||
|
|
||||||
|
use app\admin\lists\BaseAdminDataLists;
|
||||||
|
use app\common\model\supplier\Supplier;
|
||||||
|
use app\common\lists\ListsSearchInterface;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 供应链列表
|
||||||
|
* Class SupplierLists
|
||||||
|
* @package app\admin\listssupplier
|
||||||
|
*/
|
||||||
|
class SupplierLists extends BaseAdminDataLists implements ListsSearchInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 设置搜索条件
|
||||||
|
* @return \string[][]
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function setSearch(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'=' => ['mer_name', 'phone'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 获取供应链列表
|
||||||
|
* @return array
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\DbException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function lists(): array
|
||||||
|
{
|
||||||
|
return Supplier::where($this->searchWhere)
|
||||||
|
->field(['id', 'category_id', 'mer_name', 'phone', 'settle_cycle', 'address', 'mark'])
|
||||||
|
->limit($this->limitOffset, $this->limitLength)
|
||||||
|
->order(['id' => 'desc'])
|
||||||
|
->select()
|
||||||
|
->toArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 获取供应链数量
|
||||||
|
* @return int
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function count(): int
|
||||||
|
{
|
||||||
|
return Supplier::where($this->searchWhere)->count();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -11,6 +11,7 @@ use app\common\model\store_product\StoreProduct;
|
|||||||
use app\common\model\system_store\SystemStore;
|
use app\common\model\system_store\SystemStore;
|
||||||
use app\common\model\warehouse\Warehouse;
|
use app\common\model\warehouse\Warehouse;
|
||||||
use app\common\lists\ListsExcelInterface;
|
use app\common\lists\ListsExcelInterface;
|
||||||
|
use app\common\model\supplier\Supplier;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 商品仓储信息列表
|
* 商品仓储信息列表
|
||||||
@ -70,7 +71,7 @@ class WarehouseProductLists extends BaseAdminDataLists implements ListsSearchInt
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
return WarehouseProduct::where($this->searchWhere)
|
return WarehouseProduct::where($this->searchWhere)
|
||||||
->field(['id', 'admin_id', 'store_id', 'warehouse_id', 'product_id', 'financial_pm', 'batch', 'nums', 'price', 'purchase', 'cost', 'total_price', 'manufacture', 'expiration_date', 'status', 'mark', 'create_time'])
|
->field(['id', 'admin_id','supplier_id', 'store_id', 'warehouse_id', 'product_id', 'financial_pm', 'batch', 'nums', 'price', 'purchase', 'cost', 'total_price', 'manufacture', 'expiration_date', 'status', 'mark', 'create_time'])
|
||||||
->limit($this->limitOffset, $this->limitLength)
|
->limit($this->limitOffset, $this->limitLength)
|
||||||
->order(['id' => 'desc'])
|
->order(['id' => 'desc'])
|
||||||
->select()->each(function ($item) {
|
->select()->each(function ($item) {
|
||||||
@ -108,6 +109,9 @@ class WarehouseProductLists extends BaseAdminDataLists implements ListsSearchInt
|
|||||||
} else {
|
} else {
|
||||||
$item->warehouse_name = '';
|
$item->warehouse_name = '';
|
||||||
}
|
}
|
||||||
|
if ($item->supplier_id) {
|
||||||
|
$item->supplier_name = Supplier::where('id', $item->supplier_id)->value('mer_name');
|
||||||
|
}
|
||||||
$item->expiration_date = $item->expiration_date ? date('Y-m-d', $item->expiration_date) : '';
|
$item->expiration_date = $item->expiration_date ? date('Y-m-d', $item->expiration_date) : '';
|
||||||
$item->manufacture = $item->manufacture ? date('Y-m-d', $item->manufacture) : '';
|
$item->manufacture = $item->manufacture ? date('Y-m-d', $item->manufacture) : '';
|
||||||
})
|
})
|
||||||
@ -158,6 +162,7 @@ class WarehouseProductLists extends BaseAdminDataLists implements ListsSearchInt
|
|||||||
$data = [
|
$data = [
|
||||||
'admin_name' => '操作人员',
|
'admin_name' => '操作人员',
|
||||||
'warehouse_name' => '仓库',
|
'warehouse_name' => '仓库',
|
||||||
|
'supplier_name' => '供应商',
|
||||||
'store_name' => '商品名称',
|
'store_name' => '商品名称',
|
||||||
'financial_pm_name' => '出入库',
|
'financial_pm_name' => '出入库',
|
||||||
'batch' => '批次',
|
'batch' => '批次',
|
||||||
|
@ -110,6 +110,7 @@ class PurchaseProductOfferLogic extends BaseLogic
|
|||||||
];
|
];
|
||||||
if($params['is_buyer']==1){
|
if($params['is_buyer']==1){
|
||||||
$data['buyer_id']=$params['buyer_id'];
|
$data['buyer_id']=$params['buyer_id'];
|
||||||
|
$data['buyer_nums']=$params['buyer_nums'];
|
||||||
}
|
}
|
||||||
PurchaseProductOffer::where('id', $params['id'])->update($data);
|
PurchaseProductOffer::where('id', $params['id'])->update($data);
|
||||||
Db::commit();
|
Db::commit();
|
||||||
|
@ -54,6 +54,7 @@ class StoreProductLogic extends BaseLogic
|
|||||||
'manufacturer_information' => $params['manufacturer_information'] ?? '',
|
'manufacturer_information' => $params['manufacturer_information'] ?? '',
|
||||||
'swap' => $params['swap'] ?? 0,
|
'swap' => $params['swap'] ?? 0,
|
||||||
'batch' => $params['batch'] ?? 0,
|
'batch' => $params['batch'] ?? 0,
|
||||||
|
'store_batch' => $params['store_batch'] ?? 1,
|
||||||
'product_type' => $params['product_type'] ?? 0,
|
'product_type' => $params['product_type'] ?? 0,
|
||||||
];
|
];
|
||||||
// if ($params['rose'] > 0) {
|
// if ($params['rose'] > 0) {
|
||||||
@ -152,7 +153,6 @@ class StoreProductLogic extends BaseLogic
|
|||||||
} else {
|
} else {
|
||||||
$value['top_cate_id'] = $first_cate;
|
$value['top_cate_id'] = $first_cate;
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
//1-2 选的1级目录
|
//1-2 选的1级目录
|
||||||
$value['two_cate_id'] = $cate_id;
|
$value['two_cate_id'] = $cate_id;
|
||||||
@ -187,6 +187,7 @@ class StoreProductLogic extends BaseLogic
|
|||||||
'price' => $params['price'],
|
'price' => $params['price'],
|
||||||
'vip_price' => $params['vip_price'],
|
'vip_price' => $params['vip_price'],
|
||||||
'batch' => $params['batch'],
|
'batch' => $params['batch'],
|
||||||
|
'store_batch' => $params['store_batch'] ?? 1,
|
||||||
'manufacturer_information' => $params['manufacturer_information'] ?? '',
|
'manufacturer_information' => $params['manufacturer_information'] ?? '',
|
||||||
'swap' => $params['swap'] ?? 0,
|
'swap' => $params['swap'] ?? 0,
|
||||||
'rose' => $params['rose'] ?? 0,
|
'rose' => $params['rose'] ?? 0,
|
||||||
@ -194,35 +195,26 @@ class StoreProductLogic extends BaseLogic
|
|||||||
|
|
||||||
StoreProduct::where('id', $params['id'])->update($data);
|
StoreProduct::where('id', $params['id'])->update($data);
|
||||||
|
|
||||||
/*$old_cate = StoreBranchProduct::where('product_id', $params['id'])->field('cate_id,store_id')
|
|
||||||
->select();
|
|
||||||
// 获取分类ID
|
|
||||||
foreach ($old_cate as $vv) {
|
|
||||||
$related_data = Db::name('store_product_cate')->where('cate_id', $vv['cate_id'])->select();
|
|
||||||
//删除之前的分类
|
|
||||||
foreach ($related_data as $value) {
|
|
||||||
if ($value['count'] == 1) {
|
|
||||||
self::deleteRelatedData($value['cate_id']);
|
|
||||||
} elseif ($value['count'] > 1) {
|
|
||||||
self::decreaseCount($value['cate_id']);
|
|
||||||
}
|
|
||||||
//新增对应的分类
|
|
||||||
self::updateGoodsclass($params['cate_id'], $value['store_id']);
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
$dealCate = self::dealChangeCate($params['cate_id']);
|
$dealCate = self::dealChangeCate($params['cate_id']);
|
||||||
//修改
|
//修改
|
||||||
StoreBranchProduct::where('product_id', $params['id'])->update([
|
StoreBranchProduct::where('product_id', $params['id'])->update([
|
||||||
'price' => $params['price'], 'vip_price' => $params['vip_price'],
|
'price' => $params['price'],
|
||||||
'cost' => $params['cost'],'unit'=>$params['unit'],
|
'vip_price' => $params['vip_price'],
|
||||||
'batch'=>$params['batch'],'store_name'=>$params['store_name'],
|
'cost' => $params['cost'],
|
||||||
|
'unit' => $params['unit'],
|
||||||
|
'batch' => $params['batch'],
|
||||||
|
'store_name' => $params['store_name'],
|
||||||
'manufacturer_information' => $params['manufacturer_information'] ?? '',
|
'manufacturer_information' => $params['manufacturer_information'] ?? '',
|
||||||
'store_info' => $params['store_info']??'','cate_id'=>$params['cate_id'],
|
'store_info' => $params['store_info'] ?? '',
|
||||||
'top_cate_id'=>$dealCate['top_cate_id'],'two_cate_id'=>$dealCate['two_cate_id'],
|
'cate_id' => $params['cate_id'],
|
||||||
|
'top_cate_id' => $dealCate['top_cate_id'],
|
||||||
|
'two_cate_id' => $dealCate['two_cate_id'],
|
||||||
'bar_code' => $params['bar_code'],
|
'bar_code' => $params['bar_code'],
|
||||||
'purchase' => $params['purchase'],
|
'purchase' => $params['purchase'],
|
||||||
'rose' => $params['rose'] ?? 0,
|
'rose' => $params['rose'] ?? 0,
|
||||||
'image' => $params['image'],
|
'image' => $params['image'],
|
||||||
|
'store_batch' => $params['store_batch'] ?? 1,
|
||||||
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
Db::commit();
|
Db::commit();
|
||||||
@ -403,7 +395,8 @@ class StoreProductLogic extends BaseLogic
|
|||||||
|
|
||||||
|
|
||||||
/**普通 */
|
/**普通 */
|
||||||
public static function ordinary($product_arr,$store_id,$admin_id,$find,$warehouse_id){
|
public static function ordinary($product_arr, $store_id, $admin_id, $find, $warehouse_id)
|
||||||
|
{
|
||||||
$store_find = StoreBranchProduct::where(['product_id' => $product_arr['id'], 'store_id' => $store_id])->findOrEmpty()->toArray();
|
$store_find = StoreBranchProduct::where(['product_id' => $product_arr['id'], 'store_id' => $store_id])->findOrEmpty()->toArray();
|
||||||
if ($find && !$store_find) {
|
if ($find && !$store_find) {
|
||||||
//创建门店商品
|
//创建门店商品
|
||||||
@ -429,6 +422,7 @@ class StoreProductLogic extends BaseLogic
|
|||||||
'manufacturer_information' => $find['manufacturer_information'] ?? '',
|
'manufacturer_information' => $find['manufacturer_information'] ?? '',
|
||||||
'unit' => $find['unit'],
|
'unit' => $find['unit'],
|
||||||
'batch' => $find['batch'],
|
'batch' => $find['batch'],
|
||||||
|
'store_batch' => $find['store_batch'],
|
||||||
'store_id' => $store_id,
|
'store_id' => $store_id,
|
||||||
'sales' => 0,
|
'sales' => 0,
|
||||||
'product_type' => $find['product_type'],
|
'product_type' => $find['product_type'],
|
||||||
@ -474,7 +468,8 @@ class StoreProductLogic extends BaseLogic
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**兑换 */
|
/**兑换 */
|
||||||
public static function exchange($product_arr,$store_id,$admin_id,$find,$warehouse_id){
|
public static function exchange($product_arr, $store_id, $admin_id, $find, $warehouse_id)
|
||||||
|
{
|
||||||
$store_find = StoreBranchProductExchange::where(['product_id' => $product_arr['id'], 'store_id' => $store_id])->findOrEmpty()->toArray();
|
$store_find = StoreBranchProductExchange::where(['product_id' => $product_arr['id'], 'store_id' => $store_id])->findOrEmpty()->toArray();
|
||||||
if ($find && !$store_find) {
|
if ($find && !$store_find) {
|
||||||
Db::startTrans();
|
Db::startTrans();
|
||||||
|
104
app/admin/logic/supplier/SupplierLogic.php
Normal file
104
app/admin/logic/supplier/SupplierLogic.php
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace app\admin\logic\supplier;
|
||||||
|
|
||||||
|
|
||||||
|
use app\common\model\supplier\Supplier;
|
||||||
|
use app\common\logic\BaseLogic;
|
||||||
|
use think\facade\Db;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 供应链逻辑
|
||||||
|
* Class SupplierLogic
|
||||||
|
* @package app\admin\logic\supplier
|
||||||
|
*/
|
||||||
|
class SupplierLogic extends BaseLogic
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 添加供应链
|
||||||
|
* @param array $params
|
||||||
|
* @return bool
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public static function add(array $params): bool
|
||||||
|
{
|
||||||
|
Db::startTrans();
|
||||||
|
try {
|
||||||
|
Supplier::create([
|
||||||
|
'mer_name' => $params['mer_name'],
|
||||||
|
'phone' => $params['phone'],
|
||||||
|
'settle_cycle' => $params['settle_cycle'],
|
||||||
|
'address' => $params['address'],
|
||||||
|
'mark' => $params['mark'],
|
||||||
|
'status' => $params['status']
|
||||||
|
]);
|
||||||
|
|
||||||
|
Db::commit();
|
||||||
|
return true;
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
Db::rollback();
|
||||||
|
self::setError($e->getMessage());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 编辑供应链
|
||||||
|
* @param array $params
|
||||||
|
* @return bool
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public static function edit(array $params): bool
|
||||||
|
{
|
||||||
|
Db::startTrans();
|
||||||
|
try {
|
||||||
|
Supplier::where('id', $params['id'])->update([
|
||||||
|
'mer_name' => $params['mer_name'],
|
||||||
|
'phone' => $params['phone'],
|
||||||
|
'settle_cycle' => $params['settle_cycle'],
|
||||||
|
'address' => $params['address'],
|
||||||
|
'mark' => $params['mark'],
|
||||||
|
'status' => $params['status']
|
||||||
|
]);
|
||||||
|
|
||||||
|
Db::commit();
|
||||||
|
return true;
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
Db::rollback();
|
||||||
|
self::setError($e->getMessage());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 删除供应链
|
||||||
|
* @param array $params
|
||||||
|
* @return bool
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public static function delete(array $params): bool
|
||||||
|
{
|
||||||
|
return Supplier::destroy($params['id']);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 获取供应链详情
|
||||||
|
* @param $params
|
||||||
|
* @return array
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public static function detail($params): array
|
||||||
|
{
|
||||||
|
return Supplier::findOrEmpty($params['id'])->toArray();
|
||||||
|
}
|
||||||
|
}
|
@ -5,6 +5,7 @@ namespace app\admin\logic\warehouse_product;
|
|||||||
|
|
||||||
use app\common\model\warehouse_product\WarehouseProduct;
|
use app\common\model\warehouse_product\WarehouseProduct;
|
||||||
use app\common\logic\BaseLogic;
|
use app\common\logic\BaseLogic;
|
||||||
|
use app\common\model\purchase_product_offer\PurchaseProductOffer;
|
||||||
use app\common\model\store_branch_product\StoreBranchProduct;
|
use app\common\model\store_branch_product\StoreBranchProduct;
|
||||||
use app\common\model\store_product\StoreProduct;
|
use app\common\model\store_product\StoreProduct;
|
||||||
use app\common\model\system_store_storage\SystemStoreStorage;
|
use app\common\model\system_store_storage\SystemStoreStorage;
|
||||||
@ -59,6 +60,7 @@ class WarehouseProductLogic extends BaseLogic
|
|||||||
$batch_count = WarehouseProduct::where(['product_id' => $params['product_id'], 'warehouse_id' => $params['warehouse_id'], 'financial_pm' => $params['financial_pm'], 'store_id' => $params['store_id']])->count();
|
$batch_count = WarehouseProduct::where(['product_id' => $params['product_id'], 'warehouse_id' => $params['warehouse_id'], 'financial_pm' => $params['financial_pm'], 'store_id' => $params['store_id']])->count();
|
||||||
$data = [
|
$data = [
|
||||||
'warehouse_id' => $params['warehouse_id'],
|
'warehouse_id' => $params['warehouse_id'],
|
||||||
|
'supplier_id' => $params['supplier_id'] ?? 0,
|
||||||
'store_id' => $params['store_id'] ?? 0,
|
'store_id' => $params['store_id'] ?? 0,
|
||||||
'product_id' => $params['product_id'],
|
'product_id' => $params['product_id'],
|
||||||
'financial_pm' => $params['financial_pm'],
|
'financial_pm' => $params['financial_pm'],
|
||||||
@ -66,9 +68,9 @@ class WarehouseProductLogic extends BaseLogic
|
|||||||
'nums' => $params['nums'],
|
'nums' => $params['nums'],
|
||||||
'before_nums' => $before_nums,
|
'before_nums' => $before_nums,
|
||||||
'after_nums' => $after_nums,
|
'after_nums' => $after_nums,
|
||||||
'price' => $params['price'] ?? '',
|
// 'price' => $params['price'] ?? '',
|
||||||
'purchase' => $params['purchase'] ?? '',
|
'purchase' => $params['purchase'] ?? '',
|
||||||
'cost' => $params['cost'] ?? '',
|
// 'cost' => $params['cost'] ?? '',
|
||||||
'total_price' => $params['total_price'] ?? '',
|
'total_price' => $params['total_price'] ?? '',
|
||||||
'admin_id' => $params['admin_id'],
|
'admin_id' => $params['admin_id'],
|
||||||
'code' => $params['code'] ?? '',
|
'code' => $params['code'] ?? '',
|
||||||
@ -83,6 +85,9 @@ class WarehouseProductLogic extends BaseLogic
|
|||||||
}
|
}
|
||||||
$res = WarehouseProduct::create($data);
|
$res = WarehouseProduct::create($data);
|
||||||
|
|
||||||
|
if(isset($params['purchase_product_offer_id']) &&$params['purchase_product_offer_id']!=''){
|
||||||
|
PurchaseProductOffer::where('id',$params['purchase_product_offer_id'])->update(['is_storage'=>1,'supplier_id'=>$params['supplier_id']??0]);
|
||||||
|
}
|
||||||
// self::enter($res['id'], $params['financial_pm']);
|
// self::enter($res['id'], $params['financial_pm']);
|
||||||
// Db::commit();
|
// Db::commit();
|
||||||
return $res;
|
return $res;
|
||||||
@ -111,12 +116,12 @@ class WarehouseProductLogic extends BaseLogic
|
|||||||
'product_id' => $params['product_id'],
|
'product_id' => $params['product_id'],
|
||||||
'financial_pm' => $params['financial_pm'],
|
'financial_pm' => $params['financial_pm'],
|
||||||
'nums' => $params['nums'],
|
'nums' => $params['nums'],
|
||||||
'price' => $params['price'],
|
// 'price' => $params['price'],
|
||||||
'admin_id' => $params['admin_id'],
|
'admin_id' => $params['admin_id'],
|
||||||
'total_price' => $params['total_price'],
|
'total_price' => $params['total_price'],
|
||||||
'code' => $params['code'],
|
'code' => $params['code'],
|
||||||
'purchase' => $params['purchase'] ?? '',
|
'purchase' => $params['purchase'] ?? '',
|
||||||
'cost' => $params['cost'] ?? '',
|
// 'cost' => $params['cost'] ?? '',
|
||||||
];
|
];
|
||||||
if (isset($params['manufacture']) && $params['manufacture'] != '') {
|
if (isset($params['manufacture']) && $params['manufacture'] != '') {
|
||||||
$data['manufacture'] = strtotime($params['manufacture']);
|
$data['manufacture'] = strtotime($params['manufacture']);
|
||||||
|
94
app/admin/validate/supplier/SupplierValidate.php
Normal file
94
app/admin/validate/supplier/SupplierValidate.php
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace app\admin\validate\supplier;
|
||||||
|
|
||||||
|
|
||||||
|
use app\common\validate\BaseValidate;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 供应链验证器
|
||||||
|
* Class SupplierValidate
|
||||||
|
* @package app\admin\validate\supplier
|
||||||
|
*/
|
||||||
|
class SupplierValidate extends BaseValidate
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置校验规则
|
||||||
|
* @var string[]
|
||||||
|
*/
|
||||||
|
protected $rule = [
|
||||||
|
'id' => 'require',
|
||||||
|
'mer_name' => 'require',
|
||||||
|
'phone' => 'require',
|
||||||
|
'settle_cycle' => 'require',
|
||||||
|
'address' => 'require',
|
||||||
|
'mark' => 'require',
|
||||||
|
'status' => 'require',
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 参数描述
|
||||||
|
* @var string[]
|
||||||
|
*/
|
||||||
|
protected $field = [
|
||||||
|
'id' => 'id',
|
||||||
|
'mer_name' => '商户名称',
|
||||||
|
'phone' => '商户电话',
|
||||||
|
'settle_cycle' => '结算周期,单位天',
|
||||||
|
'address' => '商户地址',
|
||||||
|
'mark' => '商户备注',
|
||||||
|
'status' => '状态',
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 添加场景
|
||||||
|
* @return SupplierValidate
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function sceneAdd()
|
||||||
|
{
|
||||||
|
return $this->only(['mer_name','phone','settle_cycle','address','mark','status']);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 编辑场景
|
||||||
|
* @return SupplierValidate
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function sceneEdit()
|
||||||
|
{
|
||||||
|
return $this->only(['id','mer_name','phone','settle_cycle','address','mark','status']);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 删除场景
|
||||||
|
* @return SupplierValidate
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function sceneDelete()
|
||||||
|
{
|
||||||
|
return $this->only(['id']);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 详情场景
|
||||||
|
* @return SupplierValidate
|
||||||
|
* @author admin
|
||||||
|
* @date 2024/08/15 14:10
|
||||||
|
*/
|
||||||
|
public function sceneDetail()
|
||||||
|
{
|
||||||
|
return $this->only(['id']);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -32,6 +32,7 @@ use app\common\model\user\UserAddress;
|
|||||||
use app\common\model\user_ship\UserShip;
|
use app\common\model\user_ship\UserShip;
|
||||||
use app\common\model\user_sign\UserSign;
|
use app\common\model\user_sign\UserSign;
|
||||||
use app\common\model\user_spread_log\UserSpreadLog;
|
use app\common\model\user_spread_log\UserSpreadLog;
|
||||||
|
use DateTime;
|
||||||
use Picqer\Barcode\BarcodeGeneratorJPG;
|
use Picqer\Barcode\BarcodeGeneratorJPG;
|
||||||
use Picqer\Barcode\BarcodeGeneratorPNG;
|
use Picqer\Barcode\BarcodeGeneratorPNG;
|
||||||
use support\exception\BusinessException;
|
use support\exception\BusinessException;
|
||||||
@ -106,7 +107,6 @@ class OrderLogic extends BaseLogic
|
|||||||
} else {
|
} else {
|
||||||
$find['top_cate_id'] = $StoreCategory['pid'];
|
$find['top_cate_id'] = $StoreCategory['pid'];
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
unset($cart_select[$k]['id']);
|
unset($cart_select[$k]['id']);
|
||||||
$cart_select[$k]['total_price'] = bcmul($v['cart_num'], $find['price'], 2); //订单总价
|
$cart_select[$k]['total_price'] = bcmul($v['cart_num'], $find['price'], 2); //订单总价
|
||||||
@ -228,23 +228,6 @@ class OrderLogic extends BaseLogic
|
|||||||
$order['source'] = $params['source'];
|
$order['source'] = $params['source'];
|
||||||
}
|
}
|
||||||
//处理返回最近的店铺
|
//处理返回最近的店铺
|
||||||
$store_check = 0;
|
|
||||||
if (empty($user)) {
|
|
||||||
$store_id = getenv('STORE_ID') ?? 1;
|
|
||||||
$store['near_store'] = SystemStore::where('id', $store_id)->field('id,name,phone,address,detailed_address,latitude,longitude')->find() ?? [];
|
|
||||||
} else {
|
|
||||||
$checkOrderStore = StoreOrder::where('uid', $user['id'])->field('id,store_id')
|
|
||||||
->order('id', 'desc')->find();
|
|
||||||
if ($checkOrderStore) {
|
|
||||||
$store['near_store'] = SystemStore::where('id', $checkOrderStore['store_id'])->field('id,name,phone,address,detailed_address,latitude,longitude')->find() ?? [];
|
|
||||||
$store_check = 1;
|
|
||||||
} else {
|
|
||||||
$store_id = getenv('STORE_ID') ?? 1;
|
|
||||||
$store['near_store'] = SystemStore::where('id', $store_id)->field('id,name,phone,address,detailed_address,latitude,longitude')->find() ?? [];
|
|
||||||
}
|
|
||||||
$order['address_id'] = UserAddress::where('uid', $user['id'])->where('is_default', 1)->value('id') ?? 0;
|
|
||||||
}
|
|
||||||
if (empty($store_check)) {
|
|
||||||
if ((isset($params['lat']) && $params['lat'] != '') && (isset($params['long']) && $params['long'] != '')) {
|
if ((isset($params['lat']) && $params['lat'] != '') && (isset($params['long']) && $params['long'] != '')) {
|
||||||
$storeAll = SystemStore::field('id,name,phone,address,detailed_address,latitude,longitude')->select()->toArray();
|
$storeAll = SystemStore::field('id,name,phone,address,detailed_address,latitude,longitude')->select()->toArray();
|
||||||
$nearestStore = null;
|
$nearestStore = null;
|
||||||
@ -260,13 +243,33 @@ class OrderLogic extends BaseLogic
|
|||||||
if ($nearestStore) {
|
if ($nearestStore) {
|
||||||
$store['near_store'] = $nearestStore;
|
$store['near_store'] = $nearestStore;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (isset($params['store_id']) && $params['store_id'] > 0) {
|
||||||
|
$store_id = $params['store_id'];
|
||||||
|
} else {
|
||||||
|
$store_id = getenv('STORE_ID') ?? 1;
|
||||||
}
|
}
|
||||||
|
$store['near_store'] = SystemStore::where('id', $store_id)->field('id,name,phone,address,detailed_address,latitude,longitude')->find() ?? [];
|
||||||
|
}
|
||||||
|
if ($user) {
|
||||||
|
$order['address_id'] = UserAddress::where('uid', $user['id'])->where('is_default', 1)->value('id') ?? 0;
|
||||||
|
}
|
||||||
|
$alert = '';
|
||||||
|
// 创建一个DateTime对象表示当前时间
|
||||||
|
$currentTime = new DateTime();
|
||||||
|
|
||||||
|
// 创建一个DateTime对象表示下午4点
|
||||||
|
$fourPM = new DateTime('16:00');
|
||||||
|
|
||||||
|
// 使用DateTime::format()方法获取时间并比较
|
||||||
|
if ($currentTime->format('H:i') > $fourPM->format('H:i')) {
|
||||||
|
$alert='当前时间超过配送截止时间16:00,如下单,配送时间将顺延至次日';
|
||||||
}
|
}
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
self::setError($e->getMessage());
|
self::setError($e->getMessage());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return ['order' => $order, 'cart_list' => $cart_select, 'shopInfo' => $store['near_store']];
|
return ['order' => $order, 'cart_list' => $cart_select, 'shopInfo' => $store['near_store'],'alert'=>$alert];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
22
app/common/model/supplier/Supplier.php
Normal file
22
app/common/model/supplier/Supplier.php
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace app\common\model\supplier;
|
||||||
|
|
||||||
|
|
||||||
|
use app\common\model\BaseModel;
|
||||||
|
use think\model\concern\SoftDelete;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 供应链模型
|
||||||
|
* Class Supplier
|
||||||
|
* @package app\common\model\supplier
|
||||||
|
*/
|
||||||
|
class Supplier extends BaseModel
|
||||||
|
{
|
||||||
|
use SoftDelete;
|
||||||
|
protected $name = 'supplier';
|
||||||
|
protected $deleteTime = 'delete_time';
|
||||||
|
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user