X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FContent%2FContactSelector.php;h=7a36ea8c681be56a7ad77e9755402e2d96f76fce;hb=b852e5842bffcc1df1e5ac5d356fd9f19b7af499;hp=86dd6f002d51f2dc69ee43c9d1e12798e8dde278;hpb=c44ca31aeca8040bf30c3ba53e1555b389ac1493;p=friendica.git diff --git a/src/Content/ContactSelector.php b/src/Content/ContactSelector.php index 86dd6f002d..7a36ea8c68 100644 --- a/src/Content/ContactSelector.php +++ b/src/Content/ContactSelector.php @@ -4,10 +4,9 @@ */ namespace Friendica\Content; -use Friendica\Core\Addon; +use Friendica\Core\Hook; use Friendica\Core\L10n; use Friendica\Core\Protocol; -use Friendica\Core\System; use Friendica\Database\DBA; use Friendica\Util\Network; use Friendica\Util\Strings; @@ -20,6 +19,8 @@ class ContactSelector /** * @param string $current current * @param string $foreign_net network + * @return string + * @throws \Exception */ public static function profileAssign($current, $foreign_net) { @@ -71,11 +72,46 @@ class ContactSelector } /** - * @param string $network network - * @param string $profile optional, default empty + * @param string $profile Profile URL + * @return string Server URL + * @throws \Friendica\Network\HTTPException\InternalServerErrorException + */ + private static function getServerURLForProfile($profile) + { + $server_url = ''; + + // Fetch the server url from the contact table + $contact = DBA::selectFirst('contact', ['baseurl'], ['uid' => 0, 'nurl' => Strings::normaliseLink($profile)]); + if (DBA::isResult($contact) && !empty($contact['baseurl'])) { + $server_url = Strings::normaliseLink($contact['baseurl']); + } + + if (empty($server_url)) { + // Fetch the server url from the gcontact table + $gcontact = DBA::selectFirst('gcontact', ['server_url'], ['nurl' => Strings::normaliseLink($profile)]); + if (!empty($gcontact) && !empty($gcontact['server_url'])) { + $server_url = Strings::normaliseLink($gcontact['server_url']); + } + } + + if (empty($server_url)) { + // Create the server url out of the profile url + $parts = parse_url($profile); + unset($parts['path']); + $server_url = Strings::normaliseLink(Network::unparseURL($parts)); + } + + return $server_url; + } + + /** + * @param string $network network of the contact + * @param string $profile optional, default empty + * @param string $protocol (Optional) Protocol that is used for the transmission * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException */ - public static function networkToName($network, $profile = "") + public static function networkToName($network, $profile = '', $protocol = '') { $nets = [ Protocol::DFRN => L10n::t('DFRN'), @@ -90,30 +126,22 @@ class ContactSelector Protocol::GPLUS => L10n::t('Google+'), Protocol::PUMPIO => L10n::t('pump.io'), Protocol::TWITTER => L10n::t('Twitter'), + Protocol::DISCOURSE => L10n::t('Discourse'), Protocol::DIASPORA2 => L10n::t('Diaspora Connector'), Protocol::STATUSNET => L10n::t('GNU Social Connector'), Protocol::ACTIVITYPUB => L10n::t('ActivityPub'), Protocol::PNUT => L10n::t('pnut'), ]; - Addon::callHooks('network_to_name', $nets); + Hook::callAll('network_to_name', $nets); $search = array_keys($nets); $replace = array_values($nets); $networkname = str_replace($search, $replace, $network); - if ((in_array($network, [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS])) && ($profile != "")) { - // Create the server url out of the profile url - $parts = parse_url($profile); - unset($parts['path']); - $server_url = [Strings::normaliseLink(Network::unparseURL($parts))]; - - // Fetch the server url - $gcontact = DBA::selectFirst('gcontact', ['server_url'], ['nurl' => Strings::normaliseLink($profile)]); - if (!empty($gcontact) && !empty($gcontact['server_url'])) { - $server_url[] = Strings::normaliseLink($gcontact['server_url']); - } + if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) { + $server_url = self::getServerURLForProfile($profile); // Now query the GServer for the platform name $gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['nurl' => $server_url]); @@ -135,18 +163,77 @@ class ContactSelector } } + if (!empty($protocol) && ($protocol != $network)) { + $networkname = L10n::t('%s (via %s)', $networkname, self::networkToName($protocol)); + } + return $networkname; } + /** + * @param string $network network + * @param string $profile optional, default empty + * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException + */ + public static function networkToIcon($network, $profile = "") + { + $nets = [ + Protocol::DFRN => 'friendica', + Protocol::OSTATUS => 'gnu-social', // There is no generic OStatus icon + Protocol::FEED => 'rss', + Protocol::MAIL => 'file-text-o', /// @todo + Protocol::DIASPORA => 'diaspora', + Protocol::ZOT => 'hubzilla', + Protocol::LINKEDIN => 'linkedin', + Protocol::XMPP => 'xmpp', + Protocol::MYSPACE => 'file-text-o', /// @todo + Protocol::GPLUS => 'google-plus', + Protocol::PUMPIO => 'file-text-o', /// @todo + Protocol::TWITTER => 'twitter', + Protocol::DISCOURSE => 'dot-circle-o', /// @todo + Protocol::DIASPORA2 => 'diaspora', + Protocol::STATUSNET => 'gnu-social', + Protocol::ACTIVITYPUB => 'activitypub', + Protocol::PNUT => 'file-text-o', /// @todo + ]; + + $platform_icons = ['diaspora' => 'diaspora', 'friendica' => 'friendica', 'friendika' => 'friendica', + 'GNU Social' => 'gnu-social', 'gnusocial' => 'gnu-social', 'hubzilla' => 'hubzilla', + 'mastodon' => 'mastodon', 'peertube' => 'peertube', 'pixelfed' => 'pixelfed', + 'pleroma' => 'pleroma', 'red' => 'hubzilla', 'redmatrix' => 'hubzilla', + 'socialhome' => 'social-home', 'wordpress' => 'wordpress']; + + $search = array_keys($nets); + $replace = array_values($nets); + + $network_icon = str_replace($search, $replace, $network); + + if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) { + $server_url = self::getServerURLForProfile($profile); + + // Now query the GServer for the platform name + $gserver = DBA::selectFirst('gserver', ['platform'], ['nurl' => $server_url]); + + if (DBA::isResult($gserver) && !empty($gserver['platform'])) { + $network_icon = $platform_icons[strtolower($gserver['platform'])] ?? $network_icon; + } + } + + return $network_icon; + } + /** * @param string $current optional, default empty * @param string $suffix optionsl, default empty + * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException */ public static function gender($current = "", $suffix = "") { $o = ''; $select = [ - 'EMPTY' => '', + '' => L10n::t('No answer'), 'Male' => L10n::t('Male'), 'Female' => L10n::t('Female'), 'Currently Male' => L10n::t('Currently Male'), @@ -163,12 +250,12 @@ class ContactSelector 'Undecided' => L10n::t('Undecided'), ]; - Addon::callHooks('gender_selector', $select); + Hook::callAll('gender_selector', $select); $o .= ""; foreach ($select as $neutral => $selection) { if ($selection !== 'NOTRANSLATION') { - $selected = (($selection == $current) ? ' selected="selected" ' : ''); + $selected = (($neutral == $current) ? ' selected="selected" ' : ''); $o .= ""; } } @@ -215,51 +304,52 @@ class ContactSelector /** * @param string $current optional, default empty + * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException */ public static function maritalStatus($current = "") { $o = ''; $select = [ - 'EMPTY' => '', - 'Single' => L10n::t('Single'), - 'Lonely' => L10n::t('Lonely'), - 'Available' => L10n::t('Available'), - 'Unavailable' => L10n::t('Unavailable'), - 'Has crush' => L10n::t('Has crush'), - 'Infatuated' => L10n::t('Infatuated'), - 'Dating' => L10n::t('Dating'), - 'Unfaithful' => L10n::t('Unfaithful'), - 'Sex Addict' => L10n::t('Sex Addict'), - 'Friends' => L10n::t('Friends'), - 'Friends/Benefits' => L10n::t('Friends/Benefits'), - 'Casual' => L10n::t('Casual'), - 'Engaged' => L10n::t('Engaged'), - 'Married' => L10n::t('Married'), - 'Imaginarily married' => L10n::t('Imaginarily married'), - 'Partners' => L10n::t('Partners'), - 'Cohabiting' => L10n::t('Cohabiting'), - 'Common law' => L10n::t('Common law'), - 'Happy' => L10n::t('Happy'), - 'Not looking' => L10n::t('Not looking'), - 'Swinger' => L10n::t('Swinger'), - 'Betrayed' => L10n::t('Betrayed'), - 'Separated' => L10n::t('Separated'), - 'Unstable' => L10n::t('Unstable'), - 'Divorced' => L10n::t('Divorced'), + '' => L10n::t('No answer'), + 'Single' => L10n::t('Single'), + 'Lonely' => L10n::t('Lonely'), + 'In a relation' => L10n::t('In a relation'), + 'Has crush' => L10n::t('Has crush'), + 'Infatuated' => L10n::t('Infatuated'), + 'Dating' => L10n::t('Dating'), + 'Unfaithful' => L10n::t('Unfaithful'), + 'Sex Addict' => L10n::t('Sex Addict'), + 'Friends' => L10n::t('Friends'), + 'Friends/Benefits' => L10n::t('Friends/Benefits'), + 'Casual' => L10n::t('Casual'), + 'Engaged' => L10n::t('Engaged'), + 'Married' => L10n::t('Married'), + 'Imaginarily married' => L10n::t('Imaginarily married'), + 'Partners' => L10n::t('Partners'), + 'Cohabiting' => L10n::t('Cohabiting'), + 'Common law' => L10n::t('Common law'), + 'Happy' => L10n::t('Happy'), + 'Not looking' => L10n::t('Not looking'), + 'Swinger' => L10n::t('Swinger'), + 'Betrayed' => L10n::t('Betrayed'), + 'Separated' => L10n::t('Separated'), + 'Unstable' => L10n::t('Unstable'), + 'Divorced' => L10n::t('Divorced'), 'Imaginarily divorced' => L10n::t('Imaginarily divorced'), - 'Widowed' => L10n::t('Widowed'), - 'Uncertain' => L10n::t('Uncertain'), - 'It\'s complicated' => L10n::t('It\'s complicated'), - 'Don\'t care' => L10n::t('Don\'t care'), - 'Ask me' => L10n::t('Ask me'), + 'Widowed' => L10n::t('Widowed'), + 'Uncertain' => L10n::t('Uncertain'), + 'It\'s complicated' => L10n::t('It\'s complicated'), + 'Don\'t care' => L10n::t('Don\'t care'), + 'Ask me' => L10n::t('Ask me'), ]; - Addon::callHooks('marital_selector', $select); + Hook::callAll('marital_selector', $select); $o .= '