<template>
  <div class="create-container" v-loading="loading">
    <div class="title h1" v-if="!isModifyMode">任务</div>
    <div class="create-body">
      <div class="title h2" v-if="!isModifyMode">基本信息</div>
      <el-row :gutter="20">
        <el-col :span="15">
          <el-form :model="task" :rules="rules" ref="task" label-width="120px" class="demo-task"
                   style="margin:0 80px;">
            <el-form-item label="任务名称" prop="title" style="width: 700px;">
              <el-input size="small" v-if="isModifyMode" v-model="task.title"></el-input>
              <span v-if="!isModifyMode">{{task.title}}</span>
              <el-tag v-if="!isModifyMode" :type="task.statusVO&&task.statusVO.style">{{task.statusVO ?
                task.statusVO.text:''}}
              </el-tag>
            </el-form-item>
            <el-form-item label="任务描述" prop="desc" style="width: 700px;">
              <el-input autosize v-if="isModifyMode" type="textarea" v-model="task.description"></el-input>
              <span v-if="!isModifyMode">{{task.description ? task.description : '暂无'}}</span>
            </el-form-item>
            <el-form-item label="任务报价" prop="quotePrice" style="width: 700px;">
              <el-input size="small" type="number" v-if="isModifyMode" v-model="task.quotePrice">
                <template slot="append">¥</template>
              </el-input>
              <span v-if="!isModifyMode">¥{{task.quotePrice}}</span>
            </el-form-item>
            <!--<el-form-item type="number" label="任务定价" prop="fixedPrice">-->
            <!--<el-input v-if="isModifyMode" v-model="task.fixedPrice">-->
            <!--<template slot="append">¥</template>-->
            <!--</el-input>-->
            <!--<span v-if="!isModifyMode">{{task.fixedPrice}}</span>-->
            <!--</el-form-item>-->
            <el-form-item label="测试类型" prop="serviceType">
              <el-radio-group v-if="isModifyMode" v-model="task.serviceType" @change="handleTestTypeChange">
            <span v-for="(item,index) in serviceType" :key="index">
              <el-radio :label="item.code" name="serviceType">{{item.name}}</el-radio>
            </span>
              </el-radio-group>
              <span class="badge" v-if="!isModifyMode">{{serviceName}}</span>
            </el-form-item>

            <el-form-item label="服务序列号" prop="endPoint" style="width: 700px;"
                          v-if="showBD&&task.endPoint&&currType.type===1"
            >
              <el-input v-if="isModifyMode" v-model="task.endPoint.serverCode" label="examId"></el-input>
              <span v-if="!isModifyMode&&showBD">{{task.endPoint.serverCode}}</span>
            </el-form-item>

            <el-form-item label="任务可见性" prop="resource" style="width: 700px;">
              <div v-if="!isModifyMode">
                <!--<div v-if="task.resource=='1'">{{updateLocation(task.location)}}</div>-->
                <div v-if="task.resource==0">定向</div>
                <div v-if="task.resource==2">{{resourceType[task.resource]}}</div>
              </div>
              <el-tabs
                :tab-position="tabPosition"
                v-model="task.resource"
                style="max-height: 200px;"
                v-if="isModifyMode"
              >
                <el-tab-pane :label="resourceType[0]" name="0">
                  <el-radio-group v-model="task.institution" @change="handleTestTypeChange">
                    <el-radio
                      :label="item"
                      name="type"
                      v-for="item,index in institutionArray"
                      :key="index"
                    >{{item.evaluationAgencyName}}
                    </el-radio>
                  </el-radio-group>
                </el-tab-pane>
                <!--<el-tab-pane :label="resourceType[1]" name="1">-->
                <!--<provincecity-->
                <!--ref="addFormProvince"-->
                <!--@selectChange="locationChange"-->
                <!--:provinceCode="task.location == null ||task.location.provinceCode==null?'3200':task.location.provinceCode"-->
                <!--:cityCode="task.location == null ||task.location.cityCode==null?'3201':task.location.cityCode"-->
                <!--&gt;</provincecity>-->
                <!--</el-tab-pane>-->
                <el-tab-pane :label="resourceType[2]" name="2"></el-tab-pane>
              </el-tabs>
            </el-form-item>
            <el-form-item label="领取人数" prop="contactPhone" v-if="isModifyMode&&task.resource !== '0' && currType.type===0">
              <el-input-number v-model="task.participantCount" :min="1" :max="1000" label="领取人数"></el-input-number>
            </el-form-item>
            <el-form-item label="领取人数" prop="contactPhone" v-if="isModifyMode&&task.resource !== '0' && currType.type===1">
              <el-input-number v-model="task.participantCount" :min="2" :max="1000" label="领取人数"></el-input-number>
            </el-form-item>
            <el-form-item label="领取人数" prop="quotePrice" v-if="!isModifyMode">
              {{task.acceptedCount }}/{{ task.participantCount}}
            </el-form-item>
            <el-form-item label="需求文档" prop="doc">
              <el-upload
                style="width: 400px"
                v-if="isModifyMode"
                drag
                class="upload-demo"
                action=""
                :on-remove="handleRemove"
                :before-remove="beforeRemove"
                :limit="1"
                :on-exceed="handleExceed"

                :http-request="uploadRequireDoc"
                :file-list="task.doc"
              >
                <i class="el-icon-upload"></i>
                <div class="el-upload__text">
                  将文件拖到此处,或
                  <em>点击上传</em>
                </div>
              </el-upload>
              <span>
              <span v-if="task.requireDocUrl == null || task.requireDocUrl == ''">
                <i class="el-icon-document"></i>暂无文件
              </span>
              <span v-if="task.requireDocUrl != null && task.requireDocUrl != ''">
                <a :href="task.requireDocUrl"><el-link :underline="false" type="primary"><i
                  class="el-icon-document"></i>下载文档</el-link></a>
              </span>
            </span>
            </el-form-item>

            <el-form-item label="任务截止时间" prop="datetime">
              <div class="block" v-if="isModifyMode">
                <el-date-picker
                  size="small"
                  v-model="task.datetime"
                  type="datetime"
                  placeholder="选择截止时间"
                  align="right"
                  :picker-options="pickerOptions"
                ></el-date-picker>
              </div>
              <span v-if="!isModifyMode">{{dateFormat(new Date(task.datetime),'yyyy-MM-dd HH:mm:ss')}}</span>
            </el-form-item>
            <el-form-item v-if="isModifyMode">
              <div class="btn btn-small btn-info" @click="updateTask()">确认修改</div>
              <!--<div class="btn btn-small" @click="resetForm()">重置</div>-->
              <div class="btn btn-small" @click="cancelMode()">取消</div>
            </el-form-item>

            <el-form-item v-if="editShortLink && task.endPoint.serverCode && taskOperationControl.confirmFinish" label="任务面板链接" props="shortLink">
              <el-input v-model="shortLink" placeholder="请输入短链接生成任务报告" style="width: 800px">
                <template slot="append">
                  <el-button @click="getTaskDataBoard()">确定</el-button>
                </template>
              </el-input>
            </el-form-item>

            <el-form-item v-if="shortLink && !editShortLink" label="任务面板链接" props="shortLink">
              {{shortLink}}
              <i class="el-icon-edit" @click="editShortLink = true" v-if="taskOperationControl.confirmFinish"/>
            </el-form-item>

            <el-form-item v-if="!isModifyMode">
              <el-button size="mini" @click="toProject()">项目详情</el-button>
              <el-popover
                placement="top-start"
                title="确认结束?"
                width="200"
                trigger="hover"
                content="测评机构已提交结束申请,请确认是否结束该任务">
                <el-button v-if="taskOperationControl.confirmFinish" type="success" size="mini" slot="reference"
                           @click="endTask()">确认结束
                </el-button>
              </el-popover>

              <el-popover
                placement="top-start"
                title="确认提交?"
                width="200"
                trigger="hover"
                content="提交任务后不可更改,等待区域管理员验收">
                <el-button v-if="taskOperationControl.finish" type="primary" size="mini" slot="reference"
                           @click="submitTaskRequest()">提交任务
                </el-button>
              </el-popover>

              <el-popover
                placement="top-start"
                title="确认拒绝?"
                width="200"
                trigger="hover"
                content="拒绝后不可再接收此任务,且该任务对您不可见">
                <el-button v-if="taskOperationControl.reject" type="danger" size="mini" slot="reference"
                           @click="rejectTask()">拒绝任务
                </el-button>
              </el-popover>

              <el-popover
                placement="top-start"
                title="确认接收?"
                width="200"
                trigger="hover"
                content="接收任务后请认真完成!">
                <el-button v-if="taskOperationControl.receive" type="primary" size="mini" slot="reference"
                           @click="receiveTask()">接收任务
                </el-button>
              </el-popover>

              <el-button v-if="taskOperationControl.writeReport" type="primary" size="mini" @click="gotoWriteReport()">填写报告
              </el-button>

              <el-button v-if="taskOperationControl.update" type="primary" size="mini" @click="modifyForm()">修改任务
              </el-button>

              <el-button v-if="taskOperationControl.taskRecommend" type="primary" size="mini" @click="recommendTask()">任务推荐
              </el-button>

              <el-button v-if="taskOperationControl.uploadReport" type="primary" size="mini" @click="toCreateReport()">
                上传报告
              </el-button>
              <el-button v-if="taskOperationControl.taskDemonstrate" type="success" size="mini" @click="gotoDataboard()">
                任务面板
              </el-button>
              <!--<div class="btn btn-small btn-info"-->
              <!--v-if="taskOperationControl.confirmFinish"-->
              <!--@click="endTask()">确认结束-->
              <!--</div>-->
              <!--<div class="btn btn-small btn-info" v-if="!taskOperationControl.finish" @click="submitTaskRequest()">提交任务-->
              <!--</div>-->
              <!--<div class="btn btn-small btn-info" v-if="!taskOperationControl.receive" @click="receiveTask()">接收任务</div>-->
              <!--<div class="btn btn-small btn-danger" v-if="!taskOperationControl.reject" @click="rejectTask()">拒绝任务</div>-->
              <!--<div class="btn btn-small btn-info" v-if="taskOperationControl.update" @click="modifyForm()">修改任务</div>-->
              <!--<div class="btn btn-small btn-info" v-if="!taskOperationControl.uploadReport" @click="toCreateReport()">上传报告-->
              <!--</div>-->

            </el-form-item>
          </el-form>
        </el-col>
        <el-col :span="9">
          <TaskCloud :info="wordCloud" v-if="wordCloud.length"></TaskCloud>
        </el-col>
      </el-row>

    </div>
    <div class="create-body" v-if="!isModifyMode">
      <div class="title h2">用户报告列表</div>
      <el-collapse accordion style="margin: 0 30px">
        <el-collapse-item v-for="(item,index) in acceptedUserList" :key="item.id">
          <template slot="title">
            <el-row style="width: 100%;font-size: 16px">
              <el-col :span="6">{{item.userVO.userName}}</el-col>
              <el-col :span="6">{{item.userVO.email}}</el-col>
              <el-col :span="6">
                <el-tag type="success" v-if="item.crowdReportVOS">已提交报告</el-tag>
                <el-tag type="info" v-if="!item.crowdReportVOS">未提交报告</el-tag>
              </el-col>
              <el-col :span="6">
                <el-tag type="success" v-if="item.isCommitted">已提交任务</el-tag>
                <el-tag type="info" v-if="!item.isCommitted">未提交任务</el-tag>
              </el-col>
            </el-row>
          </template>
          <report-list v-bind:reports="item.crowdReportVOS" v-bind:taskId="taskId" v-bind:projectId="projectId"/>
        </el-collapse-item>
      </el-collapse>
      <!--      <report-list v-if="isAgency" v-bind:reports="reportList" v-bind:taskId="taskId" v-bind:projectId="projectId"/>-->
      <!--      <report-list v-bind:reports="reportList" v-bind:taskId="taskId" v-bind:projectId="projectId"/>-->
    </div>
  </div>
