PropertyTrackService.php
2.26 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<?php
namespace App\Services;
use App\Helper\CosHelper;
use App\Helper\Response;
use App\Models\Legal\Contract;
use App\Models\Legal\PropertyTrack;
use App\Models\Legal\StakeholderContract;
use App\Models\Legal\Treaty;
use App\Models\Musician\AppCompanyUser;
use Illuminate\Database\Eloquent\Builder;
use Qcloud\Cos\Client;
/**
 * Class PropertyTrackService
 * @package App\Services
 */
class PropertyTrackService extends Service
{
    /**
     * 歌曲文件列表
     * @return \Illuminate\Http\JsonResponse
     */
    public function list()
    {
        $res = PropertyTrack::query()->where(['create_admin'=>$this->identifier->company_id, 'from'=>1])
                    ->when(filled($this->request->input('upload_time')), function (Builder $builder){
                        list($start, $end) = explode('-', $this->request->input('upload_time'));
                        $builder->whereBetween('upload_time', [trim($start), trim($end)]);
                    })
                    ->when(filled($this->request->input('song_name')), function (Builder $builder){
                        $builder->where('like', 'like', "%{$this->request->input('song_name')}%");
                    })->orderByDesc('id')->paginate($this->pageSize);
        return Response::success($res);
    }
    /**
     * 歌曲文件详情
     * @return \Illuminate\Http\JsonResponse
     */
    public function show()
    {
        $data = [];
        if ($track = PropertyTrack::query()->where(['id'=>$this->request->input('track_id'), 'from'=>1])->first()) {
            $user  = AppCompanyUser::query()->where(['id'=>$track->create_admin])->first();
            $track->setAttribute('submit_name', $user ? $user->name : '');
            return Response::success();
        }
        return Response::success($data);
    }
    /**
     * 待上传数据
     * @return \Illuminate\Http\JsonResponse
     */
    public function pending()
    {
        $count = PropertyTrack::query()->where(['create_admin'=>$this->identifier->company_id])->whereNull('upload_time')->count();
        return Response::success(['count'=>$count]);
    }
    /**
     * 歌曲上传文件列表 (不登录)
     * @return \Illuminate\Http\JsonResponse
     */
    public function file()
    {
        return Response::success();
    }
}