feige
2023-12-06 5703e99b943f17aa13f55a2f90308f66c1c2fe4f
ruoyi-ui/src/views/healthy/healthyInfo.vue
@@ -13,17 +13,21 @@
    </div>
    <el-form ref="elForm" :model="formData" :rules="rules" size="medium" label-width="120px">
      <el-form-item label="体检时间" prop="checkTime">
        <el-input v-model="formData.checkTime" placeholder="请选择体检时间" clearable :style="{width: '100%'}" :disabled="dsb"></el-input>
      </el-form-item>
      <el-form-item label="就医时间" prop="checkTime">
        <el-date-picker v-model="formData.checkTime" type="date" placeholder="请选择日期"
                        :editable="false" :clearable="false" :style="{width: '100%'}" :disabled="dsb" value-format="yyyy-MM-dd"
        ></el-date-picker> </el-form-item>
      <el-form-item label="就病医院" prop="hospital">
        <el-input v-model="formData.hospital" placeholder="请选择就病医院" clearable :style="{width: '100%'}" :disabled="dsb"></el-input>
      </el-form-item>
      <el-form-item label="类别" prop="type">
        <el-input v-model="formData.type" placeholder="请输入类别" clearable :style="{width: '100%'}" :disabled="dsb">
        </el-input>
      </el-form-item>
<!--      <el-form-item label="类别" prop="type">-->
<!--        <el-select v-model="formData.type" placeholder="请选择" clearable :style="{width: '100%'}" :disabled="dsb">-->
<!--          <el-option label="体检" value="体检"></el-option>-->
<!--          <el-option label="看病" value="看病"></el-option>-->
<!--        </el-select>-->
<!--      </el-form-item>-->
      <el-form-item label="题名" prop="title">
        <el-input v-model="formData.title" placeholder="请输入题名" clearable :style="{width: '100%'}" :disabled="dsb">
        </el-input>
@@ -96,7 +100,7 @@
        list-type="picture-card"
        :on-preview="handleFileCardPreview"
        :on-remove="handleRemoveFile"
        :http-request="requestUpload"
        :http-request="requestUpload1"
        :show-file-list="true"
        :disabled="!btn"
        :class="{ hide: !btn }"
@@ -104,37 +108,44 @@
        <div v-if="uploading" class="upload-status">正在上传...</div>
        <i v-if="!uploading" slot="default" class="el-icon-plus"></i>
        <div slot="file" slot-scope="{file}">
          <img
          <!-- 添加video元素用于显示视频 -->
          <video
            v-if="file.url.includes('.mp4')"
            class="el-upload-list__item-thumbnail"
            src="../../assets/401_images/401.gif"
            alt=""
            :src="file.url"
            style="width: 147px; height: 147px"
            fit="cover"
          >
          ></video>
          <img v-else
               class="el-upload-list__item-thumbnail"
               src="../../assets/401_images/401.gif"
               alt=""
               style="width: 147px; height: 147px"
               fit="cover">
          <span class="el-upload-list__item-actions">
                  <span
               <span class="el-upload-list__item-name">{{ file.name }}</span>
                    <span
                      class="el-upload-list__item-preview"
                      @click="handleFileCardPreview(file)"
                    >
                      <i class="el-icon-zoom-in"></i>
                    </span>
                    <span
                    class="el-upload-list__item-preview"
                    @click="handleFileCardPreview(file)"
                  >
                    <i class="el-icon-zoom-in"></i>
                  </span>
                  <span
                    class="el-upload-list__item-delete"
                    @click="handleDownload(file.url)"
                  >
                      class="el-upload-list__item-delete"
                      @click="handleDownload(file.url)"
                    >
                 <i class="el-icon-download"></i>
                 </span>
                  <span
                    v-if="isShow"
                    class="el-upload-list__item-delete"
                    @click="handleRemoveFile(file)"
                  >
                    <i class="el-icon-delete"></i>
                  </span>
                </span>
                    <span
                      v-if="isShow"
                      class="el-upload-list__item-delete"
                      @click="handleRemoveFile(file)"
                    >
                      <i class="el-icon-delete"></i>
                    </span>
              </span>
        </div>
