lkk
2024-10-24 b06a903d08d6f5432105d12686ccaf074b45323a
src/views/system/bill/index.vue
@@ -18,7 +18,7 @@
      </el-form-item>
      <el-form-item label="体检号" prop="tjNum">
        <el-input
         ref="inputName"
          ref="inputName"
          style="width: 170px"
          v-model="queryParams.tjNum"
          placeholder="请输入体检号"
@@ -73,7 +73,8 @@
        <el-button
          type="primary"
          icon="el-icon-search"
          size="mini" style="margin-right:15px;"
          size="mini"
          style="margin-right: 15px"
          @click="handleQuery"
          >搜索</el-button
        >
@@ -84,27 +85,35 @@
      </el-form-item>
    </el-form>
    <el-row :gutter="10" class="mb8" style="margin-left:10px">
    <el-row :gutter="10" class="mb8" style="margin-left: 10px">
      <el-col :span="1.5">
        <el-button
        type="primary"
        @click="handleReport"
        :disabled="single"
        size="mini"
        v-hasPermi="['hosp:order:export']"
        >补打导检单</el-button
      >
          type="primary"
          @click="handleReport"
          :disabled="single"
          size="mini"
          v-hasPermi="['hosp:order:export']"
          >补打导检单</el-button
        >
      </el-col>
      <el-col :span="1.5">
      <!-- <el-col :span="1.5">
        <el-button
        type="primary"
        size="mini"
        @click="Collection"
        :disabled="single"
        >条码生成</el-button
      >
      </el-col>
          type="primary"
          size="mini"
          @click="Collection"
          :disabled="single"
          >条码生成</el-button
        >
      </el-col> -->
      <div id="printSection" style="display: none">
        <svg id="barcode"></svg>
      </div>
      <!-- <img id="base64Image" alt="Base64 Image" /> -->
      <!-- 用于显示条形码的容器 -->
      <!-- <div id="printArea">
        <svg id="barcode" v-if="barcodeVisible"></svg>
      </div> -->
      <!-- <el-button type="primary" size="mini" :disabled="multiple" @click="viewReport">体检报告</el-button>
      <el-button type="primary" size="mini" :disabled="multiple" @click="printHandle">打印小票</el-button> -->
      <!-- <el-col :span="1.5">
