Solved

Create daily calendar with PHP/HTML/CSS

Posted on 2014-09-09
2
457 Views
Last Modified: 2014-09-16
I created a day by day calendar broken down in 15 minute increments throughout the day ... now I need to figure out how to property populate the calendar for the events (so for example if an event is 2 hours from 9am to 11am that it is shown properly across the respective rows ....

Here's what I have so far:
<?php

require('library.php');

$start_time = '8:00 AM';
$end_time = '10:00 PM';
$minutes_breakage = '15';

$day = getvar('day');
if(strlen($day)<1) $day = date('m/d/Y');
else { $day = date('m/d/Y', strtotime($day)); }

$inc   = $minutes_breakage * 60;
$start = (strtotime($start_time)); // 6  AM
$end   = (strtotime($end_time)); // 10 PM

echo "<h3>Day: $day</h3>";

echo <<< HTML
<style>
/* TEST */
.id_33__08_00_AM {
	background-color: green;
}
</style>
HTML;

echo '<table border=1 cellspacing=0><tr><td>Time</td>';
	
foreach (getrows("SELECT * FROM users WHERE type='Agent' AND active='Yes'") AS $row) {
	echo "<td>{$row['full_name']}</td>";
	$usercols .= "<td class='id_{$row['user_id']}__[TIMESTART]'></td>";
}

echo '</tr>';

for( $i = $start; $i <= $end; $i += $inc ) {
    #$range = date( 'g:i', $i ) . ' - ' . date( 'g:i A', $i + $inc );
	$show = date( 'g:i A', $i );
	$csstime = date('h_i_A', $i);
	$myusercols = str_replace('[TIMESTART]', $csstime, $usercols);
	echo "<tr><td>$show</td>$myusercols</tr>";
}
echo '</table>';


?>

Open in new window


I was playing around with CSS but apparently you cannot do rowspans with it and if I define a rowspan on a td say beginning at 9AM, I need to make sure a <td> tag does not appear anywhere where the rowspan is supposed to span across. I need an example of the best way of structuring the php code to properly populate the daily calendar with events that span across the events hours.. (I know how to pull it from MySQL/etc but I need to know how to output it so it appears properly)
0
Comment
Question by:Mark
2 Comments
 
LVL 108

Accepted Solution

by:
Ray Paseur earned 500 total points
Comment Utility
Can you please share a mockup of what you want the calendar to look like, along with the test data that would be used to create the HTML document that looks like the mockup?  Can you please post the CREATE TABLE statement for the 'users' table and any other tables that are in play?  Thanks!
0
 

Author Comment

by:Mark
Comment Utility
I figured it out...

$minutesinappt = getcol("SELECT TIMESTAMPDIFF(MINUTE,`start_time`,`end_time`) FROM appointments WHERE id='{$appointment['id']}' AND cancelled != 1");
$cycles = $minutesinappt/$minutes_breakage;
		
		if($cycles==1) {
			echo "<td>Appointment With {$appointment['client']}</td>";
		}
		
		else if(!isset($appointmentrowsleft[$apptid])) {
			$appointmentrowsleft[$apptid] = 1;
			echo "<td rowspan='$cycles'>Appointment With {$appointment['client']}</td>";
		}
		......

Open in new window

0

Featured Post

Do You Know the 4 Main Threat Actor Types?

Do you know the main threat actor types? Most attackers fall into one of four categories, each with their own favored tactics, techniques, and procedures.

Join & Write a Comment

This is a PowerShell web interface I use to manage some task as a network administrator. Clicking an action button on the left frame will display a form in the middle frame to input some data in textboxes, process this data in PowerShell and display…
This article explains how to prepare an HTML email signature template file containing dynamic placeholders for users' Azure AD data. Furthermore, it explains how to use this file to remotely set up a department-wide email signature policy in Office …
In this tutorial viewers will learn how to embed Flash content in a webpage using HTML5. Ensure your DOCTYPE declaration is set to HTML5: "<!DOCTYPE html>": Use the <object> tag to embed Flash content.: To specify that the object is Flash content, d…
The viewer will learn how to count occurrences of each item in an array.

744 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now