file:增加联系方式和用户留言模块

This commit is contained in:
ll 2023-04-21 15:27:39 +08:00
parent 601a5b9181
commit aec30d6473
6 changed files with 542 additions and 0 deletions

View File

@ -0,0 +1,65 @@
<?php
namespace app\admin\controller\ContactUs;
use app\BaseController;
use app\common\model\ContactUs\ContactInfo as ModelContactInfo;
use app\Request;
use think\Validate;
use think\exception\ValidateException;
use think\facade\Filesystem;
use app\common\exception\Tool;
class ContactInfo extends BaseController
{
/**
* 获取联系方式内容
*/
public function getContactInfo(Request $request): array
{
$params = $request->param();
$query = ModelContactInfo::field([
'contact_info_id',
'contact_info_guid',
'contact_info_location',
'latitude',
'longitude',
'customer_service_wx',
'contact_info_phone',
'join_apply_content'
])->where(1)->find();
return [
'code' => 0,
'data' => $query,
'msg' => 'ok'
];
}
/**
* 编辑联系方式
*/
public function editContactInfo(Request $request): array
{
$params = $request->param();
$this->validate($params, [
'contact_info_location|定位' => 'require',
'customer_service_wx|客户微信' => 'require',
'contact_info_phone|联系电话' => 'require',
'join_apply_content|加盟简介' => 'require'
]);
$model = ModelContactInfo::where('contact_info_id',1)->find();
$model->allowField([
'contact_info_update_user_guid',
'contact_info_location',
'latitude',
'longitude',
'customer_service_wx',
'contact_info_phone',
'join_apply_content'
])->save($params);
return msg('编辑成功!');
}
}

View File

@ -0,0 +1,160 @@
<?php
namespace app\admin\controller\ContactUs;
use app\BaseController;
use app\common\model\ContactUs\LeaveMessage as ModelLeaveMessage;
use app\Request;
use think\Validate;
use think\exception\ValidateException;
use think\facade\Filesystem;
use app\common\arw\adjfut\src\Excel;
use app\common\arw\adjfut\src\UploadFile;
use app\common\exception\Tool;
use think\facade\Db;
use think\facade\Env;
class LeaveMessage extends BaseController
{
/**
* 获取用户留言列表
*/
public function getLeaveMessageList(Request $request): array
{
$params = $request->param();
$con = [];
$con = Tool::getOptionalQuery();
$query = ModelLeaveMessage::where($con)
->field([
'leave_message_id',
'leave_message_guid',
'leave_message_content',
'leave_message_status',
'leave_message_user_name',
'leave_message_user_phone'
])
->order('leave_message_update_time', 'desc');
return msg("获取用户留言列表成功!", $query);
}
/**
* 编辑用户留言
*/
public function editLeaveMessage(Request $request): array
{
$params = $request->param();
$this->validate($params, [
'leave_message_content|留言内容' => 'require',
'leave_message_status|留言受理状态' => 'require',
'leave_message_user_name|留言人名称' => 'require',
'leave_message_user_phone|留言人手机号码' => 'require'
]);
$model = ModelLeaveMessage::where('leave_message_guid', $params['leave_message_guid'])->find();
if (!$model) throwErrorMsg("该用户留言不存在", 1);
$model->allowField([
'leave_message_update_user_guid',
'leave_message_content',
'leave_message_status',
'leave_message_user_name',
'leave_message_user_phone'
])->save($params);
return msg('编辑成功!');
}
/**
* 添加用户留言
*/
public function addLeaveMessage(Request $request): array
{
$params = $request->param();
$this->validate($params, [
'leave_message_content|留言内容' => 'require',
'leave_message_status|留言受理状态' => 'require',
'leave_message_user_name|留言人名称' => 'require',
'leave_message_user_phone|留言人手机号码' => 'require'
]);
$model = ModelLeaveMessage::create($params, [
'leave_message_guid',
'leave_message_create_user_guid',
'leave_message_update_user_guid',
'leave_message_content',
'leave_message_status',
'leave_message_user_name',
'leave_message_user_phone'
]);
return msg('添加成功!');
}
/**
* 删除用户留言
*/
public function deleteLeaveMessage(Request $request): array
{
$params = $request->param();
$this->validate($params, [
'leave_message_guid' => 'require',
]);
$leave_message = ModelLeaveMessage::where([
'leave_message_guid' => explode(',', $params['leave_message_guid'])
])->select();
$leave_message->delete();
return msg('删除成功!');
}
/**
* 导出Excel
*/
public function exportExcel(Request $request)
{
$params = $request->param();
$select = ModelLeaveMessage::field([
'leave_message_content',
'leave_message_status',
'leave_message_user_name',
'leave_message_user_phone'
])
->order('leave_message_update_time', 'desc')
->select();
return ModelLeaveMessage::exportExcel($select);
}
/**
* 用户留言受理接口
*
* @param Request request
* @return array
* @date 2023-04-20
* @author xjh
* @since 1.0.0
*/
public function handleleave_messageStatus(Request $request): array
{
$params = $request->param();
$this->validate($params, [
'leave_message_guid|在线报名guid' => 'require',
]);
$msg_data = [];
$leave_message_guids = explode(',', $params['leave_message_guid']);
$leave_message_guids_count = count($leave_message_guids);
foreach ($leave_message_guids as $line => $leave_message_guid) {
$prefix_text = ($leave_message_guids_count != 1) ? "" . ($line + 1) . "行-> " : null;
try {
$leave_message = ModelLeaveMessage::where('leave_message_guid', $leave_message_guid)->find();
if (!$leave_message) throwErrorMsg('该在线报名数据不存在!');
if ($leave_message->leave_message_status == 1) throwErrorMsg('该在线报名数据已处理!');
$leave_message->leave_message_status = 1;
$leave_message->save();
$msg_data[] = $prefix_text . "用户名称【{$leave_message->leave_message_user_name}】: <span style='color:#27af49'>受理成功!</span>";
} catch (\Throwable $th) {
$msg_data[] = $prefix_text . "用户名称:【{$leave_message->leave_message_user_name}】: <span style='color:red'>{$th->getMessage()}</span>";
}
};
return msg(0, implode('<br>', $msg_data));
}
}

