X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FContent%2FContactSelector.php;h=64a2b5be9e4f4b92182a1f277a5408c88f27e6b2;hb=8e2910976f126ee7c728ba4716f317ac496f377b;hp=fcaafb898c5275a51bd35ce200517cfb82f0809b;hpb=11cf36105ccd359c9d21a006e13b3767712196b6;p=friendica.git diff --git a/src/Content/ContactSelector.php b/src/Content/ContactSelector.php index fcaafb898c..64a2b5be9e 100644 --- a/src/Content/ContactSelector.php +++ b/src/Content/ContactSelector.php @@ -4,41 +4,18 @@ */ namespace Friendica\Content; -use Friendica\Core\Addon; -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 @@ -51,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 = ['', t('Males'), t('Females'), t('Gay'), t('Lesbian'), t('No Preference'), t('Bisexual'), t('Autosexual'), t('Abstinent'), t('Virgin'), t('Deviant'), t('Fetish'), t('Oodles'), 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 = ['', t('Single'), t('Lonely'), t('Available'), t('Unavailable'), t('Has crush'), t('Infatuated'), t('Dating'), t('Unfaithful'), t('Sex Addict'), t('Friends'), t('Friends/Benefits'), t('Casual'), t('Engaged'), t('Married'), t('Imaginarily married'), t('Partners'), t('Cohabiting'), t('Common law'), t('Happy'), t('Not looking'), t('Swinger'), t('Betrayed'), t('Separated'), t('Unstable'), t('Divorced'), t('Imaginarily divorced'), t('Widowed'), t('Uncertain'), t('It\'s complicated'), t('Don\'t care'), 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 .= '';