SmartMessageSystemListView.config.tsx 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  1. import type { SmartColumn, SmartSearchFormSchema } from '@/components/SmartTable';
  2. import type { FormSchema } from '@/components/Form';
  3. import { getMessageTypeEnum, getMessagePriorityEnum } from '../../SmartMessageConstants';
  4. export const getMessageSendStatusEnum = (t: Function) => {
  5. return [
  6. {
  7. label: t('smart.message.systemMessage.form.sendStatus.NO_SEND'),
  8. value: 'NO_SEND',
  9. },
  10. {
  11. label: t('smart.message.systemMessage.form.sendStatus.SEND'),
  12. value: 'SEND',
  13. },
  14. {
  15. label: t('smart.message.systemMessage.form.sendStatus.CANCEL'),
  16. value: 'CANCEL',
  17. },
  18. ];
  19. };
  20. export const getReceiveUserTypeEnum = (t: Function) => {
  21. return [
  22. {
  23. label: t('smart.message.systemMessage.form.receiveUserType.ALL_USER'),
  24. value: 'ALL_USER',
  25. },
  26. {
  27. label: t('smart.message.systemMessage.form.receiveUserType.SPECIFY_USER'),
  28. value: 'SPECIFY_USER',
  29. },
  30. {
  31. label: t('smart.message.systemMessage.form.receiveUserType.BUSINESS_USER'),
  32. value: 'BUSINESS_USER',
  33. },
  34. ];
  35. };
  36. /**
  37. * 表格列表
  38. */
  39. export const getTableColumns = (t: Function): SmartColumn[] => {
  40. const messageTypeEnum = getMessageTypeEnum(t);
  41. const sendStatusEnum = getMessageSendStatusEnum(t);
  42. const messagePriorityEnum = getMessagePriorityEnum(t);
  43. const receiveUserTypeEnum = getReceiveUserTypeEnum(t);
  44. return [
  45. {
  46. type: 'checkbox',
  47. width: 60,
  48. align: 'center',
  49. fixed: 'left',
  50. },
  51. {
  52. field: 'title',
  53. title: '{smart.message.systemMessage.title.title}',
  54. width: 200,
  55. fixed: 'left',
  56. },
  57. {
  58. field: 'abstractContent',
  59. title: '{smart.message.systemMessage.title.abstract}',
  60. width: 120,
  61. },
  62. {
  63. field: 'messageType',
  64. title: '{smart.message.systemMessage.title.messageType}',
  65. width: 120,
  66. dynamicClass: ({ row }) => {
  67. const messageType = row.messageType;
  68. if (!messageType) {
  69. return '';
  70. }
  71. return messageType === 'ANNOUNCEMENT'
  72. ? 'text-color--success-bold'
  73. : 'text-color--link-bold';
  74. },
  75. formatter: ({ row }) => {
  76. const messageType = row.messageType;
  77. if (!messageType) {
  78. return '';
  79. }
  80. const enumList = messageTypeEnum.filter((item) => item.value === row.messageType);
  81. if (enumList.length === 0) {
  82. return '';
  83. }
  84. const data = enumList[0];
  85. return data.label;
  86. },
  87. },
  88. {
  89. field: 'sendStatus',
  90. title: '{smart.message.systemMessage.title.sendStatus}',
  91. width: 120,
  92. slots: {
  93. default: ({ row }) => {
  94. if (!row.sendStatus) {
  95. return '';
  96. }
  97. const enumList = sendStatusEnum.filter((item) => item.value === row.sendStatus);
  98. if (enumList.length === 0) {
  99. return '';
  100. }
  101. const data = enumList[0];
  102. let color = 'pink';
  103. if (data.value === 'SEND') {
  104. color = 'green';
  105. } else if (data.value === 'CANCEL') {
  106. color = 'grey';
  107. }
  108. return <a-tag color={color}>{data.label}</a-tag>;
  109. },
  110. },
  111. },
  112. {
  113. field: 'priority',
  114. title: '{smart.message.systemMessage.title.priority}',
  115. width: 120,
  116. slots: {
  117. default: ({ row }) => {
  118. if (!row.priority) {
  119. return '';
  120. }
  121. const enumList = messagePriorityEnum.filter((item) => item.value === row.priority);
  122. if (enumList.length === 0) {
  123. return '';
  124. }
  125. const data = enumList[0];
  126. let color = 'pink';
  127. if (data.value === 'MIDDLE') {
  128. color = 'orange';
  129. } else if (data.value === 'LOW') {
  130. color = 'green';
  131. }
  132. return <a-tag color={color}>{data.label}</a-tag>;
  133. },
  134. },
  135. },
  136. {
  137. field: 'receiveUserType',
  138. title: '{smart.message.systemMessage.title.receiveUserType}',
  139. width: 120,
  140. slots: {
  141. default: ({ row }) => {
  142. if (!row.receiveUserType) {
  143. return '';
  144. }
  145. const enumList = receiveUserTypeEnum.filter((item) => item.value === row.receiveUserType);
  146. if (enumList.length === 0) {
  147. return '';
  148. }
  149. const data = enumList[0];
  150. let color = '#2db7f5';
  151. if (data.value === 'SPECIFY_USER') {
  152. color = '#87d068';
  153. } else if (data.value === 'BUSINESS_USER') {
  154. color = '#108ee9';
  155. }
  156. return <a-tag color={color}>{data.label}</a-tag>;
  157. },
  158. },
  159. },
  160. {
  161. field: 'sendTime',
  162. title: '{smart.message.systemMessage.title.sendTime}',
  163. width: 165,
  164. sortable: true,
  165. },
  166. {
  167. field: 'cancelTime',
  168. title: '{smart.message.systemMessage.title.cancelTime}',
  169. width: 165,
  170. sortable: true,
  171. },
  172. {
  173. field: 'useYn',
  174. component: 'booleanTag',
  175. title: '{common.table.useYn}',
  176. width: 120,
  177. },
  178. {
  179. field: 'createTime',
  180. title: '{common.table.createTime}',
  181. width: 170,
  182. sortable: true,
  183. },
  184. {
  185. field: 'createBy',
  186. title: '{common.table.createUser}',
  187. width: 120,
  188. },
  189. {
  190. field: 'updateTime',
  191. title: '{common.table.updateTime}',
  192. width: 170,
  193. sortable: true,
  194. },
  195. {
  196. field: 'updateBy',
  197. title: '{common.table.updateUser}',
  198. width: 120,
  199. },
  200. {
  201. title: '{common.table.operation}',
  202. field: 'operation',
  203. width: 120,
  204. fixed: 'right',
  205. slots: {
  206. default: 'table-operation',
  207. },
  208. },
  209. ];
  210. };
  211. /**
  212. * 添加修改表单
  213. */
  214. export const getFormSchemas = (t: Function): FormSchema[] => {
  215. return [
  216. {
  217. field: 'id',
  218. show: false,
  219. label: t('smart.message.systemMessage.title.id'),
  220. component: 'Input',
  221. componentProps: {},
  222. },
  223. {
  224. field: 'messageType',
  225. label: t('smart.message.systemMessage.title.messageType'),
  226. component: 'RadioGroup',
  227. componentProps: {
  228. options: getMessageTypeEnum(t),
  229. },
  230. defaultValue: 'ANNOUNCEMENT',
  231. },
  232. {
  233. field: 'title',
  234. label: t('smart.message.systemMessage.title.title'),
  235. component: 'Input',
  236. componentProps: {},
  237. required: true,
  238. },
  239. {
  240. field: 'abstractContent',
  241. label: t('smart.message.systemMessage.title.abstract'),
  242. component: 'InputTextArea',
  243. componentProps: {},
  244. required: true,
  245. },
  246. {
  247. field: 'priority',
  248. label: t('smart.message.systemMessage.title.priority'),
  249. component: 'RadioGroup',
  250. componentProps: {
  251. options: getMessagePriorityEnum(t),
  252. },
  253. defaultValue: 'H',
  254. },
  255. {
  256. field: 'receiveUserType',
  257. label: t('smart.message.systemMessage.title.receiveUserType'),
  258. component: 'RadioGroup',
  259. componentProps: {
  260. options: getReceiveUserTypeEnum(t),
  261. },
  262. defaultValue: 'ALL_USER',
  263. },
  264. {
  265. field: 'userIds',
  266. label: t('smart.message.systemMessage.title.userIds'),
  267. component: 'SmartUserTableSelect',
  268. show: ({ model }) => {
  269. return model.receiveUserType !== 'ALL_USER';
  270. },
  271. required: ({ model }) => {
  272. return model.receiveUserType !== 'ALL_USER';
  273. },
  274. },
  275. {
  276. field: 'useYn',
  277. label: t('common.table.useYn'),
  278. component: 'Switch',
  279. defaultValue: true,
  280. componentProps: {},
  281. },
  282. {
  283. field: 'content',
  284. label: t('smart.message.systemMessage.title.content'),
  285. slot: 'addEdit-content',
  286. },
  287. ];
  288. };
  289. export const getSearchFormSchemas = (t: Function): SmartSearchFormSchema[] => {
  290. return [
  291. {
  292. field: 'title',
  293. label: t('smart.message.systemMessage.title.title'),
  294. component: 'Input',
  295. searchSymbol: 'like',
  296. },
  297. {
  298. field: 'messageType',
  299. label: t('smart.message.systemMessage.title.messageType'),
  300. component: 'Select',
  301. searchSymbol: '=',
  302. componentProps: {
  303. options: getMessageTypeEnum(t),
  304. style: {
  305. width: '140px',
  306. },
  307. },
  308. },
  309. {
  310. field: 'sendStatus',
  311. label: t('smart.message.systemMessage.title.sendStatus'),
  312. component: 'Select',
  313. searchSymbol: '=',
  314. componentProps: {
  315. options: getMessageSendStatusEnum(t),
  316. style: {
  317. width: '140px',
  318. },
  319. },
  320. },
  321. {
  322. field: 'priority',
  323. label: t('smart.message.systemMessage.title.priority'),
  324. component: 'Select',
  325. searchSymbol: '=',
  326. componentProps: {
  327. options: getMessagePriorityEnum(t),
  328. style: {
  329. width: '125px',
  330. },
  331. },
  332. },
  333. {
  334. field: 'receiveUserType',
  335. label: t('smart.message.systemMessage.title.receiveUserType'),
  336. component: 'Select',
  337. searchSymbol: '=',
  338. componentProps: {
  339. options: getReceiveUserTypeEnum(t),
  340. style: {
  341. width: '140px',
  342. },
  343. },
  344. },
  345. ];
  346. };
  347. export enum Auth {
  348. delete = 'smart:message:systemMessage:delete',
  349. update = 'smart:message:systemMessage:update',
  350. save = 'smart:message:systemMessage:save',
  351. publish = 'smart:message:systemMessage:publish',
  352. cancel = 'smart:message:systemMessage:cancel',
  353. }