// This is a manifest file that'll be compiled into application.js, which will include all the files // listed below. // // Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts, // or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path. // // It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the // the compiled file. // // WARNING: THE FIRST BLANK LINE MARKS THE END OF WHAT'S TO BE PROCESSED, ANY BLANK LINE SHOULD // GO AFTER THE REQUIRES BELOW. // // require autocomplete-rails-uncompressed // //= require jquery //= require jquery.purr //= require best_in_place //= require jquery_ujs //= require_tree . // other options are 'graph' 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, touchPos, touchDragNode, mouseIsDown = false; $(document).ready(function() { function bindMainMenuHover() { var menuIsOpen = false // controls the sliding hover of the bottom left menu var sliding1 = false; var lT; var closeMenu = function() { lT = setTimeout(function() { if (! sliding1) { sliding1 = true; // $('.footer .menu').animate({ // height: '0px' // }, 300, function() { // sliding1 = false; // menuIsOpen = false; // }); $('.footer').css('border-top-right-radius','5px'); $('.logo').animate({ 'background-position-x':'-10px' }, 200); $('.footer .menu').fadeOut(200, function() { sliding1 = false; menuIsOpen = false; }); } },500); } var openMenu = function() { clearTimeout(lT); if (! sliding1) { sliding1 = true; // $('.footer .menu').animate({ // height: listLength + 'px' // }, 300, function() { // sliding1 = false; // }); $('.footer').css('border-top-right-radius','0'); $('.logo').animate({ 'background-position-x':'-7px' }, 200); $('.footer .menu').fadeIn(200, function() { sliding1 = false; }); } } // bind the hover events $(".logo").hover(openMenu, closeMenu); // when on touch screen, make touching on the logo do what hovering does on desktop $("#mainTitle a").bind('touchend', function(evt) { if (!menuIsOpen) { openMenu(); evt.preventDefault(); evt.stopPropagation(); } }); } function bindSearchHover() { var searchIsOpen = false // controls the sliding hover of the search var sliding1 = false; var lT; var openSearch = function() { clearTimeout(lT); if (!sliding1 && !searchIsOpen) { hideCards(); sliding1 = true; $('.sidebarSearch .twitter-typeahead, .sidebarSearch .tt-hint, .sidebarSearchField').animate({ width: '200px' }, 200, function() { $('.sidebarSearchField, .sidebarSearch .tt-hint').css({padding:'5px 10px', width:'180px'}); $('.sidebarSearchField').focus(); sliding1 = false searchIsOpen = true; }); } } var closeSearch = function(closeAfter) { lT = setTimeout(function() { if (!sliding1 && searchIsOpen) { sliding1 = true; $('.sidebarSearchField, .sidebarSearch .tt-hint').css({padding:'5px 0', width:'200px'}); $('.sidebarSearch .twitter-typeahead, .sidebarSearch .tt-hint, .sidebarSearchField').animate({ width: '0' }, 200, function() { $('.sidebarSearchField').typeahead('setQuery',''); sliding1 = false; searchIsOpen = false; }); } },closeAfter); } // bind the hover events $(".sidebarSearch").hover(function(){ openSearch() }, function() { closeSearch(800) }); $('.sidebarSearch').click(function(e) { e.stopPropagation(); }); $('body').click(function(e) { closeSearch(0); }); // if the search is closed and user hits SHIFT+S $('body').bind('keyup', function(e) { switch(e.which) { case 83: if (e.shiftKey && !searchIsOpen) { openSearch(); } break; default: break; //console.log(e.which); } }); // initialize the search box autocomplete results $('.sidebarSearchField').typeahead([ { name: 'topics', template: $('.topicTemplate').html(), remote: { url: '/search/topics?term=%QUERY' }, engine: Hogan, header: '

Topics

' }, { name: 'maps', template: $('.mapTemplate').html(), remote: { url: '/search/maps?term=%QUERY' }, engine: Hogan, header: '

Maps

' }, { name: 'mappers', template: $('.mapperTemplate').html(), remote: { url: '/search/mappers?term=%QUERY' }, engine: Hogan, header: '

Mappers