@@ -126,145 +135,144 @@
      测试
    </div> -->
      <el-table
        border
        style="margin: 14px; width: 99%"
        v-loading="loading"
        :default-sort="{ prop: 'createTime', order: 'descending' }"
        :data="orderList"
        @selection-change="handleSelectionChange"
        ref="multipleTable"
    <el-table
      border
      style="margin: 14px; width: 99%"
      v-loading="loading"
      :default-sort="{ prop: 'createTime', order: 'descending' }"
      :data="orderList"
      @selection-change="handleSelectionChange"
      ref="multipleTable"
    >
      <el-table-column
        type="selection"
        width="40px"
        align="center"
        height="10px"
        fixed="left"
      />
      <el-table-column
        label="序号"
        align="center"
        prop="newID"
        width="50px"
        fixed="left"
        height="10px"
      />
      <el-table-column
        label="姓名"
        align="center"
        prop="tjCustomerName"
        height="10px"
        width="90px"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="性别"
        align="center"
        prop="tjCustomerSex"
        width="55px"
        height="10px"
        :show-overflow-tooltip="true"
      >
        <el-table-column
          type="selection"
          width="40px"
          align="center"
          height="10px"
          fixed="left"
        />
        <el-table-column
          label="序号"
          align="center"
          prop="newID"
          width="50px"
          fixed="left"
          height="10px"
        />
        <el-table-column
          label="姓名"
          align="center"
          prop="tjCustomerName"
          height="10px"
          width="90px"
          :show-overflow-tooltip="true"
        />
        <el-table-column
          label="性别"
          align="center"
          prop="tjCustomerSex"
          width="55px"
          height="10px"
          :show-overflow-tooltip="true"
        >
          <template slot-scope="scope">
            <span v-if="scope.row.tjCustomerSex == '0'">男</span>
            <span v-if="scope.row.tjCustomerSex == '1'">女</span>
            <span v-if="scope.row.tjCustomerSex == '2'">未知</span>
          </template>
        </el-table-column>
        <el-table-column
          label="年龄"
          align="center"
          prop="tjCustomerAge"
          height="10px"
          width="60px"
          :show-overflow-tooltip="true"
        />
        <el-table-column
          label="电话"
          align="center"
          prop="tjCustomerPhone"
          :show-overflow-tooltip="true"
          height="10px"
          width="110px"
        />
        <el-table-column
          label="体检类型"
          align="center"
          prop="tjType"
          height="10px"
          width="80px"
          :show-overflow-tooltip="true"
        >
          <template slot-scope="scope">
            <span v-if="scope.row.tjType == '2'">个人</span>
            <span v-if="scope.row.tjType == '1'">团队</span>
          </template>
        </el-table-column>
        <el-table-column
          label="体检号"
          align="center"
          prop="tjNumber"
          :show-overflow-tooltip="true"
          width="160px"
        />
        <el-table-column
          label="所选套餐"
          align="center"
          prop="pacName"
          height="10px"
          :show-overflow-tooltip="true"
          width="140px"
        />
        <el-table-column
          label="登记人"
          align="center"
          prop="createBy"
          height="10px"
          :show-overflow-tooltip="true"
          width="100px"
        />
        <el-table-column
          label="登记时间"
          align="center"
          prop="createTime"
          width="155px"
          height="10px"
          sortable
          :show-overflow-tooltip="true"
        >
          <template slot-scope="scope">
            <span>{{ parseTime(scope.row.createTime) }}</span>
          </template>
        </el-table-column>
        <!-- <el-table-column label="完成时间" align="center" prop="finishTime" width="155px" height="10px"
        <template slot-scope="scope">
          <span v-if="scope.row.tjCustomerSex == '0'">男</span>
          <span v-if="scope.row.tjCustomerSex == '1'">女</span>
          <span v-if="scope.row.tjCustomerSex == '2'">未知</span>
        </template>
      </el-table-column>
      <el-table-column
        label="年龄"
        align="center"
        prop="tjCustomerAge"
        height="10px"
        width="60px"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="电话"
        align="center"
        prop="tjCustomerPhone"
        :show-overflow-tooltip="true"
        height="10px"
        width="110px"
      />
      <el-table-column
        label="体检类型"
        align="center"
        prop="tjType"
        height="10px"
        width="80px"
        :show-overflow-tooltip="true"
      >
        <template slot-scope="scope">
          <span v-if="scope.row.tjType == '2'">个人</span>
          <span v-if="scope.row.tjType == '1'">团队</span>
        </template>
      </el-table-column>
      <el-table-column
        label="体检号"
        align="center"
        prop="tjNumber"
        :show-overflow-tooltip="true"
        width="160px"
      />
      <el-table-column
        label="所选套餐"
        align="center"
        prop="pacName"
        height="10px"
        :show-overflow-tooltip="true"
        width="140px"
      />
      <el-table-column
        label="登记人"
        align="center"
        prop="createBy"
        height="10px"
        :show-overflow-tooltip="true"
        width="100px"
      />
      <el-table-column
        label="登记时间"
        align="center"
        prop="createTime"
        width="155px"
        height="10px"
        sortable
        :show-overflow-tooltip="true"
      >
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.createTime) }}</span>
        </template>
      </el-table-column>
      <!-- <el-table-column label="完成时间" align="center" prop="finishTime" width="155px" height="10px"
          :show-overflow-tooltip="true">
          <template slot-scope="scope">
            <span>{{ parseTime(scope.row.finishTime) }}</span>
          </template>
        </el-table-column> -->
        <!-- <el-table-column label="报告时间" align="center" prop="reportTime" width="155px" height="10px"
      <!-- <el-table-column label="报告时间" align="center" prop="reportTime" width="155px" height="10px"
          :show-overflow-tooltip="true">
          <template slot-scope="scope">
            <span>{{ parseTime(scope.row.reportTime) }}</span>
          </template>
        </el-table-column> -->
        <el-table-column
          label="备注"
          align="center"
          prop="remark"
          height="10px"
          :show-overflow-tooltip="true"
        />
        <!-- <el-table-column fixed="right" label="操作" align="center" class-name="small-padding fixed-width" height="10px"
      <el-table-column
        label="备注"
        align="center"
        prop="remark"
        height="10px"
        :show-overflow-tooltip="true"
      />
      <!-- <el-table-column fixed="right" label="操作" align="center" class-name="small-padding fixed-width" height="10px"
          width="60px">
          <template slot-scope="scope">
            <el-button size="mini" type="text" icon="el-icon-document" @click="investigation(scope.row)"
              v-hasPermi="['hosp:order:edit']" title="详情" style="margin-right: 15px"></el-button>
          </template>
        </el-table-column> -->
      </el-table>
    </el-table>
    <div class="pag">
      <div class="pag1">
