mirror of
https://github.com/meshcore-dev/meshcore.js.git
synced 2026-04-20 22:13:49 +00:00
No description
This package has a single export that includes both NodeJS and browser modules. When a web project imports this library, the build generates a bunch of warnings, like this in vite: [plugin vite:resolve] Module net has been externalized for browser compatibility... [plugin vite:resolve] Module stream has been externalized for browser compatibility... ... We can clean this up by creating a special browser-only export. Bundlers like Vite and Webpack know to choose the 'browser' export in projects that are web-only (not NodeJS). This change adds a 'browser' export and updates the documentation to use browser-only examples. |
||
|---|---|---|
| examples | ||
| src | ||
| .gitignore | ||
| .npmignore | ||
| index.html | ||
| LICENSE | ||
| package-lock.json | ||
| package.json | ||
| README.md | ||
MeshCore.js
A Javascript library for interacting with a MeshCore device running the Companion Radio Firmware.
This library can be used in a Web Browser to connect to MeshCore Companion devices over BLE or USB Serial.
It can also be used in NodeJS to connect to MeshCore Companion devices over TCP/WiFi or USB Serial.
Supported Connection Methods
- Web Browser
- BLE: WebBleConnection()
- USB/Serial: WebSerialConnection()
- NodeJS
- TCP/WiFi: TCPConnection("host", "port")
- USB/Serial: NodeJSSerialConnection("/dev/ttyUSB0")
Install
npm install @liamcottle/meshcore.js
Simple Examples
Enumerate Contacts (Node.js)
import { TCPConnection, NodeJSSerialConnection } from "@liamcottle/meshcore.js";
// serial connections are supported by "companion_radio_usb" firmware
const connection = new NodeJSSerialConnection("/dev/cu.usbmodem14401");
// tcp connections are supported by "companion_radio_wifi" firmware
// const connection = new TCPConnection("10.1.0.226", 5000);
// wait until connected
connection.on("connected", async () => {
// we are now connected
console.log("connected!");
// log contacts
const contacts = await connection.getContacts();
for(const contact of contacts) {
console.log(`Contact: ${contact.advName}`);
}
// disconnect
connection.close();
});
// connect to meshcore device
await connection.connect();
Enumerate Contacts (Browser)
<button id="connect-serial">Connect via Serial</button>
<script type="module">
import { WebBleConnection, WebSerialConnection } from "@liamcottle/meshcore.js";
// wait until connected
async function onConnected(connection) {
// we are now connected
console.log("connected!");
// log contacts
const contacts = await connection.getContacts();
for (const contact of contacts) {
console.log(`Contact: ${contact.advName}`);
}
}
document.getElementById("connect-serial").addEventListener("click", async () => {
const connection = await WebSerialConnection.open();
connection.on("connected", () => onConnected(connection));
});
</script>
Examples
There's a few other examples scripts in the examples folder.
License
MIT