瀏覽代碼

优化日历显示

lex-xin 4 年之前
父節點
當前提交
3edd961feb

文件差異過大導致無法顯示
+ 0 - 0
dist/app.5b97666849af2f03afbf.js


+ 0 - 0
dist/css/PeriodAdjust~PeriodChange.b77fbbe2.css → dist/css/PeriodAdjust~PeriodChange.c4040131.css


+ 1 - 0
dist/css/PeriodChange.7419b810.css

@@ -0,0 +1 @@
+.periodchange[data-v-8218d4fe]{height:100vh;position:relative;background-color:#f3f4f8}.periodchange .container[data-v-8218d4fe]{min-height:calc(100vh - .5rem);overflow-y:auto;overflow-x:hidden;position:relative}.periodchange .button-group[data-v-8218d4fe]{width:100%}.periodchange .button-group .van-button[data-v-8218d4fe]{font-size:.16rem;width:100%;height:.5rem;line-height:.48rem}.periodchange .button-group .van-button--primary[data-v-8218d4fe]{background:#14928a;border-color:#14928a}[data-v-8218d4fe] .van-cell{line-height:inherit}[data-v-8218d4fe] .van-cell__title{font-size:.16rem;color:#444}[data-v-8218d4fe] .van-cell-group{margin-top:.05rem}.title-content[data-v-8218d4fe]{font-weight:700}.title-content .van-cell__label[data-v-8218d4fe]{font-weight:400;margin-top:.06rem;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.title-content .van-icon-location[data-v-8218d4fe]{margin-right:.05rem}[data-v-8218d4fe] .van-cell__label,[data-v-8218d4fe] .van-cell__value{color:#777}[data-v-8218d4fe] .van-cell__label span,[data-v-8218d4fe] .van-cell__value span{padding-right:.1rem}.input-cell[data-v-8218d4fe]{padding:.12rem .16rem .2rem}.input-cell .van-radio[data-v-8218d4fe]{-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}[data-v-8218d4fe] .van-radio__icon .van-icon{border-color:#aaa}[data-v-8218d4fe] .van-radio__icon--checked .van-icon{background:#f97215;border-color:#f97215}[data-v-8218d4fe] .icon{margin-top:.2rem}

+ 0 - 1
dist/css/PeriodChange.a713d6df.css

@@ -1 +0,0 @@
-.periodchange[data-v-cce84b9a]{height:100vh;position:relative;background-color:#f3f4f8}.periodchange .container[data-v-cce84b9a]{min-height:calc(100vh - .5rem);overflow-y:auto;overflow-x:hidden;position:relative}.periodchange .button-group[data-v-cce84b9a]{width:100%}.periodchange .button-group .van-button[data-v-cce84b9a]{font-size:.16rem;width:100%;height:.5rem;line-height:.48rem}.periodchange .button-group .van-button--primary[data-v-cce84b9a]{background:#14928a;border-color:#14928a}[data-v-cce84b9a] .van-cell{line-height:inherit}[data-v-cce84b9a] .van-cell__title{font-size:.16rem;color:#444}[data-v-cce84b9a] .van-cell-group{margin-top:.05rem}.title-content[data-v-cce84b9a]{font-weight:700}.title-content .van-cell__label[data-v-cce84b9a]{font-weight:400;margin-top:.06rem;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.title-content .van-icon-location[data-v-cce84b9a]{margin-right:.05rem}[data-v-cce84b9a] .van-cell__label,[data-v-cce84b9a] .van-cell__value{color:#777}[data-v-cce84b9a] .van-cell__label span,[data-v-cce84b9a] .van-cell__value span{padding-right:.1rem}.input-cell[data-v-cce84b9a]{padding:.12rem .16rem .2rem}.input-cell .van-radio[data-v-cce84b9a]{-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}[data-v-cce84b9a] .van-radio__icon .van-icon{border-color:#aaa}[data-v-cce84b9a] .van-radio__icon--checked .van-icon{background:#f97215;border-color:#f97215}[data-v-cce84b9a] .icon{margin-top:.2rem}

文件差異過大導致無法顯示
+ 0 - 0
dist/index.html


文件差異過大導致無法顯示
+ 0 - 0
dist/js/PeriodAdjust.7af7bdf0.js


文件差異過大導致無法顯示
+ 0 - 0
dist/js/PeriodAdjust.edbd3bea.js


文件差異過大導致無法顯示
+ 0 - 0
dist/js/PeriodAdjust~PeriodChange.83ace5da.js


文件差異過大導致無法顯示
+ 0 - 0
dist/js/PeriodAdjust~PeriodChange.f42c717f.js


文件差異過大導致無法顯示
+ 0 - 0
dist/js/PeriodChange.4ff1e84f.js


文件差異過大導致無法顯示
+ 0 - 0
dist/js/PeriodChange.7a08c75b.js


+ 47 - 26
src/views/teacher/PeriodChange.vue

@@ -2,7 +2,7 @@
     <div class="periodchange">
         <div :class="[dataShow ? 'container' : '']">
             <!-- <m-header /> -->
-            <m-calendar @onSelectDay="onSelectDay" />
+            <m-calendar @onSelectDay="onSelectDay" :dayList="getMonthDay" @onChangeMonth="onChangeMonth" />
 
             <van-radio-group v-if="dataShow" key="data" v-model="radioSelect">
                 <van-cell-group v-for="(item, index) in dataList" :key="index">
@@ -34,9 +34,11 @@
 // import MHeader from '@/components/MHeader'
 import MCalendar from '@/components/MCalendar'
 import MEmpty from '@/components/MEmpty'
+import dayjs from 'dayjs'
 import { browser }  from '@/common/common'
-import { getCourseSchedulesWithDate, 
+import { getCourseSchedulesWithDate,
     getCourseScheduleDateByMonth, courseSwap } from '@/api/teacher'
+import setLoading from '@/utils/loading'
 export default {
     name: 'periodchange',
     components: { MCalendar, MEmpty },
@@ -47,12 +49,13 @@ export default {
             radioSelect: null,
             radioSelectList: [], // 选中的列表
             radioDisabled: true, // 今天或今天之前的数据禁用
+            getMonthDay: []
         }
     },
     created() {
-        document.title = '课程交换'
-        let toDay = this.getFormartDate(new Date())
-        this.getCourseDate(toDay)
+        
+        // let toDay = this.getFormartDate(new Date())
+        // this.getCourseDate(toDay)
     },
     mounted() {
         let params = this.$route.query
@@ -60,7 +63,10 @@ export default {
             localStorage.setItem('Authorization', decodeURI(params.Authorization))
             localStorage.setItem('userInfo', decodeURI(params.Authorization))
         }
-        // this.getCourseMonth(toDay)
+        document.title = '课程交换'
+        let toDay = this.getFormartDate(new Date())
+        this.getCourseMonth(toDay)
+        this.getCourseDate(toDay)
     },
     methods: {
         onSelectDay(value) {
@@ -71,31 +77,46 @@ export default {
             }
             this.getCourseDate(this.getFormartDate(value))
         },
+        onChangeMonth(value) {
+            this.getCourseMonth(dayjs(value).format('YYYY-MM-DD'))
+        },
+        async getCourseMonth(month) {
+            setLoading(true)
+            try {
+                await getCourseScheduleDateByMonth({ month: month, type: 'VIP' }).then(res => {
+                    let result = res.data
+                    if(result.code == 200) {
+                        this.getMonthDay = []
+                        result.data.forEach(item => {
+                            this.getMonthDay.push(dayjs(item).format('DD'))
+                        })
+                        this.isCalendar = true
+                    }
+                })
+                setLoading(false)
+            } catch(err) {
+                setLoading(false)
+            }
+        },
         onCheckRadio(item) { // 单选按钮选中
             if(this.radioDisabled) return
             this.radioSelect = item.id
             this.radioSelectList = item
         },
-        getCourseDate(date) {
-            getCourseSchedulesWithDate({ date: date, type: 'VIP' }).then(res => {
-                let result = res.data
-                if(result.code == 200 && result.data) {
-                    this.dataList = result.data.rows
-                    this.dataShow = result.data.rows.length > 0 ? true : false
-                }
-            })
-        },
-        getCourseMonth(month) {
-            getCourseScheduleDateByMonth({ month: month, type: 'VIP' }).then(res => {
-                let result = res.data
-                if(result.code == 200) {
-                    result.data.forEach(item => {
-                        let tempDate = new Date(item)
-                        this.getMonthDay.push(tempDate.getDate())
-                    })
-                    this.isCalendar = true
-                }
-            })
+        async getCourseDate(date) {
+            setLoading(true)
+            try {
+                await getCourseSchedulesWithDate({ date: date, type: 'VIP' }).then(res => {
+                    let result = res.data
+                    if(result.code == 200 && result.data) {
+                        this.dataList = result.data.rows
+                        this.dataShow = result.data.rows.length > 0 ? true : false
+                    }
+                })
+                setLoading(false)
+            } catch(err) {
+                setLoading(false)
+            }
         },
         getFormartDate(date) {
             let checkDate = new Date(date)

部分文件因文件數量過多而無法顯示