进餐页

<!-- 进餐  -->
<template>
    <view class="content">
        <!-- 导航栏 -->
        <mynavGeneral mTitle="每日进餐" :immersionShow="immersionShow"></mynavGeneral>

        <view :style="{'margin-top':contentMarginTop+'px'}">
            <view class="topPanel">
                <view class="header">
                    <view class="zk_pressed1" @click="$Router.push({name:'health-dining-setting'})">
                        <label class="iconfont iconbutton_icon_surface"></label>
                        <text>设置时间</text>
                    </view>
                    <view class="zk_pressed1" @click="$Router.push({name:'health-dining-his'})">
                        <label class="iconfont iconicon_record"></label>
                        <text>历史记录</text>
                    </view>
                </view>
                
                <view class="ctn">
                    
                    <view class="itm" @click="clockIn(1, '', a)">
                        <text>今日早餐</text>
                        <image src="../../static/icon/icon_punch2.png"></image>
                        <text>打卡时间 {{breakfast_time}}</text>
                        <text v-if="a" class="unsign">已打卡</text>
                        <text v-else class="sign">去打卡</text>
                    </view>
                    <view class="itm" @click="clockIn(2, '', b)">
                        <text >今日午餐</text>
                        <image src="../../static/icon/icon_punch3.png"></image>
                        <text>打卡时间 {{lunch_time}}</text>
                        <text v-if="b" class="unsign">已打卡</text>
                        <text v-else class="sign">去打卡</text>
                    </view>
                    <view class="itm" @click="clockIn(3, '', c)">
                        <text>今日晚餐</text>
                        <image src="../../static/icon/icon_punch4.png"></image>
                        <text>打卡时间 {{dinner_time}}</text>  
                        <text v-if="c" class="unsign">已打卡</text>
                        <text v-else class="sign">去打卡</text>
                    </view>
                </view>
            </view>

            <view class="zk_title1" style="margin-top:30px;padding-left: 10px;color: white;">一周食谱 健康饮食生活</view>
            <view style="margin-top:9px;padding-left: 10px;color: white;">369887人已参与 持续改善饮食习惯</view>

            <!--  -->
            
            <view class="weeks">
                <text @click="switchWeek(index)" :key="index" v-for="(item,index) in weeks" class="item zk_pressed1"
                 :class="{active:curWeekIndex==index}">{{item.display}}</text>
            </view>
            <!--  -->
            <view style="margin-top: 5px;margin-bottom: 52px;" class="menuList">
                <scroll-view scroll-x="true">
                    <view style="white-space: nowrap;">
                        <view class="menuItem zk_pressed1" @click="$Router.push({name:'health-dining-detail'})">
                            <view class="header">
                                <text style="flex:1;font-size: 18px;font-weight: bold;">早餐</text>
                                <text style="font-size: 10px;">更多</text>
                            </view>
                            <view style="display: flex;">
                                <view class="itmm" v-for="item in breakfast" :key="index">
                                    <!-- <image src="/static/logo.png"></image>  -->
                                    <image :src="item.images"></image>
                                    <view class="txt">
                                        <view style="font-size: 12px;">{{item.name}}</view>
                                        <view style="font-size: 9px;color: #999999;margin: 2px 0;">{{item.weight}}</view>
                                        <view style="font-size: 9px;color: #999999;">{{item.calorie}}</view>
                                    </view>
                                </view>
                            </view>
                        </view>
                        <view class="menuItem zk_pressed1" @click="$Router.push({name:'health-dining-detail'})">
                            <view class="header">
                                <text style="flex:1;font-size: 18px;font-weight: bold;">午餐</text>
                                <text style="font-size: 10px;">更多</text>
                            </view>
                            <view style="display: flex;">
                                <view class="itmm" v-for="item in lunch" :key="index">
                                    <!-- <image src="/static/logo.png"></image>  -->
                                    <image :src="item.images"></image>
                                    <view class="txt">
                                        <view style="font-size: 12px;">{{item.name}}</view>
                                        <view style="font-size: 9px;color: #999999;margin: 2px 0;">{{item.weight}}</view>
                                        <view style="font-size: 9px;color: #999999;">{{item.calorie}}</view>
                                    </view>
                                </view>
                            </view>
                        </view>
                        <view class="menuItem zk_pressed1"  @click="$Router.push({name:'health-dining-detail'})">
                            <view class="header">
                                <text style="flex:1;font-size: 18px;font-weight: bold;">晚餐</text>
                                <text style="font-size: 10px;">更多</text>
                            </view>
                            <view style="display: flex;">
                                <view class="itmm" v-for="item in dinner" :key="index">
                                    <!-- <image src="/static/logo.png"></image>  -->
                                    <image :src="item.images"></image>
                                    <view class="txt">
                                        <view style="font-size: 12px;">{{item.name}}</view>
                                        <view style="font-size: 9px;color: #999999;margin: 2px 0;">{{item.weight}}</view>
                                        <view style="font-size: 9px;color: #999999;">{{item.calorie}}</view>
                                    </view>
                                </view>
                            </view>
                        </view>
                    </view>
                </scroll-view>
            </view>
        </view>
    </view>
