GoodsLogic.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. <?php
  2. namespace app\api\logic;
  3. use app\common\logic\BaseLogic;
  4. use app\common\model\external\ExternalPlatform;
  5. use app\common\model\external\ExternalPlatformGoods;
  6. use app\common\model\goods\Goods;
  7. use app\common\model\goods_category\GoodsCategory;
  8. use app\common\model\works\ServiceWork;
  9. use think\facade\Db;
  10. use think\facade\Log;
  11. /**
  12. * 服务商品逻辑处理
  13. * Class GoodsLogic
  14. * @package app\api\logic
  15. */
  16. class GoodsLogic extends BaseLogic
  17. {
  18. /**
  19. * @notes 商品详情
  20. * @param $goods_id
  21. * @param $userId
  22. * @return array
  23. * @author whitef
  24. * @date 2022/9/20 17:09
  25. */
  26. public static function detail($id,$type,$userId = 0,$params = []){
  27. $where = [];
  28. $service_work_id = $params['service_work_id']??0;
  29. $platform_appid = $params['platform_appid']??0;
  30. $platform_value = $params['platform_value']??0;
  31. if($type == 'category'){
  32. $where[] = ['goods_status','=',1];
  33. $where[] = ['goods_category_id','=',$id];
  34. $where[] = ['user_id','=',0];
  35. $where[] = ['is_agent','=',0];
  36. $where[] = ['is_activity','=',0];
  37. if($service_work_id > 0){
  38. $platform_value = ServiceWork::where('id',$service_work_id)->value('external_platform_id');
  39. $where[] = ['platform_value','=',$platform_value];
  40. }elseif ($platform_appid > 0){
  41. $platform_value = ExternalPlatform::where('appid',$platform_appid)->value('id');
  42. $where[] = ['platform_value','=',$platform_value];
  43. }else{
  44. $where[] = ['platform_value','=',$platform_value];
  45. }
  46. $goods = Goods::where($where)->visible([
  47. 'id','goods_image','goods_name','goods_banners','good_unit','sell_num','base_service_fee',
  48. 'service_total','service_fee','service_image','fee_schedule','warranty_period','goods_payment_type','goods_category_id'
  49. ])->select()->toArray();
  50. }else{
  51. $goods_category_id = Goods::where('id',$id)->value('goods_category_id');
  52. $goods = Goods::where(['goods_category_id'=>$goods_category_id,'user_id'=>0,'is_agent'=>0,'is_activity'=>0,'platform_value'=>0,'goods_status'=>1])->visible([
  53. 'id','goods_image','goods_name','goods_banners','good_unit','sell_num','base_service_fee',
  54. 'service_total','service_fee','service_image','fee_schedule','warranty_period','goods_payment_type','goods_category_id'
  55. ])->select()->toArray();
  56. }
  57. if(!empty($goods)){
  58. !empty(env('DEBUG_LOG', false)) && Log::info($userId.'--detail-商品详情:'.json_encode($goods));
  59. $data = [];
  60. foreach ($goods as $key => $value) {
  61. if($service_work_id > 0 || $platform_appid > 0 || $platform_value > 0){
  62. $value['service_fee'] = self::getPlatformServiceFee($platform_value,$value['id'])?:$value['service_fee'];
  63. }
  64. if($value['goods_payment_type'] == '2'){
  65. $coupon = ($value['service_total']-$value['service_fee'])>0?'立减'.$value['service_total']-$value['service_fee']:'';
  66. }
  67. if($value['goods_payment_type'] == '3'){
  68. $coupon = '首付'.$value['service_fee'];
  69. }
  70. $data[] = [
  71. 'id'=>$value['id'],
  72. 'goods_image'=>$value['goods_image'],
  73. 'goods_name'=>$value['goods_name'],
  74. 'good_unit'=>$value['good_unit'],
  75. 'goods_banners'=>!empty($value['goods_banners']) ? $value['goods_banners'] : [],
  76. 'goods_payment_type'=>$value['goods_payment_type'],
  77. 'sell_num'=>$value['sell_num'],
  78. 'base_service_fee'=>$value['base_service_fee'],
  79. 'service_total'=>$value['service_total'],
  80. 'service_fee'=>$value['service_fee'],
  81. 'coupon'=>!empty($coupon)?$coupon:'',
  82. 'service_image'=>$value['service_image'],
  83. 'warranty_period'=>$value['warranty_period'],
  84. 'fee_schedule'=>$value['fee_schedule'],
  85. 'goods_category_id'=>$value['goods_category_id']
  86. ];
  87. }
  88. $goods = $data;
  89. }
  90. return $goods;
  91. }
  92. public static function eventDetail($id,$userId){
  93. $goods = Goods::where(['id'=>$id])->where(['platform_value'=>0])->visible([
  94. 'id','goods_image','goods_name','goods_banners','good_unit','sell_num','base_service_fee',
  95. 'service_total','service_fee','service_image','fee_schedule','warranty_period','goods_payment_type','goods_category_id','is_activity','activity_service_fee'
  96. ])->select()
  97. ->each(function (&$item, $key) use ($userId){
  98. //判定是否存在可使用的用户优惠券,存在的话直接更新展示价格
  99. if($userId!=0){
  100. $result = UserCouponLogic::categoryWithAmountLists(['user_id'=>$userId,'amount'=>$item['service_fee'],'goods_category_id'=>$item['goods_category_id'],'goods_id'=>$item['id']]);
  101. if(!empty($result[0]['amount'])){
  102. !empty(env('DEBUG_LOG', false)) && Log::info($userId.'--eventDetail-用户优惠券:'.json_encode($result));
  103. $item['base_service_fee'] = '券后'.($item['base_service_fee'] - $result[0]['amount']);
  104. }
  105. }
  106. })->toArray();
  107. if(!empty($goods)){
  108. !empty(env('DEBUG_LOG', false)) && Log::info($userId.'--eventDetail-商品详情:'.json_encode($goods));
  109. $data = [];
  110. foreach ($goods as $key => $value) {
  111. if($value['goods_payment_type'] == '2'){
  112. $coupon = ($value['service_total']-$value['service_fee'])>0?'立减'.$value['service_total']-$value['service_fee']:'';
  113. }
  114. if($value['goods_payment_type'] == '3'){
  115. $coupon = '首付'.$value['service_fee'];
  116. }
  117. $data[] = [
  118. 'id'=>$value['id'],
  119. 'goods_image'=>$value['goods_image'],
  120. 'goods_name'=>$value['goods_name'],
  121. 'good_unit'=>$value['good_unit'],
  122. 'goods_banners'=>!empty($value['goods_banners']) ? $value['goods_banners'] : [],
  123. 'goods_payment_type'=>$value['goods_payment_type'],
  124. 'sell_num'=>$value['sell_num'],
  125. 'base_service_fee'=>$value['base_service_fee'],
  126. 'service_total'=>$value['service_total'],
  127. 'service_fee'=>$value['service_fee'],
  128. 'coupon'=>!empty($coupon)?$coupon:'',
  129. 'service_image'=>$value['service_image'],
  130. 'warranty_period'=>$value['warranty_period'],
  131. 'fee_schedule'=>$value['fee_schedule'],
  132. 'goods_category_id'=>$value['goods_category_id']
  133. ];
  134. }
  135. $goods = $data;
  136. }
  137. return $goods;
  138. }
  139. public static function getHotData()
  140. {
  141. return Goods::where(['user_id'=>0,'is_hot'=>1,'platform_value'=>0])
  142. ->with('goodsCategory')
  143. ->visible(['id','goods_name','goods_image'])
  144. ->order(['top_weight' => 'desc', 'id' => 'desc'])
  145. ->select()->toArray();
  146. }
  147. public static function sync(array $params,int $userId): bool
  148. {
  149. Db::startTrans();
  150. try {
  151. if(isset($params['id'])){
  152. $model = Goods::findOrEmpty($params['id']);
  153. if($model->isEmpty()){
  154. throw new \Exception('数据异常');
  155. }
  156. } else{
  157. $model = new Goods();
  158. }
  159. $params['goods_category_id'] = end($params['goods_category_ids']);
  160. $model->goods_category_id = $params['goods_category_id'];
  161. $model->category_type = GoodsCategory::where('id',$params['goods_category_id'])->value('category_type');
  162. $model->goods_category_ids = $params['goods_category_ids'];
  163. $model->goods_category_id = $params['goods_category_id'];
  164. $model->goods_name = $params['goods_name'];
  165. $model->goods_image = $params['goods_image'];
  166. $model->goods_video = $params['goods_video'];
  167. $model->goods_banners = $params['goods_banners'];
  168. $model->goods_number = $params['goods_number'];
  169. $model->good_unit = $params['good_unit'];
  170. $model->goods_size = $params['goods_size'];
  171. $model->goods_type = $params['goods_type'];
  172. $model->goods_brand = $params['goods_brand'];
  173. $model->install_guide = $params['install_guide'];
  174. $model->goods_payment_type = $params['goods_payment_type'];
  175. $model->base_service_fee = $params['base_service_fee'];
  176. $model->service_total = $params['service_total'];
  177. $model->service_fee = $params['service_fee'];
  178. $model->service_image = $params['service_image'];
  179. $model->warranty_period = $params['warranty_period'];
  180. $model->fee_schedule = $params['fee_schedule'];
  181. $model->goods_status = $params['goods_status'];
  182. $model->user_id = $userId;
  183. $model->save();
  184. Db::commit();
  185. return true;
  186. } catch (\Exception $e) {
  187. Db::rollback();
  188. self::setError($e->getMessage());
  189. return false;
  190. }
  191. }
  192. public static function firmGoodsDetail($params){
  193. try{
  194. $data= Goods::where('id',$params['id'])
  195. ->where('user_id',$params['user_id'])
  196. ->with('goodsCategory')
  197. ->withoutField(['is_recommend','recommend_weight','is_top','top_weight','is_hot','hot_weight'])
  198. ->findOrEmpty()->toArray();
  199. if(!empty($data['goods_category_ids'])) {
  200. $data['goods_category_ids'] = array_map("intval", $data['goods_category_ids']);
  201. }
  202. return $data;
  203. }catch(\Exception $e){
  204. self::setError($e->getMessage());
  205. return false;
  206. }
  207. }
  208. public static function getPlatformServiceFee($platform_value,$goods_id)
  209. {
  210. return ExternalPlatformGoods::where('external_platform_id',$platform_value)->where('goods_id',$goods_id)->value('service_fee');
  211. }
  212. public static function getPlatformCategoryIds($platform_appid){
  213. try{
  214. $platform_value = ExternalPlatform::where('appid',$platform_appid)->value('id');
  215. $goods_categorys= Goods::where('platform_value',$platform_value)
  216. ->field('goods_category_ids')
  217. ->group('goods_category_ids')
  218. ->select()->toArray();
  219. $res = [];
  220. foreach ($goods_categorys as $goods_category) {
  221. $res = array_unique(array_merge($res, $goods_category['goods_category_ids']));
  222. }
  223. return $res;
  224. }catch(\Exception $e){
  225. self::setError($e->getMessage());
  226. return [0];
  227. }
  228. }
  229. }