| | |
| | | label-width="70px" |
| | | > |
| | | <el-row :gutter="8"> |
| | | <el-col :span="6"> |
| | | <el-col :span="5"> |
| | | <el-form-item label="姓名" prop="name"> |
| | | <el-input |
| | | v-model="queryParams.name" |
| | |
| | | /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-col :span="5"> |
| | | <el-form-item |
| | | align="left" |
| | | label="医疗机构" |
| | |
| | | /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-col :span="5"> |
| | | <el-form-item label="捐献地市"> |
| | | <el-select v-model="queryParams.city" placeholder="请选择地市"> |
| | | <el-option |
| | |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item label="捐献进度" prop="recordstate"> |
| | | <el-col :span="9"> |
| | | <el-form-item label="案例时间"> |
| | | <el-date-picker |
| | | style="width: 100%" |
| | | v-model="selecttime" |
| | | type="monthrange" |
| | | range-separator="至" |
| | | start-placeholder="开始月份" |
| | | end-placeholder="结束月份" |
| | | value-format="yyyy-MM-dd" |
| | | @change="getTimeList" |
| | | > |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="8"> |
| | | <el-col :span="5"> |
| | | <el-form-item label="捐献进度" prop="workflow"> |
| | | <el-select |
| | | v-model="queryParams.recordstate" |
| | | v-model="queryParams.workflow" |
| | | placeholder="请选择当前进度" |
| | | clearable |
| | | size="small" |
| | | > |
| | | <el-option |
| | | v-for="dict in dict.type.sys_DonationStatus" |
| | | v-for="dict in dict.type.sys_donornode" |
| | | :key="dict.value" |
| | | :label="dict.label" |
| | | :value="dict.value" |
| | |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row :gutter="8"> |
| | | <el-col :span="6"> |
| | | <el-col :span="5"> |
| | | <el-form-item label="报告人"> |
| | | <el-select |
| | | v-model="queryParams.reporterno" |
| | |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | |
| | | <el-col :span="12"> |
| | | <el-form-item label="报告日期"> |
| | | <el-date-picker |
| | | style="width: 100%" |
| | | v-model="selecttime" |
| | | type="monthrange" |
| | | range-separator="至" |
| | | start-placeholder="开始月份" |
| | | end-placeholder="结束月份" |
| | | value-format="yyyy-MM-dd" |
| | | @change="getTimeList" |
| | | <el-col :span="5"> |
| | | <el-form-item label="是否终止"> |
| | | <el-select |
| | | v-model="queryParams.terminationCase" |
| | | placeholder="请选择状态" |
| | | > |
| | | </el-date-picker> |
| | | <el-option |
| | | v-for="item in terminationCaselist" |
| | | :key="item.value" |
| | | :label="item.name" |
| | | :value="item.value" |
| | | > |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <el-row> |
| | | <el-col :span="14"> |
| | | <el-col :span="9"> |
| | | <el-form-item label="籍贯"> |
| | | <div> |
| | | <li_area_select |
| | |
| | | </div> |
| | | </el-form-item> |
| | | </el-col> |
| | | |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="4"> |
| | | <el-form-item> |
| | | <el-button |
| | |
| | | :data="donatebaseinfoList" |
| | | @selection-change="handleSelectionChange" |
| | | border |
| | | :default-sort="{ prop: 'reporttime', order: 'descending' }" |
| | | :default-sort="{ prop: 'donatetime', order: 'descending' }" |
| | | > |
| | | <!-- <el-table-column label="报告时间" align="center" prop="id" /> --> |
| | | <!-- <el-table-column type="selection" width="55" align="center" /> --> |
| | | <el-table-column |
| | | label="报告时间" |
| | | label="案例时间" |
| | | align="center" |
| | | prop="reporttime" |
| | | prop="donatetime" |
| | | width="100" |
| | | > |
| | | <template slot-scope="scope"> |
| | | <span>{{ parseTime(scope.row.reporttime, "{y}-{m}-{d}") }}</span> |
| | | <span>{{ parseTime(scope.row.donatetime, "{y}-{m}-{d}") }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | <el-table-column |
| | | label="捐献编号" |
| | | align="center" |
| | | prop="donorno" |
| | | width="200" |
| | | /> |
| | | <el-table-column label="姓名" align="center" prop="name" width="100" /> |
| | | |
| | | <el-table-column label="性别" align="center" prop="sex" width="100"> |
| | | <template slot-scope="scope"> |
| | | <dict-tag |
| | |
| | | </el-table-column> |
| | | <el-table-column label="年龄" align="center" prop="age" width="100" /> |
| | | <el-table-column |
| | | label="现所在地市" |
| | | align="center" |
| | | prop="registercityname" |
| | | width="150" |
| | | /> |
| | | |
| | | <el-table-column |
| | | label="医疗机构" |
| | | align="center" |
| | | prop="treatmenthospitalname" |
| | | /> |
| | | <el-table-column label="血型" align="center" prop="bloodtype" width="100"> |
| | | <template slot-scope="scope"> |
| | | <dict-tag |
| | | :options="dict.type.sys_BloodType" |
| | | :value="scope.row.bloodtype" |
| | | /> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | <el-table-column |
| | | label="捐献类别" |
| | | align="center" |
| | | prop="donationcategory" |
| | | width="150" |
| | | > |
| | | <template slot-scope="scope"> |
| | | <dict-tag |
| | | :options="dict.type.sys_DonationCategory" |
| | | :value="scope.row.donationcategory" |
| | | /> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="报告人" |
| | | align="center" |
| | | prop="reportername" |
| | | width="100" |
| | | /> |
| | | |
| | | <el-table-column label="捐献进度" align="center" prop="recordstate" width="120"> |
| | | <!-- |
| | | <el-table-column |
| | | label="现所在地市" |
| | | align="center" |
| | | prop="registercityname" |
| | | width="150" |
| | | /> |
| | | <el-table-column |
| | | label="捐献进度" |
| | | align="center" |
| | | prop="recordstate" |
| | | width="120" |
| | | > |
| | | <template slot-scope="scope"> |
| | | <dict-tag |
| | | <dict-tag |
| | | :options="dict.type.sys_DonationStatus" |
| | | :value="scope.row.recordstate" |
| | | /> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | --> |
| | | <el-table-column |
| | | label="捐献进度" |
| | | align="center" |
| | | prop="workflow" |
| | | width="120" |
| | | > |
| | | <template slot-scope="scope"> |
| | | <div v-if="!scope.row.terminationCase"> |
| | | <dict-tag |
| | | :options="dict.type.sys_donornode" |
| | | :value="scope.row.workflow" |
| | | /> |
| | | </div> |
| | | <div v-else>任务终止</div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="操作" |
| | | align="center" |
| | | class-name="small-padding fixed-width" |
| | | width="200" |
| | | fixed="right" |
| | | > |
| | | <template slot-scope="scope"> |
| | |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['project:donatebaseinfo:edit']" |
| | | >修改</el-button |
| | | >详情</el-button |
| | | > |
| | | |
| | | <el-button |
| | | v-if="scope.row.recordstate == 0" |
| | | size="mini" |
| | |
| | | v-hasPermi="['project:donatebaseinfo:remove']" |
| | | >删除</el-button |
| | | > |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handletermination(scope.row)" |
| | | v-hasPermi="['project:donatebaseinfo:edit']" |
| | | >终止</el-button |
| | | > |
| | | <!-- |
| | | <el-button v-if="scope.row.recordstate == 0 || scope.row.recordstate == 3" size="mini" type="text" |
| | | icon="el-icon-thumb" @click="handleapproval(scope.row)">提交</el-button> |
| | | --> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | |
| | | @click="handledownload(scope.row)" |
| | | >下载</el-button |
| | | > |
| | | <el-button |
| | | v-if="scope.row.recordstate == 0 || scope.row.recordstate == 3" |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-thumb" |
| | | @click="handleapproval(scope.row)" |
| | | >上报审核</el-button |
| | | > |
| | | <!-- 撤销申请 --> |
| | | <!-- |
| | | <el-button size="mini" type="text" icon="el-icon-edit" @click="handletermination(scope.row)" |
| | | v-hasPermi="['project:donatebaseinfo:edit']">{{ scope.row.recordstate == 99 ? "恢复": "终止" }}</el-button> |
| | | --> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | |
| | | > |
| | | <div |
| | | style=" |
| | | border-bottom: 1px solid #ddd; |
| | | border-top: 1px solid #ddd; |
| | | padding-right: 60px; |
| | | " |
| | | border-bottom: 1px solid #ddd; |
| | | border-top: 1px solid #ddd; |
| | | padding-right: 60px; |
| | | " |
| | | > |
| | | <el-row style="margin-top: 40px"> |
| | | <el-col :span="8"> |
| | |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item align="left" label="姓名" prop="name"> |
| | | <el-input v-model="form.name" placeholder="请输入姓名" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item label="性别" prop="sex"> |
| | | <el-select v-model="form.sex" placeholder="请选择性别"> |
| | | <el-option |
| | | v-for="dict in dict.type.sys_user_sex" |
| | | :key="dict.label" |
| | | :label="dict.label" |
| | | :value="parseInt(dict.value)" |
| | | ></el-option> |
| | | </el-select> |
| | | <el-input v-model="form.name" placeholder="必填项" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | |
| | | <el-input v-model="form.nativeplace" placeholder="请输入国籍" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item label="国籍" prop="nationality"> |
| | | <el-input v-model="form.nationality" placeholder="请输入国籍" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item label="证件类型" prop="idcardtype"> |
| | |
| | | placeholder="请输入证件号码" |
| | | @blur="updateMessage" |
| | | /> |
| | | </el-form-item> </el-col |
| | | ><el-col :span="6"> |
| | | <el-form-item label="国籍" prop="nationality"> |
| | | <el-input v-model="form.nationality" placeholder="请输入国籍" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item label="性别" prop="sex"> |
| | | <el-select v-model="form.sex" placeholder="请输入性别"> |
| | | <el-option |
| | | v-for="dict in dict.type.sys_user_sex" |
| | | :key="dict.label" |
| | | :label="dict.label" |
| | | :value="parseInt(dict.value)" |
| | | ></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item label="年龄" prop="age"> |
| | | <el-input v-model="form.age" placeholder="请输入年龄" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item label="出生日期" prop="birthday"> |
| | | <el-date-picker |
| | | clearable |
| | | size="small" |
| | | v-model="form.birthday" |
| | | type="date" |
| | | style="width: 174px" |
| | | value-format="yyyy-MM-dd HH:mm:ss" |
| | | placeholder="选择出生日期" |
| | | > |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item label="年龄" prop="age"> |
| | | <el-input v-model="form.age" placeholder="请输入年龄" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item label="出生日期" prop="birthday"> |
| | | <el-date-picker |
| | | clearable |
| | | size="small" |
| | | v-model="form.birthday" |
| | | type="date" |
| | | style="width: 174px" |
| | | value-format="yyyy-MM-dd HH:mm:ss" |
| | | placeholder="选择出生日期" |
| | | > |
| | | </el-date-picker> |
| | | </el-form-item> </el-col |
| | | ><el-col :span="6"> |
| | | <el-form-item label="学历" prop="education"> |
| | | <el-select v-model="form.education" placeholder="请选择学历"> |
| | | <el-option |
| | |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <el-row> |
| | | <el-col :span="12"> |
| | | <el-form-item label="住址" prop="residenceaddress"> |
| | |
| | | |
| | | <div |
| | | style=" |
| | | border-bottom: 1px solid #ddd; |
| | | margin-top: 20px; |
| | | padding-right: 60px; |
| | | " |
| | | border-bottom: 1px solid #ddd; |
| | | margin-top: 20px; |
| | | padding-right: 60px; |
| | | " |
| | | > |
| | | <el-row> |
| | | <el-col :span="8"> |
| | |
| | | |
| | | <div |
| | | style=" |
| | | border-bottom: 1px solid #ddd; |
| | | padding-right: 60px; |
| | | margin-top: 20px; |
| | | " |
| | | border-bottom: 1px solid #ddd; |
| | | padding-right: 60px; |
| | | margin-top: 20px; |
| | | " |
| | | > |
| | | <el-row> |
| | | <div display="flex"> |
| | |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | <div style="padding-right: 60px; margin-top: 20px"> |
| | | <!-- <div style="padding-right: 60px; margin-top: 20px"> |
| | | <el-row> |
| | | <el-form-item label="附件" align="left" prop="annexfile"> |
| | | <annex-upload |
| | | ref="annex" |
| | | :infoid="form.id" |
| | | :donorno="form.donorno" |
| | | :flowname="flowname" |
| | | :annexno="annexno" |
| | | /> |
| | | <annex-upload ref="annex" :infoid="form.id" :donorno="form.donorno" :flowname="flowname" |
| | | :annexno="annexno" /> |
| | | </el-form-item> |
| | | </el-row> |
| | | </div> |
| | | </div> --> |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button v-show="showSaveBtn" type="primary" @click="submitForm" |
| | | >保 存</el-button |
| | | >保存并前往案例工作台</el-button |
| | | > |
| | | <el-button |
| | | v-show="showTerminationBtn" |
| | |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | <style scoped> |
| | | </style> |
| | | <script> |
| | | import { getUserProfile } from "@/api/system/user"; |
| | | import { |
| | |
| | | updateDonatebaseinfo, |
| | | exportDonatebaseinfo, |
| | | downloadbaseinfo, |
| | | getdonatorno, |
| | | // exportProvincemessage, |
| | | getDonationNumber, |
| | | getdonatorno |
| | | } from "@/api/project/donatebaseinfo"; |
| | | import Li_area_select from "@/components/Address"; |
| | | import OrgSelecter from "@/views/project/components/orgselect"; |
| | | import AnnexUpload from "@/views/project/components/annexupload"; |
| | | import ReportName from "@/views/project/components/organizationUser"; |
| | | import { getToken } from "@/utils/auth"; |
| | | import { |
| | | listOrganization, |
| | | getOrganization, |
| | | listReportname, |
| | | listUser, |
| | | listUser |
| | | } from "@/api/project/organization"; |
| | | import ReportName from "@/views/project/components/organizationUser"; |
| | | export default { |
| | | components: { |
| | | Li_area_select, |
| | | OrgSelecter, |
| | | AnnexUpload, |
| | | ReportName, |
| | | ReportName |
| | | }, |
| | | name: "Donatebaseinfo", |
| | | dicts: [ |
| | |
| | | "sys_DiseaseType", |
| | | "sys_SelfWill", |
| | | "sys_FamilyRelation", |
| | | "sys_donornode" |
| | | ], |
| | | data() { |
| | | return { |
| | |
| | | sheng: "", |
| | | shi: "", |
| | | qu: "", |
| | | organizationname: null, |
| | | organizationname: null |
| | | }, |
| | | residenceAddresss: { |
| | | sheng: "浙江省", |
| | | shi: "", |
| | | qu: "", |
| | | qu: "" |
| | | }, |
| | | registerAddresss: { |
| | | sheng: "浙江省", |
| | | shi: "", |
| | | qu: "", |
| | | qu: "" |
| | | }, |
| | | terminationCaselist: [ |
| | | { name: "终止状态", value: 1 }, |
| | | { name: "正常状态", value: 0 } |
| | | ], |
| | | // 遮罩层 |
| | | loading: true, |
| | | // 导出遮罩层 |
| | |
| | | starttime: null, |
| | | endtime: null, |
| | | city: null, |
| | | reportno: null, |
| | | reportno: null |
| | | // organizationname: null, |
| | | // organizationtype: null, |
| | | // idcardno: null, |
| | |
| | | // reporttime: null, |
| | | }, |
| | | // 表单参数 |
| | | form: {}, |
| | | form: { |
| | | id: null, |
| | | name: null, |
| | | sex: null, |
| | | idcardtype: null, |
| | | idcardno: null, |
| | | age: null, |
| | | ageunit: null, |
| | | birthday: null, |
| | | phone: null, |
| | | residenceaddress: null, |
| | | nationality: "中国", |
| | | nativeplace: null, |
| | | residenceprovince: null, |
| | | nation: null, |
| | | residenceprovincename: null, |
| | | occupation: null, |
| | | residencecity: null, |
| | | education: null, |
| | | residencecityname: null, |
| | | residencetown: null, |
| | | residencetownname: null, |
| | | residencecommunity: null, |
| | | residencecommunityname: null, |
| | | residencecountycode: null, |
| | | residencecountyname: null, |
| | | registeraddress: null, |
| | | registerprovince: null, |
| | | registerprovincename: null, |
| | | registercity: null, |
| | | registercityname: null, |
| | | registertown: null, |
| | | registertownname: null, |
| | | registercommunity: null, |
| | | registercommunityname: null, |
| | | registercountycode: null, |
| | | registercountyname: null, |
| | | recordstate: null, |
| | | treatmenthospitalno: null, |
| | | treatmenthospitalname: null, |
| | | treatmentdeptname: null, |
| | | diagnosisno: null, |
| | | diagnosisname: null, |
| | | bloodtype: "0", |
| | | inpatientno: null, |
| | | rhyin: "0", |
| | | donorno: null, |
| | | donationcategory: null, |
| | | illnessoverview: null, |
| | | diseasetype: [], |
| | | infectious: [], |
| | | selfwill: [], |
| | | diseasetypeOther: null, |
| | | othercases: [], |
| | | kinshipwill: 0, |
| | | infosources: [], |
| | | kinship: [], |
| | | redorganno: null, |
| | | redorganname: null, |
| | | contactperson: null, |
| | | infectiousOther: null, |
| | | contactnumber: null, |
| | | contacttime: null, |
| | | reporterno: null, |
| | | reportername: null, |
| | | patientstate: [], |
| | | reporterphone: null, |
| | | infosourcesOther: null, |
| | | reporttime: null, |
| | | delFlag: null, |
| | | createBy: null, |
| | | createTime: null, |
| | | updateBy: null, |
| | | updateTime: null, |
| | | kinshipOther: null, |
| | | majorrelatives: null, |
| | | familyrelations: null, |
| | | acquisitiontissueno: "ZJOPO", |
| | | acquisitiontissuename: "浙江省人体器官获取组织" |
| | | }, |
| | | //ads |
| | | reporters: [], |
| | | users: [], |
| | |
| | | // 表单校验 |
| | | rules: { |
| | | name: [ |
| | | { required: true, message: "请输入捐献者姓名", trigger: "blur" }, |
| | | { required: true, message: "请输入捐献者姓名", trigger: "blur" } |
| | | ], |
| | | birthday: [ |
| | | { required: true, message: "请选择出生日期", trigger: "blur" } |
| | | ], |
| | | idcardtype: [ |
| | | { required: true, message: "请选择证件类型", trigger: "blur" }, |
| | | { required: true, message: "请选择证件类型", trigger: "blur" } |
| | | ], |
| | | residenceaddress: [ |
| | | { required: true, message: "请输入住址", trigger: "blur" }, |
| | | { required: true, message: "请输入住址", trigger: "blur" } |
| | | ], |
| | | contacttime: [ |
| | | { |
| | | required: true, |
| | | message: "请输入红十字会联系时间", |
| | | trigger: "blur", |
| | | }, |
| | | trigger: "blur" |
| | | } |
| | | ], |
| | | idcardno: [ |
| | | { required: true, message: "请正确输入证件号码", trigger: "blur" }, |
| | | { required: true, message: "请正确输入证件号码", trigger: "blur" } |
| | | ], |
| | | sex: [{ required: true, message: "性别不能为空", trigger: "blur" }], |
| | | age: [{ required: true, message: "请输入年龄", trigger: "blur" }], |
| | | treatmenthospitalno: [ |
| | | { required: true, message: "请选择医疗机构", trigger: "blur" }, |
| | | { required: true, message: "请选择医疗机构", trigger: "blur" } |
| | | ], |
| | | // treatmenthospitalno: [{ required: true, message: "请选择医疗机构", trigger: "change" }], |
| | | bloodtype: [ |
| | | { required: true, message: "请选择ABO血型", trigger: "blur" }, |
| | | { required: true, message: "请选择ABO血型", trigger: "blur" } |
| | | ], |
| | | rhyin: [{ required: true, message: "请选择RHD血型", trigger: "blur" }], |
| | | diseasetype: [ |
| | | { required: true, message: "请选择RHD血型", trigger: "blur" }, |
| | | { required: true, message: "请选择RHD血型", trigger: "blur" } |
| | | ], |
| | | |
| | | inpatientno: [ |
| | | { required: true, message: "输入住院号", trigger: "blur" }, |
| | | { required: true, message: "输入住院号", trigger: "blur" } |
| | | ], |
| | | |
| | | diagnosisname: [ |
| | | { required: true, message: "疾病诊断不能为空", trigger: "blur" }, |
| | | { required: true, message: "疾病诊断不能为空", trigger: "blur" } |
| | | ], |
| | | infoname: [ |
| | | { required: true, message: "请输入信息员姓名", trigger: "blur" }, |
| | | { required: true, message: "请输入信息员姓名", trigger: "blur" } |
| | | ], |
| | | infophone: [ |
| | | { required: true, message: "请输入信息员联系电话", trigger: "blur" }, |
| | | { required: true, message: "请输入信息员联系电话", trigger: "blur" } |
| | | ], |
| | | redorganno: [ |
| | | { required: true, message: "请选择红十字会机构", trigger: "blur" }, |
| | | { required: true, message: "请选择红十字会机构", trigger: "blur" } |
| | | ], |
| | | contactperson: [ |
| | | { |
| | | required: true, |
| | | message: "红十字会联系人不能为空", |
| | | trigger: "blur", |
| | | }, |
| | | trigger: "blur" |
| | | } |
| | | ], |
| | | // contactnumber: [{required: true,message: "请输入红十字会联系电话",trigger: "change"}], |
| | | acquisitiontissueno: [ |
| | | { required: true, message: "器官获取组织不能为空", trigger: "blur" }, |
| | | { required: true, message: "器官获取组织不能为空", trigger: "blur" } |
| | | ], |
| | | reporterno: [ |
| | | { required: true, message: "请选择报告人", trigger: "blur" }, |
| | | { required: true, message: "请选择报告人", trigger: "blur" } |
| | | ], |
| | | reporttime: [ |
| | | { required: true, message: "请输入报告时间", trigger: "blur" }, |
| | | { required: true, message: "请输入报告时间", trigger: "blur" } |
| | | ], |
| | | reporterphone: [ |
| | | { required: true, message: "请输入报告人联系电话", trigger: "blur" }, |
| | | ], |
| | | { required: true, message: "请输入报告人联系电话", trigger: "blur" } |
| | | ] |
| | | }, |
| | | //是否显示保存按钮 |
| | | showSaveBtn: true, |
| | |
| | | endtime: "", |
| | | reportlist: [], |
| | | reportervalue: "", |
| | | headers: { |
| | | Authorization: "Bearer " + getToken() |
| | | }, |
| | | provinceData: [ |
| | | { label: "全部", value: "" }, |
| | | { label: "杭州市", value: "1" }, |
| | |
| | | { label: "衢州市", value: "8" }, |
| | | { label: "舟山市", value: "9" }, |
| | | { label: "台州市", value: "A" }, |
| | | { label: "丽水市", value: "B" }, |
| | | ], |
| | | { label: "丽水市", value: "B" } |
| | | ] |
| | | }; |
| | | }, |
| | | created() {}, |
| | | created() { |
| | | if (sessionStorage.getItem("donatebaseinfo")) { |
| | | this.queryParams = JSON.parse(sessionStorage.getItem("donatebaseinfo")); |
| | | console.log(this.queryParams, "queryParams"); |
| | | } |
| | | }, |
| | | |
| | | mounted(e) { |
| | | // let idd = this.$route.query.userid |
| | |
| | | if (this.$route.params.starttime != null && this.$route.params.endtime) { |
| | | this.selecttime = [ |
| | | this.$moment(this.$route.params.starttime).format("YYYY-MM-DD"), |
| | | this.$moment(this.$route.params.endtime) |
| | | .add(-1, "month") |
| | | .format("YYYY-MM-DD"), |
| | | this.$moment(this.$route.params.endtime).format("YYYY-MM-DD") |
| | | ]; |
| | | } |
| | | if (this.$route.params.reporterno != "") { |
| | |
| | | |
| | | methods: { |
| | | getCurrentUser() { |
| | | getUserProfile().then((response) => { |
| | | getUserProfile().then(response => { |
| | | this.currentuser = response.data; |
| | | }); |
| | | }, |
| | | |
| | | LoadReportList() { |
| | | listDonatebaseinfo().then((res) => { |
| | | listDonatebaseinfo().then(res => { |
| | | let list = res.rows; |
| | | let reportlist = []; |
| | | reportlist.push({ reporterno: "", reportername: "全部" }); |
| | | list.forEach((element) => { |
| | | list.forEach(element => { |
| | | reportlist.push({ |
| | | reporterno: element.reporterno, |
| | | reportername: element.reportername, |
| | | reportername: element.reportername |
| | | }); |
| | | }); |
| | | |
| | |
| | | |
| | | resetArr(Arr) { |
| | | var hash = {}; |
| | | Arr = Arr.reduce(function (arr, current) { |
| | | Arr = Arr.reduce(function(arr, current) { |
| | | hash[current.reporterno] |
| | | ? "" |
| | | : (hash[current.reporterno] = true && arr.push(current)); |
| | |
| | | |
| | | selectReporters() { |
| | | //专职人员 |
| | | listReportname("zzry").then((res) => { |
| | | listReportname("zzry").then(res => { |
| | | this.reporters = res.data; |
| | | }); |
| | | }, |
| | | |
| | | getuserlist() { |
| | | //用户列表 |
| | | listUser().then((res) => { |
| | | listUser().then(res => { |
| | | this.users = res.data; |
| | | }); |
| | | }, |
| | |
| | | this.$confirm("是否确认将案例上报审核?", "提示", { |
| | | confirmButtonText: "确定", |
| | | cancelButtonText: "取消", |
| | | type: "warning", |
| | | type: "warning" |
| | | }) |
| | | .then(() => { |
| | | row.recordstate = 1; |
| | | updateDonatebaseinfo(row).then((response) => { |
| | | updateDonatebaseinfo(row).then(response => { |
| | | this.$modal.msgSuccess("上报审核成功"); |
| | | this.getList(); |
| | | }); |
| | |
| | | .catch(() => { |
| | | this.$message({ |
| | | type: "info", |
| | | message: "已取消上报", |
| | | message: "已取消上报" |
| | | }); |
| | | }); |
| | | }, |
| | |
| | | this.approvalState = false; |
| | | // this.reset(); |
| | | // const id = row.id || this.ids; |
| | | updateDonatebaseinfo(row).then((response) => { |
| | | updateDonatebaseinfo(row).then(response => { |
| | | row.recordstate = 0; |
| | | }); |
| | | }, |
| | | |
| | | updateMessage() { |
| | | try { |
| | | const reg = |
| | | /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/; |
| | | const reg = /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/; |
| | | if (reg.test(this.form.idcardno)) { |
| | | // 身份证号码是否合法 |
| | | var org_birthday = this.form.idcardno.substring(6, 14); |
| | |
| | | } |
| | | this.setState({ |
| | | birthday, |
| | | sex, |
| | | sex |
| | | }); |
| | | }, |
| | | |
| | | /** 查询捐献基础列表 */ |
| | | getList(e) { |
| | | getList() { |
| | | this.loading = true; |
| | | this.queryParams.params = {}; |
| | | // if (null != this.daterangeReporttime && "" != this.daterangeReporttime) { |
| | | // this.queryParams.params["beginReporttime"] = |
| | | // this.daterangeReporttime[0]; |
| | | // this.queryParams.params["endReporttime"] = this.daterangeReporttime[1]; |
| | | // } |
| | | sessionStorage.removeItem("donatebaseinfo"); |
| | | sessionStorage.setItem( |
| | | "donatebaseinfo", |
| | | JSON.stringify(this.queryParams) |
| | | ); |
| | | // 跳转时的默认进度 |
| | | if (e != null && e != undefined && !isNaN(e)) { |
| | | this.queryParams.recordstate = e; |
| | | } |
| | | |
| | | if (this.reportervalue != "") { |
| | | this.queryParams.reportno = this.reportervalue; |
| | |
| | | this.queryParams.residenceprovince = this.$refs.areaSelect.getSheng(); |
| | | this.queryParams.residencecity = this.$refs.areaSelect.getShi(); |
| | | this.queryParams.residencetown = this.$refs.areaSelect.getQu(); |
| | | listDonatebaseinfo(this.queryParams).then((response) => { |
| | | console.log(this.queryParams); |
| | | |
| | | listDonatebaseinfo(this.queryParams).then(response => { |
| | | this.donatebaseinfoList = response.rows; |
| | | //console.log("listDonatebaseinfo", response.rows); |
| | | this.total = response.total; |
| | |
| | | majorrelatives: null, |
| | | familyrelations: null, |
| | | acquisitiontissueno: "ZJOPO", |
| | | acquisitiontissuename: "浙江省人体器官获取组织", |
| | | acquisitiontissuename: "浙江省人体器官获取组织" |
| | | }; |
| | | |
| | | this.resetForm("form"); |
| | |
| | | reportername: null, |
| | | reporttime: null, |
| | | city: null, |
| | | treatmenthospitalno: null, |
| | | treatmenthospitalno: null |
| | | }; |
| | | this.selecttime = []; |
| | | this.getTimeList(); |
| | |
| | | sheng: "", |
| | | shi: "", |
| | | qu: "", |
| | | organizationname: null, |
| | | organizationname: null |
| | | }; |
| | | //this.$refs.areaSelect.clean(); |
| | | |
| | |
| | | }, |
| | | // 多选框选中数据 |
| | | handleSelectionChange(selection) { |
| | | this.ids = selection.map((item) => item.id); |
| | | this.ids = selection.map(item => item.id); |
| | | this.single = selection.length !== 1; |
| | | this.multiple = !selection.length; |
| | | }, |
| | | /** 新增按钮操作 */ |
| | | handleAdd() { |
| | | // this.$router.push({ |
| | | // path: "/organ/donationdetails/", |
| | | // query: { |
| | | // organType: "add", |
| | | // } |
| | | // }); |
| | | this.reset(); |
| | | //设置报告人和部门/组 |
| | | this.form.reporterno = this.currentuser.userName; |
| | |
| | | this.showSaveBtn = true; |
| | | //this.$refs.annex.getAnnexList(); |
| | | this.open = true; |
| | | this.$nextTick(function () { |
| | | this.$refs.annex.getAnnexList(); |
| | | }); |
| | | // this.$nextTick(function() { |
| | | // this.$refs.annex.getAnnexList(); |
| | | // }); |
| | | |
| | | this.title = "人体器官潜在捐献者登记表"; |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | |
| | | handleUpdate(row) { |
| | | this.showSaveBtn = true; |
| | | const id = row.id || this.ids; |
| | | //this.$refs.annex.getAnnexList(); |
| | | |
| | | getDonatebaseinfo(id).then((response) => { |
| | | this.reset(); |
| | | |
| | | this.$nextTick(function () { |
| | | this.$refs.annex.getAnnexList(); |
| | | }); |
| | | this.form = response.data; |
| | | response.data.sex = parseInt(response.data.sex); |
| | | debugger; |
| | | this.form.id = response.data.id; |
| | | this.form.diseasetype = this.form.diseasetype.split(","); |
| | | this.form.infectious = this.form.infectious.split(","); |
| | | this.form.selfwill = this.form.selfwill.split(","); |
| | | this.form.othercases = this.form.othercases.split(","); |
| | | this.form.infosources = this.form.infosources.split(","); |
| | | this.form.kinship = this.form.kinship.split(","); |
| | | this.form.patientstate = this.form.patientstate.split(","); |
| | | this.open = true; |
| | | this.title = "人体器官潜在捐献者登记表"; |
| | | this.registerAddresss.sheng = response.data.registerprovincename; |
| | | this.residenceAddresss.sheng = response.data.residenceprovincename; |
| | | this.registerAddresss.shi = response.data.registercityname; |
| | | this.residenceAddresss.shi = response.data.residencecityname; |
| | | this.residenceAddresss.qu = response.data.residencetownname; |
| | | this.registerAddresss.qu = response.data.registertownname; |
| | | this.$router.push({ |
| | | path: "/organ/donationdetails/", |
| | | query: { |
| | | id: row.id, |
| | | organType: "edit" |
| | | } |
| | | }); |
| | | }, |
| | | // this.showSaveBtn = true; |
| | | // const id = row.id || this.ids; |
| | | // //this.$refs.annex.getAnnexList(); |
| | | |
| | | // getDonatebaseinfo(id).then((response) => { |
| | | // this.reset(); |
| | | |
| | | // this.$nextTick(function () { |
| | | // this.$refs.annex.getAnnexList(); |
| | | // }); |
| | | // this.form = response.data; |
| | | // response.data.sex = parseInt(response.data.sex); |
| | | // this.form.id = response.data.id; |
| | | // this.form.diseasetype = this.form.diseasetype.split(","); |
| | | // this.form.infectious = this.form.infectious.split(","); |
| | | // this.form.selfwill = this.form.selfwill.split(","); |
| | | // this.form.othercases = this.form.othercases.split(","); |
| | | // this.form.infosources = this.form.infosources.split(","); |
| | | // this.form.kinship = this.form.kinship.split(","); |
| | | // this.form.patientstate = this.form.patientstate.split(","); |
| | | // this.open = true; |
| | | // this.title = "人体器官潜在捐献者登记表"; |
| | | // this.registerAddresss.sheng = response.data.registerprovincename; |
| | | // this.residenceAddresss.sheng = response.data.residenceprovincename; |
| | | // this.registerAddresss.shi = response.data.registercityname; |
| | | // this.residenceAddresss.shi = response.data.residencecityname; |
| | | // this.residenceAddresss.qu = response.data.residencetownname; |
| | | // this.registerAddresss.qu = response.data.registertownname; |
| | | // }); |
| | | }, |
| | | // 终止案例 |
| | | handletermination(row) { |
| | | this.reset(); |
| | | this.showSaveBtn = false; |
| | | this.showTerminationBtn = true; |
| | | const id = row.id || this.ids; |
| | | getDonatebaseinfo(id).then((response) => { |
| | | getDonatebaseinfo(id).then(response => { |
| | | this.form = response.data; |
| | | |
| | | this.form.diseasetype = this.form.diseasetype.split(","); |
| | |
| | | this.open = true; |
| | | this.title = "人体器官潜在捐献者登记表"; |
| | | this.form.recordstate = 99; |
| | | this.$nextTick(function () { |
| | | this.$refs.annex.getAnnexList(); |
| | | }); |
| | | // this.$nextTick(function() { |
| | | // this.$refs.annex.getAnnexList(); |
| | | // }); |
| | | }); |
| | | }, |
| | | /** 提交按钮 */ |
| | | submitForm() { |
| | | this.$refs["form"].validate((valid) => { |
| | | console.log("提交的数据们:", this.form); |
| | | console.log(this.form); |
| | | this.$refs["form"].validate(valid => { |
| | | if (valid) { |
| | | const date = { ...this.form }; |
| | | console.log(date, "date"); |
| | | this.form.birthday = this.$moment(this.form.birthday).format( |
| | | "YYYY-MM-DD HH:mm:ss" |
| | | ); |
| | |
| | | this.form.registertownname = this.registerAddresss.qu; |
| | | |
| | | this.form.reportername = this.$refs.getReportname.$data.selectedLabel; |
| | | this.form.donatetime = this.form.reporttime; |
| | | |
| | | try { |
| | | this.form.treatmenthospitalname = |
| | | this.$refs.addOrgSelect.getOptionByValue( |
| | | this.form.treatmenthospitalno |
| | | ).organizationname; |
| | | this.form.treatmenthospitalname = this.$refs.addOrgSelect.getOptionByValue( |
| | | this.form.treatmenthospitalno |
| | | ).organizationname; |
| | | } catch { |
| | | this.form.treatmenthospitalname = this.form.treatmenthospitalno; |
| | | } |
| | | |
| | | try { |
| | | this.form.redorganname = |
| | | this.$refs.addCrossOrgSelect.getOptionByValue( |
| | | this.form.redorganno |
| | | ).organizationname; |
| | | this.form.redorganname = this.$refs.addCrossOrgSelect.getOptionByValue( |
| | | this.form.redorganno |
| | | ).organizationname; |
| | | } catch { |
| | | this.form.redorganname = this.form.redorganno; |
| | | } |
| | | |
| | | //尝试生成捐献编号(已经由addDonatebaseinfo接口中生成取代) |
| | | // getdonatorno(this.form).then((response) => { |
| | | // // alert(JSON.stringify(response)); |
| | | // this.reset(); |
| | | // }); |
| | | |
| | | if (this.form.id != null) { |
| | | updateDonatebaseinfo(this.form).then((response) => { |
| | | this.$modal.msgSuccess("修改成功"); |
| | | this.form.workflow = 0; |
| | | this.form.recordstate = 0; |
| | | addDonatebaseinfo(this.form).then(res => { |
| | | console.log("22"); |
| | | console.log(res.code); |
| | | if (res.code == 200) { |
| | | this.$modal.msgSuccess("新增成功"); |
| | | this.$router.push({ |
| | | path: "/organ/donationdetails/", |
| | | query: { |
| | | id: res.data.id, |
| | | organType: "edit" |
| | | } |
| | | }); |
| | | this.open = false; |
| | | this.getList(); |
| | | }); |
| | | } else { |
| | | this.form.recordstate = 0; |
| | | addDonatebaseinfo(this.form).then((response) => { |
| | | if (response.code == 200) { |
| | | this.$modal.msgSuccess("新增成功"); |
| | | this.open = false; |
| | | this.getList(); |
| | | } else { |
| | | this.$modal.msgError("新增失败:" + response.msg); |
| | | } |
| | | }); |
| | | } |
| | | } else { |
| | | console.log("1"); |
| | | this.form = date; |
| | | console.log(this.form, "form"); |
| | | this.$modal.msgError("新增失败:" + res.msg); |
| | | } |
| | | }); |
| | | } |
| | | }); |
| | | }, |
| | |
| | | const ids = row.id || this.ids; |
| | | this.$modal |
| | | .confirm('是否确认删除捐献基础编号为"' + ids + '"的数据项?') |
| | | .then(function () { |
| | | .then(function() { |
| | | return delDonatebaseinfo(ids); |
| | | }) |
| | | .then(() => { |
| | |
| | | this.exportLoading = true; |
| | | return exportDonatebaseinfo(queryParams); |
| | | }) |
| | | .then((response) => { |
| | | .then(response => { |
| | | this.$download.name(response.msg); |
| | | this.exportLoading = false; |
| | | }) |
| | |
| | | handledownload(row) { |
| | | const id = row.id || this.ids; |
| | | |
| | | downloadbaseinfo(id).then((response) => { |
| | | var fileUrl = response; |
| | | downloadbaseinfo(id).then(res => { |
| | | var fileUrl = res; |
| | | //获取当前网址 |
| | | var urlBase = process.env.VUE_APP_BASE_API; |
| | | var curWWWPath = window.document.location.href; |
| | | var pos = curWWWPath.indexOf(window.document.location.pathname); |
| | | |
| | | // 创建a标签 |
| | | var aEle = document.createElement("a"); |
| | | aEle.href = |
| | | curWWWPath.substring(0, pos) + urlBase + fileUrl["downloadUrl"]; |
| | | aEle.click(); |
| | | console.log(aEle.href); |
| | | // 添加Authorization头部 |
| | | fetch(aEle.href, { |
| | | headers: this.headers |
| | | }) |
| | | .then(response => { |
| | | // 将文件下载链接作为blob对象进行下载 |
| | | return response.blob(); |
| | | }) |
| | | .then(blob => { |
| | | const url = window.URL.createObjectURL(new Blob([blob])); |
| | | console.log(url); |
| | | const link = document.createElement("a"); |
| | | link.href = url; |
| | | const name = fileUrl["downloadName"]; |
| | | link.setAttribute("download", name); // 替换file.pdf为实际的文件名 |
| | | document.body.appendChild(link); |
| | | link.click(); |
| | | link.parentNode.removeChild(link); |
| | | }); |
| | | }); |
| | | }, |
| | | }, |
| | | } |
| | | } |
| | | }; |
| | | </script> |
| | | |
| | |
| | | margin: auto !important; |
| | | padding-bottom: 0px !important; |
| | | } |
| | | </style> |
| | | </style> |