X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fprofilelist.php;h=767e12bc25a7dbc2360bd65d1bddd270fd919989;hb=483b2d3d29806ca40d4b22ab29962be55346107c;hp=af38fa71d9bc62f1fcf0ea3593579f4771a5ffe3;hpb=ad86eb78d3dc395b438d1543a36eca509f53e9d4;p=quix0rs-gnu-social.git diff --git a/lib/profilelist.php b/lib/profilelist.php index af38fa71d9..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() @@ -87,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(); } @@ -103,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; } } @@ -141,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)); } @@ -150,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)); @@ -180,46 +188,27 @@ 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); - $aAttrs = $this->linkAttributes(); - $this->out->elementStart('a', $aAttrs); - $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)); - $this->out->text(' '); - $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->text(' '); - $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->text(' '); - $this->out->elementStart('span', 'label'); - $this->out->raw($this->highlight($this->profile->location)); - $this->out->elementEnd('span'); + $this->out->element('span', 'label p-locality', $this->profile->location); } } @@ -291,11 +280,10 @@ class ProfileListItem extends Widget $usf = new UnsubscribeForm($this->out, $this->profile); $usf->show(); } else { - // We can't initiate sub for a remote OMB profile. - $remote = Remote_profile::staticGet('id', $this->profile->id); - if (empty($remote)) { + if (Event::handle('StartShowProfileListSubscribeButton', array($this))) { $sf = new SubscribeForm($this->out, $this->profile); $sf->show(); + Event::handle('EndShowProfileListSubscribeButton', array($this)); } } $this->out->elementEnd('li'); @@ -321,13 +309,13 @@ class ProfileListItem extends Widget function linkAttributes() { return array('href' => $this->profile->profileurl, - 'class' => 'url entry-title', + 'class' => 'u-url', 'rel' => 'contact'); } function homepageAttributes() { return array('href' => $this->profile->homepage, - 'class' => 'url'); + 'class' => 'u-url'); } }