<!-- 发起订单 -->
<template>
  <view class="content">
    <!--    <view class="c-top">-->
    <!--      <view class="" @click="getback()">-->
    <!--        <uni-icons type="left" size="18"></uni-icons>-->
    <!--      </view>-->
    <!--      <view class="c-title" v-if="type == 'add'">新增设备</view>-->
    <!--      <view class="c-title" v-if="type == 'edit'">编辑设备</view>-->
    <!--      <view class=""></view>-->
    <!--    </view>-->
    <headersVue :titles="pageName" style="position: static !important;">
      <u-icon name="arrow-left" color="#fff" size="18"></u-icon>
    </headersVue>
    <view class="dil">
      <view class="tinput">

        <view class="text1">
          <text class="hong1">*</text>
          设备名称
        </view>
        <view class="you">
          <input type="text" placeholder="请输入设备名称" v-model="box.equName">
        </view>
      </view>
      <view class="tinput">

        <view class="text1">
          <text class="hong1">*</text>
          设备型号
        </view>
        <view class="you">
          <input type="text" placeholder="请输入设备型号" v-model="box.equModel">
        </view>
      </view>
      <view class="tinput">

        <view class="text1">
          <text class="hong1">*</text>
          设备编号
        </view>
        <view class="you">
          <input type="text" placeholder="请输入设备编号" v-model="box.equNumber">
        </view>
      </view>
      <view class="tinput" @click="typeShow = true">
        <view class="text1">
          设备类别
        </view>
        <view class="you">
          <input type="text" disabled placeholder="请选择设备类别" v-model="typeName">
        </view>
      </view>
      <view class="tinput">

        <view class="text1">
          <text class="hong1">*</text>
          设备检定周期
        </view>
        <view class="you">
          <input type="text" placeholder="请输入设备检定周期" v-model="box.equZq">
        </view>
      </view>
      <view class="tinput">

        <view class="text1">
          <text class="hong1">*</text>
          上次检定单位
        </view>
        <view class="you">
          <input type="text" placeholder="请输入上次检定单位" v-model="box.lastUnit">
        </view>
      </view>


      <view class="tinput">
        <view class="text1">
          <text class="hong1">*</text>
          有效期
        </view>
        <!-- validTime -->
        <view class="you" @click="show = true ">
          <text>{{ time || '' }}</text>
        </view>
      </view>
      <view class="tinput">
        <view class="text1">
          <text class="hong1">*</text>
          下次检定时间
        </view>
        <!-- nextCheckTime -->
        <view class="you" @click="show1 = true ">
          <text>{{ time1 || '' }}</text>
        </view>
      </view>

      <view class="tinput">
        <view class="text1">
          <text class="hong1">*</text>
          设备附件
        </view>
        <view class="lan_" @click="goFile">查看附件
          <image src="/static/imgs/add.png" mode=""></image>
        </view>
      </view>
      <u-datetime-picker
          :show="show"
          v-model="box.validTime"
          @cancel="cancels"
          @confirm="confirms"
          mode="date"
          return-type='string'
      ></u-datetime-picker>
      <u-datetime-picker
          :show="show1"
          v-model="box.nextCheckTime"
          @cancel="cancels1"
          @confirm="confirms1"
          mode="date"
          return-type='string'
      ></u-datetime-picker>

      <u-picker :show="typeShow" :columns="columns" @confirm="confirmsType" @cancel="typeShow = false"
                keyName="label"></u-picker>
      <view class="anniu" @click="getnewsadd()">
        <text>保存</text>
      </view>
      <view style="width: 100%; height: 60px;"></view>
    </view>


  </view>
</template>

<script>
import request from '../../utils/request'
import config from '@/config'
import {getToken} from '@/utils/auth'
import upload from '@/utils/upload.js'
import {getDictDataByType} from "../../utils/utils";
import headersVue from "@/components/header/headers.vue";

