111
lkk
2025-01-09 5a9be998d3dc8097d19d6f4833c0538c34bd6dcb
src/views/system/tijian/index.vue
@@ -135,6 +135,13 @@
                },
              ]"
            >
              <span
                slot="label"
                style="display: inline-block; border-bottom: 2px solid blue"
                @click="openname"
              >
                姓名
              </span>
              <el-input
                v-model="form.cusName"
                placeholder="请输入姓名"
@@ -327,7 +334,7 @@
              />
            </el-form-item>
            <el-form-item label="年龄  " prop="age">
            <el-form-item label="年龄" prop="age">
              <el-input
                v-model="form.age"
                :disabled="isDisabled"
@@ -368,28 +375,7 @@
              />
            </el-form-item>
            <el-form-item label="单位名称" prop="dictCompId">
              <el-select
                :remote-method="getRemoteData"
                v-model="form.compName"
                remote
                filterable
                style="width: 300px"
                placeholder="请选择单位名称"
                clearable
                @change="idFn1"
              >
                <el-option
                  v-for="dict in CompanyList"
                  :key="dict.cnName"
                  :label="dict.cnName"
                  :value="dict.drugManufacturerId"
                />
              </el-select>
              <i class="el-icon-circle-plus-outline" @click="handleAdd1"></i>
            </el-form-item>
            <el-form-item label="文化程度" prop="wenHua">
            <el-form-item label="文化程度" prop="wenHua" label-width="93px">
              <el-input
                :disabled="isDisabled"
                v-model="form.wenHua"
@@ -518,7 +504,8 @@
            >
            <el-button type="primary" plain size="mini" @click="setImage()"
              >拍照</el-button
            ><br />
            >
            <br />
          </div>
        </div>
      </el-col>
@@ -562,7 +549,6 @@
                @click="handle"
                >查询</el-button
              >
              <!-- <el-button type="primary"  size="mini" @click="submit">确认</el-button> -->
            </el-form-item>
          </el-form>
          <div class="tab4">
@@ -614,19 +600,6 @@
</el-table-column> -->
              </el-table>
            </div>
            <!-- <el-button
                style="
                  width: 20px;
                  height: 100px;
                  margin-top: 20%;
                  font-size: 10px;
                  padding-right: 20px;
                "
                type="primary"
                size="mini"
                @click="submit"
                ><i style="font-size: 18px" class="el-icon-d-arrow-right"></i
              ></el-button> -->
          </div>
        </el-tab-pane>
        <el-tab-pane label="组合" name="third">
@@ -862,28 +835,6 @@
                    </el-table-column>
                  </el-table>
                  <h3 style="font-weight: 600">合计:{{ marryall }}元</h3>
                  <!-- <el-collapse v-model="activeName" accordion v-if="list1">
                    <div>
                      <el-collapse-item title="请选择项目">
                        <el-table
                          :data="DataList"
                          border
                          style="width: 100%"
                          height="400"
                          :span-method="objectSpanMethod"
                        >
                          <el-table-column
                            prop="proName"
                            label="项目"
                            width="180"
                          >
                          </el-table-column>
                          <el-table-column prop="ordPrice" label="原价">
                          </el-table-column>
                        </el-table>
                      </el-collapse-item>
                    </div>
                  </el-collapse> -->
                </div>
              </el-col>
            </el-row>
@@ -899,120 +850,88 @@
    <el-row v-if="tcShow">
      <el-col :span="15">
        <div class="grid-content bg-purple">
          <!-- <el-table :data="fData" border height="220px" style="width: 100%; ">
            <el-table-column prop="proName" label="组合项目" align="center" width="200px">
            </el-table-column>
            <el-table-column prop="proPrice" label="金额" align="center" width="150px">
            </el-table-column>
            <el-table-column prop="allSonProName" label="单个项目" align="center" :show-overflow-tooltip="true">
            </el-table-column>
          </el-table>
          <div class="tab">
            <el-table :data="DataList" border height="220" style="width: 350px; margin-top: 20px">
              <el-table-column prop="proName" label="单个项目" align="center">
              </el-table-column>
              <el-table-column prop="proPrice" label="金额" align="center"></el-table-column>
            </el-table>
          </div> -->
          <!-- <div style="height:480px;overflow:scroll;background-color: #ffffff;
          font-size: 12.5px;">
            <table style="width: 96%; margin: 4px 10px; border: 1px solid white" cellspacing="4" border="2"
              v-for="(item, index) in tableData1" :key="index">
              <caption style="background-color: #f8f8f9">
                {{
                  item.parentName
                }}
              </caption>
              <tr align="center">
                <th style="width:200px">项目</th>
                <th>现价</th>
                <th>原价</th>
              </tr>
              <tr v-for="item1 in item.list" :key="item1.proId">
                <td>{{ item1.proName }}</td>
                <td>
                  {{ item1.nowPrice }}
                </td>
                <td>{{ item1.ordPrice }}</td>
              </tr>
            </table>
           </div> -->
          <template>
            <el-form
              :model="form"
              :inline="true"
              label-width="75px"
              style="margin-left: 20px"
              style="margin-left: 20px; width: 900px"
            >
              <el-form-item label="体检类型">
              <el-form-item label="姓名" prop="cusName">
                <span slot="label"> 姓名 </span>
                <el-input
                  v-model="form.cusName"
                  placeholder="请输入姓名"
                  :disabled="isDisabled"
                />
              </el-form-item>
              <el-form-item label="性别" prop="cusSex">
                <el-select
                  :disabled="isDisabled"
                  v-model="form.cusSex"
                  placeholder="性别"
                  style="width: 150px"
                  v-model="form.tjType"
                  placeholder="请选择体检类型"
                >
                  <el-option
                    v-for="dict in dict.type.sys_user_sex"
                    :key="dict.value"
                    :label="dict.label"
                    :value="parseInt(dict.value)"
                  ></el-option>
                </el-select>
              </el-form-item>
              <el-form-item label="证件号码" prop="cusIdcard">
                <span slot="label"> 证件号码 </span>
                <el-input
                  :disabled="isDisabled"
                  v-model="form.cusIdcard"
                  placeholder="请输入身份证号"
                  @input="inputChange"
                />
              </el-form-item>
              <el-form-item label="单位名称" prop="firmName">
                <el-select
                  v-model="form.firmName"
                  remote
                  default-first-option
                  allow-create
                  filterable
                  style="width: 200px"
                  placeholder="请选择单位名称"
                  clearable
                  @change="idFn1"
                  @clear="clear"
                >
                  <el-option
                    v-for="dict in CompanyList"
                    :key="dict.cnName"
                    :label="dict.cnName"
                    :value="dict.cnName"
                  />
                </el-select>
              </el-form-item>
              <el-form-item label="单位部门" prop="firmDeptName">
                <el-input
                  v-model="form.firmDeptName"
                  style="width: 150px"
                  placeholder="请输入单位部门"
                  @input="inputChange"
                />
              </el-form-item>
              <el-form-item label="体检类型">
                <el-select v-model="form.tjType" placeholder="请选择体检类型">
                  <el-option
                    v-for="dict in dict.type.dict_team"
                    :key="dict.value"
                    :label="dict.label"
                    :value="dict.value"
                  ></el-option>
                </el-select>
              </el-form-item>
              <!-- <div class="tab1"> -->
              <!-- <el-form :inline="true" class="tab1"> -->
              <el-form-item label="应收金额">
                <el-input
                  placeholder="应收金额"
                  v-model="TotalPrice1"
                  disabled
                  style="width: 150px"
                ></el-input>
              </el-form-item>
              <el-form-item label="优惠">
                <!-- <el-input style="width: 100px" type="number" v-model="discount" :value="discount"></el-input> -->
                <el-input-number
                  ref="inputNumber"
                  style="width: 150px"
                  v-model="discount"
                  :precision="2"
                  :step="0.1"
                  :max="10"
                  :min="1"
                  @change="numberChange"
                  :disabled="isfalse"
                ></el-input-number>
              </el-form-item>
              <el-form-item label="实收金额">
                <el-input
                  placeholder="实收金额"
                  v-model="TotalPrice"
                  style="width: 150px"
                ></el-input>
              </el-form-item>
              <br />
              <!-- 140828199805050012 -->
              <el-form-item label="领取方式">
                <!-- <el-input style="width: 100%;"  v-model="form.getType" placeholder="请选择领取方式" /> -->
                <el-select
                  v-model="getType"
                  style="width: 150px"
                  @change="getmailType"
                >
                  <el-option
                    v-for="dict in dict.type.report_get_type"
                    :key="dict.value"
                    :label="dict.label"
                    :value="dict.value"
                    :disabled="!form.firmId && dict.value === '1'"
                  ></el-option>
                </el-select>
              </el-form-item>
              <el-form-item label="体检类别">
                <el-select
                  style="width: 150px"
                  style="width: 200px"
                  v-model="tjCategory"
                  placeholder="请选择体检类别"
                >
