Files
huangjingfen/pro_v3.5.1_副本/app/model/order/StoreOrder.php
apple 434aa8c69d feat(fsgx): 完成全部24项开发任务 Phase1-7
Phase1 后端核心:
- 新增 fsgx_v1.sql 迁移脚本(is_queue_goods/frozen_points/available_points/no_assess)
- SystemConfigServices 返佣设置扩展(周期人数/分档比例/范围/时机)
- StoreOrderCreateServices 周期循环佣金计算
- StoreOrderTakeServices 佣金发放后同步冻结积分
- StoreProductServices/StoreProduct 保存 is_queue_goods

Phase2 后端接口:
- GET /api/hjf/brokerage/progress 佣金周期进度
- GET /api/hjf/assets/overview 资产总览
- HjfPointsServices 每日 frozen_points 0.4‰ 释放定时任务
- PUT /adminapi/hjf/member/{uid}/no_assess 不考核接口
- GET /adminapi/hjf/points/release_log 积分日志接口

Phase3 前端清理:
- hjfCustom.js 路由精简(仅保留 points/log)
- hjfQueue.js/hjfMember.js API 清理/重定向至 CRMEB 原生接口
- pages.json 公排→推荐佣金/佣金记录/佣金规则

Phase4-5 前端改造:
- queue/status.vue 推荐佣金进度页整体重写
- 商品详情/订单确认/支付结果页文案与逻辑改造
- 个人中心/资产页/引导页/规则页文案改造
- HjfQueueProgress/HjfRefundNotice/HjfAssetCard 组件改造
- 推广中心嵌入佣金进度摘要
- hjfMockData.js 全量更新(公排字段→佣金字段)

Phase6 Admin 增强:
- 用户列表新增 frozen_points/available_points 列及不考核操作按钮
- hjfPoints.js USE_MOCK=false 对接真实积分日志接口

Phase7 配置文档:
- docs/fsgx-phase7-config-checklist.md 后台配置与全链路验收清单

Made-with: Cursor
2026-03-23 22:32:19 +08:00

