index.ts 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. import config from '@/config/axios/config'
  2. import { MockMethod } from 'vite-plugin-mock'
  3. import { toAnyString } from '@/utils'
  4. import Mock from 'mockjs'
  5. const { code } = config
  6. const timeout = 1000
  7. const count = 100
  8. const baseContent =
  9. '<p>I am testing data, I am testing data.</p><p><img src="https://wpimg.wallstcn.com/4c69009c-0fd4-4153-b112-6cb53d1cf943"></p>'
  10. interface ListProps {
  11. id: string
  12. author: string
  13. title: string
  14. content: string
  15. importance: number
  16. display_time: string
  17. pageviews: number
  18. image_uri: string
  19. }
  20. interface TreeListProps {
  21. id: string
  22. author: string
  23. title: string
  24. content: string
  25. importance: number
  26. display_time: string
  27. pageviews: number
  28. children: TreeListProps[]
  29. }
  30. let List: ListProps[] = []
  31. for (let i = 0; i < count; i++) {
  32. List.push(
  33. Mock.mock({
  34. id: toAnyString(),
  35. // timestamp: +Mock.Random.date('T'),
  36. author: '@first',
  37. title: '@title(5, 10)',
  38. content: baseContent,
  39. importance: '@integer(1, 3)',
  40. display_time: '@datetime',
  41. pageviews: '@integer(300, 5000)',
  42. image_uri: Mock.Random.image('@integer(300, 5000)x@integer(300, 5000)')
  43. })
  44. )
  45. }
  46. const treeList: TreeListProps[] = []
  47. for (let i = 0; i < count; i++) {
  48. treeList.push(
  49. Mock.mock({
  50. id: toAnyString(),
  51. // timestamp: +Mock.Random.date('T'),
  52. author: '@first',
  53. title: '@title(5, 10)',
  54. content: baseContent,
  55. importance: '@integer(1, 3)',
  56. display_time: '@datetime',
  57. pageviews: '@integer(300, 5000)',
  58. children: [
  59. {
  60. id: toAnyString(),
  61. // timestamp: +Mock.Random.date('T'),
  62. author: '@first',
  63. title: '@title(5, 10)',
  64. content: baseContent,
  65. importance: '@integer(1, 3)',
  66. display_time: '@datetime',
  67. pageviews: '@integer(300, 5000)',
  68. children: [
  69. {
  70. id: toAnyString(),
  71. // timestamp: +Mock.Random.date('T'),
  72. author: '@first',
  73. title: '@title(5, 10)',
  74. content: baseContent,
  75. importance: '@integer(1, 3)',
  76. display_time: '@datetime',
  77. pageviews: '@integer(300, 5000)'
  78. },
  79. {
  80. id: toAnyString(),
  81. // timestamp: +Mock.Random.date('T'),
  82. author: '@first',
  83. title: '@title(5, 10)',
  84. content: baseContent,
  85. importance: '@integer(1, 3)',
  86. display_time: '@datetime',
  87. pageviews: '@integer(300, 5000)'
  88. }
  89. ]
  90. },
  91. {
  92. id: toAnyString(),
  93. // timestamp: +Mock.Random.date('T'),
  94. author: '@first',
  95. title: '@title(5, 10)',
  96. content: baseContent,
  97. importance: '@integer(1, 3)',
  98. display_time: '@datetime',
  99. pageviews: '@integer(300, 5000)'
  100. },
  101. {
  102. id: toAnyString(),
  103. // timestamp: +Mock.Random.date('T'),
  104. author: '@first',
  105. title: '@title(5, 10)',
  106. content: baseContent,
  107. importance: '@integer(1, 3)',
  108. display_time: '@datetime',
  109. pageviews: '@integer(300, 5000)'
  110. },
  111. {
  112. id: toAnyString(),
  113. // timestamp: +Mock.Random.date('T'),
  114. author: '@first',
  115. title: '@title(5, 10)',
  116. content: baseContent,
  117. importance: '@integer(1, 3)',
  118. display_time: '@datetime',
  119. pageviews: '@integer(300, 5000)'
  120. }
  121. ]
  122. // image_uri
  123. })
  124. )
  125. }
  126. export default [
  127. // 树形列表接口
  128. {
  129. url: '/example/treeList',
  130. method: 'get',
  131. timeout,
  132. response: ({ query }) => {
  133. const { title, pageIndex, pageSize } = query
  134. const mockList = treeList.filter((item) => {
  135. if (title && item.title.indexOf(title) < 0) return false
  136. return true
  137. })
  138. const pageList = mockList.filter(
  139. (_, index) => index < pageSize * pageIndex && index >= pageSize * (pageIndex - 1)
  140. )
  141. return {
  142. code: code,
  143. data: {
  144. total: mockList.length,
  145. list: pageList
  146. }
  147. }
  148. }
  149. },
  150. // 列表接口
  151. {
  152. url: '/example/list',
  153. method: 'get',
  154. timeout,
  155. response: ({ query }) => {
  156. const { title, pageIndex, pageSize } = query
  157. const mockList = List.filter((item) => {
  158. if (title && item.title.indexOf(title) < 0) return false
  159. return true
  160. })
  161. const pageList = mockList.filter(
  162. (_, index) => index < pageSize * pageIndex && index >= pageSize * (pageIndex - 1)
  163. )
  164. return {
  165. code: code,
  166. data: {
  167. total: mockList.length,
  168. list: pageList
  169. }
  170. }
  171. }
  172. },
  173. // 保存接口
  174. {
  175. url: '/example/save',
  176. method: 'post',
  177. timeout,
  178. response: ({ body }) => {
  179. if (!body.id) {
  180. List = [
  181. Object.assign(body, {
  182. id: toAnyString()
  183. })
  184. ].concat(List)
  185. return {
  186. code: code,
  187. data: 'success'
  188. }
  189. } else {
  190. List.map((item) => {
  191. if (item.id === body.id) {
  192. for (const key in item) {
  193. item[key] = body[key]
  194. }
  195. }
  196. })
  197. return {
  198. code: code,
  199. data: 'success'
  200. }
  201. }
  202. }
  203. },
  204. // 详情接口
  205. {
  206. url: '/example/detail',
  207. method: 'get',
  208. response: ({ query }) => {
  209. const { id } = query
  210. for (const example of List) {
  211. if (example.id === id) {
  212. return {
  213. code: code,
  214. data: example
  215. }
  216. }
  217. }
  218. }
  219. },
  220. // 删除接口
  221. {
  222. url: '/example/delete',
  223. method: 'post',
  224. response: ({ body }) => {
  225. const ids = body.ids
  226. if (!ids) {
  227. return {
  228. code: 500,
  229. message: '请选择需要删除的数据'
  230. }
  231. } else {
  232. let i = List.length
  233. while (i--) {
  234. if (ids.indexOf(List[i].id) !== -1) {
  235. List.splice(i, 1)
  236. }
  237. }
  238. return {
  239. code: code,
  240. data: 'success'
  241. }
  242. }
  243. }
  244. }
  245. ] as MockMethod[]