listTableList.ts 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. // eslint-disable-next-line import/no-extraneous-dependencies
  2. import { Request, Response } from 'express';
  3. import moment from 'moment';
  4. import { parse } from 'url';
  5. // mock tableListDataSource
  6. const genList = (current: number, pageSize: number) => {
  7. const tableListDataSource: API.RuleListItem[] = [];
  8. for (let i = 0; i < pageSize; i += 1) {
  9. const index = (current - 1) * 10 + i;
  10. tableListDataSource.push({
  11. key: index,
  12. disabled: i % 6 === 0,
  13. href: 'https://ant.design',
  14. avatar: [
  15. 'https://gw.alipayobjects.com/zos/rmsportal/eeHMaZBwmTvLdIwMfBpg.png',
  16. 'https://gw.alipayobjects.com/zos/rmsportal/udxAbMEhpwthVVcjLXik.png',
  17. ][i % 2],
  18. name: `TradeCode ${index}`,
  19. owner: '曲丽丽',
  20. desc: '这是一段描述',
  21. callNo: Math.floor(Math.random() * 1000),
  22. status: Math.floor(Math.random() * 10) % 4,
  23. updatedAt: moment().format('YYYY-MM-DD'),
  24. createdAt: moment().format('YYYY-MM-DD'),
  25. progress: Math.ceil(Math.random() * 100),
  26. });
  27. }
  28. tableListDataSource.reverse();
  29. return tableListDataSource;
  30. };
  31. let tableListDataSource = genList(1, 100);
  32. function getRule(req: Request, res: Response, u: string) {
  33. let realUrl = u;
  34. if (!realUrl || Object.prototype.toString.call(realUrl) !== '[object String]') {
  35. realUrl = req.url;
  36. }
  37. const { current = 1, pageSize = 10 } = req.query;
  38. const params = parse(realUrl, true).query as unknown as API.PageParams &
  39. API.RuleListItem & {
  40. sorter: any;
  41. filter: any;
  42. };
  43. let dataSource = [...tableListDataSource].slice(
  44. ((current as number) - 1) * (pageSize as number),
  45. (current as number) * (pageSize as number),
  46. );
  47. if (params.sorter) {
  48. const sorter = JSON.parse(params.sorter);
  49. dataSource = dataSource.sort((prev, next) => {
  50. let sortNumber = 0;
  51. Object.keys(sorter).forEach((key) => {
  52. if (sorter[key] === 'descend') {
  53. if (prev[key] - next[key] > 0) {
  54. sortNumber += -1;
  55. } else {
  56. sortNumber += 1;
  57. }
  58. return;
  59. }
  60. if (prev[key] - next[key] > 0) {
  61. sortNumber += 1;
  62. } else {
  63. sortNumber += -1;
  64. }
  65. });
  66. return sortNumber;
  67. });
  68. }
  69. if (params.filter) {
  70. const filter = JSON.parse(params.filter as any) as {
  71. [key: string]: string[];
  72. };
  73. if (Object.keys(filter).length > 0) {
  74. dataSource = dataSource.filter((item) => {
  75. return Object.keys(filter).some((key) => {
  76. if (!filter[key]) {
  77. return true;
  78. }
  79. if (filter[key].includes(`${item[key]}`)) {
  80. return true;
  81. }
  82. return false;
  83. });
  84. });
  85. }
  86. }
  87. if (params.name) {
  88. dataSource = dataSource.filter((data) => data?.name?.includes(params.name || ''));
  89. }
  90. const result = {
  91. data: dataSource,
  92. total: tableListDataSource.length,
  93. success: true,
  94. pageSize,
  95. current: parseInt(`${params.current}`, 10) || 1,
  96. };
  97. return res.json(result);
  98. }
  99. function postRule(req: Request, res: Response, u: string, b: Request) {
  100. let realUrl = u;
  101. if (!realUrl || Object.prototype.toString.call(realUrl) !== '[object String]') {
  102. realUrl = req.url;
  103. }
  104. const body = (b && b.body) || req.body;
  105. const { method, name, desc, key } = body;
  106. switch (method) {
  107. /* eslint no-case-declarations:0 */
  108. case 'delete':
  109. tableListDataSource = tableListDataSource.filter((item) => key.indexOf(item.key) === -1);
  110. break;
  111. case 'post':
  112. (() => {
  113. const i = Math.ceil(Math.random() * 10000);
  114. const newRule: API.RuleListItem = {
  115. key: tableListDataSource.length,
  116. href: 'https://ant.design',
  117. avatar: [
  118. 'https://gw.alipayobjects.com/zos/rmsportal/eeHMaZBwmTvLdIwMfBpg.png',
  119. 'https://gw.alipayobjects.com/zos/rmsportal/udxAbMEhpwthVVcjLXik.png',
  120. ][i % 2],
  121. name,
  122. owner: '曲丽丽',
  123. desc,
  124. callNo: Math.floor(Math.random() * 1000),
  125. status: Math.floor(Math.random() * 10) % 2,
  126. updatedAt: moment().format('YYYY-MM-DD'),
  127. createdAt: moment().format('YYYY-MM-DD'),
  128. progress: Math.ceil(Math.random() * 100),
  129. };
  130. tableListDataSource.unshift(newRule);
  131. return res.json(newRule);
  132. })();
  133. return;
  134. case 'update':
  135. (() => {
  136. let newRule = {};
  137. tableListDataSource = tableListDataSource.map((item) => {
  138. if (item.key === key) {
  139. newRule = { ...item, desc, name };
  140. return { ...item, desc, name };
  141. }
  142. return item;
  143. });
  144. return res.json(newRule);
  145. })();
  146. return;
  147. default:
  148. break;
  149. }
  150. const result = {
  151. list: tableListDataSource,
  152. pagination: {
  153. total: tableListDataSource.length,
  154. },
  155. };
  156. res.json(result);
  157. }
  158. export default {
  159. 'GET /api/rule': getRule,
  160. 'POST /api/rule': postRule,
  161. };