@launchsecure/launch-beacon 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"beacon.es.js","sources":["../src/ui/icons.ts","../src/ui/button.ts","../src/ui/drawer.ts","../src/ui/pin-popover.ts","../src/capture/picker.ts","../src/capture/selector.ts","../src/capture/framework.ts","../src/capture/element.ts","../src/capture/metadata.ts","../src/capture/screenshot.ts","../src/capture/overlay.ts","../src/transport/submit.ts","../src/element.ts","../src/index.ts"],"sourcesContent":["// Inline SVGs to avoid an icon library dep. Returns innerHTML strings (caller assigns).\n\nexport const ICONS = {\n feedback: `<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\"><path d=\"M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z\"/></svg>`,\n pin: `<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\"><path d=\"M12 17v5\"/><path d=\"M9 10.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24V16a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-.76a2 2 0 0 0-1.11-1.79l-1.78-.9A2 2 0 0 1 15 10.76V7a1 1 0 0 1 1-1 2 2 0 0 0 0-4H8a2 2 0 0 0 0 4 1 1 0 0 1 1 1z\"/></svg>`,\n close: `<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\"><path d=\"M18 6 6 18\"/><path d=\"m6 6 12 12\"/></svg>`,\n trash: `<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\"><path d=\"M3 6h18\"/><path d=\"M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6\"/><path d=\"M8 6V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2\"/></svg>`,\n send: `<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\"><path d=\"m22 2-7 20-4-9-9-4Z\"/><path d=\"M22 2 11 13\"/></svg>`,\n check: `<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\"><polyline points=\"20 6 9 17 4 12\"/></svg>`,\n} as const;\n","// Default floating trigger button. Rendered into the Shadow DOM unless a slot=\"trigger\"\n// child is provided by the consumer.\n\nimport { ICONS } from './icons';\n\nexport function createTriggerButton(label = 'Feedback'): HTMLButtonElement {\n const btn = document.createElement('button');\n btn.type = 'button';\n btn.className = 'beacon-default-trigger';\n btn.setAttribute('aria-label', label);\n btn.innerHTML = `${ICONS.feedback}<span>${label}</span>`;\n return btn;\n}\n","// The form drawer: description textarea + severity picker + pin list + actions.\n// Built imperatively (no JSX). The element class is the controller; this module\n// handles markup + small DOM helpers.\n\nimport { ICONS } from './icons';\nimport type { Pin, Severity } from '../types';\n\nconst DEFAULT_SEVERITIES: Severity[] = ['bug', 'idea', 'ux', 'a11y'];\n\nexport interface DrawerCallbacks {\n onClose: () => void;\n onAnnotate: () => void;\n onSubmit: () => void;\n onPinNoteChange: (pinNumber: number, note: string) => void;\n onPinDelete: (pinNumber: number) => void;\n onDescriptionChange: (value: string) => void;\n onSeverityChange: (sev: Severity) => void;\n}\n\nexport class DrawerView {\n readonly root: HTMLDivElement;\n readonly bodyEl: HTMLDivElement;\n private severities: Severity[];\n private callbacks: DrawerCallbacks;\n private state = {\n description: '',\n severity: 'bug' as Severity,\n pins: [] as Pin[],\n annotatedScreenshot: undefined as string | undefined,\n submitting: false,\n status: '' as string,\n statusKind: '' as '' | 'error' | 'success',\n };\n\n constructor(severities: Severity[], callbacks: DrawerCallbacks) {\n this.severities = severities.length > 0 ? severities : DEFAULT_SEVERITIES;\n this.callbacks = callbacks;\n this.root = document.createElement('div');\n this.root.className = 'beacon-drawer';\n this.root.innerHTML = `\n <div class=\"beacon-drawer-header\">\n <div class=\"beacon-drawer-title\">Send feedback</div>\n <button type=\"button\" class=\"beacon-icon-btn\" data-action=\"close\" aria-label=\"Close\">${ICONS.close}</button>\n </div>\n <div class=\"beacon-drawer-body\"></div>\n `;\n this.bodyEl = this.root.querySelector('.beacon-drawer-body') as HTMLDivElement;\n this.root.querySelector('[data-action=\"close\"]')!.addEventListener('click', () => this.callbacks.onClose());\n this.render();\n }\n\n open() {\n this.root.classList.remove('minimized');\n this.root.classList.add('open');\n }\n\n close() {\n this.root.classList.remove('open');\n }\n\n minimize() {\n this.root.classList.add('minimized');\n this.root.classList.remove('open');\n }\n\n setPins(pins: Pin[], annotatedScreenshot?: string) {\n this.state.pins = pins;\n if (annotatedScreenshot !== undefined) this.state.annotatedScreenshot = annotatedScreenshot;\n this.render();\n }\n\n setSubmitting(submitting: boolean) {\n this.state.submitting = submitting;\n this.render();\n }\n\n setStatus(status: string, kind: '' | 'error' | 'success' = '') {\n this.state.status = status;\n this.state.statusKind = kind;\n this.render();\n }\n\n reset() {\n this.state = {\n description: '',\n severity: 'bug',\n pins: [],\n annotatedScreenshot: undefined,\n submitting: false,\n status: '',\n statusKind: '',\n };\n this.render();\n }\n\n getDescription() { return this.state.description; }\n getSeverity() { return this.state.severity; }\n\n private render() {\n const canSubmit = this.state.description.trim().length > 0 && !this.state.submitting;\n\n this.bodyEl.innerHTML = `\n <div class=\"beacon-field\">\n <label class=\"beacon-label\" for=\"beacon-desc\">What's the issue?</label>\n <textarea id=\"beacon-desc\" class=\"beacon-textarea\" placeholder=\"Describe what you saw, what you expected, anything that helps reproduce…\">${escapeHtml(this.state.description)}</textarea>\n </div>\n\n <div class=\"beacon-field\">\n <span class=\"beacon-label\">Severity</span>\n <div class=\"beacon-severity\" role=\"radiogroup\">\n ${this.severities.map((sev) => `\n <label class=\"beacon-severity-opt ${sev === this.state.severity ? 'selected' : ''}\" data-sev=\"${sev}\">\n <input type=\"radio\" name=\"beacon-severity\" value=\"${sev}\" ${sev === this.state.severity ? 'checked' : ''}>\n ${sev}\n </label>\n `).join('')}\n </div>\n </div>\n\n ${this.state.annotatedScreenshot ? `\n <div class=\"beacon-field\">\n <span class=\"beacon-label\">Annotated screenshot</span>\n <img src=\"${this.state.annotatedScreenshot}\" class=\"beacon-thumb\" alt=\"Annotated screenshot preview\">\n </div>\n ` : ''}\n\n ${this.state.pins.length > 0 ? `\n <div class=\"beacon-field\">\n <span class=\"beacon-label\">Pins (${this.state.pins.length})</span>\n <div class=\"beacon-pin-list\">\n ${this.state.pins.map((p) => `\n <div class=\"beacon-pin-item\" data-pin=\"${p.number}\">\n <span class=\"beacon-pin-num\">${p.number}</span>\n <div class=\"beacon-pin-meta\">\n <div class=\"beacon-pin-selector\" title=\"${escapeHtml(p.selector)}\">${escapeHtml(p.selector)}</div>\n <input type=\"text\" class=\"beacon-pin-note-input\" placeholder=\"Add a note (optional)\" value=\"${escapeHtml(p.note ?? '')}\">\n </div>\n <button type=\"button\" class=\"beacon-icon-btn\" data-pin-delete=\"${p.number}\" aria-label=\"Remove pin ${p.number}\">${ICONS.trash}</button>\n </div>\n `).join('')}\n </div>\n </div>\n ` : ''}\n\n <div class=\"beacon-actions\">\n <button type=\"button\" class=\"beacon-btn secondary\" data-action=\"annotate\" ${this.state.submitting ? 'disabled' : ''}>\n ${ICONS.pin} ${this.state.pins.length > 0 ? 'Add another pin' : 'Annotate elements'}\n </button>\n <span style=\"flex:1\"></span>\n <button type=\"button\" class=\"beacon-btn primary\" data-action=\"submit\" ${canSubmit ? '' : 'disabled'}>\n ${ICONS.send} ${this.state.submitting ? 'Sending…' : 'Send'}\n </button>\n </div>\n\n ${this.state.status ? `<div class=\"beacon-status ${this.state.statusKind}\">${escapeHtml(this.state.status)}</div>` : ''}\n `;\n\n // Wire events.\n const desc = this.bodyEl.querySelector('#beacon-desc') as HTMLTextAreaElement;\n desc.addEventListener('input', () => {\n this.state.description = desc.value;\n this.callbacks.onDescriptionChange(desc.value);\n // Re-render only the submit button's disabled state — full re-render kills focus, so skip it here.\n const submitBtn = this.bodyEl.querySelector('[data-action=\"submit\"]') as HTMLButtonElement | null;\n if (submitBtn) {\n submitBtn.disabled = !(desc.value.trim().length > 0) || this.state.submitting;\n }\n });\n\n this.bodyEl.querySelectorAll<HTMLInputElement>('input[name=\"beacon-severity\"]').forEach((input) => {\n input.addEventListener('change', () => {\n if (input.checked) {\n this.state.severity = input.value as Severity;\n this.callbacks.onSeverityChange(this.state.severity);\n this.render();\n }\n });\n });\n\n this.bodyEl.querySelector('[data-action=\"annotate\"]')?.addEventListener('click', () => this.callbacks.onAnnotate());\n this.bodyEl.querySelector('[data-action=\"submit\"]')?.addEventListener('click', () => this.callbacks.onSubmit());\n\n this.bodyEl.querySelectorAll<HTMLButtonElement>('[data-pin-delete]').forEach((btn) => {\n btn.addEventListener('click', () => {\n const num = Number(btn.getAttribute('data-pin-delete'));\n this.callbacks.onPinDelete(num);\n });\n });\n\n this.bodyEl.querySelectorAll<HTMLInputElement>('.beacon-pin-note-input').forEach((input) => {\n const item = input.closest('[data-pin]');\n const num = Number(item?.getAttribute('data-pin') ?? 0);\n input.addEventListener('input', () => this.callbacks.onPinNoteChange(num, input.value));\n });\n }\n}\n\nfunction escapeHtml(s: string): string {\n return s\n .replace(/&/g, '&amp;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&#39;');\n}\n","// Small contextual popover that opens next to a picked element so the user can\n// optionally type a note. \"Save\" attaches the note to the pin; \"Skip\" creates the\n// pin with no note.\n\nimport { ICONS } from './icons';\n\nexport interface PinPopoverResult {\n note?: string;\n cancelled: boolean;\n}\n\nexport function showPinPopover(opts: {\n shadowRoot: ShadowRoot;\n anchor: { x: number; y: number }; // viewport coords\n pinNumber: number;\n}): Promise<PinPopoverResult> {\n return new Promise((resolve) => {\n const popover = document.createElement('div');\n popover.className = 'beacon-pin-popover open';\n popover.innerHTML = `\n <div style=\"display:flex;align-items:center;gap:6px;font-weight:600;font-size:13px;\">\n <span class=\"beacon-pin-num\">${opts.pinNumber}</span>\n <span>Note for this pin</span>\n </div>\n <textarea class=\"beacon-textarea\" rows=\"2\" placeholder=\"Optional — describe what's wrong here…\" style=\"min-height:48px;\"></textarea>\n <div class=\"beacon-pin-popover-actions\">\n <button type=\"button\" class=\"beacon-btn secondary\" data-action=\"skip\">Skip</button>\n <button type=\"button\" class=\"beacon-btn primary\" data-action=\"save\">${ICONS.check} Save</button>\n </div>\n `;\n\n // Position below the picked point, clamped to viewport.\n const POPOVER_W = 240;\n const POPOVER_H = 160;\n const left = Math.min(Math.max(8, opts.anchor.x), window.innerWidth - POPOVER_W - 8);\n const top = Math.min(Math.max(8, opts.anchor.y + 12), window.innerHeight - POPOVER_H - 8);\n popover.style.left = `${left}px`;\n popover.style.top = `${top}px`;\n\n opts.shadowRoot.appendChild(popover);\n\n const textarea = popover.querySelector('textarea')!;\n textarea.focus();\n\n function close(result: PinPopoverResult) {\n popover.remove();\n resolve(result);\n }\n\n popover.addEventListener('click', (e) => {\n const target = e.target as HTMLElement;\n const action = target.closest('[data-action]')?.getAttribute('data-action');\n if (action === 'skip') close({ cancelled: false });\n if (action === 'save') {\n const note = textarea.value.trim();\n close({ ...(note ? { note } : {}), cancelled: false });\n }\n });\n\n textarea.addEventListener('keydown', (e) => {\n if (e.key === 'Enter' && (e.metaKey || e.ctrlKey)) {\n const note = textarea.value.trim();\n close({ ...(note ? { note } : {}), cancelled: false });\n }\n if (e.key === 'Escape') {\n close({ cancelled: true });\n }\n });\n });\n}\n","// Hover/click element picker. Draws an outline overlay over the hovered element\n// and resolves with the clicked element. Skips the widget's own elements via\n// composedPath check against the provided shadow root.\n\nexport interface PickerOptions {\n shadowRoot: ShadowRoot;\n onHover?: (el: Element | null) => void;\n}\n\nexport interface PickerHandle {\n cancel: () => void;\n promise: Promise<Element | null>; // resolves with picked element, or null on Escape\n}\n\nexport function startPicker(opts: PickerOptions): PickerHandle {\n const { shadowRoot, onHover } = opts;\n\n // Outline overlay — appended to body, position: fixed, pointer-events: none.\n const outline = document.createElement('div');\n outline.style.cssText = [\n 'position: fixed',\n 'pointer-events: none',\n 'z-index: 2147483646',\n 'border: 2px solid #0ea5e9',\n 'background: rgba(14, 165, 233, 0.08)',\n 'transition: all 60ms ease-out',\n 'box-sizing: border-box',\n 'border-radius: 2px',\n ].join('; ');\n document.body.appendChild(outline);\n\n const tooltip = document.createElement('div');\n tooltip.style.cssText = [\n 'position: fixed',\n 'pointer-events: none',\n 'z-index: 2147483647',\n 'background: #0f172a',\n 'color: #fff',\n 'font: 11px/1.4 ui-monospace, SFMono-Regular, Menlo, monospace',\n 'padding: 3px 6px',\n 'border-radius: 3px',\n 'max-width: 280px',\n 'overflow: hidden',\n 'text-overflow: ellipsis',\n 'white-space: nowrap',\n ].join('; ');\n document.body.appendChild(tooltip);\n\n const previousCursor = document.body.style.cursor;\n document.body.style.cursor = 'crosshair';\n\n let resolved = false;\n let resolvePromise: (v: Element | null) => void = () => {};\n const promise = new Promise<Element | null>((res) => { resolvePromise = res; });\n\n function isWidgetElement(el: EventTarget | null): boolean {\n if (!el || !(el instanceof Node)) return false;\n // composedPath gives us shadow boundaries.\n let node: Node | null = el;\n while (node) {\n if (node === shadowRoot || node === shadowRoot.host) return true;\n node = node.parentNode ?? (node as ShadowRoot).host ?? null;\n }\n return false;\n }\n\n function findTarget(x: number, y: number): Element | null {\n // Hide overlay so it doesn't appear in elementsFromPoint, then use elementsFromPoint\n // and pick the first non-widget element.\n outline.style.display = 'none';\n tooltip.style.display = 'none';\n const candidates = document.elementsFromPoint(x, y);\n outline.style.display = 'block';\n tooltip.style.display = 'block';\n for (const c of candidates) {\n if (!isWidgetElement(c)) return c;\n }\n return null;\n }\n\n function positionOutline(el: Element) {\n const rect = el.getBoundingClientRect();\n outline.style.left = `${rect.left}px`;\n outline.style.top = `${rect.top}px`;\n outline.style.width = `${rect.width}px`;\n outline.style.height = `${rect.height}px`;\n\n const tag = el.tagName.toLowerCase();\n const cls = el.classList.length > 0 ? '.' + Array.from(el.classList).slice(0, 2).join('.') : '';\n tooltip.textContent = tag + cls;\n // Place tooltip just above the element, or below if it would clip the top.\n const above = rect.top - 22;\n tooltip.style.left = `${rect.left}px`;\n tooltip.style.top = `${above >= 0 ? above : rect.bottom + 4}px`;\n }\n\n function handleMove(e: MouseEvent) {\n const el = findTarget(e.clientX, e.clientY);\n if (el) {\n positionOutline(el);\n onHover?.(el);\n } else {\n outline.style.display = 'none';\n tooltip.style.display = 'none';\n onHover?.(null);\n }\n }\n\n function handleClick(e: MouseEvent) {\n e.preventDefault();\n e.stopPropagation();\n const el = findTarget(e.clientX, e.clientY);\n if (el) finish(el);\n }\n\n function handleKey(e: KeyboardEvent) {\n if (e.key === 'Escape') {\n e.preventDefault();\n finish(null);\n }\n }\n\n function finish(el: Element | null) {\n if (resolved) return;\n resolved = true;\n document.removeEventListener('mousemove', handleMove, true);\n document.removeEventListener('click', handleClick, true);\n document.removeEventListener('keydown', handleKey, true);\n outline.remove();\n tooltip.remove();\n document.body.style.cursor = previousCursor;\n resolvePromise(el);\n }\n\n document.addEventListener('mousemove', handleMove, true);\n document.addEventListener('click', handleClick, true);\n document.addEventListener('keydown', handleKey, true);\n\n return {\n cancel: () => finish(null),\n promise,\n };\n}\n","// Build a unique-ish CSS selector path for an element by walking up the parent chain.\n// Strategy per ancestor: id (if unique) → tag.classes (if unique among siblings) → tag:nth-of-type(n).\n// Stops at <body> or after a depth limit.\n\nconst MAX_DEPTH = 8;\n\nfunction isUniqueId(id: string, root: Document | ShadowRoot = document): boolean {\n if (!id) return false;\n try {\n return root.querySelectorAll(`#${CSS.escape(id)}`).length === 1;\n } catch {\n return false;\n }\n}\n\nfunction tagWithClasses(el: Element): string {\n const tag = el.tagName.toLowerCase();\n const classes = Array.from(el.classList)\n // Drop classes that look like generated atomic / hashed names (heuristic — keep stable-looking ones).\n .filter((c) => c.length > 0 && c.length < 40)\n .slice(0, 3)\n .map((c) => `.${CSS.escape(c)}`)\n .join('');\n return tag + classes;\n}\n\nfunction nthOfTypeIndex(el: Element): number {\n const parent = el.parentElement;\n if (!parent) return 1;\n const sameTag = Array.from(parent.children).filter((c) => c.tagName === el.tagName);\n return sameTag.indexOf(el) + 1;\n}\n\nexport function buildSelector(target: Element): string {\n if (!target || target.nodeType !== Node.ELEMENT_NODE) return '';\n\n // Fast path: unique id on the target itself.\n if (target.id && isUniqueId(target.id)) {\n return `#${CSS.escape(target.id)}`;\n }\n\n const parts: string[] = [];\n let el: Element | null = target;\n let depth = 0;\n\n while (el && el.tagName.toLowerCase() !== 'body' && depth < MAX_DEPTH) {\n const current: Element = el;\n\n if (current.id && isUniqueId(current.id)) {\n parts.unshift(`#${CSS.escape(current.id)}`);\n break;\n }\n\n const base = tagWithClasses(current);\n const parent: HTMLElement | null = current.parentElement;\n\n // If this base matches multiple siblings, disambiguate with :nth-of-type.\n let part = base;\n if (parent) {\n try {\n const currentClasses = Array.from(current.classList).join(' ');\n const siblings: Element[] = Array.from(parent.children).filter(\n (c: Element) => c.tagName === current.tagName && Array.from(c.classList).join(' ') === currentClasses,\n );\n if (siblings.length > 1) {\n part = `${current.tagName.toLowerCase()}:nth-of-type(${nthOfTypeIndex(current)})`;\n }\n } catch {\n // ignore — fall back to base\n }\n }\n\n parts.unshift(part);\n el = parent;\n depth++;\n }\n\n return parts.join(' > ');\n}\n","// Best-effort framework component name detection.\n// Production builds usually minify component names — return null quietly when unavailable.\n\nimport type { Pin } from '../types';\n\ntype FW = NonNullable<Pin['framework']>;\n\nfunction detectReact(el: Element): FW | null {\n // React stores fiber refs on properties like __reactFiber$<hash> / __reactInternalInstance$<hash>.\n const keys = Object.keys(el).filter((k) => k.startsWith('__reactFiber$') || k.startsWith('__reactInternalInstance$'));\n if (keys.length === 0) return null;\n\n let fiber: unknown = (el as unknown as Record<string, unknown>)[keys[0]!];\n // Walk up the fiber chain to find the nearest function/class component (skip host elements).\n for (let i = 0; i < 10 && fiber; i++) {\n const f = fiber as { type?: unknown; return?: unknown };\n const type = f.type;\n if (typeof type === 'function') {\n const name = (type as { displayName?: string; name?: string }).displayName ?? (type as { name?: string }).name;\n if (name && name !== '_default') return { lib: 'react', name };\n }\n if (typeof type === 'object' && type !== null) {\n const name = (type as { displayName?: string; name?: string }).displayName ?? (type as { name?: string }).name;\n if (name) return { lib: 'react', name };\n }\n fiber = f.return;\n }\n return { lib: 'react' };\n}\n\nfunction detectVue(el: Element): FW | null {\n const anyEl = el as unknown as Record<string, unknown>;\n const vueParent = anyEl.__vueParentComponent as { type?: { name?: string; __name?: string } } | undefined;\n if (vueParent) {\n const name = vueParent.type?.name ?? vueParent.type?.__name;\n return { lib: 'vue', ...(name ? { name } : {}) };\n }\n if (anyEl.__vue__) return { lib: 'vue' };\n return null;\n}\n\nfunction detectAngular(el: Element): FW | null {\n // Angular dev mode exposes window.ng.getComponent(el).\n const ng = (window as unknown as { ng?: { getComponent?: (el: Element) => unknown } }).ng;\n if (!ng?.getComponent) return null;\n try {\n const cmp = ng.getComponent(el);\n if (!cmp) return null;\n const ctor = (cmp as { constructor?: { name?: string } }).constructor;\n return { lib: 'angular', ...(ctor?.name ? { name: ctor.name } : {}) };\n } catch {\n return null;\n }\n}\n\nfunction detectSvelte(el: Element): FW | null {\n // Svelte exposes very little at runtime. Look for $$ properties on the host.\n const anyEl = el as unknown as Record<string, unknown>;\n if ('__svelte_meta' in anyEl) return { lib: 'svelte' };\n return null;\n}\n\nexport function detectFramework(el: Element): Pin['framework'] | undefined {\n const result = detectReact(el) ?? detectVue(el) ?? detectAngular(el) ?? detectSvelte(el);\n return result ?? undefined;\n}\n","// Capture per-pin element data: outerHTML (truncated), selector, computed styles, bounding rect, framework hint.\n\nimport type { RawPinCapture } from '../types';\nimport { buildSelector } from './selector';\nimport { detectFramework } from './framework';\n\nconst OUTER_HTML_LIMIT = 5000;\nconst PARENT_OUTER_HTML_LIMIT = 1000;\n\n// A focused, useful subset of computed style properties. Dumping all 400+ resolved\n// properties is noise; this list covers layout, typography, color, and key visual hints.\nconst USEFUL_STYLE_PROPS = [\n 'display', 'position', 'top', 'right', 'bottom', 'left',\n 'width', 'height', 'min-width', 'min-height', 'max-width', 'max-height',\n 'margin', 'padding',\n 'font-family', 'font-size', 'font-weight', 'line-height', 'text-align',\n 'color', 'background-color', 'background-image',\n 'border', 'border-radius',\n 'opacity', 'visibility', 'overflow',\n 'z-index', 'transform', 'transition',\n 'flex', 'flex-direction', 'justify-content', 'align-items', 'gap',\n 'grid-template-columns', 'grid-template-rows',\n] as const;\n\nfunction truncate(s: string, max: number): string {\n if (s.length <= max) return s;\n return s.slice(0, max) + `\\n\\n/* … truncated, original was ${s.length} chars */`;\n}\n\nfunction pickStyles(el: Element): Record<string, string> {\n const computed = getComputedStyle(el);\n const out: Record<string, string> = {};\n for (const prop of USEFUL_STYLE_PROPS) {\n const value = computed.getPropertyValue(prop);\n if (value && value !== 'normal' && value !== 'none' && value !== 'auto' && value !== '0px') {\n out[prop] = value.trim();\n }\n }\n return out;\n}\n\nexport function capturePin(el: Element): RawPinCapture {\n const rect = el.getBoundingClientRect();\n return {\n selector: buildSelector(el),\n tagName: el.tagName.toLowerCase(),\n id: el.id || null,\n classList: Array.from(el.classList),\n outerHTML: truncate(el.outerHTML, OUTER_HTML_LIMIT),\n ...(el.parentElement\n ? { parentOuterHTML: truncate(el.parentElement.outerHTML, PARENT_OUTER_HTML_LIMIT) }\n : {}),\n computedStyles: pickStyles(el),\n boundingRect: {\n x: Math.round(rect.x),\n y: Math.round(rect.y),\n w: Math.round(rect.width),\n h: Math.round(rect.height),\n },\n ...(detectFramework(el) ? { framework: detectFramework(el)! } : {}),\n };\n}\n","// Capture browser / viewport / locale metadata. Pure read-only — no instrumentation.\n\nimport type { Metadata } from '../types';\n\ninterface UADataLike {\n brands: Array<{ brand: string; version: string }>;\n mobile: boolean;\n platform: string;\n}\n\nfunction getUaData(): Metadata['uaData'] {\n const nav = navigator as Navigator & { userAgentData?: UADataLike };\n if (!nav.userAgentData) return undefined;\n // Pick the first non-\"Not.A/Brand\" brand for legibility.\n const brand = nav.userAgentData.brands.find((b) => !/Not[.\\-]?A.?Brand/i.test(b.brand))?.brand\n ?? nav.userAgentData.brands[0]?.brand\n ?? 'unknown';\n return {\n brand,\n mobile: nav.userAgentData.mobile,\n platform: nav.userAgentData.platform,\n };\n}\n\nfunction getTheme(): Metadata['theme'] {\n if (window.matchMedia('(prefers-color-scheme: dark)').matches) return 'dark';\n if (window.matchMedia('(prefers-color-scheme: light)').matches) return 'light';\n return undefined;\n}\n\nexport function captureMetadata(): Metadata {\n return {\n url: window.location.href,\n ...(document.referrer ? { referrer: document.referrer } : {}),\n userAgent: navigator.userAgent,\n ...(getUaData() ? { uaData: getUaData()! } : {}),\n viewport: {\n w: window.innerWidth,\n h: window.innerHeight,\n dpr: window.devicePixelRatio || 1,\n },\n screen: {\n w: window.screen.width,\n h: window.screen.height,\n },\n timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n locale: navigator.language,\n ...(getTheme() ? { theme: getTheme()! } : {}),\n capturedAt: new Date().toISOString(),\n };\n}\n","// Lazy-loaded screenshot capture via html-to-image.\n// Captures the viewport (document.documentElement) as a JPEG data URL.\n\nlet htmlToImage: typeof import('html-to-image') | null = null;\n\nasync function load() {\n if (!htmlToImage) {\n htmlToImage = await import('html-to-image');\n }\n return htmlToImage;\n}\n\nexport interface ScreenshotOptions {\n quality?: number; // 0..1, default 0.7\n pixelRatio?: number; // default min(devicePixelRatio, 2) — capping to keep file size sane\n excludeShadowRoot?: ShadowRoot; // skip our own widget elements\n}\n\nexport async function captureScreenshot(opts: ScreenshotOptions = {}): Promise<string> {\n const { quality = 0.7, pixelRatio = Math.min(window.devicePixelRatio || 1, 2), excludeShadowRoot } = opts;\n const lib = await load();\n\n const filter = excludeShadowRoot\n ? (node: Node) => {\n // Skip the widget's host element.\n let cur: Node | null = node;\n while (cur) {\n if (cur === excludeShadowRoot.host) return false;\n cur = cur.parentNode;\n }\n return true;\n }\n : undefined;\n\n return lib.toJpeg(document.documentElement, {\n quality,\n pixelRatio,\n cacheBust: true,\n ...(filter ? { filter } : {}),\n // Cap dimensions to viewport so we don't accidentally capture full document height.\n width: window.innerWidth,\n height: window.innerHeight,\n style: {\n // Avoid scrolling artifacts.\n transform: 'none',\n },\n });\n}\n","// Draw numbered pin markers onto a screenshot. Takes the viewport screenshot data URL\n// and a list of pins (with bounding rects in viewport coords) and returns a new data URL\n// with circular numbered badges overlaid at each pin's position.\n\nimport type { Pin } from '../types';\n\nconst MARKER_RADIUS = 14;\nconst MARKER_FILL = '#0ea5e9';\nconst MARKER_STROKE = '#ffffff';\nconst MARKER_TEXT = '#ffffff';\n\nexport async function drawMarkers(\n screenshotDataUrl: string,\n pins: Pin[],\n viewportSize: { w: number; h: number; dpr: number },\n): Promise<string> {\n const img = await loadImage(screenshotDataUrl);\n\n const canvas = document.createElement('canvas');\n canvas.width = img.naturalWidth;\n canvas.height = img.naturalHeight;\n const ctx = canvas.getContext('2d');\n if (!ctx) throw new Error('Could not get 2D canvas context');\n\n ctx.drawImage(img, 0, 0);\n\n // Map viewport coords → screenshot pixel coords using the ratio between image size\n // and the captured viewport dimensions.\n const scaleX = canvas.width / viewportSize.w;\n const scaleY = canvas.height / viewportSize.h;\n\n for (const pin of pins) {\n // Anchor the marker at the top-left of the element's rect, with a small inset.\n const cx = (pin.boundingRect.x + 8) * scaleX;\n const cy = (pin.boundingRect.y + 8) * scaleY;\n\n // Filled circle.\n ctx.beginPath();\n ctx.fillStyle = MARKER_FILL;\n ctx.arc(cx, cy, MARKER_RADIUS, 0, Math.PI * 2);\n ctx.fill();\n\n // White outer stroke for contrast.\n ctx.lineWidth = 3;\n ctx.strokeStyle = MARKER_STROKE;\n ctx.stroke();\n\n // Number text.\n ctx.fillStyle = MARKER_TEXT;\n ctx.font = 'bold 16px system-ui, -apple-system, sans-serif';\n ctx.textAlign = 'center';\n ctx.textBaseline = 'middle';\n ctx.fillText(String(pin.number), cx, cy + 1);\n }\n\n return canvas.toDataURL('image/jpeg', 0.85);\n}\n\nfunction loadImage(src: string): Promise<HTMLImageElement> {\n return new Promise((resolve, reject) => {\n const img = new Image();\n img.onload = () => resolve(img);\n img.onerror = (err) => reject(err);\n img.src = src;\n });\n}\n","// POST the feedback payload to the configured endpoint.\n\nimport type { FeedbackPayload, SubmitResponse } from '../types';\n\nexport async function submitFeedback(\n endpoint: string,\n payload: FeedbackPayload,\n headers?: Record<string, string>,\n): Promise<SubmitResponse> {\n const res = await fetch(endpoint, {\n method: 'POST',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/json',\n ...(headers ?? {}),\n },\n body: JSON.stringify(payload),\n });\n\n let body: unknown = null;\n const contentType = res.headers.get('Content-Type') ?? '';\n if (contentType.includes('application/json')) {\n try {\n body = await res.json();\n } catch {\n body = null;\n }\n } else {\n try {\n body = await res.text();\n } catch {\n body = null;\n }\n }\n\n return {\n ok: res.ok,\n status: res.status,\n body,\n };\n}\n","// <launchkit-beacon> custom element. Orchestrates the capture pipeline + UI.\n\nimport stylesCss from './styles.css?inline';\n\nimport type { BeaconConfig, FeedbackPayload, Pin, RawPinCapture, Severity } from './types';\nimport { createTriggerButton } from './ui/button';\nimport { DrawerView } from './ui/drawer';\nimport { showPinPopover } from './ui/pin-popover';\nimport { startPicker } from './capture/picker';\nimport { capturePin } from './capture/element';\nimport { captureMetadata } from './capture/metadata';\nimport { captureScreenshot } from './capture/screenshot';\nimport { drawMarkers } from './capture/overlay';\nimport { submitFeedback } from './transport/submit';\n\nconst ATTRS = ['endpoint', 'position', 'theme', 'severities'] as const;\n\nexport class LaunchkitBeacon extends HTMLElement {\n static get observedAttributes() { return ATTRS as unknown as string[]; }\n\n private shadow!: ShadowRoot;\n private trigger?: HTMLElement;\n private drawer?: DrawerView;\n private slotEl?: HTMLSlotElement;\n\n private _config: BeaconConfig | null = null;\n private pins: Pin[] = [];\n private description = '';\n private severity: Severity = 'bug';\n\n /** Public — wrappers can set `widget.config = {...}` for dynamic endpoint/headers/context. */\n set config(value: BeaconConfig) {\n this._config = value;\n }\n get config(): BeaconConfig | null {\n if (this._config) return this._config;\n const endpoint = this.getAttribute('endpoint');\n return endpoint ? { endpoint } : null;\n }\n\n connectedCallback() {\n if (!this.shadow) {\n this.shadow = this.attachShadow({ mode: 'open' });\n const style = document.createElement('style');\n style.textContent = stylesCss;\n this.shadow.appendChild(style);\n\n // Slot for custom trigger override.\n this.slotEl = document.createElement('slot');\n this.slotEl.name = 'trigger';\n this.shadow.appendChild(this.slotEl);\n\n // Default trigger (shown unless slot is filled or position=\"hidden\").\n this.trigger = createTriggerButton();\n this.shadow.appendChild(this.trigger);\n this.trigger.addEventListener('click', () => this.open());\n\n // If consumer provided a slot=\"trigger\" child, hook clicks on it.\n this.slotEl.addEventListener('slotchange', () => {\n const assigned = this.slotEl!.assignedElements();\n if (assigned.length > 0) {\n // Hide the default; wire all assigned elements to open the drawer.\n if (this.trigger) (this.trigger as HTMLElement).style.display = 'none';\n assigned.forEach((el) => el.addEventListener('click', () => this.open()));\n }\n });\n\n this.drawer = new DrawerView(this.parseSeverities(), {\n onClose: () => this.close(),\n onAnnotate: () => this.startAnnotate(),\n onSubmit: () => this.handleSubmit(),\n onPinNoteChange: (n, note) => this.updatePinNote(n, note),\n onPinDelete: (n) => this.deletePin(n),\n onDescriptionChange: (v) => { this.description = v; },\n onSeverityChange: (s) => { this.severity = s; },\n });\n this.shadow.appendChild(this.drawer.root);\n }\n\n // Default attributes if not set.\n if (!this.hasAttribute('position')) this.setAttribute('position', 'bottom-right');\n if (!this.hasAttribute('theme')) this.setAttribute('theme', 'auto');\n }\n\n attributeChangedCallback(name: string, _oldValue: string | null, _newValue: string | null) {\n if (name === 'severities' && this.drawer) {\n // Re-create drawer with new severities. Keep current state.\n // Cheapest path: instruct drawer to refresh — but our drawer captures severities at construction.\n // Acceptable simplification: log a warning if attribute changes mid-life.\n // Production wrappers should set severities at construction via initial attribute.\n console.warn('[launchkit-beacon] severities attribute changed after mount; not yet hot-reloaded.');\n }\n }\n\n // ── Public API ──────────────────────────────────────────\n\n open() {\n if (!this.drawer) return;\n // Edge-aware positioning when consumer is using a slotted trigger\n // (typical pattern when position=\"hidden\" — e.g., the trigger lives in a header).\n // Otherwise fall back to CSS-driven default position (bottom-right / bottom-left).\n if (this.getAttribute('position') === 'hidden') {\n const triggerEl = this.slotEl?.assignedElements()[0] as HTMLElement | undefined;\n if (triggerEl) {\n positionDrawerRelativeTo(this.drawer.root, triggerEl);\n }\n }\n this.drawer.open();\n }\n\n close() {\n this.drawer?.close();\n }\n\n async openWithPicker() {\n this.open();\n // Defer to next tick so the drawer is in DOM before we minimize it.\n setTimeout(() => this.startAnnotate(), 0);\n }\n\n // ── Annotate flow ──────────────────────────────────────────\n\n private async startAnnotate() {\n if (!this.drawer) return;\n this.drawer.minimize();\n\n let next = true;\n while (next) {\n const handle = startPicker({ shadowRoot: this.shadow });\n const el = await handle.promise;\n if (!el) break; // user pressed Escape\n\n const rect = el.getBoundingClientRect();\n const popoverResult = await showPinPopover({\n shadowRoot: this.shadow,\n anchor: { x: rect.left, y: rect.bottom },\n pinNumber: this.pins.length + 1,\n });\n if (popoverResult.cancelled) break;\n\n const raw = capturePin(el);\n const pin: Pin = {\n number: this.pins.length + 1,\n ...raw,\n ...(popoverResult.note ? { note: popoverResult.note } : {}),\n };\n this.pins.push(pin);\n\n // Ask the user if they want to pick another. Simple: confirm dialog\n // would be jarring; default behavior is \"user closes by pressing Escape\".\n // We loop and re-enter pick mode immediately. The user pressing Escape\n // (handled by picker.promise resolving null) ends the loop.\n // No prompt needed.\n }\n\n // Capture final screenshot + draw markers + reopen drawer with preview.\n if (this.pins.length > 0) {\n try {\n const meta = captureMetadata();\n const raw = await captureScreenshot({ excludeShadowRoot: this.shadow });\n const annotated = await drawMarkers(raw, this.pins, meta.viewport);\n this.drawer.setPins(this.pins, annotated);\n } catch (err) {\n // Screenshot failure shouldn't block submit — pins still post without image.\n console.warn('[launchkit-beacon] screenshot capture failed:', err);\n this.drawer.setPins(this.pins);\n }\n }\n\n this.drawer.open();\n }\n\n private updatePinNote(num: number, note: string) {\n const pin = this.pins.find((p) => p.number === num);\n if (!pin) return;\n if (note.trim()) {\n pin.note = note;\n } else {\n delete pin.note;\n }\n // Don't re-render — the input is already up to date; rerender would lose focus.\n }\n\n private deletePin(num: number) {\n this.pins = this.pins.filter((p) => p.number !== num);\n // Renumber.\n this.pins.forEach((p, i) => { p.number = i + 1; });\n this.drawer?.setPins(this.pins, undefined);\n }\n\n // ── Submit flow ──────────────────────────────────────────\n\n private async handleSubmit() {\n if (!this.drawer) return;\n const cfg = this.config;\n if (!cfg?.endpoint) {\n this.drawer.setStatus('Missing endpoint configuration', 'error');\n return;\n }\n\n const description = this.drawer.getDescription().trim();\n const severity = this.drawer.getSeverity();\n if (!description) {\n this.drawer.setStatus('Description is required', 'error');\n return;\n }\n\n const meta = captureMetadata();\n\n // If we have pins but no annotated screenshot yet (e.g., user submitted before annotate finished),\n // try to grab a fresh screenshot now.\n let screenshotDataUrl: string | undefined;\n if (this.pins.length > 0) {\n try {\n const raw = await captureScreenshot({ excludeShadowRoot: this.shadow });\n screenshotDataUrl = await drawMarkers(raw, this.pins, meta.viewport);\n } catch {\n // No screenshot is fine.\n }\n }\n\n const payload: FeedbackPayload = {\n description,\n severity,\n ...(screenshotDataUrl ? { screenshot: { dataUrl: screenshotDataUrl, mime: 'image/jpeg' } } : {}),\n metadata: meta,\n pins: this.pins,\n ...(this.resolveContext() ? { context: this.resolveContext() } : {}),\n };\n\n // Pre-submit hook (cancellable).\n const beforeEvent = new CustomEvent('beacon-before-submit', {\n detail: { payload },\n cancelable: true,\n bubbles: true,\n composed: true,\n });\n const proceed = this.dispatchEvent(beforeEvent);\n if (!proceed) {\n this.drawer.setStatus('Submission cancelled', 'error');\n return;\n }\n\n this.drawer.setSubmitting(true);\n this.drawer.setStatus('Sending…');\n\n try {\n const headers = this.resolveHeaders();\n const response = await submitFeedback(cfg.endpoint, payload, headers);\n this.drawer.setSubmitting(false);\n\n if (response.ok) {\n this.drawer.setStatus('Sent — thanks!', 'success');\n this.dispatchEvent(new CustomEvent('beacon-after-submit', {\n detail: { response },\n bubbles: true,\n composed: true,\n }));\n // Reset state and close after a moment.\n setTimeout(() => {\n this.pins = [];\n this.description = '';\n this.severity = 'bug';\n this.drawer!.reset();\n this.drawer!.close();\n }, 1500);\n } else {\n this.drawer.setStatus(`Failed: ${response.status}`, 'error');\n }\n } catch (err) {\n this.drawer.setSubmitting(false);\n const msg = err instanceof Error ? err.message : 'Network error';\n this.drawer.setStatus(`Failed: ${msg}`, 'error');\n }\n }\n\n // ── Helpers ──────────────────────────────────────────\n\n private resolveHeaders(): Record<string, string> | undefined {\n const h = this.config?.headers;\n if (!h) return undefined;\n return typeof h === 'function' ? h() : h;\n }\n\n private resolveContext(): Record<string, unknown> | undefined {\n const c = this.config?.context;\n if (!c) return undefined;\n return typeof c === 'function' ? c() : c;\n }\n\n private parseSeverities(): Severity[] {\n const attr = this.getAttribute('severities');\n if (!attr) return ['bug', 'idea', 'ux', 'a11y'];\n return attr.split(',').map((s) => s.trim()).filter(Boolean) as Severity[];\n }\n}\n\nexport function defineBeacon(tagName = 'launchkit-beacon'): void {\n if (typeof window === 'undefined') return;\n if (!customElements.get(tagName)) {\n customElements.define(tagName, LaunchkitBeacon);\n }\n}\n\n// ── Helpers ──────────────────────────────────────────\n\nconst DRAWER_WIDTH = 380;\nconst VIEWPORT_MARGIN = 8;\nconst ESTIMATED_DRAWER_HEIGHT = 520;\n\n/**\n * Position the drawer relative to a trigger element, edge-aware.\n *\n * Default placement: directly below the trigger, with the drawer's right edge\n * aligned to the trigger's right edge. Falls back to opening above the trigger\n * if there isn't enough space below. Always clamps within the viewport so the\n * drawer never overflows off-screen.\n */\nfunction positionDrawerRelativeTo(drawer: HTMLElement, trigger: HTMLElement): void {\n const rect = trigger.getBoundingClientRect();\n const viewportW = window.innerWidth;\n const viewportH = window.innerHeight;\n\n // ── Horizontal: align drawer's right edge to trigger's right edge ─────────\n // Compute desired right offset; clamp so drawer never overflows past either edge.\n let rightOffset = Math.max(VIEWPORT_MARGIN, viewportW - rect.right);\n // If aligning right would push the drawer's left edge past the viewport, shift it.\n const leftEdgeIfApplied = viewportW - rightOffset - DRAWER_WIDTH;\n if (leftEdgeIfApplied < VIEWPORT_MARGIN) {\n rightOffset = Math.max(VIEWPORT_MARGIN, viewportW - DRAWER_WIDTH - VIEWPORT_MARGIN);\n }\n\n // ── Vertical: prefer below trigger, fall back to above ────────────────────\n const spaceBelow = viewportH - rect.bottom - VIEWPORT_MARGIN;\n const spaceAbove = rect.top - VIEWPORT_MARGIN;\n\n // Set ALL four anchors explicitly. Use 'auto' (not '') to override CSS defaults\n // (the drawer's CSS has `bottom: 20px` for the floating-trigger case — empty\n // string falls back to that; 'auto' is the only way to truly clear it).\n drawer.style.left = 'auto';\n drawer.style.right = `${rightOffset}px`;\n\n if (spaceBelow >= ESTIMATED_DRAWER_HEIGHT || spaceBelow >= spaceAbove) {\n drawer.style.top = `${rect.bottom + VIEWPORT_MARGIN}px`;\n drawer.style.bottom = 'auto';\n } else {\n drawer.style.top = 'auto';\n drawer.style.bottom = `${viewportH - rect.top + VIEWPORT_MARGIN}px`;\n }\n}\n","// Entry point for @launchsecure/launch-beacon.\n// Importing this module auto-registers the <launchkit-beacon> custom element.\n\nimport { defineBeacon, LaunchkitBeacon } from './element';\n\nexport { LaunchkitBeacon, defineBeacon };\nexport type {\n BeaconConfig,\n FeedbackPayload,\n Pin,\n Metadata,\n Severity,\n HeaderProvider,\n ContextProvider,\n SubmitResponse,\n} from './types';\n\n// Auto-register on import. Consumers who want to control the tag name can call\n// defineBeacon('my-tag') themselves before any <launchkit-beacon> elements are parsed.\ndefineBeacon();\n"],"names":["ICONS","createTriggerButton","label","btn","DEFAULT_SEVERITIES","DrawerView","severities","callbacks","pins","annotatedScreenshot","submitting","status","kind","canSubmit","escapeHtml","sev","p","desc","submitBtn","input","_a","_b","num","item","s","showPinPopover","opts","resolve","popover","POPOVER_W","POPOVER_H","left","top","textarea","close","result","e","action","note","startPicker","shadowRoot","onHover","outline","tooltip","previousCursor","resolved","resolvePromise","promise","res","isWidgetElement","el","node","findTarget","x","y","candidates","c","positionOutline","rect","tag","cls","above","handleMove","handleClick","handleKey","finish","MAX_DEPTH","isUniqueId","id","root","tagWithClasses","classes","nthOfTypeIndex","parent","buildSelector","target","parts","depth","current","base","part","currentClasses","detectReact","keys","k","fiber","i","f","type","name","detectVue","anyEl","vueParent","detectAngular","ng","cmp","ctor","detectSvelte","detectFramework","OUTER_HTML_LIMIT","PARENT_OUTER_HTML_LIMIT","USEFUL_STYLE_PROPS","truncate","max","pickStyles","computed","out","prop","value","capturePin","getUaData","nav","b","getTheme","captureMetadata","htmlToImage","load","captureScreenshot","quality","pixelRatio","excludeShadowRoot","lib","filter","cur","MARKER_RADIUS","MARKER_FILL","MARKER_STROKE","MARKER_TEXT","drawMarkers","screenshotDataUrl","viewportSize","img","loadImage","canvas","ctx","scaleX","scaleY","pin","cx","cy","src","reject","err","submitFeedback","endpoint","payload","headers","body","ATTRS","LaunchkitBeacon","style","stylesCss","assigned","n","v","_oldValue","_newValue","triggerEl","positionDrawerRelativeTo","next","popoverResult","raw","meta","annotated","cfg","description","severity","beforeEvent","response","msg","h","attr","defineBeacon","tagName","DRAWER_WIDTH","VIEWPORT_MARGIN","ESTIMATED_DRAWER_HEIGHT","drawer","trigger","viewportW","viewportH","rightOffset","spaceBelow","spaceAbove"],"mappings":"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"}
@@ -0,0 +1,75 @@
1
+ (function(y,E){typeof exports=="object"&&typeof module<"u"?E(exports):typeof define=="function"&&define.amd?define(["exports"],E):(y=typeof globalThis<"u"?globalThis:y||self,E(y.LaunchkitBeacon={}))})(this,function(y){"use strict";const E=':host{--beacon-accent: #0ea5e9;--beacon-bg: #ffffff;--beacon-fg: #0f172a;--beacon-muted: #64748b;--beacon-border: #e2e8f0;--beacon-radius: 10px;--beacon-z-index: 2147483645;--beacon-shadow: 0 10px 30px rgba(0, 0, 0, .15), 0 2px 6px rgba(0, 0, 0, .08);--beacon-bug: #ef4444;--beacon-idea: #22c55e;--beacon-ux: #a855f7;--beacon-a11y: #06b6d4;position:fixed;z-index:var(--beacon-z-index);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color:var(--beacon-fg);line-height:1.5}:host([theme="dark"]){--beacon-bg: #0f172a;--beacon-fg: #f1f5f9;--beacon-muted: #94a3b8;--beacon-border: #334155}@media (prefers-color-scheme: dark){:host([theme="auto"]){--beacon-bg: #0f172a;--beacon-fg: #f1f5f9;--beacon-muted: #94a3b8;--beacon-border: #334155}}:host([position="bottom-right"]){right:20px;bottom:20px;left:auto;top:auto}:host([position="bottom-left"]){left:20px;bottom:20px;right:auto;top:auto}:host([position="hidden"]){position:static;display:contents}:host([position="hidden"]) .beacon-default-trigger{display:none}.beacon-default-trigger{display:inline-flex;align-items:center;gap:6px;background:var(--beacon-accent);color:#fff;border:0;border-radius:999px;padding:10px 16px;font:inherit;font-weight:500;cursor:pointer;box-shadow:var(--beacon-shadow);transition:transform .15s ease,box-shadow .15s ease}.beacon-default-trigger:hover{transform:translateY(-1px);box-shadow:0 14px 36px #0003}.beacon-default-trigger svg{width:18px;height:18px}.beacon-drawer{position:fixed;right:20px;bottom:20px;width:380px;max-width:calc(100vw - 24px);max-height:calc(100vh - 24px);background:var(--beacon-bg);color:var(--beacon-fg);border:1px solid var(--beacon-border);border-radius:var(--beacon-radius);box-shadow:var(--beacon-shadow);display:none;flex-direction:column;overflow:hidden;z-index:var(--beacon-z-index)}:host([position="bottom-left"]) .beacon-drawer{left:20px;right:auto}.beacon-drawer.open{display:flex}.beacon-drawer.minimized{display:none}.beacon-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--beacon-border)}.beacon-drawer-title{font-weight:600}.beacon-icon-btn{background:transparent;border:0;color:var(--beacon-muted);cursor:pointer;padding:4px;border-radius:4px;display:inline-flex}.beacon-icon-btn:hover{background:var(--beacon-border);color:var(--beacon-fg)}.beacon-icon-btn svg{width:16px;height:16px}.beacon-drawer-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.beacon-field{display:flex;flex-direction:column;gap:6px}.beacon-label{font-size:12px;color:var(--beacon-muted);font-weight:500}.beacon-textarea{width:100%;min-height:80px;padding:8px 10px;background:var(--beacon-bg);color:var(--beacon-fg);border:1px solid var(--beacon-border);border-radius:6px;font:inherit;resize:vertical;box-sizing:border-box}.beacon-textarea:focus{outline:2px solid var(--beacon-accent);outline-offset:-1px;border-color:var(--beacon-accent)}.beacon-severity{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.beacon-severity-opt{position:relative;display:flex;align-items:center;justify-content:center;padding:6px 4px;background:transparent;border:1px solid var(--beacon-border);border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;color:var(--beacon-fg);text-transform:capitalize}.beacon-severity-opt input{position:absolute;opacity:0;pointer-events:none}.beacon-severity-opt:hover{background:var(--beacon-border)}.beacon-severity-opt.selected[data-sev=bug]{border-color:var(--beacon-bug);color:var(--beacon-bug)}.beacon-severity-opt.selected[data-sev=idea]{border-color:var(--beacon-idea);color:var(--beacon-idea)}.beacon-severity-opt.selected[data-sev=ux]{border-color:var(--beacon-ux);color:var(--beacon-ux)}.beacon-severity-opt.selected[data-sev=a11y]{border-color:var(--beacon-a11y);color:var(--beacon-a11y)}.beacon-actions{display:flex;gap:8px;align-items:center}.beacon-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;border:0;cursor:pointer;font:inherit;font-weight:500;font-size:13px;transition:opacity .15s ease}.beacon-btn[disabled]{opacity:.5;cursor:not-allowed}.beacon-btn svg{width:14px;height:14px}.beacon-btn.primary{background:var(--beacon-accent);color:#fff}.beacon-btn.secondary{background:transparent;color:var(--beacon-fg);border:1px solid var(--beacon-border)}.beacon-btn.secondary:hover{background:var(--beacon-border)}.beacon-pin-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.beacon-pin-item{display:flex;align-items:flex-start;gap:8px;padding:8px;background:var(--beacon-border);border-radius:6px}.beacon-pin-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--beacon-accent);color:#fff;font-size:11px;font-weight:600;flex-shrink:0}.beacon-pin-meta{flex:1;min-width:0}.beacon-pin-selector{font:11px/1.4 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--beacon-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.beacon-pin-note{margin-top:4px;font-size:12px;color:var(--beacon-fg)}.beacon-pin-note-input{margin-top:4px;width:100%;padding:4px 6px;background:var(--beacon-bg);color:var(--beacon-fg);border:1px solid var(--beacon-border);border-radius:4px;font:inherit;font-size:12px;box-sizing:border-box}.beacon-thumb{width:100%;border:1px solid var(--beacon-border);border-radius:6px;display:block}.beacon-status{font-size:12px;color:var(--beacon-muted);text-align:center;padding:4px}.beacon-status.error{color:var(--beacon-bug)}.beacon-status.success{color:var(--beacon-idea)}.beacon-pin-popover{position:fixed;z-index:2147483647;width:240px;background:var(--beacon-bg);color:var(--beacon-fg);border:1px solid var(--beacon-border);border-radius:6px;box-shadow:var(--beacon-shadow);padding:10px;display:none;flex-direction:column;gap:8px}.beacon-pin-popover.open{display:flex}.beacon-pin-popover-actions{display:flex;gap:6px;justify-content:flex-end}',x={feedback:'<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"/></svg>',pin:'<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M12 17v5"/><path d="M9 10.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24V16a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-.76a2 2 0 0 0-1.11-1.79l-1.78-.9A2 2 0 0 1 15 10.76V7a1 1 0 0 1 1-1 2 2 0 0 0 0-4H8a2 2 0 0 0 0 4 1 1 0 0 1 1 1z"/></svg>',close:'<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M18 6 6 18"/><path d="m6 6 12 12"/></svg>',trash:'<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M3 6h18"/><path d="M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6"/><path d="M8 6V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"/></svg>',send:'<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="m22 2-7 20-4-9-9-4Z"/><path d="M22 2 11 13"/></svg>',check:'<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><polyline points="20 6 9 17 4 12"/></svg>'};function be(e="Feedback"){const t=document.createElement("button");return t.type="button",t.className="beacon-default-trigger",t.setAttribute("aria-label",e),t.innerHTML=`${x.feedback}<span>${e}</span>`,t}const ge=["bug","idea","ux","a11y"];class me{constructor(t,n){this.state={description:"",severity:"bug",pins:[],annotatedScreenshot:void 0,submitting:!1,status:"",statusKind:""},this.severities=t.length>0?t:ge,this.callbacks=n,this.root=document.createElement("div"),this.root.className="beacon-drawer",this.root.innerHTML=`
2
+ <div class="beacon-drawer-header">
3
+ <div class="beacon-drawer-title">Send feedback</div>
4
+ <button type="button" class="beacon-icon-btn" data-action="close" aria-label="Close">${x.close}</button>
5
+ </div>
6
+ <div class="beacon-drawer-body"></div>
7
+ `,this.bodyEl=this.root.querySelector(".beacon-drawer-body"),this.root.querySelector('[data-action="close"]').addEventListener("click",()=>this.callbacks.onClose()),this.render()}open(){this.root.classList.remove("minimized"),this.root.classList.add("open")}close(){this.root.classList.remove("open")}minimize(){this.root.classList.add("minimized"),this.root.classList.remove("open")}setPins(t,n){this.state.pins=t,n!==void 0&&(this.state.annotatedScreenshot=n),this.render()}setSubmitting(t){this.state.submitting=t,this.render()}setStatus(t,n=""){this.state.status=t,this.state.statusKind=n,this.render()}reset(){this.state={description:"",severity:"bug",pins:[],annotatedScreenshot:void 0,submitting:!1,status:"",statusKind:""},this.render()}getDescription(){return this.state.description}getSeverity(){return this.state.severity}render(){var r,i;const t=this.state.description.trim().length>0&&!this.state.submitting;this.bodyEl.innerHTML=`
8
+ <div class="beacon-field">
9
+ <label class="beacon-label" for="beacon-desc">What's the issue?</label>
10
+ <textarea id="beacon-desc" class="beacon-textarea" placeholder="Describe what you saw, what you expected, anything that helps reproduce…">${k(this.state.description)}</textarea>
11
+ </div>
12
+
13
+ <div class="beacon-field">
14
+ <span class="beacon-label">Severity</span>
15
+ <div class="beacon-severity" role="radiogroup">
16
+ ${this.severities.map(o=>`
17
+ <label class="beacon-severity-opt ${o===this.state.severity?"selected":""}" data-sev="${o}">
18
+ <input type="radio" name="beacon-severity" value="${o}" ${o===this.state.severity?"checked":""}>
19
+ ${o}
20
+ </label>
21
+ `).join("")}
22
+ </div>
23
+ </div>
24
+
25
+ ${this.state.annotatedScreenshot?`
26
+ <div class="beacon-field">
27
+ <span class="beacon-label">Annotated screenshot</span>
28
+ <img src="${this.state.annotatedScreenshot}" class="beacon-thumb" alt="Annotated screenshot preview">
29
+ </div>
30
+ `:""}
31
+
32
+ ${this.state.pins.length>0?`
33
+ <div class="beacon-field">
34
+ <span class="beacon-label">Pins (${this.state.pins.length})</span>
35
+ <div class="beacon-pin-list">
36
+ ${this.state.pins.map(o=>`
37
+ <div class="beacon-pin-item" data-pin="${o.number}">
38
+ <span class="beacon-pin-num">${o.number}</span>
39
+ <div class="beacon-pin-meta">
40
+ <div class="beacon-pin-selector" title="${k(o.selector)}">${k(o.selector)}</div>
41
+ <input type="text" class="beacon-pin-note-input" placeholder="Add a note (optional)" value="${k(o.note??"")}">
42
+ </div>
43
+ <button type="button" class="beacon-icon-btn" data-pin-delete="${o.number}" aria-label="Remove pin ${o.number}">${x.trash}</button>
44
+ </div>
45
+ `).join("")}
46
+ </div>
47
+ </div>
48
+ `:""}
49
+
50
+ <div class="beacon-actions">
51
+ <button type="button" class="beacon-btn secondary" data-action="annotate" ${this.state.submitting?"disabled":""}>
52
+ ${x.pin} ${this.state.pins.length>0?"Add another pin":"Annotate elements"}
53
+ </button>
54
+ <span style="flex:1"></span>
55
+ <button type="button" class="beacon-btn primary" data-action="submit" ${t?"":"disabled"}>
56
+ ${x.send} ${this.state.submitting?"Sending…":"Send"}
57
+ </button>
58
+ </div>
59
+
60
+ ${this.state.status?`<div class="beacon-status ${this.state.statusKind}">${k(this.state.status)}</div>`:""}
61
+ `;const n=this.bodyEl.querySelector("#beacon-desc");n.addEventListener("input",()=>{this.state.description=n.value,this.callbacks.onDescriptionChange(n.value);const o=this.bodyEl.querySelector('[data-action="submit"]');o&&(o.disabled=!(n.value.trim().length>0)||this.state.submitting)}),this.bodyEl.querySelectorAll('input[name="beacon-severity"]').forEach(o=>{o.addEventListener("change",()=>{o.checked&&(this.state.severity=o.value,this.callbacks.onSeverityChange(this.state.severity),this.render())})}),(r=this.bodyEl.querySelector('[data-action="annotate"]'))==null||r.addEventListener("click",()=>this.callbacks.onAnnotate()),(i=this.bodyEl.querySelector('[data-action="submit"]'))==null||i.addEventListener("click",()=>this.callbacks.onSubmit()),this.bodyEl.querySelectorAll("[data-pin-delete]").forEach(o=>{o.addEventListener("click",()=>{const a=Number(o.getAttribute("data-pin-delete"));this.callbacks.onPinDelete(a)})}),this.bodyEl.querySelectorAll(".beacon-pin-note-input").forEach(o=>{const a=o.closest("[data-pin]"),s=Number((a==null?void 0:a.getAttribute("data-pin"))??0);o.addEventListener("input",()=>this.callbacks.onPinNoteChange(s,o.value))})}}function k(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function ye(e){return new Promise(t=>{const n=document.createElement("div");n.className="beacon-pin-popover open",n.innerHTML=`
62
+ <div style="display:flex;align-items:center;gap:6px;font-weight:600;font-size:13px;">
63
+ <span class="beacon-pin-num">${e.pinNumber}</span>
64
+ <span>Note for this pin</span>
65
+ </div>
66
+ <textarea class="beacon-textarea" rows="2" placeholder="Optional — describe what's wrong here…" style="min-height:48px;"></textarea>
67
+ <div class="beacon-pin-popover-actions">
68
+ <button type="button" class="beacon-btn secondary" data-action="skip">Skip</button>
69
+ <button type="button" class="beacon-btn primary" data-action="save">${x.check} Save</button>
70
+ </div>
71
+ `;const r=240,i=160,o=Math.min(Math.max(8,e.anchor.x),window.innerWidth-r-8),a=Math.min(Math.max(8,e.anchor.y+12),window.innerHeight-i-8);n.style.left=`${o}px`,n.style.top=`${a}px`,e.shadowRoot.appendChild(n);const s=n.querySelector("textarea");s.focus();function c(l){n.remove(),t(l)}n.addEventListener("click",l=>{var w;const m=(w=l.target.closest("[data-action]"))==null?void 0:w.getAttribute("data-action");if(m==="skip"&&c({cancelled:!1}),m==="save"){const R=s.value.trim();c({...R?{note:R}:{},cancelled:!1})}}),s.addEventListener("keydown",l=>{if(l.key==="Enter"&&(l.metaKey||l.ctrlKey)){const d=s.value.trim();c({...d?{note:d}:{},cancelled:!1})}l.key==="Escape"&&c({cancelled:!0})})})}function we(e){const{shadowRoot:t,onHover:n}=e,r=document.createElement("div");r.style.cssText=["position: fixed","pointer-events: none","z-index: 2147483646","border: 2px solid #0ea5e9","background: rgba(14, 165, 233, 0.08)","transition: all 60ms ease-out","box-sizing: border-box","border-radius: 2px"].join("; "),document.body.appendChild(r);const i=document.createElement("div");i.style.cssText=["position: fixed","pointer-events: none","z-index: 2147483647","background: #0f172a","color: #fff","font: 11px/1.4 ui-monospace, SFMono-Regular, Menlo, monospace","padding: 3px 6px","border-radius: 3px","max-width: 280px","overflow: hidden","text-overflow: ellipsis","white-space: nowrap"].join("; "),document.body.appendChild(i);const o=document.body.style.cursor;document.body.style.cursor="crosshair";let a=!1,s=()=>{};const c=new Promise(u=>{s=u});function l(u){if(!u||!(u instanceof Node))return!1;let h=u;for(;h;){if(h===t||h===t.host)return!0;h=h.parentNode??h.host??null}return!1}function d(u,h){r.style.display="none",i.style.display="none";const O=document.elementsFromPoint(u,h);r.style.display="block",i.style.display="block";for(const P of O)if(!l(P))return P;return null}function m(u){const h=u.getBoundingClientRect();r.style.left=`${h.left}px`,r.style.top=`${h.top}px`,r.style.width=`${h.width}px`,r.style.height=`${h.height}px`;const O=u.tagName.toLowerCase(),P=u.classList.length>0?"."+Array.from(u.classList).slice(0,2).join("."):"";i.textContent=O+P;const pe=h.top-22;i.style.left=`${h.left}px`,i.style.top=`${pe>=0?pe:h.bottom+4}px`}function w(u){const h=d(u.clientX,u.clientY);h?(m(h),n==null||n(h)):(r.style.display="none",i.style.display="none",n==null||n(null))}function R(u){u.preventDefault(),u.stopPropagation();const h=d(u.clientX,u.clientY);h&&H(h)}function fe(u){u.key==="Escape"&&(u.preventDefault(),H(null))}function H(u){a||(a=!0,document.removeEventListener("mousemove",w,!0),document.removeEventListener("click",R,!0),document.removeEventListener("keydown",fe,!0),r.remove(),i.remove(),document.body.style.cursor=o,s(u))}return document.addEventListener("mousemove",w,!0),document.addEventListener("click",R,!0),document.addEventListener("keydown",fe,!0),{cancel:()=>H(null),promise:c}}const xe=8;function j(e,t=document){if(!e)return!1;try{return t.querySelectorAll(`#${CSS.escape(e)}`).length===1}catch{return!1}}function ve(e){const t=e.tagName.toLowerCase(),n=Array.from(e.classList).filter(r=>r.length>0&&r.length<40).slice(0,3).map(r=>`.${CSS.escape(r)}`).join("");return t+n}function Se(e){const t=e.parentElement;return t?Array.from(t.children).filter(r=>r.tagName===e.tagName).indexOf(e)+1:1}function Ee(e){if(!e||e.nodeType!==Node.ELEMENT_NODE)return"";if(e.id&&j(e.id))return`#${CSS.escape(e.id)}`;const t=[];let n=e,r=0;for(;n&&n.tagName.toLowerCase()!=="body"&&r<xe;){const i=n;if(i.id&&j(i.id)){t.unshift(`#${CSS.escape(i.id)}`);break}const o=ve(i),a=i.parentElement;let s=o;if(a)try{const c=Array.from(i.classList).join(" ");Array.from(a.children).filter(d=>d.tagName===i.tagName&&Array.from(d.classList).join(" ")===c).length>1&&(s=`${i.tagName.toLowerCase()}:nth-of-type(${Se(i)})`)}catch{}t.unshift(s),n=a,r++}return t.join(" > ")}function ke(e){const t=Object.keys(e).filter(r=>r.startsWith("__reactFiber$")||r.startsWith("__reactInternalInstance$"));if(t.length===0)return null;let n=e[t[0]];for(let r=0;r<10&&n;r++){const i=n,o=i.type;if(typeof o=="function"){const a=o.displayName??o.name;if(a&&a!=="_default")return{lib:"react",name:a}}if(typeof o=="object"&&o!==null){const a=o.displayName??o.name;if(a)return{lib:"react",name:a}}n=i.return}return{lib:"react"}}function Ce(e){var r,i;const t=e,n=t.__vueParentComponent;if(n){const o=((r=n.type)==null?void 0:r.name)??((i=n.type)==null?void 0:i.__name);return{lib:"vue",...o?{name:o}:{}}}return t.__vue__?{lib:"vue"}:null}function Re(e){const t=window.ng;if(!(t!=null&&t.getComponent))return null;try{const n=t.getComponent(e);if(!n)return null;const r=n.constructor;return{lib:"angular",...r!=null&&r.name?{name:r.name}:{}}}catch{return null}}function $e(e){return"__svelte_meta"in e?{lib:"svelte"}:null}function z(e){return ke(e)??Ce(e)??Re(e)??$e(e)??void 0}const Le=5e3,Te=1e3,Pe=["display","position","top","right","bottom","left","width","height","min-width","min-height","max-width","max-height","margin","padding","font-family","font-size","font-weight","line-height","text-align","color","background-color","background-image","border","border-radius","opacity","visibility","overflow","z-index","transform","transition","flex","flex-direction","justify-content","align-items","gap","grid-template-columns","grid-template-rows"];function U(e,t){return e.length<=t?e:e.slice(0,t)+`
72
+
73
+ /* … truncated, original was ${e.length} chars */`}function Ae(e){const t=getComputedStyle(e),n={};for(const r of Pe){const i=t.getPropertyValue(r);i&&i!=="normal"&&i!=="none"&&i!=="auto"&&i!=="0px"&&(n[r]=i.trim())}return n}function Me(e){const t=e.getBoundingClientRect();return{selector:Ee(e),tagName:e.tagName.toLowerCase(),id:e.id||null,classList:Array.from(e.classList),outerHTML:U(e.outerHTML,Le),...e.parentElement?{parentOuterHTML:U(e.parentElement.outerHTML,Te)}:{},computedStyles:Ae(e),boundingRect:{x:Math.round(t.x),y:Math.round(t.y),w:Math.round(t.width),h:Math.round(t.height)},...z(e)?{framework:z(e)}:{}}}function B(){var n,r;const e=navigator;return e.userAgentData?{brand:((n=e.userAgentData.brands.find(i=>!/Not[.\-]?A.?Brand/i.test(i.brand)))==null?void 0:n.brand)??((r=e.userAgentData.brands[0])==null?void 0:r.brand)??"unknown",mobile:e.userAgentData.mobile,platform:e.userAgentData.platform}:void 0}function V(){if(window.matchMedia("(prefers-color-scheme: dark)").matches)return"dark";if(window.matchMedia("(prefers-color-scheme: light)").matches)return"light"}function W(){return{url:window.location.href,...document.referrer?{referrer:document.referrer}:{},userAgent:navigator.userAgent,...B()?{uaData:B()}:{},viewport:{w:window.innerWidth,h:window.innerHeight,dpr:window.devicePixelRatio||1},screen:{w:window.screen.width,h:window.screen.height},timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,locale:navigator.language,...V()?{theme:V()}:{},capturedAt:new Date().toISOString()}}let A=null;async function _e(){return A||(A=await Promise.resolve().then(()=>Ot)),A}async function q(e={}){const{quality:t=.7,pixelRatio:n=Math.min(window.devicePixelRatio||1,2),excludeShadowRoot:r}=e,i=await _e(),o=r?a=>{let s=a;for(;s;){if(s===r.host)return!1;s=s.parentNode}return!0}:void 0;return i.toJpeg(document.documentElement,{quality:t,pixelRatio:n,cacheBust:!0,...o?{filter:o}:{},width:window.innerWidth,height:window.innerHeight,style:{transform:"none"}})}const De=14,Ie="#0ea5e9",Fe="#ffffff",He="#ffffff";async function K(e,t,n){const r=await Oe(e),i=document.createElement("canvas");i.width=r.naturalWidth,i.height=r.naturalHeight;const o=i.getContext("2d");if(!o)throw new Error("Could not get 2D canvas context");o.drawImage(r,0,0);const a=i.width/n.w,s=i.height/n.h;for(const c of t){const l=(c.boundingRect.x+8)*a,d=(c.boundingRect.y+8)*s;o.beginPath(),o.fillStyle=Ie,o.arc(l,d,De,0,Math.PI*2),o.fill(),o.lineWidth=3,o.strokeStyle=Fe,o.stroke(),o.fillStyle=He,o.font="bold 16px system-ui, -apple-system, sans-serif",o.textAlign="center",o.textBaseline="middle",o.fillText(String(c.number),l,d+1)}return i.toDataURL("image/jpeg",.85)}function Oe(e){return new Promise((t,n)=>{const r=new Image;r.onload=()=>t(r),r.onerror=i=>n(i),r.src=e})}async function je(e,t,n){const r=await fetch(e,{method:"POST",credentials:"include",headers:{"Content-Type":"application/json",...n??{}},body:JSON.stringify(t)});let i=null;if((r.headers.get("Content-Type")??"").includes("application/json"))try{i=await r.json()}catch{i=null}else try{i=await r.text()}catch{i=null}return{ok:r.ok,status:r.status,body:i}}const ze=["endpoint","position","theme","severities"];class G extends HTMLElement{constructor(){super(...arguments),this._config=null,this.pins=[],this.description="",this.severity="bug"}static get observedAttributes(){return ze}set config(t){this._config=t}get config(){if(this._config)return this._config;const t=this.getAttribute("endpoint");return t?{endpoint:t}:null}connectedCallback(){if(!this.shadow){this.shadow=this.attachShadow({mode:"open"});const t=document.createElement("style");t.textContent=E,this.shadow.appendChild(t),this.slotEl=document.createElement("slot"),this.slotEl.name="trigger",this.shadow.appendChild(this.slotEl),this.trigger=be(),this.shadow.appendChild(this.trigger),this.trigger.addEventListener("click",()=>this.open()),this.slotEl.addEventListener("slotchange",()=>{const n=this.slotEl.assignedElements();n.length>0&&(this.trigger&&(this.trigger.style.display="none"),n.forEach(r=>r.addEventListener("click",()=>this.open())))}),this.drawer=new me(this.parseSeverities(),{onClose:()=>this.close(),onAnnotate:()=>this.startAnnotate(),onSubmit:()=>this.handleSubmit(),onPinNoteChange:(n,r)=>this.updatePinNote(n,r),onPinDelete:n=>this.deletePin(n),onDescriptionChange:n=>{this.description=n},onSeverityChange:n=>{this.severity=n}}),this.shadow.appendChild(this.drawer.root)}this.hasAttribute("position")||this.setAttribute("position","bottom-right"),this.hasAttribute("theme")||this.setAttribute("theme","auto")}attributeChangedCallback(t,n,r){t==="severities"&&this.drawer&&console.warn("[launchkit-beacon] severities attribute changed after mount; not yet hot-reloaded.")}open(){var t;if(this.drawer){if(this.getAttribute("position")==="hidden"){const n=(t=this.slotEl)==null?void 0:t.assignedElements()[0];n&&Be(this.drawer.root,n)}this.drawer.open()}}close(){var t;(t=this.drawer)==null||t.close()}async openWithPicker(){this.open(),setTimeout(()=>this.startAnnotate(),0)}async startAnnotate(){if(!this.drawer)return;this.drawer.minimize();let t=!0;for(;t;){const r=await we({shadowRoot:this.shadow}).promise;if(!r)break;const i=r.getBoundingClientRect(),o=await ye({shadowRoot:this.shadow,anchor:{x:i.left,y:i.bottom},pinNumber:this.pins.length+1});if(o.cancelled)break;const a=Me(r),s={number:this.pins.length+1,...a,...o.note?{note:o.note}:{}};this.pins.push(s)}if(this.pins.length>0)try{const n=W(),r=await q({excludeShadowRoot:this.shadow}),i=await K(r,this.pins,n.viewport);this.drawer.setPins(this.pins,i)}catch(n){console.warn("[launchkit-beacon] screenshot capture failed:",n),this.drawer.setPins(this.pins)}this.drawer.open()}updatePinNote(t,n){const r=this.pins.find(i=>i.number===t);r&&(n.trim()?r.note=n:delete r.note)}deletePin(t){var n;this.pins=this.pins.filter(r=>r.number!==t),this.pins.forEach((r,i)=>{r.number=i+1}),(n=this.drawer)==null||n.setPins(this.pins,void 0)}async handleSubmit(){if(!this.drawer)return;const t=this.config;if(!(t!=null&&t.endpoint)){this.drawer.setStatus("Missing endpoint configuration","error");return}const n=this.drawer.getDescription().trim(),r=this.drawer.getSeverity();if(!n){this.drawer.setStatus("Description is required","error");return}const i=W();let o;if(this.pins.length>0)try{const l=await q({excludeShadowRoot:this.shadow});o=await K(l,this.pins,i.viewport)}catch{}const a={description:n,severity:r,...o?{screenshot:{dataUrl:o,mime:"image/jpeg"}}:{},metadata:i,pins:this.pins,...this.resolveContext()?{context:this.resolveContext()}:{}},s=new CustomEvent("beacon-before-submit",{detail:{payload:a},cancelable:!0,bubbles:!0,composed:!0});if(!this.dispatchEvent(s)){this.drawer.setStatus("Submission cancelled","error");return}this.drawer.setSubmitting(!0),this.drawer.setStatus("Sending…");try{const l=this.resolveHeaders(),d=await je(t.endpoint,a,l);this.drawer.setSubmitting(!1),d.ok?(this.drawer.setStatus("Sent — thanks!","success"),this.dispatchEvent(new CustomEvent("beacon-after-submit",{detail:{response:d},bubbles:!0,composed:!0})),setTimeout(()=>{this.pins=[],this.description="",this.severity="bug",this.drawer.reset(),this.drawer.close()},1500)):this.drawer.setStatus(`Failed: ${d.status}`,"error")}catch(l){this.drawer.setSubmitting(!1);const d=l instanceof Error?l.message:"Network error";this.drawer.setStatus(`Failed: ${d}`,"error")}}resolveHeaders(){var n;const t=(n=this.config)==null?void 0:n.headers;if(t)return typeof t=="function"?t():t}resolveContext(){var n;const t=(n=this.config)==null?void 0:n.context;if(t)return typeof t=="function"?t():t}parseSeverities(){const t=this.getAttribute("severities");return t?t.split(",").map(n=>n.trim()).filter(Boolean):["bug","idea","ux","a11y"]}}function N(e="launchkit-beacon"){typeof window>"u"||customElements.get(e)||customElements.define(e,G)}const X=380,b=8,Ue=520;function Be(e,t){const n=t.getBoundingClientRect(),r=window.innerWidth,i=window.innerHeight;let o=Math.max(b,r-n.right);r-o-X<b&&(o=Math.max(b,r-X-b));const s=i-n.bottom-b,c=n.top-b;e.style.left="auto",e.style.right=`${o}px`,s>=Ue||s>=c?(e.style.top=`${n.bottom+b}px`,e.style.bottom="auto"):(e.style.top="auto",e.style.bottom=`${i-n.top+b}px`)}N();function Ve(e,t){if(e.match(/^[a-z]+:\/\//i))return e;if(e.match(/^\/\//))return window.location.protocol+e;if(e.match(/^[a-z]+:/i))return e;const n=document.implementation.createHTMLDocument(),r=n.createElement("base"),i=n.createElement("a");return n.head.appendChild(r),n.body.appendChild(i),t&&(r.href=t),i.href=e,i.href}const We=(()=>{let e=0;const t=()=>`0000${(Math.random()*36**4<<0).toString(36)}`.slice(-4);return()=>(e+=1,`u${t()}${e}`)})();function g(e){const t=[];for(let n=0,r=e.length;n<r;n++)t.push(e[n]);return t}let v=null;function Y(e={}){return v||(e.includeStyleProperties?(v=e.includeStyleProperties,v):(v=g(window.getComputedStyle(document.documentElement)),v))}function $(e,t){const r=(e.ownerDocument.defaultView||window).getComputedStyle(e).getPropertyValue(t);return r?parseFloat(r.replace("px","")):0}function qe(e){const t=$(e,"border-left-width"),n=$(e,"border-right-width");return e.clientWidth+t+n}function Ke(e){const t=$(e,"border-top-width"),n=$(e,"border-bottom-width");return e.clientHeight+t+n}function M(e,t={}){const n=t.width||qe(e),r=t.height||Ke(e);return{width:n,height:r}}function Ge(){let e,t;try{t=process}catch{}const n=t&&t.env?t.env.devicePixelRatio:null;return n&&(e=parseInt(n,10),Number.isNaN(e)&&(e=1)),e||window.devicePixelRatio||1}const p=16384;function Ne(e){(e.width>p||e.height>p)&&(e.width>p&&e.height>p?e.width>e.height?(e.height*=p/e.width,e.width=p):(e.width*=p/e.height,e.height=p):e.width>p?(e.height*=p/e.width,e.width=p):(e.width*=p/e.height,e.height=p))}function Xe(e,t={}){return e.toBlob?new Promise(n=>{e.toBlob(n,t.type?t.type:"image/png",t.quality?t.quality:1)}):new Promise(n=>{const r=window.atob(e.toDataURL(t.type?t.type:void 0,t.quality?t.quality:void 0).split(",")[1]),i=r.length,o=new Uint8Array(i);for(let a=0;a<i;a+=1)o[a]=r.charCodeAt(a);n(new Blob([o],{type:t.type?t.type:"image/png"}))})}function L(e){return new Promise((t,n)=>{const r=new Image;r.onload=()=>{r.decode().then(()=>{requestAnimationFrame(()=>t(r))})},r.onerror=n,r.crossOrigin="anonymous",r.decoding="async",r.src=e})}async function Ye(e){return Promise.resolve().then(()=>new XMLSerializer().serializeToString(e)).then(encodeURIComponent).then(t=>`data:image/svg+xml;charset=utf-8,${t}`)}async function Je(e,t,n){const r="http://www.w3.org/2000/svg",i=document.createElementNS(r,"svg"),o=document.createElementNS(r,"foreignObject");return i.setAttribute("width",`${t}`),i.setAttribute("height",`${n}`),i.setAttribute("viewBox",`0 0 ${t} ${n}`),o.setAttribute("width","100%"),o.setAttribute("height","100%"),o.setAttribute("x","0"),o.setAttribute("y","0"),o.setAttribute("externalResourcesRequired","true"),i.appendChild(o),o.appendChild(e),Ye(i)}const f=(e,t)=>{if(e instanceof t)return!0;const n=Object.getPrototypeOf(e);return n===null?!1:n.constructor.name===t.name||f(n,t)};function Ze(e){const t=e.getPropertyValue("content");return`${e.cssText} content: '${t.replace(/'|"/g,"")}';`}function Qe(e,t){return Y(t).map(n=>{const r=e.getPropertyValue(n),i=e.getPropertyPriority(n);return`${n}: ${r}${i?" !important":""};`}).join(" ")}function et(e,t,n,r){const i=`.${e}:${t}`,o=n.cssText?Ze(n):Qe(n,r);return document.createTextNode(`${i}{${o}}`)}function J(e,t,n,r){const i=window.getComputedStyle(e,n),o=i.getPropertyValue("content");if(o===""||o==="none")return;const a=We();try{t.className=`${t.className} ${a}`}catch{return}const s=document.createElement("style");s.appendChild(et(a,n,i,r)),t.appendChild(s)}function tt(e,t,n){J(e,t,":before",n),J(e,t,":after",n)}const Z="application/font-woff",Q="image/jpeg",nt={woff:Z,woff2:Z,ttf:"application/font-truetype",eot:"application/vnd.ms-fontobject",png:"image/png",jpg:Q,jpeg:Q,gif:"image/gif",tiff:"image/tiff",svg:"image/svg+xml",webp:"image/webp"};function rt(e){const t=/\.([^./]*?)$/g.exec(e);return t?t[1]:""}function _(e){const t=rt(e).toLowerCase();return nt[t]||""}function ot(e){return e.split(/,/)[1]}function D(e){return e.search(/^(data:)/)!==-1}function it(e,t){return`data:${t};base64,${e}`}async function ee(e,t,n){const r=await fetch(e,t);if(r.status===404)throw new Error(`Resource "${r.url}" not found`);const i=await r.blob();return new Promise((o,a)=>{const s=new FileReader;s.onerror=a,s.onloadend=()=>{try{o(n({res:r,result:s.result}))}catch(c){a(c)}},s.readAsDataURL(i)})}const I={};function at(e,t,n){let r=e.replace(/\?.*/,"");return n&&(r=e),/ttf|otf|eot|woff2?/i.test(r)&&(r=r.replace(/.*\//,"")),t?`[${t}]${r}`:r}async function F(e,t,n){const r=at(e,t,n.includeQueryParams);if(I[r]!=null)return I[r];n.cacheBust&&(e+=(/\?/.test(e)?"&":"?")+new Date().getTime());let i;try{const o=await ee(e,n.fetchRequestInit,({res:a,result:s})=>(t||(t=a.headers.get("Content-Type")||""),ot(s)));i=it(o,t)}catch(o){i=n.imagePlaceholder||"";let a=`Failed to fetch resource: ${e}`;o&&(a=typeof o=="string"?o:o.message),a&&console.warn(a)}return I[r]=i,i}async function st(e){const t=e.toDataURL();return t==="data:,"?e.cloneNode(!1):L(t)}async function ct(e,t){if(e.currentSrc){const o=document.createElement("canvas"),a=o.getContext("2d");o.width=e.clientWidth,o.height=e.clientHeight,a==null||a.drawImage(e,0,0,o.width,o.height);const s=o.toDataURL();return L(s)}const n=e.poster,r=_(n),i=await F(n,r,t);return L(i)}async function lt(e,t){var n;try{if(!((n=e==null?void 0:e.contentDocument)===null||n===void 0)&&n.body)return await T(e.contentDocument.body,t,!0)}catch{}return e.cloneNode(!1)}async function dt(e,t){return f(e,HTMLCanvasElement)?st(e):f(e,HTMLVideoElement)?ct(e,t):f(e,HTMLIFrameElement)?lt(e,t):e.cloneNode(te(e))}const ut=e=>e.tagName!=null&&e.tagName.toUpperCase()==="SLOT",te=e=>e.tagName!=null&&e.tagName.toUpperCase()==="SVG";async function ht(e,t,n){var r,i;if(te(t))return t;let o=[];return ut(e)&&e.assignedNodes?o=g(e.assignedNodes()):f(e,HTMLIFrameElement)&&(!((r=e.contentDocument)===null||r===void 0)&&r.body)?o=g(e.contentDocument.body.childNodes):o=g(((i=e.shadowRoot)!==null&&i!==void 0?i:e).childNodes),o.length===0||f(e,HTMLVideoElement)||await o.reduce((a,s)=>a.then(()=>T(s,n)).then(c=>{c&&t.appendChild(c)}),Promise.resolve()),t}function ft(e,t,n){const r=t.style;if(!r)return;const i=window.getComputedStyle(e);i.cssText?(r.cssText=i.cssText,r.transformOrigin=i.transformOrigin):Y(n).forEach(o=>{let a=i.getPropertyValue(o);o==="font-size"&&a.endsWith("px")&&(a=`${Math.floor(parseFloat(a.substring(0,a.length-2)))-.1}px`),f(e,HTMLIFrameElement)&&o==="display"&&a==="inline"&&(a="block"),o==="d"&&t.getAttribute("d")&&(a=`path(${t.getAttribute("d")})`),r.setProperty(o,a,i.getPropertyPriority(o))})}function pt(e,t){f(e,HTMLTextAreaElement)&&(t.innerHTML=e.value),f(e,HTMLInputElement)&&t.setAttribute("value",e.value)}function bt(e,t){if(f(e,HTMLSelectElement)){const n=t,r=Array.from(n.children).find(i=>e.value===i.getAttribute("value"));r&&r.setAttribute("selected","")}}function gt(e,t,n){return f(t,Element)&&(ft(e,t,n),tt(e,t,n),pt(e,t),bt(e,t)),t}async function mt(e,t){const n=e.querySelectorAll?e.querySelectorAll("use"):[];if(n.length===0)return e;const r={};for(let o=0;o<n.length;o++){const s=n[o].getAttribute("xlink:href");if(s){const c=e.querySelector(s),l=document.querySelector(s);!c&&l&&!r[s]&&(r[s]=await T(l,t,!0))}}const i=Object.values(r);if(i.length){const o="http://www.w3.org/1999/xhtml",a=document.createElementNS(o,"svg");a.setAttribute("xmlns",o),a.style.position="absolute",a.style.width="0",a.style.height="0",a.style.overflow="hidden",a.style.display="none";const s=document.createElementNS(o,"defs");a.appendChild(s);for(let c=0;c<i.length;c++)s.appendChild(i[c]);e.appendChild(a)}return e}async function T(e,t,n){return!n&&t.filter&&!t.filter(e)?null:Promise.resolve(e).then(r=>dt(r,t)).then(r=>ht(e,r,t)).then(r=>gt(e,r,t)).then(r=>mt(r,t))}const ne=/url\((['"]?)([^'"]+?)\1\)/g,yt=/url\([^)]+\)\s*format\((["']?)([^"']+)\1\)/g,wt=/src:\s*(?:url\([^)]+\)\s*format\([^)]+\)[,;]\s*)+/g;function xt(e){const t=e.replace(/([.*+?^${}()|\[\]\/\\])/g,"\\$1");return new RegExp(`(url\\(['"]?)(${t})(['"]?\\))`,"g")}function vt(e){const t=[];return e.replace(ne,(n,r,i)=>(t.push(i),n)),t.filter(n=>!D(n))}async function St(e,t,n,r,i){try{const o=n?Ve(t,n):t,a=_(t);let s;return i||(s=await F(o,a,r)),e.replace(xt(t),`$1${s}$3`)}catch{}return e}function Et(e,{preferredFontFormat:t}){return t?e.replace(wt,n=>{for(;;){const[r,,i]=yt.exec(n)||[];if(!i)return"";if(i===t)return`src: ${r};`}}):e}function re(e){return e.search(ne)!==-1}async function oe(e,t,n){if(!re(e))return e;const r=Et(e,n);return vt(r).reduce((o,a)=>o.then(s=>St(s,a,t,n)),Promise.resolve(r))}async function S(e,t,n){var r;const i=(r=t.style)===null||r===void 0?void 0:r.getPropertyValue(e);if(i){const o=await oe(i,null,n);return t.style.setProperty(e,o,t.style.getPropertyPriority(e)),!0}return!1}async function kt(e,t){await S("background",e,t)||await S("background-image",e,t),await S("mask",e,t)||await S("-webkit-mask",e,t)||await S("mask-image",e,t)||await S("-webkit-mask-image",e,t)}async function Ct(e,t){const n=f(e,HTMLImageElement);if(!(n&&!D(e.src))&&!(f(e,SVGImageElement)&&!D(e.href.baseVal)))return;const r=n?e.src:e.href.baseVal,i=await F(r,_(r),t);await new Promise((o,a)=>{e.onload=o,e.onerror=t.onImageErrorHandler?(...c)=>{try{o(t.onImageErrorHandler(...c))}catch(l){a(l)}}:a;const s=e;s.decode&&(s.decode=o),s.loading==="lazy"&&(s.loading="eager"),n?(e.srcset="",e.src=i):e.href.baseVal=i})}async function Rt(e,t){const r=g(e.childNodes).map(i=>ie(i,t));await Promise.all(r).then(()=>e)}async function ie(e,t){f(e,Element)&&(await kt(e,t),await Ct(e,t),await Rt(e,t))}function $t(e,t){const{style:n}=e;t.backgroundColor&&(n.backgroundColor=t.backgroundColor),t.width&&(n.width=`${t.width}px`),t.height&&(n.height=`${t.height}px`);const r=t.style;return r!=null&&Object.keys(r).forEach(i=>{n[i]=r[i]}),e}const ae={};async function se(e){let t=ae[e];if(t!=null)return t;const r=await(await fetch(e)).text();return t={url:e,cssText:r},ae[e]=t,t}async function ce(e,t){let n=e.cssText;const r=/url\(["']?([^"')]+)["']?\)/g,o=(n.match(/url\([^)]+\)/g)||[]).map(async a=>{let s=a.replace(r,"$1");return s.startsWith("https://")||(s=new URL(s,e.url).href),ee(s,t.fetchRequestInit,({result:c})=>(n=n.replace(a,`url(${c})`),[a,c]))});return Promise.all(o).then(()=>n)}function le(e){if(e==null)return[];const t=[],n=/(\/\*[\s\S]*?\*\/)/gi;let r=e.replace(n,"");const i=new RegExp("((@.*?keyframes [\\s\\S]*?){([\\s\\S]*?}\\s*?)})","gi");for(;;){const c=i.exec(r);if(c===null)break;t.push(c[0])}r=r.replace(i,"");const o=/@import[\s\S]*?url\([^)]*\)[\s\S]*?;/gi,a="((\\s*?(?:\\/\\*[\\s\\S]*?\\*\\/)?\\s*?@media[\\s\\S]*?){([\\s\\S]*?)}\\s*?})|(([\\s\\S]*?){([\\s\\S]*?)})",s=new RegExp(a,"gi");for(;;){let c=o.exec(r);if(c===null){if(c=s.exec(r),c===null)break;o.lastIndex=s.lastIndex}else s.lastIndex=o.lastIndex;t.push(c[0])}return t}async function Lt(e,t){const n=[],r=[];return e.forEach(i=>{if("cssRules"in i)try{g(i.cssRules||[]).forEach((o,a)=>{if(o.type===CSSRule.IMPORT_RULE){let s=a+1;const c=o.href,l=se(c).then(d=>ce(d,t)).then(d=>le(d).forEach(m=>{try{i.insertRule(m,m.startsWith("@import")?s+=1:i.cssRules.length)}catch(w){console.error("Error inserting rule from remote css",{rule:m,error:w})}})).catch(d=>{console.error("Error loading remote css",d.toString())});r.push(l)}})}catch(o){const a=e.find(s=>s.href==null)||document.styleSheets[0];i.href!=null&&r.push(se(i.href).then(s=>ce(s,t)).then(s=>le(s).forEach(c=>{a.insertRule(c,a.cssRules.length)})).catch(s=>{console.error("Error loading remote stylesheet",s)})),console.error("Error inlining remote css file",o)}}),Promise.all(r).then(()=>(e.forEach(i=>{if("cssRules"in i)try{g(i.cssRules||[]).forEach(o=>{n.push(o)})}catch(o){console.error(`Error while reading CSS rules from ${i.href}`,o)}}),n))}function Tt(e){return e.filter(t=>t.type===CSSRule.FONT_FACE_RULE).filter(t=>re(t.style.getPropertyValue("src")))}async function Pt(e,t){if(e.ownerDocument==null)throw new Error("Provided element is not within a Document");const n=g(e.ownerDocument.styleSheets),r=await Lt(n,t);return Tt(r)}function de(e){return e.trim().replace(/["']/g,"")}function At(e){const t=new Set;function n(r){(r.style.fontFamily||getComputedStyle(r).fontFamily).split(",").forEach(o=>{t.add(de(o))}),Array.from(r.children).forEach(o=>{o instanceof HTMLElement&&n(o)})}return n(e),t}async function ue(e,t){const n=await Pt(e,t),r=At(e);return(await Promise.all(n.filter(o=>r.has(de(o.style.fontFamily))).map(o=>{const a=o.parentStyleSheet?o.parentStyleSheet.href:null;return oe(o.cssText,a,t)}))).join(`
74
+ `)}async function Mt(e,t){const n=t.fontEmbedCSS!=null?t.fontEmbedCSS:t.skipFonts?null:await ue(e,t);if(n){const r=document.createElement("style"),i=document.createTextNode(n);r.appendChild(i),e.firstChild?e.insertBefore(r,e.firstChild):e.appendChild(r)}}async function he(e,t={}){const{width:n,height:r}=M(e,t),i=await T(e,t,!0);return await Mt(i,t),await ie(i,t),$t(i,t),await Je(i,n,r)}async function C(e,t={}){const{width:n,height:r}=M(e,t),i=await he(e,t),o=await L(i),a=document.createElement("canvas"),s=a.getContext("2d"),c=t.pixelRatio||Ge(),l=t.canvasWidth||n,d=t.canvasHeight||r;return a.width=l*c,a.height=d*c,t.skipAutoScale||Ne(a),a.style.width=`${l}`,a.style.height=`${d}`,t.backgroundColor&&(s.fillStyle=t.backgroundColor,s.fillRect(0,0,a.width,a.height)),s.drawImage(o,0,0,a.width,a.height),a}async function _t(e,t={}){const{width:n,height:r}=M(e,t);return(await C(e,t)).getContext("2d").getImageData(0,0,n,r).data}async function Dt(e,t={}){return(await C(e,t)).toDataURL()}async function It(e,t={}){return(await C(e,t)).toDataURL("image/jpeg",t.quality||1)}async function Ft(e,t={}){const n=await C(e,t);return await Xe(n)}async function Ht(e,t={}){return ue(e,t)}const Ot=Object.freeze(Object.defineProperty({__proto__:null,getFontEmbedCSS:Ht,toBlob:Ft,toCanvas:C,toJpeg:It,toPixelData:_t,toPng:Dt,toSvg:he},Symbol.toStringTag,{value:"Module"}));y.LaunchkitBeacon=G,y.defineBeacon=N,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})});
75
+ //# sourceMappingURL=beacon.umd.js.map