Asynchronous request–response iframe messaging
The goal of Tuai is to facilitate asynchronous request–response iframe messaging.
The sender sends messages to the iframe.
const response = await sender.send({ a: 5, b: 3 });
console.log("The sum of a and b is", response);
The receiver, inside the iframe, listens to incoming messages.
receiver.addResponder(ctx => {
return ctx.message.a + ctx.message.b;
});
npm install --save tuai
<script src="https://unpkg.com/tuai@latest"></script>
import { Sender } from "tuai";
const sender = new Sender({
querySelectors: ["#portal"],
receiverOrigin: "https://receiver.fake"
});
querySelectors: array of selectors used to find the iframe of the receiver (delegated to Document.querySelector())
receiverOrigin: origin of the receiver
import { Receiver } from "tuai";
const receiver = new Receiver();
Sends a message (of any type) and returns a promise with the answer of the receiver.
const response = await sender.send("Hello, World!");
console.log(response);
Registers a responder that will respond to incomding messages.
receiver.addResponder(function(ctx) {
return "Goodbye, World!";
});
A responder:
Must be a function or a promise:
- Function: the return value (if present) will be sent as the answer.
- Promise: the resolved (or rejected) value will be sent as the answer.
Has access to a ctx variable:
ctx.origin: the origin of sender, can (read: should) be used to verify the origin:
if (ctx.origin !== "https://sender.fake") {
throw new Error("Do I know you?");
}
ctx.message: the message it is responding to:
if (!ctx.mesage.startsWith("Hello,")) {
throw new Error("Don't be so rude!");
}
- pre-commit: re-format staged files with Prettier
# Build for production
npm run build
# Re-format files with Prettier
npm run prettier