built SQL fetch_event()

This commit is contained in:
skeeter 2001-02-27 04:42:18 +00:00
parent aacca9b4da
commit 43765754ae
3 changed files with 323 additions and 10 deletions

View File

@ -14,8 +14,34 @@
/* $Id$ */ /* $Id$ */
if(extension_loaded("mcal") == False)
{
define(RECUR_NONE,0);
define(RECUR_DAILY,1);
define(RECUR_WEEKLY,2);
define(RECUR_MONTHLY_MDAY,3);
define(RECUR_MONTHLY_WDAY,4);
define(RECUR_YEARLY,5);
define(M_SUNDAY,1);
define(M_MONDAY,2);
define(M_TUESDAY,4);
define(M_WEDNESDAY,8);
define(M_THURSDAY,16);
define(M_FRIDAY,32);
define(M_SATURDAY,64);
define(M_WEEKDAYS,63);
define(M_WEEKEND,65);
define(M_ALLDAYS,127);
}
CreateObject('calendar.calendar_item'); CreateObject('calendar.calendar_item');
$phpgw_info['server']['calendar_type'] = 'sql'; $phpgw_info['server']['calendar_type'] = 'sql';
if($phpgw_info['server']['calendar_type'] == 'mcal' && extension_loaded("mcal") == False)
{
$phpgw_info['server']['calendar_type'] = 'sql';
}
include(PHPGW_INCLUDE_ROOT.'/calendar/inc/class.calendar_'.$phpgw_info['server']['calendar_type'].'.inc.php'); include(PHPGW_INCLUDE_ROOT.'/calendar/inc/class.calendar_'.$phpgw_info['server']['calendar_type'].'.inc.php');
class calendar extends calendar_ class calendar extends calendar_
@ -236,7 +262,10 @@ class calendar extends calendar_
else else
{ {
$this->repeated_events = $events; $this->repeated_events = $events;
$this->repeating_events = $this->getevent($events); for($i=0;$i<count($events);$i++)
{
$this->repeating_events[] = $this->fetch_event($this->stream,$events[$i]);
}
} }
} }
@ -404,7 +433,11 @@ class calendar extends calendar_
} }
else else
{ {
$events = $this->getevent($event); for($i=0;$i<$this->sorted_events_matching;$i++)
{
$events[] = $this->fetch_event($this->stream,$event[$i]);
}
if($this->sorted_events_matching == 1) if($this->sorted_events_matching == 1)
{ {
return $events; return $events;

View File

@ -14,11 +14,34 @@
/* $Id$ */ /* $Id$ */
class calendar_time {
var $year;
var $month;
var $mday;
var $hour;
var $min;
var $sec;
var $alarm = 0;
}
class calendar_item { class calendar_item {
var $owner; //New ICal Support
var $id = 0; var $id = 0;
var $name = "Unnamed Event"; var $public = 0;
var $category = "none";
var $title = "Unnamed Event";
var $description = "Unnamed Event"; var $description = "Unnamed Event";
var $alarm = 0;
var $start;
var $end;
var $recur_type = 0;
var $recur_interval = 0;
var $recur_enddate;
var $recur_data = 0;
// Legacy Support
var $owner;
var $name = "Unnamed Event";
var $datetime = 0; var $datetime = 0;
var $day = 0; var $day = 0;
var $month = 0; var $month = 0;

View File

@ -78,6 +78,8 @@ class calendar_
function fetch_event($mcal_stream,$event_id,$options='') function fetch_event($mcal_stream,$event_id,$options='')
{ {
global $phpgw;
if(!isset($this->stream)) if(!isset($this->stream))
{ {
return False; return False;
@ -85,24 +87,280 @@ class calendar_
$this->stream->lock(array('calendar_entry','calendar_entry_user','calendar_entry_repeats')); $this->stream->lock(array('calendar_entry','calendar_entry_user','calendar_entry_repeats'));
// This is the preferred method once everything is normalized...
//$this->stream->query('SELECT * FROM calendar_entry WHERE id='.$event_id,__LINE__,__FILE__);
// But until then, do it this way...
$this->stream->query('SELECT * FROM calendar_entry WHERE cal_id='.$event_id,__LINE__,__FILE__); $this->stream->query('SELECT * FROM calendar_entry WHERE cal_id='.$event_id,__LINE__,__FILE__);
if($this->stream->num_rows() > 0) if($this->stream->num_rows() > 0)
{ {
$this->event = CreateObject('calendar.calendar_item'); $event = CreateObject('calendar.calendar_item');
$event->start = new calendar_time;
$event->end = new calendar_time;
$event->recur_enddate = new calendar_time;
$this->stream->next_record(); $this->stream->next_record();
// Load the calendar event data from the db into $this->event structure // Load the calendar event data from the db into $event structure
// Use http://www.php.net/manual/en/function.mcal-fetch-event.php as the reference // Use http://www.php.net/manual/en/function.mcal-fetch-event.php as the reference
// This is the preferred method once everything is normalized...
//$event->owner = $this->user;
// But until then, do it this way...
//Legacy Support
$event->owner = $this->stream->f('cal_owner');
// This is the preferred method once everything is normalized...
//$event->id = $event_id;
// But until then, do it this way...
//Legacy Support
$event->id = intval($this->stream->f('cal_id'));
// This is the preferred method once everything is normalized...
//$event->public = $this->stream->f('public');
// But until then, do it this way...
//Legacy Support
$event->access = $this->stream->f('cal_access');
//Legacy Support (New)
$event->public = ($this->stream->f('cal_access')=='private'?0:1);
// This is the preferred method once everything is normalized...
//$event->category = $this->stream->f('category');
// But until then, do it this way...
//Legacy Support (New)
$event->category = 'Unfiled';
// This is the preferred method once everything is normalized...
//$event->title = $phpgw->strip_html($this->stream->f('title'));
// But until then, do it this way...
//Legacy Support
$event->name = $phpgw->strip_html($this->stream->f('cal_name'));
//Legacy Support (New)
$event->title = $phpgw->strip_html($this->stream->f('cal_name'));
// This is the preferred method once everything is normalized...
//$event->title = $phpgw->strip_html($this->stream->f('description'));
// But until then, do it this way...
//Legacy Support
//Legacy Support (New)
$event->description = $phpgw->strip_html($this->stream->f('cal_description'));
// This is the preferred method once everything is normalized...
//$event->alarm = intval($this->stream->f('alarm'));
// But until then, do it this way...
//Legacy Support (New)
$event->alarm = 0;
// This is the preferred method once everything is normalized...
//$event->start = unserialize($this->stream->f('start'));
// But until then, do it this way...
//Legacy Support
$event->datetime = $this->stream->f('cal_datetime');
$date = $this->localdates($event->datetime);
$event->day = $date['day'];
$event->month = $date['month'];
$event->year = $date['year'];
$time = $this->splittime($phpgw->common->show_date($event->datetime,'His'));
$event->hour = (int)$time['hour'];
$event->minute = (int)$time['minute'];
$event->ampm = $time['ampm'];
//Legacy Support (New)
$datetime = $this->localdates($this->stream->f('cal_datetime'));
$event->start->year = $datetime['year'];
$event->start->month = $datetime['month'];
$event->start->mday = $datetime['day'];
$event->start->hour = $datetime['hour'];
$event->start->min = $datetime['minute'];
$event->start->sec = $datetime['second'];
$event->start->alarm = 0;
//Legacy Support
$event->mdatetime = $this->stream->f('cal_mdatetime');
$date = $this->localdates($event->mdatetime);
$event->mod_day = $date['day'];
$event->mod_month = $date['month'];
$event->mod_year = $date['year'];
$time = $this->splittime($phpgw->common->show_date($event->mdatetime,'His'));
$event->mod_hour = (int)$time['hour'];
$event->mod_minute = (int)$time['minute'];
$event->mod_second = (int)$time['second'];
$event->mod_ampm = $time['ampm'];
// This is the preferred method once everything is normalized...
//$event->end = unserialize($this->stream->f('end'));
// But until then, do it this way...
//Legacy Support
$event->edatetime = $this->stream->f('cal_edatetime');
$date = $this->localdates($event->edatetime);
$event->end_day = $date['day'];
$event->end_month = $date['month'];
$event->end_year = $date['year'];
$time = $this->splittime($phpgw->common->show_date($event->edatetime,'His'));
$event->end_hour = (int)$time['hour'];
$event->end_minute = (int)$time['minute'];
$event->end_second = (int)$time['second'];
$event->end_ampm = $time['ampm'];
//Legacy Support (New)
$datetime = $this->localdates($this->stream->f('cal_edatetime'));
$event->end->year = $datetime['year'];
$event->end->month = $datetime['month'];
$event->end->mday = $datetime['day'];
$event->end->hour = $datetime['hour'];
$event->end->min = $datetime['minute'];
$event->end->sec = $datetime['second'];
$event->end->alarm = 0;
//Legacy Support
$event->priority = $this->stream->f('cal_priority');
if($this->stream->f('cal_group'))
{
$groups = explode(',',$this->stream->f('cal_group'));
for($j=1;$j<count($groups) - 1;$j++)
{
$event->groups[] = $groups[$j];
}
}
// This should all be one table,
// but for now we'll leave it separate...
// This is the preferred method once everything is normalized...
//$this->stream->query('SELECT * FROM calendar_entry_repeats WHERE id='.$event_id,__LINE__,__FILE__);
// But until then, do it this way...
//Legacy Support
$this->stream->query('SELECT * FROM calendar_entry_repeats WHERE cal_id='.$event_id,__LINE__,__FILE__);
if($this->stream->num_rows())
{
$this->stream->next_record();
// This is the preferred method once everything is normalized...
//$event->recur_type = intval($this->stream->f('recur_type'));
// But until then, do it this way...
//Legacy Support
$rpt_type = strtolower($this->stream->f('cal_type'));
$event->rpt_type = !$rpt_type?'none':$rpt_type;
//Legacy Support (New)
switch($event->rpt_type)
{
case 'none':
$event->recur_type = RECUR_NONE;
break;
case 'daily':
$event->recur_type = RECUR_DAILY;
break;
case 'weekly':
$event->recur_type = RECUR_WEEKLY;
break;
case 'monthlybydate':
$event->recur_type = RECUR_MONTHLY_MDAY;
break;
case 'monthlybyday':
$event->recur_type = RECUR_MONTHLY_WDAY;
break;
case 'yearly':
$event->recur_type = RECUR_YEARLY;
break;
}
// This is the preferred method once everything is normalized...
//$event->recur_interval = intval($this->stream->f('recur_interval'));
// But until then, do it this way...
//Legacy Support
$event->rpt_freq = (int)$this->stream->f('cal_frequency');
//Legacy Support (New)
$event->recur_interval = (int)$this->stream->f('cal_frequency');
// This is the preferred method once everything is normalized...
//$event->recur_enddate = unserialize($this->stream->f('recur_enddate'));
// But until then, do it this way...
//Legacy Support
$event->recur_use_end = $this->stream->f('cal_use_end');
if($event->recur_use_end == True)
{
//Legacy Support
$event->rpt_end = $this->stream->f('cal_end');
$date = $this->localdates($this->stream->f('cal_end'));
$event->rpt_end_day = (int)$date['day'];
$event->rpt_end_month = (int)$date['month'];
$event->rpt_end_year = (int)$date['year'];
//Legacy Support (New)
$event->recur_enddate->year = $date['year'];
$event->recur_enddate->month = $date['month'];
$event->recur_enddate->mday = $date['day'];
$event->recur_enddate->hour = $date['hour'];
$event->recur_enddate->min = $date['minute'];
$event->recur_enddate->sec = $date['second'];
$event->recur_enddate->alarm = 0;
}
else
{
//Legacy Support
$event->rpt_end = 0;
$event->rpt_end_day = 0;
$event->rpt_end_month = 0;
$event->rpt_end_year = 0;
//Legacy Support (New)
$event->recur_enddate->year = 0;
$event->recur_enddate->month = 0;
$event->recur_enddate->mday = 0;
$event->recur_enddate->hour = 0;
$event->recur_enddate->min = 0;
$event->recur_enddate->sec = 0;
$event->recur_enddate->alarm = 0;
}
// This is the preferred method once everything is normalized...
//$event->recur_data = $this->stream->f('recur_data');
// But until then, do it this way...
//Legacy Support
$rpt_days = strtoupper($this->stream->f('cal_rpt_days'));
$event->rpt_days = $rpt_days;
$event->rpt_sun = (substr($rpt_days,0,1)=='Y'?1:0);
$event->rpt_mon = (substr($rpt_days,1,1)=='Y'?1:0);
$event->rpt_tue = (substr($rpt_days,2,1)=='Y'?1:0);
$event->rpt_wed = (substr($rpt_days,3,1)=='Y'?1:0);
$event->rpt_thu = (substr($rpt_days,4,1)=='Y'?1:0);
$event->rpt_fri = (substr($rpt_days,5,1)=='Y'?1:0);
$event->rpt_sat = (substr($rpt_days,6,1)=='Y'?1:0);
//Legacy Support (New)
$event->recur_data = 0;
$event->recur_data += (substr($rpt_days,0,1)=='Y'?M_SUNDAY:0);
$event->recur_data += (substr($rpt_days,1,1)=='Y'?M_MONDAY:0);
$event->recur_data += (substr($rpt_days,2,1)=='Y'?M_TUESDAY:0);
$event->recur_data += (substr($rpt_days,3,1)=='Y'?M_WEDNESDAY:0);
$event->recur_data += (substr($rpt_days,4,1)=='Y'?M_THURSDAY:0);
$event->recur_data += (substr($rpt_days,5,1)=='Y'?M_FRIDAY:0);
$event->recur_data += (substr($rpt_days,6,1)=='Y'?M_SAYURDAY:0);
}
//Legacy Support
$this->stream->query('SELECT * FROM calendar_entry_user WHERE cal_id='.$event_id,__LINE__,__FILE__);
if($this->stream->num_rows())
{
while($this->stream->next_record())
{
$event->participants[] = $this->stream->f('cal_login');
$event->status[] = $this->stream->f('cal_status');
}
}
} }
else else
{ {
$this->event = False; $event = False;
} }
$this->stream->unlock(); $this->stream->unlock();
return $this->event; return $event;
} }
function list_events($mcal_stream,$startYear,$startMonth,$startDay,$endYear='',$endMonth='',$endYear='') function list_events($mcal_stream,$startYear,$startMonth,$startDay,$endYear='',$endMonth='',$endYear='')
@ -271,6 +529,7 @@ class calendar_
$date['dow'] = intval($phpgw->common->show_date($date['raw'],'w')); $date['dow'] = intval($phpgw->common->show_date($date['raw'],'w'));
$date['hour'] = intval($phpgw->common->show_date($date['raw'],'H')); $date['hour'] = intval($phpgw->common->show_date($date['raw'],'H'));
$date['minute'] = intval($phpgw->common->show_date($date['raw'],'i')); $date['minute'] = intval($phpgw->common->show_date($date['raw'],'i'));
$date['second'] = intval($phpgw->common->show_date($date['raw'],'s'));
return $date; return $date;
} }
@ -872,8 +1131,6 @@ class calendar_
if($calendar->rpt_use_end) if($calendar->rpt_use_end)
{ {
$calendar->rpt_end = $db2->f('cal_end'); $calendar->rpt_end = $db2->f('cal_end');
$rpt_end = $phpgw->common->show_date($db2->f('cal_end'),'Ymd');
// $date = $this->date_to_epoch($rpt_end);
$date = $this->localdates($db2->f('cal_end')); $date = $this->localdates($db2->f('cal_end'));
$calendar->rpt_end_day = (int)$date['day']; $calendar->rpt_end_day = (int)$date['day'];
$calendar->rpt_end_month = (int)$date['month']; $calendar->rpt_end_month = (int)$date['month'];