]> git.mxchange.org Git - friendica.git/blobdiff - src/Content/ContactSelector.php
Move Photo module, update Photo model
[friendica.git] / src / Content / ContactSelector.php
index fcaafb898c5275a51bd35ce200517cfb82f0809b..6a5ee9112b8ad179246a31c4230284619fc1d8b7 100644 (file)
@@ -5,9 +5,12 @@
 namespace Friendica\Content;
 
 use Friendica\Core\Addon;
-use Friendica\Database\DBM;
-use Friendica\Protocol\Diaspora;
-use dba;
+use Friendica\Core\L10n;
+use Friendica\Core\Protocol;
+use Friendica\Core\System;
+use Friendica\Database\DBA;
+use Friendica\Util\Network;
+use Friendica\Util\Strings;
 
 /**
  * @brief ContactSelector class
@@ -26,10 +29,10 @@ class ContactSelector
 
                $o .= "<select id=\"contact-profile-selector\" class=\"form-control\" $disabled name=\"profile-assign\" >\r\n";
 
-               $s = dba::select('profile', ['id', 'profile-name', 'is-default'], ['uid' => $$_SESSION['uid']]);
-               $r = dba::inArray($s);
+               $s = DBA::select('profile', ['id', 'profile-name', 'is-default'], ['uid' => $_SESSION['uid']]);
+               $r = DBA::toArray($s);
 
-               if (DBM::is_result($r)) {
+               if (DBA::isResult($r)) {
                        foreach ($r as $rr) {
                                $selected = (($rr['id'] == $current || ($current == 0 && $rr['is-default'] == 1)) ? " selected=\"selected\" " : "");
                                $o .= "<option value=\"{$rr['id']}\" $selected >{$rr['profile-name']}</option>\r\n";
@@ -51,12 +54,12 @@ class ContactSelector
                $o .= "<select id=\"contact-poll-interval\" name=\"poll\" $dis />" . "\r\n";
 
                $rep = [
-                       0 => t('Frequently'),
-                       1 => t('Hourly'),
-                       2 => t('Twice daily'),
-                       3 => t('Daily'),
-                       4 => t('Weekly'),
-                       5 => t('Monthly')
+                       0 => L10n::t('Frequently'),
+                       1 => L10n::t('Hourly'),
+                       2 => L10n::t('Twice daily'),
+                       3 => L10n::t('Daily'),
+                       4 => L10n::t('Weekly'),
+                       5 => L10n::t('Monthly')
                ];
 
                foreach ($rep as $k => $v) {
@@ -68,30 +71,29 @@ class ContactSelector
        }
 
        /**
-        * @param string $s       network
+        * @param string $network network
         * @param string $profile optional, default empty
         * @return string
         */
-       public static function networkToName($s, $profile = "")
+       public static function networkToName($network, $profile = "")
        {
                $nets = [
-                       NETWORK_DFRN     => t('Friendica'),
-                       NETWORK_OSTATUS  => t('OStatus'),
-                       NETWORK_FEED     => t('RSS/Atom'),
-                       NETWORK_MAIL     => t('Email'),
-                       NETWORK_DIASPORA => t('Diaspora'),
-                       NETWORK_FACEBOOK => t('Facebook'),
-                       NETWORK_ZOT      => t('Zot!'),
-                       NETWORK_LINKEDIN => t('LinkedIn'),
-                       NETWORK_XMPP     => t('XMPP/IM'),
-                       NETWORK_MYSPACE  => t('MySpace'),
-                       NETWORK_GPLUS    => t('Google+'),
-                       NETWORK_PUMPIO   => t('pump.io'),
-                       NETWORK_TWITTER  => t('Twitter'),
-                       NETWORK_DIASPORA2 => t('Diaspora Connector'),
-                       NETWORK_STATUSNET => t('GNU Social Connector'),
-                       NETWORK_PNUT      => t('pnut'),
-                       NETWORK_APPNET => t('App.net')
+                       Protocol::DFRN      =>   L10n::t('DFRN'),
+                       Protocol::OSTATUS   =>   L10n::t('OStatus'),
+                       Protocol::FEED      =>   L10n::t('RSS/Atom'),
+                       Protocol::MAIL      =>   L10n::t('Email'),
+                       Protocol::DIASPORA  =>   L10n::t('Diaspora'),
+                       Protocol::ZOT       =>   L10n::t('Zot!'),
+                       Protocol::LINKEDIN  =>   L10n::t('LinkedIn'),
+                       Protocol::XMPP      =>   L10n::t('XMPP/IM'),
+                       Protocol::MYSPACE   =>   L10n::t('MySpace'),
+                       Protocol::GPLUS     =>   L10n::t('Google+'),
+                       Protocol::PUMPIO    =>   L10n::t('pump.io'),
+                       Protocol::TWITTER   =>   L10n::t('Twitter'),
+                       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);
@@ -99,15 +101,37 @@ class ContactSelector
                $search  = array_keys($nets);
                $replace = array_values($nets);
 
-               $networkname = str_replace($search, $replace, $s);
+               $networkname = str_replace($search, $replace, $network);
 
-               if ((in_array($s, [NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS])) && ($profile != "")) {
-                       $r = dba::fetch_first("SELECT `gserver`.`platform` FROM `gcontact`
-                                       INNER JOIN `gserver` ON `gserver`.`nurl` = `gcontact`.`server_url`
-                                       WHERE `gcontact`.`nurl` = ? AND `platform` != ''", normalise_link($profile));
+               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))];
 
