Immerse.php
2.17 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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<?php
namespace App\Models;
use Dcat\Admin\Traits\HasDateTimeFormatter;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Str;
class Immerse extends Model
{
use HasDateTimeFormatter;
protected $table = 'immerse';
protected $guarded = [''];
protected $casts = [
'user_id' => 'integer',
'type' => 'integer',
'poem_id' => 'integer',
'temp_id' => 'integer',
];
public function send($user_id, $type, $audio = '', $video = '')
{
}
public function getUrlAttribute($url)
{
if ($url == '') return $url;
return Storage::disk('public')->url($url);
}
public function getThumbnailAttribute($url)
{
if (Str::contains($url, '//') || $url == '') return $url;
if (Str::contains($url, '/storage/app/public/')) {
$str = Str::of($url)->replace('/usr/local/nginx/html/OnePoem/storage/app/public/', '');
return Storage::disk('public')->url($str);
}
return Storage::disk('public')->url($url);
}
public function getHuangliAttribute($huangli)
{
if ($huangli == null) return '';
return $huangli;
}
public function poem()
{
return $this->hasOne(OnePoem::class,'id','poem_id');
}
public function poem2()
{
return $this->hasOne(OnePoem2::class,'id','poem_id');
}
public function temp()
{
return $this->hasOne(VideoTemp::class,'id','temp_id');
}
public function getContentPosition($field = 'one_poem')
{
$component = $this->temp()->first()->components()->where('name','=',$field)->first();
return VideoTemp::POSITION_FFMPEG[$component->position];
}
public function isPraise($immerse_id, $user_id)
{
return Praise::query()->where('immerse_id', $immerse_id)
->where('user_id', $user_id)
->where('state', 1)
->exists();
}
public function isCollect($immerse_id, $user_id)
{
return Collect::query()->where('immerse_id', $immerse_id)
->where('user_id', $user_id)
->where('state', 1)
->exists();
}
}