2022-01-31 12:07:33 +00:00
|
|
|
<template>
|
2023-05-19 04:58:09 +00:00
|
|
|
<MkTooltip ref="tooltip" :showing="showing" :x="x" :y="y" :maxWidth="340" :direction="'top'" :innerMargin="16" @closed="emit('closed')">
|
2023-01-15 00:14:17 +00:00
|
|
|
<div v-if="title || series">
|
|
|
|
<div v-if="title" :class="$style.title">{{ title }}</div>
|
2022-06-28 01:41:38 +00:00
|
|
|
<template v-if="series">
|
2023-01-15 00:14:17 +00:00
|
|
|
<div v-for="x in series">
|
|
|
|
<span :class="$style.color" :style="{ background: x.backgroundColor, borderColor: x.borderColor }"></span>
|
2022-06-28 01:41:38 +00:00
|
|
|
<span>{{ x.text }}</span>
|
|
|
|
</div>
|
|
|
|
</template>
|
2022-01-31 12:07:33 +00:00
|
|
|
</div>
|
|
|
|
</MkTooltip>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
2022-06-28 01:41:38 +00:00
|
|
|
import { } from 'vue';
|
2022-09-06 09:21:49 +00:00
|
|
|
import MkTooltip from './MkTooltip.vue';
|
2022-01-31 12:07:33 +00:00
|
|
|
|
2022-12-22 07:59:11 +00:00
|
|
|
defineProps<{
|
2022-01-31 12:07:33 +00:00
|
|
|
showing: boolean;
|
|
|
|
x: number;
|
|
|
|
y: number;
|
2022-06-28 04:06:31 +00:00
|
|
|
title?: string;
|
|
|
|
series?: {
|
2022-01-31 12:07:33 +00:00
|
|
|
backgroundColor: string;
|
|
|
|
borderColor: string;
|
|
|
|
text: string;
|
|
|
|
}[];
|
|
|
|
}>();
|
|
|
|
|
|
|
|
const emit = defineEmits<{
|
|
|
|
(ev: 'closed'): void;
|
|
|
|
}>();
|
|
|
|
</script>
|
|
|
|
|
2023-01-15 00:14:17 +00:00
|
|
|
<style lang="scss" module>
|
|
|
|
.title {
|
|
|
|
margin-bottom: 4px;
|
|
|
|
}
|
2022-01-31 12:07:33 +00:00
|
|
|
|
2023-01-15 00:14:17 +00:00
|
|
|
.color {
|
|
|
|
display: inline-block;
|
|
|
|
width: 8px;
|
|
|
|
height: 8px;
|
|
|
|
border-width: 1px;
|
|
|
|
border-style: solid;
|
|
|
|
margin-right: 8px;
|
2022-01-31 12:07:33 +00:00
|
|
|
}
|
|
|
|
</style>
|