add some initial API code

This commit is contained in:
Richard Unger
2024-01-27 22:01:16 +01:00
parent 001173d61a
commit 88f2cad3e5
6 changed files with 100 additions and 13 deletions

19
src/backend/nano.js Normal file
View File

@@ -0,0 +1,19 @@
const nano = {
get(pid, tid, vid) {
return new Promise((resolve, reject) => {
resolve({ pid: pid, tid: tid, vid: vid, value: 0.0 });
});
},
set(pid, tid, vid, value) {
return new Promise((resolve, reject) => {
resolve({ pid: pid, tid: tid, vid: vid, value: value });
});
},
onValueReceived(listener) {
}
};
export default nano;

View File

@@ -0,0 +1,23 @@
const nanodevices = {
list() {
return [];
},
async connect(devicename) {
return true;
},
async disconnect() {
return true;
},
onAttach(listener) {
},
onDetach(listener) {
}
};
export default nanodevices;

View File

@@ -1,17 +1,21 @@
import { app, BrowserWindow } from 'electron';
import path from 'path';
import 'electron-squirrel-startup';
import ess from 'electron-squirrel-startup';
import { ipcMain } from 'electron';
import nanodevices from './backend/nanodevices.js';
import nano from './backend/nano.js';
// TODO Handle creating/removing shortcuts on Windows when installing/uninstalling.
//if (require('electron-squirrel-startup')) {
// app.quit();
//}
// Handle creating/removing shortcuts on Windows when installing/uninstalling.
if (ess) {
app.quit();
}
const createWindow = () => {
// Create the browser window.
const mainWindow = new BrowserWindow({
width: 800,
height: 600,
width: 1100,
height: 912,
webPreferences: {
preload: path.join(__dirname, 'preload.js'),
},
@@ -26,12 +30,33 @@ const createWindow = () => {
// Open the DevTools.
mainWindow.webContents.openDevTools();
return mainWindow;
};
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.on('ready', createWindow);
app.whenReady().then(() => {
ipcMain.handle('nanodevices:list', nanodevices.list);
ipcMain.handle('nanodevices:connect', nanodevices.connect);
ipcMain.handle('nanodevices:disconnect', nanodevices.disconnect);
ipcMain.handle('nano:get', nano.get);
ipcMain.handle('nano:set', nano.set);
const mainWindow = createWindow();
nanodevices.onAttach((device) => {
console.log("Attached device", device);
mainWindow.webContents.send('nanodevice-attached', device);
});
nanodevices.onDetach((device) => {
console.log("Detached device", device);
mainWindow.webContents.send('nanodevice-detached', device);
});
nano.onValueReceived((value) => {
console.log("Value received", value);
mainWindow.webContents.send('nano-onvalue', value);
});
});
// Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits

View File

@@ -1,2 +1,22 @@
// See the Electron documentation for details on how to use preload scripts:
// https://www.electronjs.org/docs/latest/tutorial/process-model#preload-scripts
const { contextBridge, ipcRenderer } = require('electron')
// expose an API to choose available devices
contextBridge.exposeInMainWorld('nanodevices', {
list() { ipcRenderer.invoke('nanodevices:list'); },
connect(devicename) { ipcRenderer.invoke('nanodevices:connect', devicename); },
disconnect() { ipcRenderer.invoke('nanodevices:disconnect'); },
on_device_attached(listener) { ipcRenderer.on('nanodevice-attached', (_event, value) => listener(value)); },
on_device_detached(listener) { ipcRenderer.on('nanodevice-detached', (_event, value) => listener(value)); },
});
// expose an API to communicate with the nano device
contextBridge.exposeInMainWorld('nanodevice', {
get_value(pid, tid, vid){ ipcRenderer.invoke('nano:get', pid, tid, vid); },
set_value(pid, tid, vid, value){ ipcRenderer.invoke('nano:set', pid, tid, vid, value); },
on_value(listener){ ipcRenderer.on('nano-onvalue', (_event, value) => listener(value)); }
});