rm'ed gemfile.lock

This commit is contained in:
Metamaps on Linode 2013-03-17 10:49:49 -04:00
commit cdf0a2d5e6
19 changed files with 394 additions and 266 deletions

View file

@ -1,145 +0,0 @@
GEM
remote: https://rubygems.org/
specs:
actionmailer (3.2.11)
actionpack (= 3.2.11)
mail (~> 2.4.4)
actionpack (3.2.11)
activemodel (= 3.2.11)
activesupport (= 3.2.11)
builder (~> 3.0.0)
erubis (~> 2.7.0)
journey (~> 1.0.4)
rack (~> 1.4.0)
rack-cache (~> 1.2)
rack-test (~> 0.6.1)
sprockets (~> 2.2.1)
activemodel (3.2.11)
activesupport (= 3.2.11)
builder (~> 3.0.0)
activerecord (3.2.11)
activemodel (= 3.2.11)
activesupport (= 3.2.11)
arel (~> 3.0.2)
tzinfo (~> 0.3.29)
activeresource (3.2.11)
activemodel (= 3.2.11)
activesupport (= 3.2.11)
activesupport (3.2.11)
i18n (~> 0.6)
multi_json (~> 1.0)
arel (3.0.2)
authlogic (3.1.0)
activerecord (>= 3.0.7)
activerecord (>= 3.0.7)
best_in_place (2.0.2)
jquery-rails
rails (~> 3.1)
builder (3.0.4)
cancan (1.6.7)
coffee-rails (3.2.2)
coffee-script (>= 2.2.0)
railties (~> 3.2.0)
coffee-script (2.2.0)
coffee-script-source
execjs
coffee-script-source (1.3.3)
erubis (2.7.0)
execjs (1.4.0)
multi_json (~> 1.0)
formtastic (2.0.2)
rails (~> 3.0)
formula (0.3.3)
rails (> 3.0.0)
hike (1.2.1)
i18n (0.6.1)
jbuilder (0.8.2)
activesupport (>= 3.0.0)
journey (1.0.4)
jquery-rails (2.1.2)
railties (>= 3.1.0, < 5.0)
thor (~> 0.14)
json (1.7.6)
libv8 (3.11.8.13)
mail (2.4.4)
i18n (>= 0.4.0)
mime-types (~> 1.16)
treetop (~> 1.4.8)
mime-types (1.19)
multi_json (1.5.0)
pg (0.12.2)
pg (0.12.2-x86-mingw32)
polyglot (0.3.3)
rack (1.4.3)
rack-cache (1.2)
rack (>= 0.4)
rack-ssl (1.3.2)
rack
rack-test (0.6.2)
rack (>= 1.0)
rails (3.2.11)
actionmailer (= 3.2.11)
actionpack (= 3.2.11)
activerecord (= 3.2.11)
activeresource (= 3.2.11)
activesupport (= 3.2.11)
bundler (~> 1.0)
railties (= 3.2.11)
rails3-jquery-autocomplete (1.0.10)
rails (~> 3.0)
railties (3.2.11)
actionpack (= 3.2.11)
activesupport (= 3.2.11)
rack-ssl (~> 1.3.2)
rake (>= 0.8.7)
rdoc (~> 3.4)
thor (>= 0.14.6, < 2.0)
rake (10.0.3)
rb-readline (0.4.2)
rdoc (3.12)
json (~> 1.4)
ref (1.0.2)
sass (3.2.7)
sass-rails (3.2.3)
railties (~> 3.2.0.beta)
sass (>= 3.1.10)
tilt (~> 1.3)
sprockets (2.2.2)
hike (~> 1.2)
multi_json (~> 1.0)
rack (~> 1.0)
tilt (~> 1.1, != 1.3.0)
therubyracer (0.11.4)
libv8 (~> 3.11.8.12)
ref
thor (0.16.0)
tilt (1.3.3)
treetop (1.4.12)
polyglot
polyglot (>= 0.3.1)
tzinfo (0.3.35)
uglifier (1.3.0)
execjs (>= 0.3.0)
multi_json (~> 1.0, >= 1.0.2)
PLATFORMS
ruby
x86-mingw32
DEPENDENCIES
authlogic
best_in_place
cancan
coffee-rails (~> 3.2.1)
formtastic
formula
jbuilder
jquery-rails (= 2.1.2)
json
pg
rails (= 3.2.11)
rails3-jquery-autocomplete
rb-readline
sass-rails (= 3.2.3)
therubyracer
uglifier (>= 1.0.3)

46
Gemfile~ Normal file
View file

@ -0,0 +1,46 @@
source 'https://rubygems.org'
gem 'rails', '3.2.11'
# Bundle edge Rails instead:
# gem 'rails', :git => 'git://github.com/rails/rails.git'
gem 'pg'
gem 'authlogic'
gem 'cancan'
gem 'formula'
gem 'formtastic'
gem 'json'
gem 'rails3-jquery-autocomplete'
gem 'best_in_place'
#gem 'therubyracer' #optional
#gem 'rb-readline'
# Gems used only for assets and not required
# in production environments by default.
group :assets do
gem 'sass-rails', '~> 3.2.3'
gem 'coffee-rails', '~> 3.2.1'
# See https://github.com/sstephenson/execjs#readme for more supported runtimes
# gem 'therubyracer'
gem 'uglifier', '>= 1.0.3'
end
gem 'jquery-rails', '2.1.2'
# To use ActiveModel has_secure_password
# gem 'bcrypt-ruby', '~> 3.0.0'
# To use Jbuilder templates for JSON
gem 'jbuilder'
# Use unicorn as the web server
# gem 'unicorn'
# Deploy with Capistrano
# gem 'capistrano'
# To use debugger
# gem 'ruby-debug19', :require => 'ruby-debug'

