use Ox.api async mode and clear cache on change

This commit is contained in:
j 2025-08-11 18:27:50 +02:00
commit f5d15ce75f

View file

@ -7,19 +7,22 @@ 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)
$map.options({ placesAPI.update(places)
places: Ox.api(places, {
geo: true,
sort: '-area'
})
})
setTimeout(() => { setTimeout(() => {
Ox.Request.clearCache();
callback({ callback({
status: { status: {
code: 200 code: 200
@ -29,6 +32,7 @@ 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);
@ -36,12 +40,16 @@ Ox.load(['UI', 'Geo'], function() {
} }
}) })
$storage("places", places) $storage("places", places)
callback({ placesAPI.update(places)
status: { setTimeout(() => {
code: 200 Ox.Request.clearCache();
}, callback({
data: place status: {
}) code: 200
},
data: place
})
}, 200)
}, },
getMatches: function(names, callback) { getMatches: function(names, callback) {
console.log("getMatches", names) console.log("getMatches", names)
@ -51,28 +59,21 @@ Ox.load(['UI', 'Geo'], function() {
height: 800, height: 800,
mode: 'add', // 'define', mode: 'add', // 'define',
names: null, names: null,
places: Ox.api(places, { places: placesAPI,
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)
$map.options({ placesAPI.update(places)
places: Ox.api(places, {
geo: true,
sort: '-area'
})
})
setTimeout(() => { setTimeout(() => {
Ox.Request.clearCache();
callback({ callback({
status: { status: {
code: 200 code: 200
}, },
}) })
}, 100) }, 200)
}, },
selected: '', selected: '',
showControls: false, showControls: false,