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;