Event.php 45KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Description: 日程
  4. // +----------------------------------------------------------------------
  5. // | Author: Michael_xu | gengxiaoxu@5kcrm.com
  6. // +----------------------------------------------------------------------
  7. namespace app\oa\model;
  8. use think\Db;
  9. use app\admin\model\Common;
  10. use app\admin\model\Message;
  11. use think\Request;
  12. use think\Validate;
  13. use think\helper\Time;
  14. class Event extends Common
  15. {
  16. /**
  17. * 为了数据库的整洁,同时又不影响Model和Controller的名称
  18. * 我们约定每个模块的数据表都加上相同的前缀,比如CRM模块用crm作为数据表前缀
  19. */
  20. protected $name = 'oa_event';
  21. protected $createTime = 'create_time';
  22. protected $updateTime = 'update_time';
  23. protected $autoWriteTimestamp = true;
  24. //类型转换
  25. protected $dateFormat = 'Y-m-d H:i:s';
  26. protected $type = [
  27. 'start_time' => 'timestamp',
  28. 'end_time' => 'timestamp',
  29. ];
  30. /**
  31. * [getDataList 日程list]
  32. * @param [by] $by [查询时间段类型]
  33. * @return [array] [description]
  34. * @author Michael_xu
  35. */
  36. public function getDataList($param)
  37. {
  38. $userModel = new \app\admin\model\User();
  39. $recordModel = new \app\admin\model\Record();
  40. $user_id = $param['user_id'];
  41. //默认本账户or 自定义用户id
  42. if ($param['start_time'] && $param['end_time']) {
  43. $start_time = $param['start_time'];
  44. $end_time = $param['end_time'];
  45. } else {
  46. $start_time = mktime(0, 0, 0, date('m'), 1, date('Y'));
  47. $end_time = mktime(23, 59, 59, date('m'), date('t'), date('Y'));
  48. }
  49. $where = '( ( start_time BETWEEN ' . $start_time . ' AND ' . $end_time . ' ) AND ( create_user_id = ' . $user_id . ' or owner_user_ids like "%,' . $user_id . ',%" ) )
  50. OR ( ( end_time BETWEEN ' . $start_time . ' AND ' . $end_time . ' ) AND ( create_user_id = ' . $user_id . ' or owner_user_ids like "%,' . $user_id . ',%" ) )
  51. OR ( start_time < ' . $start_time . ' AND end_time > ' . $end_time . ' AND ( create_user_id = ' . $user_id . ' or owner_user_ids like "%,' . $user_id . ',%" ) )';
  52. $event_date = Db::name('OaEvent')->where($where)->select();
  53. foreach ($event_date as $k=>$v) {
  54. $event_date[$k]['create_user_info'] = $userModel->getUserById($v['create_user_id']);
  55. $event_date[$k]['ownerList'] = $userModel->getDataByStr($v['owner_user_ids']) ? : [];
  56. $relationArr= [];
  57. $relationArr = $recordModel->getListByRelationId('event', $v['event_id']);
  58. $event_date[$k]['businessList'] = $relationArr['businessList'];
  59. $event_date[$k]['contactsList'] = $relationArr['contactsList'];
  60. $event_date[$k]['contractList'] = $relationArr['contractList'];
  61. $event_date[$k]['customerList'] = $relationArr['customerList'];
  62. $event_date[$k]['remindtype'] = (int)$v['remindtype'];
  63. $noticeInfo = Db::name('OaEventNotice')->where(['event_id' => $v['event_id']])->find();
  64. $is_repeat = 0;
  65. if ($noticeInfo) {
  66. $is_repeat = 1;
  67. }
  68. $event_date[$k]['is_repeat'] = $is_repeat;
  69. $event_date[$k]['stop_time'] = $noticeInfo ? $noticeInfo['stop_time'] : '';
  70. $event_date[$k]['noticetype'] = $noticeInfo ? $noticeInfo['noticetype'] : '';
  71. if ($noticeInfo['noticetype'] == '2') {
  72. $event_date[$k]['repeat'] = $noticeInfo['repeated'] ? explode('|||',$noticeInfo['repeated']) : [];
  73. } else {
  74. $event_date[$k]['repeat'] = '';
  75. }
  76. //权限
  77. $is_update = 0;
  78. $is_delete = 0;
  79. if ($user_id == $v['create_user_id']) {
  80. $is_update = 1;
  81. $is_delete = 1;
  82. }
  83. $permission['is_update'] = $is_update;
  84. $permission['is_delete'] = $is_delete;
  85. $event_date[$k]['permission'] = $permission;
  86. $event_date[$k]['start_time'] = !empty($v['start_time']) ? $v['start_time'] * 1000 : null;
  87. $event_date[$k]['end_time'] = !empty($v['end_time']) ? $v['end_time'] * 1000 : null;
  88. $event_date[$k]['type_id'] = $v['schedule_id'];
  89. }
  90. return $event_date ? : [];
  91. }
  92. /**
  93. * 系统自定义类型数据(任务)
  94. *
  95. * @param $param
  96. * @return bool|\PDOStatement|string|\think\Collection
  97. * @throws \think\db\exception\DataNotFoundException
  98. * @throws \think\db\exception\ModelNotFoundException
  99. * @throws \think\exception\DbException
  100. */
  101. public function eventTask($param)
  102. {
  103. $user_id = $param['user_id'];
  104. // 默认本账户or 自定义用户id
  105. if ($param['start_time'] && $param['end_time']) {
  106. $start_time = $param['start_time'];
  107. $end_time = $param['end_time'];
  108. } else {
  109. $start_time = mktime(0, 0, 0, date('m'), 1, date('Y'));
  110. $end_time = mktime(23, 59, 59, date('m'), date('t'), date('Y'));
  111. }
  112. $between_time =
  113. '((stop_time BETWEEN ' . $start_time . ' AND ' . $end_time . ' ) AND ( create_user_id = ' . $user_id . ' or owner_user_id like "%,' . $user_id . ',%"))
  114. OR ((stop_time > ' . $start_time . ' AND stop_time <' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id like "%,' . $user_id . ',%"))
  115. OR ((stop_time > ' . $start_time . ' AND stop_time >' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id like "%,' . $user_id . ',%"))';
  116. //分配的任务 负责人或参与人是当前用户
  117. $event_date = db('task')->where(['stop_time' => ['>', 0], 'ishidden' => ['=', 0]])->where($between_time)
  118. ->field('task_id,name,start_time,stop_time')->select();
  119. foreach ($event_date as $k1 => $v) {
  120. $event_date[$k1]['color'] = 1;
  121. $event_date[$k1]['type_id'] = 1;
  122. $event_date[$k1]['type'] = 2;
  123. $event_date[$k1]['start_time'] = !empty($v['start_time']) ? $v['start_time'] * 1000 : null;
  124. $event_date[$k1]['stop_time'] = !empty($v['stop_time']) ? $v['stop_time'] * 1000 : null;
  125. }
  126. return $event_date;
  127. }
  128. /**
  129. * 系统自定义类型数据(客户)
  130. *
  131. * @param $param
  132. * @return array|mixed
  133. * @throws \think\db\exception\DataNotFoundException
  134. * @throws \think\db\exception\ModelNotFoundException
  135. * @throws \think\exception\DbException
  136. */
  137. public function eventCrm($param)
  138. {
  139. $userModel = new \app\admin\model\User();
  140. $recordModel = new \app\admin\model\Record();
  141. $user_id = $param['user_id'];
  142. //默认本账户or 自定义用户id
  143. if ($param['start_time'] && $param['end_time']) {
  144. $start_time = $param['start_time'];
  145. $end_time = $param['end_time'];
  146. if (strlen($start_time) == 13) $start_time = $start_time / 1000;
  147. if (strlen($end_time) == 13) $end_time = $end_time / 1000;
  148. } else {
  149. $start_time = mktime(0, 0, 0, date('m'), 1, date('Y'));
  150. $end_time = mktime(23, 59, 59, date('m'), date('t'), date('Y'));
  151. }
  152. $between_time = '';
  153. //需要联系的客户 next_time crm_customer
  154. $between_time = '((next_time BETWEEN ' . $start_time . ' AND ' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . '))
  155. OR ((next_time > ' . $start_time . ' AND next_time <' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id =' . $user_id . '))
  156. OR ((next_time > ' . $start_time . ' AND next_time > ' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . '))';
  157. $event_date = db('crm_customer')->where(['next_time' => ['>', 0], 'owner_user_id' => ['<>', 0]])->where($between_time)->where('')
  158. ->field('next_time as start_time,customer_id,name ')->group('start_time')->select();
  159. $item = [];
  160. foreach ($event_date as $k2 => $v) {
  161. $event_date[$k2]['color'] = 2;
  162. $event_date[$k2]['type_id'] = 2;
  163. $event_date[$k2]['type'] = 'customer';
  164. $event_date[$k2]['start_time'] = !empty($v['start_time']) ? $v['start_time'] * 1000 : null;
  165. $event_date[$k2]['stop_time'] = !empty($v['start_time']) ? $v['start_time'] * 1000 : null;
  166. $event_date[$k2]['stop_time'] = !empty($v['start_time']) ? $v['start_time'] * 1000 : null;
  167. $item[] = $v['start_time'] ? date('Y-m-d', $v['start_time']) : '';
  168. }
  169. $list_data['customer'] = $item ? array_values(array_unique($item)) : [];
  170. //即将到期的合同 end_time
  171. $starts_time = date('Y-m-d', $start_time);
  172. $ends_time = date('Y-m-d', $end_time);
  173. $searchMap = function ($query) use ($starts_time, $ends_time) {
  174. $query->where('end_time', array('between', [$starts_time, $ends_time]))
  175. ->whereOr('end_time', array('gt', $ends_time));
  176. };
  177. //需要联系的客户 next_time crm_customer
  178. $between['create_user_id|owner_user_id'] = ['eq', $user_id];
  179. $event_date = db('crm_contract')->where('end_time', '>', 0)->where($searchMap)->where($between)
  180. ->field('end_time as start_time,contract_id,name ')
  181. ->group('start_time')
  182. ->select();
  183. unset($item);
  184. foreach ($event_date as $k3 => $v) {
  185. $event_date[$k3]['color'] = 3;
  186. $event_date[$k3]['type_id'] = 3;
  187. $event_date[$k3]['type'] = 'contract';
  188. $event_date[$k3]['start_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  189. $event_date[$k3]['stop_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  190. $item[] = $v['start_time'] ? $v['start_time'] : '';
  191. }
  192. $list_data['contract'] = $item ? array_values(array_unique($item)) : [];
  193. //计划回款 return_date
  194. $between_receivables = function ($query) use ($starts_time, $ends_time) {
  195. $query->where('r.return_date', array('between', [$starts_time, $ends_time]))
  196. ->whereOr('r.return_date', array('gt', $ends_time));
  197. };
  198. $receivables['r.create_user_id|r.owner_user_id'] = ['eq', $user_id];
  199. $event_date = db('crm_receivables_plan')
  200. ->alias('r')
  201. ->where(['r.status' => 0, 'r.return_date' => ['>', 0]])
  202. ->where($between_receivables)
  203. ->where($receivables)
  204. ->field('r.return_date as start_time')
  205. ->group('start_time')
  206. ->select();
  207. unset($item);
  208. foreach ($event_date as $k4 => $v) {
  209. $event_date[$k4]['color'] = 4;
  210. $event_date[$k4]['type_id'] = 4;
  211. $event_date[$k4]['type'] = 'receivables_plan';
  212. $event_date[$k4]['start_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  213. $event_date[$k4]['stop_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  214. $item[] = $v['start_time'] ? $v['start_time'] : '';
  215. }
  216. $list_data['receivables'] = $item ? array_values(array_unique($item)) : [];
  217. //需联系的线索 next_time
  218. $between_time = '(( next_time BETWEEN ' . $start_time . ' AND ' . $end_time . ')AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . ' ))
  219. OR ((next_time > ' . $start_time . ' AND next_time <' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . ' ))
  220. OR ((next_time > ' . $start_time . ' AND next_time > ' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . ' ))';
  221. $event_date = db('crm_leads')
  222. ->where($between_time)
  223. ->where(['next_time' => ['>', 0], 'is_transform' => 0])
  224. ->field('next_time as start_time,leads_id,name')
  225. ->group('next_time')
  226. ->select();
  227. unset($item);
  228. foreach ($event_date as $k5 => $v) {
  229. $event_date[$k5]['color'] = 5;
  230. $event_date[$k5]['type_id'] = 5;
  231. $event_date[$k5]['type'] = 'leads';
  232. $event_date[$k5]['start_time'] = $v['start_time'] * 1000;
  233. $event_date[$k5]['stop_time'] = !empty($v['start_time']) ? $v['start_time'] * 1000 : null;
  234. $item[] = $v['start_time'] ? date('Y-m-d', $v['start_time']) : '';
  235. }
  236. $list_data['leads'] = $item ? array_values(array_unique($item)) : [];
  237. //需联系的商机 next_time
  238. $between_time =
  239. '((next_time BETWEEN ' . $start_time . ' AND ' . $end_time . ' ) AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . ' ))
  240. OR ((next_time > ' . $start_time . ' AND next_time <' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . ' ))
  241. OR ((next_time > ' . $start_time . ' AND next_time >' . $end_time . ') AND ( create_user_id = ' . $user_id . ' or owner_user_id = ' . $user_id . ' ))';
  242. $event_date = db('crm_business')->where($between_time)->where('next_time', '>', 0)->field('next_time as start_time,business_id,name ')->select();
  243. unset($item);
  244. foreach ($event_date as $k6 => $v) {
  245. $event_date[$k6]['color'] = 6;
  246. $event_date[$k6]['type_id'] = 6;
  247. $event_date[$k6]['type'] = 'business';
  248. $event_date[$k6]['start_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  249. $event_date[$k6]['stop_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  250. $item[] = $v['start_time'] ? date('Y-m-d', $v['start_time']) : '';
  251. }
  252. $list_data['businessNext'] = $item ? array_values(array_unique($item)) : [];
  253. //需要联系的客户 next_time crm_customer
  254. $return_time = date('Y-m-d', $start_time);
  255. $return_end = date('Y-m-d', $end_time);
  256. $searchMap = function ($query) use ($return_time, $return_end) {
  257. $query->where('deal_date', array('between', [$return_time, $return_end]))
  258. ->whereOr('deal_date', array('gt', $return_end));
  259. };
  260. $between['create_user_id|owner_user_id'] = ['eq', $user_id];
  261. $event_date = db('crm_business')
  262. ->where('deal_date', '>', 0)
  263. ->where($between)
  264. ->where($searchMap)
  265. ->field('deal_date as start_time,business_id,name')
  266. ->group('start_time')
  267. ->select();
  268. unset($item);
  269. foreach ($event_date as $k7 => $v) {
  270. $event_date[$k7]['color'] = 7;
  271. $event_date[$k7]['type_id'] = 7;
  272. $event_date[$k7]['type'] = 'business';
  273. $event_date[$k7]['start_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  274. $event_date[$k7]['stop_time'] = !empty($v['start_time']) ? strtotime($v['start_time']) * 1000 : null;
  275. $item[] = $v['start_time'] ? $v['start_time'] : '';
  276. }
  277. $list_data['business'] = $item ? array_values(array_unique($item)) : [];
  278. return $list_data ?: [];
  279. }
  280. /**
  281. * 日历上显示
  282. * @return array
  283. * @throws \think\db\exception\DataNotFoundException
  284. * @throws \think\db\exception\ModelNotFoundException
  285. * @throws \think\exception\DbException
  286. */
  287. public function listStatus($param)
  288. {
  289. $userId = $param['user_id'];
  290. if ($param['start_time'] && $param['end_time']) {
  291. $start_time = $param['start_time'];
  292. $end_time = $param['end_time'];
  293. } else {
  294. $start_time = mktime(0, 0, 0, date('m'), 1, date('Y'));
  295. $end_time = mktime(23, 59, 59, date('m'), date('t'), date('Y'));
  296. }
  297. $list = Db::name('oa_event')->where(['end_time' => ['>', 0], 'start_time' => ['>', 0]])
  298. ->where(function ($query) use ($userId) {
  299. $query->whereOr('create_user_id', $userId);
  300. $query->whereOr(['owner_user_ids' => ['in', $userId]]);
  301. })->select();
  302. foreach ($list as $k => $v) {
  303. $list[$k]['start_time'] = $v['start_time'] ? date('Y-m-d', $v['start_time']) : null;
  304. $list[$k]['end_time'] = $v['end_time'] ? date('Y-m-d', $v['end_time']) : null;
  305. }
  306. return $list;
  307. }
  308. /**
  309. * 类型列表
  310. * @return array|void
  311. * @throws \think\db\exception\DataNotFoundException
  312. * @throws \think\db\exception\ModelNotFoundException
  313. * @throws \think\exception\DbException
  314. */
  315. public function schedule($param)
  316. {
  317. $item = db('admin_oa_schedule_relation')->where('user_id', $param['user_id'])->select();
  318. if ($item) {
  319. $list = db('admin_oa_schedule')->select();
  320. foreach ($list as $k => $v) {
  321. foreach ($item as $val) {
  322. if ($val['schedule_id'] == $v['schedule_id'] && $val['type'] == 0) {
  323. $list[$k]['is_select'] = 0;
  324. }
  325. if ($val['schedule_id'] == $v['schedule_id'] && $val['type'] == 1) {
  326. $list[$k]['is_select'] = 1;
  327. }
  328. }
  329. $list[$k]['type_id'] = $v['schedule_id'];
  330. $list[$k]['create_time'] = $v['create_time'] ? date('Y-m-d H:i:s', $v['create_time']) : null;
  331. }
  332. } else {
  333. $list = db('admin_oa_schedule')->select();
  334. }
  335. $data['list'] = $list;
  336. return $data;
  337. }
  338. /**
  339. * 修改展示类型
  340. * @param $param
  341. * @return array
  342. * @throws \think\db\exception\DataNotFoundException
  343. * @throws \think\db\exception\ModelNotFoundException
  344. * @throws \think\exception\DbException
  345. */
  346. public function saveSchedule($param)
  347. {
  348. $item = db('admin_oa_schedule_relation')->where('user_id', $param['user_id'])->select();
  349. $items = db('admin_oa_schedule')->select();
  350. $item_schedule_id = array_column($items, 'schedule_id');
  351. $schedule_id = array_diff($item_schedule_id, $param['schedule_id']);
  352. foreach ($param['schedule_id'] as $v) {
  353. if ($item) {
  354. $res = db('admin_oa_schedule_relation')->where(['user_id' => $param['user_id'], 'schedule_id' => $v])->find();
  355. if ($res) {
  356. if ($res['type'] == 1) {
  357. db('admin_oa_schedule_relation')->where(['user_id' => $param['user_id']])
  358. ->whereIn('schedule_id', implode(',', $schedule_id))
  359. ->update(['type' => 0]);
  360. } else {
  361. db('admin_oa_schedule_relation')->where(['user_id' => $param['user_id']])
  362. ->whereIn('schedule_id', arrayToString($param['schedule_id']))
  363. ->update(['type' => 1]);
  364. }
  365. } else {
  366. db('admin_oa_schedule_relation')->where('user_id', $param['user_id'])->insert(['schedule_id' => $v, 'user_id' => $param['user_id'], 'type' => 1, 'create_time' => time()]);
  367. }
  368. } else {
  369. db('admin_oa_schedule_relation')->where('user_id', $param['user_id'])->insert(['schedule_id' => $v, 'user_id' => $param['user_id'], 'type' => 1, 'create_time' => time()]);
  370. }
  371. }
  372. $data = [];
  373. return $data;
  374. }
  375. /**
  376. * 创建日程信息
  377. *
  378. * @param array $param
  379. * @return bool
  380. * @throws \think\db\exception\DataNotFoundException
  381. * @throws \think\db\exception\ModelNotFoundException
  382. * @throws \think\exception\DbException
  383. */
  384. public function createData($param)
  385. {
  386. $todayTime = Time::today();
  387. # 设置日程参数
  388. $param['create_user_id'] = $param['user_id'];
  389. $param['owner_user_ids'] = arrayToString($param['owner_user_ids']);
  390. $param['start_time'] = !empty($param['start_time']) ? strtotime($param['start_time']) : $todayTime[0];
  391. $param['end_time'] = !empty($param['end_time']) ? strtotime($param['end_time']) : $todayTime[1];
  392. $param['create_time'] = time();
  393. $param['update_time'] = time();
  394. unset($param['user_id']);
  395. # 关联数据
  396. $relation = [];
  397. if (!empty($param['customer_ids'])) $relation['customer_ids'] = arrayToString($param['customer_ids']);
  398. if (!empty($param['contacts_ids'])) $relation['contacts_ids'] = arrayToString($param['contacts_ids']);
  399. if (!empty($param['business_ids'])) $relation['business_ids'] = arrayToString($param['business_ids']);
  400. if (!empty($param['contract_ids'])) $relation['contract_ids'] = arrayToString($param['contract_ids']);
  401. # 提醒数据
  402. $notice = $param['notice'];
  403. # 删除多余字段
  404. unset($param['customer_ids']);
  405. unset($param['contacts_ids']);
  406. unset($param['business_ids']);
  407. unset($param['contract_ids']);
  408. unset($param['notice']);
  409. if ($this->allowField(true)->save($param)) {
  410. $eventId = $this->event_id;
  411. # 提醒
  412. if (!empty($notice)) {
  413. $noticeData = [];
  414. foreach ($notice as $key => $value) {
  415. $startTime = $param['start_time'];
  416. if ($value['type'] == 1) $startTime = $param['start_time'] - ($value['value'] * 60);
  417. if ($value['type'] == 2) $startTime = $param['start_time'] - ($value['value'] * 60 * 60);
  418. if ($value['type'] == 3) $startTime = $param['start_time'] - ($value['value'] * 60 * 60 * 24);
  419. $noticeData[] = [
  420. 'event_id' => $eventId,
  421. 'noticetype' => $value['type'],
  422. 'number' => $value['value'],
  423. 'start_time' => $startTime,
  424. 'stop_time' => $param['end_time']
  425. ];
  426. }
  427. if (!empty($noticeData)) Db::name('oa_event_notice')->insertAll($noticeData);
  428. }
  429. # 关联数据
  430. if (!empty($relation)) {
  431. $relation['event_id'] = $eventId;
  432. $relation['status'] = 1;
  433. $relation['create_time'] = time();
  434. Db::name('oa_event_relation')->insert($relation);
  435. }
  436. actionLog($eventId, $param['owner_user_ids'], '', '创建了日程');
  437. $data['event_id'] = $eventId;
  438. // 站内信
  439. $item = Db::name('oa_event_notice')->where('event_id', $eventId)->select();
  440. $messageModel = new Message();
  441. foreach ($item as $value) {
  442. if ($value['noticetype'] == '1') { //分
  443. $dd = $param['start_time'] - ($value['number'] * 60);
  444. } else if ($value['noticetype'] == '2') { //时
  445. $dd = $param['start_time'] - ($value['number'] * 60 * 60);
  446. } else if ($value['noticetype'] == '3') {//天
  447. $dd = $param['start_time'] - ($value['number'] * 60 * 60 * 24);
  448. }
  449. $messageModel->send(
  450. Message::EVENT_MESSAGE,
  451. [
  452. 'title' => $param['title'],
  453. 'action_id' => $value['id'],
  454. 'advance_time' => $dd ?: 0
  455. ],
  456. stringToArray($param['owner_user_ids'])
  457. );
  458. }
  459. return $data;
  460. } else {
  461. $this->error = '添加失败';
  462. return false;
  463. }
  464. }
  465. /**
  466. * 即将到期合同列表
  467. * @param $param
  468. * @throws \think\db\exception\DataNotFoundException
  469. * @throws \think\db\exception\ModelNotFoundException
  470. * @throws \think\exception\DbException
  471. */
  472. public function eventContract($param)
  473. {
  474. $user_id = $param['user_id'];
  475. $time = $this->eventDataTime($param);
  476. $return_time = `'` . date('Y-m-d', $time[0]) . `'`;
  477. if ($param['type'] == 1) {
  478. $between_time['contract.end_time'] = $return_time;
  479. $between_time['contract.create_user_id|contract.owner_user_id'] = ['eq', $user_id];
  480. $event_date = db('crm_contract')->alias('contract')
  481. ->join('__CRM_CUSTOMER__ customer', 'customer.customer_id = contract.customer_id', 'LEFT')
  482. ->join('__ADMIN_USER__ u', 'u.id = contract.owner_user_id', 'LEFT')
  483. ->where('contract.end_time', '>', 0)->where($between_time)
  484. ->field('contract.name as contract_name,contract.customer_id,contract.num,contract.contract_id,customer.name,contract.money,contract.start_time,contract.end_time,u.realname as owner_user_name')
  485. ->select();
  486. $count = db('crm_contract')->alias('contract')
  487. ->join('__ADMIN_USER__ user', 'user.id = contract.create_user_id', 'LEFT')
  488. ->join('__ADMIN_USER__ u', 'u.id = contract.owner_user_id', 'LEFT')
  489. ->where('contract.end_time', '>', 0)->where($between_time)->count();
  490. foreach ($event_date as $k => $v) {
  491. $event_date[$k]['start_time'] = $v['start_time'] ? $v['start_time'] : null;
  492. $event_date[$k]['end_time'] = $v['end_time'] ? $v['end_time'] : null;
  493. }
  494. } elseif ($param['type'] == 2) {
  495. $between_time['r.return_date'] = ['=', $return_time];
  496. $between_time['r.create_user_id|r.owner_user_id'] = ['eq', $user_id];
  497. $event_date = db('crm_receivables_plan')
  498. ->alias('r')
  499. ->join('__CRM_CUSTOMER__ customer', 'customer.customer_id = r.customer_id', 'LEFT')
  500. ->join('__CRM_CONTRACT__ contract', 'contract.contract_id = r.contract_id', 'LEFT')
  501. ->where(['r.status' => 0, 'r.return_date' => ['>', 0]])
  502. ->where($between_time)
  503. ->field('r.contract_id,r.customer_id,r.return_date,r.num as plan_num,r.return_type,customer.name as name,contract.num as contract_num')
  504. ->select();
  505. $count = db('crm_receivables_plan')
  506. ->alias('r')
  507. ->join('__CRM_CUSTOMER__ customer', 'customer.customer_id = r.customer_id', 'LEFT')
  508. ->join('__CRM_CONTRACT__ contract', 'contract.contract_id = r.contract_id', 'LEFT')
  509. ->where($between_time)
  510. ->where(['r.status' => 0, 'r.return_date' => ['>', 0]])->count();
  511. foreach ($event_date as $k => $v) {
  512. $event_date[$k]['return_date'] = $v['return_date'] ? $v['return_date'] : null;
  513. }
  514. }
  515. $data = [];
  516. $data['list'] = $event_date;
  517. $data['countData'] = $count;
  518. return $data;
  519. }
  520. /**
  521. * 续联系客户
  522. * @param $param
  523. * @throws \think\db\exception\DataNotFoundException
  524. * @throws \think\db\exception\ModelNotFoundException
  525. * @throws \think\exception\DbException
  526. */
  527. public function eventCustomer($param)
  528. {
  529. $user_id = $param['user_id'];
  530. $time = $this->eventDataTime($param);
  531. $return_time = `'` . strtotime(date('Y-m-d', $time[0])) . `'`;
  532. $return_end = `'` . strtotime(date('Y-m-d 23:59:59', $time[1])) . `'`;
  533. //需要联系的客户 next_time crm_customer
  534. $between_time['customer.next_time'] = ['between', [$return_time, $return_end]];
  535. $between_time['customer.create_user_id|customer.owner_user_id'] = ['eq', $user_id];
  536. $event_date = db('crm_customer')
  537. ->alias('customer')
  538. ->join('__ADMIN_USER__ user', 'user.id = customer.owner_user_id', 'LEFT')
  539. ->where('customer.next_time', '>', 0)->where($between_time)
  540. ->field('customer.customer_id,customer.next_time,customer.name,user.realname as owner_user_name,customer.create_time,customer.last_time')
  541. ->select();
  542. $count = db('crm_customer')
  543. ->alias('customer')
  544. ->join('__ADMIN_USER__ user', 'user.id = customer.owner_user_id', 'LEFT')
  545. ->where('customer.next_time', '>', 0)->where($between_time)->where($wherePool)->count();
  546. foreach ($event_date as $k => $v) {
  547. $event_date[$k]['next_time'] = $v['next_time'] ? date('Y-m-d H:i:s', $v['next_time']) : null;
  548. $event_date[$k]['create_time'] = $v['create_time'] ? date('Y-m-d H:i:s', $v['create_time']) : null;
  549. $event_date[$k]['last_time'] = $v['last_time'] ? date('Y-m-d H:i:s', $v['last_time']) : null;
  550. }
  551. $data = [];
  552. $data['list'] = $event_date;
  553. $data['countData'] = $count;
  554. return $data;
  555. }
  556. /**
  557. * 续联系客户
  558. * @param $param
  559. * @throws \think\db\exception\DataNotFoundException
  560. * @throws \think\db\exception\ModelNotFoundException
  561. * @throws \think\exception\DbException
  562. */
  563. public function eventLeads($param)
  564. {
  565. $user_id = $param['user_id'];
  566. $time = $this->eventDataTime($param);
  567. $return_time = `'` . strtotime(date('Y-m-d', $time[0])) . `'`;
  568. $return_end = `'` . strtotime(date('Y-m-d 23:59:59', $time[1])) . `'`;
  569. $between_time['leads.next_time'] = ['between', [$return_time, $return_end]];
  570. $between_time['leads.create_user_id|leads.owner_user_id'] = ['eq', $user_id];
  571. $event_date = db('crm_leads')
  572. ->alias('leads')
  573. ->join('__ADMIN_USER__ user', 'user.id = leads.owner_user_id', 'LEFT')
  574. ->where($between_time)
  575. ->where(['leads.next_time' => ['>', 0], 'leads.is_transform' => 0])
  576. ->field('leads.leads_id,leads.next_time,leads.leads_id,leads.name,user.realname as owner_user_name,leads.create_time,leads.last_time')
  577. ->select();
  578. $count = db('crm_leads')
  579. ->alias('leads')
  580. ->join('__ADMIN_USER__ user', 'user.id = leads.owner_user_id', 'LEFT')
  581. ->where($between_time)
  582. ->where(['leads.next_time' => ['>', 0], 'leads.is_transform' => 0])->count();
  583. foreach ($event_date as $k => $v) {
  584. $event_date[$k]['create_time'] = $v['create_time'] ? date('Y-m-d H:i:s', $v['create_time']) : null;
  585. $event_date[$k]['last_time'] = $v['last_time'] ? date('Y-m-d H:i:s', $v['last_time']) : null;
  586. }
  587. $data = [];
  588. $data['list'] = $event_date;
  589. $data['countData'] = $count;
  590. return $data;
  591. }
  592. /**
  593. * 计划回款
  594. * @param $param
  595. * @throws \think\db\exception\DataNotFoundException
  596. * @throws \think\db\exception\ModelNotFoundException
  597. * @throws \think\exception\DbException
  598. */
  599. public function eventBusiness($param)
  600. {
  601. $user_id = $param['user_id'];
  602. $time = $this->eventDataTime($param);
  603. $return_time = `'` . strtotime(date('Y-m-d', $time[0])) . `'`;
  604. $return_end = `'` . strtotime(date('Y-m-d 23:59:59', $time[1])) . `'`;
  605. //需要联系的客户 next_time crm_customer
  606. $between_time['business.next_time'] = ['between', [$return_time, $return_end]];
  607. $between_time['business.create_user_id|business.owner_user_id'] = ['eq', $user_id];
  608. $event_date = db('crm_business')
  609. ->alias('business')
  610. ->join('__ADMIN_USER__ user', 'user.id = business.owner_user_id', 'LEFT')
  611. ->where($between_time)
  612. ->where('business.next_time', '>', 0)
  613. ->field('business.business_id,business.next_time,business.business_id,business.name,business.last_time,business.create_time,user.realname as owner_user_name')
  614. ->select();
  615. $count = db('crm_business')
  616. ->alias('business')
  617. ->join('__ADMIN_USER__ user', 'user.id = business.owner_user_id', 'LEFT')
  618. ->where($between_time)
  619. ->where('business.next_time', '>', 0)->count();
  620. foreach ($event_date as $k => $v) {
  621. $event_date[$k]['next_time'] = $v['next_time'] ? date('Y-m-d H:i:s', $v['next_time']) : null;
  622. $event_date[$k]['create_time'] = $v['create_time'] ? date('Y-m-d H:i:s', $v['create_time']) : null;
  623. $event_date[$k]['last_time'] = $v['last_time'] ? date('Y-m-d H:i:s', $v['last_time']) : null;
  624. }
  625. $data = [];
  626. $data['list'] = $event_date;
  627. $data['countData'] = $count;
  628. return $data;
  629. }
  630. /**
  631. * 预计成交商机
  632. * @param $param
  633. * @throws \think\db\exception\DataNotFoundException
  634. * @throws \think\db\exception\ModelNotFoundException
  635. * @throws \think\exception\DbException
  636. */
  637. public function eventDealBusiness($param)
  638. {
  639. $user_id = $param['user_id'];
  640. $time = $this->eventDataTime($param);
  641. $return_time = `'` . date('Y-m-d', $time[0]) . `'`;
  642. $return_end = `'` . date('Y-m-d', $time[1]) . `'`;
  643. $between_time['business.deal_date'] = ['between', [$return_time, $return_end]];
  644. $between_time['business.create_user_id|business.owner_user_id'] = ['eq', $user_id];
  645. $event_date = db('crm_business')
  646. ->alias('business')
  647. ->join('__ADMIN_USER__ user', 'user.id = business.owner_user_id', 'LEFT')
  648. ->where('business.deal_date', '>', 0)
  649. ->where($between_time)
  650. ->field('business.business_id,business.deal_date,business.business_id,business.name,business.last_time,business.create_time,user.realname as owner_user_name')
  651. ->select();
  652. $count = db('crm_business')
  653. ->alias('business')
  654. ->join('__ADMIN_USER__ user', 'user.id = business.owner_user_id', 'LEFT')
  655. ->where('business.deal_date', '>', 0)->where($between_time)->count();
  656. foreach ($event_date as $k => $v) {
  657. $event_date[$k]['deal_date'] = $v['deal_date'] ?: null;
  658. $event_date[$k]['create_time'] = $v['create_time'] ? date('Y-m-d H:i:s', $v['create_time']) : null;
  659. $event_date[$k]['last_time'] = $v['last_time'] ? date('Y-m-d H:i:s', $v['last_time']) : null;
  660. }
  661. $data = [];
  662. $data['list'] = $event_date;
  663. $data['countData'] = $count;
  664. return $data;
  665. }
  666. /**
  667. * 公共时间处理
  668. * @param $param
  669. */
  670. public function eventDataTime($param)
  671. {
  672. $userModel = new \app\admin\model\User();
  673. $recordModel = new \app\admin\model\Record();
  674. //默认本账户or 自定义用户id
  675. if ($param['start_time'] && $param['end_time']) {
  676. $start_time = $param['start_time'];
  677. $end_time = $param['end_time'];
  678. if (strlen($start_time) == 13) $start_time = $start_time / 1000;
  679. if (strlen($end_time) == 13) $end_time = $end_time / 1000;
  680. } else {
  681. $start_time = mktime(0, 0, 0, date('m'), 1, date('Y'));
  682. $end_time = mktime(23, 59, 59, date('m'), date('t'), date('Y'));
  683. }
  684. $data = [];
  685. $data = [$start_time, $end_time];
  686. return $data;
  687. }
  688. /**
  689. * 编辑日程信息
  690. *
  691. * @param $param
  692. * @param string $event_id
  693. * @return bool
  694. * @throws \think\Exception
  695. * @throws \think\db\exception\DataNotFoundException
  696. * @throws \think\db\exception\ModelNotFoundException
  697. * @throws \think\exception\DbException
  698. * @throws \think\exception\PDOException
  699. */
  700. public function updateDataById($param, $event_id = '')
  701. {
  702. $dataInfo = $this->getDataById($event_id, $param);
  703. if (!$dataInfo) {
  704. $this->error = '数据不存在或已删除';
  705. return false;
  706. }
  707. if ($dataInfo['create_user_id'] != $param['user_id']) {
  708. $this->error = '没有编辑权限';
  709. return false;
  710. }
  711. $todayTime = Time::today();
  712. # 设置日程参数
  713. $param['create_user_id'] = $param['user_id'];
  714. $param['owner_user_ids'] = arrayToString($param['owner_user_ids']);
  715. $param['start_time'] = !empty($param['start_time']) ? strtotime($param['start_time']) : $todayTime[0];
  716. $param['end_time'] = !empty($param['end_time']) ? strtotime($param['end_time']) : $todayTime[1];
  717. $param['update_time'] = time();
  718. unset($param['user_id']);
  719. # 关联数据
  720. $relation = [];
  721. if (!empty($param['customer_ids'])) $relation['customer_ids'] = arrayToString($param['customer_ids']);
  722. if (!empty($param['contacts_ids'])) $relation['contacts_ids'] = arrayToString($param['contacts_ids']);
  723. if (!empty($param['business_ids'])) $relation['business_ids'] = arrayToString($param['business_ids']);
  724. if (!empty($param['contract_ids'])) $relation['contract_ids'] = arrayToString($param['contract_ids']);
  725. # 提醒数据
  726. $notice = $param['notice'];
  727. # 删除多余字段
  728. unset($param['customer_ids']);
  729. unset($param['contacts_ids']);
  730. unset($param['business_ids']);
  731. unset($param['contract_ids']);
  732. unset($param['notice']);
  733. if ($this->allowField(true)->save($param, ['event_id' => $event_id])) {
  734. $eventId = $this->event_id;
  735. actionLog($event_id, $param['owner_user_ids'], '', '修改了日程');
  736. $list = db('oa_event_notice')->where('event_id', $eventId)->select();
  737. if ($list) {
  738. foreach ($list as $k => $v) {
  739. Db::name('admin_message')->where(['type' => 9, 'action_id' => $v['id']])->delete();
  740. }
  741. }
  742. $item = Db::name('OaEventNotice')->where(['event_id' => $eventId])->delete();
  743. # 提醒
  744. if (!empty($notice)) {
  745. $noticeData = [];
  746. $startTime = $param['start_time'];
  747. foreach ($notice as $key => $value) {
  748. if ($value['type'] == 1) $startTime = $param['start_time'] - ($value['number'] * 60);
  749. if ($value['type'] == 2) $startTime = $param['start_time'] - ($value['number'] * 60 * 60);
  750. if ($value['type'] == 3) $startTime = $param['start_time'] - ($value['number'] * 60 * 60 * 24);
  751. $noticeData[] = [
  752. 'event_id' => $eventId,
  753. 'noticetype' => $value['type'],
  754. 'number' => $value['value'],
  755. 'start_time' => $startTime,
  756. 'stop_time' => $param['end_time']
  757. ];
  758. }
  759. if (!empty($noticeData)) {
  760. $item = Db::name('oa_event_notice')->insertAll($noticeData);
  761. if ($item) {
  762. $item = Db::name('oa_event_notice')->where('event_id', $eventId)->select();
  763. foreach ($item as $val) {
  764. if ($value['noticetype'] == '1') { //分
  765. $dd = strtotime($param['start_time']) - ($val['number'] * 60);
  766. } else if ($val['noticetype'] == '2') { //时
  767. $dd = strtotime($param['start_time']) - ($val['number'] * 60 * 60);
  768. } else if ($val['noticetype'] == '3') {//天
  769. $dd = strtotime($param['start_time']) - ($val['number'] * 60 * 60 * 24);
  770. }
  771. // 站内信
  772. (new Message())->send(
  773. Message::EVENT_MESSAGE,
  774. [
  775. 'title' => $param['title'],
  776. 'action_id' => $val['id'],
  777. 'advance_time' => $dd ?: 0
  778. ],
  779. stringToArray($param['owner_user_ids'])
  780. );
  781. }
  782. }
  783. }
  784. }
  785. $data['event_id'] = $event_id;
  786. if (Db::name('OaEventRelation')->where(['event_id' => $event_id])->find()) {
  787. Db::name('OaEventRelation')->where(['event_id' => $event_id])->update($relation);
  788. } else {
  789. if (!empty($relation)) {
  790. $relation['event_id'] = $eventId;
  791. $relation['status'] = 1;
  792. $relation['create_time'] = time();
  793. Db::name('OaEventRelation')->where(['event_id' => $event_id])->insert($relation);
  794. }
  795. }
  796. return $data;
  797. } else {
  798. $this->error = '编辑失败';
  799. return false;
  800. }
  801. }
  802. /**
  803. * 日程数据
  804. *
  805. * @param string $eventId
  806. * @return Common|array|bool|\PDOStatement|string|\think\Model|null
  807. * @throws \think\db\exception\DataNotFoundException
  808. * @throws \think\db\exception\ModelNotFoundException
  809. * @throws \think\exception\DbException
  810. */
  811. public function getDataById($eventId)
  812. {
  813. # 日程数据
  814. $eventData = Db::name('oa_event')->where('event_id', $eventId)->find();
  815. # 颜色类型
  816. $eventData['color'] = Db::name('admin_oa_schedule')->where('schedule_id', $eventData['schedule_id'])->value('color');
  817. # 创建人信息
  818. $eventData['create_user_name'] = Db::name('admin_user')->where('id', $eventData['create_user_id'])->value('realname');
  819. # 参与人信息
  820. $eventData['owner_user_info'] = Db::name('admin_user')->field(['id', 'realname'])->whereIn('id', trim($eventData['owner_user_ids'], ','))->select();
  821. # 处理日程的日期数据
  822. $eventData['start_time'] = !empty($eventData['start_time']) ? date('Y-m-d H:i:s', $eventData['start_time']) : '';
  823. $eventData['end_time'] = !empty($eventData['end_time']) ? date('Y-m-d H:i:s', $eventData['end_time']) : '';
  824. $eventData['create_time'] = !empty($eventData['create_time']) ? date('Y-m-d H:i:s', $eventData['create_time']) : '';
  825. $eventData['update_time'] = !empty($eventData['update_time']) ? date('Y-m-d H:i:s', $eventData['update_time']) : '';
  826. # 日程提醒数据
  827. $noticeData = Db::name('oa_event_notice')->where('event_id', $eventId)->select();
  828. # 整理日程提醒数据
  829. $eventData['notice'] = [];
  830. foreach ($noticeData as $key => $value) {
  831. $eventData['notice'][] = [
  832. 'type' => $value['noticetype'],
  833. 'value' => $value['number']
  834. ];
  835. }
  836. # 关联客户数据
  837. $relationData = Db::name('oa_event_relation')->where('event_id', $eventId)->find();
  838. # 关联的客户数据
  839. $eventData['customer'] = [];
  840. if (!empty($relationData['customer_ids'])) {
  841. $eventData['customer'] = Db::name('crm_customer')->field(['customer_id', 'name'])->whereIn('customer_id', trim($relationData['customer_ids'], ','))->select();
  842. }
  843. # 关联的联系人数据
  844. $eventData['contacts'] = [];
  845. if (!empty($relationData['contacts_ids'])) {
  846. $eventData['contacts'] = Db::name('crm_contacts')->field(['contacts_id', 'name'])->whereIn('contacts_id', trim($relationData['contacts_ids'], ','))->select();
  847. }
  848. # 关联的商机数据
  849. $eventData['business'] = [];
  850. if (!empty($relationData['business_ids'])) {
  851. $eventData['business'] = Db::name('crm_business')->field(['business_id', 'name'])->whereIn('business_id', trim($relationData['business_ids'], ','))->select();
  852. }
  853. # 关联的合同数据
  854. $eventData['contract'] = [];
  855. if (!empty($relationData['contract_ids'])) {
  856. $eventData['contract'] = Db::name('crm_contract')->field(['contract_id', 'name'])->whereIn('contract_id', trim($relationData['contract_ids'], ','))->select();
  857. }
  858. return $eventData;
  859. }
  860. //根据ID 删除日程
  861. public function delDataById($param)
  862. {
  863. $dataInfo = $this->get($param['event_id']);
  864. if (!$dataInfo) {
  865. $this->error = '数据不存在或已删除';
  866. return false;
  867. }
  868. if ($dataInfo['create_user_id'] != $param['user_id']) {
  869. $this->error = '没有编辑权限';
  870. return false;
  871. }
  872. $map['event_id'] = $param['event_id'];
  873. $map['create_user_id'] = $param['user_id'];
  874. $flag = $this->where($map)->delete();
  875. if ($flag) {
  876. Db::name('OaEventNotice')->where(['event_id' => $param['event_id']])->delete();
  877. Db::name('OaEventRelation')->where(['event_id' => $param['event_id']])->delete();
  878. actionLog($param['event_id'], $dataInfo['owner_user_ids'], '', '删除了日程');
  879. return true;
  880. } else {
  881. $this->error = '删除失败';
  882. return false;
  883. }
  884. }
  885. }