Compare commits
No commits in common. "f5d15ce75fe786628133981c69fb89b2bca8a0ec" and "d737817528bc1de2e091bf000add2166cf9799ae" have entirely different histories.
f5d15ce75f
...
d737817528
2 changed files with 25 additions and 26 deletions
|
|
@ -7,22 +7,19 @@ In this example, we use Ox.MapEditor
|
||||||
Ox.load(['UI', 'Geo'], function() {
|
Ox.load(['UI', 'Geo'], function() {
|
||||||
var $storage = Ox.localStorage("map_editor")
|
var $storage = Ox.localStorage("map_editor")
|
||||||
var places = $storage('places') || []
|
var places = $storage('places') || []
|
||||||
var placesAPI = Ox.api(places, {
|
|
||||||
geo: true,
|
|
||||||
sort: '-area',
|
|
||||||
cache: true,
|
|
||||||
})
|
|
||||||
var $map = Ox.MapEditor({
|
var $map = Ox.MapEditor({
|
||||||
addPlace: function(place, callback) {
|
addPlace: function(place, callback) {
|
||||||
place = Ox.clone(place)
|
|
||||||
place.id = Ox.encodeBase26((places.length ? Ox.max(places.map(p => Ox.decodeBase26(p.id))) : 0) + 1)
|
place.id = Ox.encodeBase26((places.length ? Ox.max(places.map(p => Ox.decodeBase26(p.id))) : 0) + 1)
|
||||||
place.editable = true
|
|
||||||
console.log("addPlace", place.id, place)
|
console.log("addPlace", place.id, place)
|
||||||
places.push(place)
|
places.push(place)
|
||||||
$storage("places", places)
|
$storage("places", places)
|
||||||
placesAPI.update(places)
|
$map.options({
|
||||||
|
places: Ox.api(places, {
|
||||||
|
geo: true,
|
||||||
|
sort: '-area'
|
||||||
|
})
|
||||||
|
})
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
Ox.Request.clearCache();
|
|
||||||
callback({
|
callback({
|
||||||
status: {
|
status: {
|
||||||
code: 200
|
code: 200
|
||||||
|
|
@ -32,7 +29,6 @@ Ox.load(['UI', 'Geo'], function() {
|
||||||
}, 200)
|
}, 200)
|
||||||
},
|
},
|
||||||
editPlace: function(place, callback) {
|
editPlace: function(place, callback) {
|
||||||
place = Ox.clone(place)
|
|
||||||
places.forEach(p => {
|
places.forEach(p => {
|
||||||
if (p.id == place.id) {
|
if (p.id == place.id) {
|
||||||
Object.assign(p, place);
|
Object.assign(p, place);
|
||||||
|
|
@ -40,16 +36,12 @@ Ox.load(['UI', 'Geo'], function() {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
$storage("places", places)
|
$storage("places", places)
|
||||||
placesAPI.update(places)
|
|
||||||
setTimeout(() => {
|
|
||||||
Ox.Request.clearCache();
|
|
||||||
callback({
|
callback({
|
||||||
status: {
|
status: {
|
||||||
code: 200
|
code: 200
|
||||||
},
|
},
|
||||||
data: place
|
data: place
|
||||||
})
|
})
|
||||||
}, 200)
|
|
||||||
},
|
},
|
||||||
getMatches: function(names, callback) {
|
getMatches: function(names, callback) {
|
||||||
console.log("getMatches", names)
|
console.log("getMatches", names)
|
||||||
|
|
@ -59,21 +51,28 @@ Ox.load(['UI', 'Geo'], function() {
|
||||||
height: 800,
|
height: 800,
|
||||||
mode: 'add', // 'define',
|
mode: 'add', // 'define',
|
||||||
names: null,
|
names: null,
|
||||||
places: placesAPI,
|
places: Ox.api(places, {
|
||||||
|
geo: true,
|
||||||
|
sort: '-area'
|
||||||
|
}),
|
||||||
removePlace: function(place, callback) {
|
removePlace: function(place, callback) {
|
||||||
console.log("removePlace", place.id, places)
|
console.log("removePlace", place.id, places)
|
||||||
places = places.filter(p => { return p.id != place.id })
|
places = places.filter(p => { return p.id != place.id })
|
||||||
console.log("new places", places)
|
console.log("new places", places)
|
||||||
$storage("places", places)
|
$storage("places", places)
|
||||||
placesAPI.update(places)
|
$map.options({
|
||||||
|
places: Ox.api(places, {
|
||||||
|
geo: true,
|
||||||
|
sort: '-area'
|
||||||
|
})
|
||||||
|
})
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
Ox.Request.clearCache();
|
|
||||||
callback({
|
callback({
|
||||||
status: {
|
status: {
|
||||||
code: 200
|
code: 200
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
}, 200)
|
}, 100)
|
||||||
},
|
},
|
||||||
selected: '',
|
selected: '',
|
||||||
showControls: false,
|
showControls: false,
|
||||||
|
|
|
||||||
|
|
@ -49,7 +49,7 @@ Ox.MapEditor = function(options, self) {
|
||||||
places: function() {
|
places: function() {
|
||||||
self.isAsync = Ox.isFunction(self.options.places);
|
self.isAsync = Ox.isFunction(self.options.places);
|
||||||
self.$list.options({
|
self.$list.options({
|
||||||
items: self.isAsync ? self.options.places : Ox.clone(self.options.places)
|
items: Ox.clone(self.options.places)
|
||||||
})
|
})
|
||||||
self.$map.options({
|
self.$map.options({
|
||||||
places: self.options.places
|
places: self.options.places
|
||||||
|
|
@ -337,7 +337,7 @@ Ox.MapEditor = function(options, self) {
|
||||||
columns: self.columns,
|
columns: self.columns,
|
||||||
columnsRemovable: true,
|
columnsRemovable: true,
|
||||||
columnsVisible: true,
|
columnsVisible: true,
|
||||||
items: self.isAsync ? self.options.places : Ox.clone(self.options.places),
|
items: Ox.clone(self.options.places),
|
||||||
//items: self.options.places,
|
//items: self.options.places,
|
||||||
// area needed for icon, geoname needed for flag
|
// area needed for icon, geoname needed for flag
|
||||||
keys: ['area', 'geoname', 'matches'],
|
keys: ['area', 'geoname', 'matches'],
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue