utils.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. import {dateHandle} from "../../../utils/dateHandle.js";
  2. const {dateDiff} = dateHandle;
  3. /**
  4. * 主题数据
  5. */
  6. export const themeList = [{
  7. id: 0,
  8. title: '个案追踪',
  9. des: '评价诊疗服务的内涵质量以及对各种诊疗规范、临床路径等的执行力',
  10. },{
  11. id: 1,
  12. title: '系统追踪',
  13. des: '评价对各种质量与安全管理制度与流程的执行力、医院服务的连贯性及多学科综合的服务能力',
  14. }];
  15. // 查核计划里的数据
  16. export const checkPlanList = [
  17. {id: 'week', value: 1, label: '每周', model: 7},
  18. {id: 'month', value: 2, label: '每月', model: 30},
  19. {id: 'twoMonth', value: 3, label: '每两月', model: 60},
  20. {id: 'quarter', value: 4, label: '每季度', model: 90},
  21. {id: 'halfAYear', value: 5, label: '每半年', model: 180},
  22. {id: 'custom', value: 6, label: '天', model: null},
  23. ];
  24. /**
  25. * 底部按钮数据
  26. */
  27. export const normalBtnGroup = [
  28. {id: 'pre', label: '上一步'},
  29. {id: 'next', label: '下一步'}
  30. ];
  31. export const btnGroupPlan1 = [
  32. {id: 'pre', label: '上一步'},
  33. {id: 'checkPlanCreate', label: '生成查核计划'}
  34. ];
  35. export const btnGroupPlan2 = [
  36. {id: 'checkPlanCallback', label: '返回'},
  37. {id: 'next', label: '下一步'}
  38. ];
  39. export const btnGroupSituationPreview = [
  40. {id: 'pre', label: '上一步'},
  41. {id: 'situationPreviewOK', label: '完成'}
  42. ];
  43. /**
  44. * 增加树形数据字段,以适配公共组件
  45. * @param {Object} data
  46. */
  47. export const conditionOptions = function(data) {
  48. let options = data.map((item)=>{
  49. return {
  50. ...item,
  51. key: item.id,
  52. label: item.name,
  53. children: conditionOptions(item.child)
  54. }
  55. });
  56. return options;
  57. }
  58. /**
  59. * 创建
  60. * 构造条件提交结果
  61. */
  62. export const optionsHandle = (arr, conditionIds) => {
  63. let options = [...arr].map((item)=>{
  64. return {
  65. ...item,
  66. selectFlag: conditionIds.includes(item.id),
  67. child: optionsHandle(item.child, conditionIds)
  68. }
  69. });
  70. return options;
  71. }
  72. /**
  73. * 构造查核组提交数据
  74. */
  75. export const checkGroup = function({list, checkedItem}) {
  76. let _list = [...list].map((ntem)=>{
  77. return {
  78. ...ntem,
  79. selectFlag: ntem.id === checkedItem.id ? true : false
  80. }
  81. });
  82. return _list;
  83. }
  84. /**
  85. * 构造查核地图提交数据
  86. */
  87. export const checkDep = function(list) {
  88. return list.map((item, i)=>{
  89. return {
  90. ...item,
  91. sort: i+1,
  92. enableFlag: item.status === 'disable' ? false : true,
  93. }
  94. });
  95. }
  96. /**
  97. * 编辑
  98. * 条件树遍历,获取选中项的id
  99. */
  100. export const initConditionIds = (arr, result) => {
  101. arr.map((item)=>{
  102. if(item.selectFlag || item.selectFlag === 'true') {
  103. result.push(item.id);
  104. }
  105. if(item.child && item.child.length > 0) {
  106. initConditionIds(item.child, result);
  107. }
  108. })
  109. }
  110. // 构造条件回显数据
  111. export const editCondition = ({depType, filterCondition})=>{
  112. let conditionIds = [];
  113. initConditionIds(filterCondition, conditionIds);
  114. return {
  115. depType, // 门急诊类型 1-门诊 2-急诊
  116. conditionIds, // 选中的key
  117. options: conditionOptions(filterCondition), // 树形节点数据
  118. defaultOpen: filterCondition.length > 0 ? [filterCondition[0].id]:[], // 默认展开的项
  119. }
  120. }
  121. // 构造查核组回显数据
  122. export const editCheckRent = ({checkGroup}) =>{
  123. let obj = checkGroup.find((item)=>item.selectFlag || item.selectFlag === 'true');
  124. return { // 查核组页面数据
  125. list: checkGroup,
  126. checkedItem: obj ? obj : {id: null}
  127. }
  128. }
  129. // 查核地图数据
  130. export const editCheckMap = ({checkDep}) =>{
  131. return { // 查核地图数据
  132. list: checkDep.map((item)=>{
  133. return {
  134. ...item,
  135. status: 'normal'
  136. }
  137. }), // 列表数据
  138. actionItem: {id: '', pointList: []}, // 当前操作的列表项
  139. deptList: [], // 新增单位数据
  140. }
  141. }
  142. // 查核计划数据
  143. export const editCheckPlan = ({planConfig, planList}) =>{
  144. let checkedItem = checkPlanList.find((item)=>item.value === planConfig.frequency);
  145. return { // 查核计划
  146. checkedItem: checkedItem?checkedItem: {id: 'month', value: 2, label: '每月', model: 30}, // 选中的取模方式对象
  147. dateObj: { // 保存开始日期结束日期的对象
  148. start: planConfig.startDate,
  149. end: planConfig.endDate,
  150. dayNum: dateDiff(planConfig.startDat, planConfig.endDate) // 两个日期间隔的天数
  151. },
  152. checkList: planList.map((item)=>{
  153. return item.startDate
  154. }), // 核查计划数组
  155. }
  156. }
  157. // 预览数据
  158. export const editSituationPreview = ({name, remindPlanDay,remindPlanHour,remindCheckDay}) => {
  159. return {
  160. sitName: name,
  161. preDay: remindPlanDay,
  162. preH: remindPlanHour,
  163. startDay: remindCheckDay
  164. }
  165. }
  166. // 判断两个数组全等
  167. export const arrayEquality = (arr1,arr2) =>{
  168. let flage = true;
  169. arr1.map((item, i)=>{
  170. if(item !== arr2[i]){
  171. flage = false;
  172. }
  173. });
  174. return flage;
  175. }