linwenling
2023-07-18 9f703491c7098deda073f9f5014035e973031aa4
ruoyi-ui/src/views/pet/petInfo.vue
@@ -2,14 +2,13 @@
  <div class="app-container">
    <div class="form-header mt">
      <h4 class="dt h4">基本信息 </h4>
      <el-button type="primary" class="pt"  icon="el-icon-edit" @click="handleEdit()" :disabled="btn">编辑</el-button>
      <el-button type="primary"  @click="Petnote(id)" :disabled="btn">魅宠备忘录</el-button>
      <el-button type="primary"  @click="Petnote(pid)" :disabled="btn">魅宠备忘录</el-button>
    </div>
    <h2 style="width: 100px;height: 16px;font-size: 15px;font-family: Microsoft YaHei-Regular, Microsoft YaHei;font-weight: 400;color: #000000;line-height: 15px;">基本信息</h2>
    <el-container >
      <div >
        <el-container >
    <el-col >
          <el-col >
            <el-form ref="elForm" :model="petList" :rules="rules" size="medium"  label-position="left"
                     v-loading="loading" :data="petList" @selection-change="handleSelectionChange" label-width="120px" >
              <el-row :span="5">
@@ -105,6 +104,9 @@
                  </el-input>
                </el-form-item>
              </el-row>
              <el-form-item size="large">
              </el-form-item>
            </el-form>
          </el-col>
        </el-container>
@@ -112,16 +114,16 @@
      <div style="padding-left:250px;padding-top:30px">
        <el-col :span="6" :data="petList">
            <div class="block" :model="petList" >
              <el-col v-model="petList.url" prop="url">
          <div class="block" :model="petList" >
            <el-col v-model="petList.headPicture" prop="headPicture">
              <el-avatar shape="square" :size=200 >
                <el-image
                  :src="'http://47.93.189.255:8080/'+ petList.url"
                  :fit="fit" style="width: 212px;height: 168px;border-radius: 0px 0px 0px 0px;opacity: 1;border: 1px solid rgba(0,0,0,0.5);"
                  :src="'http://47.93.189.255:8080/'+ petList.headPicture"
                  :fit="fit" style="width: 100%;height: 100%;border-radius: 0px 0px 0px 0px;opacity: 1;border: 1px solid rgba(0,0,0,0.5);"
                ></el-image>
              </el-avatar>
              </el-col>
            </div>
            </el-col>
          </div>
        </el-col>
      </div>
@@ -132,35 +134,20 @@
    <el-container >
      <div >
        <el-container >
    <el-col >
            <el-form ref="elForm" :model="petownerList" :rules="rules" size="medium"  label-position="left"
                     v-loading="loading" :data="petownerList" @selection-change="handleSelectionChange" label-width="120px" >
          <el-col >
            <el-form ref="elForm" :model="petList" :rules="rules" size="medium"  label-position="left"
                     v-loading="loading" :data="petList" @selection-change="handleSelectionChange" label-width="120px" >
              <el-row :span="5">
                <el-form-item label="饲养人姓名" prop="name" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.name" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb" >
                <el-form-item label="饲养人姓名" prop="masterName" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petList.masterName" placeholder="" clearable :style="{width: '100%'}" readonly  unselectable="on"  >
                  </el-input>
                </el-form-item>
              </el-row>
              <el-row :span="5">
                <el-form-item label="固定电话" prop="fixedNo" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.fixedNo" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                  </el-input>
                </el-form-item>
              </el-row>
              <el-row :span="5">
                <el-form-item label="移动电话" prop="birth" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.birth" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                  </el-input>
                </el-form-item>
              </el-row>
              <el-row :span="5">
                <el-form-item label="住所性质" prop="property" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.property" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                  </el-input>
                </el-form-item>
              </el-row>
                <el-form-item label="住所详细地址" prop="address" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.address" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                <el-form-item label="住所详细地址" prop="masterAddress" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petList.masterAddress" placeholder="" clearable :style="{width: '100%'}" readonly  unselectable="on">
                  </el-input>
                </el-form-item>
              </el-row>
