2019-12-19 22:46:16 +11:00
|
|
|
// SPDX-License-Identifier: LGPL-3.0-or-later
|
|
|
|
|
2019-12-18 09:07:38 +11:00
|
|
|
import QtQuick 2.12
|
2019-12-03 07:29:29 +11:00
|
|
|
import ".."
|
|
|
|
import "../.."
|
2019-12-18 09:07:38 +11:00
|
|
|
|
|
|
|
QtObject {
|
|
|
|
function onExitRequested(exitCode) {
|
|
|
|
Qt.exit(exitCode)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function onAlertRequested() {
|
|
|
|
if (Qt.application.state !== Qt.ApplicationActive) {
|
|
|
|
window.alert(window.settings.alertOnMessageForMsec)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function onCoroutineDone(uuid, result, error, traceback) {
|
2020-03-08 19:46:20 +11:00
|
|
|
const onSuccess = Globals.pendingCoroutines[uuid].onSuccess
|
|
|
|
const onError = Globals.pendingCoroutines[uuid].onError
|
2019-12-18 09:07:38 +11:00
|
|
|
|
2019-12-03 07:29:29 +11:00
|
|
|
delete Globals.pendingCoroutines[uuid]
|
2019-12-27 00:20:51 +11:00
|
|
|
|
2019-12-18 09:07:38 +11:00
|
|
|
if (error) {
|
2019-12-27 00:20:51 +11:00
|
|
|
const type = py.getattr(py.getattr(error, "__class__"), "__name__")
|
|
|
|
const args = py.getattr(error, "args")
|
2019-12-18 09:07:38 +11:00
|
|
|
|
2020-03-13 17:52:38 +11:00
|
|
|
if (type === "CancelledError") return
|
2019-12-18 09:07:38 +11:00
|
|
|
|
2019-12-27 00:20:51 +11:00
|
|
|
if (onError) {
|
|
|
|
onError(type, args, error, traceback)
|
|
|
|
return
|
|
|
|
}
|
2019-12-18 09:07:38 +11:00
|
|
|
|
|
|
|
console.error(`python: ${uuid}\n${traceback}`)
|
|
|
|
|
2019-12-27 00:20:51 +11:00
|
|
|
if (window.hideErrorTypes.has(type)) {
|
|
|
|
console.warn(
|
|
|
|
"Not showing error popup for this type due to user choice"
|
|
|
|
)
|
|
|
|
return
|
|
|
|
}
|
2019-12-18 09:07:38 +11:00
|
|
|
|
2019-12-27 00:20:51 +11:00
|
|
|
utils.makePopup(
|
|
|
|
"Popups/UnexpectedErrorPopup.qml",
|
|
|
|
window,
|
2019-12-27 01:05:01 +11:00
|
|
|
{ errorType: type, traceback },
|
2019-12-27 00:20:51 +11:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
if (onSuccess) onSuccess(result)
|
2019-12-18 09:07:38 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-12-27 01:05:01 +11:00
|
|
|
function onLoopException(message, error, traceback) {
|
|
|
|
// No need to log these here, the asyncio exception handler does it
|
|
|
|
const type = py.getattr(py.getattr(error, "__class__"), "__name__")
|
|
|
|
|
|
|
|
if (window.hideErrorTypes.has(type)) {
|
|
|
|
console.warn(
|
|
|
|
"Not showing error popup for this type due to user choice"
|
|
|
|
)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
utils.makePopup(
|
|
|
|
"Popups/UnexpectedErrorPopup.qml",
|
|
|
|
window,
|
|
|
|
{ errorType: type, message, traceback },
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-12-03 07:29:29 +11:00
|
|
|
function onModelItemInserted(syncId, index, item) {
|
|
|
|
// print("insert", syncId, index, item)
|
|
|
|
ModelStore.get(syncId).insert(index, item)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function onModelItemFieldChanged(syncId, oldIndex, newIndex, field, value){
|
2020-03-10 08:36:47 +11:00
|
|
|
// print("change", syncId, oldIndex, newIndex, field, value)
|
2019-12-03 07:29:29 +11:00
|
|
|
const model = ModelStore.get(syncId)
|
|
|
|
model.setProperty(oldIndex, field, value)
|
|
|
|
|
|
|
|
if (oldIndex !== newIndex) model.move(oldIndex, newIndex, 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function onModelItemDeleted(syncId, index) {
|
|
|
|
// print("del", syncId, index)
|
|
|
|
ModelStore.get(syncId).remove(index)
|
|
|
|
}
|
|
|
|
|
2019-12-18 09:07:38 +11:00
|
|
|
|
2019-12-03 07:29:29 +11:00
|
|
|
function onModelCleared(syncId) {
|
|
|
|
// print("clear", syncId)
|
|
|
|
ModelStore.get(syncId).clear()
|
2019-12-18 09:07:38 +11:00
|
|
|
}
|
|
|
|
}
|