123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- /*
- * @Author: your name
- * @Date: 2021-07-26 15:20:30
- * @LastEditTime: 2021-07-27 10:04:54
- * @LastEditors: Please set LastEditors
- * @Description: In User Settings Edit
- * @FilePath: /TracerMethodology_PC/mock/userMana.js
- */
- // eslint-disable-next-line import/no-extraneous-dependencies
- import moment from 'moment';
- import { parse } from 'url'; // mock tableListDataSource
- const genList = (current, pageSize) => {
- const tableListDataSource = [];
- for (let i = 0; i < pageSize; i += 1) {
- const index = (current - 1) * 10 + i;
- tableListDataSource.push({
- key:index,
- name:`用户${i}`,
- account:`账户${i}`,
- hospitalStatus:0,
- id:index,
- password:'123'
- });
- }
- // console.log({tableListDataSource});
- tableListDataSource.reverse();
- return tableListDataSource;
- };
- let tableListDataSource = genList(1, 100);
- function getUser(req, res, u) {
- let realUrl = u;
- if (!realUrl || Object.prototype.toString.call(realUrl) !== '[object String]') {
- realUrl = req.url;
- }
- const { current = 1, pageSize = 10 } = req.query;
- const params = parse(realUrl, true).query;
- let dataSource = [...tableListDataSource].slice((current - 1) * pageSize, current * pageSize);
- if (params.sorter) {
- const sorter = JSON.parse(params.sorter);
- dataSource = dataSource.sort((prev, next) => {
- let sortNumber = 0;
- Object.keys(sorter).forEach((key) => {
- if (sorter[key] === 'descend') {
- if (prev[key] - next[key] > 0) {
- sortNumber += -1;
- } else {
- sortNumber += 1;
- }
- return;
- }
- if (prev[key] - next[key] > 0) {
- sortNumber += 1;
- } else {
- sortNumber += -1;
- }
- });
- return sortNumber;
- });
- }
- if (params.filter) {
- const filter = JSON.parse(params.filter);
- if (Object.keys(filter).length > 0) {
- dataSource = dataSource.filter((item) => {
- return Object.keys(filter).some((key) => {
- if (!filter[key]) {
- return true;
- }
- if (filter[key].includes(`${item[key]}`)) {
- return true;
- }
- return false;
- });
- });
- }
- }
- if (params.name) {
- dataSource = dataSource.filter((data) => data?.name?.includes(params.name || ''));
- }
- const result = {
- data: {
- list:dataSource,
- totalCount:tableListDataSource.length,
- pageSize:pageSize,
- },
- status:200,
- success: true,
- };
- return res.json(result);
- }
- function postUser(req, res, u, b) {
- let realUrl = u;
- if (!realUrl || Object.prototype.toString.call(realUrl) !== '[object String]') {
- realUrl = req.url;
- }
- // const body = (b && b.body) || req.body;
- const { method,body} = req;
- const {name,account, hospitalStatus,password } = body;
- switch (method) {
- /* eslint no-case-declarations:0 */
- case 'delete':
- tableListDataSource = tableListDataSource.filter((item) => key.indexOf(item.key) === -1);
- break;
- case 'POST':
- (() => {
- const i = Math.ceil(Math.random() * 10000);
- const newRule = {
- key: tableListDataSource.length,
- avatar: [
- 'https://gw.alipayobjects.com/zos/rmsportal/eeHMaZBwmTvLdIwMfBpg.png',
- 'https://gw.alipayobjects.com/zos/rmsportal/udxAbMEhpwthVVcjLXik.png',
- ][i % 2],
- name,
- account,
- hospitalStatus,
- password,
- createdAt: moment().format('YYYY-MM-DD'),
- };
- tableListDataSource.unshift(newRule);
- return res.json(newRule);
- })();
- return;
- case 'update':
- (() => {
- let newRule = {};
- tableListDataSource = tableListDataSource.map((item) => {
- if (item.key === key) {
- newRule = { ...item, desc, name };
- return { ...item, desc, name };
- }
- return item;
- });
- return res.json(newRule);
- })();
- return;
- default:
- break;
- }
- const result = {
- list: tableListDataSource,
- pagination: {
- total: tableListDataSource.length,
- },
- };
- res.json(result);
- }
- export default {
- 'GET /api/costAccount/user/list': getUser,
- 'POST /api/costAccount/user/save': postUser,
- };
|