// Copyright (c) 2020 Tulir Asokan // // This Source Code Form is subject to the terms of the Mozilla Public // License, v. 2.0. If a copy of the MPL was not distributed with this // file, You can obtain one at http://mozilla.org/MPL/2.0/. let widgetId = null window.onmessage = event => { if (!window.parent || !event.data) { return } const request = event.data if (!request.requestId || !request.widgetId || !request.action || request.api !== "toWidget") { return } if (widgetId) { if (widgetId !== request.widgetId) { return } } else { widgetId = request.widgetId } let response if (request.action === "visibility") { response = {} } else if (request.action === "capabilities") { response = { capabilities: ["m.sticker"] } } else { response = { error: { message: "Action not supported" } } } window.parent.postMessage({ ...request, response }, event.origin) } export function sendSticker(content) { const data = { content: { ...content }, // `name` is for Element Web (and also the spec) // Element Android uses content -> body as the name name: content.body, } // Custom field that stores the ID even for non-telegram stickers delete data.content.id // This is for Element iOS const widgetData = { ...data, description: content.body, file: `${content.id}.png`, } // Element iOS explodes if there are extra fields present delete widgetData.content["net.maunium.telegram.sticker"] window.parent.postMessage({ api: "fromWidget", action: "m.sticker", requestId: `sticker-${Date.now()}`, widgetId, data, widgetData, }, "*") }