* Date: 2019-7-30
*/
namespace app\home\logic;
use think\Model;
use think\Db;
use app\home\model\Ask;
/**
* 逻辑定义
* Class CatsLogic
* @package plugins\Logic
*/
class AskLogic extends Model
{
/**
* 初始化操作
*/
public function _initialize() {
parent::_initialize();
}
// 查询条件处理
public function GetAskWhere($param = [], $parent_id = null)
{
// 查询条件
$where = [
// 0未解决,1已解决
'a.status' => ['IN',[0, 1]],
// 问题是否审核,1是,0否
'a.is_review' => 1,
'a.is_del' => 0,
'SearchName' => null,
];
// 创始人可以看到所有数据,包括未审核问题
if (0 === $parent_id) unset($where['a.is_review']);
// 查询指定栏目分类下的问题
if (!empty($param['type_id'])) $where['a.type_id'] = $param['type_id'];
// 不为空则表示查询--悬赏--待回答问题
if (!empty($param['is_recom']) && 3 == intval($param['is_recom'])) $where['a.money'] = ['>',0];
// 不为空则表示查询待回答问题
if (!empty($param['is_recom']) && 2 == intval($param['is_recom'])) $where['a.replies'] = 0;
// 推荐问题
if (!empty($param['is_recom']) && 1 == intval($param['is_recom'])) $where['a.is_recom'] = 1;
// 搜索问题
if (!empty($param['search_name'])) {
$where['a.ask_title'] = ['LIKE', "%{$param['search_name']}%"];
$where['SearchName'] = $param['search_name'];
}
return $where;
}
// Url处理
public function GetUrlData($param = [], $SpecifyUrl = null)
{
if (empty($param['ask_id'])) $param['ask_id'] = 0;
$result = [];
// 最新问题url
$result['NewDateUrl'] = askurl('home/Ask/index');
// 问题详情页url
$result['AskDetailsUrl'] = askurl('home/Ask/details', ['ask_id'=>$param['ask_id']]);
// 推荐问题url
$result['RecomDateUrl'] = askurl('home/Ask/index', ['type_id'=>0, 'is_recom'=>1]);
// 等待回答url
$result['PendingAnswerUrl'] = askurl('home/Ask/index', ['type_id'=>0, 'is_recom'=>2]);
// 悬赏问题列表url
$result['RewardUrl'] = askurl('home/Ask/index', ['type_id'=>0, 'is_recom'=>3]);
// 提交回答url
$result['AddAnswerUrl'] = askurl('home/Ask/ajax_add_answer', ['ask_id'=>$param['ask_id'], '_ajax'=>1], true, false, 1, 1, 0);
// 删除整个问题数据(包扣提问、回答、评论、回复)url
$result['DelAskUrl'] = askurl('home/Ask/ajax_del_ask', ['ask_id'=>$param['ask_id'], '_ajax'=>1], true, false, 1, 1, 0);
// 删除整个回答数据(包扣回答、评论、回复)url
$result['DelAnswerUrl'] = askurl('home/Ask/ajax_del_answer', ['ask_id'=>$param['ask_id'], '_ajax'=>1], true, false, 1, 1, 0);
// 删除回答url
$result['DelCommentUrl'] = askurl('home/Ask/ajax_del_comment', ['ask_id'=>$param['ask_id'], '_ajax'=>1], true, false, 1, 1, 0);
// 点赞回答url
$result['ClickLikeUrl'] = askurl('home/Ask/ajax_click_like', ['_ajax'=>1], true, false, 1, 1, 0);
// 发布问题url
$result['AddAskUrl'] = askurl('home/Ask/add_ask');
// 提交发布问题url
$result['SubmitAddAsk'] = askurl('home/Ask/add_ask', ['_ajax'=>1], true, false, 1, 1, 0);
// 编辑问题url
$result['EditAskUrl'] = askurl('home/Ask/edit_ask', ['ask_id'=>$param['ask_id']]);
// 提交编辑问题url
$result['SubmitEditAsk'] = askurl('home/Ask/edit_ask', ['_ajax'=>1], true, false, 1, 1, 0);
// 用户问题首页
$result['UsersIndexUrl'] = askurl('home/Ask/ask_index');
// 编辑回答url
$result['EditAnswer'] = askurl('home/Ask/ajax_edit_answer');
if ('ajax_edit_answer' == request()->action()) {
$result['EditAnswer'] = askurl('home/Ask/ajax_edit_answer', ['_ajax'=>1], true, false, 1, 1, 0);
}
// 采纳最佳答案url
$result['BestAnswerUrl'] = askurl('home/Ask/ajax_best_answer', ['ask_id'=>$param['ask_id'], '_ajax'=>1], true, false, 1, 1, 0);
// 获取指定数量的评论数据(分页)
$result['ShowCommentUrl'] = askurl('home/Ask/ajax_show_comment', ['ask_id'=>$param['ask_id'], '_ajax'=>1], true, false, 1, 1, 0);
// 创始人审核评论URL(前台)
$result['ReviewCommentUrl'] = askurl('home/Ask/ajax_review_comment', ['ask_id'=>$param['ask_id'], '_ajax'=>1], true, false, 1, 1, 0);
// 创始人审核问题URL(前台)
$result['ReviewAskUrl'] = askurl('home/Ask/ajax_review_ask', ['_ajax'=>1], true, false, 1, 1, 0);
// 按点赞量排序url
$result['AnswerLikeNum'] = askurl('home/Ask/details', ['ask_id' => $param['ask_id']], true, false, 1, 1, 0);
// 等待回答url
if (!empty($param['type_id'])) {
$result['PendingAnswerUrl'] = askurl('home/Ask/index', ['type_id'=>$param['type_id'], 'is_recom'=>2]);
}
if (!empty($SpecifyUrl)) {
if (!empty($result[$SpecifyUrl])) {
return $result[$SpecifyUrl];
}else{
return $result['NewDateUrl'];
}
}else{
return $result;
}
}
// 关键词标红
public function GetRedKeyWord($SearchName, $ask_title)
{
$ks = explode(' ',$SearchName);
foreach($ks as $k){
$k = trim($k);
if($k == '') continue;
if(ord($k[0]) > 0x80 && strlen($k) < 1) continue;
$ask_title = str_replace($k, "$k", $ask_title);
}
return $ask_title;
}
// 内容转义处理
public function ContentDealWith($param = null)
{
if (!empty($param['content'])) {
$content = $param['content'];
}else if(!empty($param['ask_content'])){
$content = $param['ask_content'];
}else{
return false;
}
// 斜杆转义
$content = addslashes($content);
// 过滤内容的style属性
$content = preg_replace('/style(\s*)=(\s*)[\'|\"](.*?)[\'|\"]/i', '', $content);
// 过滤内容的class属性
$content = preg_replace('/class(\s*)=(\s*)[\'|\"](.*?)[\'|\"]/i', '', $content);
return $content;
}
// 栏目分类格式化输出
public function GetTypeHtmlCode($PidData = [], $TidData = [], $type_id = null)
{
// 下拉框拼装
$HtmlCode = '';
return $HtmlCode;
}
// 拼装html代码
public function GetReplyHtml($data = [])
{
$ReplyHtml = '';
// 如果是需要审核的评论则返回空
if (empty($data['is_review'])) return $ReplyHtml;
/*拼装html代码*/
// 友好显示时间
$data['add_time'] = friend_date($data['add_time']);
// 处理内容格式
$data['content'] = htmlspecialchars_decode($data['content']);
if (!empty($data['at_users_id'])) {
$data['content'] = '回复 @'.$data['at_usersname'].': '.$data['content'];
}
// 删除评论回答URL
$DelCommentUrl = $this->GetUrlData($data, 'DelCommentUrl');
// 提交评论回复URL
$AddAnswerUrl = $this->GetUrlData($data, 'AddAnswerUrl');
// 提交点赞URL
$ClickLikeUrl = $this->GetUrlData($data, 'ClickLikeUrl');
// 拼装html
$ReplyHtml = <<