MapComplete/src/Logic/Actors/PendingChangesUploader.ts

75 lines
2.4 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { Changes } from "../Osm/Changes"
import Constants from "../../Models/Constants"
import { UIEventSource } from "../UIEventSource"
import { Utils } from "../../Utils"
2023-03-28 05:13:48 +02:00
import { Feature } from "geojson"
export default class PendingChangesUploader {
2022-09-08 21:40:48 +02:00
private lastChange: Date
2023-03-28 05:13:48 +02:00
constructor(changes: Changes, selectedFeature: UIEventSource<Feature>) {
2022-09-08 21:40:48 +02:00
const self = this
this.lastChange = new Date()
changes.pendingChanges.addCallback(() => {
2022-09-08 21:40:48 +02:00
self.lastChange = new Date()
window.setTimeout(() => {
2022-09-08 21:40:48 +02:00
const diff = (new Date().getTime() - self.lastChange.getTime()) / 1000
if (Constants.updateTimeoutSec >= diff - 1) {
2022-09-08 21:40:48 +02:00
changes.flushChanges("Flushing changes due to timeout")
}
2022-09-08 21:40:48 +02:00
}, Constants.updateTimeoutSec * 1000)
})
2022-09-08 21:40:48 +02:00
selectedFeature.stabilized(10000).addCallback((feature) => {
if (feature === undefined) {
// The popup got closed - we flush
changes.flushChanges("Flushing changes due to popup closed")
}
})
2021-11-07 16:34:51 +01:00
if (Utils.runningFromConsole) {
2022-09-08 21:40:48 +02:00
return
}
2021-11-07 16:34:51 +01:00
2022-09-08 21:40:48 +02:00
document.addEventListener("mouseout", (e) => {
// @ts-ignore
if (!e.toElement && !e.relatedTarget) {
2022-09-08 21:40:48 +02:00
changes.flushChanges("Flushing changes due to focus lost")
}
2022-09-08 21:40:48 +02:00
})
document.onfocus = () => {
changes.flushChanges("OnFocus")
}
document.onblur = () => {
changes.flushChanges("OnFocus")
}
try {
2022-09-08 21:40:48 +02:00
document.addEventListener(
"visibilitychange",
() => {
changes.flushChanges("Visibility change")
},
false
)
} catch (e) {
console.warn("Could not register visibility change listener", e)
}
function onunload(e) {
if (changes.pendingChanges.data.length == 0) {
2022-09-08 21:40:48 +02:00
return
}
2022-09-08 21:40:48 +02:00
changes.flushChanges("onbeforeunload - probably closing or something similar")
e.preventDefault()
return "Saving your last changes..."
}
window.onbeforeunload = onunload
// https://stackoverflow.com/questions/3239834/window-onbeforeunload-not-working-on-the-ipad#4824156
window.addEventListener("pagehide", onunload)
}
2022-09-08 21:40:48 +02:00
}