Category.php
2.1 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
<?php
namespace app\admin\model\workorder;
use think\Db;
use think\Model;
use app\admin\model\workorder\Orders;
use traits\model\SoftDelete;
class Category extends Model
{
use SoftDelete;
// 表名
protected $name = 'workorder_category';
// 自动写入时间戳字段
protected $autoWriteTimestamp = 'int';
// 定义时间戳字段名
protected $createTime = 'createtime';
protected $updateTime = false;
protected $deleteTime = 'deletetime';
// 追加属性
protected $append = [
'status_text',
'wo_number'
];
protected static function init()
{
self::afterInsert(function ($row) {
$pk = $row->getPk();
$row->getQuery()->where($pk, $row[$pk])->update(['weigh' => $row[$pk]]);
});
}
public function getWoNumberAttr($value, $data)
{
$woNumber = [
'number' => 0,
'complete_number' => 0
];
if ($data['pid'] == 0) {
$category_ids = Db::name('workorder_category')->where('pid', $data['id'])->column('id');
foreach ($category_ids as $index => $category_id) {
$woNumber['number'] += Orders::where('category_id', $category_id)->count('id');
$woNumber['complete_number'] += Orders::where('category_id', $category_id)
->where('status', '>=', 4)
->count('id');
}
} else {
$woNumber['number'] = Orders::where('category_id', $data['id'])->count('id');
$woNumber['complete_number'] += Orders::where('category_id', $data['id'])
->where('status', '>=', 4)
->count('id');
}
return $woNumber;
}
public function getStatusList()
{
return ['0' => __('Status 0'), '1' => __('Status 1')];
}
public function getStatusTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
$list = $this->getStatusList();
return isset($list[$value]) ? $list[$value] : '';
}
}