@@ -171,48 +158,166 @@
      <div style="padding-left:150px">
        <el-container>
          <el-col v-loading="loading" :data="petownerList" @selection-change="handleSelectionChange">
            <el-form ref="elForm" :model="petownerList" :rules="rules" size="medium"  label-position="left" >
          <el-col v-loading="loading" :data="petList" @selection-change="handleSelectionChange">
            <el-form ref="elForm" :model="petList" :rules="rules" size="medium"  label-position="left" >
              <el-row :span="5">
                <el-form-item label="证件类型" prop="certificateType" label-width="80px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.certificateType" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                <el-form-item label="身份证号" prop="masterIdNum" label-width="80px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petList.masterIdNum" placeholder="" clearable :style="{width: '100%'}" readonly  unselectable="on">
                  </el-input>
                </el-form-item>
              </el-row>
              <el-row :span="5">
                <el-form-item label="证件号码" prop="certificateNo" label-width="80px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.certificateNo" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                  </el-input>
                </el-form-item>
              </el-row>
              <el-row :span="5">
                <el-form-item label="拥有犬只数量" prop="many" label-width="140px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.many " placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                  </el-input>
                </el-form-item>
              </el-row>
              <el-row :span="5">
                <el-form-item label="电子邮件" prop="email" label-width="80px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petownerList.email" placeholder="" clearable :style="{width: '100%'}" :disabled="dsb">
                <el-form-item label="移动电话" prop="phone" label-width="100px" style="background: #FAD1E0;border-radius: 6px 6px 0px 6px;opacity: 1;">
                  <el-input v-model="petList.phone" placeholder="" clearable :style="{width: '100%'}" readonly  unselectable="on">
                  </el-input>
                </el-form-item>
              </el-row>
              <el-form-item size="large">
              </el-form-item>
            </el-form>
          </el-col>
        </el-container>
      </div>
    </el-container>
    <h2 style="width: 100px;height: 16px;font-size: 15px;font-family: Microsoft YaHei-Regular, Microsoft YaHei;font-weight: 400;color: #000000;line-height: 15px;">魅宠全身照</h2>
    <div style="padding-left:50px;width: 1000px;;height: 500px;">
      <el-col :span="6" :data="petList">
        <div class="block" :model="petList" >
          <el-col v-model="petList.fullPicture" prop="fullPicture">
            <el-avatar shape="square"  style="width: 1000px;;height: 500px;" >
              <el-image
                :src="'http://47.93.189.255:8080/'+ petList.fullPicture"
                :fit="fit" style="width: 100%;height: 100%;border-radius: 0px 0px 0px 0px;opacity: 1;border: 1px solid rgba(0,0,0,0.5);"
              ></el-image>
            </el-avatar>
          </el-col>
        </div>
        <el-button  v-if="isShow" type="primary" @click="submitForm" :disabled="dsb">修改魅宠信息</el-button>
      </el-col>
    </div>
    <el-dialog  :visible.sync="dialogVisible">
      <img w-full :src="dialogImageUrl" alt="Preview Image" />
    </el-dialog>
    <el-dialog :title="title" :visible.sync="openDataScope" width="1000px"  append-to-body>
      <el-row :gutter="10" class="mb8">
        <el-col :span="1.5">
          <el-button
            type="primary"
            plain
            icon="el-icon-plus"
            size="mini"
            @click="handleAdd"
            v-hasPermi="['system:role:add']"
          >新增</el-button>
        </el-col>
        <el-col :span="1.5">
          <el-button
            type="danger"
            plain
            icon="el-icon-delete"
            size="mini"
            :disabled="multiple"
            @click="handleDelete"
            v-hasPermi="['system:role:remove']"
          >删除</el-button>
        </el-col>
        <el-col :span="1.5">
          <el-button
            type="warning"
            plain
            icon="el-icon-download"
            size="mini"
            @click="handleExport"
            v-hasPermi="['family:note:export']"
          >导出</el-button>
        </el-col>
        <el-col :span="1.5">
          <el-button
            type="warning"
            plain
            icon="el-icon-download"
            size="mini"
            @click="handleExport"
            v-hasPermi="['family:note:export']"
          >导入模板下载</el-button>
        </el-col>
        <el-col :span="1.2">
          <el-upload
            action=""
            class="upload-demo"
            :show-file-list="false"
            :http-request="handleEnport"
          >
            <el-button size="mini"   type="primary"
                       plain
                       icon="el-icon-plus" >导入</el-button>
          </el-upload>
        </el-col>
        <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
      </el-row>
      <el-table v-loading="loading" :data="PetNoteList" @selection-change="handleSelectionChange" @row-click="handleCheck" :row-class-name="tableRowClassName" >
        <el-table-column type="selection" width="55"  align="center" />
        <el-table-column  label="序号" sortable type="index" :index="(queryParams.pageNum-1)*queryParams.pageSize+1" width="120"/>
        <el-table-column label="题名" prop="title" sortable :show-overflow-tooltip="true" width="150" />
        <el-table-column label="提醒时间" prop="remindTime" sortable :show-overflow-tooltip="true" width="150" />
        <el-table-column label="记录时间" prop="createTime" sortable :show-overflow-tooltip="true" width="150" />
        <el-table-column label="备注" prop="remark" sortable width="100" />
        <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
          <template slot-scope="scope" v-if="scope.row.roleId !== 1">
            <el-button
              size="mini"
              type="text"
              icon="el-icon-edit"
              @click="handleUpdate(scope.row)"
              v-hasPermi="['familymodel:property:info']"
            >修改</el-button>
            <el-button
              size="mini"
              type="text"
              icon="el-icon-delete"
              @click="handleDelete(scope.row)"
              v-hasPermi="['system:role:remove']"
            >删除</el-button>
            <el-dropdown size="mini" @command="(command) => handleCommand(command, scope.row)" v-hasPermi="['familymodel:property:info']">
              <el-button size="mini" type="text" icon="el-icon-d-arrow-right"  @click="handleCheck(scope.row)">查看详情</el-button>
            </el-dropdown>
          </template>
        </el-table-column>
      </el-table>
      <pagination
        v-show="total>0"
        :total="total"
        :page.sync="queryParams.pageNum"
        :limit.sync="queryParams.pageSize"
        @pagination="getList"
      />
    </el-dialog>
  </div>
