rm'ed gemfile.lock
This commit is contained in:
commit
cdf0a2d5e6
19 changed files with 394 additions and 266 deletions
145
Gemfile.lock
145
Gemfile.lock
|
@ -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
46
Gemfile~
Normal 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'
|
|
@ -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();
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -58,7 +58,7 @@ function graphSettings(type, embed) {
|
||||||
},
|
},
|
||||||
//Update node positions when dragged
|
//Update node positions when dragged
|
||||||
onDragMove: function (node, eventInfo, e) {
|
onDragMove: function (node, eventInfo, e) {
|
||||||
onDragMoveTopicHandler(node, eventInfo, e);
|
onDragMoveTopicHandler(node, eventInfo, e);
|
||||||
},
|
},
|
||||||
onDragEnd: function(node, eventInfo, e) {
|
onDragEnd: function(node, eventInfo, e) {
|
||||||
onDragEndTopicHandler(node, eventInfo, e, false);
|
onDragEndTopicHandler(node, eventInfo, e, false);
|
||||||
|
@ -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/
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
}
|
||||||
});
|
|
||||||
|
nameContainer.onmouseout = function(){
|
||||||
$(showCard).find('.scroll').mCustomScrollbar();
|
$('.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();
|
|
||||||
});
|
var html = generateShowcardHTML();
|
||||||
|
html = replaceVariables(html, node);
|
||||||
nameContainer.onmouseover = function(){
|
|
||||||
$('.name.topic_' + node.id + ' .nodeOptions').css('display','block');
|
showCard.className = 'showcard topic_' + node.id;
|
||||||
}
|
if (authorizeToEdit(node)) {
|
||||||
|
var perm = document.createElement('div');
|
||||||
nameContainer.onmouseout = function(){
|
perm.className = 'permission canEdit';
|
||||||
$('.name.topic_' + node.id + ' .nodeOptions').css('display','none');
|
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);
|
||||||
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -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');
|
||||||
|
@ -348,6 +373,8 @@ function hideNode(nodeid) {
|
||||||
alert("You can't hide this topic, it is the root of your graph.");
|
alert("You can't hide this topic, it is the root of your graph.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
deselectNode(node);
|
||||||
|
|
||||||
node.setData('alpha', 0, 'end');
|
node.setData('alpha', 0, 'end');
|
||||||
node.eachAdjacency(function(adj) {
|
node.eachAdjacency(function(adj) {
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -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,11 +69,25 @@ 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();
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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? %>
|
||||||
|
|
|
@ -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 %>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -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>
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue