useDefineSetting.ts 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. export const useDefineSetting = () => {
  2. const flowStatusList = [
  3. { id: 0, fullName: '待提交' },
  4. { id: 1, fullName: '进行中' },
  5. { id: 2, fullName: '已通过' },
  6. { id: 3, fullName: '已拒绝' },
  7. { id: 4, fullName: '已终止' },
  8. { id: 5, fullName: '已暂停' },
  9. { id: 6, fullName: '撤销中' },
  10. { id: 7, fullName: '已撤销' },
  11. { id: 8, fullName: '已退回' },
  12. { id: 9, fullName: '已撤回' },
  13. ];
  14. const flowUrgentList = [
  15. { id: 1, fullName: '普通' },
  16. { id: 2, fullName: '重要' },
  17. { id: 3, fullName: '紧急' },
  18. ];
  19. function getUrgentText(value) {
  20. if (value == 2) return '重要';
  21. if (value == 3) return '紧急';
  22. return '普通';
  23. }
  24. function getUrgentTextColor(value) {
  25. if (value == 2) return '#E6A23D';
  26. if (value == 3) return '#FF1818';
  27. return '#1890FF';
  28. }
  29. function getFlowStatusContent(value) {
  30. return flowStatusList[value || 0]?.fullName || '';
  31. }
  32. function getFlowStatusColor(value) {
  33. if (value == 1) return '#0177FF';
  34. if (value == 2) return 'rgba(35,162,5,0.39)';
  35. if (value == 3) return 'rgba(242,68,68,0.39)';
  36. if (value == 4) return 'rgba(241,61,61,0.85)';
  37. if (value == 5) return 'rgba(185,123,6,0.39)';
  38. if (value == 6) return 'rgba(215,149,77,0.39)';
  39. if (value == 7) return 'rgba(245,127,0,0.39)';
  40. if (value == 8) return 'rgba(21,21,157,0.39)';
  41. if (value == 9) return 'rgba(186,33,33,0.39)';
  42. return '#F09437';
  43. }
  44. function getHandlingStatusContent(value) {
  45. if (value == 1) return '流转';
  46. if (value == 2) return '加签';
  47. if (value == 3) return '转审';
  48. if (value == 4) return '指派';
  49. if (value == 5) return '退回';
  50. if (value == 6) return '撤回';
  51. if (value == 7) return '协办';
  52. if (value == 8) return '撤销';
  53. if (value == 9) return '转办';
  54. return '待签收';
  55. }
  56. function getHandlingStatusColor(value) {
  57. if (value == 1) return '#3DC60A';
  58. if (value == 2) return 'rgba(25,185,185,0.39)';
  59. if (value == 3) return 'rgba(49,151,214,0.39)';
  60. if (value == 4) return 'rgba(255,0,0,0.39)';
  61. if (value == 5) return 'rgba(21,21,157,0.39)';
  62. if (value == 6) return 'rgba(186,33,33,0.39)';
  63. if (value == 7) return 'rgba(172,214,58,0.39)';
  64. if (value == 8) return 'rgba(245,127,0,0.39)';
  65. if (value == 9) return 'rgba(186,33,33,0.39)';
  66. return '#2B6EF2';
  67. }
  68. function getFlowStateContent(value) {
  69. const stateList = [
  70. '拒绝',
  71. '同意',
  72. '发起',
  73. '退回',
  74. '撤回',
  75. '加签',
  76. '减签',
  77. '转审',
  78. '暂停',
  79. '恢复',
  80. '复活',
  81. '指派',
  82. '催办',
  83. '协办',
  84. '撤销申请',
  85. '终止',
  86. '同意撤销',
  87. '拒绝撤销',
  88. '转办',
  89. ];
  90. if (value == -1) return '待审批';
  91. if (value == -2) return '未审批';
  92. if (value == -3) return '待办理';
  93. if (value == -4) return '未办理';
  94. return stateList[value] || '';
  95. }
  96. function getFlowStateColor(value) {
  97. const colorList = [
  98. 'rgba(242,68,68,0.39)',
  99. 'rgba(35,162,5,0.39)',
  100. 'rgba(0,0,255,0.39)',
  101. 'rgba(21,21,157,0.39)',
  102. 'rgba(186,33,33,0.39)',
  103. 'rgba(25,185,185,0.39)',
  104. 'rgba(50,191,61,0.39)',
  105. 'rgba(49,151,214,0.39)',
  106. 'rgba(185,123,6,0.39)',
  107. 'rgba(45,94,186,0.39)',
  108. 'rgba(50,191,61,0.39)',
  109. 'rgba(255,0,0,0.39)',
  110. 'rgba(0,128,0,0.39)',
  111. 'rgba(172,214,58,0.39)',
  112. 'rgba(245,127,0,0.39)',
  113. 'rgba(241,61,61,0.85)',
  114. 'rgba(35,162,5,0.39)',
  115. 'rgba(242,68,68,0.39)',
  116. 'rgba(49,151,214,0.39)',
  117. ];
  118. let set = new Set([-1, -2, -3, -4]);
  119. if (set.has(value)) return 'rgba(165,168,172,1)';
  120. return colorList[value] || '';
  121. }
  122. function getHexColor(color) {
  123. let values = color
  124. .replace(/rgba?\(/, '')
  125. .replace(/\)/, '')
  126. .replace(/[\s+]/g, '')
  127. .split(',');
  128. let a = parseFloat(values[3] || 1),
  129. r = Math.floor(a * parseInt(values[0]) + (1 - a) * 255),
  130. g = Math.floor(a * parseInt(values[1]) + (1 - a) * 255),
  131. b = Math.floor(a * parseInt(values[2]) + (1 - a) * 255);
  132. return '#' + ('0' + r.toString(16)).slice(-2) + ('0' + g.toString(16)).slice(-2) + ('0' + b.toString(16)).slice(-2);
  133. }
  134. return {
  135. flowStatusList,
  136. flowUrgentList,
  137. getUrgentText,
  138. getUrgentTextColor,
  139. getFlowStatusContent,
  140. getFlowStatusColor,
  141. getHandlingStatusContent,
  142. getHandlingStatusColor,
  143. getFlowStateContent,
  144. getFlowStateColor,
  145. getHexColor,
  146. };
  147. };