View File

@ -0,0 +1,41 @@
<?php
namespace app\api\controller\ContactInfo;
use app\BaseController;
use app\common\model\ContactInfo\ContactInfo as ModelContactInfo;
use app\Request;
use think\Validate;
use think\exception\ValidateException;
use think\facade\Filesystem;
use app\common\exception\Tool;
class ContactInfo extends BaseController
{
/**
* 获取联系方式内容
*/
public function getContactInfo(Request $request): array
{
$params = $request->param();
$query = ModelContactInfo::field([
'contact_info_id',
'contact_info_guid',
'contact_info_location',
'latitude',
'longitude',
'customer_service_wx',
'contact_info_phone',
'join_apply_content'
])->where(1)->find();
return [
'code' => 0,
'data' => $query,
'msg' => 'ok'
];
}
}

View File

@ -0,0 +1,69 @@
<?php
namespace app\api\controller\LeaveMessage;
use app\BaseController;
use app\common\model\LeaveMessage\LeaveMessage as ModelLeaveMessage;
use app\Request;
use think\Validate;
use think\exception\ValidateException;
use think\facade\Filesystem;
use app\common\arw\adjfut\src\Excel;
use app\common\arw\adjfut\src\UploadFile;
use think\facade\Db;
use app\common\exception\Tool;
use think\facade\Env;
class LeaveMessage extends BaseController
{
/**
* 获取用户留言列表
*/
public function getLeaveMessageList(Request $request): array
{
$params = $request->param();
$con = [];
$con = Tool::getOptionalQuery();
$query = ModelLeaveMessage::where($con)
->field([
'leave_message_id',
'leave_message_guid',
'leave_message_content',
'leave_message_status',
'leave_message_user_name',
'leave_message_user_phone'
])
->order('leave_message_update_time', 'desc');
return msg("获取用户留言列表成功!",$query);
}
/**
* 获取用户留言详情
*/
public function getLeaveMessageInfo(Request $request): array
{
$params = $request->param();
$this->validate($params, ['leave_message_guid' => 'require']);
$find = ModelLeaveMessage::field([
'leave_message_id',
'leave_message_guid',
'leave_message_content',
'leave_message_status',
'leave_message_user_name',
'leave_message_user_phone'
])
->where('leave_message_guid',$params['leave_message_guid'])
->find();
return msg(0,'获取用户留言详情成功!',['data' => $find]);
}
}

