X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fprofilelist.php;h=767e12bc25a7dbc2360bd65d1bddd270fd919989;hb=746e658f3e398948fe8c3f047e2b35ef6aa7ebd5;hp=3412d41d1c94b794b1a9251c2fd9e75d5eb326cc;hpb=12d3c44480465b494010f6f1e56d831cf3567f06;p=quix0rs-gnu-social.git diff --git a/lib/profilelist.php b/lib/profilelist.php index 3412d41d1c..767e12bc25 100644 --- a/lib/profilelist.php +++ b/lib/profilelist.php @@ -1,5 +1,4 @@ out->elementStart('ul', 'profiles xoxo'); + $this->out->elementStart('ul', 'profile_list xoxo'); } function endList() @@ -86,14 +84,13 @@ class ProfileList extends Widget function showProfiles() { - $cnt = 0; + $cnt = $this->profile->N; + $profiles = $this->profile->fetchAll(); - while ($this->profile->fetch()) { - $cnt++; - if($cnt > PROFILES_PER_PAGE) { - break; - } - $pli = $this->newListItem($this->profile); + $max = min($cnt, $this->maxProfiles()); + + for ($i = 0; $i < $max; $i++) { + $pli = $this->newListItem($profiles[$i]); $pli->show(); } @@ -102,7 +99,12 @@ class ProfileList extends Widget function newListItem($profile) { - return new ProfileListItem($this->profile, $this->action); + return new ProfileListItem($profile, $this->action); + } + + function maxProfiles() + { + return PROFILES_PER_PAGE; } } @@ -140,7 +142,7 @@ class ProfileListItem extends Widget function startItem() { - $this->out->elementStart('li', array('class' => 'profile hentry', + $this->out->elementStart('li', array('class' => 'profile', 'id' => 'profile-' . $this->profile->id)); } @@ -149,9 +151,16 @@ class ProfileListItem extends Widget $this->startProfile(); if (Event::handle('StartProfileListItemProfileElements', array($this))) { if (Event::handle('StartProfileListItemAvatar', array($this))) { - $this->showAvatar(); + $aAttrs = $this->linkAttributes(); + $this->out->elementStart('a', $aAttrs); + $this->showAvatar($this->profile); + $this->out->elementEnd('a'); Event::handle('EndProfileListItemAvatar', array($this)); } + if (Event::handle('StartProfileListItemNickname', array($this))) { + $this->showNickname(); + Event::handle('EndProfileListItemNickname', array($this)); + } if (Event::handle('StartProfileListItemFullName', array($this))) { $this->showFullName(); Event::handle('EndProfileListItemFullName', array($this)); @@ -168,6 +177,10 @@ class ProfileListItem extends Widget $this->showBio(); Event::handle('EndProfileListItemBio', array($this)); } + if (Event::handle('StartProfileListItemTags', array($this))) { + $this->showTags(); + Event::handle('EndProfileListItemTags', array($this)); + } Event::handle('EndProfileListItemProfileElements', array($this)); } $this->endProfile(); @@ -175,52 +188,36 @@ class ProfileListItem extends Widget function startProfile() { - $this->out->elementStart('div', 'entity_profile vcard entry-content'); + $this->out->elementStart('div', 'entity_profile h-card'); } - function showAvatar() + function showNickname() { - $avatar = $this->profile->getAvatar(AVATAR_STREAM_SIZE); - $this->out->elementStart('a', array('href' => $this->profile->profileurl, - 'class' => 'url entry-title', - 'rel' => 'contact')); - $this->out->element('img', array('src' => ($avatar) ? $avatar->displayUrl() : Avatar::defaultImage(AVATAR_STREAM_SIZE), - 'class' => 'photo avatar', - 'width' => AVATAR_STREAM_SIZE, - 'height' => AVATAR_STREAM_SIZE, - 'alt' => - ($this->profile->fullname) ? $this->profile->fullname : - $this->profile->nickname)); - $hasFN = (!empty($this->profile->fullname)) ? 'nickname' : 'fn nickname'; - $this->out->elementStart('span', $hasFN); - $this->out->raw($this->highlight($this->profile->nickname)); - $this->out->elementEnd('span'); - $this->out->elementEnd('a'); + $this->out->element('a', array('href'=>$this->profile->getUrl(), + 'class'=>'p-nickname'), + $this->profile->getNickname()); } function showFullName() { if (!empty($this->profile->fullname)) { - $this->out->elementStart('span', 'fn'); - $this->out->raw($this->highlight($this->profile->fullname)); - $this->out->elementEnd('span'); + $this->out->element('span', 'p-name', $this->profile->fullname); } } function showLocation() { if (!empty($this->profile->location)) { - $this->out->elementStart('span', 'location'); - $this->out->raw($this->highlight($this->profile->location)); - $this->out->elementEnd('span'); + $this->out->element('span', 'label p-locality', $this->profile->location); } } function showHomepage() { if (!empty($this->profile->homepage)) { - $this->out->elementStart('a', array('href' => $this->profile->homepage, - 'class' => 'url')); + $this->out->text(' '); + $aAttrs = $this->homepageAttributes(); + $this->out->elementStart('a', $aAttrs); $this->out->raw($this->highlight($this->profile->homepage)); $this->out->elementEnd('a'); } @@ -235,6 +232,20 @@ class ProfileListItem extends Widget } } + function showTags() + { + $user = common_current_user(); + if (!empty($user)) { + if ($user->id == $this->profile->id) { + $tags = new SelftagsWidget($this->out, $user, $this->profile); + $tags->show(); + } else if ($user->getProfile()->canTag($this->profile)) { + $tags = new PeopletagsWidget($this->out, $user, $this->profile); + $tags->show(); + } + } + } + function endProfile() { $this->out->elementEnd('div'); @@ -269,12 +280,10 @@ class ProfileListItem extends Widget $usf = new UnsubscribeForm($this->out, $this->profile); $usf->show(); } else { - // Is it a local user? can't remote sub from a list - // XXX: make that possible! - $other = User::staticGet('id', $this->profile->id); - if (!empty($other)) { + if (Event::handle('StartShowProfileListSubscribeButton', array($this))) { $sf = new SubscribeForm($this->out, $this->profile); $sf->show(); + Event::handle('EndShowProfileListSubscribeButton', array($this)); } } $this->out->elementEnd('li'); @@ -296,4 +305,17 @@ class ProfileListItem extends Widget { return htmlspecialchars($text); } + + function linkAttributes() + { + return array('href' => $this->profile->profileurl, + 'class' => 'u-url', + 'rel' => 'contact'); + } + + function homepageAttributes() + { + return array('href' => $this->profile->homepage, + 'class' => 'u-url'); + } }