</template>

<script lang="ts">
    import Vue from 'vue';
    import mynavGeneral from '@/components/mynav-general/mynav-general.vue'
    import { HealthService } from '@/services/HealthService'
    
    export default Vue.extend({
        components: {
            mynavGeneral
        },
        data() {
            return {
                // 是否展示 导航栏 阴影
                immersionShow: false,
                contentMarginTop: 0,
                curWeekIndex: 0,
                currentData: [],
                list:[],
                meal_type:1,
                time:null,
                breakfast_time:"未设置",
                lunch_time:"未设置",
                dinner_time:"未设置",
                a:0,
                b:0,
                c:0,
                breakfast:[],
                lunch:[],
                dinner:[],
                total:[],
                weeks:[
                    {display:"周天",date:""},
                    {display:"周一",date:""},
                    {display:"周二",date:""},
                    {display:"周三",date:""},
                    {display:"周四",date:""},
                    {display:"周五",date:""},
                    {display:"周六",date:""}
                ]
                
            }
        },
        
        onLoad() {
            var that: any = getApp();
            this.contentMarginTop = that.globalData.immersionAppBarHeight
            
            var d:any = new Date()
            // 今日
            this.date = `${d.getFullYear()}-${d.getMonth()>9?'':'0'}${d.getMonth()+1}-${d.getDate()>9?'':'0'}${d.getDate()}`
            
            this.getRemind();
            
            // this.requestTodayData(this.date);
            
            this.getRecord(this.date);
            
            this.getWeekRecipes();
            
            // this.getWeekRecipes();
            // 计算 weeks date
            var _day:any = d.getDay()
            
            for(var i=_day,j=0;i<this.weeks.length;i++,j++){
                
                var _tm:any = new Date(d.getTime()+(j*1000*60*60*24))
                
                this.weeks[i].date = `${_tm.getFullYear()}-${_tm.getMonth()>9?'':'0'}${_tm.getMonth()+1}-${_tm.getDate()>9?'':'0'}${_tm.getDate()}`
            }
            
            for(var i=(_day-1),j=1;i>=0;i--,j++){
                
                var _tm:any = new Date(d.getTime()-(j*1000*60*60*24))
                
                this.weeks[i].date = `${_tm.getFullYear()}-${_tm.getMonth()>9?'':'0'}${_tm.getMonth()+1}-${_tm.getDate()>9?'':'0'}${_tm.getDate()}`
            }
            
            console.log(JSON.stringify(this.weeks))
        },
        
        
        methods: {
            switchWeek(index: any) {
                
                this.curWeekIndex = index;
                // this.getWeekRecipes();
                this.getOneDay(this.weeks[index].date);
                
            },
            requestTodayData(dt:any){
                var that:any = this 
                
                new HealthService().getRecord(dt)
                .then((data:any)=>{
                    if(data.code!=1) return
                    
                    that.list = data.data
                    
                    var _b:any = that.list.filter((i:any)=>i.meal_type==1)
                    if(_b&&_b.length>0)
                    that.breakfast_time = _b[0].time
                    
                    
                    _b = that.list.filter((i:any)=>i.meal_type==2)
                    if(_b&&_b.length>0)
                    that.lunch_time= _b[0].time
                    
                    _b = that.list.filter((i:any)=>i.meal_type==3)
                    if(_b&&_b.length>0)
                    that.dinner_time= _b[0].time
                })
                .catch((error:any)=>{
                    that.alert(error.msg)
                })
            },
            //获取设置
            getRemind(){
                var that:any = this
                
                new HealthService().getRemindSett()
                .then((data:any)=>{
                    if(data.code==1){
                        
                        that.breakfast_time = data.data.breakfast_time;
                        that.lunch_time = data.data.lunch_time;
                        that.dinner_time = data.data.dinner_time;
                        that.lead_time = data.data.lead_time+"分钟";
                        
                        return;
                    }
                    
                    this.requestTodayData(this.date);
                    
                })
                .catch((error:any)=>{
                    that.alert(error.msg)
                })
            },
            //获取打卡列表
            getRecord(date:any){
                var that:any = this
                
                var weekDay = ["星期天", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"];
                var b = new Date(Date.parse(date.replace(/\-/g,"/")));
                this.curWeekIndex = b.getDay();
                
                new HealthService().getRecord(date)
                .then((data:any)=>{
                    // if(data.code==1){
                    //     that.date=data.data.date
                    // }
                    if (data.code == 1) {
                        let a = 0, b = 0, c = 0;
                        if (data.data.length) {
                          data.data.forEach((el:any) => {
                            
                            if (el.meal_type == 1) {
                                a = 1
                            } 
                            if (el.meal_type == 2) {
                                b = 1
                            } 
                            if (el.meal_type == 3) {
                                c = 1
                            }
                          });
                        }
            
                        this.a = a;
                        this.b = b;
                        this.c = c;
                      }
                })
                .catch((error:any)=>{
                    that.alert(error.msg)
                })
            },
            clockIn(meal_type:any,tt:any,num:any){
                var that:any = this
                
                if(num==1) return;
                
                new HealthService().clockIn(meal_type)
                .then((data:any)=>{
                    if(data.code==1){
                        
                        var time:any = new Date(data.data.time*1000);
                        time = `${time.getHours()>9?'':'0'}${time.getHours()}:${time.getMinutes()>9?'':'0'}${time.getMinutes()}`
                        
                        if(meal_type==1){
                            that.a = 1
                            that.breakfast_time = time
                        }
                        else if(meal_type==2){
                            that.b = 1
                            that.lunch_time = time
                        }
                        else if(meal_type==3){
                            that.c = 1
                            that.dinner_time = time
                        }
                        
                        console.log(data);
                        that.meal_type = data.data.meal_type;
                        that.time = data.data.time;
                        return;
                        
                    }
                    
                })
                .catch((error:any)=>{
                    that.alert(error.msg)
                })
                
            },
            //获取一周的食谱
            getWeekRecipes(){
                var that:any = this
                
                new HealthService().getWeekRecipes()
                .then((data:any)=>{
                    if(data.code==1){
                        
                        
                        that.list = data.data 
                        
                        
                        that.switchWeek(new Date().getDay())
                        
                        // that.breakfast = data.data[0].breakfast
                        // that.lunch = data.data[1].lunch
                        // that.dinner = data.data[2].dinner
                        // console.log("breakfast"+ data.data[0].breakfast);
                        // that.time = data.data.time
                        
                        
                    }
                    
                })
                .catch((error:any)=>{
                    that.alert(error.msg)
                })
                
            },
            getOneDay(time: any) {
                var res:any = this.list.filter((i:any)=>i.time==time)
                
                if(res&&res.length>0){
                    this.breakfast = res[0].breakfast
                                this.lunch = res[0].lunch
                                this.dinner = res[0].dinner
                }
                
        //         this.list.forEach((item) => {
        //           if (item.time == time) {
        //             this.breakfast = item.breakfast
        //             this.lunch = item.lunch
        //             this.dinner = item.dinner
        //           }
        //         })
                
              }
            
        },
        
        onPageScroll(e: any) {
            this.immersionShow = e.scrollTop >= 10
        }
    })
</script>

<style>
    page {
        background-color: #97C56B;
    }

    .topPanel {
        border-radius: 0 0 0 50px;
        background-color: white;
        padding-bottom: 30px;
    }

    .topPanel>.header {
        padding: 20px 10px;
        color: #326DE8;
        font-size: 15px;
        display: inline-block;
        width: 100%;
    }

    .topPanel>.header label {
        margin-right: 5px;
        font-size: 15px;
    }

    .topPanel>.header>view {
        display: inline-block;
    }

    .topPanel>.header>view:nth-child(2) {
        margin-left: 35px;
    }

    /*  */
    .ctn {
        padding: 14px 10px;
        display: flex;
    }

    .ctn .itm {
        display: flex;
        flex-direction: column;
        align-items: center;
        flex: 1;
        background-color: white;
        box-shadow: #8080801A 1px 0px 17px;
        margin-right: 5px;
        border-radius: 10px;
    }

    .ctn .itm :nth-last-child(1) {
        margin-right: 0px;
    }

    .ctn .itm>text:nth-child(1) {
        font-size: 15px;
        font-weight: bold;
        margin-top: 10px;
    }

    .ctn .itm image {
        height: 43px;
        width: 43px;
        margin: 11px 0;
    }

    .ctn .itm>text:nth-child(3) {
        font-size: 13px;
        margin-bottom: 18.5px;
        color: #999999;
    }

    .ctn .itm>text:nth-child(4) {
        font-size: 13px;
        margin-bottom: 10px;
        height: 20px;
        border-radius: 10px;
        background-color: #DCDCDC;
        color: white;
        min-width: 60px;
        /* padding: 0px 11px; */
        display: flex;
        justify-content: center;
        align-items: center;
    }

    /*  */
    .weeks {
        padding: 31px 10px;
        display: flex;
        justify-content: space-between;
    }

    .weeks .active {
        background-color: #5B8232;
        color: white !important;
    }

    .weeks .item {
        height: 20px;
        border-radius: 10px;
        font-size: 13px;
        color: #5B8232;
        min-width: 45px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    /*  */
    .menuList {}

    .menuList .menuItem {
        background-color: #FFFFFF7f;
        border-radius: 15px;
        margin-left: 10px;
        display: inline-block;
        padding-bottom: 27px;
    }

    .menuList .menuItem:nth-last-child(1) {
        margin-right: 10px;
    }

    .menuList .menuItem>.header {
        display: flex;
        align-items: center;
        padding: 19.5px 5px 15px 5px;
    }

    .menuList .menuItem .itmm {
        display: flex;
        flex-direction: column;
    }

    .menuList .menuItem .itmm .txt {
        padding-left: 5px;
        padding-top: 15px;
    }

    .menuList .menuItem .itmm image {
        height: 60px;
        width: 60px;
        margin-left: 5px;
        border-radius: 4px;
    }

    .menuList .menuItem .itmm:nth-last-child(1) image {
        margin-right: 5px;
    }
    .sign{
        background-color: #81C22D!important;
    }
    
</style>

 

posted @ 2020-08-18 17:03  小平头~  阅读(160)  评论(0编辑  收藏  举报