You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
126 lines
3.2 KiB
126 lines
3.2 KiB
10 months ago
|
// +----------------------------------------------------------------------
|
||
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Author: CRMEB Team <admin@crmeb.com>
|
||
|
// +----------------------------------------------------------------------
|
||
|
import Mock from 'mockjs'
|
||
|
|
||
|
const List = []
|
||
|
const count = 100
|
||
|
|
||
|
const baseContent = '<p>I am testing data, I am testing data.</p><p><img src="https://wpimg.wallstcn.com/4c69009c-0fd4-4153-b112-6cb53d1cf943"></p>'
|
||
|
const image_uri = 'https://wpimg.wallstcn.com/e4558086-631c-425c-9430-56ffb46e70b3'
|
||
|
|
||
|
for (let i = 0; i < count; i++) {
|
||
|
List.push(Mock.mock({
|
||
|
id: '@increment',
|
||
|
timestamp: +Mock.Random.date('T'),
|
||
|
author: '@first',
|
||
|
reviewer: '@first',
|
||
|
title: '@title(5, 10)',
|
||
|
content_short: 'mock data',
|
||
|
content: baseContent,
|
||
|
forecast: '@float(0, 100, 2, 2)',
|
||
|
importance: '@integer(1, 3)',
|
||
|
'type|1': ['CN', 'US', 'JP', 'EU'],
|
||
|
'status|1': ['published', 'draft'],
|
||
|
display_time: '@datetime',
|
||
|
comment_disabled: true,
|
||
|
pageviews: '@integer(300, 5000)',
|
||
|
image_uri,
|
||
|
platforms: ['a-platform']
|
||
|
}))
|
||
|
}
|
||
|
|
||
|
export default [
|
||
|
{
|
||
|
url: '/vue-element-admin/article/list',
|
||
|
type: 'get',
|
||
|
response: config => {
|
||
|
const { importance, type, title, page = 1, limit = 20, sort } = config.query
|
||
|
|
||
|
let mockList = List.filter(item => {
|
||
|
if (importance && item.importance !== +importance) return false
|
||
|
if (type && item.type !== type) return false
|
||
|
if (title && item.title.indexOf(title) < 0) return false
|
||
|
return true
|
||
|
})
|
||
|
|
||
|
if (sort === '-id') {
|
||
|
mockList = mockList.reverse()
|
||
|
}
|
||
|
|
||
|
const pageList = mockList.filter((item, index) => index < limit * page && index >= limit * (page - 1))
|
||
|
|
||
|
return {
|
||
|
code: 20000,
|
||
|
data: {
|
||
|
total: mockList.length,
|
||
|
items: pageList
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
|
||
|
{
|
||
|
url: '/vue-element-admin/article/detail',
|
||
|
type: 'get',
|
||
|
response: config => {
|
||
|
const { id } = config.query
|
||
|
for (const article of List) {
|
||
|
if (article.id === +id) {
|
||
|
return {
|
||
|
code: 20000,
|
||
|
data: article
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
|
||
|
{
|
||
|
url: '/vue-element-admin/article/pv',
|
||
|
type: 'get',
|
||
|
response: _ => {
|
||
|
return {
|
||
|
code: 20000,
|
||
|
data: {
|
||
|
pvData: [
|
||
|
{ key: 'PC', pv: 1024 },
|
||
|
{ key: 'mobile', pv: 1024 },
|
||
|
{ key: 'ios', pv: 1024 },
|
||
|
{ key: 'android', pv: 1024 }
|
||
|
]
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
|
||
|
{
|
||
|
url: '/vue-element-admin/article/create',
|
||
|
type: 'post',
|
||
|
response: _ => {
|
||
|
return {
|
||
|
code: 20000,
|
||
|
data: 'success'
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
|
||
|
{
|
||
|
url: '/vue-element-admin/article/update',
|
||
|
type: 'post',
|
||
|
response: _ => {
|
||
|
return {
|
||
|
code: 20000,
|
||
|
data: 'success'
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
]
|
||
|
|