X-Git-Url: https://git.cweiske.de/phinde.git/blobdiff_plain/f1a5d014d126621afa80af017da751ccb5ab7f85..696fcd7ce4d495e356667019493bf312e2a6e47b:/www/index.php diff --git a/www/index.php b/www/index.php index 6f4ec8f..8bf8147 100644 --- a/www/index.php +++ b/www/index.php @@ -6,8 +6,8 @@ require 'www-header.php'; if (!isset($_GET['q'])) { $_GET['q'] = ''; } +$query = trim($_GET['q']); -$query = $_GET['q']; $page = 0; if (isset($_GET['page'])) { if (!is_numeric($_GET['page'])) { @@ -16,6 +16,7 @@ if (isset($_GET['page'])) { //PEAR Pager begins at 1 $page = (int)$_GET['page'] - 1; } + $perPage = 10;//$GLOBALS['phinde']['perPage']; $site = null; $siteParam = false; @@ -34,6 +35,13 @@ if (preg_match('#site:([^ ]*)#', $query, $matches)) { $cleanQuery = $query; } +if (isset($_GET['sort']) && $_GET['sort'] == 'date') { + $sort = 'date'; + $baseLink .= '&sort=date'; +} else { + $sort = ''; +} + $filters = array(); if (isset($_GET['filter'])) { $allowedFilter = array('domain', 'language', 'tags', 'term'); @@ -80,7 +88,7 @@ if (preg_match('#site:([^ ]*)#', $query, $matches)) { $timeBegin = microtime(true); $es = new Elasticsearch($GLOBALS['phinde']['elasticsearch']); -$res = $es->search($cleanQuery, $filters, $site, $page, $perPage); +$res = $es->search($cleanQuery, $filters, $site, $page, $perPage, $sort); $timeEnd = microtime(true); $pager = new Html_Pager( @@ -107,8 +115,8 @@ foreach ($res->hits->hits as &$hit) { $doc->extra = new \stdClass(); $doc->extra->cleanUrl = preg_replace('#^.*://#', '', $doc->url); - if (isset($doc->modate)) { - $doc->extra->day = substr($doc->modate, 0, 10); + if (isset($doc->status->modate)) { + $doc->extra->day = substr($doc->status->modate, 0, 10); } } @@ -124,11 +132,25 @@ if ($site !== null) { $urlNoSite = null; } +$urlSortRelevance = buildLink( + str_replace('&sort=date', '', $baseLink), $filters, null, null +); +$urlSortDate = $urlSortRelevance . '&sort=date'; + +if (isset($_GET['format']) && $_GET['format'] == 'opensearch') { + $template = 'opensearch'; + $baseLink .= '&format=opensearch'; + header('Content-type: application/atom+xml'); +} else { + $template = 'search'; +} + render( - 'search', + $template, array( 'queryTime' => round($timeEnd - $timeBegin, 2) . 's', 'query' => $query, + 'fullUrl' => Helper::fullUrl($baseLink), 'cleanQuery' => $cleanQuery, 'urlNoSite' => $urlNoSite, 'site' => $site, @@ -137,7 +159,11 @@ render( 'hits' => $res->hits->hits, 'aggregations' => $res->aggregations, 'activeFilters' => $activeFilters, - 'pager' => $pager + 'pager' => $pager, + 'sort' => $sort, + 'urlSortRelevance' => $urlSortRelevance, + 'urlSortDate' => $urlSortDate, + 'hitTemplate' => 'search/' . $GLOBALS['phinde']['hitTemplate'], ) ); ?>