ChannelServic.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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()->where('is_del','=',0)->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. // 启用
  63. public static function enableChannel($id)
  64. {
  65. $info = NavPages::where('id',$id)->first();
  66. if(is_empty($info)){
  67. self::throwErrMsg("频道配置不存在");
  68. }
  69. NavPages::where('type',$info->type)->where('miniprogram_type',$info->miniprogram_type)->update(['status'=>0]);
  70. NavPages::where('id',$id)->update(['status'=>1]);
  71. return "操作成功";
  72. }
  73. // 保存配置
  74. public static function setChannel($id, array $set)
  75. {
  76. $info = NavPages::where('id',$id)->first();
  77. if(is_empty($info)){
  78. self::throwErrMsg("频道配置不存在");
  79. }
  80. $res = NavPages::where('id',$id)->update(['duanjus' => $set]);
  81. if ($res){
  82. return "操作成功";
  83. }
  84. self::throwErrMsg("操作失败");
  85. }
  86. // 删除
  87. public static function delChannel($id)
  88. {
  89. $info = NavPages::where('id',$id)->where('is_del',0)->first();
  90. if(is_empty($info)){
  91. self::throwErrMsg("频道配置不存在");
  92. }
  93. if ($info->status == 1){
  94. self::throwErrMsg("请先禁用");
  95. }
  96. $res = NavPages::where('id',$id)->update(['is_del' =>1,'del_at' => get_date(),'status' => 0]);
  97. if ($res){
  98. return "操作成功";
  99. }
  100. self::throwErrMsg("操作失败");
  101. }
  102. }