| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667 |
- <?php
- /**
- * 商品
- */
- namespace app\admin\controller;
- use cmf\controller\AdminBaseController;
- use think\facade\Db;
- class ShopgoodsController extends AdminbaseController {
-
-
- protected function getStatus($k=''){
- $status=[
- '-2'=>'管理员下架',
- '-1'=>'商家下架',
- '0'=>'审核中',
- '1'=>'通过',
- '2'=>'拒绝',
- ];
- if($k===''){
- return $status;
- }
- return isset($status[$k])?$status[$k]:'';
- }
- protected function getType($k=''){
- $type=[
-
- '0'=>'站内商品',
- '1'=>'外链商品',
- '2'=>'自营商品',
- ];
- if($k===''){
- return $type;
- }
- return isset($type[$k])?$type[$k]:'';
- }
-
- function wait(){
- $data = $this->request->param();
- $map=[];
- $map[]=['status','=',0];
-
- $start_time=isset($data['start_time']) ? $data['start_time']: '';
- $end_time=isset($data['end_time']) ? $data['end_time']: '';
-
- if($start_time!=""){
- $map[]=['addtime','>=',strtotime($start_time)];
- }
- if($end_time!=""){
- $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
- }
-
- $uid=isset($data['uid']) ? $data['uid']: '';
- if($uid!=''){
-
- $map[]=['uid','=',$uid];
-
- }
-
-
- $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
- if($isrecom!=''){
-
- $map[]=['isrecom','=',$isrecom];
-
- }
-
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- if($keyword!=''){
- $map[]=['name','like','%'.$keyword.'%'];
- }
-
- $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
- if($goods_type!=''){
-
- $map[]=['type','=',$goods_type];
-
- }
- $lists = Db::name("shop_goods")
- ->where($map)
- ->order("id DESC")
- ->paginate(20);
-
- $lists = $this->listFormat($lists);
-
- $lists->appends($data);
- $page = $lists->render();
- $this->assign('lists', $lists);
- $this->assign("page", $page);
-
- $this->assign('status', $this->getStatus());
- $typelist=$this->getType();
- unset($typelist[2]);
- $this->assign('type', $typelist);
-
- return $this->fetch();
- }
- function index(){
- $data = $this->request->param();
- $map=[];
- $map[]=['status','=',1];
-
- $start_time=isset($data['start_time']) ? $data['start_time']: '';
- $end_time=isset($data['end_time']) ? $data['end_time']: '';
-
- if($start_time!=""){
- $map[]=['addtime','>=',strtotime($start_time)];
- }
- if($end_time!=""){
- $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
- }
-
- $uid=isset($data['uid']) ? $data['uid']: '';
- if($uid!=''){
-
- $map[]=['uid','=',$uid];
-
- }
-
-
- $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
- if($isrecom!=''){
-
- $map[]=['isrecom','=',$isrecom];
-
- }
-
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- if($keyword!=''){
- $map[]=['name','like','%'.$keyword.'%'];
- }
-
- $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
- if($goods_type!=''){
-
- $map[]=['type','=',$goods_type];
-
- }
- $lists = Db::name("shop_goods")
- ->where($map)
- ->order("id DESC")
- ->paginate(20);
-
- $lists = $this->listFormat($lists);
-
- $lists->appends($data);
- $page = $lists->render();
- $this->assign('lists', $lists);
- $this->assign("page", $page);
-
- $this->assign('status', $this->getStatus());
- $this->assign('type', $this->getType());
-
- return $this->fetch();
- }
- function xiajialist(){
- $data = $this->request->param();
- $map=[];
- $start_time=isset($data['start_time']) ? $data['start_time']: '';
- $end_time=isset($data['end_time']) ? $data['end_time']: '';
-
- if($start_time!=""){
- $map[]=['addtime','>=',strtotime($start_time)];
- }
- if($end_time!=""){
- $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
- }
-
- $uid=isset($data['uid']) ? $data['uid']: '';
- if($uid!=''){
-
- $map[]=['uid','=',$uid];
-
- }
-
-
- $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
- if($isrecom!=''){
-
- $map[]=['isrecom','=',$isrecom];
-
- }
-
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- if($keyword!=''){
- $map[]=['name','like','%'.$keyword.'%'];
- }
-
- $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
- if($goods_type!=''){
-
- $map[]=['type','=',$goods_type];
-
- }
- $lists = Db::name("shop_goods")
- ->where($map)
- ->where("status=-1 or status=-2")
- ->order("id DESC")
- ->paginate(20);
-
- $lists = $this->listFormat($lists);
-
- $lists->appends($data);
- $page = $lists->render();
- $this->assign('lists', $lists);
- $this->assign("page", $page);
-
- $this->assign('status', $this->getStatus());
- $this->assign('type', $this->getType());
-
- return $this->fetch();
- }
- function refuselist(){
- $data = $this->request->param();
- $map=[];
- $start_time=isset($data['start_time']) ? $data['start_time']: '';
- $end_time=isset($data['end_time']) ? $data['end_time']: '';
-
- if($start_time!=""){
- $map[]=['addtime','>=',strtotime($start_time)];
- }
- if($end_time!=""){
- $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
- }
-
- $uid=isset($data['uid']) ? $data['uid']: '';
- if($uid!=''){
-
- $map[]=['uid','=',$uid];
-
- }
-
-
- $isrecom=isset($data['isrecom']) ? $data['isrecom']: '';
- if($isrecom!=''){
-
- $map[]=['isrecom','=',$isrecom];
-
- }
-
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- if($keyword!=''){
- $map[]=['name','like','%'.$keyword.'%'];
- }
-
- $goods_type=isset($data['goods_type']) ? $data['goods_type']: '';
- if($goods_type!=''){
-
- $map[]=['type','=',$goods_type];
-
- }
- $lists = Db::name("shop_goods")
- ->where($map)
- ->where("status=2")
- ->order("id DESC")
- ->paginate(20);
-
- $lists = $this->listFormat($lists);
-
- $lists->appends($data);
- $page = $lists->render();
- $this->assign('lists', $lists);
- $this->assign("page", $page);
-
- $this->assign('status', $this->getStatus());
- $typelist=$this->getType();
- unset($typelist[2]);
- $this->assign('type', $typelist);
-
- return $this->fetch();
- }
- private function listFormat($list){
- $list->each(function($v,$k){
- $v['userinfo']=getUserInfo($v['uid']);
- $oneclass_name=Db::name("shop_goods_class")->where("gc_id={$v['one_classid']}")->value("gc_name");
- $twoclass_name=Db::name("shop_goods_class")->where("gc_id={$v['two_classid']}")->value("gc_name");
- $threeclass_name=Db::name("shop_goods_class")->where("gc_id={$v['three_classid']}")->value("gc_name");
- $v['oneclass_name']=isset($oneclass_name)?$oneclass_name:'';
- $v['twoclass_name']=isset($twoclass_name)?$twoclass_name:'';
- $v['threeclass_name']=isset($threeclass_name)?$threeclass_name:'';
- $thumb_arr=explode(',',$v['thumbs']);
- $v['thumb']=get_upload_path($thumb_arr[0]);
- if($v['admin_id']){
- $v['admin_userinfo']=getUserInfo($v['admin_id']);
- }else{
- $v['admin_userinfo']=[];
- }
- return $v;
- });
- return $list;
- }
- //上架/下架
- function setStatus(){
- $data = $this->request->param();
- $status=$data['status'];
-
- if(isset($data['id'])){
- $id=$data['id'];
- $goodsinfo=DB::name('shop_goods')->where("id={$id}")->find();
- if($status==1){ //上架操作
- //判断商品所属用户是否注销
- $is_destroy=checkIsDestroy($goodsinfo['uid']);
- if($is_destroy){
- $this->error('该用户已注销,商品不可上架');
- }
- }
- //判断商品是否在直播间代售
- if($status==-2){ //下架
- $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$id} and (issale=1 or live_isshow=1)")->count();
- if($sale_platform){
- $this->error("有主播正在直播间代售该商品,暂时无法下架");
- }
- }
-
- $rs = DB::name('shop_goods')->where("id={$id}")->update(['status'=>$status]);
- if($rs===false){
- $this->error("操作失败!");
- }
- if($goodsinfo['uid']!=1){ //用户自己发布的商品
- if($status==-2){
- $title='商品下架提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”已被平台下架。';
- }else{
- $title='商品上架提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”已被平台上架成功。';
- }
- //写入记录表
-
- addSysytemInfo($goodsinfo['uid'],$title,$msg);
- //发送腾讯云IM
- txMessageIM($msg,$goodsinfo['uid']);
- }else{ //平台自营商品
- //将主播代售商品列表中的该商品全部下架
- $where=[];
- $where['goodsid']=$id;
- if($status==-2){ //下架
- $post_data=[];
- $post_data['status']=0;
- $post_data['issale']=0;
- $post_data['live_isshow']=0;
- }else{ //上架
- $post_data=[];
- $post_data['status']=1;
- }
- setOnsalePlatformInfo($where,$post_data);
- }
- $admin_id=cmf_get_current_admin_id();
-
- if($status==-2){
- $action=$admin_id.'下架商品ID: '.$id;
- }else{
- $action=$admin_id.'上架商品ID: '.$id;
- }
- setAdminLog($action);
- }else if(isset($data['ids'])){
- $ids = $data['ids'];
- foreach ($ids as $k => $v) {
- if($status==-2){ //下架
- //判断直播间是否在售商品
- $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$v} and (issale=1 or live_isshow=1)")->count();
- if($sale_platform){
- continue;
- }
- }
-
- DB::name('shop_goods')->where("id={$v}")->update(['status'=>$status]);
- //获取商品信息
- $goodsinfo=DB::name('shop_goods')->where("id={$v}")->find();
- if($goodsinfo['uid']!=1){ //用户自己发布的商品
- if($status==-2){
- $title='商品下架提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”已被平台下架。';
-
- }else{
- $title='商品上架提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”已被平台上架成功。';
- }
- //写入记录表
- addSysytemInfo($goodsinfo['uid'],$title,$msg);
- //发送腾讯云IM
- txMessageIM($msg,$goodsinfo['uid']);
- }else{//平台商品
- //将主播代售商品列表中的该商品全部下架
- $where=[];
- $where['goodsid']=$v;
- if($status==-2){ //下架
- $post_data=[];
- $post_data['status']=0;
- $post_data['issale']=0;
- $post_data['live_isshow']=0;
- }else{ //上架
- $post_data=[];
- $post_data['status']=1;
- }
- setOnsalePlatformInfo($where,$post_data);
- }
-
- }
- $admin_id=cmf_get_current_admin_id();
- if($status==-2){
- $action=$admin_id.'下架商品IDS: '.json_encode($ids);
- }else{
- $action=$admin_id.'上架商品IDS: '.json_encode($ids);
- }
- setAdminLog($action);
- }
-
- $this->success("操作成功!");
- }
-
-
- function setRecom(){
-
- $id = $this->request->param('id', 0, 'intval');
- $isrecom = $this->request->param('isrecom', 0, 'intval');
-
-
-
-
- $rs = DB::name('shop_goods')->where("id={$id}")->update(['isrecom'=>$isrecom]);
- if(!$rs){
- $this->error("操作失败!");
- }
-
-
- if($isrecom==1){
- $action='推荐商品ID: '.$id;
- }else{
- $action='取消推荐商品ID: '.$id;
- }
- setAdminLog($action);
-
-
- $this->success("操作成功!");
- }
-
- function del(){
- $data=$this->request->param();
- if(isset($data['id'])){
- $id = $data['id'];
- //判断代售该商品的用户是否有在直播间销售的
- $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$id} and (issale=1 or live_isshow=1)")->count();
- if($sale_platform){
- $this->error("有主播正在直播间代售该商品,暂时无法删除");
- }
- $goodsinfo=DB::name('shop_goods')->where("id={$id}")->find();
- $rs = DB::name('shop_goods')->where("id={$id}")->delete();
- if(!$rs){
- $this->error("删除失败!");
- }
- if($goodsinfo['uid']>1){
- $title='商品删除提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”已被平台删除。';
- //写入记录
- addSysytemInfo($goodsinfo['uid'],$title,$msg);
- //发送腾讯云IM
- txMessageIM($msg,$goodsinfo['uid']);
- }
-
- //删除商品访问记录
- Db::name("user_goods_visit")->where("goodsid={$id}")->delete();
- //修改视频的绑定信息
- Db::name("user_video")->where("goodsid={$id}")->update(array('goodsid'=>0,'isgoods'=>0));
-
- //删除收藏的商品
- Db::name('user_goods_collect')->where("goodsid='{$id}'")->delete();
-
- //删除代售商品记录
- Db::name("seller_platform_goods")->where("goodsid={$id}")->delete();
-
-
- $action='删除商品ID: '.$id;
-
- setAdminLog($action);
- }else if(isset($data['ids'])){
- $ids=$data['ids'];
- foreach ($ids as $k => $v) {
- //判断是否有主播在直播间代售该商品
-
- $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$v} and (issale=1 or live_isshow=1)")->count();
- if($sale_platform){
- continue;
- }
- $goodsinfo=DB::name('shop_goods')->where("id={$v}")->find();
- $rs = DB::name('shop_goods')->where("id={$v}")->delete();
- if($goodsinfo['uid']>0){
- $title='商品删除提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”已被平台删除。';
-
- //写入记录
- $id=addSysytemInfo($goodsinfo['uid'],$title,$msg);
- //发送腾讯云IM
- txMessageIM($msg,$goodsinfo['uid']);
- }
-
-
- //删除商品访问记录
- Db::name("user_goods_visit")->where("goodsid={$v}")->delete();
- //修改视频的绑定信息
- Db::name("user_video")->where("goodsid={$v}")->update(array('goodsid'=>0));
- }
-
-
-
- $action='删除商品IDS: '.json_encode($ids);
-
- setAdminLog($action);
- }
-
-
- $this->success("删除成功!",url("shopgoods/index"));
- }
- //审核/详情
- function edit(){
- $data=$this->request->param();
- $id = $data['id'];
- $url_type=$data['url_type'];
- $goodsinfo=Db::name("shop_goods")->where("id={$id}")->find();
-
- if(!$goodsinfo){
- $this->error("数据错误");
- }
- $userinfo=getUserInfo($goodsinfo['uid']);
- $goodsinfo['userinfo']=$userinfo;
- $oneclass_name=Db::name("shop_goods_class")->where("gc_id={$goodsinfo['one_classid']}")->value("gc_name");
- $twoclass_name=Db::name("shop_goods_class")->where("gc_id={$goodsinfo['two_classid']}")->value("gc_name");
- $threeclass_name=Db::name("shop_goods_class")->where("gc_id={$goodsinfo['three_classid']}")->value("gc_name");
- $goodsinfo['oneclass_name']=isset($oneclass_name)?$oneclass_name:'';
- $goodsinfo['twoclass_name']=isset($twoclass_name)?$twoclass_name:'';
- $goodsinfo['threeclass_name']=isset($threeclass_name)?$threeclass_name:'';
- if(isset($goodsinfo['video_url'])){
- $goodsinfo['video_url']=get_upload_path($goodsinfo['video_url']);
- }
- $thumb_arr=explode(',',$goodsinfo['thumbs']);
- foreach ($thumb_arr as $k => $v) {
- $thumb_arr[$k]=get_upload_path($v);
- }
- $goodsinfo['thumb_arr']=$thumb_arr;
- $picture_arr=[];
- if(isset($goodsinfo['pictures'])){
- $picture_arr=explode(',',$goodsinfo['pictures']);
- foreach ($picture_arr as $k => $v) {
- $picture_arr[$k]=get_upload_path($v);
- }
- }
- $goodsinfo['picture_arr']=$picture_arr;
- $spec_arr=json_decode($goodsinfo['specs'],true);
-
- $goodsinfo['spec_arr']=$spec_arr;
- unset($goodsinfo['thumbs'],$goodsinfo['pictures'],$goodsinfo['specs']);
- $this->assign('data', $goodsinfo);
- $status=$this->getStatus();
- if(($goodsinfo['status']==0 || $goodsinfo['status']==2) && $goodsinfo['type']!=2){
- unset($status['-2']);
- unset($status['-1']);
- unset($status['0']);
- }
-
- $this->assign('status', $status);
- $this->assign('url_type', $url_type);
-
- return $this->fetch();
- }
- //编辑提交
- public function editPost(){
- $data=$this->request->param();
- $id=$data['id'];
- $goodsinfo=Db::name("shop_goods")->where("id={$id}")->find();
- $status=$data['status'];
- $refuse_reason=trim($data['refuse_reason']);
- if($status==2){ //管理员拒绝
- if($refuse_reason==''){
- $this->error("请填写拒绝理由");
- }
- }else{
- $refuse_reason='';
- }
- $data['refuse_reason']=$refuse_reason;
- $data['uptime']=time();
- $res=Db::name("shop_goods")->update($data);
- if($res===false){
- $this->error("编辑失败");
- }
- $uid=$goodsinfo['uid'];
- $title='';
- if($status && $uid>1){
- if($status==1){
- $title='商品上架提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”已通过平台审核,上架成功。';
- //发送腾讯云IM
- txMessageIM($msg,$uid);
- }
- if($status==2){
- //发送极光推送
-
- $title='商品审核失败提醒';
- $msg='你的商品“'.$goodsinfo['name'].'”未通过平台审核。';
- if($refuse_reason){
- $msg.='原因:'.$refuse_reason;
- }
- //发送腾讯云IM
- txMessageIM($msg,$uid);
- }
- //写入记录
- $id=addSysytemInfo($uid,$title,$msg);
- }
- $this->success("修改成功!");
- }
- //商品评论列表
- public function commentlist(){
- $data = $this->request->param();
- $goods_id=$data['goods_id'];
- $map=[];
- $map[]=['goodsid','=',$goods_id];
- $map[]=['is_append','=','0'];
-
- $start_time=isset($data['start_time']) ? $data['start_time']: '';
- $end_time=isset($data['end_time']) ? $data['end_time']: '';
-
- if($start_time!=""){
- $map[]=['addtime','>=',strtotime($start_time)];
- }
- if($end_time!=""){
- $map[]=['addtime','<=',strtotime($end_time) + 60*60*24];
- }
-
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- if($keyword!=''){
- $map[]=['content','like','%'.$keyword.'%'];
- }
-
- $lists = Db::name("shop_order_comments")
- ->where($map)
- ->order("id asc")
- ->paginate(20);
-
- $lists->each(function($v,$k){
- $v['userinfo']=getUserInfo($v['uid']);
- $v['shop_userinfo']=getUserInfo($v['shop_uid']);
-
- if($v['thumbs']){
- $thumb_arr=explode(',',$v['thumbs']);
- foreach ($thumb_arr as $k1 => $v1) {
- $thumb_arr[$k1]=get_upload_path($v1);
- }
- $v['thumb_arr']=$thumb_arr;
- }else{
- $v['thumb_arr']=[];
- }
- if($v['video_thumb']){
- $v['video_thumb']=get_upload_path($v['video_thumb']);
- }
- if($v['video_url']){
- $v['video_url']=get_upload_path($v['video_url']);
- }
-
-
- //获取追评信息
- $append_comment=Db::name("shop_order_comments")->where("orderid={$v['orderid']} and is_append=1")->find();
- if($append_comment){
- $append_comment['userinfo']=getUserInfo($append_comment['uid']);
- $append_comment['shop_userinfo']=getUserInfo($append_comment['shop_uid']);
- if($append_comment['thumbs']){
- $thumb_arr=explode(',',$append_comment['thumbs']);
- foreach ($thumb_arr as $k1 => $v1) {
- $thumb_arr[$k1]=get_upload_path($v1);
- }
- $append_comment['thumb_arr']=$thumb_arr;
- }else{
- $append_comment['thumb_arr']=[];
- }
- if($append_comment['video_thumb']){
- $append_comment['video_thumb']=get_upload_path($append_comment['video_thumb']);
- }
- if($append_comment['video_url']){
- $append_comment['video_url']=get_upload_path($append_comment['video_url']);
- }
- }
-
- $v['append_comment']=$append_comment;
- return $v;
- });
-
- $lists->appends($data);
- $page = $lists->render();
- $this->assign('lists', $lists);
- $this->assign('goods_id', $goods_id);
- $this->assign("page", $page);
-
- return $this->fetch();
- }
- //删除视频评论
- function delComment(){
- $id = $this->request->param('id', 0, 'intval');
- $rs=Db::name("shop_order_comments")->where("id={$id}")->delete();
- if(!$rs){
- $this->error("评论删除失败");
- }
- $this->success("删除成功");
- }
- //评论视频播放
- function videoplay(){
- $data=$this->request->param();
- $url=$data['url'];
- $this->assign('url',$url);
- return $this->fetch();
- }
- //添加商品
- function add(){
- //判断自营店铺信息是否添加
- $platform_info=Db::name("shop_apply")->where("uid=1")->find();
- if(!$platform_info){
- $this->error("请先填写自营平台店铺信息");
- }
-
- $configpub=getConfigPub();
- $site=$configpub['site'];
- //通过接口获取商品分类中有三级的一级分类
- $configpub=getConfigPub();
- $site=$configpub['site'];
- $header = array(
- 'Accept: application/json',
- );
- $url=$site."/appapi/?s=Shop.getOneGoodsClass";
- $curl = curl_init();
- //设置抓取的url
- curl_setopt($curl, CURLOPT_URL, $url);
- //设置头文件的信息作为数据流输出
- curl_setopt($curl, CURLOPT_HEADER, 0);
- // 超时设置,以秒为单位
- curl_setopt($curl, CURLOPT_TIMEOUT, 30);
-
- // 设置请求头
- curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
- //设置获取的信息以文件流的形式返回,而不是直接输出。
- curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
- curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
- curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
- //执行命令
- $res = curl_exec($curl);
-
- // 显示错误信息
- if (curl_error($curl)) {
- $this->error("请确认商品分类");
- }
- curl_close($curl);
- $info=json_decode($res,true);
- $ret=$info['ret'];
- $code=$info['data']['code'];
- $msg=$info['data']['msg'];
- $one_classlist=$info['data']['info'];
- if($ret!=200){
- $this->error("请确认商品分类");
- return;
- }
- if($code!=0){
- $this->error($msg);
- return;
- }
- $this->assign("one_classlist",$one_classlist);
- return $this->fetch();
- }
- //jquery获取二级商品分类
- function getTwoClassLists(){
- $rs=array('code'=>0,'msg'=>'','info'=>array());
- $data = $this->request->param();
- $one_classid=$data['one_classid'];
- if(!$one_classid){
- $rs['code']=1001;
- $rs['msg']='请选择一级分类';
- echo json_encode($rs);
- return;
- }
- $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();
- if(empty($two_list)){
- $rs['code']=1002;
- $rs['msg']='商品二级分类为空';
- echo json_encode($rs);
- return;
- }
- $rs['info']=$two_list;
- echo json_encode($rs);
-
- }
- //jquery获取二级商品分类
- function getThreeClassLists(){
- $rs=array('code'=>0,'msg'=>'','info'=>array());
- $data = $this->request->param();
- $two_classid=$data['two_classid'];
- if(!$two_classid){
- $rs['code']=1001;
- $rs['msg']='请选择二级分类';
- echo json_encode($rs);
- return;
- }
- $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();
- if(empty($three_list)){
- $rs['code']=1002;
- $rs['msg']='商品三级分类为空';
- echo json_encode($rs);
- return;
- }
- $rs['info']=$three_list;
- echo json_encode($rs);
- }
- //商品添加保存
- function addPost(){
- $data=$this->request->param();
- $name=$data['name'];
- $one_classid=$data['one_classid'];
- $two_classid=$data['two_classid'];
- $three_classid=$data['three_classid'];
- $video_is_upload=$data['video_is_upload'];
- //$video_url=trim($data['video_url']);
- $video_thumb=$data['video_thumb'];
- $thumbs=$data['thumbs'];
- $content=trim($data['content']);
- $pictures=$data['pictures'];
- $spec_name=$data['spec_name'];
- $spec_num=$data['spec_num'];
- $spec_price=$data['spec_price'];
- $spec_thumb=$data['spec_thumb'];
- $postage=$data['postage'];
- $commission=$data['commission'];
- $status=$data['status'];
- $share_income=$data['share_income'];
- $isrecom=$data['isrecom']??0;
- $is_assisting_farmers=$data['is_assisting_farmers']??0;
- $is_seckill=$data['is_seckill']??0;
- if(!$name){
- $this->error("请填写商品标题");
- }
- if(mb_strlen($name)>15){
- $this->error("商品标题长度在15字以内");
- }
- if(!$one_classid){
- $this->error("请选择一级分类");
- }
- if(!$two_classid){
- $this->error("请选择二级分类");
- }
- if(!$three_classid){
- $this->error("请选择三级分类");
- }
- if($video_is_upload){
- if(!$video_thumb){
- $this->error("请上传视频封面图片");
- }
- if(!$_FILES["file"]){
- $this->error("请上传视频");
- }
- $files["file"]=$_FILES["file"];
- $type='mp4';
-
- $allow=['mp4'];
- if (!get_file_suffix($files['file']['name'],$allow)){
- $this->error("请上传正确MP4格式的文件");
- }
-
- $rs=adminUploadFiles($files,$type);
- //file_put_contents('111111.txt', json_encode($rs));
- if($rs['code']!=0){
- $this->error($rs['msg']);
- }
- $video_data['video_thumb']=$video_thumb;
- $video_data['video_url']=$rs['filepath'];
-
- unset($data['file']);
- }else{
- $video_data['video_thumb']='';
- $video_data['video_url']='';
- }
- if(!$thumbs){
- $this->error("请上传商品缩略图");
- }
-
- $thumbs_arr=[]; //封面图重新
- foreach ($thumbs as $k => $v) {
- if($v!=""){
- $thumbs_arr[]=$v;
- }
- }
- if(empty($thumbs_arr)){
- $this->error("请上传商品缩略图");
- }
- if($content==""){
- $this->error("请填写商品详情");
- }
- if(mb_strlen($content)>300){
- $this->error("商品详情字数在300字以内");
- }
- $picture_arr=[];
-
- if(!empty($pictures)){
- foreach ($pictures as $k => $v) {
- if($v!=''){
- $picture_arr[]=$v;
- }
- }
- }
- // 商品规格名称
- if(!$spec_name){
- $this->error("请填写商品规格名称");
- }
- $spec_name_arr=[];
- $spec_name_error=0;
- foreach ($spec_name as $k => $v) {
- $specs_list_name=trim($v);
- if($specs_list_name==''||mb_strlen($specs_list_name)>15){
- $spec_name_error=1;
- break;
- }
- $spec_name_arr[]=$specs_list_name;
- }
- if($spec_name_error){
- $this->error("请确认商品规格名称是否填写或是否超过15字");
- }
- // 商品规格库存
-
- if(!$spec_num){
- $this->error("请填写商品规格库存");
- }
- $spec_num_arr=[];
- $spec_num_error=0;
- foreach ($spec_num as $k => $v) {
- $num=trim($v);
- if($num==''||$num<1||$num>9999999||floor($num) !=$num ){
- $spec_num_error=1;
- break;
- }
- $spec_num_arr[]=$num;
- }
- if($spec_num_error){
- $this->error("请确认商品规格库存是否在1-9999999之间");
- }
- // 商品规格单价
- if(!$spec_price){
- $this->error("请填写商品规格单价");
- }
- $spec_price_arr=[];
- $spec_price_error=0;
- foreach ($spec_price as $k => $v) {
- $price=trim($v);
- if($price==''||!$price ||$price<1||$price>99999999||!is_numeric($price)){
- $spec_price_error=1;
- break;
- }
- $spec_price_arr[]=round($price,2);
- }
- if($spec_price_error){
- $this->error("请确认商品规格价格是否在1-99999999之间");
- }
- // 商品规格封面
- if(!$spec_thumb){
- $this->error("请确认商品规格封面");
- }
- $spec_thumb_arr=[];
- $spec_thumb_error=0;
- foreach ($spec_thumb as $k => $v) {
- $thumb_src=trim($v);
- if(!$thumb_src){
- $spec_thumb_error=1;
- break;
- }
- $spec_thumb_arr[]=$thumb_src;
- }
- if($spec_thumb_error){
- $this->error("请确认商品规格封面");
- }
- // 邮费
- if(!is_numeric($postage)){
- $this->error("邮费必须为数字");
- }
- if($postage<0||$postage>99999){
- $this->error("邮费必须在0-99999之间");
- }
- $postage=round($postage,2);
- // 佣金
- if(!is_numeric($commission)){
- $this->error("佣金必须为数字");
- }
- if($commission<0||$commission>99999){
- $this->error("佣金必须在0-99999之间");
- }
- $commission=round($commission,2);
- //分享得佣金
- if(!is_numeric($share_income)){
- $this->error("分享佣金必须为数字");
- }
- if($share_income<0||$share_income>99999){
- $this->error("分享佣金必须在0-99999之间");
- }
- $share_income=round($share_income,2);
- $specs_arr=[];
- foreach ($spec_name_arr as $k => $v) {
- $arr=[];
- $arr['spec_id']=$k+1;
- $arr['spec_name']=$v;
- $arr['spec_num']=$spec_num_arr[$k];
- $arr['price']=$spec_price_arr[$k];
- $arr['thumb']=$spec_thumb_arr[$k];
- $specs_arr[]=$arr;
- }
- $admin_id=cmf_get_current_admin_id();
- $post_data=array(
- 'uid'=>1,
- 'name'=>$name,
- 'one_classid'=>$one_classid,
- 'two_classid'=>$two_classid,
- 'three_classid'=>$three_classid,
- 'thumbs'=>implode(',', $thumbs_arr),
- 'content'=>htmlspecialchars($content),
- 'specs'=>json_encode($specs_arr),
- 'postage'=>$postage,
- 'addtime'=>time(),
- 'type'=>2,
- 'admin_id'=>$admin_id,
- 'commission'=>$commission,
- 'status'=>$status,
- 'share_income'=>$share_income,
- 'isrecom'=>$isrecom,
- 'is_assisting_farmers'=>$is_assisting_farmers,
- 'is_seckill'=>$is_seckill
- );
- if(!empty($picture_arr)){
- $post_data['pictures']=implode(',',$picture_arr);
- }else{
- $post_data['pictures']='';
- }
- $new_post_data=array_merge($video_data,$post_data);
- /*var_dump($new_post_data);
- die;*/
- $id=Db::name("shop_goods")->insertGetId($new_post_data);
- if(!$id){
- $this->error("商品添加失败!");
- }
- $action=$admin_id."添加商品:{$id}";
- setAdminLog($action);
- $this->success("商品添加成功!");
- }
- //平台自营商品编辑
- public function platformedit(){
- $data=$this->request->param();
- $id=$data['id'];
- $url_type=$data['url_type'];
-
- $configpub=getConfigPub();
- $site=$configpub['site'];
- $header = array(
- 'Accept: application/json',
- );
- $curl = curl_init();
- $url=$site."/appapi/?s=Shop.getOneGoodsClass";
- //设置抓取的url
- curl_setopt($curl, CURLOPT_URL, $url);
- //设置头文件的信息作为数据流输出
- curl_setopt($curl, CURLOPT_HEADER, 0);
- // 超时设置,以秒为单位
- curl_setopt($curl, CURLOPT_TIMEOUT, 30);
-
- // 设置请求头
- curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
- //设置获取的信息以文件流的形式返回,而不是直接输出。
- curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
- curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
- curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
- //执行命令
- $res = curl_exec($curl);
-
- // 显示错误信息
- if (curl_error($curl)) {
- $this->error("请确认商品分类");
- }
- curl_close($curl);
- $info=json_decode($res,true);
- $ret=$info['ret'];
- $code=$info['data']['code'];
- $msg=$info['data']['msg'];
- $one_classlist=$info['data']['info'];
- if($ret!=200){
- $this->error("请确认商品分类");
- return;
- }
- if($code!=0){
- $this->error($msg);
- return;
- }
- //获取自营商品信息
- $info=Db::name("shop_goods")->where("id='{$id}'")->find();
- //根据一级分类获取二级分类
- $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();
- //根据二级分类获取三级分类
- $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();
-
- $thumbs_arr=[];
- if($info['thumbs']){
- $thumbs_arr=explode(',',$info['thumbs']);
- }
-
- $pictures_arr=[];
- if($info['pictures']){
- $pictures_arr=explode(',', $info['pictures']);
- }
-
- $specs_arr=json_decode($info['specs'],true);
- $specs_thumbs_arr=[];
- foreach ($specs_arr as $k => $v) {
- $specs_thumbs_arr[]=$v['thumb'];
- }
- $this->assign("one_classlist",$one_classlist);
- $this->assign("info",$info);
- $this->assign("two_classlist",$two_classlist);
- $this->assign("three_classlist",$three_classlist);
- $this->assign("thumbs_arr",$thumbs_arr);
- $this->assign("thumbs_num",count($thumbs_arr));
- $this->assign("pictures_arr",$pictures_arr);
- $this->assign("pictures_num",count($pictures_arr));
- $this->assign("specs_arr",$specs_arr);
- $this->assign("specs_num",count($specs_arr));
- $this->assign("thumbs",$info['thumbs']);
- $this->assign("pictures",$info['pictures']);
- $this->assign("specs_thumbs",implode(',', $specs_thumbs_arr));
- $this->assign("url_type",$url_type);
- return $this->fetch();
- }
- //平台自营商品编辑提交
- public function platformeditPost(){
- $data=$this->request->param();
- $id=$data['id'];
- $name=$data['name'];
- $one_classid=$data['one_classid'];
- $two_classid=$data['two_classid'];
- $three_classid=$data['three_classid'];
- $video_is_upload=$data['video_is_upload'];
- $video_thumb=$data['video_thumb'];
- $video_url='';
- if(!isset($data['thumbs'])){
- $this->error("请上传商品缩略图");
- }
- $thumbs=$data['thumbs'];
- $content=trim($data['content']);
- if(isset($data['pictures'])){
- $pictures=$data['pictures'];
- }
-
- $spec_name=$data['spec_name'];
- $spec_num=$data['spec_num'];
- $spec_price=$data['spec_price'];
- $spec_thumb=$data['spec_thumb'];
- $postage=$data['postage'];
- $commission=$data['commission'];
- $status=$data['status'];
- $share_income=$data['share_income']??0;
- $isrecom=$data['isrecom']??0;
- $is_assisting_farmers=$data['is_assisting_farmers']??0;
- $is_seckill=$data['is_seckill']??0;
- if(!$name){
- $this->error("请填写商品标题");
- }
- if(mb_strlen($name)>15){
- $this->error("商品标题长度在15字以内");
- }
- if(!$one_classid){
- $this->error("请选择一级分类");
- }
- if(!$two_classid){
- $this->error("请选择二级分类");
- }
- if(!$three_classid){
- $this->error("请选择三级分类");
- }
- if($video_is_upload){
-
- if(!$video_thumb){
- $this->error("请上传视频封面图片");
- }
- if($_FILES["file"]){
-
- $files["file"]=$_FILES["file"];
- $type='mp4';
-
- $allow=['mp4'];
- if (!get_file_suffix($files['file']['name'],$allow)){
- $this->error("请上传正确MP4格式的文件");
- }
-
- $rs=adminUploadFiles($files,$type);
- if($rs['code']!=0){
- $this->error($rs['msg']);
- }
- $video_url=$rs['filepath'];
- unset($data['file']);
- $video_data['video_url']=$video_url;
- }
- $video_data['video_thumb']=$video_thumb;
-
-
- }else{
- $video_data['video_thumb']='';
- $video_data['video_url']='';
- }
- if(!$thumbs){
- $this->error("请上传商品缩略图");
- }
-
- $thumbs_arr=$thumbs;
- if($content==""){
- $this->error("请填写商品详情");
- }
- if(mb_strlen($content)>300){
- $this->error("商品详情字数在300字以内");
- }
- if(!empty($pictures)){
- $picture_arr=$pictures;
- }
-
-
- if(!$spec_name){
- $this->error("请填写商品规格名称");
- }
- $spec_name_arr=[];
- $spec_name_error=0;
- foreach ($spec_name as $k => $v) {
- $specs_list_name=trim($v);
- if($specs_list_name==''||mb_strlen($specs_list_name)>15){
- $spec_name_error=1;
- break;
- }
- $spec_name_arr[]=$specs_list_name;
- }
- if($spec_name_error){
- $this->error("请确认商品规格名称是否填写或是否超过15字");
- }
- if(!$spec_num){
- $this->error("请填写商品规格库存");
- }
- $spec_num_arr=[];
- $spec_num_error=0;
- foreach ($spec_num as $k => $v) {
- $num=trim($v);
- if($num==''||$num<1||$num>9999999||floor($num) !=$num ){
- $spec_num_error=1;
- break;
- }
- $spec_num_arr[]=$num;
- }
- if($spec_num_error){
- $this->error("请确认商品规格库存是否在1-9999999之间");
- }
- if(!$spec_price){
- $this->error("请填写商品规格单价");
- }
- $spec_price_arr=[];
- $spec_price_error=0;
- foreach ($spec_price as $k => $v) {
- $price=trim($v);
- if($price==''||!$price ||$price<1||$price>99999999||!is_numeric($price)){
- $spec_price_error=1;
- break;
- }
- $spec_price_arr[]=round($price,2);
- }
- if($spec_price_error){
- $this->error("请确认商品规格价格是否在1-99999999之间");
- }
- if(!$spec_thumb){
- $this->error("请确认商品规格封面");
- }
- $spec_thumb_arr=$spec_thumb;
- $spec_thumb_error=0;
- foreach ($spec_thumb as $k => $v) {
- $thumb_src=trim($v);
- if(!$thumb_src){
- $spec_thumb_error=1;
- break;
- }
- }
- if($spec_thumb_error){
- $this->error("请确认商品规格封面");
- }
- if(!is_numeric($postage)){
- $this->error("邮费必须为数字");
- }
- if($postage<0||$postage>99999){
- $this->error("邮费必须在0-99999之间");
- }
- $postage=round($postage,2);
- if(!is_numeric($commission)){
- $this->error("佣金必须为数字");
- }
- if($commission<0||$commission>99999){
- $this->error("佣金必须在0-99999之间");
- }
- $commission=round($commission,2);
- if(!is_numeric($share_income)){
- $this->error("分享佣金必须为数字");
- }
- if($share_income<0||$share_income>99999){
- $this->error("分享佣金必须在0-99999之间");
- }
- $share_income=round($share_income,2);
- $specs_arr=[];
- foreach ($spec_name_arr as $k => $v) {
- $arr=[];
- $arr['spec_id']=$k+1;
- $arr['spec_name']=$v;
- $arr['spec_num']=$spec_num_arr[$k];
- $arr['price']=$spec_price_arr[$k];
- $arr['thumb']=$spec_thumb_arr[$k];
- $specs_arr[]=$arr;
- }
- if($status=='-2'){
- $sale_platform=Db::name("seller_platform_goods")->where("goodsid={$id} and (issale=1 or live_isshow=1)")->count();
- if($sale_platform){
- $this->error("有主播正在直播间代售该商品,暂时无法下架");
- }
- }
- $admin_id=cmf_get_current_admin_id();
- $post_data=array(
- 'id'=>$id,
- 'uid'=>1,
- 'name'=>$name,
- 'one_classid'=>$one_classid,
- 'two_classid'=>$two_classid,
- 'three_classid'=>$three_classid,
- 'thumbs'=>implode(',', $thumbs_arr),
- 'content'=>htmlspecialchars($content),
- 'specs'=>json_encode($specs_arr),
- 'postage'=>$postage,
- 'uptime'=>time(),
- 'type'=>2,
- 'commission'=>$commission,
- 'status'=>$status,
- 'share_income'=>$share_income,
- 'isrecom'=>$isrecom,
- 'is_assisting_farmers'=>$is_assisting_farmers,
- 'is_seckill'=>$is_seckill
- );
- if(!empty($picture_arr)){
- $post_data['pictures']=implode(',',$picture_arr);
- }
- $new_post_data=array_merge($video_data,$post_data);
- $res=Db::name("shop_goods")->update($new_post_data);
- /*var_dump(Db::name("shop_goods")->getLastSql());
- die;*/
- if($res===false){
- $this->error("商品修改失败!");
- }
- if($status==0||$status==-2){ //下架或待审核
- Db::name("seller_platform_goods")->where("goodsid={$id}")->update(array("status"=>0,"issale"=>0,"live_isshow"=>0));
- }else if($status==1){
- Db::name("seller_platform_goods")->where("goodsid={$id}")->update(array("status"=>1));
- }
- $action=$admin_id."修改商品:{$id}";
- setAdminLog($action);
- $this->success("商品修改成功!");
- }
-
- }
|