var wvCurrent;
export default {
  components: {headersVue},
  data() {
    return {

      time: '请选择有效期',
      time1: '请选择下次检定时间',
      value1: '2023-10-10',
      baseUrl: this.$baseUrl,
      show: false,
      show1: false,
      fileId: null,
      id: '',
      type: 'add',
      box: {},
      typeShow: false,
      columns: [],
      typeName: null,
      //附件列表
      fileList3: [],
      pageName: '新增设备',
      baseImageUrl: config.baseImageUrl,
    }
  },
  onLoad(option) {
    this.type = option.type
    if (option.type == 'edit') {
      this.box.id = option.id
      this.pageName = '编辑设备'
    }
    this.getInsType()
  },

  onShow() {
    if (this.type == 'edit') this.getDetail();
  },
  methods: {
    confirmsType(e) {
      console.log(e)
      this.box.type = e.value[0].value
      this.typeName = e.value[0].label
      this.typeShow = false
    },
    async getInsType() {
      if (!this.columns || this.columns.length === 0) {
        this.columns = [await getDictDataByType("ins_equ_type")]
      }
      console.log(this.columns)
    },
    async getDetail() {
      let res = await request({
        url: '/system/equInfo/' + this.box.id,
        method: 'get'
      })
      if (res.code == 200) {
        this.box = res.data
        if (this.box.fileList) {
          this.fileList3 = this.box.fileList
          // 在回显时给 URL 加上域名
          this.fileList3 = this.fileList3.map(file => {
            // 如果是相对路径,添加域名
            file.url = this.baseImageUrl + '/' + file.url;
            return file;
          });
        }
        // this.maneizhi = this.box.type
        this.time = this.box.validTime
        this.time1 = this.box.nextCheckTime
      }
      if (this.box.type) {
        const data = this.columns[0]
        const index = data.findIndex(item => item.value === this.box.type)
        if (index !== -1) {
          this.typeName = data[index].label
        }
      }
    },
    cancels() {
      this.show = false
    },
    cancels1() {
      this.show1 = false
    },
    confirms(e) {
      var timestamp = e.value;
      var date = new Date(timestamp);
      var year = date.getFullYear();
      var month = ("0" + (date.getMonth() + 1)).slice(-2);
      var day = ("0" + date.getDate()).slice(-2);
      var formattedDate = year + "-" + month + "-" + day;
      this.box.validTime = formattedDate
      this.time = formattedDate
      this.show = false

    },
    confirms1(e) {
      var timestamp = e.value;
      var date = new Date(timestamp);
      var year = date.getFullYear();
      var month = ("0" + (date.getMonth() + 1)).slice(-2);
      var day = ("0" + date.getDate()).slice(-2);
      var formattedDate = year + "-" + month + "-" + day;
      this.box.nextCheckTime = formattedDate
      this.time1 = formattedDate
      this.show1 = false

    },
    //发布按钮
    async getnewsadd() {

      // if(this.box.filePath==''||this.box.fileName==''||this.box.warnTime==''){
      // uni.showToast({
      // 	title:'必填项不能有空!',
      // 	icon:'none'
      // })

      this.box.fileList = this.fileList3.map(file => {
        // 去掉域名,返回相对路径
        if (file.url && file.url.startsWith(this.baseImageUrl)) {
          file.url = file.url.replace(this.baseImageUrl, '');
        }
        return file;
      });
      if (this.type == 'add') {
        let res = await request({
          url: '/system/equInfo/add',
          method: 'post',
          data: this.box
        })
        if (res.code == 200) {
          uni.showToast({
            title: '发布成功'
          })
          setTimeout(() => {
            uni.navigateBack({
              delta: 1
            });
          }, 1000);
        }
      }
      if (this.type == 'edit') {
        let res = await request({
          url: '/system/equInfo/edit',
          method: 'post',
          data: this.box
        })
        if (res.code == 200) {
          uni.showToast({
            title: '发布成功'
          })
          setTimeout(() => {
            uni.navigateBack({
              delta: 1
            });
          }, 1000);

        }
      }

    },

    getback() {
      uni.navigateBack({
        delta: 1,
      })
    },

    // 删除图片
    deletePic(event) {
      this[`fileList${event.name}`].splice(event.index, 1);
    },
    // 新增图片
    async afterRead(event) {
      // 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式
      let lists = [].concat(event.file);
      let fileListLen = this[`fileList${event.name}`].length;
      lists.map((item) => {
        this[`fileList${event.name}`].push({
          ...item,
          status: "uploading",
          message: "上传中",
        });
      });
      for (let i = 0; i < lists.length; i++) {
        const result = await this.uploadFilePromise(lists[i].url);
        let item = this[`fileList${event.name}`][fileListLen];
        this[`fileList${event.name}`].splice(
            fileListLen,
            1,
            Object.assign(item, {
              status: "success",
              message: "",
              url: result,
            })
        );
        fileListLen++;
      }
      console.log('现在文件集合', this[`fileList${event.name}`])
    },
    uploadFilePromise(url) {
      return new Promise((resolve, reject) => {
        upload({
          url: '/common/upload',
          filePath: url,
        }).then((res) => {
          resolve(res.data.url);
        })
      });
    },

    goFile() {
      if (!this.box.id) {
        uni.showToast({
          title: '请先新建设备',
          icon: 'none'
        })
        return
      }
      if (!this.box.folderId) {
        console.log('当前员工没有文件加')
        //给当前员工创建一个文件夹
        request({
          url: '/system/equInfo/addFolder',
          method: 'post',
          data: JSON.stringify(this.box.id), // 手动转换为 JSON
        }).then(res => {
          this.box.folderId = res.data
          uni.navigateTo({
            url: '/pages/manage/deviceManage?type=staff&folderId=' + this.box.folderId
          })
        })
      } else {
        uni.navigateTo({
          url: '/pages/manage/deviceManage?type=staff&folderId=' + this.box.folderId
        })
      }

    },
  }

}
</script>

