* Add feed widget * add feed render * Add CommentPage widget * New theme (#1390) * 调整忽略目录 * add theme * fix theme scss build Co-authored-by: fen <f3nb0x@gmail.com> * s/is_writeable/is_writable/g * New upgrade method * merge new fixes from master * add pgsql ssl mode support (ref #1600) (#1623) * Feat/code refactor (#1626) * remove all magic methods, add type for class properties * refactor codes * fix all * refactor code * fix type * fix all * fix request is method * fix all * fix router * fix get page * fix 1.3.0 upgrade * [feat] support high resolution avatar * fix types in i18n component * Implement Ctrl+S or Command+S for save draft (#1628) * Implement Ctrl+S or Command+S for save draft * rename * add Typecho.savePost * fix upload file size * add new uploader * replace new uploader * fix textarea change * fix preview * refactor post edit * fix issue * fix page edit --------- Co-authored-by: joyqi <joyqi@segmentfault.com> Co-authored-by: joyqi <magike.net@gmail.com> * fix #1632 * Add svg to image types * Feat/tree pages (#1646) * add tree trait * finish category tree trait * support select fields * fix select fields * refactor admin trait * fix draft status * Add new contents type "revision" * minor refactor * add more tree view abstracts * add tree trait to pages * get ready for tree view pages * improve page edit * fix revision * fix slug * add router params delegate * fix params delegate * fix * fix * fix all * fix all * fix tree * fix page link * fix feed * fix page * fix permalink * fix permalink input * fix offset query * Support IDN (#1629) * Support IDN * use js * Optimize code * Optimize code * fix URL script * remove unnecessary use --------- Co-authored-by: joyqi <joyqi@segmentfault.com> * fix input element * fix #1651, close #1653 * Use json instead of serialize (#1624) * Use json instead of serialize * Fix Upgrade code * add tree trait * finish category tree trait * support select fields * fix select fields * refactor admin trait * fix draft status * Add new contents type "revision" * minor refactor * add more tree view abstracts * add tree trait to pages * get ready for tree view pages * improve page edit * fix revision * fix slug * add router params delegate * fix params delegate * fix * fix * fix all * fix all * fix tree * fix page link * fix feed * fix page * fix permalink * fix permalink input * fix offset query * Fix typo * remove proxy methods * remove unnecessary useage --------- Co-authored-by: joyqi <joyqi@segmentfault.com> Co-authored-by: joyqi <magike.net@gmail.com> * Fix Prevent XSS vulnerability in default theme (#1654) * Fix Prevent XSS vulnerability in default theme * Update var/Typecho/Db/Adapter/Pdo.php * fix the getter --------- Co-authored-by: joyqi <joyqi@segmentfault.com> * add throwCallback to widget response * fix: cut down fields when selecting recent posts * fix typo errors * fix typo errors * fix http client cookie * add throw finish * fix theme lang * fix default theme * fix query * add open graph and twitter card support add canonical link * fix canonical link meta * fix theme classic-22 * remove unnecessary scss file when packaging * init plugin signal * improve: remove feather-icon js file * fix: typo * improve: post detail layout * fix tags saving * improve: nav search * fix: theme screenshot * fix: theme page layout * remove php 7.2/7.3 env --------- Co-authored-by: fen <f3nb0x@gmail.com> Co-authored-by: Lu Fei <52o@qq52o.cn>
341 lines
10 KiB
PHP
341 lines
10 KiB
PHP
<?php
|
|
|
|
namespace Widget;
|
|
|
|
if (!defined('__TYPECHO_ROOT_DIR__')) {
|
|
exit;
|
|
}
|
|
|
|
/**
|
|
* 全局统计组件
|
|
*
|
|
* @property-read int $publishedPostsNum
|
|
* @property-read int $waitingPostsNum
|
|
* @property-read int $draftPostsNum
|
|
* @property-read int $myPublishedPostsNum
|
|
* @property-read int $myWaitingPostsNum
|
|
* @property-read int $myDraftPostsNum
|
|
* @property-read int $currentPublishedPostsNum
|
|
* @property-read int $currentWaitingPostsNum
|
|
* @property-read int $currentDraftPostsNum
|
|
* @property-read int $publishedPagesNum
|
|
* @property-read int $draftPagesNum
|
|
* @property-read int $publishedCommentsNum
|
|
* @property-read int $waitingCommentsNum
|
|
* @property-read int $spamCommentsNum
|
|
* @property-read int $myPublishedCommentsNum
|
|
* @property-read int $myWaitingCommentsNum
|
|
* @property-read int $mySpamCommentsNum
|
|
* @property-read int $currentCommentsNum
|
|
* @property-read int $currentPublishedCommentsNum
|
|
* @property-read int $currentWaitingCommentsNum
|
|
* @property-read int $currentSpamCommentsNum
|
|
* @property-read int $categoriesNum
|
|
* @property-read int $tagsNum
|
|
*/
|
|
class Stat extends Base
|
|
{
|
|
/**
|
|
* @param int $components
|
|
*/
|
|
protected function initComponents(int &$components)
|
|
{
|
|
$components = self::INIT_USER;
|
|
}
|
|
|
|
/**
|
|
* 获取已发布的文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___publishedPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'post')
|
|
->where('table.contents.status = ?', 'publish'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取待审核的文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___waitingPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ? OR table.contents.type = ?', 'post', 'post_draft')
|
|
->where('table.contents.status = ?', 'waiting'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取草稿文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___draftPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'post_draft'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户已发布的文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___myPublishedPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'post')
|
|
->where('table.contents.status = ?', 'publish')
|
|
->where('table.contents.authorId = ?', $this->user->uid))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户待审核文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___myWaitingPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ? OR table.contents.type = ?', 'post', 'post_draft')
|
|
->where('table.contents.status = ?', 'waiting')
|
|
->where('table.contents.authorId = ?', $this->user->uid))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户草稿文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___myDraftPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'post_draft')
|
|
->where('table.contents.authorId = ?', $this->user->uid))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户已发布的文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___currentPublishedPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'post')
|
|
->where('table.contents.status = ?', 'publish')
|
|
->where('table.contents.authorId = ?', $this->request->filter('int')->get('uid')))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户待审核文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___currentWaitingPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ? OR table.contents.type = ?', 'post', 'post_draft')
|
|
->where('table.contents.status = ?', 'waiting')
|
|
->where('table.contents.authorId = ?', $this->request->filter('int')->get('uid')))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户草稿文章数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___currentDraftPostsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'post_draft')
|
|
->where('table.contents.authorId = ?', $this->request->filter('int')->get('uid')))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取已发布页面数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___publishedPagesNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'page')
|
|
->where('table.contents.status = ?', 'publish'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取草稿页面数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___draftPagesNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(cid)' => 'num'])
|
|
->from('table.contents')
|
|
->where('table.contents.type = ?', 'page_draft'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前显示的评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___publishedCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'approved'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前待审核的评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___waitingCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'waiting'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前垃圾评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___spamCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'spam'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户显示的评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___myPublishedCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'approved')
|
|
->where('table.comments.ownerId = ?', $this->user->uid))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户待审核的评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___myWaitingCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'waiting')
|
|
->where('table.comments.ownerId = ?', $this->user->uid))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前用户垃圾评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___mySpamCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'spam')
|
|
->where('table.comments.ownerId = ?', $this->user->uid))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前文章的评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___currentCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.cid = ?', $this->request->filter('int')->get('cid')))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前文章显示的评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___currentPublishedCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'approved')
|
|
->where('table.comments.cid = ?', $this->request->filter('int')->get('cid')))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前文章待审核的评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___currentWaitingCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'waiting')
|
|
->where('table.comments.cid = ?', $this->request->filter('int')->get('cid')))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取当前文章垃圾评论数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___currentSpamCommentsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(coid)' => 'num'])
|
|
->from('table.comments')
|
|
->where('table.comments.status = ?', 'spam')
|
|
->where('table.comments.cid = ?', $this->request->filter('int')->get('cid')))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取分类数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___categoriesNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(mid)' => 'num'])
|
|
->from('table.metas')
|
|
->where('table.metas.type = ?', 'category'))->num;
|
|
}
|
|
|
|
/**
|
|
* 获取标签数目
|
|
*
|
|
* @return integer
|
|
*/
|
|
protected function ___tagsNum(): int
|
|
{
|
|
return $this->db->fetchObject($this->db->select(['COUNT(mid)' => 'num'])
|
|
->from('table.metas')
|
|
->where('table.metas.type = ?', 'tag'))->num;
|
|
}
|
|
}
|