View file

@ -85,7 +85,7 @@ var findMappers = ['name', 'topic (by name)', 'map (by name)', 'synapse (by topi
function hideAll(duration) { function hideAll(duration) {
if (duration == null) duration = 500; if (duration == null) duration = 500;
Mconsole.graph.eachNode( function (n) { Mconsole.graph.eachNode( function (n) {
if (!(n.getData('inCommons') || n.getData('onCanvas'))) { if (!(n.getData('greenCircle') || n.getData('whiteCircle'))) {
n.setData('alpha', 0.4, 'end'); n.setData('alpha', 0.4, 'end');
n.eachAdjacency(function(adj) { n.eachAdjacency(function(adj) {
adj.setData('alpha', 0.4, 'end'); adj.setData('alpha', 0.4, 'end');
@ -120,26 +120,26 @@ function onCanvasSearch(searchQuery, mapID, mapperID) {
nodeName = n.name.toLowerCase(); nodeName = n.name.toLowerCase();
if (name != null) { if (name != null) {
if (nodeName.indexOf(searchQuery) !== -1 && searchQuery != "") { if (nodeName.indexOf(searchQuery) !== -1 && searchQuery != "") {
n.setData('onCanvas', true); n.setData('whiteCircle', true);
} }
else { else {
n.setData('onCanvas', false); n.setData('whiteCircle', false);
} }
} }
else if (mapID != null) { else if (mapID != null) {
if (n.getData('inmaps').indexOf(parseInt(mapID)) !== -1) { if (n.getData('inmaps').indexOf(parseInt(mapID)) !== -1) {
n.setData('onCanvas', true); n.setData('whiteCircle', true);
} }
else { else {
n.setData('onCanvas', false); n.setData('whiteCircle', false);
} }
} }
else if (mapperID != null) { else if (mapperID != null) {
if (n.getData('userid').toString() == mapperID) { if (n.getData('userid').toString() == mapperID) {
n.setData('onCanvas', true); n.setData('whiteCircle', true);
} }
else { else {
n.setData('onCanvas', false); n.setData('whiteCircle', false);
} }
} }
Mconsole.plot(); Mconsole.plot();
@ -149,7 +149,9 @@ function onCanvasSearch(searchQuery, mapID, mapperID) {
function clearCanvas() { function clearCanvas() {
Mconsole.graph.eachNode(function(n) { Mconsole.graph.eachNode(function(n) {
Mconsole.graph.removeNode(n.id); Mconsole.graph.removeNode(n.id);
Mconsole.labels.disposeLabel(n.id); //TODO shouldn't we use disposeLabel? Yes, but it breaks things so it's
//hide for now
Mconsole.labels.hideLabel(n.id);
}); });
Mconsole.plot(); Mconsole.plot();
} }
@ -164,8 +166,7 @@ function clearCanvasExceptRoot() {
ids.forEach(function(id, index) { ids.forEach(function(id, index) {
if (id != root.id) { if (id != root.id) {
Mconsole.graph.removeNode(id); Mconsole.graph.removeNode(id);
//don't use disposeLabel or they'll never come back! //TODO is hideLabel correct? Maybe it is...
//maybe there's a better way that recreates the labels later??
Mconsole.labels.hideLabel(id); Mconsole.labels.hideLabel(id);
$('#topic_' + id + '_label').hide(); $('#topic_' + id + '_label').hide();
} }
@ -175,9 +176,11 @@ function clearCanvasExceptRoot() {
function clearFoundData() { function clearFoundData() {
Mconsole.graph.eachNode( function(n) { Mconsole.graph.eachNode( function(n) {
if (n.getData('inCommons') === true) { if (n.getData('greenCircle') === true) {
Mconsole.graph.removeNode(n.id); Mconsole.graph.removeNode(n.id);
Mconsole.labels.disposeLabel(n.id); //TODO is hideLabel correct? Maybe it is...
Mconsole.labels.hideLabel(n.id);
$('#topic_' + n.id + '_label').hide();
} }
}); });
Mconsole.plot(); Mconsole.plot();

View file

@ -33,12 +33,13 @@ function nodeDoubleClickHandler(node, e) {
return; return;
} }
if (node.getData('inCommons') == false) { //greenCircle being true denotes it's actually "in the commons" still
if (node.getData('greenCircle') == false) {
return; return;
} }
//this line adds it to the console if you close seek //this line adds it to the console if you close seek
node.setData('inCommons', false); node.setData('greenCircle', false);
//this is just aesthetic //this is just aesthetic
deselectNode(node); deselectNode(node);
@ -60,6 +61,9 @@ function nodeDoubleClickHandler(node, e) {
}//doubleClickNodeHandler }//doubleClickNodeHandler
/*
* Returns a boolean saying if the node was double clicked in our understanding of the word
*/
function nodeWasDoubleClicked() { function nodeWasDoubleClicked() {
//grab the timestamp of the click //grab the timestamp of the click
var storedTime = MetamapsModel.lastNodeClick; var storedTime = MetamapsModel.lastNodeClick;
@ -73,24 +77,6 @@ function nodeWasDoubleClicked() {
} }
}//nodeWasDoubleClicked; }//nodeWasDoubleClicked;
function selectNode(node) {
node.selected = true;
node.setData('dim', 30, 'current');
node.setData('onCanvas',true);
node.eachAdjacency(function (adj) {
selectEdge(adj);
});
}
function deselectNode(node) {
delete node.selected;
node.setData('onCanvas', false);
node.eachAdjacency(function(adj) {
deselectEdge(adj);
});
node.setData('dim', 25, 'current');
}
function selectNodeOnClickHandler(node, e) { function selectNodeOnClickHandler(node, e) {
if (Mconsole.busy) return; if (Mconsole.busy) return;
@ -150,17 +136,65 @@ function canvasDoubleClickHandler(canvasLoc,e) {
} }
}//canvasDoubleClickHandler }//canvasDoubleClickHandler
function handleSelectionBeforeDragging(node, e) {
// four cases:
// 1 nothing is selected, so pretend you aren't selecting
// 2 others are selected only and shift, so additionally select this one
// 3 others are selected only, no shift: drag only this one
// 4 this node and others were selected, so drag them (just return false)
//return value: deselect node again after?
if (MetamapsModel.selectedNodes.length == 0) {
selectNode(node);
return 'deselect';
}
if (MetamapsModel.selectedNodes.indexOf(node) == -1) {
if (e.shiftKey) {
selectNode(node);
return 'nothing';
} else {
return 'only-drag-this-one';
}
}
return 'nothing'; //case 4?
}
function onDragMoveTopicHandler(node, eventInfo, e) { function onDragMoveTopicHandler(node, eventInfo, e) {
if (node && !node.nodeFrom) { if (node && !node.nodeFrom) {
$('#new_synapse').fadeOut('fast'); $('#new_synapse').fadeOut('fast');
$('#new_topic').fadeOut('fast'); $('#new_topic').fadeOut('fast');
var pos = eventInfo.getPos(); var pos = eventInfo.getPos();
// if it's a left click, move the node // if it's a left click, or a touch, move the node
if (e.button == 0 && !e.altKey && (e.buttons == 0 || e.buttons == 1 || e.buttons == undefined)) { if ( e.touches || (e.button == 0 && !e.altKey && (e.buttons == 0 || e.buttons == 1 || e.buttons == undefined))) {
//if the node dragged isn't already selected, select it
var whatToDo = handleSelectionBeforeDragging(node, e);
if (whatToDo == 'only-drag-this-one') {
node.pos.setc(pos.x, pos.y);
node.setData('xloc', pos.x);
node.setData('yloc', pos.y);
} else {
var len = MetamapsModel.selectedNodes.length;
//first define offset for each node
var xOffset = new Array();
var yOffset = new Array();
for (var i = 0; i < len; i += 1) {
n = MetamapsModel.selectedNodes[i];
xOffset[i] = n.getData('xloc') - node.getData('xloc');
yOffset[i] = n.getData('yloc') - node.getData('yloc');
}//for
for (var i = 0; i < len; i += 1) {
n = MetamapsModel.selectedNodes[i];
n.pos.setc(pos.x + xOffset[i], pos.y + yOffset[i]);
n.setData('xloc', pos.x + xOffset[i]);
n.setData('yloc', pos.y + yOffset[i]);
}//for
}//if
if (whatToDo == 'deselect') {
deselectNode(node);
}
dragged = node.id; dragged = node.id;
node.pos.setc(pos.x, pos.y);
node.data.$xloc = pos.x;
node.data.$yloc = pos.y;
Mconsole.plot(); Mconsole.plot();
} }
// if it's a right click or holding down alt, start synapse creation ->third option is for firefox // if it's a right click or holding down alt, start synapse creation ->third option is for firefox
@ -204,3 +238,63 @@ function onDragMoveTopicHandler(node, eventInfo, e) {
} }
} }
} }
var lastDist = 0;
function getDistance(p1, p2) {
return Math.sqrt(Math.pow((p2.x - p1.x), 2) + Math.pow((p2.y - p1.y), 2));
}
function touchPanZoomHandler(eventInfo, e) {
if (e.touches.length == 1) {
var thispos = touchPos,
currentPos = eventInfo.getPos(),
canvas = Mconsole.canvas,
ox = canvas.translateOffsetX,
oy = canvas.translateOffsetY,
sx = canvas.scaleOffsetX,
sy = canvas.scaleOffsetY;
currentPos.x *= sx;
currentPos.y *= sy;
currentPos.x += ox;
currentPos.y += oy;
//var x = currentPos.x - thispos.x,
// y = currentPos.y - thispos.y;
var x = currentPos.x - thispos.x,
y = currentPos.y - thispos.y;
touchPos = currentPos;
Mconsole.canvas.translate(x * 1/sx, y * 1/sy);
}
else if (e.touches.length == 2) {
var touch1 = e.touches[0];
var touch2 = e.touches[1];
var dist = getDistance({
x: touch1.clientX,
y: touch1.clientY
}, {
x: touch2.clientX,
y: touch2.clientY
});
if(!lastDist) {
lastDist = dist;
}
var scale = dist / lastDist;
console.log(scale);
if (8 >= Mconsole.canvas.scaleOffsetX*scale && Mconsole.canvas.scaleOffsetX*scale >= 1) {
Mconsole.canvas.scale(scale, scale);
}
if (Mconsole.canvas.scaleOffsetX < 0.5) {
Mconsole.canvas.viz.labels.hideLabels(true);
}
else if (Mconsole.canvas.scaleOffsetX > 0.5) {
Mconsole.canvas.viz.labels.hideLabels(false);
}
lastDist = dist;
}
}

View file

@ -9,11 +9,13 @@ var MetamapsModel = new Object();
MetamapsModel.embed = false; MetamapsModel.embed = false;
//array of all selected edges //array of all selected edges, same for nodes
MetamapsModel.selectedEdges = new Array(); MetamapsModel.selectedEdges = new Array();
MetamapsModel.selectedNodes = new Array();
//is any showcard open right now? which one? //is any showcard open right now? which one?
MetamapsModel.showcardInUse = null; MetamapsModel.showcardInUse = null;
MetamapsModel.widthOfLabel = null;
//is the mouse hovering over an edge? which one? //is the mouse hovering over an edge? which one?
MetamapsModel.edgeHoveringOver = false; MetamapsModel.edgeHoveringOver = false;

View file

@ -67,16 +67,45 @@ function graphSettings(type, embed) {
onDragCancelHandler(node, eventInfo, e, false); onDragCancelHandler(node, eventInfo, e, false);
}, },
//Implement the same handler for touchscreens //Implement the same handler for touchscreens
onTouchStart: function (node, eventInfo, e) {
//$jit.util.event.stop(e); //stop default touchmove event
//Mconsole.events.onMouseDown(e, null, eventInfo);
Mconsole.events.touched = true;
touchPos = eventInfo.getPos();
var canvas = Mconsole.canvas,
ox = canvas.translateOffsetX;
oy = canvas.translateOffsetY,
sx = canvas.scaleOffsetX,
sy = canvas.scaleOffsetY;
touchPos.x *= sx;
touchPos.y *= sy;
touchPos.x += ox;
touchPos.y += oy;
touchDragNode = node;
},
//Implement the same handler for touchscreens
onTouchMove: function (node, eventInfo, e) { onTouchMove: function (node, eventInfo, e) {
$jit.util.event.stop(e); //stop default touchmove event if (touchDragNode) onDragMoveTopicHandler(touchDragNode, eventInfo, e);
this.onDragMove(node, eventInfo, e); else {
touchPanZoomHandler(eventInfo, e);
Mconsole.labels.hideLabel(Mconsole.graph.getNode(MetamapsModel.showcardInUse));
}
},
//Implement the same handler for touchscreens
onTouchEnd: function (node, eventInfo, e) {
},
//Implement the same handler for touchscreens
onTouchCancel: function (node, eventInfo, e) {
}, },
//Add also a click handler to nodes //Add also a click handler to nodes
onClick: function (node, eventInfo, e) { onClick: function (node, eventInfo, e) {
if (e.target.id != "infovis-canvas") return false; if (e.target.id != "infovis-canvas") return false;
//topic and synapse editing cards //topic and synapse editing cards
hideCards(); if (!Mconsole.events.moved) hideCards();
//clicking on a node, or clicking on blank part of canvas? //clicking on a node, or clicking on blank part of canvas?
if (node.nodeFrom) { if (node.nodeFrom) {
@ -84,6 +113,8 @@ function graphSettings(type, embed) {
} else if (node && !node.nodeFrom) { } else if (node && !node.nodeFrom) {
selectNodeOnClickHandler(node, e); selectNodeOnClickHandler(node, e);
} else { } else {
//topic and synapse editing cards
if (!Mconsole.events.moved) hideCards();
canvasDoubleClickHandler(eventInfo.getPos(), e); canvasDoubleClickHandler(eventInfo.getPos(), e);
}//if }//if
} }
@ -235,12 +266,12 @@ var nodeSettings = {
var pos = node.pos.getc(true), var pos = node.pos.getc(true),
dim = node.getData('dim'), dim = node.getData('dim'),
cat = node.getData('metacode'), cat = node.getData('metacode'),
inCommons = node.getData('inCommons'), greenCircle = node.getData('greenCircle'),
onCanvas = node.getData('onCanvas'), whiteCircle = node.getData('whiteCircle'),
ctx = canvas.getCtx(); ctx = canvas.getCtx();
// if the topic is from the Commons draw a green circle around it // if the topic is from the Commons draw a green circle around it
if (inCommons) { if (greenCircle) {
ctx.beginPath(); ctx.beginPath();
ctx.arc(pos.x, pos.y, dim+3, 0, 2 * Math.PI, false); ctx.arc(pos.x, pos.y, dim+3, 0, 2 * Math.PI, false);
ctx.strokeStyle = '#67be5f'; // green ctx.strokeStyle = '#67be5f'; // green
@ -248,7 +279,7 @@ var nodeSettings = {
ctx.stroke(); ctx.stroke();
} }
// if the topic is on the Canvas draw a white circle around it // if the topic is on the Canvas draw a white circle around it
if (onCanvas) { if (whiteCircle) {
ctx.beginPath(); ctx.beginPath();
ctx.arc(pos.x, pos.y, dim+3, 0, 2 * Math.PI, false); ctx.arc(pos.x, pos.y, dim+3, 0, 2 * Math.PI, false);
if (! MetamapsModel.embed) ctx.strokeStyle = 'white'; if (! MetamapsModel.embed) ctx.strokeStyle = 'white';
@ -480,6 +511,7 @@ function onDragEndTopicHandler(node, eventInfo, e, allowRealtime) {
tempNode2 = null; tempNode2 = null;
tempInit = false; tempInit = false;
} else if (dragged != 0 && goRealtime) { } else if (dragged != 0 && goRealtime) {
//TODO: dragged is invalid if multiple nodes were dragged
saveLayout(dragged); saveLayout(dragged);
} }
}//onDragEndTopicHandler }//onDragEndTopicHandler
@ -499,18 +531,28 @@ function onDragCancelHandler(node, eventInfo, e, centred) {
} }
function onPlaceLabelHandler(domElement, node) { function onPlaceLabelHandler(domElement, node) {
var style = domElement.style; var style = domElement.style;
var left = parseInt(style.left); var left = parseInt(style.left);
var top = parseInt(style.top); var top = parseInt(style.top);
var w = domElement.offsetWidth; var w = $('#topic_' + node.id + '_label').width();
style.left = (left - w / 2 + 107) + 'px'; style.left = (left - w / 2) + 'px';
style.top = (top-165) + 'px'; style.top = (top+20) + 'px';
style.display = ''; style.display = '';
var label = document.getElementById('topic_' + node.id + '_label');
$(label).show(); // now position the showcard
w = label.offsetWidth; if (MetamapsModel.showcardInUse != null) {
style = label.style; top = $('#' + MetamapsModel.showcardInUse).css('top');
style.left = (-(w / 2 + 106)) + 'px'; left = parseInt($('#' + MetamapsModel.showcardInUse).css('left'));
if (0 != $('#topic_' + MetamapsModel.showcardInUse + '_label').width()) {
MetamapsModel.widthOfLabel = $('#topic_' + MetamapsModel.showcardInUse + '_label').width();
}
w = MetamapsModel.widthOfLabel/2;
left = (left + w) + 'px';
$('#showcard').css('top', top);
$('#showcard').css('left', left);
Mconsole.labels.hideLabel(Mconsole.graph.getNode(MetamapsModel.showcardInUse));
}
} }
// thanks to http://stackoverflow.com/questions/4338963/ // thanks to http://stackoverflow.com/questions/4338963/

View file

@ -2591,6 +2591,7 @@ Extras.Classes.Navigation = new Class({
$.event.stop($.event.get(e, win)); $.event.stop($.event.get(e, win));
var val = this.config.zooming / 1000, var val = this.config.zooming / 1000,
ans = 1 + scroll * val; ans = 1 + scroll * val;
// START METAMAPS CODE
if (ans > 1) { if (ans > 1) {
if (5 >= this.canvas.scaleOffsetX) { if (5 >= this.canvas.scaleOffsetX) {
this.canvas.scale(ans, ans); this.canvas.scale(ans, ans);
@ -2607,6 +2608,8 @@ Extras.Classes.Navigation = new Class({
else if (this.canvas.scaleOffsetX > 0.5) { else if (this.canvas.scaleOffsetX > 0.5) {
this.canvas.viz.labels.hideLabels(false); this.canvas.viz.labels.hideLabels(false);
} }
// END METAMAPS CODE
// ORIGINAL CODE this.canvas.scale(ans, ans);
}, },
onMouseDown: function(e, win, eventInfo) { onMouseDown: function(e, win, eventInfo) {

View file

@ -118,6 +118,25 @@ function initialize(type, loadLater, embed){
else if ( type == "arranged" || type == "chaotic") { else if ( type == "arranged" || type == "chaotic") {
Mconsole.animate(chooseAnimate); Mconsole.animate(chooseAnimate);
} }
// prevent touch events on the canvas from default behaviour
$("#infovis-canvas").bind('touchstart', function(event) {
event.preventDefault();
Mconsole.events.touched = true;
});
// prevent touch events on the canvas from default behaviour
$("#infovis-canvas").bind('touchmove', function(event) {
//touchPanZoomHandler(event);
});
// prevent touch events on the canvas from default behaviour
$("#infovis-canvas").bind('touchend touchcancel', function(event) {
lastDist = 0;
if (!Mconsole.events.touchMoved && !touchDragNode) hideCurrentCard();
Mconsole.events.touched = Mconsole.events.touchMoved = false;
touchDragNode = false;
});
}); });
// end // end
}// if not loadLater }// if not loadLater

View file

@ -15,22 +15,6 @@
*/ */
function onCreateLabelHandler(domElement, node) { function onCreateLabelHandler(domElement, node) {
var html = generateShowcardHTML();
html = replaceVariables(html, node);
var showCard = document.createElement('div');
showCard.className = 'showcard topic_' + node.id;
if (authorizeToEdit(node)) {
var perm = document.createElement('div');
perm.className = 'permission canEdit';
perm.innerHTML = html;
showCard.appendChild(perm);
} else {
showCard.innerHTML = html;
}
showCard.style.display = "none";
domElement.appendChild(showCard);
// Create a 'name' button and add it to the main node label // Create a 'name' button and add it to the main node label
var nameContainer = document.createElement('span'), var nameContainer = document.createElement('span'),
style = nameContainer.style; style = nameContainer.style;
@ -42,7 +26,7 @@ function onCreateLabelHandler(domElement, node) {
style.fontSize = "0.9em"; style.fontSize = "0.9em";
style.color = "#222222"; style.color = "#222222";
bindCallbacks(showCard, nameContainer, node); bindNameContainerCallbacks(nameContainer, node);
} }
function generateShowcardHTML() { function generateShowcardHTML() {
@ -273,41 +257,41 @@ function hideCard(node) {
$(card).fadeOut('fast', function(){ $(card).fadeOut('fast', function(){
node.setData('dim', 25, 'current'); node.setData('dim', 25, 'current');
$('.name.topic_' + node.id).show(); Mconsole.labels.hideLabel(Mconsole.graph.getNode(node.id), true)
Mconsole.plot(); Mconsole.plot();
}); });
MetamapsModel.showcardInUse = null; MetamapsModel.showcardInUse = null;
} }
function bindCallbacks(showCard, nameContainer, node) { function bindNameContainerCallbacks(nameContainer, node) {
// add some events to the label nameContainer.onmouseover = function(){
$(showCard).find('img.icon').click(function(){ $('.name.topic_' + node.id + ' .nodeOptions').css('display','block');
hideCard(node); }
});
$(showCard).find('.scroll').mCustomScrollbar(); nameContainer.onmouseout = function(){
$('.name.topic_' + node.id + ' .nodeOptions').css('display','none');
}
var showCard = document.getElementById('showcard');
// add some events to the label // add some events to the label
$(nameContainer).find('.label').click(function(e){ $(nameContainer).find('.label').click(function(e){
$('.name').css('display','block');
$('.name.topic_' + node.id).css('display','none');
$('.showcard.topic_' + node.id).fadeIn('fast');
$('.showcard.topic_' + node.id).find('.scroll').mCustomScrollbar("update");
node.setData('dim', 1, 'current');
hideCurrentCard(); hideCurrentCard();
MetamapsModel.showcardInUse = node.id; showCard.innerHTML = '';
Mconsole.plot();
});
nameContainer.onmouseover = function(){ var html = generateShowcardHTML();
$('.name.topic_' + node.id + ' .nodeOptions').css('display','block'); html = replaceVariables(html, node);
}
nameContainer.onmouseout = function(){ showCard.className = 'showcard topic_' + node.id;
$('.name.topic_' + node.id + ' .nodeOptions').css('display','none'); if (authorizeToEdit(node)) {
} var perm = document.createElement('div');
perm.className = 'permission canEdit';
perm.innerHTML = html;
showCard.appendChild(perm);
} else {
showCard.innerHTML = html;
}
//bind best_in_place ajax callbacks //bind best_in_place ajax callbacks
$(showCard).find('.best_in_place_metacode').bind("ajax:success", function() { $(showCard).find('.best_in_place_metacode').bind("ajax:success", function() {
@ -323,6 +307,7 @@ function bindCallbacks(showCard, nameContainer, node) {
$(showCard).find('.best_in_place_name').bind("ajax:success", function() { $(showCard).find('.best_in_place_name').bind("ajax:success", function() {
var name = $(this).html(); var name = $(this).html();
$(nameContainer).find('.label').html(name); $(nameContainer).find('.label').html(name);
node.name = name;
}); });
$(showCard).find('.best_in_place_desc').bind("ajax:success", function() { $(showCard).find('.best_in_place_desc').bind("ajax:success", function() {
@ -378,4 +363,24 @@ function bindCallbacks(showCard, nameContainer, node) {
else if (permission == "public") el.html("pu"); else if (permission == "public") el.html("pu");
else if (permission == "private") el.html("pr"); else if (permission == "private") el.html("pr");
}); });
var top = $('#' + node.id).css('top');
var left = parseInt($('#' + node.id).css('left'));
var w = $('#topic_' + node.id + '_label').width();
w = w/2;
left = (left + w) + 'px';
$('#showcard').css('top', top);
$('#showcard').css('left', left);
$('.showcard.topic_' + node.id).fadeIn('fast');
$('.showcard.topic_' + node.id).find('.scroll').mCustomScrollbar();
node.setData('dim', 1, 'current');
MetamapsModel.showcardInUse = node.id;
Mconsole.plot();
Mconsole.labels.hideLabel(Mconsole.graph.getNode(node.id))
// add some events to the label
$(showCard).find('img.icon').click(function(){
hideCard(node);
});
});
} }

View file

@ -287,7 +287,32 @@ function deleteSelectedEdges() {
MetamapsModel.selectedEdges = new Array(); MetamapsModel.selectedEdges = new Array();
} }
function selectNode(node) {
if (MetamapsModel.selectedNodes.indexOf(node) != -1) return;
node.selected = true;
node.setData('dim', 30, 'current');
node.setData('whiteCircle',true);
node.eachAdjacency(function (adj) {
selectEdge(adj);
});
MetamapsModel.selectedNodes.push(node);
}
function deselectNode(node) {
delete node.selected;
node.setData('whiteCircle', false);
node.eachAdjacency(function(adj) {
deselectEdge(adj);
});
node.setData('dim', 25, 'current');
//remove the node
MetamapsModel.selectedNodes.splice(
MetamapsModel.selectedNodes.indexOf(node), 1);
}
function selectEdge(edge) { function selectEdge(edge) {
if (MetamapsModel.selectedEdges.indexOf(edge) != -1) return;
var showDesc = edge.getData("showDesc"); var showDesc = edge.getData("showDesc");
if (! showDesc) { if (! showDesc) {
edge.setData('showDesc', true, 'current'); edge.setData('showDesc', true, 'current');
@ -349,6 +374,8 @@ function hideNode(nodeid) {
return; return;
} }
deselectNode(node);
node.setData('alpha', 0, 'end'); node.setData('alpha', 0, 'end');
node.eachAdjacency(function(adj) { node.eachAdjacency(function(adj) {
adj.setData('alpha', 0, 'end'); adj.setData('alpha', 0, 'end');
@ -361,15 +388,18 @@ function hideNode(nodeid) {
Mconsole.graph.removeNode(nodeid); Mconsole.graph.removeNode(nodeid);
Mconsole.labels.disposeLabel(nodeid); Mconsole.labels.disposeLabel(nodeid);
} }
function hideSelectedNodes() { function hideSelectedNodes() {
Mconsole.graph.eachNode( function (n) { Mconsole.graph.eachNode( function (n) {
if (n.data.$onCanvas == true) { if (n.getData('whiteCircle') == true) {
hideNode(n.id); hideNode(n.id);
} }
}); });
} }
function removeNode(nodeid) { function removeNode(nodeid) {
var node = Mconsole.graph.getNode(nodeid);
deselectNode(node);
if (mapperm) { if (mapperm) {
$.ajax({ $.ajax({
type: "POST", type: "POST",
@ -380,7 +410,7 @@ function removeNode(nodeid) {
function removeSelectedNodes() { function removeSelectedNodes() {
if (mapperm) { if (mapperm) {
Mconsole.graph.eachNode( function (n) { Mconsole.graph.eachNode( function (n) {
if (n.data.$onCanvas == true) { if (n.getData('whiteCircle') == true) {
removeNode(n.id); removeNode(n.id);
} }
}); });
@ -399,7 +429,7 @@ function deleteNode(nodeid) {
} }
function deleteSelectedNodes() { function deleteSelectedNodes() {
Mconsole.graph.eachNode( function (n) { Mconsole.graph.eachNode( function (n) {
if (n.data.$onCanvas == true) { if (n.getData('whiteCircle') == true) {
deleteNode(n.id); deleteNode(n.id);
} }
}); });

View file

@ -21,7 +21,7 @@
// other options are 'graph' // other options are 'graph'
var viewMode = "list"; var viewMode = "list";
var labelType, useGradients, nativeTextSupport, animate, json, Mconsole = null, gType, tempNode = null, tempInit = false, tempNode2 = null, metacodeIMGinit = false, findOpen = false, analyzeOpen = false, organizeOpen = false, goRealtime = false, mapid = null, mapperm = false; var labelType, useGradients, nativeTextSupport, animate, json, Mconsole = null, gType, tempNode = null, tempInit = false, tempNode2 = null, metacodeIMGinit = false, findOpen = false, analyzeOpen = false, organizeOpen = false, goRealtime = false, mapid = null, mapperm = false, touchPos, touchDragNode;
$(document).ready(function() { $(document).ready(function() {
@ -69,12 +69,26 @@ var labelType, useGradients, nativeTextSupport, animate, json, Mconsole = null,
height: '0px' height: '0px'
}, 300, function() { }, 300, function() {
sliding1 = false; sliding1 = false;
menuIsOpen = false;
}); });
} }
},800); },800);
} }
); );
var menuIsOpen = false;
$("#mainTitle a").bind('touchend', function(evt) {
if (!menuIsOpen) {
menuIsOpen = true;
var listLength = $('.logo .menu li').length * 28;
$('.footer .menu').animate({
height: listLength + 'px'
}, 300);
evt.preventDefault();
evt.stopPropogation();
}
});
addHoverForSettings(); addHoverForSettings();
//bind best_in_place ajax callbacks //bind best_in_place ajax callbacks
@ -99,7 +113,7 @@ var labelType, useGradients, nativeTextSupport, animate, json, Mconsole = null,
saveLayoutAll(); saveLayoutAll();
}); });
}); }); // end document.ready
function addHoverForSettings() { function addHoverForSettings() {
// controls the sliding hover of the settings for cards // controls the sliding hover of the settings for cards

View file

@ -4,6 +4,7 @@
.label { .label {
display:block; display:block;
white-space: nowrap;
padding: 2px 4px; padding: 2px 4px;
background:#ddd; background:#ddd;
opacity:0.8; opacity:0.8;
@ -13,5 +14,4 @@
span.name { span.name {
cursor: pointer; cursor: pointer;
position: absolute; position: absolute;
top: 185px;
} }

View file

@ -7,6 +7,9 @@
} }
.showcard, #showcard { .showcard, #showcard {
position:absolute;
display:none;
margin-top: -181px;
width:216px; width:216px;
height:320px; height:320px;
color:#FFF; color:#FFF;

View file

@ -5,7 +5,17 @@ class SynapsesController < ApplicationController
respond_to :html, :js, :json respond_to :html, :js, :json
autocomplete :synapse, :desc, :full => true def autocomplete_synapse_desc
term = params[:term]
if term && !term.empty?
items = Synapse.select('DISTINCT "desc"').
where('LOWER("desc") like ?', term.downcase + '%').
limit(10).order('"desc"')
else
items = {}
end
render :json => json_for_autocomplete(items, :desc)
end
# GET synapses # GET synapses
# or GET users/:user_id/synapses # or GET users/:user_id/synapses

View file

@ -23,6 +23,7 @@
<div id="center-container"> <div id="center-container">
<div id="infovis"></div> <div id="infovis"></div>
</div> </div>
<div class="showcard" id="showcard"></div>
</div> </div>
<div class="clearfloat"></div> <div class="clearfloat"></div>
<% if authenticated? %> <% if authenticated? %>

View file

@ -19,8 +19,8 @@ var even = true;
var temp = Mconsole.graph.getNode('<%= topic.id %>'); var temp = Mconsole.graph.getNode('<%= topic.id %>');
temp.setData('dim', 1, 'start'); temp.setData('dim', 1, 'start');
temp.setData('dim', 25, 'end'); temp.setData('dim', 25, 'end');
temp.setData('inCommons',true); temp.setData('greenCircle',true);
temp.setData('onCanvas',false); temp.setData('whiteCircle',false);
temp.setPos(new $jit.Complex(myX, myY), 'current'); temp.setPos(new $jit.Complex(myX, myY), 'current');
temp.setPos(new $jit.Complex(myX, myY), 'start'); temp.setPos(new $jit.Complex(myX, myY), 'start');
temp.setPos(new $jit.Complex(myX, myY), 'end'); temp.setPos(new $jit.Complex(myX, myY), 'end');
@ -28,17 +28,16 @@ var even = true;
Mconsole.labels.plotLabel(Mconsole.canvas, temp, Mconsole.config); Mconsole.labels.plotLabel(Mconsole.canvas, temp, Mconsole.config);
myX += 100; myX += 100;
even = !even; even = !even;
} } else {
else {
var temp = Mconsole.graph.getNode('<%= topic.id %>'); var temp = Mconsole.graph.getNode('<%= topic.id %>');
if (temp == null || temp.getData('inCommons')) { if (temp == undefined) {
var newnode = <%= topic.self_as_json.html_safe %>; var newnode = <%= topic.self_as_json.html_safe %>;
Mconsole.graph.addNode(newnode); Mconsole.graph.addNode(newnode);
var temp = Mconsole.graph.getNode('<%= topic.id %>'); var temp = Mconsole.graph.getNode('<%= topic.id %>');
temp.setData('dim', 1, 'start'); temp.setData('dim', 1, 'start');
temp.setData('dim', 25, 'end'); temp.setData('dim', 25, 'end');
temp.setData('inCommons',true); temp.setData('greenCircle',true);
temp.setData('onCanvas',false); temp.setData('whiteCircle',false);
if (myX > (w-100)) { if (myX > (w-100)) {
myX = -w + 400; myX = -w + 400;
myY += 200; myY += 200;
@ -85,7 +84,7 @@ var even = true;
username: '<%= synapse.user.name %>', username: '<%= synapse.user.name %>',
permission: '<%= synapse.permission %>' permission: '<%= synapse.permission %>'
}); });
temp.data.$direction = d; temp.setData('direction', d);
Mconsole.fx.plotLine(temp, Mconsole.canvas); Mconsole.fx.plotLine(temp, Mconsole.canvas);
} }
<% end %> <% end %>

View file

@ -42,6 +42,7 @@
<div id="center-container"> <div id="center-container">
<div id="infovis"></div> <div id="infovis"></div>
</div> </div>
<div class="showcard" id="showcard"></div>
</div> </div>
<div class="clearfloat"></div> <div class="clearfloat"></div>

View file

@ -25,8 +25,8 @@ if (!$.isEmptyObject(Mconsole.graph.nodes)) {
var temp = Mconsole.graph.getNode('<%= @topic.id %>'); var temp = Mconsole.graph.getNode('<%= @topic.id %>');
temp.setData('dim', 1, 'start'); temp.setData('dim', 1, 'start');
temp.setData('dim', 40, 'end'); temp.setData('dim', 40, 'end');
temp.setData('onCanvas', false); temp.setData('whiteCircle', false);
temp.setData('inCommons', false); temp.setData('greenCircle', false);
if (gType == "centered") { if (gType == "centered") {
var tempPos = new $jit.Complex(x, y); var tempPos = new $jit.Complex(x, y);
@ -72,7 +72,7 @@ if (!$.isEmptyObject(Mconsole.graph.nodes)) {
modes: ['node-property:dim'], modes: ['node-property:dim'],
duration: 500, duration: 500,
onComplete: function() { onComplete: function() {
selectNodeOnClickHandler(temp); selectNode(temp);
} }
}); });
@ -84,8 +84,8 @@ if (!$.isEmptyObject(Mconsole.graph.nodes)) {
var temp = Mconsole.graph.getNode('<%= @topic.id %>'); var temp = Mconsole.graph.getNode('<%= @topic.id %>');
temp.setData('dim', 1, 'start'); temp.setData('dim', 1, 'start');
temp.setData('dim', 25, 'end'); temp.setData('dim', 25, 'end');
temp.setData('onCanvas', false); temp.setData('whiteCircle', false);
temp.setData('inCommons', false); temp.setData('greenCircle', false);
if (gType == "arranged" || gType == "chaotic") { if (gType == "arranged" || gType == "chaotic") {
<% if not @mapping.nil? %> <% if not @mapping.nil? %>
temp.setData('mappingid', <%= @mapping.id %>); temp.setData('mappingid', <%= @mapping.id %>);
@ -101,7 +101,7 @@ if (!$.isEmptyObject(Mconsole.graph.nodes)) {
modes: ['node-property:dim'], modes: ['node-property:dim'],
duration: 500, duration: 500,
onComplete: function() { onComplete: function() {
selectNodeOnClickHandler(temp); selectNode(temp);
} }
}); });
} }

View file

@ -30,6 +30,7 @@
<div id="center-container"> <div id="center-container">
<div id="infovis"></div> <div id="infovis"></div>
</div> </div>
<div class="showcard" id="showcard"></div>
</div> </div>
<div class="clearfloat"></div> <div class="clearfloat"></div>