View File

@ -0,0 +1,91 @@
<?php
namespace app\common\model\ContactUs;
use app\common\arw\adjfut\src\Validate;
use app\BaseModel;
use think\model\concern\SoftDelete;
use app\common\arw\adjfut\src\Excel;
use app\Request;
use app\common\exception\Tool;
use think\facade\Db;
class ContactInfo extends BaseModel
{
use SoftDelete;
// 删除字段
protected $deleteTime = 'contact_info_delete_time';
// 设置主键名
protected $pk = 'contact_info_guid';
// 设置废弃字段
protected $disuse = [];
// 设置字段信息
protected $schema = [
"contact_info_id" => "int",
"contact_info_guid" => "string",
"contact_info_location" => "string",
"latitude" => "string",
"longitude" => "string",
"customer_service_wx" => "string",
"contact_info_phone" => "int",
"join_apply_content" => "string",
"contact_info_create_time" => "datetime",
"contact_info_create_user_guid" => "string",
"contact_info_update_time" => "datetime",
"contact_info_update_user_guid" => "string",
"contact_info_delete_time" => "datetime",
"contact_info_delete_user_guid" => "string",
];
// 设置json类型字段
protected $json = [''];
// 开启自动写入时间戳字段
protected $autoWriteTimestamp = 'datetime';
// 创建时间
protected $createTime = 'contact_info_create_time';
// 修改时间
protected $updateTime = 'contact_info_update_time';
/**
* 新增前
*/
public static function onBeforeInsert(self $model): void
{
// self::checkRepeatData($model);
$model->completeCreateField();
}
/**
* 更新前
*/
public static function onBeforeUpdate(self $model): void
{
// self::checkRepeatData($model);
$model->completeUpdateField();
}
/**
* 删除前
*/
public static function onBeforeDelete(self $model): void
{
$model->completeDeleteField();
}
}

View File

@ -0,0 +1,116 @@
<?php
namespace app\common\model\ContactUs;
use app\common\arw\adjfut\src\Validate;
use app\BaseModel;
use think\model\concern\SoftDelete;
use app\common\arw\adjfut\src\Excel;
use app\Request;
use app\common\exception\Tool;
use think\facade\Db;
class LeaveMessage extends BaseModel
{
use SoftDelete;
// 删除字段
protected $deleteTime = 'leave_message_delete_time';
// 设置主键名
protected $pk = 'leave_message_guid';
// 设置废弃字段
protected $disuse = [];
// 设置字段信息
protected $schema = [
"leave_message_id" => "int",
"leave_message_guid" => "string",
"leave_message_content" => "string",
"leave_message_status" => "int",
"leave_message_user_name" => "string",
"leave_message_user_phone" => "int",
"leave_message_create_time" => "datetime",
"leave_message_create_user_guid" => "string",
"leave_message_update_time" => "datetime",
"leave_message_update_user_guid" => "string",
"leave_message_delete_time" => "datetime",
"leave_message_delete_user_guid" => "string",
];
// 设置json类型字段
protected $json = [''];
// 开启自动写入时间戳字段
protected $autoWriteTimestamp = 'datetime';
// 创建时间
protected $createTime = 'leave_message_create_time';
// 修改时间
protected $updateTime = 'leave_message_update_time';
/**
* 新增前
*/
public static function onBeforeInsert(self $model): void
{
// self::checkRepeatData($model);
$model->completeCreateField();
}
/**
* 更新前
*/
public static function onBeforeUpdate(self $model): void
{
// self::checkRepeatData($model);
$model->completeUpdateField();
}
/**
* 删除前
*/
public static function onBeforeDelete(self $model): void
{
$model->completeDeleteField();
}
/**
* 导出Excel
*/
public static function exportExcel($select)
{
$data = [[
'留言内容',
'留言受理状态',
'留言人名称',
'留言人手机号码'
]];
foreach ($select as $key => $val) {
$data[] = [
$val['leave_message_content'],
$val['leave_message_status'],
$val['leave_message_user_name'],
$val['leave_message_user_phone'],
];
}
$excel = (new Excel())->exporTsheet($data);
$excel->save('用户留言.xlsx');
}
}