import { resize_observer_styles_default } from "./chunk.BWUQXUSO.js"; import { watch } from "./chunk.JMZM2TDT.js"; import { component_styles_default } from "./chunk.INZSKSLC.js"; import { ShoelaceElement, n } from "./chunk.OGQ452CI.js"; import { x } from "./chunk.OOP2EFQH.js"; import { __decorateClass } from "./chunk.W27M6RDR.js"; // src/components/resize-observer/resize-observer.component.ts var SlResizeObserver = class extends ShoelaceElement { constructor() { super(...arguments); this.observedElements = []; this.disabled = false; } connectedCallback() { super.connectedCallback(); this.resizeObserver = new ResizeObserver((entries) => { this.emit("sl-resize", { detail: { entries } }); }); if (!this.disabled) { this.startObserver(); } } disconnectedCallback() { super.disconnectedCallback(); this.stopObserver(); } handleSlotChange() { if (!this.disabled) { this.startObserver(); } } startObserver() { const slot = this.shadowRoot.querySelector("slot"); if (slot !== null) { const elements = slot.assignedElements({ flatten: true }); this.observedElements.forEach((el) => this.resizeObserver.unobserve(el)); this.observedElements = []; elements.forEach((el) => { this.resizeObserver.observe(el); this.observedElements.push(el); }); } } stopObserver() { this.resizeObserver.disconnect(); } handleDisabledChange() { if (this.disabled) { this.stopObserver(); } else { this.startObserver(); } } render() { return x` `; } }; SlResizeObserver.styles = [component_styles_default, resize_observer_styles_default]; __decorateClass([ n({ type: Boolean, reflect: true }) ], SlResizeObserver.prototype, "disabled", 2); __decorateClass([ watch("disabled", { waitUntilFirstUpdate: true }) ], SlResizeObserver.prototype, "handleDisabledChange", 1); export { SlResizeObserver };