ActionRecord.php 3.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Description: 字段修改记录
  4. // +----------------------------------------------------------------------
  5. // | Author: Michael_xu | gengxiaoxu@5kcrm.com
  6. // +----------------------------------------------------------------------
  7. namespace app\admin\model;
  8. use app\admin\model\Common;
  9. class ActionRecord extends Common
  10. {
  11. /**
  12. * 为了数据库的整洁,同时又不影响Model和Controller的名称
  13. * 我们约定每个模块的数据表都加上相同的前缀,比如CRM模块用crm作为数据表前缀
  14. */
  15. protected $name = 'admin_action_record';
  16. public $typesArr = ['crm_leads','crm_customer','crm_contacts','crm_product','crm_business','crm_contract','crm_receivables','crm_visit'];
  17. /**
  18. * [getDataList 获取列表]
  19. * @return [array]
  20. */
  21. public function getDataList($request)
  22. {
  23. $types = trim($request['types']);
  24. $action_id = intval($request['action_id']);
  25. //判断权限
  26. if (!$this->checkData($types, $action_id, $request['user_id'])) {
  27. return [];
  28. }
  29. $dataList = db('admin_action_record')->where(['types' => $types,'action_id' => $action_id])->order('id','desc')->select();
  30. if($types == 'crm_customer') {
  31. $leads_id = db('crm_leads')->where(['customer_id' => $action_id, 'is_transform' => 1])->value('leads_id');
  32. if($leads_id){
  33. $leads_dataList = db('admin_action_record')->where(['types' => 'crm_leads','action_id' => $leads_id])->order('id','desc')->select();
  34. $dataList = array_merge($leads_dataList, $dataList);
  35. # 对线索和客户的合并数据进行排序
  36. $sortData = array_column($dataList, 'create_time');
  37. array_multisort($sortData,SORT_DESC , $dataList);
  38. }
  39. }
  40. $userModel = model('User');
  41. foreach ($dataList as $k=>$v) {
  42. $dataList[$k]['user_id_info'] = isset($v['user_id']) ? $userModel->getUserById($v['user_id']) : [];
  43. $dataList[$k]['content'] = explode('.|.', $v['content']);
  44. }
  45. return $dataList;
  46. }
  47. /**
  48. * [checkData 权限判断]
  49. * @return [array]
  50. */
  51. public function checkData($types, $action_id, $user_id)
  52. {
  53. if (!in_array($types, $this->typesArr)) {
  54. return false;
  55. }
  56. if (!$action_id) {
  57. return false;
  58. }
  59. $adminTypes = adminGroupTypes($user_id);
  60. if (in_array(1,$adminTypes)) {
  61. return true;
  62. }
  63. $checkRes = false;
  64. switch ($types) {
  65. case 'crm_leads' :
  66. $checkRes = checkPerByAction('crm', 'leads', 'read');
  67. break;
  68. case 'crm_customer' :
  69. $checkRes = checkPerByAction('crm', 'customer', 'read');
  70. break;
  71. case 'crm_contacts' :
  72. $checkRes = checkPerByAction('crm', 'contacts', 'read');
  73. break;
  74. case 'crm_product' :
  75. $checkRes = checkPerByAction('crm', 'product', 'read');
  76. break;
  77. case 'crm_business' :
  78. $checkRes = checkPerByAction('crm', 'business', 'read');
  79. break;
  80. case 'crm_contract' :
  81. $checkRes = checkPerByAction('crm', 'contract', 'read');
  82. break;
  83. case 'crm_receivables' :
  84. $checkRes = checkPerByAction('crm', 'receivables', 'read');
  85. break;
  86. case 'crm_visit' :
  87. $checkRes = checkPerByAction('crm', 'visit', 'read');
  88. break;
  89. }
  90. if ($checkRes !== false) {
  91. return true;
  92. }
  93. }
  94. /**
  95. * 删除字段修改记录
  96. * @param
  97. * @return
  98. */
  99. public function delDataById($request)
  100. {
  101. $types = trim($request['types']);
  102. $action_id = $request['action_id'];
  103. if ($types && $action_id) {
  104. $res = db('admin_action_record')->where(['types' => $types,'action_id' => ['in',$action_id]])->delete();
  105. }
  106. }
  107. }