summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvan Prodromou <evan@prodromou.name>2008-11-20 05:50:27 -0500
committerEvan Prodromou <evan@prodromou.name>2008-11-20 05:50:27 -0500
commitd1361c6e271d21f0605cd2d23d47477c4d249886 (patch)
treec4dd5d9120789b66c2758ca32b5741e24e39a125
parentdbb07db6023c7ce174bef50efec89a00ef590b5c (diff)
abstract people lists from search results
darcs-hash:20081120105027-84dde-e1c0faace07d9f2439d3a51a42cfe83464da5319.gz
-rw-r--r--actions/peoplesearch.php79
-rw-r--r--lib/profilelist.php101
2 files changed, 119 insertions, 61 deletions
diff --git a/actions/peoplesearch.php b/actions/peoplesearch.php
index 4e0ec3f0c..985d5fae5 100644
--- a/actions/peoplesearch.php
+++ b/actions/peoplesearch.php
@@ -20,7 +20,7 @@
if (!defined('LACONICA')) { exit(1); }
require_once(INSTALLDIR.'/lib/searchaction.php');
-define('PROFILES_PER_PAGE', 10);
+require_once(INSTALLDIR.'/lib/profilelist.php');
class PeoplesearchAction extends SearchAction {
@@ -55,74 +55,31 @@ class PeoplesearchAction extends SearchAction {
if ($cnt > 0) {
$terms = preg_split('/[\s,]+/', $q);
- common_element_start('ul', array('id' => 'profiles'));
- for ($i = 0; $i < min($cnt, PROFILES_PER_PAGE); $i++) {
- if ($profile->fetch()) {
- $this->show_profile($profile, $terms);
- } else {
- // shouldn't happen!
- break;
- }
- }
- common_element_end('ul');
+ $results = new PeopleSearchResults($profile, $terms);
+ $results->show_list();
} else {
common_element('p', 'error', _('No results'));
}
+ $profile->free();
+
common_pagination($page > 1, $cnt > PROFILES_PER_PAGE,
$page, 'peoplesearch', array('q' => $q));
}
+}
- function show_profile($profile, $terms) {
- common_element_start('li', array('class' => 'profile_single',
- 'id' => 'profile-' . $profile->id));
- $avatar = $profile->getAvatar(AVATAR_STREAM_SIZE);
- common_element_start('a', array('href' => $profile->profileurl));
- common_element('img', array('src' => ($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_STREAM_SIZE),
- 'class' => 'avatar stream',
- 'width' => AVATAR_STREAM_SIZE,
- 'height' => AVATAR_STREAM_SIZE,
- 'alt' =>
- ($profile->fullname) ? $profile->fullname :
- $profile->nickname));
- common_element_end('a');
- common_element_start('p');
- common_element_start('a', array('href' => $profile->profileurl,
- 'class' => 'nickname'));
- common_raw($this->highlight($profile->nickname, $terms));
- common_element_end('a');
- if ($profile->fullname) {
- common_text(' | ');
- common_element_start('span', 'fullname');
- common_raw($this->highlight($profile->fullname, $terms));
- common_element_end('span');
- }
- if ($profile->location) {
- common_text(' | ');
- common_element_start('span', 'location');
- common_raw($this->highlight($profile->location, $terms));
- common_element_end('span');
- }
- common_element_end('p');
- if ($profile->homepage) {
- common_element_start('p', 'website');
- common_element_start('a', array('href' => $profile->homepage));
- common_raw($this->highlight($profile->homepage, $terms));
- common_element_end('a');
- common_element_end('p');
- }
- if ($profile->bio) {
- common_element_start('p', 'bio');
- common_raw($this->highlight($profile->bio, $terms));
- common_element_end('p');
- }
- common_element_end('li');
- }
+class PeopleSearchResults extends ProfileList {
- function highlight($text, $terms) {
- $terms = array_map('preg_quote', array_map('htmlspecialchars', $terms));
- $pattern = '/('.implode('|',$terms).')/i';
- $result = preg_replace($pattern, '<strong>\\1</strong>', htmlspecialchars($text));
- return $result;
+ var $terms = NULL;
+ var $pattern = NULL;
+
+ function __construct($profile, $terms) {
+ parent::__construct($profile);
+ $this->terms = array_map('preg_quote', array_map('htmlspecialchars', $this->terms));
+ $this->pattern = '/('.implode('|',$terms).')/i';
+ }
+
+ function highlight($text) {
+ return preg_replace($this->pattern, '<strong>\\1</strong>', htmlspecialchars($text));
}
}
diff --git a/lib/profilelist.php b/lib/profilelist.php
new file mode 100644
index 000000000..4c2037e05
--- /dev/null
+++ b/lib/profilelist.php
@@ -0,0 +1,101 @@
+<?php
+
+/*
+ * Laconica - a distributed open-source microblogging tool
+ * Copyright (C) 2008, Controlez-Vous, Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+if (!defined('LACONICA')) { exit(1); }
+
+define('PROFILES_PER_PAGE', 10);
+
+class ProfileList {
+
+ var $profile = NULL;
+
+ function __construct($profile) {
+ $this->profile = $profile;
+ }
+
+ function show_list() {
+
+ common_element_start('ul', array('id' => 'profiles'));
+
+ for ($i = 0; $i < min($cnt, PROFILES_PER_PAGE); $i++) {
+ if ($this->profile->fetch()) {
+ $this->show();
+ } else {
+ // shouldn't happen!
+ break;
+ }
+ }
+
+ common_element_end('ul');
+ }
+
+ function show() {
+
+ $this->profile = $this->profile;
+
+ common_element_start('li', array('class' => 'profile_single',
+ 'id' => 'profile-' . $this->profile->id));
+ $avatar = $this->profile->getAvatar(AVATAR_STREAM_SIZE);
+ common_element_start('a', array('href' => $this->profile->profileurl));
+ common_element('img', array('src' => ($avatar) ? common_avatar_display_url($avatar) : common_default_avatar(AVATAR_STREAM_SIZE),
+ 'class' => 'avatar stream',
+ 'width' => AVATAR_STREAM_SIZE,
+ 'height' => AVATAR_STREAM_SIZE,
+ 'alt' =>
+ ($this->profile->fullname) ? $this->profile->fullname :
+ $this->profile->nickname));
+ common_element_end('a');
+ common_element_start('p');
+ common_element_start('a', array('href' => $this->profile->profileurl,
+ 'class' => 'nickname'));
+ common_raw($this->highlight($this->profile->nickname));
+ common_element_end('a');
+ if ($this->profile->fullname) {
+ common_text(' | ');
+ common_element_start('span', 'fullname');
+ common_raw($this->highlight($this->profile->fullname));
+ common_element_end('span');
+ }
+ if ($this->profile->location) {
+ common_text(' | ');
+ common_element_start('span', 'location');
+ common_raw($this->highlight($this->profile->location));
+ common_element_end('span');
+ }
+ common_element_end('p');
+ if ($this->profile->homepage) {
+ common_element_start('p', 'website');
+ common_element_start('a', array('href' => $this->profile->homepage));
+ common_raw($this->highlight($this->profile->homepage));
+ common_element_end('a');
+ common_element_end('p');
+ }
+ if ($this->profile->bio) {
+ common_element_start('p', 'bio');
+ common_raw($this->highlight($this->profile->bio));
+ common_element_end('p');
+ }
+ common_element_end('li');
+ }
+
+ function highlight($text) {
+ return htmlspecialchars($text);
+ }
+} \ No newline at end of file