<%ARGS> $Date => undef, @Tickets => () $slots => $default_slots, $sday => undef, $tod_row => undef, $timestep => $default_timestep, @username => () <%SHARED> my @slots = ( [], [], [], [], [], [], [] ); % #for my $t ( @{ $Tickets{$date->strftime("%F")} } ) { % for my $t (@Tickets) { % % my($sm, $sh) = ($t->StartsObj->Localtime('user'))[1,2]; % my $starts = $sh*60 + $sm; % % if ( RTx::Calendar::LocalDate($t->StartsObj->Unix) eq $Date->strftime('%F') #today % && $starts >= $tod_row && $starts < ($tod_row + $timestep) ) { % #then we're a new entry, find a slot for us % my $s = 0; % while ( ref($slots[$sday]->[$s]) ) { $s++ } % $slots[$sday]->[$s] = [ $t->Id, $t ]; % } % % my($dm, $dh) = ($t->DueObj->Localtime('user'))[1,2]; % my $due = $dh*60 + $dm; % % if ( RTx::Calendar::LocalDate($t->DueObj->Unix) eq $Date->strftime('%F') #today % && $due <= $tod_row && $due > ($tod_row + $timestep ) ) { % #then find our slot and remove us % @{ $slots[$sday] } = % map { (!ref($_) || $_->[0] != $t->Id) ? $_ : '' } % @{ $slots[$sday] }; % } % % } % % pop @{ $slots[$sday] } while @{ $slots[$sday] } && !ref($slots[$sday]->[-1]); % % #now display: % % if ( scalar(@{$slots[$sday]}) > $slots ) { % #overflow situation, eek... could be handled better, how? class="weekly %# <% $is_today ? 'today' %# : $is_yesterday ? 'yesterday' %# : $is_aweekago ? 'aweekago' %# : '' %# %> " >MULTIPLE % } else { % % foreach my $slot ( @{ $slots[$sday] } ) { % my( $id, $ticket ) = @$slot; <% $id %> % } % % if ( scalar(@{$slots[$sday]}) < $slots ) { class="weekly %# <% $is_today ? 'today' %# : $is_yesterday ? 'yesterday' %# : $is_aweekago ? 'aweekago' %# : '' %# %> " > % } % % } <%ONCE> my $default_slots = RT->Config->Get('CalendarWeeklySlots') || 5; my $default_timestep = RT->Config->Get('CalendarWeeklySizeMin') || 30; #1/2h