-                       if (DBM::is_result($r)) {
-                               $networkname = $r['platform'];
+                       // 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']);
+                       }
+
+                       // Now query the GServer for the platform name
+                       $gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['nurl' => $server_url]);
+
+                       if (DBA::isResult($gserver)) {
+                               if (!empty($gserver['platform'])) {
+                                       $platform = $gserver['platform'];
+                               } elseif (!empty($gserver['network']) && ($gserver['network'] != Protocol::ACTIVITYPUB)) {
+                                       $platform = self::networkToName($gserver['network']);
+                               }
+
+                               if (!empty($platform)) {
+                                       $networkname = $platform;
+
+                                       if ($network == Protocol::ACTIVITYPUB) {
+                                               $networkname .= ' (AP)';
+                                       }
+                               }
                        }
                }
 
@@ -121,21 +145,37 @@ class ContactSelector
        public static function gender($current = "", $suffix = "")
        {
                $o = '';
-               $select = ['', t('Male'), t('Female'), t('Currently Male'), t('Currently Female'), t('Mostly Male'), t('Mostly Female'), t('Transgender'), t('Intersex'), t('Transsexual'), t('Hermaphrodite'), t('Neuter'), t('Non-specific'), t('Other'), t('Undecided')];
-       
+               $select = [
+                       'EMPTY'            => '',
+                       'Male'             => L10n::t('Male'),
+                       'Female'           => L10n::t('Female'),
+                       'Currently Male'   => L10n::t('Currently Male'),
+                       'Currently Female' => L10n::t('Currently Female'),
+                       'Mostly Male'      => L10n::t('Mostly Male'),
+                       'Mostly Female'    => L10n::t('Mostly Female'),
+                       'Transgender'      => L10n::t('Transgender'),
+                       'Intersex'         => L10n::t('Intersex'),
+                       'Transsexual'      => L10n::t('Transsexual'),
+                       'Hermaphrodite'    => L10n::t('Hermaphrodite'),
+                       'Neuter'           => L10n::t('Neuter'),
+                       'Non-specific'     => L10n::t('Non-specific'),
+                       'Other'            => L10n::t('Other'),
+                       'Undecided'        => L10n::t('Undecided'),
+               ];
+
                Addon::callHooks('gender_selector', $select);
-       
+
                $o .= "<select name=\"gender$suffix\" id=\"gender-select$suffix\" size=\"1\" >";
-               foreach ($select as $selection) {
+               foreach ($select as $neutral => $selection) {
                        if ($selection !== 'NOTRANSLATION') {
-                               $selected = (($selection == $current) ? ' selected="selected" ' : '');
-                               $o .= "<option value=\"$selection\" $selected >$selection</option>";
+                               $selected = (($neutral == $current) ? ' selected="selected" ' : '');
+                               $o .= "<option value=\"$neutral\" $selected >$selection</option>";
                        }
                }
                $o .= '</select>';
                return $o;
        }
-       
+
        /**
         * @param string $current optional, default empty
         * @param string $suffix  optionsl, default empty
@@ -143,37 +183,84 @@ class ContactSelector
        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')];
-       
-       
+               $select = [
+                       'EMPTY'         => '',
+                       'Males'         => L10n::t('Males'),
+                       'Females'       => L10n::t('Females'),
+                       'Gay'           => L10n::t('Gay'),
+                       'Lesbian'       => L10n::t('Lesbian'),
+                       'No Preference' => L10n::t('No Preference'),
+                       'Bisexual'      => L10n::t('Bisexual'),
+                       'Autosexual'    => L10n::t('Autosexual'),
+                       'Abstinent'     => L10n::t('Abstinent'),
+                       'Virgin'        => L10n::t('Virgin'),
+                       'Deviant'       => L10n::t('Deviant'),
+                       'Fetish'        => L10n::t('Fetish'),
+                       'Oodles'        => L10n::t('Oodles'),
+                       'Nonsexual'     => L10n::t('Nonsexual'),
+               ];
+
                Addon::callHooks('sexpref_selector', $select);
-       
+
                $o .= "<select name=\"sexual$suffix\" id=\"sexual-select$suffix\" size=\"1\" >";
-               foreach ($select as $selection) {
+               foreach ($select as $neutral => $selection) {
                        if ($selection !== 'NOTRANSLATION') {
-                               $selected = (($selection == $current) ? ' selected="selected" ' : '');
-                               $o .= "<option value=\"$selection\" $selected >$selection</option>";
+                               $selected = (($neutral == $current) ? ' selected="selected" ' : '');
+                               $o .= "<option value=\"$neutral\" $selected >$selection</option>";
                        }
                }
                $o .= '</select>';
                return $o;
        }
-       
+
        /**
         * @param string $current optional, default empty
         */
        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')];
-       
+               $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'),
+                       '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'),
+               ];
+
                Addon::callHooks('marital_selector', $select);
-       
+
                $o .= '<select name="marital" id="marital-select" size="1" >';
-               foreach ($select as $selection) {
+               foreach ($select as $neutral => $selection) {
                        if ($selection !== 'NOTRANSLATION') {
-                               $selected = (($selection == $current) ? ' selected="selected" ' : '');
-                               $o .= "<option value=\"$selection\" $selected >$selection</option>";
+                               $selected = (($neutral == $current) ? ' selected="selected" ' : '');
+                               $o .= "<option value=\"$neutral\" $selected >$selection</option>";
                        }
                }
                $o .= '</select>';