DiverseYouthNightSchool/application/common/model/school/Message.php

326 lines
10 KiB
PHP

<?php
namespace app\common\model\school;
use app\common\model\BaseModel;
use think\Model;
class Message extends BaseModel
{
// 表名
protected $name = 'school_message';
// 自动写入时间戳字段
protected $autoWriteTimestamp = 'integer';
// 定义时间戳字段名
protected $createTime = 'createtime';
protected $updateTime = false;
protected $deleteTime = false;
// 追加属性
protected $append = [
'platform_text',
'oper_type_text',
'to_type_text',
'status_text',
'mini_type_text',
"type_text"
];
public function getTypeList()
{
return ['1' => __('Type 1'), '2' => __('Type 2')];
}
public function getTypeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['type']) ? $data['type'] : '');
$list = $this->getTypeList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getPlatformList()
{
return ['admin' => __('Platform admin'), 'user' => __('Platform user'), 'shop' => __('Platform shop')];
}
public function getOperTypeList()
{
return ['admin' => __('Oper_type admin'), 'user' => __('Oper_type user'), 'system' => __('Oper_type system'), 'shop' => __('Oper_type shop')];
}
public function getToTypeList()
{
return ['admin' => __('To_type admin'), 'user' => __('To_type user'), 'system' => __('To_type system'), 'shop' => __('To_type shop')];
}
public function getStatusList()
{
return ['system' => __('Status system'), 'classes' => __('Status classes'), 'order' => __('Status order')];
}
public function getMiniTypeList()
{
return ['order_notice' => __('Mini_type order_notice'), 'classes_auth' => __('Mini_type classes_auth'), 'classes_apply' => __('Mini_type classes_apply'), 'shop_apply' => __('Mini_type shop_apply'), 'classes_order_notice' => __('Mini_type classes_order_notice'), 'user_auth' => __('Mini_type user_auth'), 'aftercare' => __('Mini_type aftercare'), 'other' => __('Mini_type other')];
}
public function getPlatformTextAttr($value, $data)
{
$value = $value ?: ($data['platform'] ?? '');
$valueArr = explode(',', $value);
$list = $this->getPlatformList();
return implode(',', array_intersect_key($list, array_flip($valueArr)));
}
public function getOperTypeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['oper_type']) ? $data['oper_type'] : '');
$list = $this->getOperTypeList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getToTypeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['to_type']) ? $data['to_type'] : '');
$list = $this->getToTypeList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getStatusTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
$list = $this->getStatusList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getMiniTypeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['mini_type']) ? $data['mini_type'] : '');
$list = $this->getMiniTypeList();
return isset($list[$value]) ? $list[$value] : '';
}
protected function setPlatformAttr($value)
{
return is_array($value) ? implode(',', $value) : $value;
}
public function admin()
{
return $this->belongsTo('app\admin\model\Admin', 'oper_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
public function user()
{
return $this->belongsTo('app\admin\model\User', 'to_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
/** 发送站内信
* @param $title 站内信标题
* @param $desc 内容
* @param $mini_type 消息子类型
* @param $to_id 接收者id
* @param $to_type 接收者类型
* @param $status 消息大类型
* @param $platform 发送平台
* @param $params 额外参数
* @param $oper_id 发送人id
* @param $oper_type 发送人类型
*
*/
public static function send($title,$desc,$mini_type,$to_id,$to_type="user",$status="system",$platform="user",$params=[],$oper_id=0,$oper_type="system"){
$data = [
'title' => $title,
'desc' => $desc,
'params' => json_encode($params),
'platform' => $platform,
'oper_id' => $oper_id,
'oper_type' => $oper_type,
'to_id' => $to_id,
'to_type' => $to_type,
'status' => $status,
'mini_type' => $mini_type,
];
$message = new self();
$message->save($data);
return $message;
}
/**展示订单信息
* @param $order_no
* @param $price_info
* @return array
*/
public static function showInfo($id, $price_info = []){
$data = [];
$data['id'] =$id;
$data['message_info'] = self::getDetail($id);
return array_merge($data,$price_info);
}
/**得到订单详情
* @param $order_no
*/
public static function getDetail($id,$oper_id = []){
$model = self::where('id',$id);
if($oper_id)$model = $model->where("oper_id","in",$oper_id);
$data = $model->find();
if(!$data) return $data;
//如果非全局消息,更新成已读
if($data->to_id != 0){
$data["type"]= '2';
$data->save();
}
// //加载订单详情
// $data->detail->teacher;
// //订单用户
//// $data->user;
// $data->user->visible(['id','nickname','mobile','avatar','realname']);
//
return $data;
}
/**得到基础条件
* @param $status
* @param null $model
* @param string $alisa
*/
public static function getBaseWhere($whereData = [], $model = null, $alisa = '',$with = false)
{
if (!$model) {
$model = new static;
if ($alisa&&!$with) $model = $model->alias($alisa);
}
if ($alisa) $alisa = $alisa . '.';
$tableFields = (new static)->getTableFields();
foreach ($tableFields as $fields)
{
if(in_array($fields, ['platform','oper_type','to_type','status','mini_type','to_id']))continue;
// if (isset($whereData[$fields]) && $whereData[$fields]) $model = $model->where("{$alisa}{$fields}", '=', $whereData[$fields]);
if (isset($whereData[$fields]) && $whereData[$fields]){
if(is_array($whereData[$fields])){
$model = $model->where("{$alisa}{$fields}", $whereData[$fields][0], $whereData[$fields][1]);
}else{
$model = $model->where("{$alisa}{$fields}", '=', $whereData[$fields]);
}
}
}
if (isset($whereData['status'])) $model = $model->where("{$alisa}status", 'in', $whereData['status']);
if (isset($whereData['not_status'])) $model = $model->where("{$alisa}status", 'not in', $whereData['not_status']);
if (isset($whereData['keywords'])&&$whereData['keywords']) $model = $model->where("{$alisa}id|{$alisa}title|{$alisa}desc", '=', $whereData['keywords']);
if (isset($whereData['time'])&&$whereData['time']){
$model = $model->time($whereData['time']);
}
if (isset($whereData['user_id']) && $whereData['user_id']) $model = $model->where("{$alisa}to_id", '=', $whereData['user_id']);
if (isset($whereData['platform']) && $whereData['platform']){
$platforms = implode("|",explode(',',$whereData['platform']));
$model = $model->whereRaw(" {$alisa}platform REGEXP '({$platforms})'");
// $model = $model->where("{$alisa}platform", 'in', $whereData['platform']);
}
if (isset($whereData['oper_type']) && $whereData['oper_type']) $model = $model->where("{$alisa}oper_type", 'in', $whereData['oper_type']);
if (isset($whereData['to_type']) && $whereData['to_type']) $model = $model->where("{$alisa}to_type", 'in', $whereData['to_type']);
if (isset($whereData['mini_type']) && $whereData['mini_type']) $model = $model->where("{$alisa}mini_type", 'in', $whereData['mini_type']);
if (isset($whereData['to_id']) && $whereData['to_id']){
$model = $model->where(function ($query) use($whereData,$alisa) {
$query->where("{$alisa}to_id", $whereData['to_id'])
->whereOr("{$alisa}to_id", '=', 0);
});
}
return $model;
}
public static function baseCount($where = []){
$where["type"] = '1';
$where["platform"]= 'user';
$unread_number = self::getBaseWhere($where)->count();
$unread_system_number = self::getBaseWhere(array_merge(['status'=>'system'],$where))->count();
$unread_classes_number = self::getBaseWhere(array_merge(['status'=>'classes'],$where))->count();
$unread_order_number = self::getBaseWhere(array_merge(['status'=>'order'],$where))->count();
return compact('unread_number','unread_system_number','unread_classes_number','unread_order_number');
}
/**订单数量统计
* @param int $user_id
* @return array
*/
public static function messageCount($user_id = 0){
return self::baseCount(['user_id'=>$user_id]);
}
public static function messageList($page, $limit,$to_id,$keywords,$status,$mini_type,$type){
$with_field = [
'user'=>['nickname','mobile','avatar','realname'],
'base'=>['*'],
// 'shop'=>['*'],
// 'detail'=>['*'],
];
$alisa = (new self)->getWithAlisaName();
$sort = "field({$alisa}.type,'1','2') asc,{$alisa}.weigh desc,{$alisa}.id desc";
$serch_where = ["to_id"=>$to_id,'platform'=>"user",'status'=>$status,'keywords'=>$keywords,"mini_type"=>$mini_type,"type"=>$type];
// if($type)$serch_where['type'] = $type;
return (new self)->getBaseList($serch_where, $page, $limit,$sort,$with_field);
}
}