1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-09-20 09:18:48 +02:00

Always draw images with Javascript

Summary:
Currently, we use two different methods to draw Mock main images:

  - When the page first loads, we draw the image on the server with PHP.
  - When the user clicks a thumbnail, we draw the image on the client with JS.

Since we can't reasonably get rid of the client version of this, move it all to the client. This paves the way for some future features, like:

  - Doing some magic with stage sizing
  - URIs that jump to a specific comment
  - showing "loading" indicators while images are loading
  - Loading lowsrc images first?

Test Plan: Loaded page, clicked thumbs.

Reviewers: ljalonen, chad

Reviewed By: chad

CC: aran

Differential Revision: https://secure.phabricator.com/D5073
This commit is contained in:
epriestley 2013-02-22 10:34:32 -08:00
parent 5fdaebf158
commit 9b17870611
3 changed files with 56 additions and 32 deletions

View file

@ -1873,7 +1873,7 @@ celerity_register_resource_map(array(
),
'javelin-behavior-pholio-mock-view' =>
array(
'uri' => '/res/84215004/rsrc/js/application/pholio/behavior-pholio-mock-view.js',
'uri' => '/res/893b9f91/rsrc/js/application/pholio/behavior-pholio-mock-view.js',
'type' => 'js',
'requires' =>
array(
@ -3217,7 +3217,7 @@ celerity_register_resource_map(array(
),
'pholio-css' =>
array(
'uri' => '/res/3b87f5ae/rsrc/css/application/pholio/pholio.css',
'uri' => '/res/ecd07cd8/rsrc/css/application/pholio/pholio.css',
'type' => 'css',
'requires' =>
array(

View file

@ -14,28 +14,38 @@ final class PholioMockImagesView extends AphrontView {
throw new Exception("Call setMock() before render()!");
}
$mock = $this->mock;
$main_image_id = celerity_generate_unique_node_id();
require_celerity_resource('javelin-behavior-pholio-mock-view');
$images = array();
foreach ($mock->getImages() as $image) {
$images[] = array(
'id' => $image->getID(),
'fullURI' => $image->getFile()->getBestURI(),
);
}
$config = array(
'mainID' => $main_image_id,
'mockID' => $this->mock->getID());
'mockID' => $mock->getID(),
'images' => $images,
);
Javelin::initBehavior('pholio-mock-view', $config);
$mockview = '';
$main_image = head($this->mock->getImages());
$main_image = head($mock->getImages());
$main_image_tag = javelin_tag(
'img',
array(
'id' => $main_image_id,
'src' => $main_image->getFile()->getBestURI(),
'sigil' => 'mock-image',
'class' => 'pholio-mock-image',
'meta' => array(
'fullSizeURI' => $main_image->getFile()->getBestURI(),
'imageID' => $main_image->getID(),
),
'style' => 'display: none;',
));
$main_image_tag = javelin_tag(
@ -64,9 +74,9 @@ final class PholioMockImagesView extends AphrontView {
),
array($main_image_tag, $inline_comments_holder));
if (count($this->mock->getImages()) > 1) {
if (count($mock->getImages()) > 1) {
$thumbnails = array();
foreach ($this->mock->getImages() as $image) {
foreach ($mock->getImages() as $image) {
$thumbfile = $image->getFile();
$dimensions = PhabricatorImageTransformer::getPreviewDimensions(
@ -89,8 +99,7 @@ final class PholioMockImagesView extends AphrontView {
'sigil' => 'mock-thumbnail',
'class' => 'pholio-mock-carousel-thumb-item',
'meta' => array(
'fullSizeURI' => $thumbfile->getBestURI(),
'imageID' => $image->getID()
'imageID' => $image->getID(),
),
),
$tag);

View file

@ -19,27 +19,42 @@ JX.behavior('pholio-mock-view', function(config) {
var selection_border;
var selection_fill;
var active_image;
function get_image(id) {
for (var ii = 0; ii < config.images.length; ii++) {
if (config.images[ii].id == id) {
return config.images[ii];
}
}
return null;
}
function select_image(image_id) {
var image = get_image(image_id);
active_image = image;
var main = JX.$(config.mainID);
main.src = image.fullURI;
JX.DOM.show(main);
// NOTE: This is to clear inline comment reticles.
JX.DOM.setContent(wrapper, main);
load_inline_comments();
}
JX.Stratcom.listen(
'click', // Listen for clicks...
'mock-thumbnail', // ...on nodes with sigil "mock-thumbnail".
'click',
'mock-thumbnail',
function(e) {
var data = e.getNodeData('mock-thumbnail');
var main = JX.$(config.mainID);
JX.Stratcom.addData(
main,
{
fullSizeURI: data['fullSizeURI'],
imageID: data['imageID']
});
main.src = data.fullSizeURI;
JX.DOM.setContent(wrapper,main);
load_inline_comments();
e.kill();
select_image(e.getNodeData('mock-thumbnail').imageID);
});
// Select and show the first image.
select_image(config.images[0].id);
function draw_rectangle(nodes, current, init) {
for (var ii = 0; ii < nodes.length; ii++) {
var node = nodes[ii];
@ -143,11 +158,11 @@ JX.behavior('pholio-mock-view', function(config) {
});
function load_inline_comments() {
var data = JX.Stratcom.getData(JX.$(config.mainID));
var comment_holder = JX.$('mock-inline-comments');
JX.DOM.setContent(comment_holder, '');
var inline_comments_uri = "/pholio/inline/" + data['imageID'] + "/";
var id = active_image.id;
var inline_comments_uri = "/pholio/inline/" + id + "/";
var inline_comments = new JX.Request(inline_comments_uri, function(r) {
if (r.length > 0) {
@ -339,7 +354,7 @@ JX.behavior('pholio-mock-view', function(config) {
var commentToAdd = {
mockID: config.mockID,
op: 'save',
imageID: imageData['imageID'],
imageID: active_image.id,
startX: Math.min(startPos.x, endPos.x),
startY: Math.min(startPos.y, endPos.y),
endX: Math.max(startPos.x,endPos.x),