47 lines
1.4 KiB
TypeScript
47 lines
1.4 KiB
TypeScript
import { debounce } from "lodash";
|
|
import { defineStore } from "pinia"
|
|
import { ref, watch, type Ref } from "vue"
|
|
import request from "./request";
|
|
import { message } from "ant-design-vue";
|
|
import useLayoutStore from "@/layout/useLayoutStore";
|
|
export type StatisticType = {
|
|
widget: string;
|
|
space?: string;
|
|
action: string;
|
|
key?: string;
|
|
}
|
|
export default defineStore('statistic', () => {
|
|
const list = ref([] as StatisticType[])
|
|
const store = useLayoutStore()
|
|
const send = (item: StatisticType) => {
|
|
list.value.push(item)
|
|
}
|
|
const debouncedHandler = debounce((newValue: StatisticType[]) => {
|
|
console.log('数值改变并已防抖处理:', newValue)
|
|
if (newValue.length === 0) return
|
|
request("POST", `/api/app/statistics`, {
|
|
data: newValue.map((item) => ({
|
|
widget: item.widget,
|
|
space: item.space || store.state.current === 0 ? 'TAB_GAME' : store.state.current === 1 ? 'TAB_WORK' : 'TAB_EAZY',
|
|
action: item.action,
|
|
key: item.key
|
|
})),
|
|
returnType: 'text'
|
|
}).then(() => {
|
|
|
|
list.value = []
|
|
message.success('发送统计成功')
|
|
})
|
|
}, 2500) //
|
|
watch(list, (newValue) => {
|
|
console.log(list);
|
|
|
|
debouncedHandler(newValue)
|
|
}, {
|
|
deep: true
|
|
})
|
|
return {
|
|
list,
|
|
send
|
|
}
|
|
})
|