index.vue 11.1 KB
<template>
<div class='container'>
  <form class="baseinfo-box" @submit='commit'>
    <div class="baseinfo">
    <div class="list-input">
      <span>值班人</span>
      <p class="text_right">{{name}}</p>
    </div>
    <div class="list-input">
      <span>值班日期</span>
      <div class="datebox">
        <!--<picker class="date" v-model="startDate" mode='date' :value='startDate' @change="pickerConfirm($event,'date')">
          <div hover-class='hover' :class="{unset:startDate==''}">{{startDate || '选择日期'}}</div>
        </picker>-->
        <picker class="date" v-model="startDate" mode='date' :value='startDate' @change="pickerConfirm($event,'date')">
          <div hover-class='hover' :class="{unset:startDate==''}">{{startDate || '选择日期'}}</div>
        </picker>
      </div>
    </div>
    <div class="list-input">
      <span>值班社区</span>
      <p class="text_right">{{commName}}</p>
    </div>
    <div class='greytitle'>值班证明图片</div>
    <div class="img-box" style='background:white;'>
      <div class='image' v-for="(item,i) in imgfiles" :key="i" @tap='previewImg(i)'>
        <img :src="item" mode='aspectFill'>
        <div @tap.stop='cancelImg(i)'><img src='/static/imgs/cancel.png'></div>
      </div>
      <div hover-class='fade' class='upload' @tap="chooseImage"><img src=''></div>
    </div>
    <div class='commit'>
      <button form-type='submit' hover-class='fade' :disabled='commiting' bindtap='submit'>提交</button>
    </div>
  </div>
  </form>
</div>
</template>
<script>
  export default {
    data() {
      return {
        SCID: '',
        name: '',
        commName: '',
        startDate: '',
        commiting: false,
        loaded: false,
        imgfiles: []
      }
    },
    methods: {
      commit(e){
        if(this.commiting) return
        if(!this.service.checkEmptyInput([this.startDate,this.commName,this.imgfiles,this.SCID],['值班日期','值班社区','值班证明图片','值班社区'])){
          return
        }
        wx.showModal({
          title:'',
          content:'确定要提交吗?',
          success: res => {
            if(res.confirm){
              this.execCommit(e)
            }
          }
        })
      },
      execCommit(e){
        this.commiting = true
        wx.showLoading({ title: '正在提交' })
        wx.request({
          url: this.rootUrl + 'duty/add',
          method: 'POST',
          header: { 'content-type': 'application/x-www-form-urlencoded' },
          data: {
            duty_date: this.startDate,
            SCID: this.SCID,
            sessionID: wx.getStorageSync('sessionID')
          },
          success: res => {
            console.log(res)
            if (res.statusCode == '500') {
              this.service.getUnionId(this.rootAvatar, this.rootUrl).then(res => this.submit_exec(content))
            } else {
              wx.hideLoading()
              if (res.data > 0) {
                this.upLoadImgs(res.data)
                wx.showModal({
                  title: '提交成功',
                  content: '',
                  showCancel: false
                })
                wx.hideLoading()
              } else {
                wx.showToast({ title: '提交失败', icon: 'none' })
              }
              this.commiting = false
              this.toHomelist()
            }
          }
        })
      },
      loadArticles () {
        this.getLawName()
      },
      // /*根据时间和当前律师获取值班街道*/
      getLawStreet(){
        wx.request({
          url: this.rootUrl + '/sch/getLawStreet',
          method: 'POST',
          header: { 'content-type': 'application/x-www-form-urlencoded' },
          data: {
            Schedule_Date: this.startDate,
            sessionID: wx.getStorageSync('sessionID')},
          success: res => {
            console.log(res.data)
              this.commName = res.data.comm_Name
               this.SCID = res.data.scid
          }
        })
      },
      // /*获取值班律师的姓名*/
      getLawName(){
        wx.showLoading({ title: '正在加载' })
        wx.request({
          url: this.rootUrl + '/law/getLawName',
          method: 'GET',
          header: { 'content-type': 'application/x-www-form-urlencoded' },
          data: { sessionID: wx.getStorageSync('sessionID')},
          success: res => {
            console.log(res)
            // this.name = res.data[0].name
            if(undefined != res.data[0].name){
              this.name = res.data[0].name
            }else{
              this.name = ''
            }
            wx.hideLoading()
          }
        })
      },
      //回到首页
      toHomelist: function () {
        wx.navigateBack({
          // url: '../homelist'
          delta: 1
        })
      },
      pickerConfirm(e, s) {
        switch (s) {
          case 'date': this.startDate = e.mp.detail.value;break
        }
        this.getLawStreet()
      },
      upLoadImgs(id) {
        wx.showLoading({ title: '正在上传图片' })
        const time = this.imgfiles.length
        let counter = time
        for(let i = 0; i < time; i++){
          wx.uploadFile({
            url: this.rootUrl + 'duty/addpic',
            filePath: this.imgfiles[i],
            formData: {
              id,
              filetype: 0
            },
            name: 'file',
            header: {
              'content-type': 'multipart/form-data'
            },
            success: res => {
              if(res.data == 1){
                console.log(res)
                wx.showLoading({ title: `图片上传成功` })
                wx.hideLoading()
                //
              }else{
                wx.showLoading({ title: `图片上传失败` })
                wx.hideLoading()
                //
              }
            },
            fail: res => {
              wx.hideLoading()
              wx.showToast({title:'上传失败',icon: 'none'})
              this.commiting = false
            }
          })
        }
      },
      chooseImage() {
        const count = 6 - this.imgfiles.length
        if(count==0){
          if(!wx.showModal({
            title: '上传限制',
            content: '图片数量上限为6张\n请删除部分图片后再上传新图片',
            showCancel: false,
            success: res => {
              if(res.confirm){return false}
            }
          })){return}
        }
        wx.chooseImage({
          count,
          sizeType: ['compressed'],
          success: res => {
            console.log(res)
            this.imgfiles = this.imgfiles.concat(res.tempFilePaths)
          }
        })
      },
      cancelImg(i){
        wx.showModal({
          title:'',
          content: '放弃上传这张照片吗?',
          success: res => {
            if(res.confirm){
              this.imgfiles.splice(i, 1)
            }
          }
        })
      },
      previewImg(i){
        wx.previewImage({
          urls: this.imgfiles,
          current: this.imgfiles[i]
        })
      }
    },
    onLoad() {
      this.getLawName()
    },
    onShow(){
      this.loadArticles()
    },
    onUnload() {
      this.commName = ''
      this.name = ''
      this.imgfiles = []
      this.loaded = false
    }
  }
</script>
<style lang="stylus" scoped>
.container
  position absolute
  min-height 100%
  width 100%
  Background()
  .baseinfo-box
    Background()
.datebox
  margin-right 0 !important
  width 100%
  text-align right
.date
  float right
  width 180rpx
.img-box
  padding 0 30rpx 30rpx 30rpx
  .image
    position relative
    > img
      Height_Width(100%)
    div
      position absolute
      top 0
      right 0
      background rgba(0,0,0,.5)
      Height_Width(100% / 5)
      Flex(flex,center,center)
      border-radius 0 0 0 10rpx
      img
        Height_Width(60%)
  .upload
    Flex(flex,center,center)
    background #f5f5f5
    img
      Height_Width(40%)
.text_right
  display: block;
  text-align: right;
  width: 100%;
  padding-right: 30rpx;
</style>