' } ]); } // end bindSearchHover function bindAccountHover() { var accountIsOpen = false // controls the sliding hover of the bottom left menu var sliding1 = false; var lT; var closeAccount = function() { lT = setTimeout(function() { if (! sliding1) { sliding1 = true; $('.sidebarAccountIcon').css('background-color','rgba(0,0,0,0.7)'); $('.sidebarAccountBox').fadeOut(200, function() { sliding1 = false; accountIsOpen = false; }); } },300); } var openAccount = function() { clearTimeout(lT); if (! sliding1) { sliding1 = true; $('.sidebarAccountIcon').css('background-color','rgba(0,0,0,0.9)'); $('.sidebarAccountBox').fadeIn(200, function() { sliding1 = false; accountIsOpen = true; }); } } // bind the hover events $(".sidebarAccount").hover(openAccount, closeAccount); } // end bindAccountHover // bind hover events bindMainMenuHover(); bindSearchHover(); bindAccountHover(); // disable right click events on the new topic and new synapse input fields $('#new_topic, #new_synapse').bind('contextmenu', function(e){ return false; }); // initialize the autocomplete results for the metacode spinner $('#topic_name').typeahead([ { name: 'topic_autocomplete', template: '

{{value}}

{{type}}
{{type}}', remote: { url: '/topics/autocomplete_topic?term=%QUERY' }, engine: Hogan } ]); // tell the autocomplete to submit the form with the topic you clicked on if you pick from the autocomplete $('#topic_name').bind('typeahead:selected', function (event, datum, dataset) { $('#topic_grabTopic').val(datum.id); $('.new_topic').submit(); event.preventDefault(); event.stopPropagation(); }); // when either form submits, don't leave the page $('.new_topic, .new_synapse').bind('submit', function(event, data){ event.preventDefault(); }); $(".scroll").mCustomScrollbar(); $('.notice.metamaps').delay(10000).fadeOut('fast'); $('.alert.metamaps').delay(10000).fadeOut('fast'); addHoverForSettings(); //bind best_in_place ajax callbacks $('.best_in_place_metacode').bind("ajax:success", function() { var metacode = $(this).html(); //changing img alt, img src for top card (topic view page) //and on-canvas card. Also changing image of node $(this).parents('.CardOnGraph').find('img.icon').attr('alt', metacode); $(this).parents('.CardOnGraph').find('img.icon').attr('src', imgArray[metacode].src); }); $('.best_in_place_desc').bind("ajax:success", function() { $(this).parents('.CardOnGraph').find('.scroll').mCustomScrollbar("update"); }); $('.best_in_place_link').bind("ajax:success", function() { var link = $(this).html(); $(this).parents('.CardOnGraph').find('.go-link').attr('href', link); }); $('.addMap').click(function(event) { createNewMap(); }); // bind keyboard handlers $('body').bind('keyup', function(e) { switch(e.which) { case 13: enterKeyHandler(); break; case 27: escKeyHandler(); break; default: break; //console.log(e.which); } }); }); // end document.ready function addHoverForSettings() { // controls the sliding hover of the settings for cards $(".permActivator").unbind('mouseover'); $(".permActivator").unbind('mouseout'); var sliding2 = false; var lT1,lT2; $(".permActivator").bind('mouseover', function () { clearTimeout(lT2); that = this; lT1 = setTimeout(function() { if (! sliding2) { sliding2 = true; $(that).animate({ width: '203px', height: '37px' }, 300, function() { sliding2 = false; }); } }, 300); }); $(".permActivator").bind('mouseout', function () { clearTimeout(lT1); that = this; lT2 = setTimeout(function() { if (! sliding2) { sliding2 = true; $(that).animate({ height: '16px', width: '16px' }, 300, function() { sliding2 = false; }); } },800); } ); $('.best_in_place_permission').unbind("ajax:success"); //bind best_in_place ajax callbacks $('.best_in_place_permission').bind("ajax:success", function() { var permission = $(this).html(); var el = $(this).parents('.cardSettings').find('.mapPerm'); el.attr('title', permission); if (permission == "commons") el.html("co"); else if (permission == "public") el.html("pu"); else if (permission == "private") el.html("pr"); }); } // this is to save the layout of a map function saveLayoutAll() { $('.wandSaveLayout').html('Saving...'); var coor = ""; if (gType == "arranged" || gType == "chaotic") { Mconsole.graph.eachNode(function(n) { coor = coor + n.getData("mappingid") + '/' + n.pos.x + '/' + n.pos.y + ','; }); coor = coor.slice(0, -1); $('#map_coordinates').val(coor); $('#saveMapLayout').submit(); } } // this is to update the location coordinate of a single node on a map function saveLayout(id) { var n = Mconsole.graph.getNode(id); $('#map_coordinates').val(n.getData("mappingid") + '/' + n.pos.x + '/' + n.pos.y); $('#saveMapLayout').submit(); dragged = 0; $('.wandSaveLayout').html('Saved!'); setTimeout(function(){$('.wandSaveLayout').html('Save Layout')},1500); } // this is to save your console to a map function saveToMap() { var nodes_data = "", synapses_data = ""; var synapses_array = new Array(); Mconsole.graph.eachNode(function(n) { //don't add to the map if it was filtered out if (categoryVisible[n.getData('metacode')] == false) { return; } var x, y; if (n.pos.x && n.pos.y) { x = n.pos.x; y = n.pos.y; } else { var x = Math.cos(n.pos.theta) * n.pos.rho; var y = Math.sin(n.pos.theta) * n.pos.rho; } nodes_data += n.id + '/' + x + '/' + y + ','; n.eachAdjacency(function(adj) { synapses_array.push(adj.getData("id")); }); }); //get unique values only synapses_array = $.grep(synapses_array, function(value, key){ return $.inArray(value, synapses_array) === key; }); synapses_data = synapses_array.join(); nodes_data = nodes_data.slice(0, -1); $('#map_topicsToMap').val(nodes_data); $('#map_synapsesToMap').val(synapses_data); $('#fork_map').fadeIn('fast'); } function createNewMap() { $('#new_map').fadeIn('fast'); } function addMetacode() { // code from http://www.professorcloud.com/mainsite/carousel-integration.htm //mouseWheel:true, if (!metacodeIMGinit) { $("#metacodeImg").CloudCarousel( { titleBox: $('#metacodeImgTitle'), yRadius:40, xPos: 150, yPos: 40, speed:0.3, mouseWheel:true, bringToFront: true }); metacodeIMGinit = true; } } function fetchRelatives(node) { var myA = $.ajax({ type: "Get", url: "/topics/" + node.id + "?format=json", success: function(data) { if (gType == "centered") { Mconsole.busy = true; Mconsole.op.sum(data, { type: 'fade', duration: 500, hideLabels: false }); Mconsole.graph.eachNode(function (n) { n.eachAdjacency(function (a) { if (!a.getData('showDesc')) { a.setData('alpha', 0.4, 'start'); a.setData('alpha', 0.4, 'current'); a.setData('alpha', 0.4, 'end'); } }); }); Mconsole.busy = false; } else { Mconsole.op.sum(data, { type: 'nothing', }); Mconsole.plot(); } /*Mconsole.op.contract(node, { type: 'replot' }); Mconsole.op.expand(node, { type: 'animate', transition: $jit.Trans.Elastic.easeOut, duration: 1000 });*/ }, error: function(){ alert('failure'); } }); } function MconsoleReset() { var tX = Mconsole.canvas.translateOffsetX; var tY = Mconsole.canvas.translateOffsetY; Mconsole.canvas.translate(-tX,-tY); var mX = Mconsole.canvas.scaleOffsetX; var mY = Mconsole.canvas.scaleOffsetY; Mconsole.canvas.scale((1/mX),(1/mY)); } function openNodeShowcard(node) { //populate the card that's about to show with the right topics data populateShowCard(node); // positions the card in the right place $('#showcard').css('top', '250px'); $('#showcard').css('left', '100px'); $('.showcard.topic_' + node.id).fadeIn('fast'); //node.setData('dim', 1, 'current'); MetamapsModel.showcardInUse = node.id; }