</template>
<script>
import {getPetList, getPetownerList, uploadPic, download} from "@/api/pet/index";
import {getPetList, getPetowner, listPetnote,getPetnoteList,uploadPic, download,updatePetowner,updatePet,addPetnote} from "@/api/pet/index";
import {addRole, updateRole} from "@/api/system/role";
import {blobValidate} from "@/utils/ruoyi";
import errorCode from "@/utils/errorCode";
@@ -229,10 +334,36 @@
      fileList:[
      ],
      fileListOther:[
      ],
      dsb:true,
      btn:false,
      isShow:true,
      // 总条数
      total: 0,
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        title:undefined,
        remindTime:undefined,
        createTime:undefined,
        remark:undefined,
        url:undefined,
        happenStartTime:undefined,
        happenEndTime:undefined
      },
      pid:undefined,
      dsb:true,
      btn:false,
      title: '魅宠备忘录',
      openDataScope: false,
      PetNoteList:{
        pid:undefined,
        title:undefined,
        remide_time:undefined,
        create_time:undefined,
        remark:undefined,
        url:undefined,
      },
      petList: {
        type: undefined,
        kind: undefined,
@@ -250,23 +381,16 @@
        certificateNo: undefined,
        fixedNo:undefined,
        many:undefined,
        phoneNo:undefined,
        address: undefined,
        property: undefined,
      },
        dialogImageUrl: '',
        dialogVisible: false,
        disabled: false,
      dialogImageUrl: '',
      dialogVisible: false,
      disabled: false,
      rules: {
        idNum: [{
          required: true,
          message: '请输入idNum',
          trigger: 'blur'
        }],
        kind: [{
          required: true,
          message: '请选择保洁/收纳',
          trigger: 'change'
        }],
        type: [{
          required: true,
          message: '请输入类别',
@@ -301,6 +425,7 @@
  watch: {},
  created() {
    const id = this.$route.params && this.$route.params.pid;
    this.pid = id;
    let jd;
    if(this.$route.query.detail!=undefined)
    {
@@ -316,49 +441,58 @@
    }
    let _this = this
    if (id) {
      this.loading = true;
      getPetList(id).then((response) => {
        this.petList = response.data;
        console.log(response.data)
        this.loading = false;
      });
      this.getCateInfor()
    };
    if (id) {
      this.loading = true;
      getPetownerList(id).then((response) => {
      getPetowner(id).then((response) => {
        this.petownerList = response.data;
        console.log(response.data)
        this.loading = false;
      });
      this.getCateInfor()
    };
    this.getList();
    }
  },
  mounted() {},
  methods: {
    getList() {
      this.loading = true;
      //   this.queryParams.happenStartTime = this.dateRange.length > 0 && this.dateRange[0]
      //   this.queryParams.happenEndTime = this.dateRange.length > 0 && this.dateRange[1]
      // console.log(this.queryParams)
      this.queryParams.pid = this.pid;
      //  listProperty(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
      listPetnote(this.queryParams).then(response => {
          //  alert(123)
          //   console.log(response.data)
          console.log(response.data)
          this.PetNoteList = response.data.data;
          this.total = response.data.total;
          this.loading = false;
        }
      );
    },
    submitForm() {
      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
      }).join(",")
      this.petList.url = ul+","+uls
      this.$refs['elForm'].validate(valid => {
        if (valid) {
          if (this.formData.id != undefined) {
            updateEconomy(this.formData).then(response => {
          if (this.petList.id != undefined) {
            updatePet(this.petList).then(response => {
              this.$modal.msgSuccess("修改成功");
              // this.open = false;
              this.btn=false
@@ -370,6 +504,26 @@
        }
      })
    },
    /** 查看详细信息 */
    handleCheck(row){
      const id = row.id;
      this.$router.push("/familymodel/pet/petnote/" + id);
    },
    /** 修改按钮操作 */
    handleUpdate(row) {
      const id = row.id;
      let jd = true
      this.$router.push({
        path:"/familymodel/pet/petnote/" + id,
        query:{
          detail:jd
        }
      });
    },
    resetForm() {
      this.$refs['elForm'].resetFields()
    },
@@ -388,17 +542,25 @@
    },
   /** 备忘录 */
        Petnote(pid){
      this.$router.push("/familymodel/pet/petnote/" + pid);
    /** 备忘录 */
    Petnote(pid){
      this.openDataScope = true
      this.getList()
    },
      handlePictureCardPreview(file) {
        this.dialogFileUrl = file.url;
    handlePictureCardPreview(file) {
      this.dialogFileUrl = file.url;
      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');
      },
    },
    /** 新增备忘录按钮操作 */
    handleAdd() {
      this.reset();
      this.open = true;
      this.title = "添加备忘录详细信息";
    },
//删除图片
    handleRemoveFile(file,) {
@@ -408,19 +570,19 @@
          this.$delete(this.fileListOther,i);
      }
    },
      handleDownload(url) {
        var formData = {'path':"/"+url.replace(process.env.VUE_APP_BASE_TRUE_API,"")};
    handleDownload(url) {
      var formData = {'path':"/"+url.replace(process.env.VUE_APP_BASE_TRUE_API,"")};
        let lens = formData.path.split(".")
        let suffix = lens[lens.length-1]
        download(formData).then(async (response) => {
          const isLogin = await blobValidate(response);
          let nt = new Date().getTime()
          let filename = 'property_'+nt+'.'+suffix
          const blob = new Blob([response])
          saveAs(blob, filename)
        })
      },
      let lens = formData.path.split(".")
      let suffix = lens[lens.length-1]
      download(formData).then(async (response) => {
        const isLogin = await blobValidate(response);
        let nt = new Date().getTime()
        let filename = 'property_'+nt+'.'+suffix
        const blob = new Blob([response])
        saveAs(blob, filename)
      })
    },
    handleEdit()
    {
      this.dsb = false