Merge pull request #730 from metamaps/feature/synapse-check-for-topic-by-name
allow synapses to be imported by topic name as well as id
This commit is contained in:
commit
d80d33761d
1 changed files with 22 additions and 12 deletions
|
@ -27,7 +27,7 @@ const Import = {
|
||||||
'id', 'name', 'metacode', 'x', 'y', 'description', 'link', 'permission'
|
'id', 'name', 'metacode', 'x', 'y', 'description', 'link', 'permission'
|
||||||
],
|
],
|
||||||
synapseWhitelist: [
|
synapseWhitelist: [
|
||||||
'topic1', 'topic2', 'category', 'desc', 'description', 'permission'
|
'topic1', 'topic2', 'category', 'direction', 'desc', 'description', 'permission'
|
||||||
],
|
],
|
||||||
cidMappings: {}, // to be filled by import_id => cid mappings
|
cidMappings: {}, // to be filled by import_id => cid mappings
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ const Import = {
|
||||||
console.warn(err)
|
console.warn(err)
|
||||||
return topicsPromise.resolve([])
|
return topicsPromise.resolve([])
|
||||||
}
|
}
|
||||||
topicsPromise.resolve(data.map(row => self.normalizeKeys(row)))
|
topicsPromise.resolve(data)
|
||||||
})
|
})
|
||||||
|
|
||||||
const synapsesPromise = $.Deferred()
|
const synapsesPromise = $.Deferred()
|
||||||
|
@ -68,7 +68,7 @@ const Import = {
|
||||||
console.warn(err)
|
console.warn(err)
|
||||||
return synapsesPromise.resolve([])
|
return synapsesPromise.resolve([])
|
||||||
}
|
}
|
||||||
synapsesPromise.resolve(data.map(row => self.normalizeKeys(row)))
|
synapsesPromise.resolve(data)
|
||||||
})
|
})
|
||||||
|
|
||||||
$.when(topicsPromise, synapsesPromise).done((topics, synapses) => {
|
$.when(topicsPromise, synapsesPromise).done((topics, synapses) => {
|
||||||
|
@ -83,8 +83,8 @@ const Import = {
|
||||||
|
|
||||||
handle: function(results) {
|
handle: function(results) {
|
||||||
var self = Import
|
var self = Import
|
||||||
var topics = results.topics
|
var topics = results.topics.map(topic => self.normalizeKeys(topic))
|
||||||
var synapses = results.synapses
|
var synapses = results.synapses.map(synapse => self.normalizeKeys(synapse))
|
||||||
|
|
||||||
if (topics.length > 0 || synapses.length > 0) {
|
if (topics.length > 0 || synapses.length > 0) {
|
||||||
if (window.confirm('Are you sure you want to create ' + topics.length +
|
if (window.confirm('Are you sure you want to create ' + topics.length +
|
||||||
|
@ -149,7 +149,7 @@ const Import = {
|
||||||
state = STATES.ABORT
|
state = STATES.ABORT
|
||||||
}
|
}
|
||||||
topicHeaders = line.map(function (header, index) {
|
topicHeaders = line.map(function (header, index) {
|
||||||
return header.toLowerCase().replace('description', 'desc')
|
return self.normalizeKey(header)
|
||||||
})
|
})
|
||||||
state = STATES.TOPICS
|
state = STATES.TOPICS
|
||||||
break
|
break
|
||||||
|
@ -160,7 +160,7 @@ const Import = {
|
||||||
state = STATES.ABORT
|
state = STATES.ABORT
|
||||||
}
|
}
|
||||||
synapseHeaders = line.map(function (header, index) {
|
synapseHeaders = line.map(function (header, index) {
|
||||||
return header.toLowerCase().replace('description', 'desc')
|
return self.normalizeKey(header)
|
||||||
})
|
})
|
||||||
state = STATES.SYNAPSES
|
state = STATES.SYNAPSES
|
||||||
break
|
break
|
||||||
|
@ -253,12 +253,16 @@ const Import = {
|
||||||
|
|
||||||
parsedSynapses.forEach(function (synapse) {
|
parsedSynapses.forEach(function (synapse) {
|
||||||
// only createSynapseWithParameters once both topics are persisted
|
// only createSynapseWithParameters once both topics are persisted
|
||||||
|
// if there isn't a cidMapping, check by topic name instead
|
||||||
var topic1 = Metamaps.Topics.get(self.cidMappings[synapse.topic1])
|
var topic1 = Metamaps.Topics.get(self.cidMappings[synapse.topic1])
|
||||||
|
if (!topic1) topic1 = Metamaps.Topics.findWhere({ name: synapse.topic1 })
|
||||||
var topic2 = Metamaps.Topics.get(self.cidMappings[synapse.topic2])
|
var topic2 = Metamaps.Topics.get(self.cidMappings[synapse.topic2])
|
||||||
|
if (!topic1) topic1 = Metamaps.Topics.findWhere({ name: synapse.topic1 })
|
||||||
|
|
||||||
if (!topic1 || !topic2) {
|
if (!topic1 || !topic2) {
|
||||||
console.error("One of the two topics doesn't exist!")
|
console.error("One of the two topics doesn't exist!")
|
||||||
console.error(synapse)
|
console.error(synapse)
|
||||||
return true
|
return // next
|
||||||
}
|
}
|
||||||
|
|
||||||
// ensure imported topics have a chance to get a real id attr before creating synapses
|
// ensure imported topics have a chance to get a real id attr before creating synapses
|
||||||
|
@ -402,14 +406,20 @@ const Import = {
|
||||||
.toLowerCase()
|
.toLowerCase()
|
||||||
},
|
},
|
||||||
|
|
||||||
|
normalizeKey: function(key) {
|
||||||
|
let newKey = key.toLowerCase()
|
||||||
|
newKey = newKey.replace(/\s/g, '') // remove whitespace
|
||||||
|
if (newKey === 'url') newKey = 'link'
|
||||||
|
if (newKey === 'title') newKey = 'name'
|
||||||
|
if (newKey === 'description') newKey = 'desc'
|
||||||
|
if (newKey === 'direction') newKey = 'category'
|
||||||
|
return newKey
|
||||||
|
},
|
||||||
|
|
||||||
// thanks to http://stackoverflow.com/a/25290114/5332286
|
// thanks to http://stackoverflow.com/a/25290114/5332286
|
||||||
normalizeKeys: function(obj) {
|
normalizeKeys: function(obj) {
|
||||||
return _.transform(obj, (result, val, key) => {
|
return _.transform(obj, (result, val, key) => {
|
||||||
let newKey = key.toLowerCase()
|
const newKey = Import.normalizeKey(key)
|
||||||
if (newKey === 'url') key = 'link'
|
|
||||||
if (newKey === 'title') key = 'name'
|
|
||||||
if (newKey === 'description') key = 'desc'
|
|
||||||
result[newKey] = val
|
result[newKey] = val
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue