X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FContent%2FContactSelector.php;h=64a2b5be9e4f4b92182a1f277a5408c88f27e6b2;hb=8e2910976f126ee7c728ba4716f317ac496f377b;hp=b5122da808854261786e6d9a94e24248e42e4028;hpb=07d306aa3736aa8a0b46109b15a6c637919c33b1;p=friendica.git diff --git a/src/Content/ContactSelector.php b/src/Content/ContactSelector.php index b5122da808..64a2b5be9e 100644 --- a/src/Content/ContactSelector.php +++ b/src/Content/ContactSelector.php @@ -4,42 +4,18 @@ */ namespace Friendica\Content; -use Friendica\Core\Addon; -use Friendica\Core\L10n; -use Friendica\Database\DBM; -use Friendica\Protocol\Diaspora; -use dba; +use Friendica\Core\Hook; +use Friendica\Core\Protocol; +use Friendica\Database\DBA; +use Friendica\DI; +use Friendica\Util\Network; +use Friendica\Util\Strings; /** - * @brief ContactSelector class + * ContactSelector class */ class ContactSelector { - /** - * @param string $current current - * @param string $foreign_net network - */ - public static function profileAssign($current, $foreign_net) - { - $o = ''; - - $disabled = (($foreign_net) ? ' disabled="true" ' : ''); - - $o .= "\r\n"; - return $o; - } - /** * @param string $current current * @param boolean $disabled optional, default false @@ -52,12 +28,12 @@ class ContactSelector $o .= ""; - foreach ($select as $selection) { - if ($selection !== 'NOTRANSLATION') { - $selected = (($selection == $current) ? ' selected="selected" ' : ''); - $o .= ""; + $nets = [ + Protocol::DFRN => 'friendica', + Protocol::OSTATUS => 'gnu-social', // There is no generic OStatus icon + Protocol::FEED => 'rss', + Protocol::MAIL => 'inbox', + 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; } } - $o .= ''; - return $o; + + 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 sexualPreference($current = "", $suffix = "") { $o = ''; - $select = ['', L10n::t('Males'), L10n::t('Females'), L10n::t('Gay'), L10n::t('Lesbian'), L10n::t('No Preference'), L10n::t('Bisexual'), L10n::t('Autosexual'), L10n::t('Abstinent'), L10n::t('Virgin'), L10n::t('Deviant'), L10n::t('Fetish'), L10n::t('Oodles'), L10n::t('Nonsexual')]; - - - Addon::callHooks('sexpref_selector', $select); - + $select = [ + '' => DI::l10n()->t('No answer'), + 'Males' => DI::l10n()->t('Males'), + 'Females' => DI::l10n()->t('Females'), + 'Gay' => DI::l10n()->t('Gay'), + 'Lesbian' => DI::l10n()->t('Lesbian'), + 'No Preference' => DI::l10n()->t('No Preference'), + 'Bisexual' => DI::l10n()->t('Bisexual'), + 'Autosexual' => DI::l10n()->t('Autosexual'), + 'Abstinent' => DI::l10n()->t('Abstinent'), + 'Virgin' => DI::l10n()->t('Virgin'), + 'Deviant' => DI::l10n()->t('Deviant'), + 'Fetish' => DI::l10n()->t('Fetish'), + 'Oodles' => DI::l10n()->t('Oodles'), + 'Nonsexual' => DI::l10n()->t('Nonsexual'), + ]; + + Hook::callAll('sexpref_selector', $select); + $o .= "'; return $o; } - + /** * @param string $current optional, default empty + * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException */ public static function maritalStatus($current = "") { $o = ''; - $select = ['', L10n::t('Single'), L10n::t('Lonely'), L10n::t('Available'), L10n::t('Unavailable'), L10n::t('Has crush'), L10n::t('Infatuated'), L10n::t('Dating'), L10n::t('Unfaithful'), L10n::t('Sex Addict'), L10n::t('Friends'), L10n::t('Friends/Benefits'), L10n::t('Casual'), L10n::t('Engaged'), L10n::t('Married'), L10n::t('Imaginarily married'), L10n::t('Partners'), L10n::t('Cohabiting'), L10n::t('Common law'), L10n::t('Happy'), L10n::t('Not looking'), L10n::t('Swinger'), L10n::t('Betrayed'), L10n::t('Separated'), L10n::t('Unstable'), L10n::t('Divorced'), L10n::t('Imaginarily divorced'), L10n::t('Widowed'), L10n::t('Uncertain'), L10n::t('It\'s complicated'), L10n::t('Don\'t care'), L10n::t('Ask me')]; - - Addon::callHooks('marital_selector', $select); - + $select = [ + '' => DI::l10n()->t('No answer'), + 'Single' => DI::l10n()->t('Single'), + 'Lonely' => DI::l10n()->t('Lonely'), + 'In a relation' => DI::l10n()->t('In a relation'), + 'Has crush' => DI::l10n()->t('Has crush'), + 'Infatuated' => DI::l10n()->t('Infatuated'), + 'Dating' => DI::l10n()->t('Dating'), + 'Unfaithful' => DI::l10n()->t('Unfaithful'), + 'Sex Addict' => DI::l10n()->t('Sex Addict'), + 'Friends' => DI::l10n()->t('Friends'), + 'Friends/Benefits' => DI::l10n()->t('Friends/Benefits'), + 'Casual' => DI::l10n()->t('Casual'), + 'Engaged' => DI::l10n()->t('Engaged'), + 'Married' => DI::l10n()->t('Married'), + 'Imaginarily married' => DI::l10n()->t('Imaginarily married'), + 'Partners' => DI::l10n()->t('Partners'), + 'Cohabiting' => DI::l10n()->t('Cohabiting'), + 'Common law' => DI::l10n()->t('Common law'), + 'Happy' => DI::l10n()->t('Happy'), + 'Not looking' => DI::l10n()->t('Not looking'), + 'Swinger' => DI::l10n()->t('Swinger'), + 'Betrayed' => DI::l10n()->t('Betrayed'), + 'Separated' => DI::l10n()->t('Separated'), + 'Unstable' => DI::l10n()->t('Unstable'), + 'Divorced' => DI::l10n()->t('Divorced'), + 'Imaginarily divorced' => DI::l10n()->t('Imaginarily divorced'), + 'Widowed' => DI::l10n()->t('Widowed'), + 'Uncertain' => DI::l10n()->t('Uncertain'), + 'It\'s complicated' => DI::l10n()->t('It\'s complicated'), + 'Don\'t care' => DI::l10n()->t('Don\'t care'), + 'Ask me' => DI::l10n()->t('Ask me'), + ]; + + Hook::callAll('marital_selector', $select); + $o .= '';