where($where)->count(); } /** * 列表 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-09-29 * @desc description * @param [array] $params [输入参数] */ public static function AnswerList($params = []) { $where = empty($params['where']) ? [] : $params['where']; $field = empty($params['field']) ? '*' : $params['field']; $order_by = empty($params['order_by']) ? 'id desc' : $params['order_by']; $m = isset($params['m']) ? intval($params['m']) : 0; $n = isset($params['n']) ? intval($params['n']) : 10; // 获取数据列表 $data = Db::name('Answer')->field($field)->where($where)->limit($m, $n)->order($order_by)->select()->toArray(); return DataReturn(MyLang('handle_success'), 0, self::AnswerListHandle($data, $params)); } /** * 列表数据处理 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2022-08-01 * @desc description * @param [array] $data [数据列表] * @param [array] $params [输入参数] */ public static function AnswerListHandle($data, $params = []) { if(!empty($data)) { // 用户默认头像 $default_avatar = SystemBaseService::AttachmentHost().'/static/index/'.strtolower(MyFileConfig('common_default_theme', '', 'default', true)).'/images/default-user-avatar.jpg'; foreach($data as &$v) { // 用户信息 if(isset($v['user_id'])) { $user = UserService::GetUserViewInfo($v['user_id']); if(!isset($params['is_public']) || $params['is_public'] == 1) { $v['user'] = [ 'avatar' => empty($user['avatar']) ? $default_avatar : $user['avatar'], 'user_name_view' => empty($user['user_name_view']) ? '网友' : $user['user_name_view'], ]; } else { $v['user'] = $user; } } // 内容 if(!empty($v['content']) && APPLICATION == 'web') { $v['content'] = str_replace("\n", '
', $v['content']); } // 回复内容 if(!empty($v['reply']) && APPLICATION == 'web') { $v['reply'] = str_replace("\n", '
', $v['reply']); } // 回复时间 if(isset($v['reply_time'])) { $v['reply_time_time'] = empty($v['reply_time']) ? null : date('Y-m-d H:i:s', $v['reply_time']); $v['reply_time_date'] = empty($v['reply_time']) ? null : date('Y-m-d', $v['reply_time']); } // 添加时间 if(isset($v['add_time'])) { $v['add_time_time'] = date('Y-m-d H:i:s', $v['add_time']); $v['add_time_date'] = date('Y-m-d', $v['add_time']); } // 更新时间 if(isset($v['upd_time'])) { $v['upd_time_time'] = empty($v['upd_time']) ? null : date('Y-m-d H:i:s', $v['upd_time']); $v['upd_time_date'] = empty($v['upd_time']) ? null : date('Y-m-d', $v['upd_time']); } } } return $data; } /** * 列表条件 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-09-29 * @desc description * @param [array] $params [输入参数] */ public static function AnswerListWhere($params = []) { $where = []; // id if(!empty($params['id'])) { $where[] = ['id', '=', $params['id']]; } // 用户id if(!empty($params['user'])) { $where[] = ['user_id', '=', $params['user']['id']]; } if(!empty($params['keywords'])) { $where[] = ['name|tel|title|content', 'like', '%'.$params['keywords'].'%']; } // 是否更多条件 if(isset($params['is_more']) && $params['is_more'] == 1) { // 等值 if(isset($params['is_show']) && $params['is_show'] > -1) { $where[] = ['is_show', '=', intval($params['is_show'])]; } if(isset($params['is_reply']) && $params['is_reply']> -1) { $where[] = ['is_reply', '=', intval($params['is_reply'])]; } if(!empty($params['time_start'])) { $where[] = ['add_time', '>', strtotime($params['time_start'])]; } if(!empty($params['time_end'])) { $where[] = ['add_time', '<', strtotime($params['time_end'])]; } } return $where; } /** * 用户留言保存 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-07-17 * @desc description * @param [array] $params [输入参数] */ public static function AnswerSave($params = []) { // 是否开启登录留言,管理员登录状态可继续操作 $admin = AdminService::LoginInfo(); if(MyC('common_is_login_answer') == 1 && empty($admin)) { $user = UserService::LoginUserInfo(); if(empty($user)) { return DataReturn('请先登录', -400); } } // 参数校验 $p = [ [ 'checked_type' => 'length', 'key_name' => 'name', 'checked_data' => '30', 'is_checked' => 1, 'error_msg' => '联系人最多30个字符', ], [ 'checked_type' => 'isset', 'key_name' => 'tel', 'error_msg' => '请填写有效的电话', ], [ 'checked_type' => 'length', 'key_name' => 'title', 'checked_data' => '60', 'is_checked' => 1, 'error_msg' => '标题最多60个字符', ], [ 'checked_type' => 'empty', 'key_name' => 'content', 'error_msg' => '详细内容不能为空', ], [ 'checked_type' => 'length', 'key_name' => 'content', 'checked_data' => '1000', 'error_msg' => '详细内容格式 2~1000 个字符', ], ]; $ret = ParamsChecked($params, $p); if($ret !== true) { return DataReturn($ret, -1); } // 开始操作 $data = [ 'user_id' => isset($params['user']['id']) ? intval($params['user']['id']) : (isset($params['user_id']) ? intval($params['user_id']) : 0), 'name' => isset($params['name']) ? $params['name'] : '', 'tel' => isset($params['tel']) ? $params['tel'] : '', 'title' => isset($params['title']) ? $params['title'] : '', 'content' => $params['content'], 'reply' => isset($params['reply']) ? $params['reply'] : '', 'access_count' => isset($params['access_count']) ? intval($params['access_count']) : 0, 'is_reply' => isset($params['is_reply']) ? intval($params['is_reply']) : 0, 'is_show' => isset($params['is_show']) ? intval($params['is_show']) : 0, 'add_time' => time(), ]; // 回复时间 $data['reply_time'] = (isset($data['is_reply']) && $data['is_reply'] == 1) ? time() : 0; // 不存在添加,则更新 if(empty($params['id'])) { $data['add_time'] = time(); if(Db::name('Answer')->insertGetId($data) > 0) { return DataReturn('提交成功', 0); } return DataReturn('提交失败', -100); } else { $data['upd_time'] = time(); if(Db::name('Answer')->where(['id'=>intval($params['id'])])->update($data)) { return DataReturn(MyLang('edit_success'), 0); } return DataReturn(MyLang('edit_fail'), -100); } } /** * 删除 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-09-30 * @desc description * @param [array] $params [输入参数] */ public static function AnswerDelete($params = []) { // 请求参数 $p = [ [ 'checked_type' => 'empty', 'key_name' => 'ids', 'error_msg' => '操作id有误', ], [ 'checked_type' => 'empty', 'key_name' => 'user_type', 'error_msg' => '用户类型有误', ], ]; $ret = ParamsChecked($params, $p); if($ret !== true) { return DataReturn($ret, -1); } // 是否数组 if(!is_array($params['ids'])) { $params['ids'] = explode(',', $params['ids']); } // 条件 $where = [ 'id' => $params['ids'], ]; // 用户类型 if($params['user_type'] == 'user') { if(empty($params['user'])) { return DataReturn('用户信息有误', -1); } $where['user_id'] = $params['user']['id']; } // 开始删除 if(Db::name('Answer')->where($where)->delete()) { return DataReturn(MyLang('delete_success'), 0); } return DataReturn(MyLang('delete_fail'), -1); } /** * 回复 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-12-18 * @desc description * @param [array] $params [输入参数] */ public static function AnswerReply($params = []) { // 请求参数 $p = [ [ 'checked_type' => 'empty', 'key_name' => 'id', 'error_msg' => '操作id有误', ], [ 'checked_type' => 'empty', 'key_name' => 'reply', 'error_msg' => '回复内容不能为空', ], [ 'checked_type' => 'length', 'key_name' => 'reply', 'checked_data' => '1000', 'error_msg' => '回复内容格式最多1000个字符', ], ]; $ret = ParamsChecked($params, $p); if($ret !== true) { return DataReturn($ret, -1); } // 条件 $where = [ 'id' => intval($params['id']), ]; // 问答是否存在 $temp = Db::name('Answer')->where($where)->field('id')->find(); if(empty($temp)) { return DataReturn('资源不存在或已被删除', -2); } // 更新问答 $data = [ 'reply' => $params['reply'], 'is_reply' => 1, 'reply_time' => time(), 'upd_time' => time() ]; if(Db::name('Answer')->where($where)->update($data)) { return DataReturn(MyLang('operate_success'), 0); } return DataReturn(MyLang('operate_fail'), -100); } /** * 状态更新 * @author Devil * @blog http://gong.gg/ * @version 0.0.1 * @datetime 2016-12-06T21:31:53+0800 * @param [array] $params [输入参数] */ public static function AnswerStatusUpdate($params = []) { // 请求参数 $p = [ [ 'checked_type' => 'empty', 'key_name' => 'id', 'error_msg' => '操作id有误', ], [ 'checked_type' => 'empty', 'key_name' => 'field', 'error_msg' => '字段有误', ], [ 'checked_type' => 'in', 'key_name' => 'state', 'checked_data' => [0,1], 'error_msg' => '状态有误', ], ]; $ret = ParamsChecked($params, $p); if($ret !== true) { return DataReturn($ret, -1); } // 数据更新 if(Db::name('Answer')->where(['id'=>intval($params['id'])])->update([$params['field']=>intval($params['state']), 'upd_time'=>time()])) { return DataReturn(MyLang('edit_success'), 0); } return DataReturn(MyLang('edit_fail'), -100); } /** * 访问统计加1 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-10-15 * @desc description * @param [array] $params [输入参数] */ public static function AnswerAccessCountInc($params = []) { if(!empty($params['answer_id'])) { return Db::name('Answer')->where(['id'=>intval($params['answer_id'])])->inc('access_count')->update(); } return false; } } ?>