This commit is contained in:
expdsn 2024-11-04 14:42:27 +08:00
parent 38c07cb9ce
commit dc90fdd621
3 changed files with 143 additions and 54 deletions

View File

@ -3,7 +3,7 @@ import { defineComponent } from 'vue'
export default defineComponent(() => { export default defineComponent(() => {
return () => ( return () => (
<div class="w-full h-full bg-[#ecfbff] flex flex-col"> <div class="w-full h-full bg-[#ecfbff] flex flex-col">
large
</div> </div>
) )
}) })

View File

@ -1,6 +1,7 @@
import { computed, defineComponent, ref } from 'vue' import { computed, defineComponent, ref } from 'vue'
import useTomatoStore from '../useTomatoStore' import useTomatoStore from '../useTomatoStore'
import NoDataImg from "~/public/icons/work/noData.png" import NoDataImg from "~/public/icons/work/noData.png"
import StopImg from "~/public/icons/work/tomotoIconEnd.png"
import clsx from 'clsx' import clsx from 'clsx'
import dayjs from 'dayjs' import dayjs from 'dayjs'
import PlayImg from "~/public/icons/work/work_page-play.png" import PlayImg from "~/public/icons/work/work_page-play.png"
@ -88,18 +89,36 @@ export default defineComponent(() => {
<span class={" tracking-wide"}> <span class={"text-[#5b47ff]"}>{store.state.list.filter(val => dayjs(val.finishTime).isSame(dayjs(), 'day') && val.isCompleted).length}</span></span> <span class={" tracking-wide"}> <span class={"text-[#5b47ff]"}>{store.state.list.filter(val => dayjs(val.finishTime).isSame(dayjs(), 'day') && val.isCompleted).length}</span></span>
<span class={"text-[#ff8686]"}></span> <span class={"text-[#ff8686]"}></span>
</div> </div>
{
store.state.isStart ?
<button class={"w-[126px] h-[44px] text-[16px] text-white rounded-lg gap-x-1 font-bold flex items-center justify-center"} style={{ <button class={"w-[126px] h-[44px] text-[16px] text-white rounded-lg gap-x-1 font-bold flex items-center justify-center"} style={{
background: 'linear-gradient(225deg,#642FFF 0%,#5162FF 100%)', background: 'linear-gradient(225deg,#642FFF 0%,#5162FF 100%)',
boxShadow: '0 2px 4px #0003' boxShadow: '0 2px 4px #0003'
}}
onClick={() => {
store.stopTomatoTime()
}}
>
<img src={StopImg} alt="play img " class={"w-[13px]"} />
</button> :
<button class={"w-[126px] h-[44px] text-[16px] text-white rounded-lg gap-x-1 font-bold flex items-center hover:opacity-90 justify-center"} style={{
background: 'linear-gradient(225deg,#642FFF 0%,#5162FF 100%)',
boxShadow: '0 2px 4px #0003'
}} }}
onClick={() => { onClick={() => {
store.openFullscreen = true store.openFullscreen = true
store.beginTomatoTime()
}} }}
> >
<img src={PlayImg} alt="play img " class={"w-[13px]"} /> <img src={PlayImg} alt="play img " class={"w-[13px]"} />
</button> </button>
}
</div> </div>
</div> </div>

View File

@ -1,16 +1,21 @@
import { defineStore } from 'pinia' import useTimeStore from "@/utils/useTimeStore";
import { computed, reactive, ref, watch } from 'vue' import dayjs from "dayjs";
import { defineStore } from "pinia";
import { computed, reactive, ref, watch } from "vue";
const TOTAL_TIME = 60 * 60 * 15
export type TomatoTarget = { export type TomatoTarget = {
id: string id: string;
finishTime: number finishTime: number;
remindTime: number | null remindTime: number | null;
title: string title: string;
isCompleted: boolean isCompleted: boolean;
} }
export type TomatoTime = { export type TomatoTime = {
date: number date: number;
finishTime: number finishTime: number;
} }
export const musicList = [ export const musicList = [
{ {
@ -34,16 +39,81 @@ export const musicList = [
music: 'https://newfatfox.oss-cn-beijing.aliyuncs.com/admin/music/AWonderfulStore.mp3' music: 'https://newfatfox.oss-cn-beijing.aliyuncs.com/admin/music/AWonderfulStore.mp3'
} }
] ]
export default defineStore('work', () => { export default defineStore("work", () => {
const state = reactive({ const state = reactive({
list: [] as TomatoTarget[], list: [] as TomatoTarget[],
timeList: [] as TomatoTime[] timeList: [] as TomatoTime[],
isPlaying: false as boolean,
selectMusic: 0,
isStart: false as boolean,
beginTime: -1 as number
}) })
const time = useTimeStore()
const beginTomatoTime = () => {
state.beginTime = dayjs().valueOf()
state.isStart = true
playMusic()
}
const stopTomatoTime = () => {
state.isStart = false
state.beginTime = -1
stopMusic()
}
const remainingTime = computed(() => {
const totalTime = TOTAL_TIME
return dayjs(state.beginTime).add(15, 'minute').diff(dayjs(time.date), 'second')
})
const playAudio = computed(() => {
const audio = new Audio(musicList[state.selectMusic].music)
return audio
})
watch(() => remainingTime, (val) => {
if (val.value < 0) {
state.isPlaying = false
state.isStart = false
state.beginTime = -1
state.timeList.push({
date: dayjs().valueOf(),
finishTime: TOTAL_TIME
})
}
})
// watch(() => state.isPlaying, (val) => {
// if (val) {
// playAudio.value.play()
// } else {
// playAudio.value.pause()
// }
// })
const playMusic = () => {
state.isPlaying = true
playAudio.value.play()
}
const pauseMusic = () => {
state.isPlaying = false
playAudio.value.pause()
}
const stopMusic = () => {
state.isPlaying = false
playAudio.value.pause()
playAudio.value.currentTime = 0
}
const openShowModel = ref<undefined | null | TomatoTarget>() const openShowModel = ref<undefined | null | TomatoTarget>()
const openFullscreen = ref(false) const openFullscreen = ref(false)
return { return {
state, state,
openShowModel, openShowModel,
openFullscreen openFullscreen,
beginTomatoTime,
remainingTime,
playMusic,
pauseMusic,
stopMusic,
stopTomatoTime
} }
}) })