ProjectTask.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <?php
  2. /**
  3. +-----------------------------------------------------------------------------------------------
  4. * GouGuOPEN [ 左手研发,右手开源,未来可期!]
  5. +-----------------------------------------------------------------------------------------------
  6. * @Copyright (c) 2021~2024 http://www.gouguoa.com All rights reserved.
  7. +-----------------------------------------------------------------------------------------------
  8. * @Licensed 勾股OA,开源且可免费使用,但并不是自由软件,未经授权许可不能去除勾股OA的相关版权信息
  9. +-----------------------------------------------------------------------------------------------
  10. * @Author 勾股工作室 <hdm58@qq.com>
  11. +-----------------------------------------------------------------------------------------------
  12. */
  13. namespace app\project\model;
  14. use think\facade\Db;
  15. use think\Model;
  16. class ProjectTask extends Model
  17. {
  18. //列表
  19. function datalist($param=[],$where=[],$whereOr=[]) {
  20. $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit'];
  21. $order = empty($param['order']) ? 'status asc,id desc' : $param['order'];
  22. try {
  23. $list = self::where($where)
  24. ->where(function ($query) use ($whereOr) {
  25. if (!empty($whereOr))
  26. $query->whereOr($whereOr);
  27. })
  28. ->withoutField('content')
  29. ->order($order)
  30. ->paginate(['list_rows'=> $rows])
  31. ->each(function ($item, $key){
  32. $item['director_name'] = '-';
  33. if ($item['director_uid'] > 0) {
  34. $item['director_name'] = Db::name('Admin')->where(['id' => $item['director_uid']])->value('name');
  35. }
  36. $assist_admin_names = Db::name('Admin')->where([['id', 'in', $item['assist_admin_ids']]])->column('name');
  37. if (empty($assist_admin_names)) {
  38. $item['assist_admin_names'] = '-';
  39. } else {
  40. $item['assist_admin_names'] = implode(',', $assist_admin_names);
  41. }
  42. $item['cate_name'] = Db::name('WorkCate')->where(['id' => $item['work_id']])->value('title');
  43. if ($item['project_id'] == 0) {
  44. $item['project_name'] = '-';
  45. } else {
  46. $item['project_name'] = Db::name('Project')->where(['id' => $item['project_id']])->value('name');
  47. }
  48. $item['delay'] = 0;
  49. if ($item['end_time'] > 0) {
  50. $item['end_time'] = date('Y-m-d', $item['end_time']);
  51. if ($item['over_time'] > 0 && $item['status'] < 4) {
  52. $item['delay'] = count_days($item['end_time'], date('Y-m-d', $item['over_time']));
  53. }
  54. if ($item['over_time'] == 0 && $item['status'] < 4) {
  55. $item['delay'] = count_days($item['end_time']);
  56. }
  57. }
  58. else{
  59. $item['delay'] = 9999;
  60. $item['end_time'] = '-';
  61. }
  62. $item['priority_name'] = priority_name($item['priority']);
  63. $item['status_name'] = status_task_name($item['status']);
  64. return $item;
  65. });
  66. return $list;
  67. } catch(\Exception $e) {
  68. return ['code' => 1, 'data' => [], 'msg' => $e->getMessage()];
  69. }
  70. }
  71. //详情
  72. public function detail($id)
  73. {
  74. $detail = Db::name('ProjectTask')->where(['id' => $id])->find();
  75. if (!empty($detail)) {
  76. $detail['project_name'] = '';
  77. if ($detail['project_id'] > 0) {
  78. $detail['project_name'] = Db::name('Project')->where(['id' => $detail['project_id']])->value('name');
  79. }
  80. $detail['admin_name'] = Db::name('Admin')->where(['id' => $detail['admin_id']])->value('name');
  81. $detail['work_hours'] = Db::name('Schedule')->where(['delete_time' => 0, 'tid' => $detail['id']])->sum('labor_time');
  82. $detail['cate_name'] = Db::name('WorkCate')->where(['id' => $detail['work_id']])->value('title');
  83. $detail['director_name']= '';
  84. if($detail['director_uid'] > 0){
  85. $detail['director_name'] = Db::name('Admin')->where(['id' => $detail['director_uid']])->value('name');
  86. }
  87. $detail['schedules'] = Db::name('Schedule')->where(['tid' => $detail['id'], 'delete_time' => 0])->count();
  88. $detail['logs'] = Db::name('EditLog')->where(['name' => 'Task', 'action_id' => $detail['id']])->count();
  89. $detail['comments'] = Db::name('Comment')->where(['module' => 'task', 'delete_time' => 0, 'topic_id' => $detail['id']])->count();
  90. $detail['assist_admin_names'] = '';
  91. if (!empty($detail['assist_admin_ids'])) {
  92. $assist_admin_names = Db::name('Admin')->where('id', 'in', $detail['assist_admin_ids'])->column('name');
  93. $detail['assist_admin_names'] = implode(',', $assist_admin_names);
  94. }
  95. $detail['priority_name'] = priority_name($detail['priority']);
  96. $detail['status_name'] = status_task_name($detail['status']);
  97. $detail['times'] = time_trans($detail['create_time']);
  98. $detail['delay'] = 0;
  99. if($detail['end_time']>0){
  100. $detail['end_time'] = date('Y-m-d', $detail['end_time']);
  101. if ($detail['over_time'] > 0 && $detail['status'] < 4) {
  102. $detail['delay'] = count_days($detail['end_time'], date('Y-m-d', $detail['over_time']));
  103. }
  104. if ($detail['over_time'] == 0 && $detail['status'] < 4) {
  105. $detail['delay'] = count_days($detail['end_time']);
  106. }
  107. }
  108. else{
  109. $detail['end_time'] = '';
  110. }
  111. }
  112. return $detail;
  113. }
  114. }