1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 14:51:06 +01:00

Don't mix different users on the same line in Calendar

Summary:
The current state is very confusing:
{F11734, size=full}

Test Plan: Display calendar for user with two different events in the same week.

Reviewers: epriestley, btrahan

Reviewed By: epriestley

CC: aran, Koolvin

Differential Revision: https://secure.phabricator.com/D2522
This commit is contained in:
vrana 2012-05-21 11:59:12 -07:00
parent 77f546c572
commit bb7285ab46
5 changed files with 41 additions and 12 deletions

View file

@ -389,7 +389,7 @@ celerity_register_resource_map(array(
),
'aphront-calendar-view-css' =>
array(
'uri' => '/res/4fd79240/rsrc/css/aphront/calendar-view.css',
'uri' => '/res/b200376d/rsrc/css/aphront/calendar-view.css',
'type' => 'css',
'requires' =>
array(

View file

@ -51,6 +51,7 @@ final class PhabricatorCalendarBrowseController
$name_text = $handles[$status->getUserPHID()]->getName();
$status_text = $status->getTextStatus();
$event->setUserPHID($status->getUserPHID());
$event->setName("{$name_text} ({$status_text})");
$event->setDescription($status->getStatusDescription($user));
$month_view->addEvent($event);

View file

@ -18,11 +18,21 @@
final class AphrontCalendarEventView extends AphrontView {
private $userPHID;
private $name;
private $epochStart;
private $epochEnd;
private $description;
public function setUserPHID($user_phid) {
$this->userPHID = $user_phid;
return $this;
}
public function getUserPHID() {
return $this->userPHID;
}
public function setName($name) {
$this->name = $name;
return $this;

View file

@ -69,6 +69,8 @@ final class AphrontCalendarMonthView extends AphrontView {
$markup[] = $empty_box;
}
$show_events = array();
foreach ($days as $day) {
$holiday = idx($this->holidays, $day->format('Y-m-d'));
$class = 'aphront-calendar-day';
@ -80,18 +82,27 @@ final class AphrontCalendarMonthView extends AphrontView {
$day->setTime(0, 0, 0);
$epoch_start = $day->format('U');
$day->setTime(23, 59, 59);
$day->setTime(24, 0, 0);
$epoch_end = $day->format('U');
$show_events = array();
if ($weekday == 0) {
$show_events = array();
} else {
$show_events = array_fill_keys(
array_keys($show_events),
'<div class="aphront-calendar-event aphront-calendar-event-empty">'.
'&nbsp;'.
'</div>');
}
foreach ($events as $event) {
if ($event->getEpochStart() > $epoch_end) {
if ($event->getEpochStart() >= $epoch_end) {
// This list is sorted, so we can stop looking.
break;
}
if ($event->getEpochStart() <= $epoch_end &&
$event->getEpochEnd() >= $epoch_start) {
$show_events[] = $this->renderEvent(
if ($event->getEpochStart() < $epoch_end &&
$event->getEpochEnd() > $epoch_start) {
$show_events[$event->getUserPHID()] = $this->renderEvent(
$event,
$day,
$epoch_start,
@ -101,18 +112,19 @@ final class AphrontCalendarMonthView extends AphrontView {
$holiday_markup = null;
if ($holiday) {
$name = phutil_escape_html($holiday->getName());
$holiday_markup =
'<div class="aphront-calendar-holiday">'.
phutil_escape_html($holiday->getName()).
'<div class="aphront-calendar-holiday" title="'.$name.'">'.
$name.
'</div>';
}
$markup[] =
'<div class="'.$class.'">'.
$holiday_markup.
'<div class="aphront-calendar-date-number">'.
$day->format('j').
'</div>'.
$holiday_markup.
implode("\n", $show_events).
'</div>';
}
@ -213,7 +225,7 @@ final class AphrontCalendarMonthView extends AphrontView {
if ($event_end > $epoch_end) {
$classes[] = 'aphront-calendar-event-continues-after';
$when[] = 'Ends '.phabricator_datetime($event_start, $user);
$when[] = 'Ends '.phabricator_datetime($event_end, $user);
} else {
$when[] = 'Ends at '.phabricator_time($event_end, $user);
}

View file

@ -36,9 +36,10 @@ table.aphront-calendar-view td div.aphront-calendar-day {
}
.aphront-calendar-holiday {
float: left;
color: #666666;
padding: .5em;
max-height: 1em;
overflow: hidden;
}
.aphront-calendar-date-number {
@ -83,6 +84,11 @@ table.aphront-calendar-view td div.aphront-calendar-day {
overflow: hidden;
}
.aphront-calendar-event-empty {
border-color: transparent;
background: transparent;
}
.aphront-calendar-event-text {
overflow: hidden;
white-space: nowrap;