. /** * Personal tag cloud section * * @category Widget * @package GNUsocial * @author Evan Prodromou * @copyright 2009 StatusNet, Inc. * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ defined('GNUSOCIAL') || die(); /** * Group tag cloud section * * @category Widget * @package StatusNet * @author Evan Prodromou * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ */ class GroupTagCloudSection extends TagCloudSection { public $group = null; public function __construct($out = null, $group = null) { parent::__construct($out); $this->group = $group; } public function title() { // TRANS: Title for group tag cloud section. // TRANS: %s is a group name. return _('Tags'); } public function getTags() { $weightexpr = common_sql_weight('notice_tag.created', common_config('tag', 'dropoff')); // @fixme should we use the cutoff too? Doesn't help with indexing per-group. $names = $this->group->getAliases(); $names = array_merge(array($this->group->nickname), $names); // XXX This is dumb. $quoted = array(); foreach ($names as $name) { $quoted[] = "'$name'"; } $namestring = implode(',', $quoted); $limit = TAGS_PER_SECTION; $qry = 'SELECT notice_tag.tag, ' . $weightexpr . ' AS weight ' . 'FROM notice_tag INNER JOIN notice ' . 'ON notice_tag.notice_id = notice.id ' . 'INNER JOIN group_inbox ON group_inbox.notice_id = notice.id ' . 'WHERE group_inbox.group_id = %d ' . 'AND notice_tag.tag NOT IN (%s) '. 'GROUP BY notice_tag.tag ' . 'ORDER BY weight DESC LIMIT ' . $limit; $tag = Memcached_DataObject::cachedQuery( 'Notice_tag', sprintf($qry, $this->group->id, $namestring), 3600 ); return $tag; } }