</template>

<script>
  import ResourceType from '@/constants/enum/resource-type.js'
  import provincecity from '@/components/commons/ProvinceCity'
  import ReportList from '@/components/report/ReportList'
  import TaskCloud from '@/components/task/TaskCloud'
  import Http from '@/js/http.js'
  import Apis from '@/js/api.js'
  import {notify} from '@/constants/index'
  import {
    ensureEndTask,
    getAllAgencies,
    getAllServiceTypes,
    getFormalTimeFromDate,
    getProvinceCodeByProvinceName,
    getProvinceNameByProvinceCode,
    getTask,
    receiveTaskRequest,
    rejectTask,
    storageGet,
    submitTaskRequest,
    updateTask,
    getTaskWordCloud
  } from '@/js/index'

  export default {
    name: 'Task',
    components: {
      provincecity,
      ReportList,
      TaskCloud
    },
    data() {
      return {
        currType: {},
        user: {},
        serviceName:'',
        showBD: true,
        rolesPermissions: {},
        loading: false,
        isModifyMode: false,
        institutionArray: [],
        tabPosition: 'top',
        resourceType: ResourceType,
        serviceType: [],
        taskId: '',
        projectId: '',
        taskOperationControl: {
          confirmFinish: false,
          finish: false,
          receive: false,
          update: false,
          uploadReport: false,
          writeReport: false,
          taskDemonstrate: false,
          taskRecommend: false
        },
        crowdReportUrl: '',
        wordCloud:[],
        task: {
          agencyId: '',
          status: '',
          name: '',
          desc: '',
          serviceType: '',
          resource: '',
          location: {},
          institution: {},
          datetime: '',
          quotePrice: '',
          fixedPrice: '',
          doc: [],
          requireDocUrl: '',
          participantCount: 1,
          title: '',
          description: '',
          endPoint: {
            serverCode: '',
            token: ''
          }
        },
        reportList: [],
        pickerOptions: {
          shortcuts: [
            {
              text: '今天',
              onClick(picker) {
                picker.$emit('pick', new Date())
              }
            },
            {
              text: '昨天',
              onClick(picker) {
                const date = new Date()
                date.setTime(date.getTime() - 3600 * 1000 * 24)
                picker.$emit('pick', date)
              }
            },
            {
              text: '一周前',
              onClick(picker) {
                const date = new Date()
                date.setTime(date.getTime() - 3600 * 1000 * 24 * 7)
                picker.$emit('pick', date)
              }
            }
          ]
        },
        rules: {
          title: [
            {required: true, message: '请输入任务名称', trigger: 'blur'},
            {min: 5, max: 50, message: '任务名称长度在 5 到 50 个字符', trigger: 'blur'}
          ],
          serviceType: [
            {required: true, message: '测试类型不可为空', trigger: 'change'},
          ],
          desc: [{required: false, message: '请填写描述', trigger: 'blur'}],
          //price: [{required: true, message: '请填写价格', trigger: 'blur'}],
          quotePrice: [
            {required: true, message: '预算不可为空', trigger: 'blur'},
            {
              validator: (rule, value, callback) => {
                if (value < 0) {
                  callback(new Error('请输入不小于0的数'))
                } else {
                  callback()
                }
              }, trigger: 'blur'
            },
          ],
          resource: [
            {required: true},
            {
              validator: (rule, value, callback) => {
                if (value == 0 && this.task.institution.id == null) {
                  callback(new Error('定向发布至少要选择一个测评机构'))
                } else {
                  callback()
                }
              }, trigger: 'change'
            },
          ],
          endPoint: [
            {
              validator: (rule, value, callback) => {
                if (this.currType.type === 1 && this.task.endPoint.serverCode === '') {
                  callback(new Error('请填写对应得服务序列号'))
                } else {
                  callback()
                }
              }, trigger: ['change','blur']
            },
          ],
          datetime: [{required: true, message: '截止时间不可为空', trigger: 'blur'}],
        },
        acceptedUserList: [],
        shortLink:'',
        editShortLink:false,
      }
    },
    watch: {
      institutionArray(val) {
        this.institutionArray = val
      },
      serviceType(val) {
        this.serviceType = val
      },
      // 'task.institution' () {
      //   if (this.task.institution) {
      //     //this.$refs.addFormProvince.resetProviceCity()
      //     this.task.location = {provinceCode: '', cityCode: ''}
      //   }
      // },
      // 'task.location' () {
      //   if (this.task.location.provinceCode || this.task.location.cityCode) {
      //     this.task.institution = ''
      //   }
      // },
      // 'task.resource' () {
      //   if (this.task.resource == '广场') {
      //     this.$refs.addFormProvince.resetProviceCity()
      //     this.task.institution = ''
      //     this.task.location = {provinceCode: '', cityCode: ''}
      //   }
      // },
      deep: true
    },
    mounted() {
      this.$nextTick(() => {
        this.init()
      })
    },
    methods: {
      //跳转到任务对应的数据面板
      gotoDataboard(){
        window.open(this.task.endPoint.token)
      },
      //根据短链接获取生成databoard
      getTaskDataBoard(){
        this.showLoading()
        Http.put(`/api/project/${this.projectId}/task/${this.taskId}/addToken`,{"token":this.shortLink}).then((res)=>{
          this.taskOperationControl = res.taskOperationControl;
          this.task.endPoint = res.crowdTaskVO.endPointVO;
          this.shortLink = res.crowdTaskVO.endPointVO.token;
          if(this.shortLink != ''){
            this.editShortLink = false;
          }
          this.hideLoading()
        })
      },
      getServiceByCode(code){
        let serviceName = this.serviceType.filter((item) => {
          return item.code === code;
        });
        return serviceName&&serviceName[0]&&serviceName[0]['name']
      },

      handleTestTypeChange(val) {
        let type = this.serviceType.filter((item) => {
          return item.code === val;
        });
        this.currType = type[0] ? type[0] : {};
        if (this.currType.type === 0) {
          this.$refs.task.clearValidate('endPoint');
        }
      },
      init() {
        this.taskId = this.$route.params.taskId
        this.projectId = this.$route.params.projectId
        this.setUserInfo()
        this.setServiceType()
        //this.loadData(this.projectId, this.taskId)
        this.getTaskDetail()
        this.getWordCloud()
        this.setInstitutions()
      },

      //北斗测试报告填写跳转
      gotoWriteReport() {
        window.open(this.crowdReportUrl, '_blank');
      },

      //跳转至项目详情页面
      toProject() {
        this.$router.push({
          name: 'Project',
          params: {projectId: this.projectId}
        })
      },

      //切换至可编辑页面
      modifyForm() {
        // this.task.serviceType = ''
        this.isModifyMode = true
      },
      //切换至不可编辑页面
      cancelMode() {
        this.isModifyMode = false
      },
      //重置表单
      resetForm() {
        this.task.name = ''
        this.task.desc = ''
        this.task.quotePrice = ''
        this.task.fixedPrice = ''
        this.task.type = ''
        this.task.resource = '2' //如果是广场不用管Location和institution ,定向看institution,区域看location
        this.task.location = {provinceCode: '', cityCode: ''}
        this.task.institution = ''
        this.task.datetime = ''
        this.task.participantCount = 1
        // this.task.endPointVO.caseId = ''
        // this.task.endPointVO.examId = ''
      },
      //显示页面加载画面
      showLoading() {
        this.loading = true
      },
      //隐藏页面加载画面
      hideLoading() {
        this.loading = false
      },
      //加载用户信息
      setUserInfo() {
        this.user = storageGet('user')
        this.rolesPermissions = storageGet('rolesPermissions')
        if (storageGet('rolesPermissions').isRegionManager || storageGet('rolesPermissions').isSystemAdministrator) {
          this.showBD = true;
        } else {
          this.showBD = false;
        }
      },
      //加载任务的测试类型
      setServiceType() {
        getAllServiceTypes().then((res) => {
          this.serviceType = res
        }).catch((error) => {
          notify('error', '加载测试类型失败')
        })
      },
      //加载所有的测评机构
      setInstitutions() {
        getAllAgencies().then((res) => {
          this.institutionArray = res
        }).catch((error) => {
          notify('error', '获取机构列表失败')
        })
      },
      //获取任务详情
      getTaskDetail() {
        this.showLoading()
        getTask(this.projectId, this.taskId, this.getTaskDetailSuccess, this.getTaskDetailFail)
      },

      //获取词云
      getWordCloud(){
        getTaskWordCloud(this.projectId, this.taskId, this.getTaskCloudSuccess, this.getTaskCloudFail)
      },
      getTaskCloudSuccess(words){
        this.wordCloud = words.data;
      },
      getTaskCloudFail(err){
        notify('error',err)
      },

      //获取任务详情成功时回调函数
      getTaskDetailSuccess(res) {
        this.hideLoading()
        // console.log(res)
        this.taskId = res.crowdTaskVO.id
        this.projectId = res.crowdTaskVO.projectId
        this.task.title = res.crowdTaskVO.title
        this.task.description = res.crowdTaskVO.description
        this.task.serviceType = res.crowdTaskVO.serviceType
        this.task.resource = res.crowdTaskVO.resource.toString()
        this.task.location = getProvinceCodeByProvinceName(res.crowdTaskVO.location.provinceCode, res.crowdTaskVO.location.cityCode)
        this.task.institution = res.crowdTaskVO.institution
        this.task.datetime = new Date(res.crowdTaskVO.datetime)
        this.task.quotePrice = res.crowdTaskVO.quotePrice
        this.task.acceptedCount = res.crowdTaskVO.acceptedCount
        this.task.participantCount = res.crowdTaskVO.participantCount
        this.task.fixedPrice = res.crowdTaskVO.fixedPrice
        this.task.doc = []
        this.task.requireDocUrl = res.crowdTaskVO.requirementFile
        this.task.agencyId = res.crowdTaskVO.agencyId
        this.task.status = res.crowdTaskVO.status
        this.task.statusVO = res.crowdTaskVO.statusVO
        this.task.endPoint = res.crowdTaskVO.endPointVO ? res.crowdTaskVO.endPointVO : {
          serverCode: '',
        }
        this.taskOperationControl = res.taskOperationControl;
        this.acceptedUserList = res.acceptedUserList;
        this.crowdReportUrl = res.crowdTaskVO.writeReportUrl;
        this.handleFormatReport(this.acceptedUserList);
        this.handleTestTypeChange(res.crowdTaskVO.serviceType);
        this.serviceName = this.getServiceByCode(res.crowdTaskVO.serviceType);
        if(res.crowdTaskVO.endPointVO){
          if(res.crowdTaskVO.endPointVO.token){
            this.shortLink = res.crowdTaskVO.endPointVO.token;
            this.editShortLink = false
          }else{
            this.editShortLink = true
          }
        }
        // console.log(res.crowdTaskVO.endPointVO.token)
        // console.log(this.editShortLink)
        // console.log(this.isModifyMode)
      },
      //获取任务详情失败时回调函数
      getTaskDetailFail(error) {
        this.hideLoading()
        // notify('error', '获取任务详情失败:' + error.data)
      },

      //处理显示报告
      handleFormatReport(acceptedUserList) {
        acceptedUserList.map((user) => {
          user.crowdReportVOS && user.crowdReportVOS.map((report) => {
            report.userName = user.userVO.userName;
            this.reportList.push(report);
          })
        })
      },

      dateFormat(date, format) {
        date = new Date(date)
        let o = {
          'M+': date.getMonth() + 1, //month
          'd+': date.getDate(), //day
          'H+': date.getHours(), //hour+8小时
          'm+': date.getMinutes(), //minute
          's+': date.getSeconds(), //second
          'q+': Math.floor((date.getMonth() + 3) / 3), //quarter
          'S': date.getMilliseconds() //millisecond
        }
        if (/(y+)/.test(format)) {
          format = format.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length));
        }

        for (let k in o)
          if (new RegExp('(' + k + ')').test(format))
            format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ('00' + o[k]).substr(('' + o[k]).length));

        return format;
      },

      //更新任务信息
      updateTask() {
        this.$refs['task'].validate(valid => {
          if (valid) {
            this.showLoading()
            const newTask = {
              name: this.task.title,
              desc: this.task.description,
              type: this.task.serviceType,
              resource: this.task.resource,
              location: this.task.location == null ? {} : getProvinceNameByProvinceCode(this.task.location.provinceCode, this.task.location.cityCode),
              institution: this.task.institution ? this.task.institution.id : null,
              datetime: this.task.datetime,
              quotePrice: this.task.quotePrice,
              fixedPrice: this.task.fixedPrice,
              requirementFile: this.task.requireDocUrl,
              participantCount: this.task.participantCount,
              endPoint: this.task.endPoint
            }
            //console.log(newTask)
            updateTask(this.projectId, this.taskId, newTask, this.updateTaskSuccess, this.updateTaskFail)
          } else {
            notify('error', '表单填写有误!')
            return false
          }
        })
      },
      //更新任务信息成功时回调函数
      updateTaskSuccess(res) {
        this.cancelMode()
        this.taskId = res.crowdTaskVO.id
        this.projectId = res.crowdTaskVO.projectId
        this.task.title = res.crowdTaskVO.title
        this.task.description = res.crowdTaskVO.description
        this.task.serviceType = res.crowdTaskVO.serviceType
        this.task.resource = res.crowdTaskVO.resource
        this.task.location = res.crowdTaskVO.location == null ? {
          provinceCode: 3200,
          cityCode: 3201
        } : getProvinceCodeByProvinceName(res.crowdTaskVO.location.provinceCode, res.crowdTaskVO.location.cityCode)
        this.task.institution = res.crowdTaskVO.institution
        this.task.datetime = new Date(res.crowdTaskVO.datetime)
        this.task.quotePrice = res.crowdTaskVO.quotePrice
        this.task.fixedPrice = res.crowdTaskVO.fixedPrice
        // this.task.endPointVO = res.crowdTaskVO.endPointVO
        this.task.doc = []
        this.task.requireDocUrl = res.crowdTaskVO.requirementFile,
          this.task.participantCount = res.crowdTaskVO.participantCount
          this.task.endPoint = res.crowdTaskVO.endPointVO ? res.crowdTaskVO.endPointVO : {
            serverCode: '',
          }
        this.task.createTime = res.crowdTaskVO.createTime,
        this.reportList = res.crowdReportVOList
        this.crowdReportUrl = res.crowdTaskVO.writeReportUrl;
        this.acceptedUserList = res.acceptedUserList
        this.handleTestTypeChange(res.crowdTaskVO.serviceType);
        this.serviceName = this.getServiceByCode(res.crowdTaskVO.serviceType);
        this.hideLoading()
        notify('success', '修改成功')
      },
      //更新任务信息失败时回调函数
      updateTaskFail(error) {
        notify('error', '修改失败:' + error.data)
        this.hideLoading()
      },
      //上传任务需求文档
      uploadRequireDoc(param) {
        const formData = new FormData()
        let config = {
          //添加请求头
          headers: {'Content-Type': 'multipart/form-data'},
        }
        formData.append('file', param.file)
        Http.upload(Apis.FILE.REQUIREMENT_FILE.replace('{userId}', this.user.userVO.id), formData, config).then((res) => {
          notify('success', '上传成功')
          this.uploadRequireDocSuccess(res)
        }).catch((error) => {
          notify('error', '上传失败:' + error.data)
          this.uploadRequireDocFail(error)
        })
      },
      //上传任务需求文档成功时回调函数
      uploadRequireDocSuccess(res) {
        this.hideLoading()
        console.log('上传成功')
        this.task.requireDocUrl = res.data
        console.log(res.data)
      },
      //上传任务需求文档失败时回调函数
      uploadRequireDocFail(error) {
        this.hideLoading()
        notify('error', '任务需求文档上传失败:' + error.data)
      },
      //文档上传前响应函数

      //移除文档前的响应函数
      beforeRemove(file, fileList) {
        //return this.$confirm(`确定移除 ${file.name}?`)
      },
      //移除文档时的响应函数
      handleRemove(file, fileList) {
        console.log(file, fileList)
      },
      //需求文档添加进来时的响应函数
      handleExceed(files, fileList) {
        this.$message.warning(
          `当前限制选择 1 个文件,本次选择了 ${
            files.length
            } 个文件,共选择了 ${files.length + fileList.length} 个文件`
        )
      },
      //接收任务
      receiveTask() {
        this.$confirm('确认接收任务?', '提示', {
          confirmButtonText: '确认接收',
          cancelButtonText: '取消',
          type: 'success'
        }).then(() => {
          this.showLoading()
          receiveTaskRequest(this.projectId, this.taskId, this.user.userVO.id, this.receiveTaskSuccess, this.receiveTaskFail)
        }).catch(() => {
        })
      },
      //接收任务成功时的回调函数
      receiveTaskSuccess(res) {
        this.hideLoading()
        this.getTaskDetail();
        notify('success', '接收任务成功')
        // console.log(res)
        this.taskOperationControl = res.taskOperationControl
        this.task.status = res.crowdTaskVO.status
        this.task.institution = res.crowdTaskVO.institution
      },
      //接收任务失败时的回调函数
      receiveTaskFail(error) {
        this.hideLoading()
        notify('error', '接收任务失败:' + error.data)
      },

      // 任务推荐
      recommendTask(){
        let task = {
          "title": this.task.title,
          "description": this.task.description,
          "participantCount": this.task.participantCount,
          "quotePrice": this.task.quotePrice,
          "requirementFile": this.task.requireDocUrl,
          "serviceType": this.task.serviceType,
          "createTime": this.task.createTime,
          "datetime": this.task.datetime
        };
        Http.post('/recommendationtest/querywithparam',task).then((res)=>{
          window.open('http://59.42.10.54:7477/userinformation.html');
        })
      },

      //拒绝任务
      rejectTask() {
        this.$confirm('确认拒绝任务?拒绝后将不能再接收该任务', '提示', {
          confirmButtonText: '确认拒绝',
          cancelButtonText: '取消',
          type: 'success'
        }).then(() => {
          this.showLoading()
          rejectTask(this.projectId, this.taskId, this.rejectTaskSuccess, this.rejectTaskFail)
        }).catch(() => {

        })
      },
      //拒绝任务成功时的回调函数
      rejectTaskSuccess(res) {
        this.hideLoading()
        this.$router.push({
          name: 'Mine'
        })
        notify('success', '拒绝任务成功,已为您自动跳转到个人中心')
      },
      //拒绝任务失败时的回调函数
      rejectTaskFail(error) {
        this.hideLoading()
        notify('error', '拒绝任务失败:' + error.data)
      },
      //提交结束任务申请
      submitTaskRequest() {
        this.$confirm('确认提交任务?提交后将不能再修改', '提示', {
          confirmButtonText: '确认提交',
          cancelButtonText: '取消',
          type: 'success'
        }).then(() => {
          this.showLoading()
          submitTaskRequest(this.projectId, this.taskId, this.submitTaskRequestSuccess, this.submitTaskRequestFail)

        }).catch(() => {

        })
      },
      //提交结束任务申请成功时的回调函数
      submitTaskRequestSuccess(res) {
        this.hideLoading()
        console.log(res)
        this.taskOperationControl = res.taskOperationControl
        this.task.status = res.crowdTaskVO.status
        this.task.institution = res.crowdTaskVO.institution
        notify('success', '提交任务成功,等待区域管理员审核')
        this.getTaskDetail();
      },
      //提交结束任务申请失败时的回调函数
      submitTaskRequestFail(error) {
        this.hideLoading()
        notify('error', '提交任务失败:' + error.data)
      },
      //结束任务
      endTask() {
        this.$confirm('确认结束任务?', '提示', {
          confirmButtonText: '确认结束',
          cancelButtonText: '取消',
          type: 'success'
        }).then(() => {
          this.getTaskDetail()
          this.showLoading()
          ensureEndTask(this.projectId, this.taskId, this.endTaskSuccess, this.endTaskFail)
        }).catch(() => {

        })
      },
      //结束任务成功时的回调函数
      endTaskSuccess(res) {
        this.hideLoading()
        this.taskOperationControl = res.taskOperationControl
        this.task.status = res.crowdTaskVO.status
        this.task.institution = res.crowdTaskVO.institution
        notify('success', '结束任务成功!')
        this.getTaskDetail();
      },
      //结束任务失败时的回调函数
      endTaskFail(error) {
        this.hideLoading()
        notify('error', '结束任务失败:' + error.data)
      },
      //跳转到创建项目报告页面
      toCreateReport() {
        this.$router.push({
          name: 'TaskReportCreate',
          params: {
            scope: 1,
            dependencyCode: this.taskId,
            projectId: this.projectId,
            taskId: this.taskId,
          }
        })
      },
      reformDate(date) {
        return getFormalTimeFromDate(date)
      }
    },
  }
  //回收站
  //
  // updateLocation (location) {
  //   console.log(location)
  //   const loactionName = getProvinceNameByProvinceCode(location.provinceCode, location.cityCode)
  //   // var provinceName = ''
  //   // var cityName = ''
  //   // for (var item of provinceCityJSON.provinces) {
  //   //   if (item.code === location.provinceCode) {
  //   //     provinceName = item.name
  //   //     for (var city of item.cities) {
  //   //       if (city.code === location.cityCode) {
  //   //         cityName = city.name
  //   //         break
  //   //       }
  //   //     }
  //   //   }
  //   // }
  //   return loactionName.provinceCode + ' / ' + loactionName.cityCode
  // },
  //
  // locationChange (provinceId, cityId) {
  //   if (provinceId || cityId) {
  //     this.task.location = {provinceCode: provinceId, cityCode: cityId}
  //   }
  // },
  // submitForm (formName) {
  // this.$refs[formName].validate(valid => {
  //   if (valid) {
  //     this.isModifyMode = false
  //
  //   } else {
  //     console.log('error submit!!')
  //     return false
  //   }
  // })
  // },
</script>

<style lang="less" scoped>
  .el-radio {
    margin: 10px 20px 10px 0;
  }

  .el-form-item /deep/ .el-tabs__content {
    /*max-height: 120px !important;*/
    overflow: auto;
  }

  .el-collapse-item__content {
    padding-bottom: 0 !important;
  }
</style>