var nodes; var edges; var options = { nodes: { shape: 'dot', size: 40, borderWidth:4, color: { border: '#222222', background: '#666666' }, font:{ color:'#eeeeee', size: 12 }, }, edges: { color: 'lightgray' } }; /** * Checks if a user is a node in the graph * * @param userID * @returns {boolean} */ function alreadyInGraph(userID) { for(var i = 0; i < nodes.length; i++) { if(nodes[i].id === userID) { return true; } } return false; } /** * adds a person to the nodes list * * @param profileData */ function addSelfAsOrg(orgData) { nodes.push( { id:orgData.id, name:orgData.login, image:orgData.avatar_url, background: '#eeeeee', size:100, label: orgData.name, }); console.log(orgData.name); } function addSelfAsRepo(repoData) { nodes.push( { id:repoData.id, name:repoData.name, label: repoData.name, }); } /** * Adds the followers/following of a person * to the graph * * @param username * @param apiPath * @returns {Promise} */ function addRepos(orgName, apiPath, page) { console.log(orgName + " page=" + page); updateProgress(); return new Promise(function(resolve, reject) { queryAPIByOrg(apiPath + "?page=" + page, orgName, function(data) { console.log(data); console.log(data.length); var prom = []; for(var i = 0; i < data.length; i++) { if(!alreadyInGraph(data[i].id)) { prom.push(addRepoToGraph(data[i])); } } Promise.all(prom).then( () => { if(data.length === 30) { addRepos(orgName, apiPath, page+ 1).then(function() { resolve(); }) } else { resolve(); } }) }, function(error) { reject(error); }) }); } /** * Greedy function which checks to see if a edge is in the graphs * * @param id1 * @param id2 * @returns {boolean} */ function edgeInGraph(id1, id2) { console.log("edge check"); for(var i = 0;i < edges.length; i++) { if(edges[i].from === id1 && edges[i].to === id2) { return true; } if(edges[i].to === id1 && edges[i].from === id2) { return true; } } return false; } /** * Adds a connection to the graph * * @param person1 * @param person2 */ function addConnection(person1, person2) { if(person1.id !== person2.id) { if(alreadyInGraph(person2.id) && !edgeInGraph(person1.id, person2.id)) { edges.push( { from: person1.id, to: person2.id }); } } } function processConnections(user, apiPoint, page) { updateProgress(); return new Promise(function(resolve, reject) { queryAPIByUser(apiPoint + "?page=" + page, user.name, function(data) { for(var i = 0; i < data.length; i++) { addConnection(user, data[i]) } if(data.length === 30) { processConnections(user, apiPoint, page + 1).then(function() { resolve(); }); } else { resolve(); } }, function(error) { console.log(error); resolve(); }) }) } /** * Processes all the connections of a user and adds them to the graph * * @param user has .id and .name * @returns {Promise} */ function processUserConnections(user) { return new Promise(function(resolve, reject) { processConnections(user, API_FOLLOWING, 1).then(function() { processConnections(user, API_FOLLOWERS, 1).then(function() { resolve(); }) }) }); } /** * Creates connections between all the nodes in * the graph. * * @returns {Promise} */ function createConnections() { return new Promise(function(resolve, reject) { var prom = []; for(var i = 0; i < nodes.length; i++) { prom.push(processUserConnections(nodes[i])); } Promise.all(prom).then(function() { resolve(); }).catch(function(error) { console.log(error); resolve(); }); }); } var total = 1; var indexed = 0; var progressID; function updateProgress() { indexed++; var percent = parseInt((indexed/total)*100); $("#" + progressID).html("
\n" + "
\n" + "
"); console.log(); } /** * Adds the base person to the graph. * * @param username * @returns {Promise} */ function addOrgToGraph(orgname) { return new Promise(function(resolve, reject) { queryAPIByOrg("", orgname, function(data) { total = (data.public_repos) * 2; addSelfAsOrg(data); resolve(); }, function(error) { reject(error); }); }); } function addRepoToGraph(repo) { return new Promise(function(resolve, reject) { console.log(repo); addSelfAsRepo(repo); resolve(); }); } function bringUpProfileView(id) { for(var i = 0; i < nodes.length; i++) { if(nodes[i].id === id) { profileGen(nodes[i].name, "profileGen"); } } } /** * Creates a graph * @param username * @param containerName * @param graphsTitle */ function createOrgRepoGraph(orgname, containerName, graphsTitle) { progressID = graphsTitle; nodes = []; edges = []; addOrgToGraph(orgname).then(function() { addRepos(orgname, API_REPOS,1).then(function() { $("#" + progressID).html(""); createConnections().then( () => { var container = document.getElementById(containerName); var data = { nodes: nodes, edges: edges }; var network = new vis.Network(container, data, options); network.on("click", function (params) { params.event = "[original event]"; if(Number(this.getNodeAt(params.pointer.DOM)) !== NaN) { bringUpProfileView(Number(this.getNodeAt(params.pointer.DOM))); } }); }) }) }).catch(function(error) { alert("Invalid Organization"); }); }