import { LitElement, css, html } from "lit"; import { customElement, state } from "lit/decorators.js"; import { renderPlayerFlag } from "../core/CustomFlag"; import { FlagSchema } from "../core/Schemas"; import { translateText } from "./Utils"; const flagKey: string = "flag"; @customElement("flag-input") export class FlagInput extends LitElement { @state() public flag: string = ""; static styles = css` @media (max-width: 768px) { .flag-modal { width: 80vw; } .dropdown-item { width: calc(100% / 3 - 15px); } } `; public getCurrentFlag(): string { return this.flag; } private getStoredFlag(): string { const storedFlag = localStorage.getItem(flagKey); if (storedFlag) { return storedFlag; } return ""; } private dispatchFlagEvent() { this.dispatchEvent( new CustomEvent("flag-change", { detail: { flag: this.flag }, bubbles: true, composed: true, }), ); } private updateFlag = (ev: Event) => { const e = ev as CustomEvent<{ flag: string }>; if (!FlagSchema.safeParse(e.detail.flag).success) return; if (this.flag !== e.detail.flag) { this.flag = e.detail.flag; } }; connectedCallback() { super.connectedCallback(); this.flag = this.getStoredFlag(); this.dispatchFlagEvent(); window.addEventListener("flag-change", this.updateFlag as EventListener); } disconnectedCallback() { super.disconnectedCallback(); window.removeEventListener("flag-change", this.updateFlag as EventListener); } createRenderRoot() { return this; } render() { return html`