You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

426 lines
16 KiB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
  1. <template>
  2. <div style="display:flex">
  3. <div>
  4. <el-form ref="form" :model="form" label-width="80px" :rules="rules" size="medium">
  5. <el-row>
  6. <el-col :span="6">
  7. <el-form-item label="单位名称" prop="customerOrgId">
  8. <el-cascader v-model="form.customerOrgId" :options="patientRegister.customerOrgTreeAll"
  9. :props="{ checkStrictly: true, expandTrigger: 'hover', ...customerOrg.treeprops }" :show-all-levels="false"
  10. disabled>
  11. </el-cascader>
  12. </el-form-item>
  13. </el-col>
  14. <el-col :span="6">
  15. <el-form-item label="条码号" prop="patientRegisterNo">
  16. <el-input v-model="form.patientRegisterNo" disabled></el-input>
  17. </el-form-item>
  18. </el-col>
  19. <el-col :span="6">
  20. <el-form-item label="档案号" prop="patientId">
  21. <el-input v-model="form.patientId" disabled></el-input>
  22. </el-form-item>
  23. </el-col>
  24. <el-col :span="6" />
  25. </el-row>
  26. <el-row>
  27. <el-col :span="6">
  28. <el-form-item label="姓名" prop="patientName">
  29. <el-input v-model="form.patientName"></el-input>
  30. </el-form-item>
  31. </el-col>
  32. <el-col :span="6">
  33. <el-form-item label="性别" prop="sexId">
  34. <el-select v-model="form.sexId" placeholder="请选择">
  35. <el-option v-for="item in dict.sex" :key="item.id" :label="item.displayName" :value="item.id">
  36. </el-option>
  37. </el-select>
  38. </el-form-item>
  39. </el-col>
  40. <el-col :span="6">
  41. <el-form-item label="体检次数" prop="medicalTimes">
  42. <el-input v-model="form.medicalTimes" disabled></el-input>
  43. </el-form-item>
  44. </el-col>
  45. <el-col :span="6" />
  46. </el-row>
  47. <el-row>
  48. <el-col :span="6">
  49. <el-form-item label="年龄" prop="age">
  50. <el-input v-model="form.age"></el-input>
  51. </el-form-item>
  52. </el-col>
  53. <el-col :span="6">
  54. <el-form-item label="出生日期" prop="birthDate">
  55. <el-date-picker v-model="form.birthDate" type="date" placeholder="出生日期" style="width:135px;" />
  56. </el-form-item>
  57. </el-col>
  58. <el-col :span="6">
  59. <el-form-item label="婚姻状况" prop="maritalStatusId">
  60. <el-select v-model="form.maritalStatusId" placeholder="请选择">
  61. <el-option v-for="item in dict.maritalStatus" :key="item.id" :label="item.displayName" :value="item.id">
  62. </el-option>
  63. </el-select>
  64. </el-form-item>
  65. </el-col>
  66. <el-col :span="6" />
  67. </el-row>
  68. <el-row>
  69. <el-col :span="6">
  70. <el-form-item label="体检类别" prop="medicalTypeId">
  71. <el-select v-model="form.medicalTypeId" placeholder="请选择">
  72. <el-option v-for="item in dict.medicalType" :key="item.id" :label="item.displayName" :value="item.id">
  73. </el-option>
  74. </el-select>
  75. </el-form-item>
  76. </el-col>
  77. <el-col :span="6">
  78. <el-form-item label="工卡号" prop="jobCardNo">
  79. <el-input v-model="form.jobCardNo"></el-input>
  80. </el-form-item>
  81. </el-col>
  82. <el-col :span="6">
  83. <el-form-item label="体检卡号" prop="medicalCardNo">
  84. <el-input v-model="form.medicalCardNo"></el-input>
  85. </el-form-item>
  86. </el-col>
  87. <el-col :span="6">
  88. <el-form-item label="职务" prop="jobPost">
  89. <el-input v-model="form.jobPost"></el-input>
  90. </el-form-item>
  91. </el-col>
  92. <el-col :span="6">
  93. <el-form-item label="职称" prop="jobTitle">
  94. <el-input v-model="form.jobTitle"></el-input>
  95. </el-form-item>
  96. </el-col>
  97. <el-col :span="6">
  98. <el-form-item label="介绍人" prop="salesman">
  99. <el-input v-model="form.salesman"></el-input>
  100. </el-form-item>
  101. </el-col>
  102. <el-col :span="6">
  103. <el-form-item label="性激素期" prop="sexHormoneTermId">
  104. <el-select v-model="form.sexHormoneTermId" placeholder="请选择" filterable clearable>
  105. <el-option v-for="item in dict.sexHormoneTerm" :key="item.id" :label="item.displayName" :value="item.id">
  106. </el-option>
  107. </el-select>
  108. </el-form-item>
  109. </el-col>
  110. <el-col :span="6">
  111. <el-form-item label="是否VIP" prop="isVip">
  112. <el-radio v-model="form.isVip" label="Y"></el-radio>
  113. <el-radio v-model="form.isVip" label="N"></el-radio>
  114. </el-form-item>
  115. </el-col>
  116. </el-row>
  117. <el-row>
  118. <el-col :span="6">
  119. <el-form-item label="电话随访" prop="isPhoneFollow">
  120. <el-radio v-model="form.isPhoneFollow" label="Y"></el-radio>
  121. <el-radio v-model="form.isPhoneFollow" label="N"></el-radio>
  122. </el-form-item>
  123. </el-col>
  124. <el-col :span="6">
  125. <el-form-item label="隐藏姓名" prop="isNameHide">
  126. <el-radio v-model="form.isNameHide" label="Y"></el-radio>
  127. <el-radio v-model="form.isNameHide" label="N"></el-radio>
  128. </el-form-item>
  129. </el-col>
  130. <el-col :span="6">
  131. <el-form-item label="是否锁住" prop="isLock">
  132. <el-radio v-model="form.isLock" label="Y"></el-radio>
  133. <el-radio v-model="form.isLock" label="N"></el-radio>
  134. </el-form-item>
  135. </el-col>
  136. <el-col :span="6">
  137. <el-form-item label="体检开始" prop="isMedicalStart">
  138. <el-radio v-model="form.isMedicalStart" label="Y" disabled></el-radio>
  139. <el-radio v-model="form.isMedicalStart" label="N" disabled></el-radio>
  140. </el-form-item>
  141. </el-col>
  142. <el-col :span="6">
  143. <el-form-item label="体检中心" prop="organizationUnitId">
  144. <el-select v-model="form.organizationUnitId" placeholder="请选择" filterable>
  145. <el-option v-for="item in dict.organization" :key="item.id" :label="item.displayName" :value="item.id">
  146. </el-option>
  147. </el-select>
  148. </el-form-item>
  149. </el-col>
  150. <el-col :span="6">
  151. <el-form-item label="分组" prop="customerOrgGroupId">
  152. <el-select v-model="form.customerOrgGroupId" placeholder="请选择" filterable clearable
  153. :disabled="form.customerOrgId == '00000000-0000-0000-0000-000000000000' ? false : true">
  154. <el-option v-for="item in patientRegister.customerOrgGroup" :key="item.id" :label="item.displayName"
  155. :value="item.id">
  156. </el-option>
  157. </el-select>
  158. </el-form-item>
  159. </el-col>
  160. <el-col :span="6">
  161. <el-form-item label="套餐" prop="medicalPackageId">
  162. <el-select v-model="form.medicalPackageId" placeholder="请选择" filterable clearable
  163. :disabled="form.customerOrgId == '00000000-0000-0000-0000-000000000000' ? true : false">
  164. <el-option v-for="item in dict.medicalPackage" :key="item.id" :label="item.displayName" :value="item.id">
  165. </el-option>
  166. </el-select>
  167. </el-form-item>
  168. </el-col>
  169. <el-col :span="6">
  170. <el-form-item label="完成标志" prop="completeFlag">
  171. <el-select v-model="form.completeFlag" placeholder="请选择" disabled>
  172. <el-option v-for="item in dict.completeFlag" :key="item.id" :label="item.displayName" :value="item.id">
  173. </el-option>
  174. </el-select>
  175. </el-form-item>
  176. </el-col>
  177. <el-col :span="24">
  178. <el-form-item label="备注" prop="remark">
  179. <el-input v-model="form.remark" type="textarea" :rows="2" placeholder="请输入内容"></el-input>
  180. </el-form-item>
  181. </el-col>
  182. </el-row>
  183. <el-row>
  184. <el-col :span="6">
  185. <el-form-item label="创建者">
  186. <el-input v-model="form.creatorName" disabled></el-input>
  187. </el-form-item>
  188. </el-col>
  189. <el-col :span="6">
  190. <el-form-item label="创建时间">
  191. <el-input :value="form.creationTime | dateFormat" disabled></el-input>
  192. </el-form-item>
  193. </el-col>
  194. <el-col :span="6">
  195. <el-form-item label="修改者">
  196. <el-input v-model="form.creatorName" disabled></el-input>
  197. </el-form-item>
  198. </el-col>
  199. <el-col :span="6">
  200. <el-form-item label="修改时间">
  201. <el-input :value="form.lastModificationTime | dateFormat" disabled></el-input>
  202. </el-form-item>
  203. </el-col>
  204. </el-row>
  205. </el-form>
  206. <el-image class="photo" src="https://cube.elemecdn.com/6/94/4d3ea53c084bad6931a56d5158a48jpeg.jpeg">
  207. <div slot="placeholder" class="image-slot">
  208. 加载中<span class="dot">...</span>
  209. </div>
  210. </el-image>
  211. </div>
  212. <!-- 按钮区域 -->
  213. <div style="margin-left: 10px;" width="120px">
  214. <div class="btn">
  215. <el-button @click="readIdCard">读身份证</el-button>
  216. </div>
  217. <div class="btn">
  218. <el-button type="success" @click="Onsubmit('form')">保存</el-button>
  219. </div>
  220. <div class="btn">
  221. <el-button type="primary" @click="">拍照</el-button>
  222. </div>
  223. <div class="btn">
  224. <el-button type="primary" @click="">申请单</el-button>
  225. </div>
  226. <div class="btn">
  227. <el-button type="primary" @click="">打条码</el-button>
  228. </div>
  229. <div class="btn">
  230. <el-button type="primary" @click="">打指引单</el-button>
  231. </div>
  232. <div class="btn">
  233. <el-button type="primary" @click="">复制新增</el-button>
  234. </div>
  235. </div>
  236. </div>
  237. </template>
  238. <script>
  239. import moment from 'moment';
  240. import { mapState } from 'vuex'
  241. import { getapi, postapi, putapi, deletapi } from "@/api/api";
  242. import { tcdate, objCopy } from '../../utlis/proFunc'
  243. export default {
  244. components: {
  245. },
  246. data() {
  247. return {
  248. data: {
  249. organizationdata: [], //体检中心数据
  250. customerOrgType: [], //单位类别
  251. },
  252. form: {
  253. id: '', //id
  254. patientId: '00000000-0000-0000-0000-000000000000', //档案号ID 选择了档案就传档案号,未选就传00000-0000...
  255. customerOrgId: null, //单位编号
  256. customerOrgGroupId: null, //分组
  257. medicalPackageId: null,//套餐
  258. patientName: '', //姓名
  259. birthDate: '', //字符串 如:2012-01-29
  260. sexId: 'U', //性别 默认未知U
  261. age: null, //年龄
  262. jobCardNo: '', //工卡号
  263. medicalCardNo: '', //体检卡号
  264. maritalStatusId: 'U', //婚姻状况 默认未知
  265. medicalTypeId: null, //体检类别
  266. personnelTypeId: null, //人员类别
  267. jobPost: '', //职务
  268. jobTitle: '', //职称
  269. photo: '', //照片
  270. salesman: '', //介绍人
  271. sexHormoneTermId: null, //性激素期限
  272. isNameHide: 'N', //隐藏姓名
  273. isPhoneFollow: 'N', //电话随访
  274. isVip: 'N', //vip客户
  275. remark: '', //
  276. isLock: 'N', //是否锁住
  277. completeFlag: '1', //完成标志 0:预登记,1:未检,2:部份已检,3:已总检 【创建编辑时不操作】
  278. isMedicalStart: 'N', //体检开始标志 【创建编辑时不操作】
  279. patientRegisterNo: '', //条码号 【创建编辑时不操作】
  280. medicalTimes: 1, //条码号 【创建编辑时不操作】
  281. organizationUnitId: null //体检中心
  282. }, //单位 记录 目前新增与更新是一致
  283. rules: {
  284. patientName: [
  285. { required: true, message: "请输入姓名", trigger: "blur" },
  286. ],
  287. },
  288. };
  289. },
  290. created() {
  291. },
  292. //挂载完成
  293. mounted() {
  294. //表单赋值
  295. //console.log('mounted this.patientRegister.patientRegisterRd',this.patientRegister.patientRegisterRd)
  296. objCopy(this.patientRegister.patientRegisterRd, this.form)
  297. //console.log('mounted this.form',this.form)
  298. },
  299. computed: {
  300. ...mapState(['dict', 'patientRegister', 'customerOrg']),
  301. },
  302. methods: {
  303. readIdCard() {
  304. console.log('this.form1', this.form)
  305. },
  306. //提交
  307. Onsubmit(formName) {
  308. this.$refs[formName].validate((valid) => {
  309. if (valid) {
  310. //赋值
  311. let body = {...this.form}
  312. delete body.id
  313. delete body.patientRegisterNo
  314. delete body.medicalTimes
  315. delete body.completeFlag
  316. delete body.isMedicalStart
  317. delete body.customerOrgGroupId
  318. delete body.medicalPackageId
  319. //日期转换
  320. console.log('body.birthDate',body.birthDate)
  321. if(body.birthDate){
  322. body.birthDate = moment(new Date(body.birthDate)).format('yyyy-MM-DD')
  323. }
  324. console.log('body.birthDate',body.birthDate)
  325. //moment(pub.dateAddSeconds(new Date('2022-12-09T02:39:33.983Z'),60*60)).format('yyyyMMDDHHmmssSSS')
  326. console.log('this.form.id',this.form.id)
  327. console.log('body',body)
  328. if (this.form.id.length < 1) {
  329. //id为空则新增
  330. postapi(`/api/app/patient-register`, body).then(
  331. (res) => {
  332. if(res.code == 1){
  333. this.$message.success("创健 操作成功");
  334. this.patientRegister.patientRegisterId = res.id
  335. this.patientRegister.patientRegisterRd = res
  336. }
  337. }
  338. );
  339. } else {
  340. //id不为空则编辑
  341. putapi(`/api/app/patient-register/${this.form.id}`, body).then(
  342. (res) => {
  343. this.$message.success("更新 操作成功");
  344. objCopy(this.patientRegister.patientRegisterRd,this.form)
  345. }
  346. );
  347. }
  348. } else {
  349. alert('未通过数据校验');
  350. return false;
  351. }
  352. });
  353. },
  354. //新增弹框
  355. add() {
  356. this.customerOrg.customerOrgId = ''
  357. this.customerOrg.customerOrgRd = {
  358. id: '', isLock: 'N',
  359. isActive: 'Y'
  360. }
  361. },
  362. //删除
  363. del() {
  364. deletapi(`/api/app/customer-org/${this.customerOrg.customerOrgRd.id}`).then(
  365. (res) => {
  366. this.$message.success("删除 操作成功");
  367. this.setData({ key: 'customerOrg.customerOrgRd', value: { id: '' } })
  368. this.getCustomerOrgTree()
  369. }
  370. );
  371. }
  372. },
  373. //监听事件
  374. watch: {
  375. 'patientRegister.patientRegisterRd.customerOrgId'(newVal, oldVal) {
  376. if (newVal != oldVal) {
  377. //console.log('patientRegister.patientRegisterRd.customerOrgId',this.patientRegister.patientRegisterRd.customerOrgId)
  378. objCopy(this.patientRegister.patientRegisterRd, this.form)
  379. }
  380. },
  381. 'patientRegister.patientRegisterRd.id'(newVal, oldVal) {
  382. if (newVal != oldVal) {
  383. //console.log('patientRegister.patientRegisterRd.customerOrgId',this.patientRegister.patientRegisterRd.customerOrgId)
  384. objCopy(this.patientRegister.patientRegisterRd, this.form)
  385. }
  386. },
  387. },
  388. };
  389. </script>
  390. <style scoped>
  391. .btn {
  392. margin-top: 10px;
  393. }
  394. .photo {
  395. position: absolute;
  396. top: 60px;
  397. right: 150px;
  398. width: 150px;
  399. height: 180px;
  400. }</style>