X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=src%2FContent%2FWidget.php;h=397a1863d339efadf86d739acc6ea95e3d6f3e95;hb=d50a1edef468b9e3de456cb7c4570da5272b0cd8;hp=3c8131f45cad614c528f979b2467cbcd0e0ed672;hpb=46bf82eeb793b016d40d040d8fa5e9745810a88f;p=friendica.git diff --git a/src/Content/Widget.php b/src/Content/Widget.php index 3c8131f45c..397a1863d3 100644 --- a/src/Content/Widget.php +++ b/src/Content/Widget.php @@ -6,16 +6,22 @@ namespace Friendica\Content; use Friendica\Content\ContactSelector; use Friendica\Content\Feature; +use Friendica\Core\Addon; use Friendica\Core\Config; +use Friendica\Core\L10n; use Friendica\Core\PConfig; +use Friendica\Core\Protocol; +use Friendica\Core\Renderer; use Friendica\Core\System; -use Friendica\Database\DBM; +use Friendica\Database\DBA; +use Friendica\Model\Contact; +use Friendica\Model\FileTag; use Friendica\Model\GContact; use Friendica\Model\Profile; - -use dba; +use Friendica\Util\XML; require_once 'boot.php'; +require_once 'include/dba.php'; class Widget { @@ -26,12 +32,12 @@ class Widget */ public static function follow($value = "") { - return replace_macros(get_markup_template('follow.tpl'), array( - '$connect' => t('Add New Contact'), - '$desc' => t('Enter address or web location'), - '$hint' => t('Example: bob@example.com, http://example.com/barbara'), + return Renderer::replaceMacros(Renderer::getMarkupTemplate('follow.tpl'), array( + '$connect' => L10n::t('Add New Contact'), + '$desc' => L10n::t('Enter address or web location'), + '$hint' => L10n::t('Example: bob@example.com, http://example.com/barbara'), '$value' => $value, - '$follow' => t('Connect') + '$follow' => L10n::t('Connect') )); } @@ -46,25 +52,30 @@ class Widget if (Config::get('system', 'invitation_only')) { $x = PConfig::get(local_user(), 'system', 'invites_remaining'); if ($x || is_site_admin()) { - $a->page['aside'] .= '' . $inv; + $a->page['aside'] .= ''; } } - return replace_macros(get_markup_template('peoplefind.tpl'), array( - '$findpeople' => t('Find People'), - '$desc' => t('Enter name or interest'), - '$label' => t('Connect/Follow'), - '$hint' => t('Examples: Robert Morgenstein, Fishing'), - '$findthem' => t('Find'), - '$suggest' => t('Friend Suggestions'), - '$similar' => t('Similar Interests'), - '$random' => t('Random Profile'), - '$inv' => t('Invite Friends'), - '$directory' => t('View Global Directory'), - '$global_dir' => $global_dir - )); + $nv = []; + $nv['findpeople'] = L10n::t('Find People'); + $nv['desc'] = L10n::t('Enter name or interest'); + $nv['label'] = L10n::t('Connect/Follow'); + $nv['hint'] = L10n::t('Examples: Robert Morgenstein, Fishing'); + $nv['findthem'] = L10n::t('Find'); + $nv['suggest'] = L10n::t('Friend Suggestions'); + $nv['similar'] = L10n::t('Similar Interests'); + $nv['random'] = L10n::t('Random Profile'); + $nv['inv'] = L10n::t('Invite Friends'); + $nv['directory'] = L10n::t('Global Directory'); + $nv['global_dir'] = $global_dir; + $nv['local_directory'] = L10n::t('Local Directory'); + + $aside = []; + $aside['$nv'] = $nv; + + return Renderer::replaceMacros(Renderer::getMarkupTemplate('peoplefind.tpl'), $aside); } /** @@ -72,38 +83,31 @@ class Widget */ public static function unavailableNetworks() { - $networks = array(); - - if (!plugin_enabled("appnet")) { - $networks[] = NETWORK_APPNET; - } - - if (!plugin_enabled("fbpost") && !plugin_enabled("facebook")) { - $networks[] = NETWORK_FACEBOOK; - } + // Always hide content from these networks + $networks = ['face', 'apdn']; - if (!plugin_enabled("statusnet")) { - $networks[] = NETWORK_STATUSNET; + if (!Addon::isEnabled("statusnet")) { + $networks[] = Protocol::STATUSNET; } - if (!plugin_enabled("pumpio")) { - $networks[] = NETWORK_PUMPIO; + if (!Addon::isEnabled("pumpio")) { + $networks[] = Protocol::PUMPIO; } - if (!plugin_enabled("twitter")) { - $networks[] = NETWORK_TWITTER; + if (!Addon::isEnabled("twitter")) { + $networks[] = Protocol::TWITTER; } if (Config::get("system", "ostatus_disabled")) { - $networks[] = NETWORK_OSTATUS; + $networks[] = Protocol::OSTATUS; } if (!Config::get("system", "diaspora_enabled")) { - $networks[] = NETWORK_DIASPORA; + $networks[] = Protocol::DIASPORA; } - if (!plugin_enabled("pnut")) { - $networks[] = NETWORK_PNUT; + if (!Addon::isEnabled("pnut")) { + $networks[] = Protocol::PNUT; } if (!sizeof($networks)) { @@ -135,28 +139,25 @@ class Widget $extra_sql = self::unavailableNetworks(); - $r = dba::p("SELECT DISTINCT(`network`) FROM `contact` WHERE `uid` = ? AND `network` != '' $extra_sql ORDER BY `network`", + $r = DBA::p("SELECT DISTINCT(`network`) FROM `contact` WHERE `uid` = ? AND `network` != '' $extra_sql ORDER BY `network`", local_user() ); $nets = array(); - while ($rr = dba::fetch($r)) { - /// @TODO If 'network' is not there, this triggers an E_NOTICE - if ($rr['network']) { - $nets[] = array('ref' => $rr['network'], 'name' => ContactSelector::networkToName($rr['network']), 'selected' => (($selected == $rr['network']) ? 'selected' : '' )); - } + while ($rr = DBA::fetch($r)) { + $nets[] = array('ref' => $rr['network'], 'name' => ContactSelector::networkToName($rr['network']), 'selected' => (($selected == $rr['network']) ? 'selected' : '' )); } - dba::close($r); + DBA::close($r); if (count($nets) < 2) { return ''; } - return replace_macros(get_markup_template('nets.tpl'), array( - '$title' => t('Networks'), + return Renderer::replaceMacros(Renderer::getMarkupTemplate('nets.tpl'), array( + '$title' => L10n::t('Networks'), '$desc' => '', '$sel_all' => (($selected == '') ? 'selected' : ''), - '$all' => t('All Networks'), + '$all' => L10n::t('All Networks'), '$nets' => $nets, '$base' => $baseurl, )); @@ -187,17 +188,18 @@ class Widget $terms = array(); $cnt = preg_match_all('/\[(.*?)\]/', $saved, $matches, PREG_SET_ORDER); if ($cnt) { - foreach ($matches as $mtch) { - $unescaped = xmlify(file_tag_decode($mtch[1])); + foreach ($matches as $mtch) + { + $unescaped = XML::escape(FileTag::decode($mtch[1])); $terms[] = array('name' => $unescaped, 'selected' => (($selected == $unescaped) ? 'selected' : '')); } } - return replace_macros(get_markup_template('fileas_widget.tpl'), array( - '$title' => t('Saved Folders'), + return Renderer::replaceMacros(Renderer::getMarkupTemplate('fileas_widget.tpl'), array( + '$title' => L10n::t('Saved Folders'), '$desc' => '', '$sel_all' => (($selected == '') ? 'selected' : ''), - '$all' => t('Everything'), + '$all' => L10n::t('Everything'), '$terms' => $terms, '$base' => $baseurl, )); @@ -228,16 +230,16 @@ class Widget if ($cnt) { foreach ($matches as $mtch) { - $unescaped = xmlify(file_tag_decode($mtch[1])); + $unescaped = XML::escape(FileTag::decode($mtch[1])); $terms[] = array('name' => $unescaped, 'selected' => (($selected == $unescaped) ? 'selected' : '')); } } - return replace_macros(get_markup_template('categories_widget.tpl'), array( - '$title' => t('Categories'), + return Renderer::replaceMacros(Renderer::getMarkupTemplate('categories_widget.tpl'), array( + '$title' => L10n::t('Categories'), '$desc' => '', '$sel_all' => (($selected == '') ? 'selected' : ''), - '$all' => t('Everything'), + '$all' => L10n::t('Everything'), '$terms' => $terms, '$base' => $baseurl, )); @@ -256,7 +258,7 @@ class Widget $cid = $zcid = 0; - if (is_array($_SESSION['remote'])) { + if (!empty($_SESSION['remote'])) { foreach ($_SESSION['remote'] as $visitor) { if ($visitor['uid'] == $profile_uid) { $cid = $visitor['cid']; @@ -267,13 +269,13 @@ class Widget if (!$cid) { if (Profile::getMyURL()) { - $contact = dba::selectFirst('contact', ['id'], + $contact = DBA::selectFirst('contact', ['id'], ['nurl' => normalise_link(Profile::getMyURL()), 'uid' => $profile_uid]); - if (DBM::is_result($contact)) { + if (DBA::isResult($contact)) { $cid = $contact['id']; } else { - $gcontact = dba::selectFirst('gcontact', ['id'], ['nurl' => normalise_link(Profile::getMyURL())]); - if (DBM::is_result($gcontact)) { + $gcontact = DBA::selectFirst('gcontact', ['id'], ['nurl' => normalise_link(Profile::getMyURL())]); + if (DBA::isResult($gcontact)) { $zcid = $gcontact['id']; } } @@ -300,14 +302,41 @@ class Widget $r = GContact::commonFriendsZcid($profile_uid, $zcid, 0, 5, true); } - return replace_macros(get_markup_template('remote_friends_common.tpl'), array( - '$desc' => tt("%d contact in common", "%d contacts in common", $t), + return Renderer::replaceMacros(Renderer::getMarkupTemplate('remote_friends_common.tpl'), array( + '$desc' => L10n::tt("%d contact in common", "%d contacts in common", $t), '$base' => System::baseUrl(), '$uid' => $profile_uid, '$cid' => (($cid) ? $cid : '0'), '$linkmore' => (($t > 5) ? 'true' : ''), - '$more' => t('show more'), + '$more' => L10n::t('show more'), '$items' => $r) ); } + + /** + * Insert a tag cloud widget for the present profile. + * + * @brief Insert a tag cloud widget for the present profile. + * @param int $limit Max number of displayed tags. + * @return string HTML formatted output. + */ + public static function tagCloud($limit = 50) + { + $a = get_app(); + + if (!$a->profile['profile_uid'] || !$a->profile['url']) { + return ''; + } + + if (Feature::isEnabled($a->profile['profile_uid'], 'tagadelic')) { + $owner_id = Contact::getIdForURL($a->profile['url'], 0, true); + + if (!$owner_id) { + return ''; + } + return Widget\TagCloud::getHTML($a->profile['profile_uid'], $limit, $owner_id, 'wall'); + } + + return ''; + } }