@@ -148,12 +159,12 @@
    <el-dialog  :visible.sync="dialogVisible">
      <img w-full :src="dialogImageUrl" alt="Preview Image" />
      <img w-full :src="dialogImageUrl" style="width: 100%; height: 100%" alt="Preview Image" />
    </el-dialog>
  </div>
</template>
<script>
import {getHealthInfo,  uploadPic, download, updateSecret} from "@/api/healthy/index";
import {getHealthInfo, uploadPic, download, updateHealth} from "@/api/healthy/index";
import {addRole, updateRole} from "@/api/system/role";
import {blobValidate} from "@/utils/ruoyi";
import errorCode from "@/utils/errorCode";
@@ -166,7 +177,10 @@
    return {
      cdi:"健康详细信息",
      udi:"健康信息修改",
      fot:[".jpg",".jif"],
 // 数据范围选项
 fot:['.bmp','.jpg','.jpeg','.png','.tif','.gif','.pcx','.tga','.exif','.fpx',
   '.svg','.psd','.cdr','.pcd','.dxf','.ufo','.eps','.ai','.aw','.WMF','.webp','.apng'],
      fileList:[
      ],
      fileListOther:[
@@ -193,48 +207,29 @@
      dialogVisible: false,
      disabled: false,
      rules: {
        password: [{
        checkTime: [{
          required: true,
          message: '请输入密码',
          message: '请选择就医时间',
          trigger: 'blur'
        }],
        accNo: [{
        hospital: [{
          required: true,
          message: '请输入账号',
          message: '请输入医院',
          trigger: 'blur'
        }],
        type: [{
        title: [{
          required: true,
          message: '请选择基金/台账',
          trigger: 'change'
          message: '请输入标题',
          trigger: 'blur'
        }],
        isFinger: [{
        notice: [{
          required: true,
          message: '请选择是否',
          trigger: 'change'
        }],
        isFace: [{
          required: true,
          message: '请选择是否',
          trigger: 'change'
        }],
        isPrivate: [{
          required: true,
          message: '请选择是否',
          trigger: 'change'
          message: '请输入注意事项',
          trigger: 'blur'
        }],
        validityDate: [{
          // required: true,
          message: '请选择有效期',
          trigger: 'change'
        }],
        happenTime: [{
          required: true,
          message: '请选择有效期',
          trigger: 'change'
        }],
      },
      typeOptions: [{
@@ -330,7 +325,7 @@
        if (valid) {
          if (this.formData.id != undefined) {
            updateSecret(this.formData).then(response => {
            updateHealth(this.formData).then(response => {
              this.$modal.msgSuccess("修改成功");
              // this.open = false;
              this.btn=false
@@ -374,12 +369,29 @@
    },
    handleFileCardPreview(file){
      this.dialogFileUrl = file.url;
      // alert(file.url)
      // this.dialogFileUrl = 'https://www.bendudu.com:8080/profile/upload/2023/10/18/20231018214647A011.doc'
      // this.dialogFileUrl = 'https://47.93.189.255:8080/profile/upload/2023/03/19/test7_20230319222030A007.jpg'
      if(this.dialogFileUrl.includes("47.93.189.255")==true)
        this.dialogFileUrl = this.dialogFileUrl.replace("47.93.189.255","www.bendudu.com")
      //alert(this.dialogFileUrl)
      const Base64 = require('js-base64').Base64
      this.desurl = process.env.VUE_APP_BASE_OTHER_API+'onlinePreview?url='+encodeURIComponent(Base64.encode(this.dialogFileUrl));
      myWindow=window.open(this.desurl,'','width=1200,height=800,top=150,left=300');
      this.desurl = process.env.VUE_APP_BASE_OTHER_API+"preview/"+'onlinePreview?url='+encodeURIComponent(Base64.encode(this.dialogFileUrl));
      let myWindow=window.open(this.desurl,'','width=1200,height=800,top=150,left=300');
    },
    handlePictureCardPreview(file) {
      this.dialogImageUrl = file.url;
      this.dialogFileUrl = file.url;
      // alert(file.url)
      // this.dialogFileUrl = 'https://www.bendudu.com:8080/profile/upload/2023/10/18/20231018214647A011.doc'
      // this.dialogFileUrl = 'https://47.93.189.255:8080/profile/upload/2023/03/19/test7_20230319222030A007.jpg'
      if(this.dialogFileUrl.includes("47.93.189.255")==true)
      {
        this.dialogImageUrl = this.dialogImageUrl.replace("47.93.189.255","www.bendudu.com")
        this.dialogFileUrl = this.dialogFileUrl.replace("47.93.189.255","www.bendudu.com")
}
      this.dialogVisible = true;
    },
    handleDownload(url) {
@@ -398,10 +410,52 @@
    handleEdit()
    {
      this.dsb = false
      // this.btn = true
      this.btn = true
      this.isShow=false
    },
    requestUpload(params)
    {
      var file = params.file;
      var formData = new FormData();
      formData.append('uploadFile', file);
      let _this = this
      this.uploading = true;
      uploadPic(formData).then(response => {
        let pth = response.data.originalFilename.substr(response.data.originalFilename.length-4, response.data.originalFilename.length)
        this.uploading = false;
        this.$modal.msgSuccess("上传成功");
        if(_this.fot.includes(pth) === true)
        {
          _this.fileList.push({name:response.data.fileName, "url":response.data.url})
          let ul = _this.fileList.map(function (elem){
                 return elem.url.replace(process.env.VUE_APP_BASE_TRUE_API,"")
               }).join(",")
               let uls = _this.fileListOther.map(function (elem){
                 return elem.url.replace(process.env.VUE_APP_BASE_TRUE_API,"")
               }).join(",")
               _this.formData.url = ul+","+uls
              // _this.fileListOther.push({name:response.data.fileName, url:response.data.url})
               alert(_this.formData.url)
               alert(12)
               updateHealth(_this.formData).then(response => {
                 this.$modal.msgSuccess("修改成功");
                 // this.open = false;
                 this.btn=false
               });
        }
        else{
          _this.fileListOther.push({name:response.data.fileName, url:response.data.url})
        }
      })
    },  requestUpload1(params)
    {
      var file = params.file;
      var formData = new FormData();
@@ -420,24 +474,33 @@
        else{
          _this.fileListOther.push({name:response.data.fileName, url:response.data.url})
  let ul = _this.fileList.map(function (elem){
                 return elem.url.replace(process.env.VUE_APP_BASE_TRUE_API,"")
               }).join(",")
               let uls = _this.fileListOther.map(function (elem){
                 return elem.url.replace(process.env.VUE_APP_BASE_TRUE_API,"")
               }).join(",")
               _this.formData.url = ul+","+uls
              // _this.fileListOther.push({name:response.data.fileName, url:response.data.url})
               console.log(_this.formData.url)
               updateHealth(_this.formData).then(response => {
                 this.$modal.msgSuccess("修改成功");
                 // this.open = false;
                 this.btn=false
               });
        }
      })
    },
    /** 导出按钮操作 */
    handleExport() {
      this.download('/zYearInfo/export', {
        ...this.queryParams
      }, `zYearInfo${new Date().getTime()}.xlsx`)
    }
  }
}
</script>
<style scoped lang="scss">
<style scoped>
.mt
{
  position: relative;
@@ -452,7 +515,7 @@
  display: block;
  position: absolute;
}
.hide .el-upload--picture-card {
.hide /deep/ .el-upload--picture-card {
  display: none;
}
.form{