@@ -1025,6 +944,37 @@
                </el-select>
                <!-- <el-input v-model="form.category" placeholder="请输入体检类别" /> -->
              </el-form-item>
              <el-form-item label="应收金额">
                <el-input
                  placeholder="应收金额"
                  v-model="TotalPrice1"
                  disabled
                  style="width: 150px"
                ></el-input>
              </el-form-item>
              <el-form-item label="优惠">
                <!-- {{ discount }} -->
                <el-input-number
                  ref="inputNumber"
                  style="width: 150px"
                  v-model="discount"
                  :precision="2"
                  :step="0.1"
                  :max="10"
                  :min="0"
                  @change="numberChange"
                  :disabled="isfalse"
                ></el-input-number>
              </el-form-item>
              <el-form-item label="实收金额">
                <el-input
                  placeholder="实收金额"
                  v-model="TotalPrice"
                  style="width: 206px"
                ></el-input>
              </el-form-item>
              <br />
              <el-form-item style="margin-left: 149px">
                <el-button
@@ -1044,7 +994,8 @@
                <el-button
                  type="primary"
                  @click="submitPrice"
                  :disabled="confirm"
                  :loading="loadingSubmit"
                  :disabled="confirm || loadingSubmit"
                  v-if="showHidden.has_charge == 'N'"
                  size="mini"
                  >签到登记</el-button
