converted all references to items to topics

This commit is contained in:
Connor Turland 2013-01-01 17:45:35 -05:00
parent 0d4e694a4c
commit 131e27aefe
61 changed files with 1142 additions and 212 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 178 B

View file

@ -1,6 +1,6 @@
// create filters for maps, and for card views // create filters for maps, and for card views
// keep an array of which item categories are currently visible. // keep an array of which metacodes are currently visible.
var categoryVisible = new Object(); var categoryVisible = new Object();
categoryVisible['Group'] = true; categoryVisible['Group'] = true;
@ -44,7 +44,7 @@ function switchVisible(category, duration) {
function hideCategory(category, duration) { function hideCategory(category, duration) {
if (duration == null) duration = 500; if (duration == null) duration = 500;
Mconsole.graph.eachNode( function (n) { Mconsole.graph.eachNode( function (n) {
if (n.getData('itemcatname') == category) { if (n.getData('metacode') == category) {
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');
@ -61,7 +61,7 @@ function hideCategory(category, duration) {
function showCategory(category, duration) { function showCategory(category, duration) {
if (duration == null) duration = 500; if (duration == null) duration = 500;
Mconsole.graph.eachNode( function (n) { Mconsole.graph.eachNode( function (n) {
if (n.getData('itemcatname') == category) { if (n.getData('metacode') == category) {
n.setData('alpha', 1, 'end'); n.setData('alpha', 1, 'end');
n.eachAdjacency(function(adj) { n.eachAdjacency(function(adj) {
adj.setData('alpha', 1, 'end'); adj.setData('alpha', 1, 'end');
@ -130,31 +130,31 @@ function onCanvasSearch(name,mapID,mapperID) {
if (name != null) { if (name != null) {
if (n.name.indexOf(name) !== -1 && name != "") { if (n.name.indexOf(name) !== -1 && name != "") {
n.setData('onCanvas', true); n.setData('onCanvas', true);
//$('.name.item_' + n.id).css('display','block'); //$('.name.topic_' + n.id).css('display','block');
} }
else { else {
n.setData('onCanvas', false); n.setData('onCanvas', false);
//$('.name.item_' + n.id).css('display','none'); //$('.name.topic_' + n.id).css('display','none');
} }
} }
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('onCanvas', true);
//$('.name.item_' + n.id).css('display','block'); //$('.name.topic_' + n.id).css('display','block');
} }
else { else {
n.setData('onCanvas', false); n.setData('onCanvas', false);
//$('.name.item_' + n.id).css('display','none'); //$('.name.topic_' + n.id).css('display','none');
} }
} }
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('onCanvas', true);
//$('.name.item_' + n.id).css('display','block'); //$('.name.topic_' + n.id).css('display','block');
} }
else { else {
n.setData('onCanvas', false); n.setData('onCanvas', false);
//$('.name.item_' + n.id).css('display','none'); //$('.name.topic_' + n.id).css('display','none');
} }
} }
Mconsole.plot(); Mconsole.plot();
@ -194,7 +194,7 @@ $(document).ready(function() {
Mconsole.graph.eachNode( function (n) { Mconsole.graph.eachNode( function (n) {
n.setData('inCommons', false); n.setData('inCommons', false);
n.setData('onCanvas', false); n.setData('onCanvas', false);
//$('.name.item_' + n.id).css('display','block'); //$('.name.topic_' + n.id).css('display','block');
}); });
Mconsole.plot(); Mconsole.plot();
$('#closeFind, #findWhere').css('display','none'); $('#closeFind, #findWhere').css('display','none');
@ -372,7 +372,7 @@ $(document).ready(function() {
$('.find_topic_by_name #topic_by_name_input').bind('railsAutocomplete.select', function(event, data){ $('.find_topic_by_name #topic_by_name_input').bind('railsAutocomplete.select', function(event, data){
/* Do something here */ /* Do something here */
if (data.item.id != undefined) { if (data.item.id != undefined) {
window.open("/items/" + data.item.id) window.open("/topics/" + data.item.id)
} }
$('.find_topic_by_name #topic_by_name_input').val(''); $('.find_topic_by_name #topic_by_name_input').val('');
}); });
@ -471,7 +471,7 @@ $(document).ready(function() {
event.preventDefault(); event.preventDefault();
}); });
// toggle visibility of item categories based on status in the filters list // toggle visibility of topics with metacodes based on status in the filters list
$('.find_topic_by_metacode ul li').click(function(event) { $('.find_topic_by_metacode ul li').click(function(event) {
obj = document.getElementById('container'); obj = document.getElementById('container');
@ -485,7 +485,7 @@ $(document).ready(function() {
} }
// this means that we are on a card view // this means that we are on a card view
else { else {
$('.item').fadeIn('slow'); $('.topic').fadeIn('slow');
} }
$('.find_topic_by_metacode ul li').not('#hideAll, #showAll').removeClass('toggledOff'); $('.find_topic_by_metacode ul li').not('#hideAll, #showAll').removeClass('toggledOff');
for (var catVis in categoryVisible) { for (var catVis in categoryVisible) {
@ -499,7 +499,7 @@ $(document).ready(function() {
} }
// this means that we are on a card view // this means that we are on a card view
else { else {
$('.item').fadeOut('slow'); $('.topic').fadeOut('slow');
} }
$('.find_topic_by_metacode ul li').not('#hideAll, #showAll').addClass('toggledOff'); $('.find_topic_by_metacode ul li').not('#hideAll, #showAll').addClass('toggledOff');
for (var catVis in categoryVisible) { for (var catVis in categoryVisible) {

View file

@ -61,15 +61,15 @@ function graphSettings(type) {
}, },
onDragEnd: function() { onDragEnd: function() {
if (tempInit && tempNode2 == null) { if (tempInit && tempNode2 == null) {
$('#item_addSynapse').val("true"); $('#topic_addSynapse').val("true");
$('#new_item').fadeIn('fast'); $('#new_topic').fadeIn('fast');
addMetacode(); addMetacode();
$('#item_name').focus(); $('#topic_name').focus();
} }
else if (tempInit && tempNode2 != null) { else if (tempInit && tempNode2 != null) {
$('#item_addSynapse').val("false"); $('#topic_addSynapse').val("false");
$('#synapse_item1id').val(tempNode.id); $('#synapse_topic1id').val(tempNode.id);
$('#synapse_item2id').val(tempNode2.id); $('#synapse_topic2id').val(tempNode2.id);
$('#new_synapse').fadeIn('fast'); $('#new_synapse').fadeIn('fast');
$('#synapse_desc').focus(); $('#synapse_desc').focus();
tempNode = null; tempNode = null;
@ -81,9 +81,9 @@ function graphSettings(type) {
tempNode = null; tempNode = null;
tempNode2 = null; tempNode2 = null;
tempInit = false; tempInit = false;
$('#item_addSynapse').val("false"); $('#topic_addSynapse').val("false");
$('#item_item1id').val(0); $('#topic_topic1id').val(0);
$('#item_item2id').val(0); $('#topic_topic2id').val(0);
Mconsole.plot(); Mconsole.plot();
}, },
//Implement the same handler for touchscreens //Implement the same handler for touchscreens
@ -112,14 +112,14 @@ function graphSettings(type) {
// on label creation and only for DOM labels (not native canvas ones). // on label creation and only for DOM labels (not native canvas ones).
onCreateLabel: function (domElement, node) { onCreateLabel: function (domElement, node) {
var html = var html =
'<div class="CardOnGraph" title="Click to Hide" id="item_' + node.id + '"><p class="type">' + node.getData("itemcatname") + '</p>' + '<div class="CardOnGraph" title="Click to Hide" id="topic_' + node.id + '"><p class="type">' + node.getData("metacode") + '</p>' +
'<img alt="' + node.getData("itemcatname") + '" class="icon" height="50" src="' + imgArray[node.getData("itemcatname")].src + '" width="50" />' + '<img alt="' + node.getData("metacode") + '" class="icon" height="50" src="' + imgArray[node.getData("metacode")].src + '" width="50" />' +
'<div class="scroll"><a href="/items/' + node.id + '" class="title">' + node.name + '</a>' + '<div class="scroll"><a href="/topics/' + node.id + '" class="title">' + node.name + '</a>' +
'<div class="contributor">Added by: <a href="/users/' + node.getData('userid') + '">' + node.getData('username') + '</a></div>' + '<div class="contributor">Added by: <a href="/users/' + node.getData('userid') + '">' + node.getData('username') + '</a></div>' +
'<div class="desc"><p>' + node.getData('desc') + '</p></div></div>' + '<div class="desc"><p>' + node.getData('desc') + '</p></div></div>' +
'<a href="' + node.getData('link') + '" class="link" target="_blank">' + node.getData('link') + '</a></div>'; '<a href="' + node.getData('link') + '" class="link" target="_blank">' + node.getData('link') + '</a></div>';
var showCard = document.createElement('div'); var showCard = document.createElement('div');
showCard.className = 'showcard item_' + node.id; showCard.className = 'showcard topic_' + node.id;
showCard.innerHTML = html; showCard.innerHTML = html;
showCard.style.display = "none"; showCard.style.display = "none";
domElement.appendChild(showCard); domElement.appendChild(showCard);
@ -139,7 +139,7 @@ function graphSettings(type) {
modes: ['edge-property:lineWidth:color'], modes: ['edge-property:lineWidth:color'],
duration: 500 duration: 500
}); });
$('.showcard.item_' + node.id).fadeOut('fast', function(){ $('.showcard.topic_' + node.id).fadeOut('fast', function(){
$('.name').css('display','block'); $('.name').css('display','block');
Mconsole.plot(); Mconsole.plot();
}); });
@ -149,7 +149,7 @@ function graphSettings(type) {
// to the main node label // to the main node label
var nameContainer = document.createElement('span'), var nameContainer = document.createElement('span'),
style = nameContainer.style; style = nameContainer.style;
nameContainer.className = 'name item_' + node.id; nameContainer.className = 'name topic_' + node.id;
nameContainer.innerHTML = '<div class="label">' + node.name + '</div>'; nameContainer.innerHTML = '<div class="label">' + node.name + '</div>';
domElement.appendChild(nameContainer); domElement.appendChild(nameContainer);
style.fontSize = "0.9em"; style.fontSize = "0.9em";
@ -239,15 +239,15 @@ function graphSettings(type) {
}, },
onDragEnd: function() { onDragEnd: function() {
if (tempInit && tempNode2 == null) { if (tempInit && tempNode2 == null) {
$('#item_addSynapse').val("true"); $('#topic_addSynapse').val("true");
$('#new_item').fadeIn('fast'); $('#new_topic').fadeIn('fast');
addMetacode(); addMetacode();
$('#item_name').focus(); $('#topic_name').focus();
} }
else if (tempInit && tempNode2 != null) { else if (tempInit && tempNode2 != null) {
$('#item_addSynapse').val("false"); $('#topic_addSynapse').val("false");
$('#synapse_item1id').val(tempNode.id); $('#synapse_topic1id').val(tempNode.id);
$('#synapse_item2id').val(tempNode2.id); $('#synapse_topic2id').val(tempNode2.id);
$('#new_synapse').fadeIn('fast'); $('#new_synapse').fadeIn('fast');
$('#synapse_desc').focus(); $('#synapse_desc').focus();
tempNode = null; tempNode = null;
@ -294,14 +294,14 @@ function graphSettings(type) {
// on label creation and only for DOM labels (not native canvas ones). // on label creation and only for DOM labels (not native canvas ones).
onCreateLabel: function (domElement, node) { onCreateLabel: function (domElement, node) {
var html = var html =
'<div class="CardOnGraph" title="Click to Hide" id="item_' + node.id + '"><p class="type">' + node.getData("itemcatname") + '</p>' + '<div class="CardOnGraph" title="Click to Hide" id="topic_' + node.id + '"><p class="type">' + node.getData("metacode") + '</p>' +
'<img alt="' + node.getData("itemcatname") + '" class="icon" height="50" src="' + imgArray[node.getData("itemcatname")].src + '" width="50" />' + '<img alt="' + node.getData("metacode") + '" class="icon" height="50" src="' + imgArray[node.getData("metacode")].src + '" width="50" />' +
'<div class="scroll"><a href="/items/' + node.id + '" class="title">' + node.name + '</a>' + '<div class="scroll"><a href="/topics/' + node.id + '" class="title">' + node.name + '</a>' +
'<div class="contributor">Added by: <a href="/users/' + node.getData('userid') + '">' + node.getData('username') + '</a></div>' + '<div class="contributor">Added by: <a href="/users/' + node.getData('userid') + '">' + node.getData('username') + '</a></div>' +
'<div class="desc"><p>' + node.getData('desc') + '</p></div></div>' + '<div class="desc"><p>' + node.getData('desc') + '</p></div></div>' +
'<a href="' + node.getData('link') + '" class="link" target="_blank">' + node.getData('link') + '</a></div>'; '<a href="' + node.getData('link') + '" class="link" target="_blank">' + node.getData('link') + '</a></div>';
var showCard = document.createElement('div'); var showCard = document.createElement('div');
showCard.className = 'showcard item_' + node.id; showCard.className = 'showcard topic_' + node.id;
showCard.innerHTML = html; showCard.innerHTML = html;
showCard.style.display = "none"; showCard.style.display = "none";
domElement.appendChild(showCard); domElement.appendChild(showCard);
@ -322,7 +322,7 @@ function graphSettings(type) {
modes: ['edge-property:lineWidth:color'], modes: ['edge-property:lineWidth:color'],
duration: 500 duration: 500
}); });
$('.showcard.item_' + node.id).fadeOut('fast', function(){ $('.showcard.topic_' + node.id).fadeOut('fast', function(){
$('.name').css('display','block'); $('.name').css('display','block');
Mconsole.plot(); Mconsole.plot();
}); });
@ -333,7 +333,7 @@ function graphSettings(type) {
// to the main node label // to the main node label
var nameContainer = document.createElement('span'), var nameContainer = document.createElement('span'),
style = nameContainer.style; style = nameContainer.style;
nameContainer.className = 'name item_' + node.id; nameContainer.className = 'name topic_' + node.id;
nameContainer.innerHTML = '<div class="label">' + node.name + '</div>'; nameContainer.innerHTML = '<div class="label">' + node.name + '</div>';
domElement.appendChild(nameContainer); domElement.appendChild(nameContainer);
style.fontSize = "0.9em"; style.fontSize = "0.9em";
@ -410,7 +410,7 @@ var nodeSettings = {
'render': function (node, canvas) { 'render': function (node, canvas) {
var pos = node.pos.getc(true), var pos = node.pos.getc(true),
dim = node.getData('dim'), dim = node.getData('dim'),
cat = node.getData('itemcatname'), cat = node.getData('metacode'),
inCommons = node.getData('inCommons'), inCommons = node.getData('inCommons'),
onCanvas = node.getData('onCanvas'), onCanvas = node.getData('onCanvas'),
ctx = canvas.getCtx(); ctx = canvas.getCtx();
@ -502,8 +502,8 @@ function selectNodeOnClickHandler(node) {
$('.showcard').css('display','none'); $('.showcard').css('display','none');
$('.name').css('display','block'); $('.name').css('display','block');
$('.name.item_' + node.id).css('display','none'); $('.name.topic_' + node.id).css('display','none');
$('.showcard.item_' + node.id).fadeIn('fast'); $('.showcard.topic_' + node.id).fadeIn('fast');
//set final styles //set final styles
Mconsole.graph.eachNode(function (n) { Mconsole.graph.eachNode(function (n) {
@ -552,18 +552,18 @@ function canvasDoubleClickHandler(canvasLoc,e) {
if (now - storedTime < TOLERANCE) { if (now - storedTime < TOLERANCE) {
//pop up node creation :) //pop up node creation :)
$('#item_grabItem').val("null"); $('#topic_grabTopic').val("null");
$('#item_addSynapse').val("false"); $('#topic_addSynapse').val("false");
document.getElementById('new_item').style.left = e.x + "px"; document.getElementById('new_topic').style.left = e.x + "px";
document.getElementById('new_item').style.top = e.y + "px"; document.getElementById('new_topic').style.top = e.y + "px";
$('#item_x').val(canvasLoc.x); $('#topic_x').val(canvasLoc.x);
$('#item_y').val(canvasLoc.y); $('#topic_y').val(canvasLoc.y);
$('#new_item').fadeIn('fast'); $('#new_topic').fadeIn('fast');
addMetacode(); addMetacode();
$('#item_name').focus(); $('#topic_name').focus();
} else { } else {
canvasDoubleClickHandlerObject.storedTime = now; canvasDoubleClickHandlerObject.storedTime = now;
$('#new_item').fadeOut('fast'); $('#new_topic').fadeOut('fast');
$('#new_synapse').fadeOut('fast'); $('#new_synapse').fadeOut('fast');
tempInit = false; tempInit = false;
tempNode = null; tempNode = null;
@ -576,7 +576,7 @@ function canvasDoubleClickHandler(canvasLoc,e) {
function clickDragOnTopic(node, eventInfo, e) { function clickDragOnTopic(node, eventInfo, e) {
if (node && !node.nodeFrom) { if (node && !node.nodeFrom) {
$('#new_synapse').fadeOut('fast'); $('#new_synapse').fadeOut('fast');
$('#new_item').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, move the node
if (e.button == 0 && !e.altKey ) { if (e.button == 0 && !e.altKey ) {
@ -608,15 +608,15 @@ function clickDragOnTopic(node, eventInfo, e) {
n.setData('dim', 25, 'current'); n.setData('dim', 25, 'current');
}); });
//pop up node creation :) //pop up node creation :)
$('#item_grabItem').val("null"); $('#topic_grabTopic').val("null");
var myX = e.x - 110; var myX = e.x - 110;
var myY = e.y - 30; var myY = e.y - 30;
document.getElementById('new_item').style.left = myX + "px"; document.getElementById('new_topic').style.left = myX + "px";
document.getElementById('new_item').style.top = myY + "px"; document.getElementById('new_topic').style.top = myY + "px";
document.getElementById('new_synapse').style.left = myX + "px"; document.getElementById('new_synapse').style.left = myX + "px";
document.getElementById('new_synapse').style.top = myY + "px"; document.getElementById('new_synapse').style.top = myY + "px";
$('#item_x').val(eventInfo.getPos().x); $('#topic_x').val(eventInfo.getPos().x);
$('#item_y').val(eventInfo.getPos().y); $('#topic_y').val(eventInfo.getPos().y);
Mconsole.plot(); Mconsole.plot();
renderMidArrow({ x: tempNode.pos.getc().x, y: tempNode.pos.getc().y }, { x: pos.x, y: pos.y }, 13, false, Mconsole.canvas); renderMidArrow({ x: tempNode.pos.getc().x, y: tempNode.pos.getc().y }, { x: pos.x, y: pos.y }, 13, false, Mconsole.canvas);
Mconsole.fx.plotNode(tempNode, Mconsole.canvas); Mconsole.fx.plotNode(tempNode, Mconsole.canvas);

View file

@ -25,14 +25,14 @@ var labelType, useGradients, nativeTextSupport, animate, json, Mconsole = null,
$(document).ready(function() { $(document).ready(function() {
$('#new_item, #new_synapse').bind('contextmenu', function(e){ $('#new_topic, #new_synapse').bind('contextmenu', function(e){
return false; return false;
}); });
/// this is for the topic creation autocomplete field /// this is for the topic creation autocomplete field
$('#item_name').bind('railsAutocomplete.select', function(event, data){ $('#topic_name').bind('railsAutocomplete.select', function(event, data){
if (data.item.id != undefined) { if (data.item.id != undefined) {
$('#item_grabItem').val(data.item.id); $('#topic_grabTopic').val(data.item.id);
} }
}); });

View file

@ -187,7 +187,7 @@
if ( items[this.frontIndex] === undefined ) { return; } // Images might not have loaded yet. if ( items[this.frontIndex] === undefined ) { return; } // Images might not have loaded yet.
$(options.titleBox).html( $(items[this.frontIndex].image).attr('title')); $(options.titleBox).html( $(items[this.frontIndex].image).attr('title'));
// METAMAPS CODE // METAMAPS CODE
$('#item_metacode').val( $(items[this.frontIndex].image).attr('title')); $('#topic_metacode').val( $(items[this.frontIndex].image).attr('title'));
// NOT METAMAPS CODE // NOT METAMAPS CODE
$(options.altBox).html( $(items[this.frontIndex].image).attr('alt')); $(options.altBox).html( $(items[this.frontIndex].image).attr('alt'));
}; };

View file

@ -0,0 +1,6 @@
# Place all the behaviors and hooks related to the matching controller here.
# All this logic will automatically be available in application.js.
# You can use CoffeeScript in this file: http://jashkenas.github.com/coffee-script/
jQuery ->
$('.best_in_place').best_in_place()

View file

@ -93,7 +93,7 @@ a {
.new_user, .new_user,
.new_map, .new_map,
.edit_user, .edit_user,
.edit_item, .edit_topic,
.edit_synapse, .edit_synapse,
.edit_map, .edit_map,
.invite { .invite {
@ -135,18 +135,18 @@ a {
right:3px; right:3px;
} }
.anypage .new_item { .anypage .new_topic {
width:300px; width:300px;
margin:-40px 0 0 -50px; margin:-40px 0 0 -50px;
} }
.anypage .new_item, .anypage .new_topic,
.anypage .new_synapse { .anypage .new_synapse {
display: block; display: block;
position: absolute; position: absolute;
} }
.anypage #item_name { .anypage #topic_name {
width:200px; width:200px;
position:absolute; position:absolute;
top:40px; top:40px;

View file

@ -152,18 +152,18 @@ button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra pad
.ui-menu { list-style:none; padding: 2px; margin: 0; display:block; outline: none; } .ui-menu { list-style:none; padding: 2px; margin: 0; display:block; outline: none; }
.ui-menu .ui-menu { margin-top: -3px; position: absolute; } .ui-menu .ui-menu { margin-top: -3px; position: absolute; }
.ui-menu .ui-menu-item { margin: 0; padding: 0; zoom: 1; width: 100%; } .ui-menu .ui-menu-topic { margin: 0; padding: 0; zoom: 1; width: 100%; }
.ui-menu .ui-menu-divider { margin: 5px -2px 5px -2px; height: 0; font-size: 0; line-height: 0; border-width: 1px 0 0 0; } .ui-menu .ui-menu-divider { margin: 5px -2px 5px -2px; height: 0; font-size: 0; line-height: 0; border-width: 1px 0 0 0; }
.ui-menu .ui-menu-item a { text-decoration: none; display: block; padding: 2px .4em; line-height: 1.5; zoom: 1; font-weight: normal; } .ui-menu .ui-menu-topic a { text-decoration: none; display: block; padding: 2px .4em; line-height: 1.5; zoom: 1; font-weight: normal; }
.ui-menu .ui-menu-item a.ui-state-focus, .ui-menu .ui-menu-topic a.ui-state-focus,
.ui-menu .ui-menu-item a.ui-state-active { font-weight: normal; margin: -1px; } .ui-menu .ui-menu-topic a.ui-state-active { font-weight: normal; margin: -1px; }
.ui-menu .ui-state-disabled { font-weight: normal; margin: .4em 0 .2em; line-height: 1.5; } .ui-menu .ui-state-disabled { font-weight: normal; margin: .4em 0 .2em; line-height: 1.5; }
.ui-menu .ui-state-disabled a { cursor: default; } .ui-menu .ui-state-disabled a { cursor: default; }
/* icon support */ /* icon support */
.ui-menu-icons { position: relative; } .ui-menu-icons { position: relative; }
.ui-menu-icons .ui-menu-item a { position: relative; padding-left: 2em; } .ui-menu-icons .ui-menu-topic a { position: relative; padding-left: 2em; }
/* left-aligned */ /* left-aligned */
.ui-menu .ui-icon { position: absolute; top: .2em; left: .2em; } .ui-menu .ui-icon { position: absolute; top: .2em; left: .2em; }

View file

@ -46,4 +46,4 @@ line-height: 24px;}
// add topic on maps pages // add topic on maps pages
.selecttype { border:1px solid #000; margin-top: 20px; border-radius:15px; } .selecttype { border:1px solid #000; margin-top: 20px; border-radius:15px; }
.mapspages .new_item h3 { padding: 10px 26px; display: block; cursor: pointer; color: #2d6a5d; float:left; } .mapspages .new_topic h3 { padding: 10px 26px; display: block; cursor: pointer; color: #2d6a5d; float:left; }

View file

@ -0,0 +1,37 @@
// Place all the styles related to the Topics controller here.
// They will automatically be included in application.css.
// You can use Sass (SCSS) here: http://sass-lang.com/
.topic { display:block; float:left; position:relative; width:175px; height:300px; padding:10px 5px 10px 35px; background: url('bg.png'); border-radius:15px; margin:30px 0 30px 50px; color:#000; }
.topic .delete {position: absolute;
top: -14px;
left: 0px;
background: none;
border: 0;
color: white;
border: none;
font-size: 14px;
margin: 0;
padding: 0;
cursor:pointer;
}
.topic .scroll { display:block; height:283px; }
.topic .type {position: absolute;
color: white;
top: -22px;
right: 0;
font-weight: bold;
font-size: 20px;
line-height: 24px;}
.topic .icon { position:absolute; top:135px; left:-25px; }
.topic .title { font-size:22px; line-height:25px; display:block; border-bottom:2px solid #000; padding-bottom:5px; }
.topic .desc { font-size:15px; font-family:Arial, Helvetica, sans-serif; }
.topic .desc h3 { font-style:normal; margin-top:5px; }
.topic .link { position:absolute; width:170px; top:295px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

View file

@ -1,5 +1,5 @@
class MainController < ApplicationController class MainController < ApplicationController
include ItemsHelper include TopicsHelper
before_filter :require_user, only: [:invite] before_filter :require_user, only: [:invite]
@ -11,16 +11,16 @@ class MainController < ApplicationController
def search def search
@current = current_user @current = current_user
@items = Array.new() @topics = Array.new()
if params[:topics_by_user_id] != "" if params[:topics_by_user_id] != ""
@user = User.find(params[:topics_by_user_id]) @user = User.find(params[:topics_by_user_id])
@items = Item.visibleToUser(@current, @user) @topics = Topic.visibleToUser(@current, @user)
elsif params[:topics_by_map_id] != "" elsif params[:topics_by_map_id] != ""
@map = Map.find(params[:topics_by_map_id]) @map = Map.find(params[:topics_by_map_id])
@items = @map.items.delete_if{|item| not item.authorize_to_view(@current)} @topics = @map.topics.delete_if{|topic| not topic.authorize_to_view(@current)}
end end
respond_to do |format| respond_to do |format|
format.js { respond_with(@items) } format.js { respond_with(@topics) }
end end
end end

View file

@ -63,15 +63,15 @@ class MapsController < ApplicationController
if params[:map][:topicsToMap] if params[:map][:topicsToMap]
@all = params[:map][:topicsToMap] @all = params[:map][:topicsToMap]
@all = @all.split(',') @all = @all.split(',')
@all.each do |item| @all.each do |topic|
item = item.split('/') topic = topic.split('/')
@mapping = Mapping.new() @mapping = Mapping.new()
@mapping.category = "Item" @mapping.category = "Topic"
@mapping.user = @user @mapping.user = @user
@mapping.map = @map @mapping.map = @map
@mapping.item = Item.find(item[0]) @mapping.topic = Topic.find(topic[0])
@mapping.xloc = item[1] @mapping.xloc = topic[1]
@mapping.yloc = item[2] @mapping.yloc = topic[2]
@mapping.save @mapping.save
end end
@map.arranged = true @map.arranged = true
@ -95,9 +95,9 @@ class MapsController < ApplicationController
redirect_to root_url and return redirect_to root_url and return
end end
@outitems = @map.items.order("name ASC").delete_if{|item| not item.authorize_to_view(@current)} @outtopics = @map.topics.order("name ASC").delete_if{|topic| not topic.authorize_to_view(@current)}
respond_with(@user, @map, @outitems) respond_with(@user, @map, @outtopics)
end end
# PUT maps/:id # PUT maps/:id
@ -107,10 +107,10 @@ class MapsController < ApplicationController
@map.attributes = params[:map] @map.attributes = params[:map]
@map.save @map.save
if params[:outitems] if params[:outtopics]
@outitems = params[:outitems] @outtopics = params[:outtopics]
@outitems.each do |item| @outtopics.each do |topic|
@mapping = Mapping.where("map_id = ? AND item_id = ?", @map.id, item).first @mapping = Mapping.where("map_id = ? AND topic_id = ?", @map.id, topic).first
@mapping.delete @mapping.delete
end end
end end
@ -126,11 +126,11 @@ class MapsController < ApplicationController
if params[:map][:coordinates] if params[:map][:coordinates]
@all = params[:map][:coordinates] @all = params[:map][:coordinates]
@all = @all.split(',') @all = @all.split(',')
@all.each do |item| @all.each do |topic|
item = item.split('/') topic = topic.split('/')
@mapping = Mapping.find(item[0]) @mapping = Mapping.find(topic[0])
@mapping.xloc = item[1] @mapping.xloc = topic[1]
@mapping.yloc = item[2] @mapping.yloc = topic[2]
@mapping.save @mapping.save
end end
@map.arranged = true @map.arranged = true

View file

@ -1,5 +1,5 @@
class SynapsesController < ApplicationController class SynapsesController < ApplicationController
include ItemsHelper include TopicsHelper
before_filter :require_user, only: [:new, :create, :edit, :update] before_filter :require_user, only: [:new, :create, :edit, :update]
@ -39,10 +39,10 @@ class SynapsesController < ApplicationController
def show def show
@current = current_user @current = current_user
@synapse = Synapse.find(params[:id]).authorize_to_show(@current) @synapse = Synapse.find(params[:id]).authorize_to_show(@current)
@item1 = @synapse.item1.authorize_to_show(@current) @topic1 = @synapse.topic1.authorize_to_show(@current)
@item2 = @synapse.item2.authorize_to_show(@current) @topic2 = @synapse.topic2.authorize_to_show(@current)
if @synapse && @item1 && @item2 if @synapse && @topic1 && @topic2
@synapsejson = @synapse.selfplusnodes_as_json.html_safe @synapsejson = @synapse.selfplusnodes_as_json.html_safe
else else
redirect_to root_url and return redirect_to root_url and return
@ -60,8 +60,8 @@ class SynapsesController < ApplicationController
@user = current_user @user = current_user
@synapse = Synapse.new() @synapse = Synapse.new()
@synapse.desc = params[:synapse][:desc] @synapse.desc = params[:synapse][:desc]
@synapse.item1 = Item.find(params[:synapse][:item1id]) @synapse.topic1 = Topic.find(params[:synapse][:topic1id])
@synapse.item2 = Item.find(params[:synapse][:item2id]) @synapse.topic2 = Topic.find(params[:synapse][:topic2id])
@synapse.permission = "commons" @synapse.permission = "commons"
@synapse.category = "from-to" @synapse.category = "from-to"
@synapse.weight = 5 @synapse.weight = 5
@ -90,12 +90,12 @@ class SynapsesController < ApplicationController
@synapse = Synapse.find(params[:id]).authorize_to_edit(@current) @synapse = Synapse.find(params[:id]).authorize_to_edit(@current)
if @synapse if @synapse
@items = Item.visibleToUser(@current, nil) @topics = Topic.visibleToUser(@current, nil)
elsif not @synapse elsif not @synapse
redirect_to root_url and return redirect_to root_url and return
end end
respond_with(@synapse, @items) respond_with(@synapse, @topics)
end end
# PUT synapses/:id # PUT synapses/:id
@ -106,8 +106,8 @@ class SynapsesController < ApplicationController
if @synapse if @synapse
@synapse.desc = params[:synapse][:desc] @synapse.desc = params[:synapse][:desc]
@synapse.category = params[:synapse][:category] @synapse.category = params[:synapse][:category]
@synapse.item1 = Item.find(params[:node1_id][:node1]) @synapse.topic1 = Topic.find(params[:node1_id][:node1])
@synapse.item2 = Item.find(params[:node2_id][:node2]) @synapse.topic2 = Topic.find(params[:node2_id][:node2])
@synapse.permission = params[:synapse][:permission] @synapse.permission = params[:synapse][:permission]
@synapse.save @synapse.save
end end

View file

@ -0,0 +1,163 @@
class TopicsController < ApplicationController
before_filter :require_user, only: [:new, :create, :edit, :update]
respond_to :html, :js, :json
autocomplete :topic, :name, :full => true, :extra_data => [:user_id]
# GET topics
# or GET /users/:user_id/topics
def index
@current = current_user
if params[:user_id]
@user = User.find(params[:user_id])
@topics = Topic.order("name ASC").visibleToUser(@current, @user)
elsif
@topics = Topic.order("name ASC").visibleToUser(@current, nil)
end
respond_with(@user,@topics)
end
# Get topics/new
def new
@topic = Topic.new
@user = current_user
respond_with(@topic)
end
# GET topics/:id
def show
@current = current_user
@topic = Topic.find(params[:id]).authorize_to_show(@current)
if @topic
@relatives = @topic.network_as_json(@current).html_safe
else
redirect_to root_url and return
end
respond_to do |format|
format.html { respond_with(@topic, @user) }
format.json { respond_with(@relatives) }
end
end
# GET showcard/:id
def showcard
@user = current_user
@topic = Topic.find(params[:id]).authorize_to_show(@user)
respond_to do |format|
format.html { respond_with(@topic, @user) }
end
end
# POST topics
def create
@user = current_user
# if the topic exists grab it and return it
if params[:topic][:grabTopic] != "null"
@topic = Topic.find(params[:topic][:grabTopic])
# if the topic doesn't exist yet, create it
else
@topic = Topic.new()
@topic.name = params[:topic][:name]
@topic.desc = ""
@topic.link = ""
@topic.permission = 'commons'
@topic.metacode = Metacode.find_by_name(params[:topic][:metacode])
@topic.user = @user
@topic.save
end
# pass on to the topic create js whether it's being created with a synapse
@synapse = "false"
if params[:topic][:addSynapse] == "true"
@synapse = "true"
end
# also create an object to return the position to the canvas
@position = Hash.new()
@position['x'] = params[:topic][:x]
@position['y'] = params[:topic][:y]
# set this for the case where the topic is being created on a map.
@mapping = Mapping.new()
if params[:topic][:map]
@mapping.category = "Topic"
@mapping.user = @user
@mapping.map = Map.find(params[:topic][:map])
@mapping.topic = @topic
@mapping.xloc = params[:topic][:x]
@mapping.yloc = params[:topic][:y]
@mapping.save
end
respond_to do |format|
format.html { respond_with(@user, location: topic_url(@topic)) }
format.js { respond_with(@topic, @mapping, @synapse, @position) }
end
end
# GET topics/:id/edit
def edit
@current = current_user
@topic = Topic.find(params[:id]).authorize_to_edit(@current)
if not @topic
redirect_to root_url and return
end
respond_with(@topic)
end
# PUT topics/:id
def update
@current = current_user
@topic = Topic.find(params[:id]).authorize_to_edit(@current)
if @topic
@topic.name = params[:topic][:name]
@topic.desc = params[:topic][:desc]
@topic.link = params[:topic][:link]
@topic.permission = params[:topic][:permission]
@topic.metacode = Metacode.find(params[:category][:metacode_id])
@topic.save
end
respond_with(@user, location: topic_url(@topic)) do |format|
end
end
# DELETE topics/:id
def destroy
@current = current_user
@topic = Topic.find(params[:id]).authorize_to_edit(@current)
if @topic
@synapses = @topic.synapses
@mappings = @topic.mappings
@synapses.each do |synapse|
synapse.delete
end
@mappings.each do |mapping|
mapping.delete
end
@topic.delete
end
respond_to do |format|
format.js
end
end
end

View file

@ -0,0 +1,128 @@
module TopicsHelper
#find all nodes in any given nodes network
def network(node, array, count)
# recurse starting with a node to find all connected nodes and return an array of topics that constitutes the starting nodes network
# if the array of nodes is empty initialize it
if array.nil?
array = Array.new
end
# add the node to the array
array.push(node)
if count == 0
return array
end
count = count - 1
# check if each relative is already in the array and if not, call the network function again
if not node.relatives.empty?
if (node.relatives-array).empty?
return array
else
(node.relatives-array).each do |relative|
array = (array | network(relative, array, count))
end
return array
end
elsif node.relatives.empty?
return array
end
end
#return a json object containing all of a users added synapses
def synapses_as_json(current, synapses)
Jbuilder.encode do |json|
@topics = Array.new
synapses.each do |synapse|
@topics.push(synapse.topic1) if (not @topics.include?(synapse.topic1)) && synapse.topic1.authorize_to_view(current)
@topics.push(synapse.topic2) if (not @topics.include?(synapse.topic2)) && synapse.topic2.authorize_to_view(current)
end
json.array!(@topics) do |topic|
json.adjacencies topic.synapses2.delete_if{|synapse| not @topics.include?(Topic.find_by_id(synapse.node1_id))} do |json, synapse|
json.nodeTo synapse.node1_id
json.nodeFrom synapse.node2_id
@synapsedata = Hash.new
@synapsedata['$desc'] = synapse.desc
@synapsedata['$showDesc'] = false
@synapsedata['$category'] = synapse.category
@synapsedata['$id'] = synapse.id
@synapsedata['$userid'] = synapse.user.id
@synapsedata['$username'] = synapse.user.name
@synapsedata['$direction'] = [synapse.node1_id.to_s(), synapse.node2_id.to_s()]
json.data @synapsedata
end
@inmaps = Array.new
topic.maps.each do |map|
@inmaps.push(map.id)
end
@topicdata = Hash.new
@topicdata['$desc'] = topic.desc
@topicdata['$link'] = topic.link
@topicdata['$metacode'] = topic.metacode.name
@topicdata['$inmaps'] = @inmaps
@topicdata['$userid'] = topic.user.id
@topicdata['$username'] = topic.user.name
json.data @topicdata
json.id topic.id
json.name topic.name
end
end
end
def all_as_json(current, user)
# current is current user
Jbuilder.encode do |json|
if user.nil?
@topics = Topic.visibleToUser(current, nil)
@synapses = Synapse.visibleToUser(current, nil)
else
@topics = Topic.visibleToUser(current, user)
@synapses = Synapse.visibleToUser(current, user)
end
json.array!(@topics) do |topic|
json.adjacencies topic.synapses2.delete_if{|synapse| (not @topics.include?(Topic.find_by_id(synapse.node1_id))) || (not @synapses.include?(synapse))} do |json, synapse|
json.nodeTo synapse.node1_id
json.nodeFrom synapse.node2_id
@synapsedata = Hash.new
@synapsedata['$desc'] = synapse.desc
@synapsedata['$category'] = synapse.category
@synapsedata['$userid'] = synapse.user.id
@synapsedata['$username'] = synapse.user.name
json.data @synapsedata
end
@inmaps = Array.new
topic.maps.each do |map|
@inmaps.push(map.id)
end
@topicdata = Hash.new
@topicdata['$desc'] = topic.desc
@topicdata['$link'] = topic.link
@topicdata['$metacode'] = topic.metacode.name
@topicdata['$inmaps'] = @inmaps
@topicdata['$userid'] = topic.user.id
@topicdata['$username'] = topic.user.name
json.data @topicdata
json.id topic.id
json.name topic.name
end
end
end
end

View file

@ -2,14 +2,14 @@ class Map < ActiveRecord::Base
belongs_to :user belongs_to :user
has_many :itemmappings, :class_name => 'Mapping', :conditions => {:category => 'Item'} has_many :topicmappings, :class_name => 'Mapping', :conditions => {:category => 'Topic'}
has_many :synapsemappings, :class_name => 'Mapping', :conditions => {:category => 'Synapse'} has_many :synapsemappings, :class_name => 'Mapping', :conditions => {:category => 'Synapse'}
has_many :items, :through => :itemmappings has_many :topics, :through => :topicmappings
has_many :synapses, :through => :synapsemappings has_many :synapses, :through => :synapsemappings
def mappings def mappings
itemmappings + synapsemappings topicmappings + synapsemappings
end end
@ -17,14 +17,14 @@ end
#build a json object of a map #build a json object of a map
def self_as_json(current) def self_as_json(current)
Jbuilder.encode do |json| Jbuilder.encode do |json|
@items = self.items @topics = self.topics
@synapses = self.synapses @synapses = self.synapses
json.array!(@items.delete_if{|item| not item.authorize_to_view(current)}) do |item| json.array!(@topics.delete_if{|topic| not topic.authorize_to_view(current)}) do |topic|
#json.adjacencies item.synapses2.delete_if{|synapse| (not @items.include?(synapse.item1)) || (not @synapses.include?(synapse)) || (not synapse.authorize_to_view(current)) || (not synapse.item1.authorize_to_view(current)) } do |json, synapse| #json.adjacencies topic.synapses2.delete_if{|synapse| (not @topics.include?(synapse.topic1)) || (not @synapses.include?(synapse)) || (not synapse.authorize_to_view(current)) || (not synapse.topic1.authorize_to_view(current)) } do |json, synapse|
json.adjacencies item.synapses1.delete_if{|synapse| (not @items.include?(synapse.item2)) || (not synapse.authorize_to_view(current)) || (not synapse.item2.authorize_to_view(current)) } do |json, synapse| json.adjacencies topic.synapses1.delete_if{|synapse| (not @topics.include?(synapse.topic2)) || (not synapse.authorize_to_view(current)) || (not synapse.topic2.authorize_to_view(current)) } do |json, synapse|
json.nodeTo synapse.node2_id json.nodeTo synapse.node2_id
json.nodeFrom synapse.node1_id json.nodeFrom synapse.node1_id
@ -40,24 +40,24 @@ end
end end
@inmaps = Array.new @inmaps = Array.new
item.maps.each do |map| topic.maps.each do |map|
@inmaps.push(map.id) @inmaps.push(map.id)
end end
@itemdata = Hash.new @topicdata = Hash.new
@itemdata['$desc'] = item.desc @topicdata['$desc'] = topic.desc
@itemdata['$link'] = item.link @topicdata['$link'] = topic.link
@itemdata['$itemcatname'] = item.item_category.name @topicdata['$metacode'] = topic.metacode.name
@itemdata['$inmaps'] = @inmaps @topicdata['$inmaps'] = @inmaps
@itemdata['$userid'] = item.user.id @topicdata['$userid'] = topic.user.id
@itemdata['$username'] = item.user.name @topicdata['$username'] = topic.user.name
@mapping = Mapping.find_by_item_id_and_map_id(item.id,self.id) @mapping = Mapping.find_by_topic_id_and_map_id(topic.id,self.id)
@itemdata['$xloc'] = @mapping.xloc @topicdata['$xloc'] = @mapping.xloc
@itemdata['$yloc'] = @mapping.yloc @topicdata['$yloc'] = @mapping.yloc
@itemdata['$mappingid'] = @mapping.id @topicdata['$mappingid'] = @mapping.id
json.data @itemdata json.data @topicdata
json.id item.id json.id topic.id
json.name item.name json.name topic.name
end end
end end
end end

View file

@ -1,6 +1,6 @@
class Mapping < ActiveRecord::Base class Mapping < ActiveRecord::Base
belongs_to :item, :class_name => "Item", :foreign_key => "item_id" belongs_to :topic, :class_name => "Topic", :foreign_key => "topic_id"
belongs_to :synapse, :class_name => "Synapse", :foreign_key => "synapse_id" belongs_to :synapse, :class_name => "Synapse", :foreign_key => "synapse_id"
belongs_to :map, :class_name => "Map", :foreign_key => "map_id" belongs_to :map, :class_name => "Map", :foreign_key => "map_id"

5
app/models/metacode.rb Normal file
View file

@ -0,0 +1,5 @@
class Metacode < ActiveRecord::Base
has_many :topics
end

View file

@ -2,8 +2,8 @@ class Synapse < ActiveRecord::Base
belongs_to :user belongs_to :user
belongs_to :item1, :class_name => "Item", :foreign_key => "node1_id" belongs_to :topic1, :class_name => "Topic", :foreign_key => "node1_id"
belongs_to :item2, :class_name => "Item", :foreign_key => "node2_id" belongs_to :topic2, :class_name => "Topic", :foreign_key => "node2_id"
has_many :mappings has_many :mappings
has_many :maps, :through => :mappings has_many :maps, :through => :mappings
@ -26,12 +26,12 @@ has_many :maps, :through => :mappings
def selfplusnodes_as_json def selfplusnodes_as_json
Jbuilder.encode do |json| Jbuilder.encode do |json|
@items = Array.new @topics = Array.new
@items.push(self.item1) @topics.push(self.topic1)
@items.push(self.item2) @topics.push(self.topic2)
json.array!(@items) do |item| json.array!(@topics) do |topic|
json.adjacencies item.synapses1.delete_if{|synapse| not @items.include?(Item.find_by_id(synapse.node2_id))} do |json, synapse| json.adjacencies topic.synapses1.delete_if{|synapse| not @topics.include?(Topic.find_by_id(synapse.node2_id))} do |json, synapse|
json.nodeTo synapse.node2_id json.nodeTo synapse.node2_id
json.nodeFrom synapse.node1_id json.nodeFrom synapse.node1_id
@ -47,20 +47,20 @@ has_many :maps, :through => :mappings
end end
@inmaps = Array.new @inmaps = Array.new
item.maps.each do |map| topic.maps.each do |map|
@inmaps.push(map.id) @inmaps.push(map.id)
end end
@itemdata = Hash.new @topicdata = Hash.new
@itemdata['$desc'] = item.desc @topicdata['$desc'] = topic.desc
@itemdata['$link'] = item.link @topicdata['$link'] = topic.link
@itemdata['$itemcatname'] = item.item_category.name @topicdata['$metacode'] = topic.metacode.name
@itemdata['$inmaps'] = @inmaps @topicdata['$inmaps'] = @inmaps
@itemdata['$userid'] = item.user.id @topicdata['$userid'] = topic.user.id
@itemdata['$username'] = item.user.name @topicdata['$username'] = topic.user.name
json.data @itemdata json.data @topicdata
json.id item.id json.id topic.id
json.name item.name json.name topic.name
end end
end end
end end

171
app/models/topic.rb Normal file
View file

@ -0,0 +1,171 @@
class Topic < ActiveRecord::Base
include TopicsHelper
belongs_to :user
has_many :synapses1, :class_name => 'Synapse', :foreign_key => 'node1_id'
has_many :synapses2, :class_name => 'Synapse', :foreign_key => 'node2_id'
has_many :topics1, :through => :synapses2, :source => :topic1
has_many :topics2, :through => :synapses1, :source => :topic2
has_many :mappings
has_many :maps, :through => :mappings
def synapses
synapses1 + synapses2
end
def relatives
topics1 + topics2
end
belongs_to :metacode
# has no viewable synapses helper function
def has_viewable_synapses(current)
result = false
self.synapses.each do |synapse|
if synapse.authorize_to_view(current)
result = true
end
end
return result
end
###### JSON ######
def self_as_json
Jbuilder.encode do |json|
@inmaps = Array.new
self.maps.each do |map|
@inmaps.push(map.id)
end
@topicdata = Hash.new
@topicdata['$desc'] = self.desc
@topicdata['$link'] = self.link
@topicdata['$metacode'] = self.metacode.name
@topicdata['$inmaps'] = @inmaps
@topicdata['$userid'] = self.user.id
@topicdata['$username'] = self.user.name
json.data @topicdata
json.id self.id
json.name self.name
end
end
#build a json object of everything connected to a specified node
def network_as_json(current)
Jbuilder.encode do |json|
@topics = network(self,nil,4)
if @topics.count > 1
json.array!(@topics.delete_if{|topic| (not topic.authorize_to_view(current)) || (not topic.has_viewable_synapses(current))}) do |topic|
json.adjacencies topic.synapses1.delete_if{|synapse| (not @topics.include?(synapse.topic2)) || (not synapse.authorize_to_view(current)) || (not synapse.topic2.authorize_to_view(current)) } do |json, synapse|
json.nodeTo synapse.node2_id
json.nodeFrom synapse.node1_id
@synapsedata = Hash.new
@synapsedata['$desc'] = synapse.desc
@synapsedata['$showDesc'] = false
@synapsedata['$category'] = synapse.category
@synapsedata['$id'] = synapse.id
@synapsedata['$userid'] = synapse.user.id
@synapsedata['$username'] = synapse.user.name
@synapsedata['$direction'] = [synapse.node1_id.to_s(), synapse.node2_id.to_s()]
json.data @synapsedata
end
@inmaps = Array.new
topic.maps.each do |map|
@inmaps.push(map.id)
end
@topicdata = Hash.new
@topicdata['$desc'] = topic.desc
@topicdata['$link'] = topic.link
@topicdata['$metacode'] = topic.metacode.name
@topicdata['$inmaps'] = @inmaps
@topicdata['$userid'] = topic.user.id
@topicdata['$username'] = topic.user.name
json.data @topicdata
json.id topic.id
json.name topic.name
end
elsif @topics.count == 1
json.array!(@topics) do |topic|
@inmaps = Array.new
topic.maps.each do |map|
@inmaps.push(map.id)
end
@topicdata = Hash.new
@topicdata['$desc'] = topic.desc
@topicdata['$link'] = topic.link
@topicdata['$metacode'] = topic.metacode.name
@topicdata['$inmaps'] = @inmaps
@topicdata['$userid'] = topic.user.id
@topicdata['$username'] = topic.user.name
json.data @topicdata
json.id topic.id
json.name topic.name
end
end
end
end
##### PERMISSIONS ######
scope :visibleToUser, lambda { |current, user|
if user != nil
if user != current
Topic.find_all_by_user_id_and_permission(user.id, "commons") | Topic.find_all_by_user_id_and_permission(user.id, "public")
elsif user == current
Topic.find_all_by_user_id_and_permission(user.id, "commons") | Topic.find_all_by_user_id_and_permission(user.id, "public") | current.topics.where(:permission => "private")
end
elsif (current != nil && user == nil)
Topic.find_all_by_permission("commons") | Topic.find_all_by_permission("public") | current.topics.where(:permission => "private")
elsif (current == nil)
Topic.find_all_by_permission("commons") | Topic.find_all_by_permission("public")
end
}
# returns false if user not allowed to 'show' Topic, Synapse, or Map
def authorize_to_show(user)
if (self.permission == "private" && self.user != user)
return false
end
return self
end
# returns false if user not allowed to 'edit' Topic, Synapse, or Map
def authorize_to_edit(user)
if (self.permission == "private" && self.user != user)
return false
elsif (self.permission == "public" && self.user != user)
return false
end
return self
end
# returns Boolean if user allowed to view Topic, Synapse, or Map
def authorize_to_view(user)
if (self.permission == "private" && self.user != user)
return false
end
return true
end
# returns Boolean based on whether user has permissions to edit or not
def authorize_linkto_edit(user)
if (self.user == user)
return true
elsif (self.permission == "commons")
return true
end
return false
end
end

View file

@ -2,7 +2,7 @@ require 'open-uri'
class User < ActiveRecord::Base class User < ActiveRecord::Base
has_many :items has_many :topics
has_many :synapses has_many :synapses
has_many :maps has_many :maps
has_many :mappings has_many :mappings

View file

@ -33,7 +33,7 @@
<% unless authenticated? %> <% unless authenticated? %>
<ul class="menu"> <ul class="menu">
<li class="first"><%= link_to "Console", console_url %></li> <li class="first"><%= link_to "Console", console_url %></li>
<li><%= link_to "Topics", items_url %></li> <li><%= link_to "Topics", topics_url %></li>
<li><%= link_to "Synapses", synapses_url %></li> <li><%= link_to "Synapses", synapses_url %></li>
<li><%= link_to "Maps", maps_url %></li> <li><%= link_to "Maps", maps_url %></li>
<li class="last"><%= link_to "Login", new_session_path, id: "Login" %></li> <li class="last"><%= link_to "Login", new_session_path, id: "Login" %></li>
@ -43,7 +43,7 @@
<ul class="menu"> <ul class="menu">
<li class="first"><%= link_to "Console", console_url %></li> <li class="first"><%= link_to "Console", console_url %></li>
<li><%= link_to "Create Map", new_map_url %></li> <li><%= link_to "Create Map", new_map_url %></li>
<li><%= link_to "My Topics", user_items_url(user) %></li> <li><%= link_to "My Topics", user_topics_url(user) %></li>
<li><%= link_to "My Synapses", user_synapses_url(user) %></li> <li><%= link_to "My Synapses", user_synapses_url(user) %></li>
<li><%= link_to "My Maps", user_maps_url(user) %></li> <li><%= link_to "My Maps", user_maps_url(user) %></li>
<li><%= link_to "Invite", invite_path %></li> <li><%= link_to "Invite", invite_path %></li>

View file

@ -10,7 +10,7 @@
</div> </div>
<div class="clearfloat"></div> <div class="clearfloat"></div>
<% if authenticated? %> <% if authenticated? %>
<%= render :partial => 'items/new' %> <%= render :partial => 'topics/new' %>
<%= render :partial => 'synapses/new' %> <%= render :partial => 'synapses/new' %>
<%= render :partial => 'maps/new' %> <%= render :partial => 'maps/new' %>
<% end %> <% end %>
@ -43,8 +43,8 @@
<option value="mapper (by name)">mapper (by name)</option> <option value="mapper (by name)">mapper (by name)</option>
</select> </select>
<div class="clearfloat"></div> <div class="clearfloat"></div>
<%= form_for Item.new, :html => { :class => "find_topic_by_name find find_topic", :id => "find_topic_by_name" } do |f| %> <%= form_for Topic.new, :html => { :class => "find_topic_by_name find find_topic", :id => "find_topic_by_name" } do |f| %>
<%= f.autocomplete_field :name, autocomplete_item_name_items_path, :id => "topic_by_name_input", :placeholder => "Search for topics..." %> <%= f.autocomplete_field :name, autocomplete_topic_name_topics_path, :id => "topic_by_name_input", :placeholder => "Search for topics..." %>
<% end %> <% end %>
<%= form_for Map.new, :html => { :class => "find_map_by_name find", :id => "find_map_by_name" } do |f| %> <%= form_for Map.new, :html => { :class => "find_map_by_name find", :id => "find_map_by_name" } do |f| %>
<%= f.autocomplete_field :name, autocomplete_map_name_maps_path, :id => "map_by_name_input", :placeholder => "Search for maps..." %> <%= f.autocomplete_field :name, autocomplete_map_name_maps_path, :id => "map_by_name_input", :placeholder => "Search for maps..." %>

View file

@ -1,4 +1,4 @@
<% unless @item.nil? %> <% unless @topic.nil? %>
<div class="home" id="container"> <div class="home" id="container">
<div id="center-container"> <div id="center-container">
<div id="infovis"></div> <div id="infovis"></div>
@ -14,12 +14,12 @@
}); });
</script> </script>
<% end %> <% end %>
<% if @item.nil? %> <% if @topic.nil? %>
<p><br>Shucks, there is nothing in metamaps.<p> <p><br>Shucks, there is nothing in metamaps.<p>
<% end %> <% end %>
<% if authenticated? %> <% if authenticated? %>
<%= render :partial => 'items/new' %> <%= render :partial => 'topics/new' %>
<%= render :partial => 'synapses/new' %> <%= render :partial => 'synapses/new' %>
<% end %> <% end %>

View file

@ -7,11 +7,11 @@ var myX = -w + 400;
var myY = -h + 100; var myY = -h + 100;
var even = true; var even = true;
<% @items.each do |item| %> <% @topics.each do |topic| %>
if ($.isEmptyObject(Mconsole.graph.nodes)) { if ($.isEmptyObject(Mconsole.graph.nodes)) {
json = <%= item.self_as_json.html_safe %>; json = <%= topic.self_as_json.html_safe %>;
Mconsole.loadJSON(json); Mconsole.loadJSON(json);
var temp = Mconsole.graph.getNode('<%= item.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('inCommons',true);
@ -23,11 +23,11 @@ var even = true;
even = !even; even = !even;
} }
else { else {
var temp = Mconsole.graph.getNode('<%= item.id %>'); var temp = Mconsole.graph.getNode('<%= topic.id %>');
if (temp == null) { if (temp == null) {
var newnode = <%= item.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('<%= item.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('inCommons',true);

View file

@ -2,7 +2,7 @@
<% if map.user == user %><%= link_to 'Delete', map_path(map), :class => 'delete', :confirm => 'Delete this map (nodes and synapses will remain)?', :method => :delete, :remote => true %><% end %> <% if map.user == user %><%= link_to 'Delete', map_path(map), :class => 'delete', :confirm => 'Delete this map (nodes and synapses will remain)?', :method => :delete, :remote => true %><% end %>
<div class="scroll"> <div class="scroll">
<%= link_to map.name, map_path(map), :class => 'title' %> <%= link_to map.name, map_path(map), :class => 'title' %>
<div class="desc"><p><%= map.desc %></p><p># of Topics: <%= map.items.count %></p><p># of Synapses: <%= map.synapses.count %></p></div> <div class="desc"><p><%= map.desc %></p><p># of Topics: <%= map.topics.count %></p><p># of Synapses: <%= map.synapses.count %></p></div>
</div> </div>
<div class="link"><p>Permissions:<%= map.permission %></p></div> <div class="link"><p>Permissions:<%= map.permission %></p></div>
<% end %> <% end %>

View file

@ -1,8 +1,8 @@
<div class="anypage"> <div class="anypage">
<%= form_for Synapse.new, url: synapses_url, remote: true do |form| %> <%= form_for Synapse.new, url: synapses_url, remote: true do |form| %>
<%= form.autocomplete_field :desc, autocomplete_synapse_desc_synapses_path, :placeholder => "Describe the connection..." %> <%= form.autocomplete_field :desc, autocomplete_synapse_desc_synapses_path, :placeholder => "Describe the connection..." %>
<%= form.hidden_field :item1id, :value => 0 %> <%= form.hidden_field :topic1id, :value => 0 %>
<%= form.hidden_field :item2id, :value => 0 %> <%= form.hidden_field :topic2id, :value => 0 %>
<%= form.hidden_field :map, :value => @map.id %> <%= form.hidden_field :map, :value => @map.id %>
<% end %> <% end %>
</div> </div>

View file

@ -1,12 +1,12 @@
<div class="anypage"> <div class="anypage">
<%= form_for Item.new, url: items_url, remote: true do |form| %> <%= form_for Topic.new, url: topics_url, remote: true do |form| %>
<div id="metacodeImg"><img class="cloudcarousel" width="40" height="40" src="/assets/action.png" alt="Action" title="Action"/><img class="cloudcarousel" width="40" height="40" src="/assets/activity.png" alt="Activity" title="Activity"/><img class="cloudcarousel" width="40" height="40" src="/assets/bizarre.png" alt="Bizarre" title="Bizarre"/><img class="cloudcarousel" width="40" height="40" src="/assets/catalyst.png" alt="Catalyst" title="Catalyst"/><img class="cloudcarousel" width="40" height="40" src="/assets/closed.png" alt="Closed" title="Closed"/><img class="cloudcarousel" width="40" height="40" src="/assets/experience.png" alt="Experience" title="Experience"/><img class="cloudcarousel" width="40" height="40" src="/assets/futuredev.png" alt="Future Dev" title="Future Dev"/><img class="cloudcarousel" width="40" height="40" src="/assets/group.png" alt="Group" title="Group"/><img class="cloudcarousel" width="40" height="40" src="/assets/idea.png" alt="Idea" title="Idea"/><img class="cloudcarousel" width="40" height="40" src="/assets/implication.png" alt="Implication" title="Implication"/><img class="cloudcarousel" width="40" height="40" src="/assets/insight.png" alt="Insight" title="Insight"/><img class="cloudcarousel" width="40" height="40" src="/assets/intention.png" alt="Intention" title="Intention"/><img class="cloudcarousel" width="40" height="40" src="/assets/knowledge.png" alt="Knowledge" title="Knowledge"/><img class="cloudcarousel" width="40" height="40" src="/assets/location.png" alt="Location" title="Location"/><img class="cloudcarousel" width="40" height="40" src="/assets/openissue.png" alt="Open Issue" title="Open Issue"/><img class="cloudcarousel" width="40" height="40" src="/assets/opinion.png" alt="Opinion" title="Opinion"/><img class="cloudcarousel" width="40" height="40" src="/assets/opportunity.png" alt="Opportunity" title="Opportunity"/><img class="cloudcarousel" width="40" height="40" src="/assets/person.png" alt="Person" title="Person"/><img class="cloudcarousel" width="40" height="40" src="/assets/platform.png" alt="Platform" title="Platform"/><img class="cloudcarousel" width="40" height="40" src="/assets/problem.png" alt="Problem" title="Problem"/><img class="cloudcarousel" width="40" height="40" src="/assets/question.png" alt="Question" title="Question"/><img class="cloudcarousel" width="40" height="40" src="/assets/reference.png" alt="Reference" title="Reference"/><img class="cloudcarousel" width="40" height="40" src="/assets/requirement.png" alt="Requirement" title="Requirement"/><img class="cloudcarousel" width="40" height="40" src="/assets/resource.png" alt="Resource" title="Resource"/><img class="cloudcarousel" width="40" height="40" src="/assets/role.png" alt="Role" title="Role"/><img class="cloudcarousel" width="40" height="40" src="/assets/task.png" alt="Task" title="Task"/><img class="cloudcarousel" width="40" height="40" src="/assets/tool.png" alt="Tool" title="Tool"/><img class="cloudcarousel" width="40" height="40" src="/assets/trajectory.png" alt="Trajectory" title="Trajectory"/></div> <div id="metacodeImg"><img class="cloudcarousel" width="40" height="40" src="/assets/action.png" alt="Action" title="Action"/><img class="cloudcarousel" width="40" height="40" src="/assets/activity.png" alt="Activity" title="Activity"/><img class="cloudcarousel" width="40" height="40" src="/assets/bizarre.png" alt="Bizarre" title="Bizarre"/><img class="cloudcarousel" width="40" height="40" src="/assets/catalyst.png" alt="Catalyst" title="Catalyst"/><img class="cloudcarousel" width="40" height="40" src="/assets/closed.png" alt="Closed" title="Closed"/><img class="cloudcarousel" width="40" height="40" src="/assets/experience.png" alt="Experience" title="Experience"/><img class="cloudcarousel" width="40" height="40" src="/assets/futuredev.png" alt="Future Dev" title="Future Dev"/><img class="cloudcarousel" width="40" height="40" src="/assets/group.png" alt="Group" title="Group"/><img class="cloudcarousel" width="40" height="40" src="/assets/idea.png" alt="Idea" title="Idea"/><img class="cloudcarousel" width="40" height="40" src="/assets/implication.png" alt="Implication" title="Implication"/><img class="cloudcarousel" width="40" height="40" src="/assets/insight.png" alt="Insight" title="Insight"/><img class="cloudcarousel" width="40" height="40" src="/assets/intention.png" alt="Intention" title="Intention"/><img class="cloudcarousel" width="40" height="40" src="/assets/knowledge.png" alt="Knowledge" title="Knowledge"/><img class="cloudcarousel" width="40" height="40" src="/assets/location.png" alt="Location" title="Location"/><img class="cloudcarousel" width="40" height="40" src="/assets/openissue.png" alt="Open Issue" title="Open Issue"/><img class="cloudcarousel" width="40" height="40" src="/assets/opinion.png" alt="Opinion" title="Opinion"/><img class="cloudcarousel" width="40" height="40" src="/assets/opportunity.png" alt="Opportunity" title="Opportunity"/><img class="cloudcarousel" width="40" height="40" src="/assets/person.png" alt="Person" title="Person"/><img class="cloudcarousel" width="40" height="40" src="/assets/platform.png" alt="Platform" title="Platform"/><img class="cloudcarousel" width="40" height="40" src="/assets/problem.png" alt="Problem" title="Problem"/><img class="cloudcarousel" width="40" height="40" src="/assets/question.png" alt="Question" title="Question"/><img class="cloudcarousel" width="40" height="40" src="/assets/reference.png" alt="Reference" title="Reference"/><img class="cloudcarousel" width="40" height="40" src="/assets/requirement.png" alt="Requirement" title="Requirement"/><img class="cloudcarousel" width="40" height="40" src="/assets/resource.png" alt="Resource" title="Resource"/><img class="cloudcarousel" width="40" height="40" src="/assets/role.png" alt="Role" title="Role"/><img class="cloudcarousel" width="40" height="40" src="/assets/task.png" alt="Task" title="Task"/><img class="cloudcarousel" width="40" height="40" src="/assets/tool.png" alt="Tool" title="Tool"/><img class="cloudcarousel" width="40" height="40" src="/assets/trajectory.png" alt="Trajectory" title="Trajectory"/></div>
<%= form.autocomplete_field :name, autocomplete_item_name_items_path, :placeholder => "What is the name of your topic?" %> <%= form.autocomplete_field :name, autocomplete_topic_name_topics_path, :placeholder => "What is the name of your topic?" %>
<%= form.hidden_field :metacode, :value => "Action" %> <%= form.hidden_field :metacode, :value => "Action" %>
<%= form.hidden_field :x, :value => 0 %> <%= form.hidden_field :x, :value => 0 %>
<%= form.hidden_field :y, :value => 0 %> <%= form.hidden_field :y, :value => 0 %>
<%= form.hidden_field :map, :value => @map.id %> <%= form.hidden_field :map, :value => @map.id %>
<%= form.hidden_field :grabItem, :value => "null" %> <%= form.hidden_field :grabTopic, :value => "null" %>
<%= form.hidden_field :addSynapse, :value => false %> <%= form.hidden_field :addSynapse, :value => false %>
<!--<input id="left-but" type="button" value="Left" />--> <!--<input id="left-but" type="button" value="Left" />-->
<div id="metacodeImgTitle"></div> <div id="metacodeImgTitle"></div>

View file

@ -4,8 +4,8 @@
<%= form.text_field :name %> <%= form.text_field :name %>
<label for="map_desc">Description</label> <label for="map_desc">Description</label>
<%= form.text_area :desc, class: "description", :rows => 5 %> <%= form.text_area :desc, class: "description", :rows => 5 %>
<label for="outitems">Remove Topics From Map</label> <label for="outtopics">Remove Topics From Map</label>
<%= select_tag "outitems", options_from_collection_for_select(@outitems, "id", "name"), { :multiple => true } %> <%= select_tag "outtopics", options_from_collection_for_select(@outtopics, "id", "name"), { :multiple => true } %>
<label for="map_perm">Permission</label> <label for="map_perm">Permission</label>
<%= form.select :permission, options_for_select(['commons', 'public', 'private'], @map.permission) %> <%= form.select :permission, options_for_select(['commons', 'public', 'private'], @map.permission) %>
<%= form.submit "Update", class: "update" %> <%= form.submit "Update", class: "update" %>

View file

@ -1,6 +1,6 @@
<div class="focus"> <div class="focus">
<div class="focusleft"> <div class="focusleft">
<p># of Topics: <%= @map.items.count %></p> <p># of Topics: <%= @map.topics.count %></p>
<p># of Synapses: <%= @map.synapses.count %></p> <p># of Synapses: <%= @map.synapses.count %></p>
<% if (@map.permission == "commons" && authenticated?) || @map.user == user %> <% if (@map.permission == "commons" && authenticated?) || @map.user == user %>
<%= form_for @map, :url => savelayout_path(@map), :html => { :class => "saveMapLayout", :id => "saveMapLayout"}, remote: true do |form| %> <%= form_for @map, :url => savelayout_path(@map), :html => { :class => "saveMapLayout", :id => "saveMapLayout"}, remote: true do |form| %>

View file

@ -1,7 +1,7 @@
<div class="anypage"> <div class="anypage">
<%= form_for Synapse.new, url: synapses_url, remote: true do |form| %> <%= form_for Synapse.new, url: synapses_url, remote: true do |form| %>
<%= form.autocomplete_field :desc, autocomplete_synapse_desc_synapses_path, :placeholder => "Describe the connection..." %> <%= form.autocomplete_field :desc, autocomplete_synapse_desc_synapses_path, :placeholder => "Describe the connection..." %>
<%= form.hidden_field :item1id, :value => 0 %> <%= form.hidden_field :topic1id, :value => 0 %>
<%= form.hidden_field :item2id, :value => 0 %> <%= form.hidden_field :topic2id, :value => 0 %>
<% end %> <% end %>
</div> </div>

View file

@ -1,13 +1,13 @@
$('#new_synapse').fadeOut('fast'); $('#new_synapse').fadeOut('fast');
$('#synapse_desc').attr('value',''); $('#synapse_desc').attr('value','');
$('#synapse_item1id').attr('value','0'); $('#synapse_topic1id').attr('value','0');
$('#synapse_item2id').attr('value','0'); $('#synapse_topic2id').attr('value','0');
var temp1, temp2, temp; var temp1, temp2, temp;
if ( Mconsole != null) { if ( Mconsole != null) {
temp1 = Mconsole.graph.getNode(<%= @synapse.item1.id %>); temp1 = Mconsole.graph.getNode(<%= @synapse.topic1.id %>);
temp2 = Mconsole.graph.getNode(<%= @synapse.item2.id %>); temp2 = Mconsole.graph.getNode(<%= @synapse.topic2.id %>);
Mconsole.graph.addAdjacence(temp1, temp2, {}); Mconsole.graph.addAdjacence(temp1, temp2, {});
temp = Mconsole.graph.getAdjacence(temp1.id, temp2.id); temp = Mconsole.graph.getAdjacence(temp1.id, temp2.id);
console.log(temp); console.log(temp);

View file

@ -1,16 +1,16 @@
<%= form_for @synapse, url: synapse_url do |form| %> <%= form_for @synapse, url: synapse_url do |form| %>
<h3>Edit Synapse</h3> <h3>Edit Synapse</h3>
<% if Item.visibleToUser(user, nil).count > 0 %> <% if Topic.visibleToUser(user, nil).count > 0 %>
<label for="node1_id">Choose First Topic</label> <label for="node1_id">Choose First Topic</label>
<%= select "node1_id", "node1", Item.order("name ASC").visibleToUser(user, nil).map {|p| [ p.name, p.id ] }, { :selected => @synapse.node1_id } %> <%= select "node1_id", "node1", Topic.order("name ASC").visibleToUser(user, nil).map {|p| [ p.name, p.id ] }, { :selected => @synapse.node1_id } %>
<% end %> <% end %>
<label for="item_category">Directionality of the Connection</label> <label for="metacode">Directionality of the Connection</label>
<%= form.select :category, options_for_select(['none', 'both', 'from-to'], @synapse.category) %> <%= form.select :category, options_for_select(['none', 'both', 'from-to'], @synapse.category) %>
<label for="item_desc">Describe The Connection</label> <label for="topic_desc">Describe The Connection</label>
<%= form.text_field :desc, class: "description" %> <%= form.text_field :desc, class: "description" %>
<% if Item.visibleToUser(user, nil).count > 0 %> <% if Topic.visibleToUser(user, nil).count > 0 %>
<label for="node2_id">Choose Second Topic</label> <label for="node2_id">Choose Second Topic</label>
<%= select "node2_id", "node2", Item.order("name ASC").visibleToUser(user, nil).map {|p| [ p.name, p.id ] }, { :selected => @synapse.node2_id } %> <%= select "node2_id", "node2", Topic.order("name ASC").visibleToUser(user, nil).map {|p| [ p.name, p.id ] }, { :selected => @synapse.node2_id } %>
<% end %> <% end %>
<label for="synapse_permission">Permission</label> <label for="synapse_permission">Permission</label>
<%= form.select :permission, options_for_select(['commons', 'public', 'private'], @synapse.permission) %> <%= form.select :permission, options_for_select(['commons', 'public', 'private'], @synapse.permission) %>

View file

@ -17,6 +17,6 @@
</script> </script>
<% if authenticated? %> <% if authenticated? %>
<%= render :partial => 'items/new' %> <%= render :partial => 'topics/new' %>
<%= render :partial => 'synapses/new' %> <%= render :partial => 'synapses/new' %>
<% end %> <% end %>

View file

@ -1,17 +1,17 @@
<div class="newsynapses"> <div class="newsynapses">
<%= form_for @synapse, url: synapses_url do |form| %> <%= form_for @synapse, url: synapses_url do |form| %>
<h3>Add Synapse Between Topics</h3> <h3>Add Synapse Between Topics</h3>
<% if Item.visibleToUser(user, nil).count > 0 %> <% if Topic.visibleToUser(user, nil).count > 0 %>
<label for="node1_id">Choose First Topic</label> <label for="node1_id">Choose First Topic</label>
<%= select_tag :node1_id, options_from_collection_for_select(Item.order("name ASC").visibleToUser(user, nil), "id", "name") %> <%= select_tag :node1_id, options_from_collection_for_select(Topic.order("name ASC").visibleToUser(user, nil), "id", "name") %>
<% end %> <% end %>
<label for="item_category">Directionality of the Connection</label> <label for="metacode">Directionality of the Connection</label>
<%= form.select :category, options_for_select(['none', 'both', 'from-to']) %> <%= form.select :category, options_for_select(['none', 'both', 'from-to']) %>
<label for="item_desc">Describe The Connection</label> <label for="topic_desc">Describe The Connection</label>
<%= form.text_field :desc, class: "description" %> <%= form.text_field :desc, class: "description" %>
<% if Item.visibleToUser(user, nil).count > 0 %> <% if Topic.visibleToUser(user, nil).count > 0 %>
<label for="node2_id">Choose Second Topic</label> <label for="node2_id">Choose Second Topic</label>
<%= select_tag :node2_id, options_from_collection_for_select(Item.order("name ASC").visibleToUser(user, nil), "id", "name") %> <%= select_tag :node2_id, options_from_collection_for_select(Topic.order("name ASC").visibleToUser(user, nil), "id", "name") %>
<% end %> <% end %>
<label for="synapse_permission">Permission</label> <label for="synapse_permission">Permission</label>
<%= form.select(:permission, options_for_select(['commons', 'public', 'private'])) %> <%= form.select(:permission, options_for_select(['commons', 'public', 'private'])) %>

View file

@ -16,6 +16,6 @@
</script> </script>
<% if authenticated? %> <% if authenticated? %>
<%= render :partial => 'items/new' %> <%= render :partial => 'topics/new' %>
<%= render :partial => 'synapses/new' %> <%= render :partial => 'synapses/new' %>
<% end %> <% end %>

View file

@ -0,0 +1,15 @@
<div class="anypage">
<%= form_for Topic.new, url: topics_url, remote: true do |form| %>
<div id="metacodeImg"><img class="cloudcarousel" width="40" height="40" src="/assets/action.png" alt="Action" title="Action"/><img class="cloudcarousel" width="40" height="40" src="/assets/activity.png" alt="Activity" title="Activity"/><img class="cloudcarousel" width="40" height="40" src="/assets/bizarre.png" alt="Bizarre" title="Bizarre"/><img class="cloudcarousel" width="40" height="40" src="/assets/catalyst.png" alt="Catalyst" title="Catalyst"/><img class="cloudcarousel" width="40" height="40" src="/assets/closed.png" alt="Closed" title="Closed"/><img class="cloudcarousel" width="40" height="40" src="/assets/experience.png" alt="Experience" title="Experience"/><img class="cloudcarousel" width="40" height="40" src="/assets/futuredev.png" alt="Future Dev" title="Future Dev"/><img class="cloudcarousel" width="40" height="40" src="/assets/group.png" alt="Group" title="Group"/><img class="cloudcarousel" width="40" height="40" src="/assets/idea.png" alt="Idea" title="Idea"/><img class="cloudcarousel" width="40" height="40" src="/assets/implication.png" alt="Implication" title="Implication"/><img class="cloudcarousel" width="40" height="40" src="/assets/insight.png" alt="Insight" title="Insight"/><img class="cloudcarousel" width="40" height="40" src="/assets/intention.png" alt="Intention" title="Intention"/><img class="cloudcarousel" width="40" height="40" src="/assets/knowledge.png" alt="Knowledge" title="Knowledge"/><img class="cloudcarousel" width="40" height="40" src="/assets/location.png" alt="Location" title="Location"/><img class="cloudcarousel" width="40" height="40" src="/assets/openissue.png" alt="Open Issue" title="Open Issue"/><img class="cloudcarousel" width="40" height="40" src="/assets/opinion.png" alt="Opinion" title="Opinion"/><img class="cloudcarousel" width="40" height="40" src="/assets/opportunity.png" alt="Opportunity" title="Opportunity"/><img class="cloudcarousel" width="40" height="40" src="/assets/person.png" alt="Person" title="Person"/><img class="cloudcarousel" width="40" height="40" src="/assets/platform.png" alt="Platform" title="Platform"/><img class="cloudcarousel" width="40" height="40" src="/assets/problem.png" alt="Problem" title="Problem"/><img class="cloudcarousel" width="40" height="40" src="/assets/question.png" alt="Question" title="Question"/><img class="cloudcarousel" width="40" height="40" src="/assets/reference.png" alt="Reference" title="Reference"/><img class="cloudcarousel" width="40" height="40" src="/assets/requirement.png" alt="Requirement" title="Requirement"/><img class="cloudcarousel" width="40" height="40" src="/assets/resource.png" alt="Resource" title="Resource"/><img class="cloudcarousel" width="40" height="40" src="/assets/role.png" alt="Role" title="Role"/><img class="cloudcarousel" width="40" height="40" src="/assets/task.png" alt="Task" title="Task"/><img class="cloudcarousel" width="40" height="40" src="/assets/tool.png" alt="Tool" title="Tool"/><img class="cloudcarousel" width="40" height="40" src="/assets/trajectory.png" alt="Trajectory" title="Trajectory"/></div>
<%= form.autocomplete_field :name, autocomplete_topic_name_topics_path, :placeholder => "What is the name of your topic?" %>
<%= form.hidden_field :metacode, :value => "Action" %>
<%= form.hidden_field :x, :value => 0 %>
<%= form.hidden_field :y, :value => 0 %>
<%= form.hidden_field :grabTopic, :value => "null" %>
<%= form.hidden_field :addSynapse, :value => false %>
<!--<input id="left-but" type="button" value="Left" />-->
<div id="metacodeImgTitle"></div>
<!--<input id="right-but" type="button" value="Right" />-->
<div class="clearfloat"></div>
<% end %>
</div>

View file

@ -0,0 +1,10 @@
<%= div_for topic, class: topic.metacode.name do %>
<% if topic.user == user %><%= link_to 'Delete', topic_path(topic), :class => 'delete', :confirm => 'Delete this topic and all synapses linking to it?', :method => :delete, :remote => true%><% end %>
<p class="type"><%= topic.metacode.name %></p>
<%= image_tag topic.metacode.icon, :class => 'icon', :size => '50x50' %>
<div class="scroll">
<%= link_to topic.name, topic_path(topic), :class => 'title' %>
<div class="desc"><p><%=topic.desc %></p></div>
</div>
<%= link_to topic.link, topic.link, :class => 'link', :target => '_blank' %>
<% end %>

View file

@ -0,0 +1,83 @@
$('#new_topic').fadeOut('fast');
$('#topic_name').data().autocomplete.term = null;
$('.ui-autocomplete').children().remove();
$('.ui-autocomplete').css('display','none');
$('#topic_name').attr('value','');
$('#topic_grabTopic').attr('value','null');
$('#topic_addSynapse').attr('value','false');
var newnode = <%= @topic.self_as_json.html_safe %>;
var x = <%= @position['x'] %>;
var y = <%= @position['y'] %>;
if (!$.isEmptyObject(Mconsole.graph.nodes)) {
Mconsole.graph.addNode(newnode);
// set the animation for everything back to normal
Mconsole.graph.eachNode( function (n) {
n.setData('dim', 25, 'start');
n.setData('dim', 25, 'end');
});
var temp = Mconsole.graph.getNode('<%= @topic.id %>');
temp.setData('dim', 1, 'start');
temp.setData('dim', 40, 'end');
if (gType == "centered") {
var tempPos = new $jit.Complex(x, y);
tempPos = tempPos.toPolar();
temp.setPos(tempPos, 'current');
temp.setPos(tempPos, 'start');
temp.setPos(tempPos, 'end');
}
else if (gType == "arranged" || gType == "chaotic") {
temp.setData('xloc',0);
temp.setData('yloc',0);
temp.setData('mappingid', '<%= @mapping.id %>');
temp.setPos(new $jit.Complex(x, y), 'current');
temp.setPos(new $jit.Complex(x, y), 'start');
temp.setPos(new $jit.Complex(x, y), 'end');
}
if ( '<%= @synapse %>' == "true" ) {
$('#synapse_topic1id').val(tempNode.id);
$('#synapse_topic2id').val(temp.id);
$('#new_synapse').fadeIn('fast');
$('#synapse_desc').focus();
Mconsole.fx.animate({
modes: ['node-property:dim'],
duration: 500,
onComplete: function() {
renderMidArrow({ x: tempNode.pos.getc().x, y: tempNode.pos.getc().y }, { x: temp.pos.getc().x, y: temp.pos.getc().y }, 13, false, Mconsole.canvas);
Mconsole.fx.plotNode(tempNode, Mconsole.canvas);
Mconsole.fx.plotNode(temp, Mconsole.canvas);
tempNode = null;
tempNode2 = null;
tempInit = false;
}
});
} else {
Mconsole.fx.plotNode(temp, Mconsole.canvas);
Mconsole.fx.animate({
modes: ['node-property:dim'],
duration: 500
});
}
} else {
json = newnode;
Mconsole.loadJSON(json);
var temp = Mconsole.graph.getNode('<%= @topic.id %>');
temp.setData('dim', 1, 'start');
temp.setData('dim', 25, 'end');
temp.setPos(new $jit.Complex(x, y), 'current');
temp.setPos(new $jit.Complex(x, y), 'start');
temp.setPos(new $jit.Complex(x, y), 'end');
Mconsole.fx.plotNode(temp, Mconsole.canvas);
Mconsole.fx.animate({
modes: ['node-property:dim'],
duration: 500
});
}

View file

@ -0,0 +1 @@
$('#<%= dom_id(@topic) %>').fadeOut('slow');

View file

@ -0,0 +1,14 @@
<%= form_for @topic, url: topic_url do |form| %>
<h3>Edit Topic</h3>
<label for="category">Category</label>
<%= select "category", "metacode_id", Metacode.order("name ASC").all.collect {|p| [ p.name, p.id ] }, { :selected => @topic.metacode.id } %>
<label for="topic_name">Title</label>
<%= form.text_field :name %>
<label for="topic_desc">Description</label>
<%= form.text_area :desc, class: "description", :rows => 5 %>
<label for="topic_link">Link</label>
<%= form.text_field :link, class: "link" %>
<label for="topic_permission">Permission</label>
<%= form.select :permission, options_for_select(['commons', 'public', 'private'], @topic.permission) %>
<%= form.submit "Update", class: "update" %>
<% end %>

View file

@ -0,0 +1,11 @@
<h1 class="index"><% if @user %><%= @user.name %>'s<% end %> Topics</h1>
<div class="topics" id="cards">
<% @topics.each do |topic| %>
<%= render topic %>
<% end %>
<% if @topics.empty? %>
<p class="empty"><br>Shucks, there are no topics. <% if authenticated? %><%= link_to "Create some if you want.", console_url %><% end %></p>
<% end %>
</div>
<div class="clearfloat"></div>

View file

@ -0,0 +1,16 @@
<div class="nothidden">
<%= form_for @topic || Topic.new, url: topics_path do |form| %>
<h3>Add Topic</h3>
<label for="category">Category</label>
<%= select_tag "category", options_from_collection_for_select(Metacode.order("name ASC").all, "id", "name") %>
<label for="topic_name">Title</label>
<%= form.text_field :name %>
<label for="topic_desc">Description</label>
<%= form.text_area :desc, class: "description", :rows => 5 %>
<label for="topic_link">Link</label>
<%= form.text_field :link, class: "link" %>
<label for="topic_permission">Permission</label>
<%= form.select(:permission, options_for_select(['commons', 'public', 'private'])) %>
<%= form.submit "Add Topic", class: "addTopic", id: "addTopic" %>
<% end %>
</div>

View file

@ -0,0 +1,38 @@
<div class="focus">
<div class="focusleft">
<p><%= @topic.metacode.name %></p>
<%= image_tag @topic.metacode.icon, :class => 'icon', :size => '50x50' %>
</div>
<div class="focusmiddle">
<h1 class="title"><%= @topic.name %> <% if (@topic.permission == "commons" && authenticated?) || @topic.user == user %><%= link_to "[edit]", edit_topic_path(@topic) %><% end %></h1>
<div class="desc">
<p><%= @topic.desc %></p>
</div>
</div>
<div class="focusright">
<p>Link</p>
<%= link_to @topic.link, @topic.link, :class => 'link', :target => '_blank' %>
</div>
</div>
<div class="clearfloat nodemargin"></div>
<div class="relatives" id="container">
<div id="center-container">
<div id="infovis"></div>
</div>
</div>
<div class="clearfloat"></div>
<script>
json = <%= @relatives %>;
console.log(json);
$(document).ready(function() {
initialize("centered");
});
</script>
<% if authenticated? %>
<%= render :partial => 'topics/new' %>
<%= render :partial => 'synapses/new' %>
<% end %>

View file

@ -0,0 +1,29 @@
<div class="showcard topic_<%= @topic.id %>">
<div class="CardOnGraph" title="Click to Hide" id="topic_' + node.id + '">
<p class="type">
<%= @topic.metacode.name %>
</p>
<img alt="<%= @topic.metacode.name %>"
src="/assets/<%= @topic.metacode.name %>.png"
class="icon" height="50" width="50" />
<div class="scroll">
<a href="/topics/<%=@topic.id%>" class="title">
<%= @topic.name %>
</a>
<div class="contributor">
Added by:
<a href="/users/<%= @user.id %>">
<%= @user.name %>
</a>
</div>
<div class="desc">
<p>
<%= @topic.desc %>
</p>
</div>
</div><!-- div.scroll -->
<a href="<%= @topic.link %>" class="link" target="_blank">
<%= @topic.link %>
</a>
</div>
</div>

View file

@ -1,13 +1,13 @@
<div class="focus"> <div class="focus">
<div class="focusleft"> <div class="focusleft">
<p># of Topics: <%= @user.items.count %></p> <p># of Topics: <%= @user.topics.count %></p>
<p># of Synapses: <%= @user.synapses.count %></p> <p># of Synapses: <%= @user.synapses.count %></p>
<p># of Maps: <%= @user.maps.count %></p> <p># of Maps: <%= @user.maps.count %></p>
</div> </div>
<div class="focusmiddle"> <div class="focusmiddle">
<h1 class="title"><%= @user.name %></h1> <h1 class="title"><%= @user.name %></h1>
<div class="desc"> <div class="desc">
<p><%= link_to "View their topics", user_items_path(@user)%></p> <p><%= link_to "View their topics", user_topics_path(@user)%></p>
<p><%= link_to "View their synapses", user_synapses_path(@user)%></p> <p><%= link_to "View their synapses", user_synapses_path(@user)%></p>
<p><%= link_to "View their maps", user_maps_path(@user) %></p> <p><%= link_to "View their maps", user_maps_path(@user) %></p>
</div> </div>

View file

@ -14,8 +14,8 @@ ISSAD::Application.routes.draw do
resource :session resource :session
resources :items do resources :topics do
get :autocomplete_item_name, :on => :collection get :autocomplete_topic_name, :on => :collection
end end
resources :synapses do resources :synapses do
@ -28,7 +28,7 @@ ISSAD::Application.routes.draw do
resources :users do resources :users do
get :autocomplete_user_name, :on => :collection get :autocomplete_user_name, :on => :collection
resources :items, :only => [:index] resources :topics, :only => [:index]
resources :synapses, :only => [:index] resources :synapses, :only => [:index]
resources :maps, :only => [:index] resources :maps, :only => [:index]
end end

View file

@ -3,8 +3,8 @@ class CreateUsers < ActiveRecord::Migration
create_table :users do |t| create_table :users do |t|
t.string :name t.string :name
t.string :email t.string :email
t.string :code, :limit => 8 t.string :code, :limit => 8
t.string :joinedwithcode, :limit => 8 t.string :joinedwithcode, :limit => 8
t.string :crypted_password t.string :crypted_password
t.string :password_salt t.string :password_salt
t.string :persistence_token t.string :persistence_token

View file

@ -2,12 +2,12 @@ class CreateSynapses < ActiveRecord::Migration
def change def change
create_table :synapses do |t| create_table :synapses do |t|
t.text :desc t.text :desc
t.text :category t.text :category
t.text :weight t.text :weight
t.text :permission t.text :permission
t.integer :node1_id t.integer :node1_id
t.integer :node2_id t.integer :node2_id
t.integer :user_id t.integer :user_id
t.timestamps t.timestamps
end end

View file

@ -2,12 +2,12 @@ class CreateMappings < ActiveRecord::Migration
def change def change
create_table :mappings do |t| create_table :mappings do |t|
t.text :category t.text :category
t.integer :xloc t.integer :xloc
t.integer :yloc t.integer :yloc
t.integer :item_id t.integer :topic_id
t.integer :synapse_id t.integer :synapse_id
t.integer :map_id t.integer :map_id
t.integer :user_id t.integer :user_id
t.timestamps t.timestamps
end end
end end

View file

@ -0,0 +1,13 @@
class CreateTopics < ActiveRecord::Migration
def change
create_table :topics do |t|
t.text :name
t.text :desc
t.text :link
t.text :permission
t.integer :user_id
t.integer :metacode_id
t.timestamps
end
end
end

View file

@ -0,0 +1,10 @@
class CreateMetacodes < ActiveRecord::Migration
def change
create_table :metacodes do |t|
t.text :name
t.string :icon
t.timestamps
end
end
end

View file

@ -0,0 +1,9 @@
class ItemsToTopics < ActiveRecord::Migration
def change
rename_column :items, :item_category_id, :metacode_id
rename_column :mappings, :item_id, :topic_id
rename_table :items, :topics
rename_table :item_categories, :metacodes
end
end

View file

@ -11,7 +11,7 @@
# #
# It's strongly recommended to check this file into your version control system. # It's strongly recommended to check this file into your version control system.
ActiveRecord::Schema.define(:version => 20121203225613) do ActiveRecord::Schema.define(:version => 20130101215010) do
create_table "item_categories", :force => true do |t| create_table "item_categories", :force => true do |t|
t.text "name" t.text "name"
@ -35,7 +35,7 @@ ActiveRecord::Schema.define(:version => 20121203225613) do
t.text "category" t.text "category"
t.integer "xloc" t.integer "xloc"
t.integer "yloc" t.integer "yloc"
t.integer "item_id" t.integer "topic_id"
t.integer "synapse_id" t.integer "synapse_id"
t.integer "map_id" t.integer "map_id"
t.integer "user_id" t.integer "user_id"
@ -53,6 +53,13 @@ ActiveRecord::Schema.define(:version => 20121203225613) do
t.boolean "arranged" t.boolean "arranged"
end end
create_table "metacodes", :force => true do |t|
t.text "name"
t.string "icon"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
create_table "synapses", :force => true do |t| create_table "synapses", :force => true do |t|
t.text "desc" t.text "desc"
t.text "category" t.text "category"
@ -65,6 +72,17 @@ ActiveRecord::Schema.define(:version => 20121203225613) do
t.datetime "updated_at", :null => false t.datetime "updated_at", :null => false
end end
create_table "topics", :force => true do |t|
t.text "name"
t.text "desc"
t.text "link"
t.text "permission"
t.integer "user_id"
t.integer "metacode_id"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
create_table "users", :force => true do |t| create_table "users", :force => true do |t|
t.string "name" t.string "name"
t.string "email" t.string "email"

View file

@ -4,8 +4,8 @@
# model remove the '{}' from the fixture names and add the columns immediately # model remove the '{}' from the fixture names and add the columns immediately
# below each fixture, per the syntax in the comments below # below each fixture, per the syntax in the comments below
# #
one: {} #one: {}
# column: value # column: value
# #
two: {} #two: {}
# column: value # column: value

117
test/fixtures/metacodes.yml vendored Normal file
View file

@ -0,0 +1,117 @@
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/Fixtures.html
# This model initially had no columns defined. If you add columns to the
# model remove the '{}' from the fixture names and add the columns immediately
# below each fixture, per the syntax in the comments below
#
one:
name: Action
icon: action.png
two:
name: Activity
icon: activity.png
three:
name: Bizarre
icon: bizarre.png
four:
name: Catalyst
icon: catalyst.png
five:
name: Closed
icon: closed.png
six:
name: Experience
icon: experience.png
seven:
name: Future Dev
icon: futuredev.png
eight:
name: Group
icon: group.png
nine:
name: Idea
icon: idea.png
ten:
name: Implication
icon: implication.png
eleven:
name: Insight
icon: insight.png
twelve:
name: Intention
icon: intention.png
thirteen:
name: Knowledge
icon: knowledge.png
fourteen:
name: Location
icon: location.png
fifteen:
name: Open Issue
icon: openissue.png
sixteen:
name: Opinion
icon: opinion.png
seventeen:
name: Opportunity
icon: opportunity.png
eighteen:
name: Person
icon: person.png
nineteen:
name: Platform
icon: platform.png
twenty:
name: Problem
icon: problem.png
twenty-one:
name: Question
icon: question.png
twenty-two:
name: Reference
icon: reference.png
twenty-three:
name: Requirement
icon: requirement.png
twenty-four:
name: Resource
icon: resource.png
twenty-five:
name: Role
icon: role.png
twenty-six:
name: Task
icon: task.png
twenty-seven:
name: Tool
icon: tool.png
twenty-eight:
name: Trajectory
icon: trajectory.png

11
test/fixtures/topics.yml vendored Normal file
View file

@ -0,0 +1,11 @@
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/Fixtures.html
# This model initially had no columns defined. If you add columns to the
# model remove the '{}' from the fixture names and add the columns immediately
# below each fixture, per the syntax in the comments below
#
#one: {}
# column: value
#
#two: {}
# column: value

View file

@ -0,0 +1,7 @@
require 'test_helper'
class TopicsControllerTest < ActionController::TestCase
# test "the truth" do
# assert true
# end
end

View file

@ -0,0 +1,4 @@
require 'test_helper'
class TopicsHelperTest < ActionView::TestCase
end

View file

@ -0,0 +1,7 @@
require 'test_helper'
class MetacodeTest < ActiveSupport::TestCase
# test "the truth" do
# assert true
# end
end

7
test/unit/topic_test.rb Normal file
View file

@ -0,0 +1,7 @@
require 'test_helper'
class TopicTest < ActiveSupport::TestCase
# test "the truth" do
# assert true
# end
end