import { Directive } from "vue"; export default { mounted(src, binding, vn) { const getBgColor = (el: HTMLElement) => { const style = window.getComputedStyle(el); if ( style.backgroundColor && !["rgba(0, 0, 0, 0)", "rgba(0,0,0,0)", "transparent"].includes( style.backgroundColor, ) ) { return style.backgroundColor; } else { return el.parentElement ? getBgColor(el.parentElement) : "transparent"; } }; const parentBg = getBgColor(src.parentElement); const myBg = window.getComputedStyle(src).backgroundColor; if (parentBg === myBg) { src.style.borderColor = "var(--divider)"; } else { src.style.borderColor = myBg; } }, } as Directive;