Merge pull request #698 from metamaps/feature/random-updates
more random js & import updates
This commit is contained in:
commit
77d353464b
4 changed files with 97 additions and 79 deletions
|
@ -7,7 +7,7 @@ const AutoLayout = {
|
||||||
nextYshift: 0,
|
nextYshift: 0,
|
||||||
timeToTurn: 0,
|
timeToTurn: 0,
|
||||||
|
|
||||||
getNextCoord: function () {
|
getNextCoord: function (opts = {}) {
|
||||||
var self = AutoLayout
|
var self = AutoLayout
|
||||||
var nextX = self.nextX
|
var nextX = self.nextX
|
||||||
var nextY = self.nextY
|
var nextY = self.nextY
|
||||||
|
@ -49,9 +49,22 @@ const AutoLayout = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
if (opts.map && self.coordsTaken(nextX, nextY, opts.map)) {
|
||||||
x: nextX,
|
// check if the coordinate is already taken on the current map
|
||||||
y: nextY
|
return self.getNextCoord(opts)
|
||||||
|
} else {
|
||||||
|
return {
|
||||||
|
x: nextX,
|
||||||
|
y: nextY
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
coordsTaken: function (x, y, map) {
|
||||||
|
const mappings = map.getMappings()
|
||||||
|
if (mappings.findWhere({ xloc: x, yloc: y })) {
|
||||||
|
return true
|
||||||
|
} else {
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
resetSpiral: function () {
|
resetSpiral: function () {
|
||||||
|
|
|
@ -4,6 +4,7 @@ import parse from 'csv-parse'
|
||||||
import _ from 'lodash'
|
import _ from 'lodash'
|
||||||
|
|
||||||
import Active from './Active'
|
import Active from './Active'
|
||||||
|
import AutoLayout from './AutoLayout'
|
||||||
import GlobalUI from './GlobalUI'
|
import GlobalUI from './GlobalUI'
|
||||||
import Map from './Map'
|
import Map from './Map'
|
||||||
import Synapse from './Synapse'
|
import Synapse from './Synapse'
|
||||||
|
@ -40,9 +41,9 @@ const Import = {
|
||||||
|
|
||||||
const topicsRegex = /("?Topics"?)([\s\S]*)/mi
|
const topicsRegex = /("?Topics"?)([\s\S]*)/mi
|
||||||
const synapsesRegex = /("?Synapses"?)([\s\S]*)/mi
|
const synapsesRegex = /("?Synapses"?)([\s\S]*)/mi
|
||||||
let topicsText = text.match(topicsRegex)
|
let topicsText = text.match(topicsRegex) || ''
|
||||||
if (topicsText) topicsText = topicsText[2].replace(synapsesRegex, '')
|
if (topicsText) topicsText = topicsText[2].replace(synapsesRegex, '')
|
||||||
let synapsesText = text.match(synapsesRegex)
|
let synapsesText = text.match(synapsesRegex) || ''
|
||||||
if (synapsesText) synapsesText = synapsesText[2].replace(topicsRegex, '')
|
if (synapsesText) synapsesText = synapsesText[2].replace(topicsRegex, '')
|
||||||
|
|
||||||
// merge default options and extra options passed in parserOpts argument
|
// merge default options and extra options passed in parserOpts argument
|
||||||
|
@ -54,14 +55,20 @@ const Import = {
|
||||||
|
|
||||||
const topicsPromise = $.Deferred()
|
const topicsPromise = $.Deferred()
|
||||||
parse(topicsText, csv_parser_options, (err, data) => {
|
parse(topicsText, csv_parser_options, (err, data) => {
|
||||||
if (err) return topicsPromise.reject(err)
|
if (err) {
|
||||||
topicsPromise.resolve(data.map(row => self.lowercaseKeys(row)))
|
console.warn(err)
|
||||||
|
return topicsPromise.resolve([])
|
||||||
|
}
|
||||||
|
topicsPromise.resolve(data.map(row => self.normalizeKeys(row)))
|
||||||
})
|
})
|
||||||
|
|
||||||
const synapsesPromise = $.Deferred()
|
const synapsesPromise = $.Deferred()
|
||||||
parse(synapsesText, csv_parser_options, (err, data) => {
|
parse(synapsesText, csv_parser_options, (err, data) => {
|
||||||
if (err) return synapsesPromise.reject(err)
|
if (err) {
|
||||||
synapsesPromise.resolve(data.map(row => self.lowercaseKeys(row)))
|
console.warn(err)
|
||||||
|
return synapsesPromise.resolve([])
|
||||||
|
}
|
||||||
|
synapsesPromise.resolve(data.map(row => self.normalizeKeys(row)))
|
||||||
})
|
})
|
||||||
|
|
||||||
$.when(topicsPromise, synapsesPromise).done((topics, synapses) => {
|
$.when(topicsPromise, synapsesPromise).done((topics, synapses) => {
|
||||||
|
@ -217,32 +224,26 @@ const Import = {
|
||||||
importTopics: function (parsedTopics) {
|
importTopics: function (parsedTopics) {
|
||||||
var self = Import
|
var self = Import
|
||||||
|
|
||||||
// up to 25 topics: scale 100
|
|
||||||
// up to 81 topics: scale 200
|
|
||||||
// up to 169 topics: scale 300
|
|
||||||
var scale = Math.floor((Math.sqrt(parsedTopics.length) - 1) / 4) * 100
|
|
||||||
if (scale < 100) scale = 100
|
|
||||||
var autoX = -scale
|
|
||||||
var autoY = -scale
|
|
||||||
|
|
||||||
parsedTopics.forEach(function (topic) {
|
parsedTopics.forEach(function (topic) {
|
||||||
var x, y
|
let coords = { x: topic.x, y: topic.y }
|
||||||
if (topic.x && topic.y) {
|
if (!coords.x || !coords.y) {
|
||||||
x = topic.x
|
coords = AutoLayout.getNextCoord({ map: Active.Map })
|
||||||
y = topic.y
|
}
|
||||||
} else {
|
|
||||||
x = autoX
|
if (!topic.name && topic.link ||
|
||||||
y = autoY
|
topic.name && topic.link && !topic.metacode) {
|
||||||
autoX += 50
|
self.handleURL(topic.link, {
|
||||||
if (autoX > scale) {
|
coords,
|
||||||
autoY += 50
|
name: topic.name,
|
||||||
autoX = -scale
|
permission: topic.permission,
|
||||||
}
|
import_id: topic.id
|
||||||
|
})
|
||||||
|
return // "continue"
|
||||||
}
|
}
|
||||||
|
|
||||||
self.createTopicWithParameters(
|
self.createTopicWithParameters(
|
||||||
topic.name, topic.metacode, topic.permission,
|
topic.name, topic.metacode, topic.permission,
|
||||||
topic.desc, topic.link, x, y, topic.id
|
topic.desc, topic.link, coords.x, coords.y, topic.id
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
@ -345,6 +346,47 @@ const Import = {
|
||||||
Synapse.renderSynapse(mapping, synapse, node1, node2, true)
|
Synapse.renderSynapse(mapping, synapse, node1, node2, true)
|
||||||
},
|
},
|
||||||
|
|
||||||
|
handleURL: function (url, opts = {}) {
|
||||||
|
let coords = opts.coords
|
||||||
|
if (!coords || coords.x === undefined || coords.y === undefined) {
|
||||||
|
coords = AutoLayout.getNextCoord({ map: Active.Map })
|
||||||
|
}
|
||||||
|
|
||||||
|
const name = opts.name || 'Link'
|
||||||
|
const metacode = opts.metacode || 'Reference'
|
||||||
|
const import_id = opts.import_id || null // don't store a cidMapping
|
||||||
|
const permission = opts.permission || null // use default
|
||||||
|
const desc = opts.desc || url
|
||||||
|
|
||||||
|
Import.createTopicWithParameters(
|
||||||
|
name,
|
||||||
|
metacode,
|
||||||
|
permission,
|
||||||
|
desc,
|
||||||
|
url,
|
||||||
|
coords.x,
|
||||||
|
coords.y,
|
||||||
|
import_id,
|
||||||
|
{
|
||||||
|
success: function(topic) {
|
||||||
|
if (topic.get('name') !== 'Link') return
|
||||||
|
$.get('/hacks/load_url_title', {
|
||||||
|
url
|
||||||
|
}, function success(data, textStatus) {
|
||||||
|
var selector = '#showcard #topic_' + topic.get('id') + ' .best_in_place'
|
||||||
|
if ($(selector).find('form').length > 0) {
|
||||||
|
$(selector).find('textarea, input').val(data.title)
|
||||||
|
} else {
|
||||||
|
$(selector).html(data.title)
|
||||||
|
}
|
||||||
|
topic.set('name', data.title)
|
||||||
|
topic.save()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* helper functions
|
* helper functions
|
||||||
*/
|
*/
|
||||||
|
@ -353,6 +395,7 @@ const Import = {
|
||||||
console.error(message)
|
console.error(message)
|
||||||
},
|
},
|
||||||
|
|
||||||
|
// TODO investigate replacing with es6 (?) trim()
|
||||||
simplify: function (string) {
|
simplify: function (string) {
|
||||||
return string
|
return string
|
||||||
.replace(/(^\s*|\s*$)/g, '')
|
.replace(/(^\s*|\s*$)/g, '')
|
||||||
|
@ -361,9 +404,13 @@ const Import = {
|
||||||
|
|
||||||
|
|
||||||
// thanks to http://stackoverflow.com/a/25290114/5332286
|
// thanks to http://stackoverflow.com/a/25290114/5332286
|
||||||
lowercaseKeys: function(obj) {
|
normalizeKeys: function(obj) {
|
||||||
return _.transform(obj, (result, val, key) => {
|
return _.transform(obj, (result, val, key) => {
|
||||||
result[key.toLowerCase()] = val
|
let newKey = key.toLowerCase()
|
||||||
|
if (newKey === 'url') key = 'link'
|
||||||
|
if (newKey === 'title') key = 'name'
|
||||||
|
if (newKey === 'description') key = 'desc'
|
||||||
|
result[newKey] = val
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
/* global $ */
|
/* global $ */
|
||||||
|
|
||||||
import AutoLayout from './AutoLayout'
|
|
||||||
import Import from './Import'
|
import Import from './Import'
|
||||||
import TopicCard from './TopicCard'
|
|
||||||
import Util from './Util'
|
import Util from './Util'
|
||||||
|
|
||||||
const PasteInput = {
|
const PasteInput = {
|
||||||
|
@ -58,7 +56,7 @@ const PasteInput = {
|
||||||
var self = PasteInput
|
var self = PasteInput
|
||||||
|
|
||||||
if (text.match(self.URL_REGEX)) {
|
if (text.match(self.URL_REGEX)) {
|
||||||
self.handleURL(text, coords)
|
Import.handleURL(text, coords)
|
||||||
} else if (text[0] === '{') {
|
} else if (text[0] === '{') {
|
||||||
Import.handleJSON(text)
|
Import.handleJSON(text)
|
||||||
} else if (text.match(/\t/)) {
|
} else if (text.match(/\t/)) {
|
||||||
|
@ -67,47 +65,6 @@ const PasteInput = {
|
||||||
// just try to see if CSV works
|
// just try to see if CSV works
|
||||||
Import.handleCSV(text)
|
Import.handleCSV(text)
|
||||||
}
|
}
|
||||||
},
|
|
||||||
|
|
||||||
handleURL: function (text, coords) {
|
|
||||||
var title = 'Link'
|
|
||||||
if (!coords || !coords.x || !coords.y) {
|
|
||||||
coords = AutoLayout.getNextCoord()
|
|
||||||
}
|
|
||||||
|
|
||||||
var import_id = null // don't store a cidMapping
|
|
||||||
var permission = null // use default
|
|
||||||
|
|
||||||
Import.createTopicWithParameters(
|
|
||||||
title,
|
|
||||||
'Reference', // metacode - todo fix
|
|
||||||
permission,
|
|
||||||
text, // desc - todo load from url?
|
|
||||||
text, // link - todo fix because this isn't being POSTed
|
|
||||||
coords.x,
|
|
||||||
coords.y,
|
|
||||||
import_id,
|
|
||||||
{
|
|
||||||
success: function(topic) {
|
|
||||||
$.get('/hacks/load_url_title', {
|
|
||||||
url: text
|
|
||||||
}, function success(data, textStatus) {
|
|
||||||
var selector = '#showcard #topic_' + topic.get('id') + ' .best_in_place'
|
|
||||||
if ($(selector).find('form').length > 0) {
|
|
||||||
$(selector).find('textarea, input').val(data.title)
|
|
||||||
} else {
|
|
||||||
$(selector).html(data.title)
|
|
||||||
}
|
|
||||||
topic.set('name', data.title)
|
|
||||||
topic.save()
|
|
||||||
})
|
|
||||||
TopicCard.showCard(topic.get('node'), function() {
|
|
||||||
$('#showcard #titleActivator').click()
|
|
||||||
.find('textarea, input').focus()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ const config = module.exports = {
|
||||||
test: /\.(js|jsx)?$/,
|
test: /\.(js|jsx)?$/,
|
||||||
exclude: /node_modules/,
|
exclude: /node_modules/,
|
||||||
loaders: [
|
loaders: [
|
||||||
"babel-loader?cacheDirectory"
|
'babel-loader?cacheDirectory&retainLines=true'
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -36,6 +36,7 @@ const config = module.exports = {
|
||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
path: './app/assets/javascripts/webpacked',
|
path: './app/assets/javascripts/webpacked',
|
||||||
filename: '[name].js'
|
filename: '[name].js',
|
||||||
|
devtoolModuleFilenameTemplate: '[absolute-resource-path]'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue