CategoryGroup.php
2.2 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
<?php
namespace app\api\model;
use think\Model;
class CategoryGroup extends Model
{
// 表名
protected $name = 'category_group';
// 自动写入时间戳字段
protected $autoWriteTimestamp = 'int';
// 定义时间戳字段名
protected $createTime = 'createtime';
protected $updateTime = 'updatetime';
protected $deleteTime = false;
// 追加属性
protected $append = [
];
protected static function init()
{
self::afterInsert(function ($row) {
$pk = $row->getPk();
$row->getQuery()->where($pk, $row[$pk])->update(['weigh' => $row[$pk]]);
});
}
public function getStatusList()
{
return ['1' => __('Status 1'), '2' => __('Status 2')];
}
public function getSitelistList()
{
return ['1' => __('Sitelist 1'), '2' => __('Sitelist 2'), '3' => __('Sitelist 3')];
}
public function getStatusTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
$list = $this->getStatusList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getSitelistTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['sitelist']) ? $data['sitelist'] : '');
$valueArr = explode(',', $value);
$list = $this->getSitelistList();
return implode(',', array_intersect_key($list, array_flip($valueArr)));
}
protected function setSitelistAttr($value)
{
return is_array($value) ? implode(',', $value) : $value;
}
public function getImageAttr($value)
{
if($value) $value = cdnurl($value);
return $value;
}
public function getIndexImageAttr($value)
{
if($value) $value = cdnurl($value);
return $value;
}
public function selectData($where, $limit,$lang)
{
$where['status'] = ['eq', '1'];
if ($lang == 'ch') $field = 'id,ch_name name,ch_index_name index_name,index_image,image';
else $field = 'id,en_name name,en_index_name index_name,index_image,image';
$data = $this->where($where)->field($field)->order('weigh desc')->limit($limit)->select();
return $data;
}
}