* * http://www.radix.net/~cknudsen * * Modified by Mark Peters * * -------------------------------------------- * * This program is free software; you can redistribute it and/or modify it * * under the terms of the GNU General Public License as published by the * * Free Software Foundation; either version 2 of the License, or (at your * * option) any later version. * \**************************************************************************/ /* $Id$ */ $phpgw_flags = Array( 'currentapp' => 'calendar', 'enable_nextmatchs_class' => True ); $phpgw_info['flags'] = $phpgw_flags; if (! $keywords) { // If we reach this, it is because they didn't search for anything, // attempt to send them back to where they where. Header('Location: ' . $phpgw->link($from,'month='.$month.'&day='.$day.'&year='.$year)); } include('../header.inc.php'); $error = ''; if (strlen($keywords) == 0) { echo ''.lang('Error').':'; echo lang('You must enter one or more search keywords.'); $phpgw->common->phpgw_footer(); $phpgw->common->phpgw_exit(); } $matches = 0; $phpgw->calendar->set_filter(); // There is currently a problem searching in with repeated events. // It spits back out the date it was entered. I would like to to say that // it is a repeated event. $ids = array(); $words = split(' ',$keywords); for ($i=0;$icalendar->filter,'private')) { $sql .= "AND calendar_entry.cal_access='private' "; } $sql .= 'ORDER BY calendar_entry.cal_datetime ASC, calendar_entry.cal_edatetime ASC, calendar_entry.cal_priority ASC'; $events = $phpgw->calendar->get_event_ids(True,$sql); if($events == False) { $matches = 0; } else { $cal_stream = $phpgw->calendar->open('INBOX',intval($owner),''); for($i=0;$icalendar->fetch_event($cal_stream,$events[$i]); $datetime = mktime($event->start->hour,$event->start->min,$event->start->sec,$event->start->month,$event->start->mday,$event->start->year) - ((60 * 60) * intval($phpgw_info['user']['preferences']['common']['tz_offset'])); $ids[strval($event->id)]++; $info[strval($event->id)] = $event->name.' (' . $phpgw->common->show_date($datetime).')'; } $matches = count($events); } } if ($matches > 0) { $matches = count($ids); } if ($matches == 1) { $quantity = lang('1 match found').'.'; } elseif ($matches > 0) { $quantity = lang('x matches found',$matches).'.'; } else { echo ''.lang('Error').':'; echo lang('no matches found.'); $phpgw->common->phpgw_footer(); $phpgw->common->phpgw_exit(); } $p = CreateObject('phpgwapi.Template',$phpgw->calendar->template_dir); $templates = Array( 'search' => 'search.tpl', 'search_list' => 'search_list.tpl', ); $p->set_file($templates); $var = Array( 'color' => $phpgw_info['theme']['bg_text'], 'search_text' => lang('Search Results'), 'quantity' => $quantity ); $p->set_var($var); // now sort by number of hits arsort($ids); for(reset($ids);$key=key($ids);next($ids)) { $p->set_var('url_result',$phpgw->link('/'.$phpgw_info['flags']['currentapp'].'/view.php','id='.$key.'&owner='.$owner)); $p->set_var('result_desc',$info[$key]); $p->parse('output','search_list',True); } $p->pparse('out','search'); $phpgw->common->phpgw_footer(); ?>