lex 1 rok temu
rodzic
commit
2ba36d00d6

BIN
src/tenant/ranking-list/images/empty-logo.png


+ 144 - 15
src/tenant/ranking-list/index.module.less

@@ -5,6 +5,29 @@
   :global {
     .van-tabs__nav {
       background-color: transparent !important;
+      justify-content: center;
+    }
+
+    .van-tab {
+      font-size: 16px;
+      font-weight: bold;
+      color: rgba(0, 0, 0, 0.5);
+      line-height: 22px;
+    }
+
+    .van-tab--active {
+      color: rgba(19, 20, 21, 1);
+    }
+
+    .van-tabs__line {
+      background: #2B2A2F;
+      border-radius: 2px !important;
+      bottom: 20px;
+      width: 22px;
+    }
+
+    .van-tab--shrink {
+      padding: 0 25px;
     }
 
     .van-calendar__day--end,
@@ -51,6 +74,7 @@
 .sticky {
   :global {
     .van-sticky {
+      transition: none;
       background: url('./images/time-bg.png') no-repeat top center;
       background-size: 100% 397px;
     }
@@ -59,6 +83,8 @@
   .backArrow {
     position: absolute;
     z-index: 10;
+    left: 13px;
+    top: 14px;
     display: inline-block;
     font: 0.37333rem/1 vant-icon;
     font-size: inherit;
@@ -128,9 +154,9 @@
 
     .levelTime {
       font-size: 12px;
-      color: #000000;
       line-height: 17px;
       padding: 2px 0 8px;
+      color: rgba(0, 0, 0, 0.6);
     }
   }
 
@@ -158,7 +184,7 @@
   }
 
   .level2 {
-    margin-top: 30px;
+    margin-top: 33px;
 
     &::after {
       background: url('./images/level-2-bg.png') no-repeat center;
@@ -177,6 +203,7 @@
     margin-top: 30px;
 
     &::after {
+      height: 118px;
       background: url('./images/level-3-bg.png') no-repeat center;
       background-size: contain;
     }
@@ -202,7 +229,7 @@
     display: flex;
     align-items: center;
     justify-content: space-between;
-    padding: 19px 12px 2px 0;
+    padding: 19px 12px 4px 0;
 
     .titleName {
       display: flex;
@@ -226,21 +253,123 @@
   }
 }
 
-.rankItem {
-  background-color: transparent;
-  padding: 6px 10px;
-  border-radius: 12px;
+.rankContainer {
+
+  .rankItem,
+  .selfInfo {
+    position: relative;
+    background-color: transparent;
+    padding: 6px 10px 6px 30px;
+    border-radius: 12px;
+    margin: 0 6px 4px;
+    width: auto;
+
+
+
+    &.active {
+      background-color: #FFE5EA;
+    }
+
+
+    .num {
+      position: absolute;
+      left: 8px;
+      top: 20px;
+      font-size: 20px;
+      font-family: DINAlternate-Bold, DINAlternate;
+      font-weight: bold;
+      color: #AAAAAA;
+      line-height: 24px;
+    }
+
+    .userImg {
+      width: 48px;
+      height: 48px;
+      border-radius: 50%;
+      overflow: hidden;
+      margin-right: 12px;
+      flex-shrink: 0;
+    }
+
+    .userName {
+      font-size: 16px;
+      font-weight: 600;
+      color: #131415;
+      line-height: 22px;
+    }
+
+    .subjectName {
+      font-size: 12px;
+      color: #777777;
+      line-height: 17px;
+    }
+
+    .times {
+      font-size: 14px;
+      color: #777777;
+      line-height: 20px;
+
+      span {
+        font-size: 18px;
+        font-family: DINAlternate-Bold, DINAlternate;
+        font-weight: bold;
+        color: #333333;
+        line-height: 21px;
+        padding-right: 4px;
+      }
+    }
+  }
+
+  .selfInfo {
+    background: #FFFFFF;
+    box-shadow: 0px 1px 12px 0px rgba(240, 192, 221, 0.43);
+    border-radius: 20px 20px 0px 0px;
+    margin: 0;
+    padding: 14px 25px calc(14px + env(safe-area-inset-bottom)) 56px;
+
+    .num {
+      position: absolute;
+      left: 30px;
+      top: 26px;
+    }
+  }
+}
+
+.rankListDay {
+  background: linear-gradient(180deg, #C1F2F9 0%, #D3FFFF 29%, #FFEBCE 100%);
+
 
-  &.acitve {
-    background-color: #FFE5EA;
+  .sticky {
+    :global {
+      .van-sticky {
+        background: url('./images/day-bg.png') no-repeat top center #C1F2F9;
+        background-size: 100% 397px;
+      }
+    }
+  }
+
+  .rankItem,
+  .selfInfo {
+    &.active {
+      background-color: rgba(228, 247, 247, 1);
+    }
   }
 
+  .selfInfo {
+    box-shadow: 0px 1px 12px 0px rgba(236, 219, 196, 0.34);
 
-  .num {
-    font-size: 20px;
-    font-family: DINAlternate-Bold, DINAlternate;
-    font-weight: bold;
-    color: #AAAAAA;
-    line-height: 24px;
+    .num {
+      position: absolute;
+      left: 30px;
+      top: 26px;
+    }
   }
+}
+
+.emptyResult {
+  position: absolute;
+  width: 100%;
+  height: calc(100vh - var(--header-height));
+  display: flex;
+  align-items: center;
 }

+ 257 - 91
src/tenant/ranking-list/index.tsx

@@ -1,5 +1,5 @@
 import TheSticky from '@/components/the-sticky'
-import { defineComponent, reactive } from 'vue'
+import { computed, defineComponent, onMounted, reactive } from 'vue'
 import { useRoute } from 'vue-router'
 import styles from './index.module.less'
 import ColHeader from '@/components/col-header'
@@ -11,26 +11,30 @@ import { Tabs, Tab, Image, Icon, Calendar, Cell } from 'vant'
 import dayjs from 'dayjs'
 import isBetween from 'dayjs/plugin/isBetween'
 dayjs.extend(isBetween)
-
+import request from '@/helpers/request'
+import { state as baseState } from '@/state'
+import studentLogo from '@/common/images/icon_student.png'
+import emptyLogo from './images/empty-logo.png'
+import ColResult from '@/components/col-result'
 export default defineComponent({
   name: 'ranking-list',
   setup() {
     const route = useRoute()
     const state = reactive({
       showPopoverTime: false,
-      currentDate: [dayjs().format('YYYY'), dayjs().format('MM')],
-      isClick: false,
-      practiceMonthName: route.query.practiceMonthName
-        ? route.query.practiceMonthName
-        : dayjs().format('YYYY') + '年' + dayjs().format('MM') + '月',
-      userTrainOverView: {
-        trainDays: 0,
-        trainNum: 0,
-        trainTime: 0,
-        avgTrainTime: 0
-      },
-      userTrainChartData: [] as any,
-      myChart: null as any
+      tabActive: 'timeBill',
+      firstInfo: {} as any,
+      secondInfo: {} as any,
+      threeInfo: {} as any,
+      myInfo: {} as any,
+      list: [] as any,
+      loading: false,
+      beforListShow: true,
+      listShow: true // 是否显示
+    })
+
+    const isDayRank = computed(() => {
+      return state.tabActive === 'dayBill'
     })
 
     // 初始化周一
@@ -62,12 +66,56 @@ export default defineComponent({
 
     const forms = reactive({
       ...formatWeekDays(),
+      studentIds: baseState.user.data?.userId,
+      name: 0,
       page: 1,
       rows: 20
     })
 
+    const getList = async () => {
+      state.loading = true
+      try {
+        const { data } = await request.post(
+          '/api-tenant/studentMusicCompareRecord/rankingList',
+          {
+            data: {
+              ...forms
+            }
+          }
+        )
+        state.beforListShow = data.detail && data.detail.length > 0
+        state.myInfo = data.head || {}
+        state.myInfo.trainTime = state.myInfo.trainTime
+          ? Math.floor(state.myInfo.trainTime / 60)
+          : 0
+        state.list = data.detail || []
+        state.list.forEach((item: any) => {
+          item.trainTime = item.trainTime ? Math.floor(item.trainTime / 60) : 0
+        })
+        state.firstInfo =
+          state.list.length > 0 ? state.list.splice(0, 1)[0] : {}
+        state.secondInfo =
+          state.list.length > 0 ? state.list.splice(0, 1)[0] : {}
+        state.threeInfo =
+          state.list.length > 0 ? state.list.splice(0, 1)[0] : {}
+
+        state.listShow = state.list.length > 0
+      } catch {
+        //
+      }
+      state.loading = false
+    }
+
+    onMounted(() => {
+      getList()
+    })
     return () => (
-      <div class={styles.rankListPage}>
+      <div
+        class={[
+          styles.rankListPage,
+          isDayRank.value ? styles.rankListDay : styles.rankListTime
+        ]}
+      >
         <div class={styles.sticky}>
           <TheSticky position="top">
             <ColHeader
@@ -81,7 +129,21 @@ export default defineComponent({
                 content: () => (
                   <>
                     <Icon name="arrow-left" class={styles.backArrow} />
-                    <Tabs lineWidth={22} lineHeight={4}>
+                    <Tabs
+                      lineWidth={22}
+                      lineHeight={4}
+                      shrink
+                      v-model:active={state.tabActive}
+                      onChange={(val: string) => {
+                        if (val === 'dayBill') {
+                          forms.name = 2
+                        } else {
+                          forms.name = 0
+                        }
+
+                        getList()
+                      }}
+                    >
                       <Tab title="时长榜" name="timeBill"></Tab>
                       <Tab title="天数榜" name="dayBill"></Tab>
                     </Tabs>
@@ -90,91 +152,193 @@ export default defineComponent({
               }}
             </ColHeader>
           </TheSticky>
-          <img class={styles.bgImg} src={bgImg} />
+          <img class={styles.bgImg} src={isDayRank.value ? bgImg2 : bgImg} />
         </div>
 
-        <div class={styles.rankContainer}>
-          <div class={styles.rankLevel}>
-            <div class={[styles.levelItem, styles.level2]}>
-              <div class={styles.levelUserImg}>
-                <Image
-                  class={styles.img}
-                  src={
-                    'https://ks3-cn-beijing.ksyuncs.com/daya/16644378620311664437783089.jpg'
-                  }
-                />
+        {/* {state.beforListShow && ( */}
+          <div class={styles.rankContainer}>
+            <div class={styles.rankLevel}>
+              <div class={[styles.levelItem, styles.level2]}>
+                {state.secondInfo.userId ? (
+                  <>
+                    <div class={styles.levelUserImg}>
+                      <Image
+                        class={styles.img}
+                        src={state.secondInfo.avatar || studentLogo}
+                      />
+                    </div>
+                    <h2 class={'van-ellipsis'}>
+                      {state.secondInfo.studentName}
+                    </h2>
+                    <p class={[styles.levelTime, 'van-ellipsis']}>
+                      {state.secondInfo.subjectName}-
+                      {state.secondInfo.trainTime}
+                      分钟
+                    </p>
+                  </>
+                ) : (
+                  <>
+                    <div class={styles.levelUserImg}>
+                      <Image class={styles.img} src={emptyLogo} />
+                    </div>
+                    <h2 class={'van-ellipsis'}>虚位以待</h2>
+                    <p class={[styles.levelTime, 'van-ellipsis']}>&nbsp;</p>
+                  </>
+                )}
               </div>
-              <h2 class={'van-ellipsis'}>夏可可夏可可夏可可夏可可</h2>
-              <p class={[styles.levelTime, 'van-ellipsis']}>
-                夏可可夏可可竖笛-240分钟
-              </p>
-            </div>
-            <div class={[styles.levelItem, styles.level1]}>
-              <div class={styles.levelUserImg}>
-                <Image
-                  class={styles.img}
-                  src={
-                    'https://ks3-cn-beijing.ksyuncs.com/daya/16644378620311664437783089.jpg'
-                  }
-                />
+              <div class={[styles.levelItem, styles.level1]}>
+                {state.firstInfo.userId ? (
+                  <>
+                    <div class={styles.levelUserImg}>
+                      <Image
+                        class={styles.img}
+                        src={state.firstInfo.avatar || studentLogo}
+                      />
+                    </div>
+                    <h2 class={'van-ellipsis'}>{state.firstInfo.studentName}</h2>
+                    <p class={[styles.levelTime, 'van-ellipsis']}>
+                      {state.firstInfo.subjectName}-{state.firstInfo.trainTime}分钟
+                    </p>
+                  </>
+                ) : (
+                  <>
+                    <div class={styles.levelUserImg}>
+                      <Image class={styles.img} src={emptyLogo} />
+                    </div>
+                    <h2 class={'van-ellipsis'}>虚位以待</h2>
+                    <p class={[styles.levelTime, 'van-ellipsis']}>&nbsp;</p>
+                  </>
+                )}
               </div>
-              <h2 class={'van-ellipsis'}>夏可可</h2>
-              <p class={[styles.levelTime, 'van-ellipsis']}>竖笛-240分钟</p>
-            </div>
-            <div class={[styles.levelItem, styles.level3]}>
-              <div class={styles.levelUserImg}>
-                <Image
-                  class={styles.img}
-                  src={
-                    'https://ks3-cn-beijing.ksyuncs.com/daya/16644378620311664437783089.jpg'
-                  }
-                />
+              <div class={[styles.levelItem, styles.level3]}>
+                {state.threeInfo.userId ? (
+                  <>
+                    <div class={styles.levelUserImg}>
+                      <Image
+                        class={styles.img}
+                        src={state.threeInfo.avatar || studentLogo}
+                      />
+                    </div>
+                    <h2 class={'van-ellipsis'}>
+                      {state.threeInfo.studentName}
+                    </h2>
+                    <p class={[styles.levelTime, 'van-ellipsis']}>
+                      {state.threeInfo.subjectName}-{state.threeInfo.trainTime}
+                      分钟
+                    </p>
+                  </>
+                ) : (
+                  <>
+                    <div class={styles.levelUserImg}>
+                      <Image class={styles.img} src={emptyLogo} />
+                    </div>
+                    <h2 class={'van-ellipsis'}>虚位以待</h2>
+                    <p class={[styles.levelTime, 'van-ellipsis']}>&nbsp;</p>
+                  </>
+                )}
               </div>
-              <h2 class={'van-ellipsis'}>夏可可</h2>
-              <p class={[styles.levelTime, 'van-ellipsis']}>竖笛-240分钟</p>
             </div>
-          </div>
 
-          <div class={styles.rankList}>
-            <div class={styles.rankTitle}>
-              <div class={styles.titleName}>
-                <img src={timeTitle} />
+            <div class={styles.rankList}>
+              <div class={styles.rankTitle}>
+                <div class={styles.titleName}>
+                  <img src={isDayRank.value ? dayTitle : timeTitle} />
+                </div>
+                <span
+                  class={styles.timeRange}
+                  onClick={() => (state.showPopoverTime = true)}
+                >
+                  {dayjs(forms.startTime).format('YYYY-MM-DD')}至
+                  {dayjs(forms.endTime).format('YYYY-MM-DD')}
+                  <i class={styles.iconArrow}></i>
+                </span>
               </div>
-              <span
-                class={styles.timeRange}
-                onClick={() => (state.showPopoverTime = true)}
-              >
-                {dayjs(forms.startTime).format('YYYY-MM-DD')}至
-                {dayjs(forms.endTime).format('YYYY-MM-DD')}
-                <i class={styles.iconArrow}></i>
-              </span>
+
+              {state.list.map((item: any) => (
+                // i == 4 && styles.active
+                <Cell
+                  class={[
+                    styles.rankItem,
+                    state.myInfo.userId === item.userId ? styles.active : ''
+                  ]}
+                  border={false}
+                  center
+                >
+                  {{
+                    icon: () => (
+                      <>
+                        <span class={styles.num}>{item.rankNum}</span>
+                        <Image
+                          class={styles.userImg}
+                          src={item.avatar || studentLogo}
+                        />
+                      </>
+                    ),
+                    title: () => (
+                      <div class={styles.userInfo}>
+                        <p class={styles.userName}>{item.studentName}</p>
+                        <p class={styles.subjectName}>{item.subjectName}</p>
+                      </div>
+                    ),
+                    value: () => (
+                      <div class={styles.times}>
+                        <span>{item.trainTime}</span>分钟
+                      </div>
+                    )
+                  }}
+                </Cell>
+              ))}
+
+              {!state.loading && !state.listShow && (
+                <ColResult tips="暂无数据" btnStatus={false} />
+              )}
             </div>
+            {state.myInfo?.userId ? (
+              <TheSticky position="bottom">
+                <Cell class={styles.selfInfo} border={false} center>
+                  {{
+                    icon: () => (
+                      <>
+                        <span class={styles.num}>
+                          {state.myInfo.rankNum == -1
+                            ? '-'
+                            : state.myInfo.rankNum}
+                        </span>
+                        <Image
+                          src={state.myInfo.avatar || studentLogo}
+                          class={styles.userImg}
+                        />
+                      </>
+                    ),
+                    title: () => (
+                      <div class={styles.userInfo}>
+                        <p class={styles.userName}>
+                          {state.myInfo.studentName}
+                        </p>
+                        <p class={styles.subjectName}>
+                          {state.myInfo.subjectName}
+                        </p>
+                      </div>
+                    ),
+                    value: () => (
+                      <div class={styles.times}>
+                        <span>{state.myInfo.trainTime}</span>分钟
+                      </div>
+                    )
+                  }}
+                </Cell>
+              </TheSticky>
+            ) : (
+              ''
+            )}
+          </div>
+        // )}
 
-            {[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15].map(() => (
-              <Cell class={styles.rankItem}>
-                {{
-                  icon: () => (
-                    <>
-                      <span class={styles.num}>4</span>
-                      <Image class={styles.userImg} />
-                    </>
-                  ),
-                  title: () => (
-                    <div class={styles.userInfo}>
-                      <p class={styles.userName}>李同学</p>
-                      <p class={styles.subjectName}>竖笛</p>
-                    </div>
-                  ),
-                  value: () => (
-                    <div class={styles.times}>
-                      <span>229</span>分钟
-                    </div>
-                  )
-                }}
-              </Cell>
-            ))}
+        {/* {!state.loading && !state.beforListShow && (
+          <div class={styles.emptyResult}>
+            <ColResult tips="暂无数据" btnStatus={false} />
           </div>
-        </div>
+        )} */}
 
         <Calendar
           v-model:show={state.showPopoverTime}
@@ -205,6 +369,8 @@ export default defineComponent({
               forms.endTime = times.endTime
             }
             state.showPopoverTime = false
+
+            getList()
           }}
         />
       </div>

+ 206 - 0
src/tenant/ranking-list/list.tsx

@@ -0,0 +1,206 @@
+import { defineComponent, reactive } from 'vue'
+import styles from './index.module.less'
+import { Image, Calendar, Cell } from 'vant'
+import timeTitle from './images/time-title.png'
+import dayTitle from './images/day-title.png'
+import { useRoute } from 'vue-router'
+import dayjs from 'dayjs'
+import isBetween from 'dayjs/plugin/isBetween'
+dayjs.extend(isBetween)
+export default defineComponent({
+  name: 'rank-list',
+  setup() {
+    const route = useRoute()
+    const state = reactive({
+      showPopoverTime: false,
+      currentDate: [dayjs().format('YYYY'), dayjs().format('MM')],
+      isClick: false,
+      practiceMonthName: route.query.practiceMonthName
+        ? route.query.practiceMonthName
+        : dayjs().format('YYYY') + '年' + dayjs().format('MM') + '月',
+      userTrainOverView: {
+        trainDays: 0,
+        trainNum: 0,
+        trainTime: 0,
+        avgTrainTime: 0
+      },
+      userTrainChartData: [] as any,
+      myChart: null as any
+    })
+
+    // 初始化周一
+    const formatWeekDays = (time?: any) => {
+      const week = dayjs(time).day()
+      let startTime = ''
+      let endTime = ''
+      if (week === 0) {
+        // 星期天
+        startTime = dayjs(time).subtract(6, 'day').format('YYYY-MM-DD')
+        endTime = dayjs(time).format('YYYY-MM-DD')
+      } else if (week === 1) {
+        // 星期一
+        startTime = dayjs(time).format('YYYY-MM-DD')
+        endTime = dayjs(time).add(6, 'day').format('YYYY-MM-DD')
+      } else {
+        startTime = dayjs(time)
+          .subtract(week - 1, 'day')
+          .format('YYYY-MM-DD')
+        endTime = dayjs(time)
+          .add(7 - week, 'day')
+          .format('YYYY-MM-DD')
+      }
+      return {
+        startTime,
+        endTime
+      }
+    }
+
+    const forms = reactive({
+      ...formatWeekDays(),
+      page: 1,
+      rows: 20
+    })
+    return () => (
+      <>
+        <div class={styles.rankContainer}>
+          <div class={styles.rankLevel}>
+            <div class={[styles.levelItem, styles.level2]}>
+              <div class={styles.levelUserImg}>
+                <Image
+                  class={styles.img}
+                  src={
+                    'https://ks3-cn-beijing.ksyuncs.com/daya/16644378620311664437783089.jpg'
+                  }
+                />
+              </div>
+              <h2 class={'van-ellipsis'}>夏可可夏可可夏可可夏可可</h2>
+              <p class={[styles.levelTime, 'van-ellipsis']}>
+                夏可可夏可可竖笛-240分钟
+              </p>
+            </div>
+            <div class={[styles.levelItem, styles.level1]}>
+              <div class={styles.levelUserImg}>
+                <Image
+                  class={styles.img}
+                  src={
+                    'https://ks3-cn-beijing.ksyuncs.com/daya/16644378620311664437783089.jpg'
+                  }
+                />
+              </div>
+              <h2 class={'van-ellipsis'}>夏可可</h2>
+              <p class={[styles.levelTime, 'van-ellipsis']}>竖笛-240分钟</p>
+            </div>
+            <div class={[styles.levelItem, styles.level3]}>
+              <div class={styles.levelUserImg}>
+                <Image
+                  class={styles.img}
+                  src={
+                    'https://ks3-cn-beijing.ksyuncs.com/daya/16644378620311664437783089.jpg'
+                  }
+                />
+              </div>
+              <h2 class={'van-ellipsis'}>夏可可</h2>
+              <p class={[styles.levelTime, 'van-ellipsis']}>竖笛-240分钟</p>
+            </div>
+          </div>
+
+          <div class={styles.rankList}>
+            <div class={styles.rankTitle}>
+              <div class={styles.titleName}>
+                <img src={timeTitle} />
+              </div>
+              <span
+                class={styles.timeRange}
+                onClick={() => (state.showPopoverTime = true)}
+              >
+                {dayjs(forms.startTime).format('YYYY-MM-DD')}至
+                {dayjs(forms.endTime).format('YYYY-MM-DD')}
+                <i class={styles.iconArrow}></i>
+              </span>
+            </div>
+
+            {[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15].map(() => (
+              <Cell class={styles.rankItem} border={false} center>
+                {{
+                  icon: () => (
+                    <>
+                      <span class={styles.num}>4</span>
+                      <Image class={styles.userImg} />
+                    </>
+                  ),
+                  title: () => (
+                    <div class={styles.userInfo}>
+                      <p class={styles.userName}>李同学</p>
+                      <p class={styles.subjectName}>竖笛</p>
+                    </div>
+                  ),
+                  value: () => (
+                    <div class={styles.times}>
+                      <span>229</span>分钟
+                    </div>
+                  )
+                }}
+              </Cell>
+            ))}
+          </div>
+
+          <TheSticky position="bottom">
+            <Cell class={styles.selfInfo} border={false} center>
+              {{
+                icon: () => (
+                  <>
+                    <span class={styles.num}>4</span>
+                    <Image class={styles.userImg} />
+                  </>
+                ),
+                title: () => (
+                  <div class={styles.userInfo}>
+                    <p class={styles.userName}>李同学</p>
+                    <p class={styles.subjectName}>竖笛</p>
+                  </div>
+                ),
+                value: () => (
+                  <div class={styles.times}>
+                    <span>229</span>分钟
+                  </div>
+                )
+              }}
+            </Cell>
+          </TheSticky>
+        </div>
+
+        <Calendar
+          v-model:show={state.showPopoverTime}
+          firstDayOfWeek={1}
+          showConfirm={false}
+          type="range"
+          title="周期选择"
+          maxRange={7}
+          minDate={new Date('2023-02-27')}
+          defaultDate={[
+            dayjs(forms.startTime).toDate(),
+            dayjs(forms.endTime).toDate()
+          ]}
+          style={{
+            height: '70%'
+          }}
+          onSelect={(item: any) => {
+            forms.startTime = ''
+            forms.endTime = ''
+            if (
+              !dayjs(item[0]).isBetween(
+                dayjs(forms.startTime),
+                dayjs(forms.endTime)
+              )
+            ) {
+              const times = formatWeekDays(item[0])
+              forms.startTime = times.startTime
+              forms.endTime = times.endTime
+            }
+            state.showPopoverTime = false
+          }}
+        />
+      </>
+    )
+  }
+})