|
...
|
...
|
@@ -2,16 +2,12 @@ |
|
|
|
|
|
|
|
namespace App\Http\Controllers\Bside;
|
|
|
|
|
|
|
|
use App\Exceptions\BsideGlobalException;
|
|
|
|
use App\Helper\Arr;
|
|
|
|
|
|
|
|
use App\Http\Logic\Bside\InquiryLogic;
|
|
|
|
use App\Http\Requests\Bside\InquiryRequest;
|
|
|
|
use App\Rules\Ids;
|
|
|
|
use App\Services\BatchExportService;
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
use Illuminate\Support\Facades\Storage;
|
|
|
|
use Illuminate\Validation\ValidationException;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 精准询盘
|
|
...
|
...
|
@@ -25,23 +21,18 @@ class InquiryController extends BaseController |
|
|
|
|
|
|
|
public function index(InquiryLogic $logic)
|
|
|
|
{
|
|
|
|
$map = [];
|
|
|
|
if(!empty($this->param['search'])){
|
|
|
|
$map[] = ['name|email|content', 'like', "%{$this->param['search']}%"];
|
|
|
|
}
|
|
|
|
$sort = ['id' => 'desc'];
|
|
|
|
$data = $logic->getList($map, $sort, ['id', 'name', 'email', 'phone', 'url', 'ip', 'ip_country', 'status', 'created_at']);
|
|
|
|
$data = $logic->getApiList();
|
|
|
|
return $this->success($data);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function info(Request $request, InquiryLogic $logic){
|
|
|
|
$request->validate([
|
|
|
|
'id'=>'required'
|
|
|
|
'id' => 'required',
|
|
|
|
],[
|
|
|
|
'id.required' => 'ID不能为空'
|
|
|
|
]);
|
|
|
|
$data = $logic->getInfo($this->param['id']);
|
|
|
|
return $this->success(Arr::twoKeepKeys($data, ['id', 'name', 'email', 'phone', 'url', 'ip', 'ip_country', 'status', 'content', 'trans_content', 'created_at']));
|
|
|
|
return $this->success($data);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function delete(Request $request, InquiryLogic $logic)
|
|
...
|
...
|
@@ -52,8 +43,8 @@ class InquiryController extends BaseController |
|
|
|
'ids.required' => 'ID不能为空'
|
|
|
|
]);
|
|
|
|
|
|
|
|
$data = $logic->delete($this->param['ids']);
|
|
|
|
return $this->success($data);
|
|
|
|
$logic->delete($this->param['ids']);
|
|
|
|
return $this->success();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
...
|
...
|
@@ -66,22 +57,20 @@ class InquiryController extends BaseController |
|
|
|
*/
|
|
|
|
public function export(InquiryLogic $logic)
|
|
|
|
{
|
|
|
|
$sort = ['id' => 'desc'];
|
|
|
|
//最多到1w条
|
|
|
|
$data = $logic->getList([], $sort, ['name', 'email', 'phone', 'url', 'ip', 'ip_country', 'content', 'created_at'], 10000);
|
|
|
|
$data = $logic->getApiList(true);
|
|
|
|
$data = $data['list'] ?? [];
|
|
|
|
foreach ($data as &$item){
|
|
|
|
$item['ip_address'] = "{$item['ip_country']}({$item['ip']})";
|
|
|
|
$item['ip_address'] = "{$item['country']}({$item['ip']})";
|
|
|
|
}
|
|
|
|
|
|
|
|
$map = [
|
|
|
|
'created_at' => '询盘发送时间',
|
|
|
|
'submit_time' => '询盘发送时间',
|
|
|
|
'name' => '姓名',
|
|
|
|
'email' => '邮箱',
|
|
|
|
'phone' => '电话',
|
|
|
|
'ip_address' => '访问国家/地区(IP)',
|
|
|
|
'url' => '发送页面',
|
|
|
|
'content' => '询盘内容',
|
|
|
|
'refer' => '发送页面',
|
|
|
|
'message' => '询盘内容',
|
|
|
|
];
|
|
|
|
|
|
|
|
//生成文件,发送到客户端
|
|
...
|
...
|
@@ -94,4 +83,17 @@ class InquiryController extends BaseController |
|
|
|
// return Storage::disk('runtime')->download($file); //直接下载
|
|
|
|
return $this->success(['url' => $fileurl]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 询盘通知设置
|
|
|
|
* @author zbj
|
|
|
|
* @date 2023/5/17
|
|
|
|
*/
|
|
|
|
public function set(Request $request, InquiryLogic $logic){
|
|
|
|
if($request->isMethod('get')){
|
|
|
|
return $this->success($logic->getSet());
|
|
|
|
}
|
|
|
|
$logic->saveSet();
|
|
|
|
return $this->success();
|
|
|
|
}
|
|
|
|
} |
...
|
...
|
|