Sha256: a5c1a7099106a687d16ef82bfb60c27a4c372c3b4a066c827569c47b74805bd3
Contents?: true
Size: 1.49 KB
Versions: 4
Compression:
Stored size: 1.49 KB
Contents
import { connectStreamSource, disconnectStreamSource } from "@hotwired/turbo" import { subscribeTo } from "./cable" import snakeize from "./snakeize" class TurboCableStreamSourceElement extends HTMLElement { static observedAttributes = ["channel", "signed-stream-name"] async connectedCallback() { connectStreamSource(this) this.subscription = await subscribeTo(this.channel, { received: this.dispatchMessageEvent.bind(this), connected: this.subscriptionConnected.bind(this), disconnected: this.subscriptionDisconnected.bind(this) }) } disconnectedCallback() { disconnectStreamSource(this) if (this.subscription) this.subscription.unsubscribe() this.subscriptionDisconnected() } attributeChangedCallback() { if (this.subscription) { this.disconnectedCallback() this.connectedCallback() } } dispatchMessageEvent(data) { const event = new MessageEvent("message", { data }) return this.dispatchEvent(event) } subscriptionConnected() { this.setAttribute("connected", "") } subscriptionDisconnected() { this.removeAttribute("connected") } get channel() { const channel = this.getAttribute("channel") const signed_stream_name = this.getAttribute("signed-stream-name") return { channel, signed_stream_name, ...snakeize({ ...this.dataset }) } } } if (customElements.get("turbo-cable-stream-source") === undefined) { customElements.define("turbo-cable-stream-source", TurboCableStreamSourceElement) }
Version data entries
4 entries across 4 versions & 1 rubygems