low hanging fruit

Here is my TODO list:

already done
==> Account.js <==
==> Admin.js <==
==> AutoLayout.js <==
==> Listeners.js <==
==> Mapper.js <==
==> Organize.js <==
==> PasteInput.js <==
==> ReactComponents.js <==
==> Util.js <==

TODO (I think) simple to make modular
==> Backbone.js <==
==> Control.js <==
==> Create.js <==
==> Filter.js <==
==> Import.js <==
==> Mobile.js <==
==> Synapse.js <==
==> SynapseCard.js <==
==> Topic.js <==
==> TopicCard.js <==
==> Views.js <==
==> Visualize.js <==

TODO hard to make modular
==> Constants.js <==
==> Debug.js <==
==> GlobalUI.js <==
==> JIT.js <==
==> Map.js <==
==> Realtime.js <==
==> Router.js <==
This commit is contained in:
Devin Howard 2016-09-22 17:00:12 +08:00
parent 0a109895f7
commit 0562134157
7 changed files with 41 additions and 63 deletions

View file

@ -1,14 +1,6 @@
window.Metamaps = window.Metamaps || {} /* uses window.Metamaps.Erb */
/* global Metamaps, $ */
/* const Account = {
* Metamaps.Account.js.erb
*
* Dependencies:
* - Metamaps.Erb
*/
Metamaps.Account = {
listenersInitialized: false, listenersInitialized: false,
init: function () { init: function () {
var self = Metamaps.Account var self = Metamaps.Account
@ -20,24 +12,24 @@ Metamaps.Account = {
self.listenersInitialized = true self.listenersInitialized = true
}, },
toggleChangePicture: function () { toggleChangePicture: function () {
var self = Metamaps.Account var self = Account
$('.userImageMenu').toggle() $('.userImageMenu').toggle()
if (!self.listenersInitialized) self.initListeners() if (!self.listenersInitialized) self.initListeners()
}, },
openChangePicture: function () { openChangePicture: function () {
var self = Metamaps.Account var self = Account
$('.userImageMenu').show() $('.userImageMenu').show()
if (!self.listenersInitialized) self.initListeners() if (!self.listenersInitialized) self.initListeners()
}, },
closeChangePicture: function () { closeChangePicture: function () {
var self = Metamaps.Account var self = Account
$('.userImageMenu').hide() $('.userImageMenu').hide()
}, },
showLoading: function () { showLoading: function () {
var self = Metamaps.Account var self = Account
var loader = new CanvasLoader('accountPageLoading') var loader = new CanvasLoader('accountPageLoading')
loader.setColor('#4FC059'); // default is '#000000' loader.setColor('#4FC059'); // default is '#000000'
@ -48,7 +40,7 @@ Metamaps.Account = {
$('#accountPageLoading').show() $('#accountPageLoading').show()
}, },
showImagePreview: function () { showImagePreview: function () {
var self = Metamaps.Account var self = Account
var file = $('#user_image')[0].files[0] var file = $('#user_image')[0].files[0]
@ -94,10 +86,10 @@ Metamaps.Account = {
} }
}, },
removePicture: function () { removePicture: function () {
var self = Metamaps.Account var self = Account
$('.userImageDiv canvas').remove() $('.userImageDiv canvas').remove()
$('.userImageDiv img').attr('src', Metamaps.Erb['user.png']).show() $('.userImageDiv img').attr('src', window.Metamaps.Erb['user.png']).show()
$('.userImageMenu').hide() $('.userImageMenu').hide()
var input = $('#user_image') var input = $('#user_image')
@ -122,4 +114,4 @@ Metamaps.Account = {
} }
} }
export default Metamaps.Account export default Account

View file

@ -4,26 +4,26 @@ const Admin = {
selectMetacodes: [], selectMetacodes: [],
allMetacodes: [], allMetacodes: [],
init: function () { init: function () {
var self = Metamaps.Admin var self = Admin
$('#metacodes_value').val(self.selectMetacodes.toString()) $('#metacodes_value').val(self.selectMetacodes.toString())
}, },
selectAll: function () { selectAll: function () {
var self = Metamaps.Admin var self = Admin
$('.editMetacodes li').removeClass('toggledOff') $('.editMetacodes li').removeClass('toggledOff')
self.selectMetacodes = self.allMetacodes.slice(0) self.selectMetacodes = self.allMetacodes.slice(0)
$('#metacodes_value').val(self.selectMetacodes.toString()) $('#metacodes_value').val(self.selectMetacodes.toString())
}, },
deselectAll: function () { deselectAll: function () {
var self = Metamaps.Admin var self = Admin
$('.editMetacodes li').addClass('toggledOff') $('.editMetacodes li').addClass('toggledOff')
self.selectMetacodes = [] self.selectMetacodes = []
$('#metacodes_value').val(0) $('#metacodes_value').val(0)
}, },
liClickHandler: function () { liClickHandler: function () {
var self = Metamaps.Admin var self = Admin
if ($(this).attr('class') != 'toggledOff') { if ($(this).attr('class') != 'toggledOff') {
$(this).addClass('toggledOff') $(this).addClass('toggledOff')
@ -38,7 +38,7 @@ const Admin = {
} }
}, },
validate: function () { validate: function () {
var self = Metamaps.Admin var self = Admin
if (self.selectMetacodes.length == 0) { if (self.selectMetacodes.length == 0) {
alert('Would you pretty please select at least one metacode for the set?') alert('Would you pretty please select at least one metacode for the set?')

View file

@ -1,8 +1,6 @@
/* global Metamaps, $ */ /* global Metamaps, $ */
/* /*
* Metamaps.Listeners.js.erb
*
* Dependencies: * Dependencies:
* - Metamaps.Active * - Metamaps.Active
* - Metamaps.Control * - Metamaps.Control

View file

@ -1,9 +1,5 @@
/* global Metamaps */ import Backbone from './Backbone'
/*
* Dependencies:
* - Metamaps.Backbone
*/
const Mapper = { const Mapper = {
// this function is to retrieve a mapper JSON object from the database // this function is to retrieve a mapper JSON object from the database
// @param id = the id of the mapper to retrieve // @param id = the id of the mapper to retrieve
@ -13,7 +9,7 @@ const Mapper = {
if (!response.ok) throw response if (!response.ok) throw response
return response.json() return response.json()
}).then(payload => { }).then(payload => {
callback(new Metamaps.Backbone.Mapper(payload)) callback(new Backbone.Mapper(payload))
}) })
} }
} }

View file

@ -10,7 +10,7 @@
const Mobile = { const Mobile = {
init: function () { init: function () {
var self = Metamaps.Mobile var self = Mobile
$('#menu_icon').click(self.toggleMenu) $('#menu_icon').click(self.toggleMenu)
$('#mobile_menu li a').click(self.liClick) $('#mobile_menu li a').click(self.liClick)

View file

@ -1,21 +1,18 @@
/* global Metamaps, $ */ /* global $ */
import Visualize from './Visualize'
import JIT from './JIT'
/*
* Metamaps.Organize.js.erb
*
* Dependencies:
* - Metamaps.Visualize
*/
const Organize = { const Organize = {
arrange: function (layout, centerNode) { arrange: function (layout, centerNode) {
// first option for layout to implement is 'grid', will do an evenly spaced grid with its center at the 0,0 origin // first option for layout to implement is 'grid', will do an evenly spaced grid with its center at the 0,0 origin
if (layout == 'grid') { if (layout == 'grid') {
var numNodes = _.size(Metamaps.Visualize.mGraph.graph.nodes); // this will always be an integer, the # of nodes on your graph visualization var numNodes = _.size(Visualize.mGraph.graph.nodes); // this will always be an integer, the # of nodes on your graph visualization
var numColumns = Math.floor(Math.sqrt(numNodes)) // the number of columns to make an even grid var numColumns = Math.floor(Math.sqrt(numNodes)) // the number of columns to make an even grid
var GRIDSPACE = 400 var GRIDSPACE = 400
var row = 0 var row = 0
var column = 0 var column = 0
Metamaps.Visualize.mGraph.graph.eachNode(function (n) { Visualize.mGraph.graph.eachNode(function (n) {
if (column == numColumns) { if (column == numColumns) {
column = 0 column = 0
row += 1 row += 1
@ -26,14 +23,14 @@ const Organize = {
n.setPos(newPos, 'end') n.setPos(newPos, 'end')
column += 1 column += 1
}) })
Metamaps.Visualize.mGraph.animate(Metamaps.JIT.ForceDirected.animateSavedLayout) Visualize.mGraph.animate(JIT.ForceDirected.animateSavedLayout)
} else if (layout == 'grid_full') { } else if (layout == 'grid_full') {
// this will always be an integer, the # of nodes on your graph visualization // this will always be an integer, the # of nodes on your graph visualization
var numNodes = _.size(Metamaps.Visualize.mGraph.graph.nodes) var numNodes = _.size(Visualize.mGraph.graph.nodes)
// var numColumns = Math.floor(Math.sqrt(numNodes)) // the number of columns to make an even grid // var numColumns = Math.floor(Math.sqrt(numNodes)) // the number of columns to make an even grid
// var GRIDSPACE = 400 // var GRIDSPACE = 400
var height = Metamaps.Visualize.mGraph.canvas.getSize(0).height var height = Visualize.mGraph.canvas.getSize(0).height
var width = Metamaps.Visualize.mGraph.canvas.getSize(0).width var width = Visualize.mGraph.canvas.getSize(0).width
var totalArea = height * width var totalArea = height * width
var cellArea = totalArea / numNodes var cellArea = totalArea / numNodes
var ratio = height / width var ratio = height / width
@ -44,7 +41,7 @@ const Organize = {
var totalCells = row * column var totalCells = row * column
if (totalCells) if (totalCells)
Metamaps.Visualize.mGraph.graph.eachNode(function (n) { Visualize.mGraph.graph.eachNode(function (n) {
if (column == numColumns) { if (column == numColumns) {
column = 0 column = 0
row += 1 row += 1
@ -55,7 +52,7 @@ const Organize = {
n.setPos(newPos, 'end') n.setPos(newPos, 'end')
column += 1 column += 1
}) })
Metamaps.Visualize.mGraph.animate(Metamaps.JIT.ForceDirected.animateSavedLayout) Visualize.mGraph.animate(JIT.ForceDirected.animateSavedLayout)
} else if (layout == 'radial') { } else if (layout == 'radial') {
var centerX = centerNode.getPos().x var centerX = centerNode.getPos().x
var centerY = centerNode.getPos().y var centerY = centerNode.getPos().y
@ -87,16 +84,16 @@ const Organize = {
}) })
} }
radial(centerNode, 1, 0) radial(centerNode, 1, 0)
Metamaps.Visualize.mGraph.animate(Metamaps.JIT.ForceDirected.animateSavedLayout) Visualize.mGraph.animate(JIT.ForceDirected.animateSavedLayout)
} else if (layout == 'center_viewport') { } else if (layout == 'center_viewport') {
var lowX = 0, var lowX = 0,
lowY = 0, lowY = 0,
highX = 0, highX = 0,
highY = 0 highY = 0
var oldOriginX = Metamaps.Visualize.mGraph.canvas.translateOffsetX var oldOriginX = Visualize.mGraph.canvas.translateOffsetX
var oldOriginY = Metamaps.Visualize.mGraph.canvas.translateOffsetY var oldOriginY = Visualize.mGraph.canvas.translateOffsetY
Metamaps.Visualize.mGraph.graph.eachNode(function (n) { Visualize.mGraph.graph.eachNode(function (n) {
if (n.id === 1) { if (n.id === 1) {
lowX = n.getPos().x lowX = n.getPos().x
lowY = n.getPos().y lowY = n.getPos().y

View file

@ -1,12 +1,7 @@
/* global Metamaps, $ */ /* global $ */
/* import AutoLayout from './AutoLayout'
* Metamaps.PasteInput.js.erb import Import from './Import'
*
* Dependencies:
* - Metamaps.Import
* - Metamaps.AutoLayout
*/
const PasteInput = { const PasteInput = {
// thanks to https://github.com/kevva/url-regex // thanks to https://github.com/kevva/url-regex
@ -74,13 +69,13 @@ const PasteInput = {
handleURL: function (text, coords) { handleURL: function (text, coords) {
var title = 'Link' var title = 'Link'
if (!coords || !coords.x || !coords.y) { if (!coords || !coords.x || !coords.y) {
coords = Metamaps.AutoLayout.getNextCoord() coords = AutoLayout.getNextCoord()
} }
var import_id = null // don't store a cidMapping var import_id = null // don't store a cidMapping
var permission = null // use default var permission = null // use default
Metamaps.Import.createTopicWithParameters( Import.createTopicWithParameters(
title, title,
'Reference', // metacode - todo fix 'Reference', // metacode - todo fix
permission, permission,
@ -101,11 +96,11 @@ const PasteInput = {
}, },
handleJSON: function (text) { handleJSON: function (text) {
Metamaps.Import.handleJSON(text) Import.handleJSON(text)
}, },
handleTSV: function (text) { handleTSV: function (text) {
Metamaps.Import.handleTSV(text) Import.handleTSV(text)
} }
} }