1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-24 13:38:19 +01:00

Add optional keystroke support for AphrontPagerView

Summary: This is sort of silly but maybe useful? The real problem is that there
are like 500k conduit call logs and the real solution to that is better
filtering options, but this seems sort of okay.

Test Plan: Used "[" and "]" to switch between pages on the conduit call log.

Reviewers: btrahan, jungejason, nh, aran

Reviewed By: nh

CC: aran, nh, epriestley

Differential Revision: 1145
This commit is contained in:
epriestley 2011-11-30 15:59:02 -08:00
parent 77a5a3ab00
commit bd520076f9
5 changed files with 94 additions and 10 deletions

View file

@ -248,6 +248,17 @@ celerity_register_resource_map(array(
), ),
'disk' => '/rsrc/js/javelin/lib/behavior.js', 'disk' => '/rsrc/js/javelin/lib/behavior.js',
), ),
0 =>
array(
'uri' => '/res/b6096fdd/rsrc/js/javelin/lib/__tests__/URI.js',
'type' => 'js',
'requires' =>
array(
0 => 'javelin-uri',
1 => 'javelin-php-serializer',
),
'disk' => '/rsrc/js/javelin/lib/__tests__/URI.js',
),
'javelin-behavior-aphront-basic-tokenizer' => 'javelin-behavior-aphront-basic-tokenizer' =>
array( array(
'uri' => '/res/9be30797/rsrc/js/application/core/behavior-tokenizer.js', 'uri' => '/res/9be30797/rsrc/js/application/core/behavior-tokenizer.js',
@ -675,6 +686,18 @@ celerity_register_resource_map(array(
), ),
'disk' => '/rsrc/js/application/owners/owners-path-editor.js', 'disk' => '/rsrc/js/application/owners/owners-path-editor.js',
), ),
'javelin-behavior-phabricator-keyboard-pager' =>
array(
'uri' => '/res/56d64eff/rsrc/js/application/core/behavior-keyboard-pager.js',
'type' => 'js',
'requires' =>
array(
0 => 'javelin-behavior',
1 => 'javelin-uri',
2 => 'phabricator-keyboard-shortcut',
),
'disk' => '/rsrc/js/application/core/behavior-keyboard-pager.js',
),
'javelin-behavior-phabricator-keyboard-shortcuts' => 'javelin-behavior-phabricator-keyboard-shortcuts' =>
array( array(
'uri' => '/res/94b009e2/rsrc/js/application/core/behavior-keyboard-shortcuts.js', 'uri' => '/res/94b009e2/rsrc/js/application/core/behavior-keyboard-shortcuts.js',

View file

@ -32,7 +32,7 @@ class PhabricatorConduitLogController extends PhabricatorConduitController {
$nav = new AphrontSideNavView(); $nav = new AphrontSideNavView();
$links = array( $links = array(
'calls' => 'All Calls', 'calls' => 'All Calls',
); );
if (empty($links[$this->view])) { if (empty($links[$this->view])) {
@ -65,6 +65,7 @@ class PhabricatorConduitLogController extends PhabricatorConduitController {
$pager->getPageSize() + 1); $pager->getPageSize() + 1);
$calls = $pager->sliceResults($calls); $calls = $pager->sliceResults($calls);
$pager->setURI(new PhutilURI('/conduit/log/view/'.$this->view.'/'), 'page'); $pager->setURI(new PhutilURI('/conduit/log/view/'.$this->view.'/'), 'page');
$pager->setEnableKeyboardShortcuts(true);
$min = $pager->getOffset() + 1; $min = $pager->getOffset() + 1;
$max = ($min + count($calls) - 1); $max = ($min + count($calls) - 1);

View file

@ -27,6 +27,7 @@ final class AphrontPagerView extends AphrontView {
private $uri; private $uri;
private $pagingParameter; private $pagingParameter;
private $surroundingPages = 2; private $surroundingPages = 2;
private $enableKeyboardShortcuts;
final public function setPageSize($page_size) { final public function setPageSize($page_size) {
$this->pageSize = max(1, $page_size); $this->pageSize = max(1, $page_size);
@ -106,6 +107,11 @@ final class AphrontPagerView extends AphrontView {
return $results; return $results;
} }
public function setEnableKeyboardShortcuts($enable) {
$this->enableKeyboardShortcuts = $enable;
return $this;
}
public function render() { public function render() {
if (!$this->uri) { if (!$this->uri) {
throw new Exception( throw new Exception(
@ -146,12 +152,16 @@ final class AphrontPagerView extends AphrontView {
$links = array(); $links = array();
$prev_index = null;
$next_index = null;
if ($min > 0) { if ($min > 0) {
$links[] = array(0, 'First', null); $links[] = array(0, 'First', null);
} }
if ($page > 0) { if ($page > 0) {
$links[] = array($page - 1, 'Prev', null); $links[] = array($page - 1, 'Prev', null);
$prev_index = $page - 1;
} }
for ($ii = $min; $ii <= $max; $ii++) { for ($ii = $min; $ii <= $max; $ii++) {
@ -160,6 +170,7 @@ final class AphrontPagerView extends AphrontView {
if ($page < $last && $last > 0) { if ($page < $last && $last > 0) {
$links[] = array($page + 1, 'Next', null); $links[] = array($page + 1, 'Next', null);
$next_index = $page + 1;
} }
if ($max < ($last - 1)) { if ($max < ($last - 1)) {
@ -168,20 +179,29 @@ final class AphrontPagerView extends AphrontView {
$base_uri = $this->uri; $base_uri = $this->uri;
$parameter = $this->pagingParameter; $parameter = $this->pagingParameter;
$page_size = $this->getPageSize();
if ($this->enableKeyboardShortcuts) {
$pager_links = array();
$pager_index = array(
'prev' => $prev_index,
'next' => $next_index,
);
foreach ($pager_index as $key => $index) {
if ($index !== null) {
$display_index = $this->getDisplayIndex($index);
$pager_links[$key] = (string)$base_uri->alter(
$parameter,
$display_index);
}
}
Javelin::initBehavior('phabricator-keyboard-pager', $pager_links);
}
// Convert tuples into rendered nodes. // Convert tuples into rendered nodes.
$rendered_links = array(); $rendered_links = array();
foreach ($links as $link) { foreach ($links as $link) {
list($index, $label, $class) = $link; list($index, $label, $class) = $link;
// Use a 1-based sequence for display so that the number in the URI is $display_index = $this->getDisplayIndex($index);
// the same as the page number you're on.
if ($index == 0) {
// No need for the first page to say page=1.
$display_index = null;
} else {
$display_index = $index * $page_size;
}
$link = $base_uri->alter($parameter, $display_index); $link = $base_uri->alter($parameter, $display_index);
$rendered_links[] = phutil_render_tag( $rendered_links[] = phutil_render_tag(
'a', 'a',
@ -198,4 +218,17 @@ final class AphrontPagerView extends AphrontView {
'</div>'; '</div>';
} }
private function getDisplayIndex($page_index) {
$page_size = $this->getPageSize();
// Use a 1-based sequence for display so that the number in the URI is
// the same as the page number you're on.
if ($page_index == 0) {
// No need for the first page to say page=1.
$display_index = null;
} else {
$display_index = $page_index * $page_size;
}
return $display_index;
}
} }

View file

@ -7,6 +7,7 @@
phutil_require_module('phabricator', 'infrastructure/celerity/api'); phutil_require_module('phabricator', 'infrastructure/celerity/api');
phutil_require_module('phabricator', 'infrastructure/javelin/api');
phutil_require_module('phabricator', 'view/base'); phutil_require_module('phabricator', 'view/base');
phutil_require_module('phutil', 'markup'); phutil_require_module('phutil', 'markup');

View file

@ -0,0 +1,26 @@
/**
* @provides javelin-behavior-phabricator-keyboard-pager
* @requires javelin-behavior
* javelin-uri
* phabricator-keyboard-shortcut
*/
JX.behavior('phabricator-keyboard-pager', function(config) {
new JX.KeyboardShortcut('[', 'Prev Page')
.setHandler(function(manager) {
if (config.prev) {
JX.$U(config.prev).go();
}
})
.register();
new JX.KeyboardShortcut(']', 'Next Page')
.setHandler(function(manager) {
if (config.next) {
JX.$U(config.next).go();
}
})
.register();
});