ShopgoodsController.php 48 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667
  1. <?php
  2. /**
  3. * 商品
  4. */
  5. namespace app\admin\controller;
  6. use cmf\controller\AdminBaseController;
  7. use think\facade\Db;
  8. class ShopgoodsController extends AdminbaseController {
  9. protected function getStatus($k=''){
  10. $status=[
  11. '-2'=>'管理员下架',
  12. '-1'=>'商家下架',
  13. '0'=>'审核中',
  14. '1'=>'通过',
  15. '2'=>'拒绝',
  16. ];
  17. if($k===''){
  18. return $status;
  19. }
  20. return isset($status[$k])?$status[$k]:'';
  21. }
  22. protected function getType($k=''){
  23. $type=[
  24. '0'=>'站内商品',
  25. '1'=>'外链商品',
  26. '2'=>'自营商品',
  27. ];
  28. if($k===''){
  29. return $type;
  30. }
  31. return isset($type[$k])?$type[$k]:'';
  32. }
  33. function wait(){
  34. $data = $this->request->param();
  35. $map=[];
  36. $map[]=['status','=',0];
  37. $start_time=isset($data['start_time']) ? $data['start_time']: '';
  38. $end_time=isset($data['end_time']) ? $data['end_time']: '';
  39. if($start_time!=""){
  40. $map[]=['addtime','>=',strtotime($start_time)];
  41. }
  42. if($end_time!=""){
  43. $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
  44. }
  45. $uid=isset($data['uid']) ? $data['uid']: '';
  46. if($uid!=''){
  47. $map[]=['uid','=',$uid];
  48. }
  49. $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
  50. if($isrecom!=''){
  51. $map[]=['isrecom','=',$isrecom];
  52. }
  53. $keyword=isset($data['keyword']) ? $data['keyword']: '';
  54. if($keyword!=''){
  55. $map[]=['name','like','%'.$keyword.'%'];
  56. }
  57. $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
  58. if($goods_type!=''){
  59. $map[]=['type','=',$goods_type];
  60. }
  61. $lists = Db::name("shop_goods")
  62. ->where($map)
  63. ->order("id DESC")
  64. ->paginate(20);
  65. $lists = $this->listFormat($lists);
  66. $lists->appends($data);
  67. $page = $lists->render();
  68. $this->assign('lists', $lists);
  69. $this->assign("page", $page);
  70. $this->assign('status', $this->getStatus());
  71. $typelist=$this->getType();
  72. unset($typelist[2]);
  73. $this->assign('type', $typelist);
  74. return $this->fetch();
  75. }
  76. function index(){
  77. $data = $this->request->param();
  78. $map=[];
  79. $map[]=['status','=',1];
  80. $start_time=isset($data['start_time']) ? $data['start_time']: '';
  81. $end_time=isset($data['end_time']) ? $data['end_time']: '';
  82. if($start_time!=""){
  83. $map[]=['addtime','>=',strtotime($start_time)];
  84. }
  85. if($end_time!=""){
  86. $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
  87. }
  88. $uid=isset($data['uid']) ? $data['uid']: '';
  89. if($uid!=''){
  90. $map[]=['uid','=',$uid];
  91. }
  92. $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
  93. if($isrecom!=''){
  94. $map[]=['isrecom','=',$isrecom];
  95. }
  96. $keyword=isset($data['keyword']) ? $data['keyword']: '';
  97. if($keyword!=''){
  98. $map[]=['name','like','%'.$keyword.'%'];
  99. }
  100. $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
  101. if($goods_type!=''){
  102. $map[]=['type','=',$goods_type];
  103. }
  104. $lists = Db::name("shop_goods")
  105. ->where($map)
  106. ->order("id DESC")
  107. ->paginate(20);
  108. $lists = $this->listFormat($lists);
  109. $lists->appends($data);
  110. $page = $lists->render();
  111. $this->assign('lists', $lists);
  112. $this->assign("page", $page);
  113. $this->assign('status', $this->getStatus());
  114. $this->assign('type', $this->getType());
  115. return $this->fetch();
  116. }
  117. function xiajialist(){
  118. $data = $this->request->param();
  119. $map=[];
  120. $start_time=isset($data['start_time']) ? $data['start_time']: '';
  121. $end_time=isset($data['end_time']) ? $data['end_time']: '';
  122. if($start_time!=""){
  123. $map[]=['addtime','>=',strtotime($start_time)];
  124. }
  125. if($end_time!=""){
  126. $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
  127. }
  128. $uid=isset($data['uid']) ? $data['uid']: '';
  129. if($uid!=''){
  130. $map[]=['uid','=',$uid];
  131. }
  132. $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
  133. if($isrecom!=''){
  134. $map[]=['isrecom','=',$isrecom];
  135. }
  136. $keyword=isset($data['keyword']) ? $data['keyword']: '';
  137. if($keyword!=''){
  138. $map[]=['name','like','%'.$keyword.'%'];
  139. }
  140. $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
  141. if($goods_type!=''){
  142. $map[]=['type','=',$goods_type];
  143. }
  144. $lists = Db::name("shop_goods")
  145. ->where($map)
  146. ->where("status=-1 or status=-2")
  147. ->order("id DESC")
  148. ->paginate(20);
  149. $lists = $this->listFormat($lists);
  150. $lists->appends($data);
  151. $page = $lists->render();
  152. $this->assign('lists', $lists);
  153. $this->assign("page", $page);
  154. $this->assign('status', $this->getStatus());
  155. $this->assign('type', $this->getType());
  156. return $this->fetch();
  157. }
  158. function refuselist(){
  159. $data = $this->request->param();
  160. $map=[];
  161. $start_time=isset($data['start_time']) ? $data['start_time']: '';
  162. $end_time=isset($data['end_time']) ? $data['end_time']: '';
  163. if($start_time!=""){
  164. $map[]=['addtime','>=',strtotime($start_time)];
  165. }
  166. if($end_time!=""){
  167. $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
  168. }
  169. $uid=isset($data['uid']) ? $data['uid']: '';
  170. if($uid!=''){
  171. $map[]=['uid','=',$uid];
  172. }
  173. $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
  174. if($isrecom!=''){
  175. $map[]=['isrecom','=',$isrecom];
  176. }
  177. $keyword=isset($data['keyword']) ? $data['keyword']: '';
  178. if($keyword!=''){
  179. $map[]=['name','like','%'.$keyword.'%'];
  180. }
  181. $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
  182. if($goods_type!=''){
  183. $map[]=['type','=',$goods_type];
  184. }
  185. $lists = Db::name("shop_goods")
  186. ->where($map)
  187. ->where("status=2")
  188. ->order("id DESC")
  189. ->paginate(20);
  190. $lists = $this->listFormat($lists);
  191. $lists->appends($data);
  192. $page = $lists->render();
  193. $this->assign('lists', $lists);
  194. $this->assign("page", $page);
  195. $this->assign('status', $this->getStatus());
  196. $typelist=$this->getType();
  197. unset($typelist[2]);
  198. $this->assign('type', $typelist);
  199. return $this->fetch();
  200. }
  201. private function listFormat($list){
  202. $list->each(function($v,$k){
  203. $v['userinfo']=getUserInfo($v['uid']);
  204. $oneclass_name=Db::name("shop_goods_class")->where("gc_id={$v['one_classid']}")->value("gc_name");
  205. $twoclass_name=Db::name("shop_goods_class")->where("gc_id={$v['two_classid']}")->value("gc_name");
  206. $threeclass_name=Db::name("shop_goods_class")->where("gc_id={$v['three_classid']}")->value("gc_name");
  207. $v['oneclass_name']=isset($oneclass_name)?$oneclass_name:'';
  208. $v['twoclass_name']=isset($twoclass_name)?$twoclass_name:'';
  209. $v['threeclass_name']=isset($threeclass_name)?$threeclass_name:'';
  210. $thumb_arr=explode(',',$v['thumbs']);
  211. $v['thumb']=get_upload_path($thumb_arr[0]);
  212. if($v['admin_id']){
  213. $v['admin_userinfo']=getUserInfo($v['admin_id']);
  214. }else{
  215. $v['admin_userinfo']=[];
  216. }
  217. return $v;
  218. });
  219. return $list;
  220. }
  221. //上架/下架
  222. function setStatus(){
  223. $data = $this->request->param();
  224. $status=$data['status'];
  225. if(isset($data['id'])){
  226. $id=$data['id'];
  227. $goodsinfo=DB::name('shop_goods')->where("id={$id}")->find();
  228. if($status==1){ //上架操作
  229. //判断商品所属用户是否注销
  230. $is_destroy=checkIsDestroy($goodsinfo['uid']);
  231. if($is_destroy){
  232. $this->error('该用户已注销,商品不可上架');
  233. }
  234. }
  235. //判断商品是否在直播间代售
  236. if($status==-2){ //下架
  237. $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$id} and (issale=1 or live_isshow=1)")->count();
  238. if($sale_platform){
  239. $this->error("有主播正在直播间代售该商品,暂时无法下架");
  240. }
  241. }
  242. $rs = DB::name('shop_goods')->where("id={$id}")->update(['status'=>$status]);
  243. if($rs===false){
  244. $this->error("操作失败!");
  245. }
  246. if($goodsinfo['uid']!=1){ //用户自己发布的商品
  247. if($status==-2){
  248. $title='商品下架提醒';
  249. $msg='你的商品“'.$goodsinfo['name'].'”已被平台下架。';
  250. }else{
  251. $title='商品上架提醒';
  252. $msg='你的商品“'.$goodsinfo['name'].'”已被平台上架成功。';
  253. }
  254. //写入记录表
  255. addSysytemInfo($goodsinfo['uid'],$title,$msg);
  256. //发送腾讯云IM
  257. txMessageIM($msg,$goodsinfo['uid']);
  258. }else{ //平台自营商品
  259. //将主播代售商品列表中的该商品全部下架
  260. $where=[];
  261. $where['goodsid']=$id;
  262. if($status==-2){ //下架
  263. $post_data=[];
  264. $post_data['status']=0;
  265. $post_data['issale']=0;
  266. $post_data['live_isshow']=0;
  267. }else{ //上架
  268. $post_data=[];
  269. $post_data['status']=1;
  270. }
  271. setOnsalePlatformInfo($where,$post_data);
  272. }
  273. $admin_id=cmf_get_current_admin_id();
  274. if($status==-2){
  275. $action=$admin_id.'下架商品ID: '.$id;
  276. }else{
  277. $action=$admin_id.'上架商品ID: '.$id;
  278. }
  279. setAdminLog($action);
  280. }else if(isset($data['ids'])){
  281. $ids = $data['ids'];
  282. foreach ($ids as $k => $v) {
  283. if($status==-2){ //下架
  284. //判断直播间是否在售商品
  285. $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$v} and (issale=1 or live_isshow=1)")->count();
  286. if($sale_platform){
  287. continue;
  288. }
  289. }
  290. DB::name('shop_goods')->where("id={$v}")->update(['status'=>$status]);
  291. //获取商品信息
  292. $goodsinfo=DB::name('shop_goods')->where("id={$v}")->find();
  293. if($goodsinfo['uid']!=1){ //用户自己发布的商品
  294. if($status==-2){
  295. $title='商品下架提醒';
  296. $msg='你的商品“'.$goodsinfo['name'].'”已被平台下架。';
  297. }else{
  298. $title='商品上架提醒';
  299. $msg='你的商品“'.$goodsinfo['name'].'”已被平台上架成功。';
  300. }
  301. //写入记录表
  302. addSysytemInfo($goodsinfo['uid'],$title,$msg);
  303. //发送腾讯云IM
  304. txMessageIM($msg,$goodsinfo['uid']);
  305. }else{//平台商品
  306. //将主播代售商品列表中的该商品全部下架
  307. $where=[];
  308. $where['goodsid']=$v;
  309. if($status==-2){ //下架
  310. $post_data=[];
  311. $post_data['status']=0;
  312. $post_data['issale']=0;
  313. $post_data['live_isshow']=0;
  314. }else{ //上架
  315. $post_data=[];
  316. $post_data['status']=1;
  317. }
  318. setOnsalePlatformInfo($where,$post_data);
  319. }
  320. }
  321. $admin_id=cmf_get_current_admin_id();
  322. if($status==-2){
  323. $action=$admin_id.'下架商品IDS: '.json_encode($ids);
  324. }else{
  325. $action=$admin_id.'上架商品IDS: '.json_encode($ids);
  326. }
  327. setAdminLog($action);
  328. }
  329. $this->success("操作成功!");
  330. }
  331. function setRecom(){
  332. $id = $this->request->param('id', 0, 'intval');
  333. $isrecom = $this->request->param('isrecom', 0, 'intval');
  334. $rs = DB::name('shop_goods')->where("id={$id}")->update(['isrecom'=>$isrecom]);
  335. if(!$rs){
  336. $this->error("操作失败!");
  337. }
  338. if($isrecom==1){
  339. $action='推荐商品ID: '.$id;
  340. }else{
  341. $action='取消推荐商品ID: '.$id;
  342. }
  343. setAdminLog($action);
  344. $this->success("操作成功!");
  345. }
  346. function del(){
  347. $data=$this->request->param();
  348. if(isset($data['id'])){
  349. $id = $data['id'];
  350. //判断代售该商品的用户是否有在直播间销售的
  351. $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$id} and (issale=1 or live_isshow=1)")->count();
  352. if($sale_platform){
  353. $this->error("有主播正在直播间代售该商品,暂时无法删除");
  354. }
  355. $goodsinfo=DB::name('shop_goods')->where("id={$id}")->find();
  356. $rs = DB::name('shop_goods')->where("id={$id}")->delete();
  357. if(!$rs){
  358. $this->error("删除失败!");
  359. }
  360. if($goodsinfo['uid']>1){
  361. $title='商品删除提醒';
  362. $msg='你的商品“'.$goodsinfo['name'].'”已被平台删除。';
  363. //写入记录
  364. addSysytemInfo($goodsinfo['uid'],$title,$msg);
  365. //发送腾讯云IM
  366. txMessageIM($msg,$goodsinfo['uid']);
  367. }
  368. //删除商品访问记录
  369. Db::name("user_goods_visit")->where("goodsid={$id}")->delete();
  370. //修改视频的绑定信息
  371. Db::name("user_video")->where("goodsid={$id}")->update(array('goodsid'=>0,'isgoods'=>0));
  372. //删除收藏的商品
  373. Db::name('user_goods_collect')->where("goodsid='{$id}'")->delete();
  374. //删除代售商品记录
  375. Db::name("seller_platform_goods")->where("goodsid={$id}")->delete();
  376. $action='删除商品ID: '.$id;
  377. setAdminLog($action);
  378. }else if(isset($data['ids'])){
  379. $ids=$data['ids'];
  380. foreach ($ids as $k => $v) {
  381. //判断是否有主播在直播间代售该商品
  382. $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$v} and (issale=1 or live_isshow=1)")->count();
  383. if($sale_platform){
  384. continue;
  385. }
  386. $goodsinfo=DB::name('shop_goods')->where("id={$v}")->find();
  387. $rs = DB::name('shop_goods')->where("id={$v}")->delete();
  388. if($goodsinfo['uid']>0){
  389. $title='商品删除提醒';
  390. $msg='你的商品“'.$goodsinfo['name'].'”已被平台删除。';
  391. //写入记录
  392. $id=addSysytemInfo($goodsinfo['uid'],$title,$msg);
  393. //发送腾讯云IM
  394. txMessageIM($msg,$goodsinfo['uid']);
  395. }
  396. //删除商品访问记录
  397. Db::name("user_goods_visit")->where("goodsid={$v}")->delete();
  398. //修改视频的绑定信息
  399. Db::name("user_video")->where("goodsid={$v}")->update(array('goodsid'=>0));
  400. }
  401. $action='删除商品IDS: '.json_encode($ids);
  402. setAdminLog($action);
  403. }
  404. $this->success("删除成功!",url("shopgoods/index"));
  405. }
  406. //审核/详情
  407. function edit(){
  408. $data=$this->request->param();
  409. $id = $data['id'];
  410. $url_type=$data['url_type'];
  411. $goodsinfo=Db::name("shop_goods")->where("id={$id}")->find();
  412. if(!$goodsinfo){
  413. $this->error("数据错误");
  414. }
  415. $userinfo=getUserInfo($goodsinfo['uid']);
  416. $goodsinfo['userinfo']=$userinfo;
  417. $oneclass_name=Db::name("shop_goods_class")->where("gc_id={$goodsinfo['one_classid']}")->value("gc_name");
  418. $twoclass_name=Db::name("shop_goods_class")->where("gc_id={$goodsinfo['two_classid']}")->value("gc_name");
  419. $threeclass_name=Db::name("shop_goods_class")->where("gc_id={$goodsinfo['three_classid']}")->value("gc_name");
  420. $goodsinfo['oneclass_name']=isset($oneclass_name)?$oneclass_name:'';
  421. $goodsinfo['twoclass_name']=isset($twoclass_name)?$twoclass_name:'';
  422. $goodsinfo['threeclass_name']=isset($threeclass_name)?$threeclass_name:'';
  423. if(isset($goodsinfo['video_url'])){
  424. $goodsinfo['video_url']=get_upload_path($goodsinfo['video_url']);
  425. }
  426. $thumb_arr=explode(',',$goodsinfo['thumbs']);
  427. foreach ($thumb_arr as $k => $v) {
  428. $thumb_arr[$k]=get_upload_path($v);
  429. }
  430. $goodsinfo['thumb_arr']=$thumb_arr;
  431. $picture_arr=[];
  432. if(isset($goodsinfo['pictures'])){
  433. $picture_arr=explode(',',$goodsinfo['pictures']);
  434. foreach ($picture_arr as $k => $v) {
  435. $picture_arr[$k]=get_upload_path($v);
  436. }
  437. }
  438. $goodsinfo['picture_arr']=$picture_arr;
  439. $spec_arr=json_decode($goodsinfo['specs'],true);
  440. $goodsinfo['spec_arr']=$spec_arr;
  441. unset($goodsinfo['thumbs'],$goodsinfo['pictures'],$goodsinfo['specs']);
  442. $this->assign('data', $goodsinfo);
  443. $status=$this->getStatus();
  444. if(($goodsinfo['status']==0 || $goodsinfo['status']==2) && $goodsinfo['type']!=2){
  445. unset($status['-2']);
  446. unset($status['-1']);
  447. unset($status['0']);
  448. }
  449. $this->assign('status', $status);
  450. $this->assign('url_type', $url_type);
  451. return $this->fetch();
  452. }
  453. //编辑提交
  454. public function editPost(){
  455. $data=$this->request->param();
  456. $id=$data['id'];
  457. $goodsinfo=Db::name("shop_goods")->where("id={$id}")->find();
  458. $status=$data['status'];
  459. $refuse_reason=trim($data['refuse_reason']);
  460. if($status==2){ //管理员拒绝
  461. if($refuse_reason==''){
  462. $this->error("请填写拒绝理由");
  463. }
  464. }else{
  465. $refuse_reason='';
  466. }
  467. $data['refuse_reason']=$refuse_reason;
  468. $data['uptime']=time();
  469. $res=Db::name("shop_goods")->update($data);
  470. if($res===false){
  471. $this->error("编辑失败");
  472. }
  473. $uid=$goodsinfo['uid'];
  474. $title='';
  475. if($status && $uid>1){
  476. if($status==1){
  477. $title='商品上架提醒';
  478. $msg='你的商品“'.$goodsinfo['name'].'”已通过平台审核,上架成功。';
  479. //发送腾讯云IM
  480. txMessageIM($msg,$uid);
  481. }
  482. if($status==2){
  483. //发送极光推送
  484. $title='商品审核失败提醒';
  485. $msg='你的商品“'.$goodsinfo['name'].'”未通过平台审核。';
  486. if($refuse_reason){
  487. $msg.='原因:'.$refuse_reason;
  488. }
  489. //发送腾讯云IM
  490. txMessageIM($msg,$uid);
  491. }
  492. //写入记录
  493. $id=addSysytemInfo($uid,$title,$msg);
  494. }
  495. $this->success("修改成功!");
  496. }
  497. //商品评论列表
  498. public function commentlist(){
  499. $data = $this->request->param();
  500. $goods_id=$data['goods_id'];
  501. $map=[];
  502. $map[]=['goodsid','=',$goods_id];
  503. $map[]=['is_append','=','0'];
  504. $start_time=isset($data['start_time']) ? $data['start_time']: '';
  505. $end_time=isset($data['end_time']) ? $data['end_time']: '';
  506. if($start_time!=""){
  507. $map[]=['addtime','>=',strtotime($start_time)];
  508. }
  509. if($end_time!=""){
  510. $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
  511. }
  512. $keyword=isset($data['keyword']) ? $data['keyword']: '';
  513. if($keyword!=''){
  514. $map[]=['content','like','%'.$keyword.'%'];
  515. }
  516. $lists = Db::name("shop_order_comments")
  517. ->where($map)
  518. ->order("id asc")
  519. ->paginate(20);
  520. $lists->each(function($v,$k){
  521. $v['userinfo']=getUserInfo($v['uid']);
  522. $v['shop_userinfo']=getUserInfo($v['shop_uid']);
  523. if($v['thumbs']){
  524. $thumb_arr=explode(',',$v['thumbs']);
  525. foreach ($thumb_arr as $k1 => $v1) {
  526. $thumb_arr[$k1]=get_upload_path($v1);
  527. }
  528. $v['thumb_arr']=$thumb_arr;
  529. }else{
  530. $v['thumb_arr']=[];
  531. }
  532. if($v['video_thumb']){
  533. $v['video_thumb']=get_upload_path($v['video_thumb']);
  534. }
  535. if($v['video_url']){
  536. $v['video_url']=get_upload_path($v['video_url']);
  537. }
  538. //获取追评信息
  539. $append_comment=Db::name("shop_order_comments")->where("orderid={$v['orderid']} and is_append=1")->find();
  540. if($append_comment){
  541. $append_comment['userinfo']=getUserInfo($append_comment['uid']);
  542. $append_comment['shop_userinfo']=getUserInfo($append_comment['shop_uid']);
  543. if($append_comment['thumbs']){
  544. $thumb_arr=explode(',',$append_comment['thumbs']);
  545. foreach ($thumb_arr as $k1 => $v1) {
  546. $thumb_arr[$k1]=get_upload_path($v1);
  547. }
  548. $append_comment['thumb_arr']=$thumb_arr;
  549. }else{
  550. $append_comment['thumb_arr']=[];
  551. }
  552. if($append_comment['video_thumb']){
  553. $append_comment['video_thumb']=get_upload_path($append_comment['video_thumb']);
  554. }
  555. if($append_comment['video_url']){
  556. $append_comment['video_url']=get_upload_path($append_comment['video_url']);
  557. }
  558. }
  559. $v['append_comment']=$append_comment;
  560. return $v;
  561. });
  562. $lists->appends($data);
  563. $page = $lists->render();
  564. $this->assign('lists', $lists);
  565. $this->assign('goods_id', $goods_id);
  566. $this->assign("page", $page);
  567. return $this->fetch();
  568. }
  569. //删除视频评论
  570. function delComment(){
  571. $id = $this->request->param('id', 0, 'intval');
  572. $rs=Db::name("shop_order_comments")->where("id={$id}")->delete();
  573. if(!$rs){
  574. $this->error("评论删除失败");
  575. }
  576. $this->success("删除成功");
  577. }
  578. //评论视频播放
  579. function videoplay(){
  580. $data=$this->request->param();
  581. $url=$data['url'];
  582. $this->assign('url',$url);
  583. return $this->fetch();
  584. }
  585. //添加商品
  586. function add(){
  587. //判断自营店铺信息是否添加
  588. $platform_info=Db::name("shop_apply")->where("uid=1")->find();
  589. if(!$platform_info){
  590. $this->error("请先填写自营平台店铺信息");
  591. }
  592. $configpub=getConfigPub();
  593. $site=$configpub['site'];
  594. //通过接口获取商品分类中有三级的一级分类
  595. $configpub=getConfigPub();
  596. $site=$configpub['site'];
  597. $header = array(
  598. 'Accept: application/json',
  599. );
  600. $url=$site."/appapi/?s=Shop.getOneGoodsClass";
  601. $curl = curl_init();
  602. //设置抓取的url
  603. curl_setopt($curl, CURLOPT_URL, $url);
  604. //设置头文件的信息作为数据流输出
  605. curl_setopt($curl, CURLOPT_HEADER, 0);
  606. // 超时设置,以秒为单位
  607. curl_setopt($curl, CURLOPT_TIMEOUT, 30);
  608. // 设置请求头
  609. curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
  610. //设置获取的信息以文件流的形式返回,而不是直接输出。
  611. curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
  612. curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
  613. curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
  614. //执行命令
  615. $res = curl_exec($curl);
  616. // 显示错误信息
  617. if (curl_error($curl)) {
  618. $this->error("请确认商品分类");
  619. }
  620. curl_close($curl);
  621. $info=json_decode($res,true);
  622. $ret=$info['ret'];
  623. $code=$info['data']['code'];
  624. $msg=$info['data']['msg'];
  625. $one_classlist=$info['data']['info'];
  626. if($ret!=200){
  627. $this->error("请确认商品分类");
  628. return;
  629. }
  630. if($code!=0){
  631. $this->error($msg);
  632. return;
  633. }
  634. $this->assign("one_classlist",$one_classlist);
  635. return $this->fetch();
  636. }
  637. //jquery获取二级商品分类
  638. function getTwoClassLists(){
  639. $rs=array('code'=>0,'msg'=>'','info'=>array());
  640. $data = $this->request->param();
  641. $one_classid=$data['one_classid'];
  642. if(!$one_classid){
  643. $rs['code']=1001;
  644. $rs['msg']='请选择一级分类';
  645. echo json_encode($rs);
  646. return;
  647. }
  648. $two_list=Db::name("shop_goods_class")->field("gc_id,gc_name")->where("gc_parentid={$one_classid} and gc_isshow=1")->order("gc_sort")->select()->toArray();
  649. if(empty($two_list)){
  650. $rs['code']=1002;
  651. $rs['msg']='商品二级分类为空';
  652. echo json_encode($rs);
  653. return;
  654. }
  655. $rs['info']=$two_list;
  656. echo json_encode($rs);
  657. }
  658. //jquery获取二级商品分类
  659. function getThreeClassLists(){
  660. $rs=array('code'=>0,'msg'=>'','info'=>array());
  661. $data = $this->request->param();
  662. $two_classid=$data['two_classid'];
  663. if(!$two_classid){
  664. $rs['code']=1001;
  665. $rs['msg']='请选择二级分类';
  666. echo json_encode($rs);
  667. return;
  668. }
  669. $three_list=Db::name("shop_goods_class")->field("gc_id,gc_name")->where("gc_parentid={$two_classid} and gc_isshow=1")->order("gc_sort")->select()->toArray();
  670. if(empty($three_list)){
  671. $rs['code']=1002;
  672. $rs['msg']='商品三级分类为空';
  673. echo json_encode($rs);
  674. return;
  675. }
  676. $rs['info']=$three_list;
  677. echo json_encode($rs);
  678. }
  679. //商品添加保存
  680. function addPost(){
  681. $data=$this->request->param();
  682. $name=$data['name'];
  683. $one_classid=$data['one_classid'];
  684. $two_classid=$data['two_classid'];
  685. $three_classid=$data['three_classid'];
  686. $video_is_upload=$data['video_is_upload'];
  687. //$video_url=trim($data['video_url']);
  688. $video_thumb=$data['video_thumb'];
  689. $thumbs=$data['thumbs'];
  690. $content=trim($data['content']);
  691. $pictures=$data['pictures'];
  692. $spec_name=$data['spec_name'];
  693. $spec_num=$data['spec_num'];
  694. $spec_price=$data['spec_price'];
  695. $spec_thumb=$data['spec_thumb'];
  696. $postage=$data['postage'];
  697. $commission=$data['commission'];
  698. $status=$data['status'];
  699. $share_income=$data['share_income'];
  700. $isrecom=$data['isrecom']??0;
  701. $is_assisting_farmers=$data['is_assisting_farmers']??0;
  702. $is_seckill=$data['is_seckill']??0;
  703. if(!$name){
  704. $this->error("请填写商品标题");
  705. }
  706. if(mb_strlen($name)>15){
  707. $this->error("商品标题长度在15字以内");
  708. }
  709. if(!$one_classid){
  710. $this->error("请选择一级分类");
  711. }
  712. if(!$two_classid){
  713. $this->error("请选择二级分类");
  714. }
  715. if(!$three_classid){
  716. $this->error("请选择三级分类");
  717. }
  718. if($video_is_upload){
  719. if(!$video_thumb){
  720. $this->error("请上传视频封面图片");
  721. }
  722. if(!$_FILES["file"]){
  723. $this->error("请上传视频");
  724. }
  725. $files["file"]=$_FILES["file"];
  726. $type='mp4';
  727. $allow=['mp4'];
  728. if (!get_file_suffix($files['file']['name'],$allow)){
  729. $this->error("请上传正确MP4格式的文件");
  730. }
  731. $rs=adminUploadFiles($files,$type);
  732. //file_put_contents('111111.txt', json_encode($rs));
  733. if($rs['code']!=0){
  734. $this->error($rs['msg']);
  735. }
  736. $video_data['video_thumb']=$video_thumb;
  737. $video_data['video_url']=$rs['filepath'];
  738. unset($data['file']);
  739. }else{
  740. $video_data['video_thumb']='';
  741. $video_data['video_url']='';
  742. }
  743. if(!$thumbs){
  744. $this->error("请上传商品缩略图");
  745. }
  746. $thumbs_arr=[]; //封面图重新
  747. foreach ($thumbs as $k => $v) {
  748. if($v!=""){
  749. $thumbs_arr[]=$v;
  750. }
  751. }
  752. if(empty($thumbs_arr)){
  753. $this->error("请上传商品缩略图");
  754. }
  755. if($content==""){
  756. $this->error("请填写商品详情");
  757. }
  758. if(mb_strlen($content)>300){
  759. $this->error("商品详情字数在300字以内");
  760. }
  761. $picture_arr=[];
  762. if(!empty($pictures)){
  763. foreach ($pictures as $k => $v) {
  764. if($v!=''){
  765. $picture_arr[]=$v;
  766. }
  767. }
  768. }
  769. // 商品规格名称
  770. if(!$spec_name){
  771. $this->error("请填写商品规格名称");
  772. }
  773. $spec_name_arr=[];
  774. $spec_name_error=0;
  775. foreach ($spec_name as $k => $v) {
  776. $specs_list_name=trim($v);
  777. if($specs_list_name==''||mb_strlen($specs_list_name)>15){
  778. $spec_name_error=1;
  779. break;
  780. }
  781. $spec_name_arr[]=$specs_list_name;
  782. }
  783. if($spec_name_error){
  784. $this->error("请确认商品规格名称是否填写或是否超过15字");
  785. }
  786. // 商品规格库存
  787. if(!$spec_num){
  788. $this->error("请填写商品规格库存");
  789. }
  790. $spec_num_arr=[];
  791. $spec_num_error=0;
  792. foreach ($spec_num as $k => $v) {
  793. $num=trim($v);
  794. if($num==''||$num<1||$num>9999999||floor($num) !=$num ){
  795. $spec_num_error=1;
  796. break;
  797. }
  798. $spec_num_arr[]=$num;
  799. }
  800. if($spec_num_error){
  801. $this->error("请确认商品规格库存是否在1-9999999之间");
  802. }
  803. // 商品规格单价
  804. if(!$spec_price){
  805. $this->error("请填写商品规格单价");
  806. }
  807. $spec_price_arr=[];
  808. $spec_price_error=0;
  809. foreach ($spec_price as $k => $v) {
  810. $price=trim($v);
  811. if($price==''||!$price ||$price<1||$price>99999999||!is_numeric($price)){
  812. $spec_price_error=1;
  813. break;
  814. }
  815. $spec_price_arr[]=round($price,2);
  816. }
  817. if($spec_price_error){
  818. $this->error("请确认商品规格价格是否在1-99999999之间");
  819. }
  820. // 商品规格封面
  821. if(!$spec_thumb){
  822. $this->error("请确认商品规格封面");
  823. }
  824. $spec_thumb_arr=[];
  825. $spec_thumb_error=0;
  826. foreach ($spec_thumb as $k => $v) {
  827. $thumb_src=trim($v);
  828. if(!$thumb_src){
  829. $spec_thumb_error=1;
  830. break;
  831. }
  832. $spec_thumb_arr[]=$thumb_src;
  833. }
  834. if($spec_thumb_error){
  835. $this->error("请确认商品规格封面");
  836. }
  837. // 邮费
  838. if(!is_numeric($postage)){
  839. $this->error("邮费必须为数字");
  840. }
  841. if($postage<0||$postage>99999){
  842. $this->error("邮费必须在0-99999之间");
  843. }
  844. $postage=round($postage,2);
  845. // 佣金
  846. if(!is_numeric($commission)){
  847. $this->error("佣金必须为数字");
  848. }
  849. if($commission<0||$commission>99999){
  850. $this->error("佣金必须在0-99999之间");
  851. }
  852. $commission=round($commission,2);
  853. //分享得佣金
  854. if(!is_numeric($share_income)){
  855. $this->error("分享佣金必须为数字");
  856. }
  857. if($share_income<0||$share_income>99999){
  858. $this->error("分享佣金必须在0-99999之间");
  859. }
  860. $share_income=round($share_income,2);
  861. $specs_arr=[];
  862. foreach ($spec_name_arr as $k => $v) {
  863. $arr=[];
  864. $arr['spec_id']=$k+1;
  865. $arr['spec_name']=$v;
  866. $arr['spec_num']=$spec_num_arr[$k];
  867. $arr['price']=$spec_price_arr[$k];
  868. $arr['thumb']=$spec_thumb_arr[$k];
  869. $specs_arr[]=$arr;
  870. }
  871. $admin_id=cmf_get_current_admin_id();
  872. $post_data=array(
  873. 'uid'=>1,
  874. 'name'=>$name,
  875. 'one_classid'=>$one_classid,
  876. 'two_classid'=>$two_classid,
  877. 'three_classid'=>$three_classid,
  878. 'thumbs'=>implode(',', $thumbs_arr),
  879. 'content'=>htmlspecialchars($content),
  880. 'specs'=>json_encode($specs_arr),
  881. 'postage'=>$postage,
  882. 'addtime'=>time(),
  883. 'type'=>2,
  884. 'admin_id'=>$admin_id,
  885. 'commission'=>$commission,
  886. 'status'=>$status,
  887. 'share_income'=>$share_income,
  888. 'isrecom'=>$isrecom,
  889. 'is_assisting_farmers'=>$is_assisting_farmers,
  890. 'is_seckill'=>$is_seckill
  891. );
  892. if(!empty($picture_arr)){
  893. $post_data['pictures']=implode(',',$picture_arr);
  894. }else{
  895. $post_data['pictures']='';
  896. }
  897. $new_post_data=array_merge($video_data,$post_data);
  898. /*var_dump($new_post_data);
  899. die;*/
  900. $id=Db::name("shop_goods")->insertGetId($new_post_data);
  901. if(!$id){
  902. $this->error("商品添加失败!");
  903. }
  904. $action=$admin_id."添加商品:{$id}";
  905. setAdminLog($action);
  906. $this->success("商品添加成功!");
  907. }
  908. //平台自营商品编辑
  909. public function platformedit(){
  910. $data=$this->request->param();
  911. $id=$data['id'];
  912. $url_type=$data['url_type'];
  913. $configpub=getConfigPub();
  914. $site=$configpub['site'];
  915. $header = array(
  916. 'Accept: application/json',
  917. );
  918. $curl = curl_init();
  919. $url=$site."/appapi/?s=Shop.getOneGoodsClass";
  920. //设置抓取的url
  921. curl_setopt($curl, CURLOPT_URL, $url);
  922. //设置头文件的信息作为数据流输出
  923. curl_setopt($curl, CURLOPT_HEADER, 0);
  924. // 超时设置,以秒为单位
  925. curl_setopt($curl, CURLOPT_TIMEOUT, 30);
  926. // 设置请求头
  927. curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
  928. //设置获取的信息以文件流的形式返回,而不是直接输出。
  929. curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
  930. curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
  931. curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
  932. //执行命令
  933. $res = curl_exec($curl);
  934. // 显示错误信息
  935. if (curl_error($curl)) {
  936. $this->error("请确认商品分类");
  937. }
  938. curl_close($curl);
  939. $info=json_decode($res,true);
  940. $ret=$info['ret'];
  941. $code=$info['data']['code'];
  942. $msg=$info['data']['msg'];
  943. $one_classlist=$info['data']['info'];
  944. if($ret!=200){
  945. $this->error("请确认商品分类");
  946. return;
  947. }
  948. if($code!=0){
  949. $this->error($msg);
  950. return;
  951. }
  952. //获取自营商品信息
  953. $info=Db::name("shop_goods")->where("id='{$id}'")->find();
  954. //根据一级分类获取二级分类
  955. $two_classlist=Db::name("shop_goods_class")->field("gc_id,gc_name")->where("gc_parentid={$info['one_classid']} and gc_isshow=1")->order("gc_sort")->select()->toArray();
  956. //根据二级分类获取三级分类
  957. $three_classlist=Db::name("shop_goods_class")->field("gc_id,gc_name")->where("gc_parentid={$info['two_classid']} and gc_isshow=1")->order("gc_sort")->select()->toArray();
  958. $thumbs_arr=[];
  959. if($info['thumbs']){
  960. $thumbs_arr=explode(',',$info['thumbs']);
  961. }
  962. $pictures_arr=[];
  963. if($info['pictures']){
  964. $pictures_arr=explode(',', $info['pictures']);
  965. }
  966. $specs_arr=json_decode($info['specs'],true);
  967. $specs_thumbs_arr=[];
  968. foreach ($specs_arr as $k => $v) {
  969. $specs_thumbs_arr[]=$v['thumb'];
  970. }
  971. $this->assign("one_classlist",$one_classlist);
  972. $this->assign("info",$info);
  973. $this->assign("two_classlist",$two_classlist);
  974. $this->assign("three_classlist",$three_classlist);
  975. $this->assign("thumbs_arr",$thumbs_arr);
  976. $this->assign("thumbs_num",count($thumbs_arr));
  977. $this->assign("pictures_arr",$pictures_arr);
  978. $this->assign("pictures_num",count($pictures_arr));
  979. $this->assign("specs_arr",$specs_arr);
  980. $this->assign("specs_num",count($specs_arr));
  981. $this->assign("thumbs",$info['thumbs']);
  982. $this->assign("pictures",$info['pictures']);
  983. $this->assign("specs_thumbs",implode(',', $specs_thumbs_arr));
  984. $this->assign("url_type",$url_type);
  985. return $this->fetch();
  986. }
  987. //平台自营商品编辑提交
  988. public function platformeditPost(){
  989. $data=$this->request->param();
  990. $id=$data['id'];
  991. $name=$data['name'];
  992. $one_classid=$data['one_classid'];
  993. $two_classid=$data['two_classid'];
  994. $three_classid=$data['three_classid'];
  995. $video_is_upload=$data['video_is_upload'];
  996. $video_thumb=$data['video_thumb'];
  997. $video_url='';
  998. if(!isset($data['thumbs'])){
  999. $this->error("请上传商品缩略图");
  1000. }
  1001. $thumbs=$data['thumbs'];
  1002. $content=trim($data['content']);
  1003. if(isset($data['pictures'])){
  1004. $pictures=$data['pictures'];
  1005. }
  1006. $spec_name=$data['spec_name'];
  1007. $spec_num=$data['spec_num'];
  1008. $spec_price=$data['spec_price'];
  1009. $spec_thumb=$data['spec_thumb'];
  1010. $postage=$data['postage'];
  1011. $commission=$data['commission'];
  1012. $status=$data['status'];
  1013. $share_income=$data['share_income']??0;
  1014. $isrecom=$data['isrecom']??0;
  1015. $is_assisting_farmers=$data['is_assisting_farmers']??0;
  1016. $is_seckill=$data['is_seckill']??0;
  1017. if(!$name){
  1018. $this->error("请填写商品标题");
  1019. }
  1020. if(mb_strlen($name)>15){
  1021. $this->error("商品标题长度在15字以内");
  1022. }
  1023. if(!$one_classid){
  1024. $this->error("请选择一级分类");
  1025. }
  1026. if(!$two_classid){
  1027. $this->error("请选择二级分类");
  1028. }
  1029. if(!$three_classid){
  1030. $this->error("请选择三级分类");
  1031. }
  1032. if($video_is_upload){
  1033. if(!$video_thumb){
  1034. $this->error("请上传视频封面图片");
  1035. }
  1036. if($_FILES["file"]){
  1037. $files["file"]=$_FILES["file"];
  1038. $type='mp4';
  1039. $allow=['mp4'];
  1040. if (!get_file_suffix($files['file']['name'],$allow)){
  1041. $this->error("请上传正确MP4格式的文件");
  1042. }
  1043. $rs=adminUploadFiles($files,$type);
  1044. if($rs['code']!=0){
  1045. $this->error($rs['msg']);
  1046. }
  1047. $video_url=$rs['filepath'];
  1048. unset($data['file']);
  1049. $video_data['video_url']=$video_url;
  1050. }
  1051. $video_data['video_thumb']=$video_thumb;
  1052. }else{
  1053. $video_data['video_thumb']='';
  1054. $video_data['video_url']='';
  1055. }
  1056. if(!$thumbs){
  1057. $this->error("请上传商品缩略图");
  1058. }
  1059. $thumbs_arr=$thumbs;
  1060. if($content==""){
  1061. $this->error("请填写商品详情");
  1062. }
  1063. if(mb_strlen($content)>300){
  1064. $this->error("商品详情字数在300字以内");
  1065. }
  1066. if(!empty($pictures)){
  1067. $picture_arr=$pictures;
  1068. }
  1069. if(!$spec_name){
  1070. $this->error("请填写商品规格名称");
  1071. }
  1072. $spec_name_arr=[];
  1073. $spec_name_error=0;
  1074. foreach ($spec_name as $k => $v) {
  1075. $specs_list_name=trim($v);
  1076. if($specs_list_name==''||mb_strlen($specs_list_name)>15){
  1077. $spec_name_error=1;
  1078. break;
  1079. }
  1080. $spec_name_arr[]=$specs_list_name;
  1081. }
  1082. if($spec_name_error){
  1083. $this->error("请确认商品规格名称是否填写或是否超过15字");
  1084. }
  1085. if(!$spec_num){
  1086. $this->error("请填写商品规格库存");
  1087. }
  1088. $spec_num_arr=[];
  1089. $spec_num_error=0;
  1090. foreach ($spec_num as $k => $v) {
  1091. $num=trim($v);
  1092. if($num==''||$num<1||$num>9999999||floor($num) !=$num ){
  1093. $spec_num_error=1;
  1094. break;
  1095. }
  1096. $spec_num_arr[]=$num;
  1097. }
  1098. if($spec_num_error){
  1099. $this->error("请确认商品规格库存是否在1-9999999之间");
  1100. }
  1101. if(!$spec_price){
  1102. $this->error("请填写商品规格单价");
  1103. }
  1104. $spec_price_arr=[];
  1105. $spec_price_error=0;
  1106. foreach ($spec_price as $k => $v) {
  1107. $price=trim($v);
  1108. if($price==''||!$price ||$price<1||$price>99999999||!is_numeric($price)){
  1109. $spec_price_error=1;
  1110. break;
  1111. }
  1112. $spec_price_arr[]=round($price,2);
  1113. }
  1114. if($spec_price_error){
  1115. $this->error("请确认商品规格价格是否在1-99999999之间");
  1116. }
  1117. if(!$spec_thumb){
  1118. $this->error("请确认商品规格封面");
  1119. }
  1120. $spec_thumb_arr=$spec_thumb;
  1121. $spec_thumb_error=0;
  1122. foreach ($spec_thumb as $k => $v) {
  1123. $thumb_src=trim($v);
  1124. if(!$thumb_src){
  1125. $spec_thumb_error=1;
  1126. break;
  1127. }
  1128. }
  1129. if($spec_thumb_error){
  1130. $this->error("请确认商品规格封面");
  1131. }
  1132. if(!is_numeric($postage)){
  1133. $this->error("邮费必须为数字");
  1134. }
  1135. if($postage<0||$postage>99999){
  1136. $this->error("邮费必须在0-99999之间");
  1137. }
  1138. $postage=round($postage,2);
  1139. if(!is_numeric($commission)){
  1140. $this->error("佣金必须为数字");
  1141. }
  1142. if($commission<0||$commission>99999){
  1143. $this->error("佣金必须在0-99999之间");
  1144. }
  1145. $commission=round($commission,2);
  1146. if(!is_numeric($share_income)){
  1147. $this->error("分享佣金必须为数字");
  1148. }
  1149. if($share_income<0||$share_income>99999){
  1150. $this->error("分享佣金必须在0-99999之间");
  1151. }
  1152. $share_income=round($share_income,2);
  1153. $specs_arr=[];
  1154. foreach ($spec_name_arr as $k => $v) {
  1155. $arr=[];
  1156. $arr['spec_id']=$k+1;
  1157. $arr['spec_name']=$v;
  1158. $arr['spec_num']=$spec_num_arr[$k];
  1159. $arr['price']=$spec_price_arr[$k];
  1160. $arr['thumb']=$spec_thumb_arr[$k];
  1161. $specs_arr[]=$arr;
  1162. }
  1163. if($status=='-2'){
  1164. $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$id} and (issale=1 or live_isshow=1)")->count();
  1165. if($sale_platform){
  1166. $this->error("有主播正在直播间代售该商品,暂时无法下架");
  1167. }
  1168. }
  1169. $admin_id=cmf_get_current_admin_id();
  1170. $post_data=array(
  1171. 'id'=>$id,
  1172. 'uid'=>1,
  1173. 'name'=>$name,
  1174. 'one_classid'=>$one_classid,
  1175. 'two_classid'=>$two_classid,
  1176. 'three_classid'=>$three_classid,
  1177. 'thumbs'=>implode(',', $thumbs_arr),
  1178. 'content'=>htmlspecialchars($content),
  1179. 'specs'=>json_encode($specs_arr),
  1180. 'postage'=>$postage,
  1181. 'uptime'=>time(),
  1182. 'type'=>2,
  1183. 'commission'=>$commission,
  1184. 'status'=>$status,
  1185. 'share_income'=>$share_income,
  1186. 'isrecom'=>$isrecom,
  1187. 'is_assisting_farmers'=>$is_assisting_farmers,
  1188. 'is_seckill'=>$is_seckill
  1189. );
  1190. if(!empty($picture_arr)){
  1191. $post_data['pictures']=implode(',',$picture_arr);
  1192. }
  1193. $new_post_data=array_merge($video_data,$post_data);
  1194. $res=Db::name("shop_goods")->update($new_post_data);
  1195. /*var_dump(Db::name("shop_goods")->getLastSql());
  1196. die;*/
  1197. if($res===false){
  1198. $this->error("商品修改失败!");
  1199. }
  1200. if($status==0||$status==-2){ //下架或待审核
  1201. Db::name("seller_platform_goods")->where("goodsid={$id}")->update(array("status"=>0,"issale"=>0,"live_isshow"=>0));
  1202. }else if($status==1){
  1203. Db::name("seller_platform_goods")->where("goodsid={$id}")->update(array("status"=>1));
  1204. }
  1205. $action=$admin_id."修改商品:{$id}";
  1206. setAdminLog($action);
  1207. $this->success("商品修改成功!");
  1208. }
  1209. }