status-desktop/src/nim_status_client.nim

99 lines
2.8 KiB
Nim
Raw Normal View History

2020-05-06 17:40:00 +00:00
import NimQml
import app/chat/core as chat
import app/wallet/core as wallet
import app/node/core as node
import app/profile/core as profile
2020-05-18 15:07:30 +00:00
import app/signals/core as signals
import state
import strformat
import strutils
import json
2020-05-13 15:37:12 +00:00
import status/core as status
import status/chat as status_chat
2020-05-13 15:37:12 +00:00
import status/test as status_test
import status/types as types
import status/wallet as status_wallet
import status/libstatus
import state
2020-05-18 18:48:20 +00:00
var signalsQObjPointer: pointer
2020-05-06 17:40:00 +00:00
proc mainProc() =
2020-05-18 20:32:53 +00:00
let app = newQApplication()
let engine = newQQmlApplicationEngine()
let signalController = signals.newController(app)
2020-05-18 18:48:20 +00:00
2020-05-18 20:32:53 +00:00
defer: # Defer will run this just before mainProc() function ends
app.delete()
engine.delete()
signalController.delete()
2020-05-18 18:48:20 +00:00
# We need this global variable in order to be able to access the application
# from the non-closure callback passed to `libstatus.setSignalEventCallback`
signalsQObjPointer = cast[pointer](signalController.vptr)
var appState = state.newAppState()
echo appState.title
var accounts = status_test.setupNewAccount()
echo "---------"
echo parseJSON(accounts)[0]
echo parseJSON(accounts)[1]
echo "---------"
2020-05-18 18:20:20 +00:00
status_chat.startMessenger()
2020-05-15 21:40:05 +00:00
var wallet = wallet.newController()
wallet.init()
2020-05-15 21:40:05 +00:00
engine.setRootContextProperty("assetsModel", wallet.variant)
2020-05-13 19:14:35 +00:00
2020-05-15 21:40:05 +00:00
var chat = chat.newController()
chat.init()
2020-05-15 21:40:05 +00:00
engine.setRootContextProperty("chatsModel", chat.variant)
2020-05-15 21:40:05 +00:00
var node = node.newController()
node.init()
2020-05-15 21:40:05 +00:00
engine.setRootContextProperty("nodeModel", node.variant)
2020-05-06 17:40:00 +00:00
var profile = profile.newController()
profile.init(accounts) # TODO: use correct account
engine.setRootContextProperty("profileModel", profile.variant)
2020-05-18 15:07:30 +00:00
signalController.init()
signalController.addSubscriber(SignalType.Wallet, wallet)
2020-05-19 21:00:04 +00:00
signalController.addSubscriber(SignalType.Wallet, node)
2020-05-18 18:20:20 +00:00
signalController.addSubscriber(SignalType.Message, chat)
2020-05-19 21:00:04 +00:00
2020-05-18 15:07:30 +00:00
engine.setRootContextProperty("signals", signalController.variant)
appState.subscribe(proc () =
# chatsModel.names = @[]
for channel in appState.channels:
echo channel.name
# chatsModel.addNameTolist(channel.name)
chat.join(channel.name)
)
appState.addChannel("test")
appState.addChannel("test2")
2020-05-18 18:48:20 +00:00
engine.load("../ui/main.qml")
2020-05-18 18:48:20 +00:00
# Please note that this must use the `cdecl` calling convention because
# it will be passed as a regular C function to libstatus. This means that
# we cannot capture any local variables here (we must rely on globals)
var callback: SignalCallback = proc(p0: cstring) {.cdecl.} =
setupForeignThreadGc()
2020-05-18 15:07:30 +00:00
signal_handler(signalsQObjPointer, p0, "receiveSignal")
tearDownForeignThreadGc()
libstatus.setSignalEventCallback(callback)
2020-05-10 23:24:06 +00:00
# Qt main event loop is entered here
# The termination of the loop will be performed when exit() or quit() is called
2020-05-06 17:40:00 +00:00
app.exec()
when isMainModule:
mainProc()
GC_fullcollect()