| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- import { useTimeoutFn } from '/@/hooks/core/useTimeout';
- import { tryOnUnmounted } from '/@/utils/helper/vueHelper';
- import { unref, Ref, nextTick } from 'vue';
- import type { EChartOption, ECharts } from 'echarts';
- import echarts from 'echarts';
- import { useDebounce } from '/@/hooks/core/useDebounce';
- import { useEventListener } from '/@/hooks/event/useEventListener';
- import { useBreakpoint } from '/@/hooks/event/useBreakpoint';
- export type { EChartOption, ECharts };
- export function useECharts(
- elRef: Ref<HTMLDivElement>,
- theme: 'light' | 'dark' | 'default' = 'light'
- ) {
- let chartInstance: Nullable<ECharts> = null;
- let resizeFn: Fn = resize;
- let removeResizeFn: Fn = () => {};
- const [debounceResize] = useDebounce(resize, 200);
- resizeFn = debounceResize;
- function init() {
- const el = unref(elRef);
- if (!el || !unref(el)) {
- return;
- }
- chartInstance = echarts.init(el, theme);
- const { removeEvent } = useEventListener({
- el: window,
- name: 'resize',
- listener: resizeFn,
- });
- removeResizeFn = removeEvent;
- const { widthRef, screenEnum } = useBreakpoint();
- if (unref(widthRef) <= screenEnum.MD || el.offsetHeight === 0) {
- useTimeoutFn(() => {
- resizeFn();
- }, 30);
- }
- }
- function setOptions(options: any, clear = true) {
- if (unref(elRef)?.offsetHeight === 0) {
- useTimeoutFn(() => {
- setOptions(options);
- }, 30);
- return;
- }
- nextTick(() => {
- useTimeoutFn(() => {
- if (!chartInstance) {
- init();
- if (!chartInstance) return;
- }
- clear && chartInstance?.clear();
- chartInstance?.setOption(options);
- }, 30);
- });
- }
- function resize() {
- chartInstance?.resize();
- }
- tryOnUnmounted(() => {
- if (!chartInstance) return;
- removeResizeFn();
- chartInstance.dispose();
- chartInstance = null;
- });
- return {
- setOptions,
- echarts,
- resize,
- };
- }
|