<style scoped lang="scss">
.content {
  width: 100%;
  height: calc(100vh);
  background-color: #F6F6F6;
  box-sizing: border-box;
  // padding-top: 45px;
}

.dil {
  box-sizing: border-box;
  background-color: #F6F6F6;
  padding: 0px 12px;

}

.lan_ {
  font-size: 28rpx;
  color: #327DFB;
  display: flex;
  align-items: center;

  image {
    width: 36rpx;
    height: 36rpx;
    margin-left: 15rpx;
  }
}

.top-icon {
  margin-bottom: 45px;
}

.c-top {
  width: 100%;
  box-sizing: border-box;
  padding: 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: white;
  padding-top: 40px;
}

.c-title {
  font-size: 18px;
  font-weight: bold
}

.top {
  box-sizing: border-box;
  padding: 0px 15px;
  width: 100%;
  background-color: white;
}

.top-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  padding: 20px 0px;
}

.tb-left {
  height: 100%;
  width: 80%;
  display: flex;
  align-items: center;
}

.uicon {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  color: white;
  background: orangered;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  font-weight: bold;
  margin-right: 6px;

}

.tb-right {
  width: 20px;
  height: 26px;

  image {
    width: 100%;
    height: 100%;
  }
}

.text1 {
  font-size: 16px;
  font-weight: bold;
  color: #363636;
}

.hong1 {
  margin-top: 5px;
  font-size: 12px;
  font-weight: 400;
  color: #FF5453;
}

.hong2 {
  margin-top: 5px;
  font-size: 12px;
  font-weight: 400;

}

.tinput {
  width: 100%;
  display: flex;
  background: white;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  padding: 16px;
  margin-top: 14px;
  margin-bottom: 14px;
}

.xinput {
  width: 100%;
  background: white;
  box-sizing: border-box;
  padding: 16px;
  margin-top: 14px;
}

.you {
  text-align: right;

}

.xz {
  margin-top: 10px;
  display: flex;
  align-items: center;

}

.kuang {
  width: 80px;
  height: 23px;
  background: #ECECEC;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #666666;
  font-size: 14px;
  margin-right: 15px;
}

.xlan {
  background: #CDE7FF !important;
  color: #1D62FF !important;
  border: 1px solid #2A96FE;
}

.anniu {
  width: 100%;
  //background: linear-gradient(180deg, #3F61C0 0%, #0D2E8D 100%);
  background: #327dfb;
  border-radius: 50px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  //color: #542F0E;
  margin-top: 20px;
  color: white;

}


button::after {
  border: none;
}
</style>