UNPKG

tasmota-esp-web-tools

Version:
93 lines (92 loc) 3.01 kB
import { connect } from "./connect"; export class InstallButton extends HTMLElement { connectedCallback() { if (this.renderRoot) { return; } this.renderRoot = this.attachShadow({ mode: "open" }); if (!InstallButton.isSupported || !InstallButton.isAllowed) { this.toggleAttribute("install-unsupported", true); this.renderRoot.innerHTML = !InstallButton.isAllowed ? "<slot name='not-allowed'>You can only install ESP devices on HTTPS websites or on the localhost.</slot>" : "<slot name='unsupported'>Your browser does not support installing things on ESP devices. Use Google Chrome or Microsoft Edge.</slot>"; return; } this.toggleAttribute("install-supported", true); const slot = document.createElement("slot"); slot.addEventListener("click", async (ev) => { ev.preventDefault(); connect(this); }); slot.name = "activate"; const button = document.createElement("button"); button.innerText = "CONNECT"; slot.append(button); if ("adoptedStyleSheets" in Document.prototype && "replaceSync" in CSSStyleSheet.prototype) { const sheet = new CSSStyleSheet(); sheet.replaceSync(InstallButton.style); this.renderRoot.adoptedStyleSheets = [sheet]; } else { const styleSheet = document.createElement("style"); styleSheet.innerText = InstallButton.style; this.renderRoot.append(styleSheet); } this.renderRoot.append(slot); } } InstallButton.isSupported = "serial" in navigator; InstallButton.isAllowed = window.isSecureContext; InstallButton.style = ` button { position: relative; cursor: pointer; font-size: 14px; padding: 8px 28px; color: var(--esp-tools-button-text-color, #fff); background-color: var(--esp-tools-button-color, #03a9f4); border: none; border-radius: 4px; box-shadow: 0 2px 2px 0 rgba(0,0,0,.14), 0 3px 1px -2px rgba(0,0,0,.12), 0 1px 5px 0 rgba(0,0,0,.2); } button::before { content: " "; position: absolute; top: 0; bottom: 0; left: 0; right: 0; opacity: 0.2; border-radius: 4px; } button:hover { box-shadow: 0 4px 8px 0 rgba(0,0,0,.14), 0 1px 7px 0 rgba(0,0,0,.12), 0 3px 1px -1px rgba(0,0,0,.2); } button:hover::before { background-color: rgba(255,255,255,.8); } button:focus { outline: none; } button:focus::before { background-color: white; } button:active::before { background-color: grey; } :host([active]) button { color: rgba(0, 0, 0, 0.38); background-color: rgba(0, 0, 0, 0.12); box-shadow: none; cursor: unset; pointer-events: none; } improv-wifi-launch-button { display: block; margin-top: 16px; } .hidden { display: none; }`; customElements.define("esp-web-install-button", InstallButton);