summaryrefslogtreecommitdiff
path: root/lib/searchaction.php
diff options
context:
space:
mode:
authorEvan Prodromou <git@evanprodromou.name>2009-01-23 08:58:31 +0100
committerEvan Prodromou <git@evanprodromou.name>2009-01-23 08:58:31 +0100
commita7c85bebd5be9ea019a8c80d74730d7eb28d4651 (patch)
treec3fdf9575a342624bc71aad1d439ae73594f558c /lib/searchaction.php
parent4873277b58941ae6ec16543f437f4267ccab5ac0 (diff)
parent7aa496cd8a939960eeaf79f3397f6fe94097e047 (diff)
Merge branch 'master' of /var/www/mublog
Conflicts: actions/api.php actions/deletenotice.php actions/recoverpassword.php actions/remotesubscribe.php actions/tag.php actions/tagrss.php actions/twitapiaccount.php actions/twitapiusers.php classes/Notice.php classes/User.php lib/common.php lib/language.php lib/subs.php lib/twitterapi.php lib/util.php scripts/inbox_users.php scripts/update_translations.php Merged development trunk into laconica head. woohoo!
Diffstat (limited to 'lib/searchaction.php')
-rw-r--r--lib/searchaction.php184
1 files changed, 104 insertions, 80 deletions
diff --git a/lib/searchaction.php b/lib/searchaction.php
index f99883b25..70e63146a 100644
--- a/lib/searchaction.php
+++ b/lib/searchaction.php
@@ -1,5 +1,16 @@
<?php
-/*
+/**
+ * Base search action class.
+ *
+ * PHP version 5
+ *
+ * @category Action
+ * @package Laconica
+ * @author Evan Prodromou <evan@controlyourself.ca>
+ * @author Robin Millette <millette@controlyourself.ca>
+ * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
+ * @link http://laconi.ca/
+ *
* Laconica - a distributed open-source microblogging tool
* Copyright (C) 2008, Controlez-Vous, Inc.
*
@@ -17,94 +28,107 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
-if (!defined('LACONICA')) { exit(1); }
+if (!defined('LACONICA')) {
+ exit(1);
+}
+
+require_once INSTALLDIR.'/lib/searchgroupnav.php';
-class SearchAction extends Action {
+/**
+ * Base search action class.
+ *
+ * @category Action
+ * @package Laconica
+ * @author Evan Prodromou <evan@controlyourself.ca>
+ * @author Robin Millette <millette@controlyourself.ca>
+ * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
+ * @link http://laconi.ca/
+ */
+class SearchAction extends Action
+{
+ /**
+ * Return true if read only.
+ *
+ * @return boolean true
+ */
+ function isReadOnly()
+ {
+ return true;
+ }
- function is_readonly() {
- return true;
- }
+ function handle($args)
+ {
+ parent::handle($args);
+ $this->showPage();
+ }
- function handle($args) {
- parent::handle($args);
- $this->show_form();
- }
+ /**
+ * Show tabset for this page
+ *
+ * Uses the SearchGroupNav widget
+ *
+ * @return void
+ * @see SearchGroupNav
+ */
- function show_top($arr=NULL) {
- if ($arr) {
- $error = $arr[1];
- }
- if ($error) {
- common_element('p', 'error', $error);
- } else {
- $instr = $this->get_instructions();
- $output = common_markup_to_html($instr);
- common_element_start('div', 'instructions');
- common_raw($output);
- common_element_end('div');
- }
- $this->search_menu();
- }
+ function showLocalNav()
+ {
+ $nav = new SearchGroupNav($this, $this->trimmed('q'));
+ $nav->show();
+ }
- function get_title() {
- return NULL;
- }
+ function showTop($arr=null)
+ {
+ if ($arr) {
+ $error = $arr[1];
+ }
+ if ($error) {
+ $this->element('p', 'error', $error);
+ } else {
+ $instr = $this->getInstructions();
+ $output = common_markup_to_html($instr);
+ $this->elementStart('div', 'instructions');
+ $this->raw($output);
+ $this->elementEnd('div');
+ }
+ }
- function show_header($arr) {
- return;
- }
+ function title()
+ {
+ return null;
+ }
- function show_form($error=NULL) {
- global $config;
+ function showNoticeForm() {
+ // remote post notice form
+ }
- $q = $this->trimmed('q');
- $page = $this->trimmed('page', 1);
+ function showContent() {
+ $this->showTop();
+ $this->showForm();
+ }
- common_show_header($this->get_title(), array($this, 'show_header'), array($q, $error),
- array($this, 'show_top'));
- common_element_start('form', array('method' => 'get',
- 'id' => 'login',
- 'action' => common_local_url($this->trimmed('action'))));
- common_element_start('p');
- if (!isset($config['site']['fancy']) || !$config['site']['fancy']) {
- common_element('input', array('name' => 'action',
- 'type' => 'hidden',
- 'value' => $this->trimmed('action')));
- }
- common_element('input', array('name' => 'q',
- 'id' => 'q',
- 'type' => 'text',
- 'class' => 'input_text',
- 'value' => ($q) ? $q : ''));
- common_text(' ');
- common_element('input', array('type' => 'submit',
- 'id' => 'search',
- 'name' => 'search',
- 'class' => 'submit',
- 'value' => _('Search')));
+ function showForm($error=null)
+ {
+ global $config;
- common_element_end('p');
- common_element_end('form');
- if ($q) {
- $this->show_results($q, $page);
- }
- common_show_footer();
- }
+ $q = $this->trimmed('q');
+ $page = $this->trimmed('page', 1);
+ $this->elementStart('form', array('method' => 'get',
+ 'id' => 'login',
+ 'action' => common_local_url($this->trimmed('action'))));
+ $this->elementStart('p');
+ if (!isset($config['site']['fancy']) || !$config['site']['fancy']) {
+ $this->hidden('action', $this->trimmed('action'));
+ }
+ $this->input('q', '', $q);
+ $this->text(' ');
+ $this->submit('search', 'Search');
- function search_menu() {
- # action => array('prompt', 'title', $args)
- $action = $this->trimmed('action');
- $menu =
- array('peoplesearch' =>
- array(
- _('People'),
- _('Find people on this site'),
- ($action != 'peoplesearch' && $this->trimmed('q')) ? array('q' => $this->trimmed('q')) : NULL),
- 'noticesearch' =>
- array( _('Text'),
- _('Find content of notices'),
- ($action != 'noticesearch' && $this->trimmed('q')) ? array('q' => $this->trimmed('q')) : NULL)
- );
- $this->nav_menu($menu);
- }
+ $this->elementEnd('p');
+ $this->elementEnd('form');
+ if ($q) {
+ $this->showResults($q, $page);
+ }
+ }
}
+