@@ -1099,159 +1050,107 @@
            </div>
          </el-dialog>
          <div style="text-align: center; margin-bottom: 10px">
          <div
            style="
              display: flex;
              align-items: center;
              justify-content: flex-start;
              width: 100%;
            "
          >
            <div
              style="
                white-space: nowrap;
                overflow: hidden;
                text-overflow: ellipsis;
                margin-left: 46px;
                font-size: 16px;
                margin-right: 20px;
              "
            >
              <span v-if="this.tableData1[0]">{{
                this.tableData1[0].pacName || ""
              }}</span>
              已选项目条数:<span
                style="font-weight: 700; color: red; margin-right: 5px"
                >{{ this.tableData1.length || 0 }}</span
              >条
            </div>
            已选项目列表
          </div>
          <div
            style="
              padding: 0px 6px;
              border: 1px solid #e6ebf5;
              max-height: 420px;
              max-height: 650%;
              overflow: auto;
              width: 916px;
              margin-left: 35px;
            "
          >
            <el-collapse v-model="index" accordion v-if="list3">
              <div
                class="info1"
                v-for="(item, index) in tableData1"
                :key="'info1-' + index"
              >
                <el-collapse-item :name="index">
                  <template slot="title">
                    <div style="width: 70%">
                      {{
                        item.pacName +
                        ":" +
                        item.parentName +
                        " (应收金额:" +
                        item.ordPrice +
                        "元 / 实收金额:" +
                        item.nowPrice +
                        "元)"
                      }}
                    </div>
                    <div style="width: 20%">
                      <el-button
                        type="primary"
                        @click="candelete(item)"
                        style="float: right"
                        >删 除</el-button
                      >
                    </div>
                  </template>
                  <el-table
                    :data="item.list"
                    border
                    style="width: 100%"
                    height="270"
                  >
                    <el-table-column prop="s" label="项目" width="180">
                    </el-table-column>
                    <el-table-column prop="proType" label="性别" width="180">
                      <template
                        slot-scope="scope"
                        v-if="scope.row.proType == ''"
                      >
                        {{ scope.row.proType == "" ? "全部" : "" }}
                      </template>
                      <template slot-scope="scope" v-else>
                        <dict-tag
                          :options="dict.type.sys_user_sex"
                          :value="scope.row.proType"
                        />
                      </template>
                    </el-table-column>
                    <el-table-column prop="ordPrice" label="应收金额">
                    </el-table-column>
                    <el-table-column prop="nowPrice" label="实收金额">
                    </el-table-column>
                    <el-table-column prop="proCheckMethod" label="是否空腹">
                      <template slot-scope="scope">
                        <dict-tag
                          :options="dict.type.sys_yes_no"
                          :value="scope.row.proCheckMethod"
                        />
                      </template>
                    </el-table-column>
                  </el-table>
                </el-collapse-item>
              </div>
            </el-collapse>
            <div v-if="list2 == true">
              <el-table
                :data="tableData1"
                border
                style="width: 100%"
                height="250"
              >
                <el-table-column prop="proName" label="项目" width="180">
                </el-table-column>
                <el-table-column prop="proType" label="性别" width="180">
                  <template slot-scope="scope" v-if="scope.row.proType == ''">
                    {{ scope.row.proType == "" ? "全部" : "" }}
                  </template>
                  <template slot-scope="scope" v-else>
            <el-table :data="tableData1" border style="width: 100%">
              <el-table-column prop="proName" label="项目" width="180">
              </el-table-column>
              <el-table-column prop="proType" label="性别" width="50">
                <template slot-scope="scope">
                  <template v-if="isAll(scope.row.proType)"> 全部 </template>
                  <template v-else>
                    <dict-tag
                      :options="dict.type.sys_user_sex"
                      :value="scope.row.proType"
                    />
                  </template>
                </el-table-column>
                <el-table-column prop="ysPrice" label="应收金额">
                </el-table-column>
                <el-table-column prop="proPrice" label="实收金额">
                </el-table-column>
                <el-table-column prop="proCheckMethod" label="是否空腹">
                  <template slot-scope="scope">
                    <dict-tag
                      :options="dict.type.sys_yes_no"
                      :value="scope.row.proCheckMethod"
                    />
                  </template>
                </el-table-column>
              </el-table>
            </div>
                </template>
              </el-table-column>
            <el-collapse v-model="activeName" accordion v-if="list1">
              <div>
                <el-collapse-item title="请选择项目">
                  <el-table :data="list" border style="width: 100%">
                    <el-table-column prop="proName" label="项目" width="180">
                    </el-table-column>
                    <el-table-column prop="proType" label="性别" width="180">
                      <template
                        slot-scope="scope"
                        v-if="scope.row.proType == ''"
                      >
                        {{ scope.row.proType == "" ? "全部" : "" }}
                      </template>
                      <template slot-scope="scope" v-else>
                        <dict-tag
                          :options="dict.type.sys_user_sex"
                          :value="scope.row.proType"
                        />
                      </template>
                    </el-table-column>
                    <el-table-column prop="ordPrice" label="应收金额">
                    </el-table-column>
                    <el-table-column prop="nowPrice" label="实收金额">
                    </el-table-column>
                    <el-table-column prop="proCheckMethod" label="是否空腹">
                      <template slot-scope="scope">
                        <dict-tag
                          :options="dict.type.sys_yes_no"
                          :value="scope.row.proCheckMethod"
                        />
                      </template>
                    </el-table-column>
                  </el-table>
                </el-collapse-item>
              </div>
            </el-collapse>
              <el-table-column prop="ordPrice" label="应收金额">
              </el-table-column>
              <el-table-column label="折扣">
                <template slot-scope="scope">
                  <!-- 只输入纯数字折扣 -->
                  <el-input
                    v-model.number="scope.row.discount"
                    @input="validateDiscount(scope.row)"
                    placeholder="输入折扣"
                    size="small"
                    type="number"
                    min="0"
                    step="1"
                    max="10"
                  >
                  </el-input>
                </template>
              </el-table-column>
              <el-table-column prop="nowPrice" label="实收金额">
              </el-table-column>
              <el-table-column prop="proCheckMethod" label="是否空腹">
                <template slot-scope="scope">
                  <dict-tag
                    :options="dict.type.sys_yes_no"
                    :value="scope.row.proCheckMethod"
                  />
                </template>
              </el-table-column>
              <!-- <el-table-column prop="proCheckMethod" label="公费">
                <template #default="scope">
                  <el-checkbox v-model="scope.row.free" :disabled="true">
                    {{ scope.row.free ? "免费" : "收费" }}
                  </el-checkbox>
                </template>
              </el-table-column> -->
              <el-table-column label="操作" align="center" width="80px">
                <template slot-scope="scope">
                  <el-button
                    size="mini"
                    type="text"
                    icon="el-icon-delete"
                    @click="handleDelete1(scope.row)"
                    title="删除"
                  >
                  </el-button>
                </template>
              </el-table-column>
            </el-table>
          </div>
        </div>
      </el-col>
@@ -1379,7 +1278,7 @@
                  :precision="2"
                  :step="0.1"
                  :max="10"
                  :min="1"
                  :min="0"
                  @change="numberChange"
                  :disabled="isfalse"
                ></el-input-number>
@@ -1495,10 +1394,13 @@
      </span>
    </el-dialog>
    <Packages ref="aaa" @add="handleChanges" />
    <selectName ref="bbb" @add="handleChangesName" />
  </div>