803 lines
19 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2026 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\model\order;
use app\model\activity\combination\StorePink;
use app\model\product\sku\StoreProductVirtual;
use app\model\store\DeliveryService;
use app\model\store\SystemStore;
use app\model\store\SystemStoreStaff;
use app\model\supplier\SystemSupplier;
use app\model\user\User;
use app\model\user\UserBrokerage;
use crmeb\basic\BaseModel;
use crmeb\traits\ModelTrait;
use think\Model;
/**
* 订单Model
* Class StoreOrder
* @package app\model\order
*/
class StoreOrder extends BaseModel
{
use ModelTrait;
/**
* 支付类型
* @var string[]
*/
protected $pay_type = [
1 => 'weixin',
2 => 'yue',
3 => 'offline',
4 => 'alipay',
5 => 'integral'
];
/**
* 数据表主键
* @var string
*/
protected $pk = 'id';
/**
* 模型名称
* @var string
*/
protected $name = 'store_order';
protected $insert = ['add_time'];
/**
* 更新时间
* @var bool | string | int
*/
protected $updateTime = false;
/**
* 创建时间修改器
* @return int
*/
protected function setAddTimeAttr($time = 0)
{
if ($time) return $time;
return time();
}
/**
* 自定义表单信息
* @param $value
* @param $data
* @return mixed
*/
protected function setCustomFormAttr($value)
{
if ($value) {
return is_array($value) ? json_encode($value) : $value;
}
return '';
}
/**
* 自定义表单信息
* @param $value
* @param $data
* @return mixed
*/
protected function getCustomFormAttr($value)
{
if ($value) {
return is_string($value) ? json_decode($value, true) : $value;
}
return [];
}
/**
* 优惠活动赠送信息
* @param $value
* @param $data
* @return mixed
*/
protected function getPromotionsGiveAttr($value)
{
if ($value) {
return is_string($value) ? json_decode($value, true) : $value;
}
return [];
}
/**
* 优惠活动赠送优惠券
* @param $value
* @param $data
* @return mixed
*/
protected function getGiveCouponAttr($value)
{
if ($value) {
return is_string($value) ? explode(',', $value) : $value;
}
return [];
}
/**
* 获取卡密信息
* @param $value
* @param $data
* @return mixed
*/
protected function getVirtualInfoAttr($value)
{
if ($value) {
return is_string($value) ? json_decode($value, true) : $value;
}
return [];
}
/**
* 一对多关联查询子订单
* @return \think\model\relation\HasMany
*/
public function split()
{
return $this->hasMany(StoreOrder::class, 'pid', 'id');
}
/**
* 一对一关联用户表
* @return \think\model\relation\HasOne
*/
public function user()
{
return $this->hasOne(User::class, 'uid', 'uid', false)->field(['uid', 'avatar', 'nickname', 'phone', 'now_money', 'integral', 'delete_time'])->bind([
'avatar' => 'avatar',
'nickname' => 'nickname',
'phone' => 'phone',
'now_money' => 'now_money',
'integral' => 'integral',
'delete_time' => 'delete_time'
]);
}
/**
* 一对多关联退款订单
* @return \think\model\relation\hasMany
*/
public function refund()
{
return $this->hasMany(StoreOrderRefund::class, 'store_order_id', 'id')->where('refund_type', '<>', 3)->where('is_cancel', 0);
}
/**
* 一对多关联订单优惠详情
* @return \think\model\relation\hasMany
*/
public function promotions()
{
return $this->hasMany(StoreOrderPromotions::class, 'oid', 'id');
}
/**
* 一对一关联上级用户信息
* @return \think\model\relation\HasOne
*/
public function spread()
{
return $this->hasOne(User::class, 'uid', 'spread_uid')->field(['uid', 'nickname'])->bind([
'spread_nickname' => 'nickname'
]);
}
/**
* 一对一拼团获取状态
* @return \think\model\relation\HasOne
*/
public function pink()
{
return $this->hasOne(StorePink::class, 'id', 'pink_id')->field(['id', 'order_id_key', 'status'])->bind([
'pinkStatus' => 'status'
]);
}
/**
* 门店一对一关联
* @return \think\model\relation\HasOne
*/
public function store()
{
return $this->hasOne(SystemStore::class, 'id', 'store_id')->hidden(['bank_code,bank_address', 'alipay_account', 'alipay_qrcode_url', 'wechat', 'wechat_qrcode_url']);
}
/**
* 门店一对一关联
* @return \think\model\relation\HasOne
*/
public function storeName()
{
return $this->hasOne(SystemStore::class, 'id', 'store_id')->field('id,name')->bind(['store_name' => 'name']);
}
/**
* 订单关联门店店员
* @return \think\model\relation\HasOne
*/
public function storeStaff()
{
return $this->hasOne(SystemStoreStaff::class, 'id', 'staff_id')->field(['id', 'uid', 'store_id', 'staff_name'])->bind([
'staff_uid' => 'uid',
'staff_store_id' => 'store_id',
'clerk_name' => 'staff_name'
]);
}
/**
* 订单关联店员
* @return \think\model\relation\HasOne
*/
public function staff()
{
return $this->hasOne(SystemStoreStaff::class, 'uid', 'clerk_id')->field(['id', 'uid', 'store_id', 'staff_name'])->bind([
'staff_uid' => 'uid',
'staff_store_id' => 'store_id',
'clerk_name' => 'staff_name'
]);
}
/**
* 店员关联用户
* @return \think\model\relation\HasOne
*/
public function staffUser()
{
return $this->hasOne(User::class, 'uid', 'staff_uid')->field(['uid', 'nickname'])->bind([
'clerk_name' => 'nickname'
]);
}
/**
* 关联配送员
* @return \think\model\relation\HasOne
*/
public function deliveryService()
{
return $this->hasOne(DeliveryService::class, 'uid', 'delivery_uid')->field(['uid', 'nickname'])->bind([
'delivery_name' => 'nickname'
]);
}
/**
* 关联订单发票
* @return \think\model\relation\HasOne
*/
public function invoice()
{
return $this->hasOne(StoreOrderInvoice::class, 'order_id', 'id');
}
/**
* 关联分佣表
* @return \think\model\relation\HasOne
*/
public function brokerage()
{
return $this->hasOne(UserBrokerage::class, 'link_id', 'id');
}
/**
* 关联卡密
* @return \think\model\relation\HasMany
*/
public function virtual()
{
return $this->hasMany(StoreProductVirtual::class, 'order_id', 'order_id')->where('order_type', 1);
}
/**
* 关联订单记录
* @return \think\model\relation\HasMany
*/
public function orderStatus()
{
return $this->hasMany(StoreOrderStatus::class, 'oid', 'id');
}
/**
* 关联配送订单记录
* @return \think\model\relation\hasOne
*/
public function deliveryOrder()
{
return $this->hasOne(StoreDeliveryOrder::class, 'oid', 'id');
}
/**
* 购物车ID修改器
* @param $value
* @return false|string
*/
protected function setCartIdAttr($value)
{
return is_array($value) ? json_encode($value) : $value;
}
/**
* 购物车获取器
* @param $value
* @param $data
* @return mixed
*/
protected function getCartIdAttr($value, $data)
{
return $value ? json_decode($value, true) : [];
}
/**
* 订单ID搜索器
* @param Model $query
* @param $value
*/
public function searchOrderIdAttr($query, $value)
{
$query->where('order_id', $value);
}
/**
* 活动ID搜索器
* @param Model $query
* @param $value
*/
public function searchActivityIdAttr($query, $value)
{
if ($value !== '') $query->where('activity_id', $value);
}
/**
* 父类ID搜索器
* @param Model $query
* @param $value
*/
public function searchPidAttr($query, $value)
{
if ($value === 0) {
$query->where('pid', '>=', 0);
} else {
if (is_array($value)) {
$query->whereIn('pid', $value);
} else {
$query->where('pid', $value);
}
}
}
/**
* 没拆分订单 与子订单(0:为拆分订单-1已拆分主订单 >0 :拆分后子订单)
* @param Model $query
* @param $value
*/
public function searchNotPidAttr($query, $value)
{
$query->where('pid', '<>', -1);
}
/**
* @param Model $query
* @param $value
*/
public function searchIdAttr($query, $value)
{
if (is_array($value)) {
$query->whereIn('id', $value);
} else if ($value !== '') {
$query->where('id', $value);
}
}
/**
* 支付方式搜索器
* @param $query
* @param $value
*/
// public function searchPayTypeAttr($query, $value)
// {
// if (is_array($value)) {
// $query->whereIn('pay_type', $value);
// } else {
// if ($value !== '') {
// $pay_type = $this->pay_type;
// if (in_array($value, array_keys($pay_type)) && $type = $pay_type[$value] ?? '') {
// $query->where('pay_type', $type);
// } else {
// $query->where('pay_type', $value);
// }
// }
// }
// }
/**
* 不等于余额支付
* @param $query
* @param $value
*/
public function searchPayTypeNoAttr($query, $value)
{
$query->where('pay_type', "<>", $value);
}
/**
* 订单id或者用户名搜索器
* @param $query
* @param $value
*/
public function searchOrderIdRealNameAttr($query, $value)
{
$query->where('order_id|real_name', $value);
}
/**
* 用户ID搜索器
* @param Model $query
* @param $value
*/
public function searchUidAttr($query, $value)
{
if (is_array($value))
$query->whereIn('uid|receive_gift_uid', $value);
else
$query->where('uid|receive_gift_uid', $value);
}
/**
* 支付状态搜索器
* @param Model $query
* @param $value
*/
public function searchPaidAttr($query, $value)
{
if (in_array($value, [0, 1])) {
$query->where('paid', $value);
}
}
/**
* 退款状态搜索器
* @param Model $query
* @param $value
* @param $data
*/
public function searchRefundStatusAttr($query, $value, $data)
{
if ($value !== '') {
if (is_array($value)) {
$query->whereIn('refund_status', $value);
} else {
$query->where('refund_status', $value);
}
}
}
/**
* 退款状态搜索器
* @param Model $query
* @param $value
* @param $data
*/
public function searchRefundStatusInAttr($query, $value)
{
$query->whereIn('refund_status', $value);
}
/**
* 是否是拼团订单
* @param Model $query
* @param $value
*/
public function searchPinkIdAttr($query, $value)
{
$query->where('pink_id', $value);
}
/**
* 核销码搜索器
* @param Model $query
* @param $value
*/
public function searchVerifyCodeAttr($query, $value)
{
$query->where('verify_code', $value);
}
/**
* 支付状态搜索器
* @param Model $query
* @param $value
*/
public function searchIsDelAttr($query, $value)
{
if ($value !== ''){
if(is_array($value)){
$query->whereIn('is_del', $value);
}else{
$query->where('is_del', $value);
}
}
}
/**
* 是否删除搜索器
* @param Model $query
* @param $value
*/
public function searchIsSystemDelAttr($query, $value)
{
if ($value != '') $query->where('is_system_del', $value);
}
/**
* 退款状态搜索器
* @param $query
* @param $value
*/
public function searchRefundTypeAttr($query, $value)
{
if (is_array($value)) {
$query->whereIn('refund_type', $value);
} else {
if ($value == -1) {
$query->where('refund_type', 'in', '0,3');
} else {
if ($value == 0 || $value == '') {
$query->where('refund_type', '<>', 0);
} else {
$query->where('refund_type', $value);
}
}
}
}
/**
* 用户来源
* @param Model $query
* @param $value
*/
public function searchChannelTypeAttr($query, $value)
{
if ($value != '') $query->where('channel_type', $value);
}
/**
* 退款id搜索器
* @param Model $query
* @param $value
*/
public function searchRefundIdAttr($query, $value)
{
if ($value) {
$query->where('id', 'in', $value);
}
}
/**
* 上级|上上级推广人
* @param $query
* @param $value
*/
public function searchSpreadOrUidAttr($query, $value)
{
if ($value) $query->where('spread_uid|spread_two_uid', $value);
}
/**
* 上级|上上级推广人|事业部|代理商|员工
* @param $query
* @param $value
*/
public function searchDivisionSpreadAttr($query, $value)
{
if ($value) $query->where('spread_uid|spread_two_uid|division_id|division_agent_id|division_staff_id', $value);
}
/**
* 上级推广人
* @param $query
* @param $value
*/
public function searchSpreadUidAttr($query, $value)
{
if ($value) $query->where('spread_uid', $value);
}
/**
* 上上级推广人
* @param $query
* @param $value
*/
public function searchSpreadTwoUidAttr($query, $value)
{
if ($value) $query->where('spread_two_uid', $value);
}
/**
* 门店ID
* @param $query
* @param $value
*/
public function searchStoreIdAttr($query, $value)
{
if ($value !== '') {
if ($value == -1) {//所有门店
$query->where('store_id', '>', 0);
} else {
$query->where('store_id', $value);
}
}
}
/**
* 门店店员ID
* @param $query
* @param $value
*/
public function searchStaffIdAttr($query, $value)
{
if ($value) $query->where('staff_id', $value);
}
/**
* 配送方式
* @param $query
* @param $value
*/
public function searchShippingTypeAttr($query, $value)
{
if ($value) {
if (is_array($value)) {
$query->where('shipping_type', $value);
} else {
$query->where('shipping_type', $value);
}
}
}
/**
* 配送员UID
* @param $query
* @param $value
*/
public function searchDeliveryUidAttr($query, $value)
{
$query->where('delivery_uid', $value);
}
/**
* 配送类型
* @param $query
* @param $value
*/
public function searchDeliveryTypeAttr($query, $value)
{
if ($value) $query->where('delivery_type', $value);
}
/**
* 供应商ID
* @param $query
* @param $value
*/
public function searchSupplierIdAttr($query, $value)
{
if ($value !== '') {
if ($value == -1) {
$query->where('supplier_id', '>', 0);
} else {
$query->where('supplier_id', $value);
}
}
}
public function searchRefundReasonTimeAttr($query, $value)
{
if ($value !== '') {
if (is_array($value)) {
$query->whereBetween('refund_reason_time', [strtotime($value[0]), strtotime($value[1]) + 86400]);
} else {
$query->where('refund_reason_time', $value);
}
}
}
/**
* 支付渠道
* @param $query
* @param $value
*/
public function searchIsChannelAttr($query, $value)
{
if ($value !== '') $query->where('is_channel', $value);
}
public function searchChannelAttr($query, $value)
{
if ($value !== '') $query->where('channel', $value);
}
/**
* 一对一关联供应商
* @return \think\model\relation\HasOne
*/
public function supplier()
{
return $this->hasOne(SystemSupplier::class, 'id', 'supplier_id')->field(['id', 'supplier_name'])->bind([
'supplier_name'
]);
}
/**
* 一对一关联供应商
* @return \think\model\relation\HasOne
*/
public function supplierInfo()
{
return $this->hasOne(SystemSupplier::class, 'id', 'supplier_id')->field(['id', 'supplier_name', 'name', 'phone', 'email']);
}
/**
* 供应商统计
* @param $query
* @param $value
*/
public function searchSupplierAttr($query, $value)
{
if ($value !== '') $query->where('supplier_id', '>', 0);
}
public function searchDivisionIdAttr($query, $value)
{
if ($value !== 0) {
if ($value == -1) {
$query->where('division_id', '>', $value);
} else {
$query->where('division_id', $value);
}
}
}
public function searchDivisionAgentIdAttr($query, $value)
{
if ($value !== 0) {
if ($value == -1) {
$query->where('division_agent_id', '>', $value);
} else {
$query->where('division_agent_id', $value);
}
}
}
public function searchDivisionStaffIdAttr($query, $value)
{
if ($value !== 0) {
if ($value == -1) {
$query->where('division_staff_id', '>', $value);
} else {
$query->where('division_staff_id', $value);
}
}
}
public function searchDivisionTypeAttr($query, $value)
{
if ($value !== 0) $query->where('division_id|division_agent_id|division_staff_id', '>', 0);
}
}