mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-25 00:02:41 +01:00
7969f66dfe
Summary: Ref T10077. Currently, we issue 6+ queries on every page to build this menu, since the menu is built application-by-application. Build the menu with dedicated modules instead so a single "EditEngine" module can provide all of them with one query. I'd like to reduce this to 0 queries but I'm not totally sure what we want to do with this menu. This change removes these items, because EditEngine can not currently provide them: - Calendar: Eventually via EditEngine eventually. - Conpherence: Probably via EditEngine, doesn't seem too important. - People: Maybe via EditEngine, doesn't seem too important? "Welcome" is likely better? - Pholio: Eventually via EditEngine. It adds a bunch of other items as a side effect: {F1677151} This reduces the queries issued on every page by ~5. This also makes quick create actions visible while logged out (see T7073). Test Plan: - Viewed menu while logged in. - Viewed menu while logged out. - Viewed standalone version of menu. Reviewers: chad Reviewed By: chad Maniphest Tasks: T10077 Differential Revision: https://secure.phabricator.com/D16045
90 lines
2.6 KiB
PHP
90 lines
2.6 KiB
PHP
<?php
|
|
|
|
final class PhabricatorCalendarApplication extends PhabricatorApplication {
|
|
|
|
public function getName() {
|
|
return pht('Calendar');
|
|
}
|
|
|
|
public function getShortDescription() {
|
|
return pht('Upcoming Events');
|
|
}
|
|
|
|
public function getFlavorText() {
|
|
return pht('Never miss an episode ever again.');
|
|
}
|
|
|
|
public function getBaseURI() {
|
|
return '/calendar/';
|
|
}
|
|
|
|
public function getIcon() {
|
|
return 'fa-calendar';
|
|
}
|
|
|
|
public function getTitleGlyph() {
|
|
// Unicode has a calendar character but it's in some distant code plane,
|
|
// use "keyboard" since it looks vaguely similar.
|
|
return "\xE2\x8C\xA8";
|
|
}
|
|
|
|
public function isPrototype() {
|
|
return true;
|
|
}
|
|
|
|
public function getRemarkupRules() {
|
|
return array(
|
|
new PhabricatorCalendarRemarkupRule(),
|
|
);
|
|
}
|
|
|
|
public function getRoutes() {
|
|
return array(
|
|
'/E(?P<id>[1-9]\d*)(?:/(?P<sequence>\d+))?'
|
|
=> 'PhabricatorCalendarEventViewController',
|
|
'/calendar/' => array(
|
|
'(?:query/(?P<queryKey>[^/]+)/(?:(?P<year>\d+)/'.
|
|
'(?P<month>\d+)/)?(?:(?P<day>\d+)/)?)?'
|
|
=> 'PhabricatorCalendarEventListController',
|
|
'event/' => array(
|
|
'create/'
|
|
=> 'PhabricatorCalendarEventEditController',
|
|
'edit/(?P<id>[1-9]\d*)/(?:(?P<sequence>\d+)/)?'
|
|
=> 'PhabricatorCalendarEventEditController',
|
|
'drag/(?P<id>[1-9]\d*)/'
|
|
=> 'PhabricatorCalendarEventDragController',
|
|
'cancel/(?P<id>[1-9]\d*)/(?:(?P<sequence>\d+)/)?'
|
|
=> 'PhabricatorCalendarEventCancelController',
|
|
'(?P<action>join|decline|accept)/(?P<id>[1-9]\d*)/'
|
|
=> 'PhabricatorCalendarEventJoinController',
|
|
'comment/(?P<id>[1-9]\d*)/(?:(?P<sequence>\d+)/)?'
|
|
=> 'PhabricatorCalendarEventCommentController',
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
public function getHelpDocumentationArticles(PhabricatorUser $viewer) {
|
|
return array(
|
|
array(
|
|
'name' => pht('Calendar User Guide'),
|
|
'href' => PhabricatorEnv::getDoclink('Calendar User Guide'),
|
|
),
|
|
);
|
|
}
|
|
|
|
public function getMailCommandObjects() {
|
|
return array(
|
|
'event' => array(
|
|
'name' => pht('Email Commands: Events'),
|
|
'header' => pht('Interacting with Calendar Events'),
|
|
'object' => new PhabricatorCalendarEvent(),
|
|
'summary' => pht(
|
|
'This page documents the commands you can use to interact with '.
|
|
'events in Calendar. These commands work when creating new tasks '.
|
|
'via email and when replying to existing tasks.'),
|
|
),
|
|
);
|
|
}
|
|
|
|
}
|