GoodsLogic.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. namespace app\api\logic;
  3. use app\common\logic\BaseLogic;
  4. use app\common\model\goods\Goods;
  5. use app\common\model\goods_category\GoodsCategory;
  6. use think\facade\Db;
  7. /**
  8. * 服务商品逻辑处理
  9. * Class GoodsLogic
  10. * @package app\api\logic
  11. */
  12. class GoodsLogic extends BaseLogic
  13. {
  14. /**
  15. * @notes 文章详情
  16. * @param $goods_id
  17. * @param $userId
  18. * @return array
  19. * @author whitef
  20. * @date 2022/9/20 17:09
  21. */
  22. public static function detail($id,$type){
  23. if($type == 'category'){
  24. $goods = Goods::where('goods_category_id',$id)->visible([
  25. 'id','goods_image','goods_name','goods_banner_images','good_unit','base_service_fee',
  26. 'service_total','service_fee','service_image','fee_schedule','warranty_period','goods_payment_type'
  27. ])->select()->toArray();
  28. }else{
  29. $goods_category_id = Goods::where('id',$id)->value('goods_category_id');
  30. $goods = Goods::where('goods_category_id',$goods_category_id)->visible([
  31. 'id','goods_image','goods_name','goods_banner_images','good_unit','base_service_fee',
  32. 'service_total','service_fee','service_image','fee_schedule','warranty_period','goods_payment_type'
  33. ])->select()->toArray();
  34. }
  35. if(!empty($goods)){
  36. $data = [];
  37. foreach ($goods as $key => $value) {
  38. if($value['goods_payment_type'] == '2'){
  39. $coupon = ($value['service_total']-$value['service_fee'])>0?'秒杀减'.$value['service_total']-$value['service_fee']:'';
  40. }
  41. $data[] = [
  42. 'id'=>$value['id'],
  43. 'goods_image'=>$value['goods_image'],
  44. 'goods_name'=>$value['goods_name'],
  45. 'goods_banner_images'=>!empty($value['goods_banner_images']) ? explode(',',$value['goods_banner_images']) : [],
  46. 'goods_payment_type'=>$value['goods_payment_type'],
  47. 'base_service_fee'=>$value['base_service_fee'],
  48. 'service_total'=>$value['service_total'],
  49. 'service_fee'=>$value['service_fee'],
  50. 'coupon'=>!empty($coupon)?$coupon:'',
  51. 'service_image'=>$value['service_image'],
  52. 'warranty_period'=>$value['warranty_period'],
  53. 'fee_schedule'=>$value['fee_schedule']
  54. ];
  55. }
  56. $goods = $data;
  57. }
  58. return $goods;
  59. }
  60. public static function getHotData()
  61. {
  62. return Goods::where('is_hot', '=', 1)
  63. ->with('goodsCategory')
  64. ->visible(['id','goods_name','goods_image'])
  65. ->order(['top_weight' => 'desc', 'id' => 'desc'])
  66. ->select()->toArray();
  67. }
  68. public static function sync(array $params,int $userId): bool
  69. {
  70. Db::startTrans();
  71. try {
  72. if(isset($params['id'])){
  73. $model = Goods::findOrEmpty($params['id']);
  74. if($model->isEmpty()){
  75. throw new \Exception('数据异常');
  76. }
  77. } else{
  78. $model = new Goods();
  79. }
  80. $model->goods_category_id = end($params['goods_category_ids']);
  81. $model->category_type = GoodsCategory::where('id', end($params['goods_category_ids']))->value('category_type');
  82. $model->goods_category_ids = $params['goods_category_ids'];
  83. $model->goods_category_id = $params['goods_category_id'];
  84. $model->goods_name = $params['goods_name'];
  85. $model->goods_image = $params['goods_image'];
  86. $model->goods_video = $params['goods_video'];
  87. $model->goods_number = $params['goods_number'];
  88. $model->good_unit = $params['good_unit'];
  89. $model->goods_size = $params['goods_size'];
  90. $model->goods_type = $params['goods_type'];
  91. $model->goods_brand = $params['goods_brand'];
  92. $model->install_guide = $params['install_guide'];
  93. $model->goods_payment_type = $params['goods_payment_type'];
  94. $model->base_service_fee = $params['base_service_fee'];
  95. $model->service_total = $params['service_total'];
  96. $model->service_fee = $params['service_fee'];
  97. $model->service_image = $params['service_image'];
  98. $model->warranty_period = $params['warranty_period'];
  99. $model->fee_schedule = $params['fee_schedule'];
  100. $model->goods_status = $params['goods_status'];
  101. $model->is_recommend = $params['is_recommend'] ?:0;
  102. $model->recommend_weight = $params['recommend_weight'] ?:0;
  103. $model->is_top = $params['is_top'] ?:0;
  104. $model->top_weight = $params['top_weight'] ?:0;
  105. $model->is_hot = $params['is_hot'] ?:0;
  106. $model->hot_weight = $params['hot_weight'] ?:0;
  107. $model->user_id = $userId;
  108. $model->save();
  109. Db::commit();
  110. return true;
  111. } catch (\Exception $e) {
  112. Db::rollback();
  113. self::setError($e->getMessage());
  114. return false;
  115. }
  116. }
  117. }