mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-01 18:30:59 +01:00
Fix event pagination in month views
Summary: Closes T7927, Fix event pagination in month views. Test Plan: Querying for events in month view should display max that month's events and min the subset of days selected. Reviewers: #blessed_reviewers, epriestley Reviewed By: #blessed_reviewers, epriestley Subscribers: Korvin, epriestley Maniphest Tasks: T7927 Differential Revision: https://secure.phabricator.com/D12661
This commit is contained in:
parent
25b1fb1de2
commit
0c1f367c92
5 changed files with 105 additions and 27 deletions
|
@ -42,7 +42,7 @@ final class PhabricatorCalendarApplication extends PhabricatorApplication {
|
||||||
return array(
|
return array(
|
||||||
'/E(?P<id>[1-9]\d*)' => 'PhabricatorCalendarEventViewController',
|
'/E(?P<id>[1-9]\d*)' => 'PhabricatorCalendarEventViewController',
|
||||||
'/calendar/' => array(
|
'/calendar/' => array(
|
||||||
'(?:query/(?P<queryKey>[^/]+)/)?'
|
'(?:query/(?P<queryKey>[^/]+)/(?:(?P<year>\d+)/(?P<month>\d+)/)?)?'
|
||||||
=> 'PhabricatorCalendarEventListController',
|
=> 'PhabricatorCalendarEventListController',
|
||||||
'event/' => array(
|
'event/' => array(
|
||||||
'create/'
|
'create/'
|
||||||
|
|
|
@ -3,20 +3,22 @@
|
||||||
final class PhabricatorCalendarEventListController
|
final class PhabricatorCalendarEventListController
|
||||||
extends PhabricatorCalendarController {
|
extends PhabricatorCalendarController {
|
||||||
|
|
||||||
private $queryKey;
|
|
||||||
|
|
||||||
public function shouldAllowPublic() {
|
public function shouldAllowPublic() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function willProcessRequest(array $data) {
|
public function handleRequest(AphrontRequest $request) {
|
||||||
$this->queryKey = idx($data, 'queryKey');
|
$year = $request->getURIData('year');
|
||||||
}
|
$month = $request->getURIData('month');
|
||||||
|
$engine = new PhabricatorCalendarEventSearchEngine();
|
||||||
|
|
||||||
|
if ($month && $year) {
|
||||||
|
$engine->setCalendarYearAndMonth($year, $month);
|
||||||
|
}
|
||||||
|
|
||||||
public function processRequest() {
|
|
||||||
$controller = id(new PhabricatorApplicationSearchController())
|
$controller = id(new PhabricatorApplicationSearchController())
|
||||||
->setQueryKey($this->queryKey)
|
->setQueryKey($request->getURIData('queryKey'))
|
||||||
->setSearchEngine(new PhabricatorCalendarEventSearchEngine())
|
->setSearchEngine($engine)
|
||||||
->setNavigation($this->buildSideNav());
|
->setNavigation($this->buildSideNav());
|
||||||
return $this->delegateToController($controller);
|
return $this->delegateToController($controller);
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,9 @@
|
||||||
final class PhabricatorCalendarEventSearchEngine
|
final class PhabricatorCalendarEventSearchEngine
|
||||||
extends PhabricatorApplicationSearchEngine {
|
extends PhabricatorApplicationSearchEngine {
|
||||||
|
|
||||||
|
private $calendarYear;
|
||||||
|
private $calendarMonth;
|
||||||
|
|
||||||
public function getResultTypeDescription() {
|
public function getResultTypeDescription() {
|
||||||
return pht('Calendar Events');
|
return pht('Calendar Events');
|
||||||
}
|
}
|
||||||
|
@ -47,6 +50,7 @@ final class PhabricatorCalendarEventSearchEngine
|
||||||
|
|
||||||
public function buildQueryFromSavedQuery(PhabricatorSavedQuery $saved) {
|
public function buildQueryFromSavedQuery(PhabricatorSavedQuery $saved) {
|
||||||
$query = id(new PhabricatorCalendarEventQuery());
|
$query = id(new PhabricatorCalendarEventQuery());
|
||||||
|
$viewer = $this->requireViewer();
|
||||||
|
|
||||||
$min_range = null;
|
$min_range = null;
|
||||||
$max_range = null;
|
$max_range = null;
|
||||||
|
@ -59,6 +63,33 @@ final class PhabricatorCalendarEventSearchEngine
|
||||||
$max_range = $saved->getParameter('rangeEnd');
|
$max_range = $saved->getParameter('rangeEnd');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($saved->getParameter('display') == 'month') {
|
||||||
|
list($start_month, $start_year) = $this->getDisplayMonthAndYear($saved);
|
||||||
|
$start_day = 1;
|
||||||
|
|
||||||
|
$end_year = ($start_month == 12) ? $start_year + 1 : $start_year;
|
||||||
|
$end_month = ($start_month == 12) ? 1 : $start_month + 1;
|
||||||
|
$end_day = 1;
|
||||||
|
|
||||||
|
$calendar_start = AphrontFormDateControlValue::newFromParts(
|
||||||
|
$viewer,
|
||||||
|
$start_year,
|
||||||
|
$start_month,
|
||||||
|
$start_day)->getEpoch();
|
||||||
|
$calendar_end = AphrontFormDateControlValue::newFromParts(
|
||||||
|
$viewer,
|
||||||
|
$end_year,
|
||||||
|
$end_month,
|
||||||
|
$end_day)->getEpoch();
|
||||||
|
|
||||||
|
if (!$min_range || ($min_range < $calendar_start)) {
|
||||||
|
$min_range = $calendar_start;
|
||||||
|
}
|
||||||
|
if (!$max_range || ($max_range > $calendar_end)) {
|
||||||
|
$max_range = $calendar_end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ($saved->getParameter('upcoming')) {
|
if ($saved->getParameter('upcoming')) {
|
||||||
if ($min_range) {
|
if ($min_range) {
|
||||||
$min_range = max(time(), $min_range);
|
$min_range = max(time(), $min_range);
|
||||||
|
@ -178,6 +209,13 @@ final class PhabricatorCalendarEventSearchEngine
|
||||||
return $names;
|
return $names;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setCalendarYearAndMonth($year, $month) {
|
||||||
|
$this->calendarYear = $year;
|
||||||
|
$this->calendarMonth = $month;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function buildSavedQueryFromBuiltin($query_key) {
|
public function buildSavedQueryFromBuiltin($query_key) {
|
||||||
$query = $this->newSavedQuery();
|
$query = $this->newSavedQuery();
|
||||||
$query->setQueryKey($query_key);
|
$query->setQueryKey($query_key);
|
||||||
|
@ -252,25 +290,21 @@ final class PhabricatorCalendarEventSearchEngine
|
||||||
$viewer = $this->requireViewer();
|
$viewer = $this->requireViewer();
|
||||||
$now = time();
|
$now = time();
|
||||||
|
|
||||||
$epoch = $query->getParameter('rangeStart');
|
list($start_month, $start_year) = $this->getDisplayMonthAndYear($query);
|
||||||
if (!$epoch) {
|
|
||||||
$epoch = $query->getParameter('rangeEnd');
|
|
||||||
if (!$epoch) {
|
|
||||||
$epoch = time();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$year = phabricator_format_local_time($epoch, $viewer, 'Y');
|
|
||||||
$month = phabricator_format_local_time($epoch, $viewer, 'm');
|
|
||||||
|
|
||||||
$now_year = phabricator_format_local_time($now, $viewer, 'Y');
|
$now_year = phabricator_format_local_time($now, $viewer, 'Y');
|
||||||
$now_month = phabricator_format_local_time($now, $viewer, 'm');
|
$now_month = phabricator_format_local_time($now, $viewer, 'm');
|
||||||
$now_day = phabricator_format_local_time($now, $viewer, 'j');
|
$now_day = phabricator_format_local_time($now, $viewer, 'j');
|
||||||
|
|
||||||
if ($month == $now_month && $year == $now_year) {
|
if ($start_month == $now_month && $start_year == $now_year) {
|
||||||
$month_view = new PHUICalendarMonthView($month, $year, $now_day);
|
$month_view = new PHUICalendarMonthView(
|
||||||
|
$start_month,
|
||||||
|
$start_year,
|
||||||
|
$now_day);
|
||||||
} else {
|
} else {
|
||||||
$month_view = new PHUICalendarMonthView($month, $year);
|
$month_view = new PHUICalendarMonthView(
|
||||||
|
$start_month,
|
||||||
|
$start_year);
|
||||||
}
|
}
|
||||||
|
|
||||||
$month_view->setUser($viewer);
|
$month_view->setUser($viewer);
|
||||||
|
@ -309,9 +343,37 @@ final class PhabricatorCalendarEventSearchEngine
|
||||||
$month_view->addEvent($event);
|
$month_view->addEvent($event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$month_view->setBrowseURI(
|
||||||
|
$this->getURI('query/'.$query->getQueryKey().'/'));
|
||||||
|
|
||||||
return $month_view;
|
return $month_view;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getDisplayMonthAndYear(
|
||||||
|
PhabricatorSavedQuery $query) {
|
||||||
|
$viewer = $this->requireViewer();
|
||||||
|
|
||||||
|
// get month/year from url
|
||||||
|
if ($this->calendarYear && $this->calendarMonth) {
|
||||||
|
$start_year = $this->calendarYear;
|
||||||
|
$start_month = $this->calendarMonth;
|
||||||
|
} else {
|
||||||
|
$epoch = $query->getParameter('rangeStart');
|
||||||
|
if (!$epoch) {
|
||||||
|
$epoch = $query->getParameter('rangeEnd');
|
||||||
|
if (!$epoch) {
|
||||||
|
$epoch = time();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$start_year = phabricator_format_local_time($epoch, $viewer, 'Y');
|
||||||
|
$start_month = phabricator_format_local_time($epoch, $viewer, 'm');
|
||||||
|
}
|
||||||
|
|
||||||
|
return array($start_month, $start_year);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getPageSize(PhabricatorSavedQuery $saved) {
|
||||||
|
return $saved->getParameter('limit', 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,23 @@ final class AphrontFormDateControlValue extends Phobject {
|
||||||
return ($this->getEpoch() !== null);
|
return ($this->getEpoch() !== null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function newFromParts(
|
||||||
|
PhabricatorUser $viewer,
|
||||||
|
$year,
|
||||||
|
$month,
|
||||||
|
$day,
|
||||||
|
$time = '12:00 AM') {
|
||||||
|
|
||||||
|
$value = new AphrontFormDateControlValue();
|
||||||
|
$value->viewer = $viewer;
|
||||||
|
$value->valueYear = $year;
|
||||||
|
$value->valueMonth = $month;
|
||||||
|
$value->valueDay = $day;
|
||||||
|
$value->valueTime = $time;
|
||||||
|
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
|
||||||
public static function newFromRequest($request, $key) {
|
public static function newFromRequest($request, $key) {
|
||||||
$value = new AphrontFormDateControlValue();
|
$value = new AphrontFormDateControlValue();
|
||||||
$value->viewer = $request->getViewer();
|
$value->viewer = $request->getViewer();
|
||||||
|
|
|
@ -205,14 +205,11 @@ final class PHUICalendarMonthView extends AphrontView {
|
||||||
// check for a browseURI, which means we need "fancy" prev / next UI
|
// check for a browseURI, which means we need "fancy" prev / next UI
|
||||||
$uri = $this->getBrowseURI();
|
$uri = $this->getBrowseURI();
|
||||||
if ($uri) {
|
if ($uri) {
|
||||||
$uri = new PhutilURI($uri);
|
|
||||||
list($prev_year, $prev_month) = $this->getPrevYearAndMonth();
|
list($prev_year, $prev_month) = $this->getPrevYearAndMonth();
|
||||||
$query = array('year' => $prev_year, 'month' => $prev_month);
|
$prev_uri = $uri.$prev_year.'/'.$prev_month.'/';
|
||||||
$prev_uri = (string) $uri->setQueryParams($query);
|
|
||||||
|
|
||||||
list($next_year, $next_month) = $this->getNextYearAndMonth();
|
list($next_year, $next_month) = $this->getNextYearAndMonth();
|
||||||
$query = array('year' => $next_year, 'month' => $next_month);
|
$next_uri = $uri.$next_year.'/'.$next_month.'/';
|
||||||
$next_uri = (string) $uri->setQueryParams($query);
|
|
||||||
|
|
||||||
$button_bar = new PHUIButtonBarView();
|
$button_bar = new PHUIButtonBarView();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue