AgentController.php 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. <?php
  2. /**
  3. * 经销商管理
  4. * @author system
  5. * @version 1.0
  6. * @date 2018-05-14 13:26:07
  7. *
  8. */
  9. namespace App\Http\Controllers\Admin\Album;
  10. use App\Http\Controllers\Admin\Controller;
  11. use App\Models\AgentBannerModel;
  12. use App\Models\AlbumAgentModel;
  13. use App\Models\AlbumProductPriceModel;
  14. use App\Models\AlbumUserModel;
  15. use App\Repositories\Album\Criteria\AgentWhere;
  16. use App\Services\OSS;
  17. use Illuminate\Http\Request;
  18. use App\Repositories\Base\Criteria\OrderBy;
  19. use App\Repositories\Album\Criteria\MultiWhere;
  20. use App\Repositories\Album\AgentRepository;
  21. class AgentController extends Controller
  22. {
  23. private $repository;
  24. public function __construct(AgentRepository $repository) {
  25. if(!$this->repository) $this->repository = $repository;
  26. }
  27. function index(Request $request) {
  28. $search['keyword'] = $request->input('keyword');
  29. $query = $this->repository->pushCriteria(new AgentWhere($search,$this->getStoreId()));
  30. if(isset($request['sort_field']) && $request['sort_field'] && isset($request['sort_field_by'])) {
  31. $query = $query->pushCriteria(new OrderBy($request['sort_field'],$request['sort_field_by']));
  32. }else{
  33. $query = $query->pushCriteria(new OrderBy('id','DESC'));
  34. }
  35. $list = $query->paginate();
  36. foreach ($list as $item){
  37. $product = AlbumProductPriceModel::where([['agent_id',$item->id],['store_id',$this->getStoreId()]])->first();
  38. if(!empty($product)){
  39. $item->product_name = $product['mobile'];
  40. }
  41. $item->product_pic = $product['cover_pic'];
  42. }
  43. foreach ($list as $item){
  44. if($item->status == 0){
  45. $item->status = '待审核';
  46. }else{
  47. $item->status = '已审核';
  48. }
  49. }
  50. return view('admin.album.agent.index',compact('list'));
  51. }
  52. function check(Request $request) {
  53. $request = $request->all();
  54. $search['keyword'] = $request->input('keyword');
  55. $orderby = array();
  56. if(isset($request['sort_field']) && $request['sort_field'] && isset($request['sort_field_by'])) {
  57. $orderby[$request['sort_field']] = $request['sort_field_by'];
  58. }
  59. $list = $this->repository->search($search,$orderby);
  60. return view('admin.album.agent.check',compact('list'));
  61. }
  62. /**
  63. * 添加
  64. *
  65. */
  66. public function create(Request $request)
  67. {
  68. if($request->method() == 'POST') {
  69. return $this->_createSave();
  70. }
  71. return view('admin.album.agent.edit');
  72. }
  73. /**
  74. * 保存修改
  75. */
  76. private function _createSave(){
  77. $data = (array) request('data');
  78. $agent_banner = $data['banner_agent']['url'];
  79. unset($data['banner_agent']);
  80. if($agent_banner){
  81. foreach($agent_banner as $key=>$val){
  82. $add['url'] = $this->formatImgUrl($val);
  83. $add['agent_id'] = request('id');
  84. $add['type'] = 0;
  85. AgentBannerModel::create($add);
  86. }
  87. }
  88. $id = $this->repository->create($data);
  89. if($id) {
  90. $url[] = array('url'=>U( 'Album/Agent/index'),'title'=>'返回列表');
  91. $url[] = array('url'=>U( 'Album/Agent/create'),'title'=>'继续添加');
  92. $this->showMessage('添加成功',$url);
  93. }else{
  94. $url[] = array('url'=>U( 'Album/Agent/index'),'title'=>'返回列表');
  95. return $this->showWarning('添加失败',$url);
  96. }
  97. }
  98. /**
  99. *
  100. * 修改
  101. *
  102. *
  103. */
  104. public function update(Request $request) {
  105. if($request->method() == 'POST') {
  106. return $this->_updateSave();
  107. }
  108. $data = $this->repository->find($request->get('id'));
  109. $banner = AgentBannerModel::where([['agent_id',$data['id']],['type',0]])->get();
  110. $imgs = array();
  111. foreach($banner as $key=>$val){
  112. $imgs[] = $val['url'];
  113. }
  114. $data->agent_banner = $imgs;
  115. $video = AgentBannerModel::where([['agent_id',$request->get('id')],['type',1]])->first();
  116. return view('admin.album.agent.edit',compact('data','video'));
  117. }
  118. public function videoDel(Request $request)
  119. {
  120. $check = AgentBannerModel::find($request->get('id'));
  121. if($check) $osskey = $check->oss_key;
  122. if(!$check) return $this->showWarning("操作失败");
  123. $bool = AgentBannerModel::where('id',$request->get('id'))->delete();
  124. if($bool) {
  125. OSS::publicDeleteObject(config('alioss.BucketName'),$osskey);
  126. return $this->showMessage('操作成功');
  127. }else{
  128. return $this->showWarning("操作失败");
  129. }
  130. }
  131. /**
  132. * 保存修改
  133. */
  134. private function _updateSave() {
  135. $data = (array) request('data');//dd($data);
  136. $id = request('id');
  137. $banner = AgentBannerModel::where([['agent_id',$id],['type',0]])->get();
  138. if($banner){
  139. foreach ($banner as $key=>$val){
  140. $url = str_replace(env('APP_URL'),public_path(),$val['url']);
  141. if(file_exists($url)) unlink($url);
  142. }
  143. }
  144. AgentBannerModel::where([['agent_id',$id],['type',0]])->delete();
  145. if(!empty($data['agent_banner']['url'])){
  146. foreach($data['agent_banner']['url'] as $key=>$val){
  147. $add['url'] = $this->formatImgUrl($val);
  148. $add['agent_id'] = $id;
  149. $add['type'] = 0;
  150. AgentBannerModel::create($add);
  151. }
  152. }
  153. unset($data['agent_banner']);
  154. $ok = $this->repository->update(request('id'),$data);
  155. if($ok) {
  156. $urls[] = array('url'=>U( 'Album/Agent/index'),'title'=>'返回列表');
  157. $this->showMessage('添加成功',$urls);
  158. }else{
  159. $urls[] = array('url'=>U( 'Album/Agent/index'),'title'=>'返回列表');
  160. return $this->showWarning('操作失败',$urls);
  161. }
  162. }
  163. public function view(Request $request) {
  164. $data = $this->repository->find(request('id'));
  165. return view('admin.album.agent.view',compact('data'));
  166. }
  167. /**
  168. *
  169. * 状态改变
  170. *
  171. */
  172. public function status(Request $request) {
  173. $ok = $this->repository->updateStatus(request('id'),request('status'));
  174. if(request('status')==1){
  175. $agent = AlbumAgentModel::find(request('id'));
  176. $user = AlbumUserModel::find($agent->user_id);
  177. $user->is_dealer = 1;
  178. $user->save();
  179. }
  180. if($ok) {
  181. return $this->showMessage('操作成功');
  182. }else{
  183. return $this->showWarning('操作失败');
  184. }
  185. }
  186. /**
  187. * 删除
  188. */
  189. public function destroy(Request $request) {
  190. $agent = AlbumAgentModel::find($request->get('id'));
  191. $id= $agent->user_id;
  192. $ok = $agent->delete();
  193. $save['is_dealer'] = 0;
  194. AlbumUserModel::where('id',$id)->update($save);
  195. if($ok) {
  196. return $this->showMessage('操作成功');
  197. }else{
  198. return $this->showWarning("操作失败");
  199. }
  200. }
  201. public function uploadVideo(Request $request)
  202. {
  203. $video = $request->file('video');
  204. // 判断图片有效性
  205. if (!$video) {
  206. return back()->withErrors('上传视频无效..');
  207. }
  208. $agentid = $request->input('agent_id');
  209. $check = AgentBannerModel::where([['agent_id',$agentid],['type',1]])->first();
  210. if($check) OSS::publicDeleteObject(config('alioss.BucketName'),$check->oss_key);
  211. // 获取图片在临时文件中的地址
  212. $videoPath = $video->getRealPath();
  213. // 制作文件名
  214. $ex = $video->getClientOriginalExtension();
  215. $key = time() . rand(10000, 99999999) . '.' . $ex;
  216. //阿里 OSS 文件上传
  217. $result = OSS::publicUpload(config('alioss.BucketName'),$key, $videoPath);
  218. if ($result) {
  219. $data['name'] = $video->getClientOriginalName();
  220. $data['type'] = 1;
  221. $data['agent_id'] = $agentid;
  222. $data['oss_key'] = $key;
  223. $data['url'] = config('alioss.FileUrl').$key;
  224. $video = AgentBannerModel::create($data);
  225. if(!$video){
  226. return back()->withErrors('上传视频失败..');
  227. }
  228. return $this->showMessage('上传成功');
  229. } else {
  230. return back()->withErrors('上传视频失败..');
  231. }
  232. }
  233. }