Contract.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2021 勾股工作室
  4. * @license https://opensource.org/licenses/GPL-3.0
  5. * @link https://www.gougucms.com
  6. */
  7. namespace app\contract\model;
  8. use think\facade\Db;
  9. use think\Model;
  10. class Contract extends Model
  11. {
  12. const ZERO = 0;
  13. const ONE = 1;
  14. const TWO = 2;
  15. const THREE = 3;
  16. const FORE = 4;
  17. const FIVE = 5;
  18. const SIX = 6;
  19. public static $Type = [
  20. self::ZERO => '未设置',
  21. self::ONE => '普通合同',
  22. self::TWO => '框架合同',
  23. self::THREE => '补充协议',
  24. self::FORE => '其他合同',
  25. ];
  26. public static $Status = [
  27. self::ZERO => '待审核',
  28. self::ONE => '审核中',
  29. self::TWO => '审核通过',
  30. self::THREE => '审核拒绝',
  31. self::FORE => '已撤销',
  32. self::FIVE => '已中止',
  33. self::SIX => '已作废',
  34. ];
  35. public static $ArchiveStatus = [
  36. self::ZERO => '未归档',
  37. self::ONE => '已归档',
  38. ];
  39. //列表检索
  40. public function get_list($param = [], $where = [], $whereOr=[])
  41. {
  42. $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit'];
  43. $list = self::where($where)
  44. ->where(function ($query) use($whereOr) {
  45. $query->whereOr($whereOr);
  46. })
  47. ->field('a.*, a.type as type_a, c.title as cate_title, d.title as sign_department')
  48. ->alias('a')
  49. ->join('contract_cate c', 'a.cate_id = c.id')
  50. ->join('department d', 'a.sign_did = d.id','LEFT')
  51. ->order('a.create_time desc')
  52. ->paginate($rows, false, ['query' => $param])
  53. ->each(function ($item, $key) {
  54. $item->keeper_name = Db::name('Admin')->where(['id' => $item->keeper_uid])->value('nickname');
  55. $item->sign_name = Db::name('Admin')->where(['id' => $item->sign_uid])->value('nickname');
  56. $item->sign_time = date('Y-m-d', $item->sign_time);
  57. $item->interval_time = date('Y-m-d', $item->start_time) . ' 至 ' . date('Y-m-d', $item->end_time);
  58. $item->type_name = self::$Type[(int)$item->type_a];
  59. $item->status_name = self::$Status[(int)$item->check_status];
  60. $item->delay = countDays(date("Y-m-d"),date('Y-m-d', $item->end_time));
  61. if($item->cost == 0){
  62. $item->cost = '-';
  63. }
  64. });
  65. return $list;
  66. }
  67. // 获取合同详情
  68. public function detail($id)
  69. {
  70. $detail = self::where(['id' => $id])->find();
  71. if (!empty($detail)) {
  72. $detail['status_name'] = self::$Status[(int) $detail['check_status']];
  73. $detail['archive_status_name'] = self::$ArchiveStatus[(int) $detail['archive_status']];
  74. $detail['sign_time'] = date('Y-m-d', $detail['sign_time']);
  75. $detail['start_time'] = date('Y-m-d', $detail['start_time']);
  76. $detail['end_time'] = date('Y-m-d', $detail['end_time']);
  77. $detail['cate_title'] = Db::name('ContractCate')->where(['id' => $detail['cate_id']])->value('title');
  78. $detail['sign_department'] = Db::name('Department')->where(['id' => $detail['sign_did']])->value('title');
  79. $detail['sign_name'] = Db::name('Admin')->where(['id' => $detail['sign_uid']])->value('nickname');
  80. $detail['admin_name'] = Db::name('Admin')->where(['id' => $detail['admin_id']])->value('nickname');
  81. $detail['prepared_name'] = Db::name('Admin')->where(['id' => $detail['prepared_uid']])->value('nickname');
  82. $detail['keeper_name'] = Db::name('Admin')->where(['id' => $detail['keeper_uid']])->value('nickname');
  83. $share_names = Db::name('Admin')->where([['id','in',$detail['share_ids']]])->column('nickname');
  84. $detail['share_names'] = implode(',',$share_names);
  85. //审核信息
  86. if($detail['check_uid'] > 0){
  87. $detail['check_name'] = Db::name('Admin')->where(['id' => $detail['check_uid']])->value('nickname');
  88. $detail['check_time'] = date('Y-m-d', $detail['check_time']);
  89. }
  90. //中止信息
  91. if($detail['stop_uid'] > 0){
  92. $detail['stop_name'] = Db::name('Admin')->where(['id' => $detail['stop_uid']])->value('nickname');
  93. $detail['stop_time'] = date('Y-m-d', $detail['stop_time']);
  94. }
  95. //作废信息
  96. if($detail['void_uid'] > 0){
  97. $detail['void_name'] = Db::name('Admin')->where(['id' => $detail['void_uid']])->value('nickname');
  98. $detail['voidtime'] = date('Y-m-d', $detail['void_time']);
  99. }
  100. //归档信息
  101. if($detail['archive_status'] == 1){
  102. $detail['archive_name'] = Db::name('Admin')->where(['id' => $detail['archive_uid']])->value('nickname');
  103. $detail['archive_time'] = date('Y-m-d', $detail['archive_time']);
  104. }
  105. if($detail['pid']>0){
  106. $detail['pname'] = self::where(['id' => $detail['pid']])->value('name');
  107. }
  108. if($detail['file_ids'] !=''){
  109. $fileArray = Db::name('File')->where('id','in',$detail['file_ids'])->select();
  110. $detail['fileArray'] = $fileArray;
  111. }
  112. }
  113. return $detail;
  114. }
  115. }