diff --git a/src/lib/device.ts b/src/lib/device.ts index e71125bedebd01dcc31821f495c877924e686c25..9ede78353f3958ba08673b9d9aa5b05103a9d559 100644 --- a/src/lib/device.ts +++ b/src/lib/device.ts @@ -396,12 +396,16 @@ export default abstract class Device extends js.global.EventEmitter { ackHandler, replyId, hopLimit, - }: ITextMessageParams): boolean { - // @ts-expect-error It's fucken ambient okay? - const enc = new TextEncoder(); - const payload = enc.encode(text); - if (payload.length > MAX_PAYLOAD) this.error(`sendText: payload length ${payload.length} exceeds maximum (${MAX_PAYLOAD})`); - return this.sendPacket({ payload, portNum: protobuf.Portnums.PortNum.TEXT_MESSAGE_APP, to, channel, wantAck, ackHandler, replyId, hopLimit }); + }: ITextMessageParams): void { + const msgs = chunkText(text); + for (const msg of msgs) { + // @ts-expect-error It's fucken ambient okay? + const enc = new TextEncoder(); + const payload = enc.encode(msg); + if (payload.length > MAX_PAYLOAD) this.error(`sendText: payload length ${payload.length} exceeds maximum (${MAX_PAYLOAD})`); + const res = this.sendPacket({ payload, portNum: protobuf.Portnums.PortNum.TEXT_MESSAGE_APP, to, channel, wantAck, ackHandler, replyId, hopLimit }); + if (!res) this.error(`failed to send text message`); + } } /**