| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267 |
- <?php
- namespace app\common\model;
- use think\Model;
- use Exception;
- class ProductOrder extends Model
- {
- // 表名
- protected $table = 'product_order';
-
- // 自动写入时间戳字段
- protected $autoWriteTimestamp = 'int';
- // 定义时间戳字段名
- protected $createTime = 'create_time';
- protected $updateTime = 'update_time';
- protected $deleteTime = false;
- // 追加属性
- protected $append = [
- 'create_time_text',
- 'update_time_text'
- ];
- //状态
- const Paid = 1;
- const Transferred = 2;
- const Shipped = 3;
- const Cancelled = 4; //取消
- const Closure = 5; //关闭
- const Freeze = 6; //质押
- //类型
- const Popular = 0; //热销
- const Transfer = 1; //转让
- const Giveaway = 2; //赠送
- const Newbie = 3; //新人茶权空投
- const Super = 4; //新人福利空投
- const Airdrop = 5; //空投
- const Synthesi = 6; //合成
- const Buying = 7; //求购
-
- // 订单状态 '已下单', 1=>'已付款', 2=>'已转让', 3=>'提货', 4=>'已取消', 5=>'完成'];
- public $order_status = [
- '-1' => '全部',
- self::Paid => '已付款',
- self::Transferred => '已转让',
- self::Shipped => '提货',
- self::Closure => '关闭',
- self::Freeze => '质押',
- ];
- //抢购下单:未选择地区购买
- public static function setPopularNoAreaOrder($num, $orderId, $price, $productId, $uid, $typeId):bool
- {
- for ($i = 0; $i < $num; $i++) {
- $order_arr['price'] = $price;
- $order_arr['product_id']= $productId;
- $order_arr['area_id'] = 0;
- self::setCreateOrder($orderId, $order_arr, $typeId, $uid, 0, getOrderSN('R'.$i), 0, $price);
- }
- return true;
- }
- //抢购下单:选择地区购买
- public static function setPopularAreaOrder($areaArr, $orderId, $price, $productId, $uid, $typeId):bool
- {
- $result = true;
- foreach ($areaArr as $item) {
- // 生成订单
- $order_arr['price'] = $price;
- $order_arr['product_id']= $productId;
- $order_arr['area_id'] = $item;
- self::setCreateOrder($orderId, $order_arr, $typeId, $uid, 0, getOrderSN('R'), 0, $price);
- }
- //修改区域状态
- $count = ProductArea::whereIn('id', $areaArr)->setField('status', ProductLists::Stop);
- if($count != count($areaArr)) $result = false;
- return $result;
- }
- //合成订单
- public static function setSynthesisOrder($synthesis, $productId, $num, $uid):array
- {
- $result = array();
- foreach ($productId as $key => $item) {
- //获取需求数量
- if(!isset($synthesis[$key.'_num'])) throw new Exception(__("参数有误,无可用产品"));
- //判断持有数量足够
- $total_num = $synthesis[$key.'_num'] * $num;
-
- $order_arr = self::getUserOrderByProductNum($uid, $item, $total_num);
- if($total_num != count($order_arr)) throw new Exception(__("材料不足"));
- //关闭持有订单
- self::whereIn('id', $order_arr)->setField('status', self::Closure);
- $result[$key][] = ['combine'=>$item, 'new_order'=>$order_arr];
- }
- return $result;
- }
- /**
- * @param int $orderId 订单id
- * @param array $orderInfo 订单详情
- * @param int $typeId 订单类型
- * @param int $userId 用户id
- * @param int $fromUser 来源id
- * @param float $fees 手续费
- * @param float $fees 抢购价
- */
- public static function setCreateOrder(int $orderId, $orderInfo, $typeId, $userId, $fromUser, string $orderNo, float $fees, float $price): object
- {
- return self::create([
- 'order_id' => $orderId,
- 'product_id' => $orderInfo['product_id'],
- 'type_id' => $typeId,
- 'status' => self::Paid,
- 'area_id' => $orderInfo['area_id'],
- 'order_no' => $orderNo,
- 'user_id' => $userId,
- 'from_user' => $fromUser,
- 'price' => $orderInfo['price'],
- 'popular_price'=> $price,
- 'fees' => $fees,
- 'num' => 1
- ]);
- }
- //获取持有产品数量
- public static function getByOrderProductNum($productId, $num, $uid)
- {
- if(empty($productId)) return (object)[];
- foreach ($productId as &$item) {
- $item['num'] = $num;
- $count = self::getUserOrderNum($uid, $item['id']);
- if(empty($count)) $count = 0;
- $item['hold_num'] = $count;
- }
- return $productId;
- }
- //获取持有产品数量
- private static function getUserOrderNum(int $uid, int $product_id): int
- {
- return self::where('user_id', $uid)->where('product_id', $product_id)->where('status', '=', self::Paid)->sum('num');
- }
- //获取持有产品数量订单
- private static function getUserOrderByProductNum(int $uid, int $product_id, int $totalNum): array
- {
- return self::where('user_id', $uid)->where('product_id', $product_id)->where('status', '=', self::Paid)->limit($totalNum)->column('id');
- }
- // 获取订单状态
- public static function getProductOrder($orderId, $status, string $field){
- return self::alias('a')->where('a.id', $orderId)
- ->join("product_list b", "a.product_id = b.id", "left")
- ->field('a.*,'.$field)
- ->where('a.status', $status)
- ->find();
- }
- // 获取新人福利领取订单记录
- public static function getUserWelfare($uid, $typeId){
- return self::where('user_id', $uid)
- ->where('type_id', $typeId)
- ->order('create_time desc')
- ->find();
- }
-
- public static function getStatusList()
- {
- return [self::Paid => __('已付款'), self::Transferred => __('已转让'),
- self::Shipped => __('提货'), self::Cancelled => __('已取消'), self::Closure => __('关闭'), self::Freeze => __('质押')];
- }
- //全部类型:
- public static function getStatusAll()
- {
- return [
- ['type_id'=>self::Popular, 'status'=> self::Paid, 'text' => __('已购买')],
- ['type_id'=>self::Popular, 'status'=> self::Closure, 'text' => __('已关闭')],
- ['type_id'=>self::Transfer, 'status'=> self::Transferred,'text' => __('转让中')],
- ['type_id'=>self::Giveaway, 'status'=> self::Closure, 'text' => __('已赠送')],
- ['type_id'=>self::Transfer, 'status'=> self::Closure, 'text' => __('已转让')],
- ['type_id'=>self::Popular, 'status' => self::Shipped, 'text' => __('已提货')],
- ['type_id'=>self::Transfer, 'status'=> self::Cancelled,'text' => __('已取消')],
- ['type_id'=>self::Popular, 'status' => self::Freeze, 'text' => __('质押')],
- ['type_id'=>self::Transfer, 'status' => self::Paid, 'text' => __('购买寄售')],
- ['type_id'=>self::Airdrop, 'status' => self::Paid, 'text' => __('空投')],
- ['type_id'=>self::Airdrop, 'status' => self::Closure, 'text' => __('空投关闭')],
- ['type_id'=>self::Synthesi, 'status' => self::Paid, 'text' => __('合成')],
- ['type_id'=>self::Synthesi, 'status' => self::Closure, 'text' => __('合成关闭')],
- ['type_id'=>self::Buying, 'status' => self::Paid, 'text' => __('求购')],
- ['type_id'=>self::Buying, 'status' => self::Closure, 'text' => __('求购关闭')],
- ['type_id'=>self::Newbie, 'status' => self::Paid, 'text' => __('新人茶权')],
- ['type_id'=>self::Newbie, 'status' => self::Closure, 'text' => __('新人茶权关闭')],
- ['type_id'=>self::Super, 'status' => self::Paid, 'text' => __('新人福利')],
- ['type_id'=>self::Super, 'status' => self::Closure, 'text' => __('新人福利关闭')],
-
- ];
- }
- //产品
- public function products()
- {
- return $this->hasOne('ProductLists', 'id', 'product_id', [], 'LEFT')->setEagerlyType(0);
- }
- //用户 user_id
- public function users()
- {
- return $this->hasOne('UserModel', 'id', 'user_id', [], 'LEFT')->setEagerlyType(0);
- }
- //区域
- public function areas()
- {
- return $this->hasOne('ProductArea', 'id', 'area_id', [], 'LEFT')->setEagerlyType(0);
- }
-
-
- //提货地址
- public function address()
- {
- return $this->hasOne('UserArea', 'order_id', 'id', [], 'LEFT')->setEagerlyType(0);
- }
- public function getCreateTimeTextAttr($value, $data)
- {
- $value = $value ? $value : (isset($data['create_time']) ? $data['create_time'] : '');
- return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
- }
- public function getUpdateTimeTextAttr($value, $data)
- {
- $value = $value ? $value : (isset($data['update_time']) ? $data['update_time'] : '');
- return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
- }
- protected function setCreateTimeAttr($value)
- {
- return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
- }
- protected function setUpdateTimeAttr($value)
- {
- return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
- }
- }
|