@@ -459,7 +467,7 @@
</template>
<script>
import print from "print-js";
import {
  listOrder,
  getNumber,
@@ -468,12 +476,13 @@
  hasReport,
  hasPrintCode,
  getOrderList,
  getNewDateList
  getNewDateList,
} from "@/api/hosp/order";
import moment from "moment";
import ViewPdf from "@/components/ViewPdf";
import { projectGetList, getOrder } from "@/api/system/tijian";
import { SubmitCompany, getCompany, queryCompany } from "@/api/team/tuanti";
import JsBarcode from "jsbarcode";
export default {
  components: {
    ViewPdf,
@@ -631,19 +640,32 @@
          },
        ],
      },
      barcode: "", // 存储条码值
      barcodeVisible: false, // 控制条形码是否可见
      single: false, // 控制按钮是否禁用的条件
    };
  },
  created() {
    // this.getNowTime();
    this.Company();
    this.getdate();
  },
  mounted() {
    this.$nextTick(() => {
      this.$refs.inputName.focus();
    });
  },
  // mounted() {
  //   // const base64String =
  //   //   "";
  //   // const binaryString = atob(base64String.split(",")[1]);
  //   // // 将二进制数据转换为 Blob 对象
  //   // const blob = new Blob([binaryString], { type: "image/png" });
  //   // // 创建 URL 对象并将其分配给图像的 src 属性
  //   // const image = document.getElementById("base64Image");
  //   // console.log(image, 1111);
  //   // // image.src = URL.createObjectURL(blob);
  //   // image.src = base64String;
  //   // this.$nextTick(() => {
  //   //   this.$refs.inputName.focus();
  //   // });
  // },
  methods: {
    getdate() {
      getNewDateList().then((res) => {
@@ -803,37 +825,88 @@
      });
    },
    // 采血单
    Collection() {
      let tjNumber = this.barcode;
      hasPrintCode(tjNumber).then((response) => {
        this.$message({
          showClose: true,
          message: "条码已生成!",
          type: "success",
        });
      });
    },
    // onSubmit() {
    //   console.log("submit!");
    // Collection() {
    //   let tjNumber = this.barcode;
    //   hasPrintCode(tjNumber).then((response) => {
    //     this.$message({
    //       showClose: true,
    //       message: "条码已生成!",
    //       type: "success",
    //     });
    //   });
    // },
    // Collection() {
    //   let tjNumber = this.barcode;
    //   JsBarcode("#barcode", tjNumber, {
    //     format: "CODE128",
    //     width: 2,
    //     height: 100,
    //     displayValue: true,
    //   });
    //   this.$nextTick(() => {
    //     const barcodeElement = document.querySelector("#barcode");
    //     if (barcodeElement) {
    //       console.log(barcodeElement.innerHTML); // 打印条形码的内容,看看是否生成成功
    //     } else {
    //       console.log("条形码元素未找到");
    //     }
    //     const printContents = document.getElementById("printSection").innerHTML;
    //     const newWindow = window.open("", "_blank", "width=800,height=600");
    //     console.log(printContents);
    //     newWindow.document.write(`
    //    <html>
    //         <head>
    //           <title>Print Barcode</title>
    //           <style>
    //             @media print {
    //                body {
    //                   width: 80mm;
    //                   margin: 0;
    //                   padding: 0;
    //                   height: 25mm;
    //                 }
    //                 /* 将条形码居中 */
    //                 #barcode {
    //                   display: block;
    //                   // margin-left: 50%;
    //                   text-align: center;
    //                   width: 100%;
    //                   height: auto;
    //                 }
    //                /* 让条形码在打印时显示 */
    //                svg {
    //                  display: block;
    //                }
    //           </style>
    //         </head>
    //         <body>${printContents}</body>
    //       </html>
    //     `);
    //     newWindow.document.close();
    //     newWindow.focus();
    //     newWindow.print();
    //     newWindow.close();
    //   });
    // },
    dateChangebirthday1(val) {
      this.startTime = val;
    },
    /** 查询体检记录列表 */
    getList() {
      if(this.createTimeList){
      if (this.createTimeList) {
        this.queryParams.djbeginTime = this.createTimeList[0];
      this.queryParams.djendTime = this.createTimeList[1];
      }else if(this.createTimeList == null){
        this.queryParams.djendTime = this.createTimeList[1];
      } else if (this.createTimeList == null) {
        this.queryParams.djbeginTime = null;
      this.queryParams.djendTime = null;
      }else{
        this.queryParams.djendTime = null;
      } else {
        this.queryParams.djbeginTime = this.startTime[0];
      this.queryParams.djendTime = this.startTime[1];
        this.queryParams.djendTime = this.startTime[1];
      }
      this.loading = true;
      getOrderList(this.queryParams).then((response) => {
        this.orderList = response.data.list;
@@ -900,9 +973,9 @@
      };
      this.resetForm("form");
    },
    hb(){
    hb() {
      // console.log(this.queryParams.tjNum);
       if (this.queryParams.tjNum != undefined) {
      if (this.queryParams.tjNum != undefined) {
        this.handleQuery();
      }
    },
@@ -913,7 +986,7 @@
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.createTimeList=[]
      this.createTimeList = [];
      this.resetForm("queryForm");
      this.handleQuery();
    },
@@ -1075,7 +1148,7 @@
  },
};
</script>
<style lang="scss">
<style lang="scss" scoped>
.pag {
  width: 100%;
  display: flex;
@@ -1173,4 +1246,49 @@
  display: flex;
  justify-content: center;
}
.print-container {
  width: 300px; /* 设定宽度以确保打印时布局合适 */
  padding: 10px;
  border: 1px solid #000; /* 可选:给打印区域加一个边框 */
  font-family: Arial, sans-serif;
}
.barcode-section {
  text-align: center;
  margin-bottom: 10px;
}
.info-section {
  font-size: 14px;
  line-height: 1.5;
}
.info-section p {
  margin: 2px 0; /* 控制信息间的间距 */
}
#barcode {
  display: block;
  margin: 0 auto;
}
.info-section p {
  margin: 2px 0;
  font-size: 14px;
}
/* 打印时隐藏所有其他内容 */
// @media print {
//   #barcode {
//     width: 58mm;
//     height: auto;
//   }
//   #printSection {
//     display: flex;
//     justify-content: center;
//     align-items: center;
//     height: 100vh; /* 父容器高度为全页高度 */
//   }
// }
</style>