2023-07-27 07:31:52 +02:00
|
|
|
/*
|
2024-02-13 16:59:27 +01:00
|
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
2023-07-27 07:31:52 +02:00
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2021-11-28 12:07:37 +01:00
|
|
|
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 {
|
2021-12-25 17:42:50 +01:00
|
|
|
return el.parentElement ? getBgColor(el.parentElement) : 'transparent';
|
2021-11-28 12:07:37 +01:00
|
|
|
}
|
2022-06-10 07:36:55 +02:00
|
|
|
};
|
2023-07-08 00:08:16 +02:00
|
|
|
|
2021-11-28 12:07:37 +01:00
|
|
|
const parentBg = getBgColor(src.parentElement);
|
|
|
|
|
|
|
|
const myBg = getComputedStyle(document.documentElement).getPropertyValue('--panel');
|
|
|
|
|
|
|
|
if (parentBg === myBg) {
|
|
|
|
src.style.backgroundColor = 'var(--bg)';
|
|
|
|
} else {
|
|
|
|
src.style.backgroundColor = 'var(--panel)';
|
|
|
|
}
|
|
|
|
},
|
|
|
|
} as Directive;
|