ChannelServic.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <?php
  2. /**
  3. *
  4. * @file:Channel.php
  5. * @Date: 2023/6/8
  6. * @Time: 11:17
  7. */
  8. namespace Modules\Operation\Service;
  9. use Modules\Common\Services\BaseService;
  10. use Modules\Operation\Models\NavPages;
  11. class ChannelServic extends BaseService
  12. {
  13. public static function ChannelList($param)
  14. {
  15. $sql = self::getQuerySql($param);
  16. $isAll = getProp($param,'is_all',false);
  17. if ($isAll){
  18. $list = $sql->get();
  19. }else{
  20. $list = $sql->paginate(getProp($param,'limit',15));
  21. }
  22. if (!$list->isEmpty()){
  23. $type = array_column(self::getNavPagesType(),null,'value');
  24. $minParamType = array_column(self::getMiniProgramType(),null,'value');
  25. foreach ($list as $value){
  26. $value->type_txt = $type[$value->type]['name'] ?? "-";
  27. $value->miniprogram_type_text = $minParamType[$value->miniprogram_type]['name'] ?? "-";
  28. $value->duanjus = collect($value->duanjus)->sortBy('sort');
  29. }
  30. }
  31. return $list;
  32. }
  33. public static function getQuerySql($param)
  34. {
  35. $sql = NavPages::query()->orderBy('status','desc')->orderBy('id','desc');
  36. if (getProp($param,'type')){
  37. $sql->where('type',$param['type']);
  38. }
  39. if (getProp($param,'miniprogram_type')){
  40. $sql->where("miniprogram_type",$param['miniprogram_type']);
  41. }
  42. return $sql;
  43. }
  44. /**
  45. * 添加
  46. * name: addChannel
  47. * @param mixed $param
  48. * @return string|void
  49. * date 2023/06/08 15:11
  50. */
  51. public static function addChannel(mixed $param)
  52. {
  53. $res = NavPages::create($param);
  54. if ($res){
  55. if ($param['status'] == 1){
  56. NavPages::where('id','<>',$res->id)->where('type',$param['type'])->where('miniprogram_type',$param['miniprogram_type'])->update(['status' => 0]);
  57. }
  58. return "操作成功";
  59. }
  60. self::throwErrMsg("添加失败");
  61. }
  62. public static function enableChannel($id)
  63. {
  64. $info = NavPages::where('id',$id)->first();
  65. if(is_empty($info)){
  66. self::throwErrMsg("频道配置不存在");
  67. }
  68. NavPages::where('type',$info->type)->where('miniprogram_type',$info->miniprogram_type)->update(['status'=>0]);
  69. NavPages::where('id',$id)->update(['status'=>1]);
  70. return "操作成功";
  71. }
  72. public static function setChannel($id, array $set)
  73. {
  74. $info = NavPages::where('id',$id)->first();
  75. if(is_empty($info)){
  76. self::throwErrMsg("频道配置不存在");
  77. }
  78. $res = NavPages::where('id',$id)->update(['duanjus' => $set]);
  79. if ($res){
  80. return "操作成功";
  81. }
  82. self::throwErrMsg("操作失败");
  83. }
  84. }