<?php
-
+/**
+ * @file include/tags.php
+ */
use Friendica\App;
+use Friendica\Content\Feature;
use Friendica\Core\System;
use Friendica\Database\DBM;
-use Friendica\Object\Contact;
+use Friendica\Model\Contact;
function create_tags_from_item($itemid) {
$profile_base = System::baseUrl();
/**
* @brief Get alphabetical sorted array of used tags/terms of an user including
* a weighting by frequency of use.
- *
+ *
* @param int $uid The user ID.
* @param int $count Max number of displayed tags/terms.
* @param int $owner_id The contact id of the owner of the tagged items.
* @param string $flags Special item flags.
* @param int $type The tag/term type.
- *
+ *
* @return arr Alphabetical sorted array of used tags of an user.
*/
function tagadelic($uid, $count = 0, $owner_id = 0, $flags = '', $type = TERM_HASHTAG) {
$item_condition = item_condition();
$sql_options = item_permissions_sql($uid);
- $count = intval($count);
+ $limit = $count ? sprintf("LIMIT %d", intval($count)) : "";
+
if ($flags) {
if ($flags === 'wall') {
$sql_options .= " AND `item`.`wall` ";
}
// Fetch tags
- $r = q("SELECT `term`, COUNT(`term`) AS `total` FROM `term`
+ $r = dba::p("SELECT `term`, COUNT(`term`) AS `total` FROM `term`
LEFT JOIN `item` ON `term`.`oid` = `item`.`id`
- WHERE `term`.`uid` = %d AND `term`.`type` = %d
- AND `term`.`otype` = %d
+ WHERE `term`.`uid` = ? AND `term`.`type` = ?
+ AND `term`.`otype` = ?
AND $item_condition $sql_options
- GROUP BY `term` ORDER BY `total` DESC %s",
- intval($uid),
- intval($type),
- intval(TERM_OBJ_POST),
- ((intval($count)) ? "LIMIT $count" : '')
+ GROUP BY `term` ORDER BY `total` DESC $limit",
+ $uid,
+ $type,
+ TERM_OBJ_POST
);
if(!DBM::is_result($r)) {
return array();
}
-
+
return tag_calc($r);
}
/**
* @brief Construct a tag/term cloud block for an user.
- *
+ *
* @param int $uid The user ID.
* @param int $count Max number of displayed tags/terms.
* @param int $owner_id The contact ID of the owner of the tagged items.
* @param string $flags Special item flags.
* @param int $type The tag/term type.
- *
+ *
* @return string HTML formatted output.
*/
function wtagblock($uid, $count = 0,$owner_id = 0, $flags = '', $type = TERM_HASHTAG) {
/**
* @brief Calculate weighting of tags according to the frequency of use.
- *
+ *
* @param array $arr Array of tags/terms with tag/term name and total count of use.
* @return array Alphabetical sorted array of used tags/terms of an user.
*/
/**
* @brief Compare function to sort tags/terms alphabetically.
- *
+ *
* @param type $a
* @param type $b
- *
+ *
* @return int
*/
function tags_sort($a, $b) {
/**
* @brief Insert a tag cloud widget for the present profile.
- *
+ *
* @param int $limit Max number of displayed tags.
* @return string HTML formattat output.
*/
return "";
}
- if(feature_enabled($a->profile['profile_uid'], 'tagadelic')) {
+ if(Feature::isEnabled($a->profile['profile_uid'], 'tagadelic')) {
$owner_id = Contact::getIdForURL($a->profile['url']);
if(!$owner_id) {