</template>
<script>
import Big from "big.js";
import selectName from "@/components/selectName";
import { dataURLtoFile, random } from "./file";
import { getInfo } from "@/api/login";
import {
@@ -1508,9 +1410,8 @@
  getByTjNum,
} from "@/api/hosp/customer";
import { getPrintSetUp } from "@/api/system/examcharge";
import axios from "axios";
import { getIp } from "@/utils/auth";
import {
  tuantiSelect,
  deptTreeSelect,
  projectGetList,
  getOrder,
@@ -1519,7 +1420,9 @@
  getCusIdcard,
  getPackageListName,
  getaddtTransition,
  tuantiqueren,
  getTransitionList,
  getTransitionList1,
  getByTeamNo,
  delTbBycusCardIdAndProId,
  getLoadFile,
@@ -1527,6 +1430,7 @@
  getconfigKey,
  getHistryTjOrderProByCusIdCard,
  readCertCardInfos,
  gaibianzhekou,
} from "@/api/system/tijian";
import { addComp } from "@/api/system/comp";
import { getCompany, queryCompany } from "@/api/team/tuanti";
@@ -1554,6 +1458,7 @@
    VTreeTransfer,
    historyTj,
    Packages,
    selectName,
  },
  data() {
    return {
@@ -1575,7 +1480,7 @@
      lishi: false,
      table: false,
      HistoryList: {},
      index: 0,
      index: [],
      names: "",
      inputSSS: "",
      dictType: [
@@ -1624,6 +1529,7 @@
      hide: true,
      beat: false,
      dialogVisibles: false,
      loadingSubmit: false,
      charge: false,
      src: "",
      url: "",
@@ -1650,10 +1556,9 @@
      isDisabled: false,
      size: "",
      tcShow: false,
      tcShows: false,
      // 套餐提交按钮
      confirm: false,
      TotalPrice: "0.00",
      TotalPrice: 0,
      TotalPrice1: 0,
      discount: 10,
      newpacName: [],
@@ -1765,12 +1670,14 @@
      CompanyList: [],
      form: {
        cusIdcard: "",
        tjType: "3",
        tjType: "",
        cusSex: 1,
        cusNational: "1",
        cusMarryStatus: "5",
        idType: "1",
        ageUnit: "0",
        firmId: "",
        firmDeptName: "",
      },
      form1: {},
      title: "",
@@ -1817,13 +1724,77 @@
    this.getCurrentDateTime();
    this.startTimer();
    this.getList1();
    // this.getData();
  },
  mounted() {
  },
  mounted() {},
  methods: {
    clear() {
      this.form.firmId = "";
    },
    /** 删除按钮操作 */
    handleDelete1(row) {
      // console.log(row);
      let data = {
        cusCardId: row.cusId,
        proId: row.parentProId,
      };
      this.$modal
        .confirm("是否确认删除?")
        .then(() => {
          return delTbBycusCardIdAndProId(data);
        })
        .then(() => {
          this.TotalPrice1 = 0;
          getTransitionList1(row.cusId).then((response) => {
            this.tableData1 = response.data;
            this.tableData1.forEach((item) => {
              this.TotalPrice1 += item.ordPrice;
              this.TotalPrice += item.nowPrice;
            });
            this.TotalPrice = this.tableData1.reduce((sum, item) => {
              return sum.plus(new Big(item.nowPrice || "0"));
            }, new Big(0));
            this.discount =
              (Math.floor((this.TotalPrice / this.TotalPrice1) * 100) / 100) *
              10;
          });
          this.$modal.msgSuccess("删除成功");
        })
        .catch(() => {});
    },
    validateDiscount(row) {
      if (row.discount > 10) {
        row.discount = 10; // 强制将值设置为最大值
      } else if (row.discount < 0) {
        row.discount = 0; // 强制将值设置为最小值
      }
      this.updateProPrice(row); // 更新价格或其他逻辑
    },
    isAll(value) {
      return value === "" || value === null;
    },
    updateProPrice(row) {
      const ordPrice = new Big(row.ordPrice);
      const discount = new Big(row.discount);
      const result = ordPrice.times(discount.div(10)); // ordPrice * (discount / 10)
      row.nowPrice = result.toNumber();
      this.TotalPrice = this.tableData1.reduce((sum, item) => {
        return sum.plus(new Big(item.nowPrice || "0"));
      }, new Big(0));
      this.discount =
        (Math.floor((this.TotalPrice / this.TotalPrice1) * 100) / 100) * 10;
    },
    openname() {
      this.$refs.bbb.open = true;
      this.$refs.bbb.title = "搜索姓名";
      this.$refs.bbb.getList();
    },
    getCompanyList() {
      this.loading = true;
      getconfigKey("team_reservation_default_day").then((res) => {
@@ -1866,25 +1837,22 @@
      this.title = "添加体检单位信息维护";
    },
    idFn1(value) {
      if (value) {
        this.form.dictCompId = value;
        // console.log(value);
        const originalCompId = this.form.firmId;
        this.form.firmName = value;
        this.CompanyList.forEach((item) => {
          if (item.drugManufacturerId == this.form.dictCompId) {
            this.form.compName = item.cnName;
          if (item.cnName == this.form.firmName) {
            this.form.firmId = item.drugManufacturerId;
          }
        });
      }
    },
    getRemoteData(query) {
      if (query) {
        let compName = query;
        queryCompany(compName).then((response) => {
          this.CompanyList = response.data;
          this.CompanyList.forEach((item) => {
            this.objs = item;
          });
        });
        if (this.form.firmId === originalCompId) {
          this.form.firmId = "";
        }
        if (this.form.firmId) {
          this.form.tjType = "1";
        }
      }
    },
    getCurrentDateTime() {
@@ -1999,47 +1967,6 @@
      this.$refs.historyTj.getlist();
    },
    candelete(item) {
      let data = {
        cusCardId: this.form.cusIdcard,
        proId: item.proPrantId,
      };
      delTbBycusCardIdAndProId(data).then((res) => {
        getTransitionList(this.form.cusIdcard).then((response) => {
          this.tableData1 = response.data;
          this.TotalPrice1 = 0;
          if (this.tableData1) {
            this.tableData1.forEach((item) => {
              this.TotalPrice1 += item.nowPrice;
              if (item.pacName === null) {
                item.pacName = "单项";
              }
              if (item.pacName == "单项") {
                item.list.forEach((item9) => {
                  this.treeList.push(item9.proId);
                });
              }
              this.pacName = item.pacName;
            });
            const r = /^\+?[0-9][0-9]*$/; //正整数(可以0打头)
            let TotalPrice = this.TotalPrice1 * (this.discount / 10);
            if (r.test(TotalPrice)) {
              this.TotalPrice = TotalPrice + ".00";
            } else {
              this.TotalPrice = TotalPrice;
            }
            this.list1 = false;
            this.list3 = true;
          } else {
            this.list1 = true;
            this.TotalPrice = "0.00";
          }
        });
      });
    },
    cope() {
      this.tcShow = true;
      let cusIdCard = this.form.cusIdcard;
@@ -2085,12 +2012,13 @@
          if (response.code === 200) {
            let cusId = this.form.cusIdcard;
            this.proIds = [];
            getTransitionList(cusId).then((response) => {
            getTransitionList1(cusId).then((response) => {
              this.tableData1 = response.data;
              this.TotalPrice1 = 0;
              if (this.tableData1) {
                this.tableData1.forEach((item) => {
                  this.TotalPrice1 += item.nowPrice;
                  this.TotalPrice1 += item.ordPrice;
                  this.TotalPrice += item.nowPrice;
                  if (item.pacName === null) {
                    item.pacName = "单项";
                  }
@@ -2102,20 +2030,12 @@
                  this.pacName = item.pacName;
                });
                const r = /^\+?[0-9][0-9]*$/; //正整数(可以0打头)
                let TotalPrice = this.TotalPrice1 * (this.discount / 10);
                if (r.test(TotalPrice)) {
                  this.TotalPrice = TotalPrice + ".00";
                } else {
                  this.TotalPrice = TotalPrice;
                }
                this.list1 = false;
                this.list3 = true;
              } else {
                this.list1 = true;
                this.TotalPrice = "0.00";
                this.TotalPrice = 0;
              }
            });
          }
@@ -2294,6 +2214,8 @@
        updateBy: null,
        updateTime: null,
        deleted: null,
        firmid: "",
        firmDeptName: "",
      };
      this.resetForm("form");
    },
@@ -2326,11 +2248,32 @@
    // 折扣
    numberChange(currentValue, oldValue) {
      this.discount = currentValue;
      if (this.discount <= this.getInfodis) {
        this.discount = this.getInfodis;
      }
      this.TotalPrice = (this.TotalPrice1 * (this.discount / 10)).toFixed(2);
      this.$confirm("确定修改所有子项的折扣吗?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          this.discount = currentValue;
          if (this.discount < this.getInfodis) {
            this.discount = this.getInfodis;
            // this.$modal.msgError(`该人员最高优惠权限为${this.getInfodis}折`);
          }
          this.tableData1.forEach((item) => {
            item.discount = this.discount;
            const ordPrice = new Big(item.ordPrice);
            const discount = new Big(item.discount);
            const result = ordPrice.times(discount.div(10)); // ordPrice * (discount / 10)
            item.nowPrice = result.toNumber();
            this.TotalPrice = this.tableData1.reduce((sum, item) => {
              return sum.plus(new Big(item.nowPrice || "0"));
            }, new Big(0));
          });
          // ----------------------------------------------------------
        })
        .catch(() => {
          this.discount = oldValue;
        });
    },
    /** 登记提交按钮 */
@@ -2348,18 +2291,16 @@
          if (this.form.cusSex === "未知") {
            this.form.cusSex = 2;
          }
          if (this.form.tjType === "") {
            this.form.tjType = this.dict.type.dict_team[0].value;
          }
          addCustomer(this.form).then((response) => {
            this.responseList = response.data;
            this.$modal.msgSuccess("新增成功");
            // let cusSex = this.form.cusSex;
            // //全部套餐
            // deptTreeSelect(cusSex).then((response) => {
            //   this.newpacName = response.rows;
            //   this.loading = false;
            // });
            // this.handleQuery();
            _this.tcShow = true;
            _this.tcShows = true;
            _this.isDisabled = true;
            _this.top = false;
          });
@@ -2391,7 +2332,7 @@
              this.discount = this.form.discount;
            }
            if (this.form.tjType === null) {
              this.form.tjType = "3";
              this.form.tjType = this.dict.type.dict_team[0].value;
            }
            if (this.form.cusMarryStatus === "null") {
              this.form.cusMarryStatus = "5";
@@ -2401,21 +2342,21 @@
            }
            if (this.form.reservationId != null) {
              if (this.form.groupingId) {
                this.form.firmName = this.form.compName;
                this.form.tjType = "1";
                this.CompanyList.forEach((item) => {
                  if (item.cnName == this.form.firmName) {
                    this.form.firmId = item.drugManufacturerId;
                  }
                });
                _this.tcShow = true;
                _this.tcShows = false;
                let data = {
                  // teamNo: this.form.teamNo,
                  groupingId: this.form.groupingId,
                };
                getByTeamNo(data).then((res) => {
                getTransitionList1(this.form.cusIdcard).then((res) => {
                  this.tableData1 = res.data;
                  if (this.tableData1) {
                    this.tableData1.forEach((item) => {
                      this.TotalPrice1 += item.ysPrice;
                      this.TotalPrice = (
                        this.TotalPrice1 *
                        (this.discount / 10)
                      ).toFixed(2);
                      this.TotalPrice1 += item.ordPrice;
                      this.TotalPrice += item.nowPrice;
                      if (item.pacName === null) {
                        item.pacName = "单项";
                      }
@@ -2423,27 +2364,25 @@
                    this.list1 = false;
                    this.list2 = true;
                    this.list3 = false;
                    this.top = false;
                  } else {
                    this.list1 = true;
                    this.TotalPrice = "0.00";
                    this.TotalPrice = 0;
                    this.top = false;
                  }
                });
              } else {
                if (this.form) {
                  _this.tcShow = true;
                  _this.tcShows = true;
                  _this.formPacId = this.form.pacId;
                  let cusId = this.form.cusIdcard;
                  getTransitionList(cusId).then((response) => {
                  getTransitionList1(cusId).then((response) => {
                    this.tableData1 = response.data;
                    if (this.tableData1) {
                      this.TotalPrice1 = 0;
                      this.tableData1.forEach((item) => {
                        this.TotalPrice1 += item.nowPrice;
                        this.TotalPrice = (
                          this.TotalPrice1 *
                          (this.discount / 10)
                        ).toFixed(2);
                        this.TotalPrice1 += item.ordPrice;
                        this.TotalPrice += item.nowPrice;
                        if (item.pacName === null) {
                          item.pacName = "单项";
                        }
@@ -2469,18 +2408,15 @@
              this.$message.warning("暂无预约信息");
              _this.resetpackage();
            }
            this.top = false;
            _this.isDisabled = true;
          } else {
            this.$message.warning("未查到用户信息");
          }
        });
        // .catch((error) => {
        //   this.$message.error("此用户不存在");
        // });
      } else {
        let configKey = "getInfoFromSqlData";
        getconfigKey(configKey).then((res) => {
          if (res.code == 200) {
            if (res.msg == "N") {
              var websocket = null;
@@ -2490,7 +2426,6 @@
              } else if ("MozWebSocket" in window) {
                websocket = new MozWebSocket(url);
              } else {
              }
              if (websocket == null) {
@@ -2516,23 +2451,15 @@
                var jsonObj = {
                  // name: "readCert",
                };
                // var jStr = JSON.stringify(jsonObj);
                // this.websocket.send(jStr);
                this.dialogVisible = false;
              };
              //接收到消息的回调方法
              websocket.onmessage = (event) => {
                var resultObj = eval("(" + event.data + ")");
                //resultFlag为0代表读卡成功
                // TODO 以下代码可能是泾川使用的
                // this.jingChuanHandlerWebSocketResult(resultObj)
                this.readCardWebSocket(resultObj);
              };
              //连接关闭的回调方法
              websocket.onclose = function () {
                alert("读卡器连接关闭");
              };
@@ -2544,43 +2471,17 @@
              this.cardreader = true;
              _this.cardreaderradio = 3;
              _this.inputSSS = "";
              // let url = window.location.protocol + "//" + window.location.host;
              // axios
              //   .get("http://localhost:81/dev-api/readCertCardInfos")
              //   .then((res) => {
              //   })
              //   .catch((err) => {
              //   });
              // readCertCardInfos().then((res) => {
              //   _this.form.cusName = res.data.name;
              //       _this.form.cusSex =
              //       res.data.sex;
              //       _this.form.cusNational = res.data.mz;
              //       _this.form.cusBrithday = res.data.csrq;
              //       if (_this.form.cusBrithday) {
              //         _this.form.cusBrithday = _this.form.cusBrithday.replace(
              //           /^(\d{4})(\d{2})(\d{2})$/,
              //           "$1-$2-$3"
              //         );
              //       }
              //       _this.form.cusAddr = res.data.addres;
              //       _this.form.cusIdcard = res.data.card;
              // });
            }
          }
        });
      }
    },
    // 最新使用webSocket通信
    readCardWebSocket(resultObj) {
      let _this = this;
      if (resultObj.code === 200 && resultObj.data.name != null) {
        //回显相关数据
        _this.form.cusName = resultObj.data.name;
        _this.form.cusSex = resultObj.data.sex == "0" ? "女" : "男";
@@ -2591,6 +2492,29 @@
            /^(\d{4})(\d{2})(\d{2})$/,
            "$1-$2-$3"
          );
        } else if (_this.form.cusIdcard) {
          // 从身份证号码提取出生日期
          var org_birthday = _this.form.cusIdcard.substring(6, 14);
          _this.form.cusBrithday =
            org_birthday.substring(0, 4) +
            "-" +
            org_birthday.substring(4, 6) +
            "-" +
            org_birthday.substring(6, 8);
        }
        // 如果出生日期存在,计算年龄
        if (_this.form.cusBrithday) {
          var birthdays = new Date(_this.form.cusBrithday);
          let d = new Date();
          let age =
            d.getFullYear() -
            birthdays.getFullYear() -
            (d.getMonth() < birthdays.getMonth() ||
            (d.getMonth() == birthdays.getMonth() &&
              d.getDate() < birthdays.getDate())
              ? 1
              : 0);
          _this.form.age = age; // 赋值计算的年龄
        }
        _this.form.cusAddr = resultObj.data.addres;
        _this.form.cusIdcard = resultObj.data.card;
@@ -2678,7 +2602,6 @@
        } else if ("MozWebSocket" in window) {
          websocket = new MozWebSocket(url);
        } else {
        }
        if (websocket == null) {
          alert("11111");
@@ -2783,7 +2706,6 @@
        } else if ("MozWebSocket" in window) {
          websocket = new MozWebSocket(url);
        } else {
        }
        if (websocket == null) {
          alert("11111");
@@ -2884,27 +2806,11 @@
      } else {
        this.form.cusIdcard = param1[0].pacCode;
      }
      // this.form.cusName = param1[0].pacName;
      // this.form.cusPhone = param1[0].pacRemark;
    },
    // selected(row, index) {
    //   if (this.formPacId !== null) {
    //     if (row.pacId == this.formPacId) {
    //       setTimeout(() => {
    //         if (this.$refs.tb) {
    //           this.$refs.tb.toggleRowSelection(row, true);
    //         }
    //       }, 10);
    //       return true;
    //     } else {
    //       return false;
    //     }
    //   } else {
    //     return this.newpacName;
    //   }
    // },
    handleChangesName(params) {
      this.form.cusIdcard = params[0].sfzh;
      this.handleQuery();
    },
    // 上传头像
    handleAvatarSuccess(res, file) {
@@ -2943,16 +2849,27 @@
    handle() {
      this.loading = true;
      this.name = this.queryParam.pacName;
      let param = {
        sex: this.form.cusSex,
        dwId: this.form.firmId,
      };
      if (this.name) {
        getPackageListName(this.name).then((response) => {
          this.newpacName = response.data;
          this.loading = false;
        });
      } else {
        deptTreeSelect().then((response) => {
          this.newpacName = response.rows;
          this.loading = false;
        });
        if (this.form.tjType == 1) {
          tuantiSelect(param).then((response) => {
            this.newpacName = response.data;
            this.loading = false;
          });
        } else {
          deptTreeSelect().then((response) => {
            this.newpacName = response.rows;
            this.loading = false;
          });
        }
      }
    },
@@ -3004,6 +2921,7 @@
    // },
    resetpackage() {
      this.discount = 10;
      if (this.form.cusIdcard) {
        var cusId = this.form.cusIdcard;
      } else {
@@ -3022,7 +2940,7 @@
        if (response.code === 200) {
          let cusId = this.form.cusIdcard;
          this.proIds = [];
          getTransitionList(cusId).then((response) => {
          getTransitionList1(cusId).then((response) => {
            this.tableData1 = response.data;
            this.TotalPrice1 = 0;
            if (this.tableData1.length >= 1) {
@@ -3031,7 +2949,7 @@
            } else {
              this.list1 = true;
              this.TotalPrice = "0.00";
              this.TotalPrice = 0;
            }
          });
        }
@@ -3039,33 +2957,69 @@
    },
    Package() {
      this.taocan = true;
      this.activeNames = "first";
      let cusSex = this.form.cusSex;
      this.datekey = Date.now();
      //全部套餐
      this.loading = true;
      deptTreeSelect(cusSex).then((response) => {
        this.newpacName = response.rows;
        try {
          if (this.tableData1.length >= 1) {
            this.newpacName.forEach((item3) => {
              this.tableData1.forEach((item4) => {
                item4.list.forEach((item6) => {
                  if (item6.pacName === item3.pacName) {
                    this.$nextTick(() => {
                      this.$refs.tb.toggleRowSelection(item3, true);
      let param = {
        sex: cusSex,
        dwId: this.form.firmId || "",
      };
      if (this.form.tjType == 1) {
        if (!this.form.firmId) {
          this.$message({
            type: "warning",
            message: "请先维护单位!",
          });
        } else {
          this.taocan = true;
          this.loading = true;
          tuantiSelect(param).then((res) => {
            this.newpacName = res.data;
            try {
              if (this.tableData1.length >= 1) {
                this.newpacName.forEach((item3) => {
                  this.tableData1.forEach((item4) => {
                    item4.list.forEach((item6) => {
                      if (item6.pacName === item3.pacName) {
                        this.$nextTick(() => {
                          this.$refs.tb.toggleRowSelection(item3, true);
                        });
                        throw Error();
                      }
                    });
                    throw Error();
                  }
                  });
                });
              }
            } catch (error) {}
            this.loading = false;
          });
        }
      } else {
        this.taocan = true;
        this.loading = true;
        deptTreeSelect(cusSex).then((response) => {
          this.newpacName = response.rows;
          try {
            if (this.tableData1.length >= 1) {
              this.newpacName.forEach((item3) => {
                this.tableData1.forEach((item4) => {
                  item4.list.forEach((item6) => {
                    if (item6.pacName === item3.pacName) {
                      this.$nextTick(() => {
                        this.$refs.tb.toggleRowSelection(item3, true);
                      });
                      throw Error();
                    }
                  });
                });
              });
            });
          }
        } catch (error) {}
        this.loading = false;
      });
      // this.getData();
            }
          } catch (error) {}
          this.loading = false;
        });
      }
    },
    // 点击多选框获取选中数据
@@ -3176,7 +3130,6 @@
      this.loading = true;
      getProParentIdDxList().then((response) => {
        this.Treedata = response.data.list;
        if (this.tableData[0]) {
          this.tableData[0].tjProjectList.forEach((selectionitem) => {
@@ -3200,7 +3153,7 @@
        };
        getlistByZhId(datas).then((res) => {
          this.packagedataList = res.data.tjProjectList;
          this.DataLists = [];
          this.checkedListkey1 = [];
          for (var i = 0; i < this.packagedataList.length; i++) {
@@ -3210,12 +3163,11 @@
            getProSonDxList(proId).then((res) => {
              this.TreedataList = res.data.list;
              this.TreedataList.forEach((item) => {
                // this.checkedListkey1.push(item.proId);
                this.DataLists.push(item);
                if (this.DataLists.length >= 1) {
                  this.marryalls = 0;
                  this.DataLists.forEach((item1) => {
@@ -3318,7 +3270,6 @@
          if (this.DataList.length != 0) {
            this.list1 = false;
            this.DataList.forEach((item) => {
              // this.TotalPrice1 = item.proPrice + this.TotalPrice1;
              this.marryall += item.proPrice;
            });
          }
@@ -3348,7 +3299,7 @@
    renderContent(h, { node, data, store }) {
      return (
        <span class="custom-tree-node">
            <span>{node.label}</span>
          <span>{node.label}</span>
          <span>({data.proPrice}元)</span>
        </span>
      );
@@ -3411,7 +3362,6 @@
        }
      });
    },
    //  // 默认接受四个值 { 当前行的值, 当前列的值, 行的下标, 列的下标 }
    objectSpanMethod({ row, column, rowIndex, columnIndex }) {
      let fields = ["propinName"];
      let cellValue = row[column.property];
@@ -3439,7 +3389,6 @@
      } else {
        this.$message.warning("请先填写信息,再选体检内容");
      }
      let _this = this;
      if (this.tableData.length != 0) {
        this.tableData.forEach((item) => {
@@ -3464,63 +3413,92 @@
        pacId: _this.pacId,
        proIds: this.proIds,
      };
      getaddtTransition(data).then((response) => {
        if (response.code == 200) {
      if (this.form.tjType == 1) {
        tuantiqueren(data).then((response) => {
          if (response.code == 200) {
            let cusId = this.form.cusIdcard;
            this.proIds = [];
            getTransitionList1(cusId).then((response) => {
              this.tableData1 = response.data;
              this.TotalPrice1 = 0;
              if (this.tableData1) {
                this.tableData1.forEach((item) => {
                  if (item.tjCategory != null) {
                    this.tjCategory = item.tjCategory;
                  }
                  if (item.pacName == "单项") {
                    item.list.forEach((item9) => {
                      this.treeList.push(item9.proId);
                    });
                  }
                  this.TotalPrice1 += item.ordPrice;
                  this.TotalPrice += item.nowPrice;
          let cusId = this.form.cusIdcard;
          this.proIds = [];
          getTransitionList(cusId).then((response) => {
            this.tableData1 = response.data;
            this.TotalPrice1 = 0;
            if (this.tableData1) {
              this.tableData1.forEach((item) => {
                this.TotalPrice1 += item.nowPrice;
                if (item.tjCategory != null) {
                  this.tjCategory = item.tjCategory;
                }
                if (item.pacName == "单项") {
                  item.list.forEach((item9) => {
                    this.treeList.push(item9.proId);
                  });
                }
                this.pacName = item.pacName;
              });
                  this.pacName = item.pacName;
                });
              const r = /^\+?[0-9][0-9]*$/; //正整数(可以0打头)
              let TotalPrice = this.TotalPrice1 * (this.discount / 10);
              if (r.test(TotalPrice)) {
                this.TotalPrice = TotalPrice + ".00";
                this.TotalPrice = this.tableData1.reduce((sum, item) => {
                  return sum.plus(new Big(item.nowPrice || "0"));
                }, new Big(0));
                this.discount =
                  (Math.floor((this.TotalPrice / this.TotalPrice1) * 100) /
                    100) *
                  10;
                this.list1 = false;
                this.list3 = true;
                this.list2 = false;
              } else {
                this.TotalPrice = TotalPrice;
                this.list1 = true;
                this.TotalPrice = 0;
              }
              this.list1 = false;
              this.list3 = true;
              this.list2 = false;
            } else {
              this.list1 = true;
              this.TotalPrice = "0.00";
            }
          });
        } else {
          console.log(失败了);
        }
      });
            });
          } else {
          }
        });
      } else {
        getaddtTransition(data).then((response) => {
          if (response.code == 200) {
            let cusId = this.form.cusIdcard;
            this.proIds = [];
            getTransitionList1(cusId).then((response) => {
              this.tableData1 = response.data;
              this.TotalPrice1 = 0;
              if (this.tableData1) {
                this.tableData1.forEach((item) => {
                  if (item.tjCategory != null) {
                    this.tjCategory = item.tjCategory;
                  }
                  if (item.pacName == "单项") {
                    item.list.forEach((item9) => {
                      this.treeList.push(item9.proId);
                    });
                  }
                  this.TotalPrice1 += item.ordPrice;
                  this.TotalPrice += item.nowPrice;
                  this.pacName = item.pacName;
                });
                this.discount =
                  (Math.floor((this.TotalPrice / this.TotalPrice1) * 100) /
                    100) *
                  10;
                this.list1 = false;
                this.list3 = true;
                this.list2 = false;
              } else {
                this.list1 = true;
                this.TotalPrice = 0;
              }
            });
          } else {
          }
        });
      }
      this.taocan = false;
      this.defaultKeys = [];
      this.DataLists = [];
    },
    // changeCategoryKeys(val) {
    //   this.proIds = [];
    //   this.proIds = val;
    // if (this.DataList.length != 0) {
    //   this.DataList.forEach((item) => {
    //     this.proIds.push(item.proId);
    //   });
    // } else {
    //   this.proIds = [];
    // }
    // },
    submitCheckinfee() {
      let _this = this;
      if (_this.tjCategory !== "") {
@@ -3784,6 +3762,7 @@
    submitPrice() {
      let _this = this;
      if (_this.tjCategory !== "") {
        this.loadingSubmit = true;
        let List = _this.tableData1; //单个项目信息
        if (this.responseList.cusId) {
          var userId = this.responseList.cusId;
@@ -3825,43 +3804,65 @@
        let paidIn = this.TotalPrice.toString();
        let discount = this.discount;
        this.tjFlowingWater = { copeWith, paidIn, discount };
        const newArray = this.tableData1
          .filter((item) => item.discount < 10) // 过滤出 discount < 10 的项
          .map((item) => ({
            discount: item.discount,
            parentProId: item.parentProId,
            cusIdCard: item.cusId,
          })); // 创建新的对象,包含 discount 和 id
        gaibianzhekou(newArray).then((res) => {
          if (res.code === 200) {
            this.loadingSubmit = false;
            let data;
        let data;
        if (pacId || this.tjOrderList.length > 0) {
          data = {
            photo: this.srcUrl,
            pacId,
            tjOrderList: this.tjOrderList,
            tjFlowingWater: this.tjFlowingWater,
            userId,
            tjType,
            tjCategory: this.tjCategory,
          };
          this.listgetOrder(data);
        } else if (pacId || this.tjOrderList.length > 0) {
          data = {
            photo: this.srcUrl,
            tjOrderList: this.tjOrderList,
            tjFlowingWater: this.tjFlowingWater,
            userId,
            tjType,
            tjCategory: this.tjCategory,
          };
          this.listgetOrder(data);
        } else {
          this.$message({
            type: "warning ",
            message: "请选择套餐!",
          });
        }
            if (pacId || this.tjOrderList.length > 0) {
              data = {
                photo: this.srcUrl,
                pacId,
                tjOrderList: this.tjOrderList,
                tjFlowingWater: this.tjFlowingWater,
                userId,
                tjType,
                tjCategory: this.tjCategory,
                firmId: this.form.firmId,
                firmName: this.form.firmName,
                firmDeptName: this.form.firmDeptName,
              };
              this.listgetOrder(data);
            } else if (pacId || this.tjOrderList.length > 0) {
              data = {
                photo: this.srcUrl,
                tjOrderList: this.tjOrderList,
                tjFlowingWater: this.tjFlowingWater,
                userId,
                tjType,
                tjCategory: this.tjCategory,
                firmId: this.form.firmId,
                firmName: this.form.firmName,
                firmDeptName: this.form.firmDeptName,
              };
              this.listgetOrder(data);
            } else {
              this.$message({
                type: "warning ",
                message: "请选择套餐!",
              });
            }
          } else {
            this.loadingSubmit = false;
            this.$modal.msgError("改变折扣错误");
          }
        });
      } else {
        this.loadingSubmit = false;
        this.$modal.msgError("请选择体检类别");
      }
    },
  },
};
</script>
<style>
.el-form-item__error {
@@ -3907,6 +3908,7 @@
  width: 100%;
  display: flex;
}
.tab3 {
  border: 1px solid #dcdfe6;
}
@@ -3984,12 +3986,14 @@
  width: 300px;
  height: 300px;
}
.dialog-footer2 {
  width: 960px;
  height: 36px;
  display: flex;
  justify-content: center;
}
.el-input--suffix .el-input__inner {
  padding-right: 15px;
}
@@ -4020,6 +4024,7 @@
.content {
  margin-bottom: 25px;
}
.tab8 {
  width: 100%;
  display: flex;