diff options
| author | syuilo <Syuilotan@yahoo.co.jp> | 2022-06-25 18:05:35 +0900 |
|---|---|---|
| committer | syuilo <Syuilotan@yahoo.co.jp> | 2022-06-25 18:05:35 +0900 |
| commit | 7be4b2145b5eb5db02400ba66366aa682111ffaa (patch) | |
| tree | 1d3132f3e01b1bfabcffa79eaaf8c6c11365ab46 /packages/client/src/scripts/use-chart-tooltip.ts | |
| parent | fix(client): only enable hotkeys for logged in users (#8793) (diff) | |
| download | sharkey-7be4b2145b5eb5db02400ba66366aa682111ffaa.tar.gz sharkey-7be4b2145b5eb5db02400ba66366aa682111ffaa.tar.bz2 sharkey-7be4b2145b5eb5db02400ba66366aa682111ffaa.zip | |
refactor(client): extract tooltip logic of chart
Diffstat (limited to 'packages/client/src/scripts/use-chart-tooltip.ts')
| -rw-r--r-- | packages/client/src/scripts/use-chart-tooltip.ts | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/packages/client/src/scripts/use-chart-tooltip.ts b/packages/client/src/scripts/use-chart-tooltip.ts new file mode 100644 index 0000000000..ab57165694 --- /dev/null +++ b/packages/client/src/scripts/use-chart-tooltip.ts @@ -0,0 +1,50 @@ +import { onUnmounted, ref } from 'vue'; +import * as os from '@/os'; +import MkChartTooltip from '@/components/chart-tooltip.vue'; + +export function useChartTooltip() { + const tooltipShowing = ref(false); + const tooltipX = ref(0); + const tooltipY = ref(0); + const tooltipTitle = ref(null); + const tooltipSeries = ref(null); + let disposeTooltipComponent; + + os.popup(MkChartTooltip, { + showing: tooltipShowing, + x: tooltipX, + y: tooltipY, + title: tooltipTitle, + series: tooltipSeries, + }, {}).then(({ dispose }) => { + disposeTooltipComponent = dispose; + }); + + onUnmounted(() => { + if (disposeTooltipComponent) disposeTooltipComponent(); + }); + + function handler(context) { + if (context.tooltip.opacity === 0) { + tooltipShowing.value = false; + return; + } + + tooltipTitle.value = context.tooltip.title[0]; + tooltipSeries.value = context.tooltip.body.map((b, i) => ({ + backgroundColor: context.tooltip.labelColors[i].backgroundColor, + borderColor: context.tooltip.labelColors[i].borderColor, + text: b.lines[0], + })); + + const rect = context.chart.canvas.getBoundingClientRect(); + + tooltipShowing.value = true; + tooltipX.value = rect.left + window.pageXOffset + context.tooltip.caretX; + tooltipY.value = rect.top + window.pageYOffset + context.tooltip.caretY; + } + + return { + handler, + }; +} |