InquireLogic.php 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: Administrator
  5. * Date: 2019/4/29 0029
  6. * Time: 17:16
  7. */
  8. namespace App\Http\Logics\Admin;
  9. use App\Http\Models\Role;
  10. use App\Http\Models\SiteProcess;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Support\Facades\DB;
  13. use function GuzzleHttp\Psr7\str;
  14. class InquireLogic
  15. {
  16. /**
  17. * 项目详情中的询盘和客户询盘记录筛选
  18. * @param Request $request
  19. * @param $server
  20. * @param $site
  21. * @param $condition
  22. * @param int $isDelete
  23. * @return array
  24. */
  25. public function pageRecords(Request $request, $server, $site, $condition, $isDelete = null)
  26. {
  27. //流程程序开发流程 部署
  28. $config = [
  29. 'connection_name' => sprintf('connection_name_%s', $site->id),
  30. 'host' => $server->server_ip,
  31. 'port' => '3306',
  32. 'database' => $site->database,
  33. 'username' => $server->mysql_user_name,
  34. 'password' => $server->mysql_passwd,
  35. ];
  36. config_connection($config);
  37. $builder = DB::connection($config['connection_name'])->table('user_msg')->where($condition);
  38. $nowUser = auth()->user();
  39. if ($nowUser->role_id == Role::TYPE_TYPE_CUSTOMER_STAFF) {
  40. $inquireIds = DB::table('user_has_inquire')->where(['user_id' => $nowUser->id])->get()->pluck('inquire_id')->toArray();
  41. $builder->whereIn('id', $inquireIds);
  42. }
  43. //是否真实询盘筛选
  44. if (isset($isDelete)) {
  45. $builder->where('is_delete', $isDelete);
  46. }
  47. $records = $builder->orderBy('create_time', 'desc')
  48. ->paginate($request->input('pageSize') ?? TABLE_PAGE_SIZE);
  49. $items = $records->items();
  50. array_walk($items, function ($item) {
  51. $item->created_at = date('Y-m-d H:i:s', $item->create_time);
  52. $item->is_read = $item->is_read ? '已读' : '未读';
  53. preg_match('/(?:\()(.*)(?:\))/i', $item->content, $match);
  54. preg_match("/(?:\()(.*)(?:\))/i", $match[0] ?? '', $result);
  55. preg_match('/\d{10,}/', $item->content, $match2);
  56. $item->location = $result[1] ?? '';
  57. $item->phone = $match2[0] ?? '';
  58. $item->mail_date = '详情';
  59. if (!in_array($item->mail_time, [-1, 0])) {
  60. $item->mail_date = date('Y-m-d H:i:s', $item->mail_time);
  61. }
  62. });
  63. $condition['is_delete'] = 0;
  64. $realInquire = DB::connection($config['connection_name'])->table('user_msg')->where($condition)->count();
  65. return [$records, $realInquire];
  66. }
  67. public function PageRecordsExport(Request $request, $server, $site, $condition)
  68. {
  69. //流程程序开发流程 部署
  70. $config = [
  71. 'connection_name' => sprintf('connection_name_%s', $site->id),
  72. 'host' => $server->server_ip,
  73. 'port' => '3306',
  74. 'database' => $site->database,
  75. 'username' => $server->mysql_user_name,
  76. 'password' => $server->mysql_passwd,
  77. ];
  78. config_connection($config);
  79. $builder = DB::connection($config['connection_name'])->table('user_msg')->select([
  80. 'sender_name',
  81. 'sender_email',
  82. 'create_time',
  83. 'title',
  84. 'content',
  85. 'is_delete',
  86. 'is_read'
  87. ])->where($condition);
  88. if (!$request->input('notCustomer')) {
  89. $nowUser = auth()->user();
  90. if ($nowUser->role_id == Role::TYPE_TYPE_CUSTOMER_STAFF) {
  91. $inquireIds = DB::table('user_has_inquire')->where(['user_id' => $nowUser->id])->get()->pluck('inquire_id')->toArray();
  92. $builder->whereIn('id', $inquireIds);
  93. }
  94. }
  95. $records = $builder->get()->toArray();
  96. $resultsRecord = [];
  97. foreach ($records as $record) {
  98. preg_match('/(?:\()(.*)(?:\))/i', $record->content, $match);
  99. preg_match("/(?:\()(.*)(?:\))/i", $match[0] ?? '', $result);
  100. preg_match('/\d{10,}/', $record->content, $match2);
  101. // $content = preg_replace('/\r|\n/', '', $record->content);
  102. // preg_match('/留言\:\<\/td\>.*?\<\/div>/i', $content, $m1);
  103. // $m1[0] = str_replace('留言:', '', $m1[0]);
  104. $memo = explode('留言:', strip_tags($record->content));
  105. if (!empty($memo[1])) {
  106. $memo1 = explode('URL:', $memo[1]);
  107. if (!empty($memo1[1])) {
  108. $url = explode('温馨提示:', $memo1[1]);
  109. }
  110. }
  111. $resultsRecord[] = [
  112. 'sender_name' => $record->sender_name,
  113. 'sender_email' => $record->sender_email,
  114. 'phone' => $match2[0] ?? '',
  115. 'location' => $result[1] ?? '',
  116. 'create_time' => date('Y-m-d', $record->create_time),
  117. 'title' => $record->title,
  118. 'content' => strip_tags($record->content),
  119. 'is_delete' => $record->is_read ? '是' : '否',
  120. 'is_read' => $record->is_read ? '已读' : '未读',
  121. 'memo' => $memo1[0] ?? '',
  122. 'url' => $url[0] ?? '',
  123. ];
  124. }
  125. return $resultsRecord;
  126. }
  127. public function PageRecordsAllExport($server, $site)
  128. {
  129. $config = [
  130. 'connection_name' => sprintf('connection_name_%s', $site->id),
  131. 'host' => $server->server_ip,
  132. 'port' => '3306',
  133. 'database' => $site->database,
  134. 'username' => $server->mysql_user_name,
  135. 'password' => $server->mysql_passwd,
  136. ];
  137. config_connection($config);
  138. $builder = DB::connection($config['connection_name'])
  139. ->table('user_log')
  140. ->whereBetween('create_time', [strtotime(date('Y-m-d', strtotime("first day of last month"))), strtotime("now")])
  141. ->where('user_id', 1)->select('id', 'user_id', 'notice', 'url', 'request', 'cookie', 'client_ip', 'create_time')->get();
  142. $resultsRecord = [];
  143. foreach ($builder as $record) {
  144. $resultsRecord[] = [
  145. 'id' => $record->id,
  146. 'user_id' => $record->user_id,
  147. 'notice' => $record->notice,
  148. 'url' => $record->url,
  149. 'request' => $record->request,
  150. 'cookie' => $record->cookie,
  151. 'client_ip' => long2ip($record->client_ip),
  152. 'create_time' => date('Y-m-d', $record->create_time),
  153. ];
  154. }
  155. return $resultsRecord;
  156. }
  157. public function pageRecordsExportBak(Request $request, $server, $site, $condition)
  158. {
  159. //流程程序开发流程 部署
  160. $config = [
  161. 'connection_name' => sprintf('connection_name_%s', $site->id),
  162. 'host' => $server->server_ip,
  163. 'port' => '3306',
  164. 'database' => $site->database,
  165. 'username' => $server->mysql_user_name,
  166. 'password' => $server->mysql_passwd,
  167. ];
  168. config_connection($config);
  169. $builder = DB::connection($config['connection_name'])->table('user_msg')->select([
  170. 'sender_name',
  171. 'sender_email',
  172. 'create_time',
  173. 'title',
  174. 'content',
  175. 'is_delete',
  176. 'is_read'
  177. ])->where($condition);
  178. $records = $builder->get()->toArray();
  179. $resultsRecord = [];
  180. foreach ($records as $record) {
  181. preg_match('/(?:\()(.*)(?:\))/i', $record->content, $match);
  182. preg_match("/(?:\()(.*)(?:\))/i", $match[0] ?? '', $result);
  183. preg_match('/\d{10,}/', $record->content, $match2);
  184. // $content = preg_replace('/\r|\n/', '', $record->content);
  185. // preg_match('/留言\:\<\/td\>.*?\<\/div>/i', $content, $m1);
  186. // $m1[0] = str_replace('留言:', '', $m1[0]);
  187. $resultsRecord[] = [
  188. 'sender_name' => $record->sender_name,
  189. 'sender_email' => $record->sender_email,
  190. 'phone' => $match2[0] ?? '',
  191. 'location' => $result[1] ?? '',
  192. 'create_time' => date('Y-m-d', $record->create_time),
  193. 'title' => $record->title,
  194. 'content' => str_replace('留言:', '', strip_tags($record->content)),
  195. 'is_delete' => $record->is_read ? '是' : '否',
  196. 'is_read' => $record->is_read ? '已读' : '未读',
  197. ];
  198. }
  199. return $resultsRecord;
  200. }
  201. }