|
@@ -4,7 +4,7 @@ const Service = require('egg').Service;
|
|
|
const assert = require('assert');
|
|
|
const moment = require('moment');
|
|
|
class ContentService extends Service {
|
|
|
- async create({ title, thumbnail, annex, content, istop, columns, date, annexname, term }) {
|
|
|
+ async create({ title, thumbnail, annex, content, istop, menus, date, annexname, term }) {
|
|
|
assert(title, '标题不存在');
|
|
|
assert(thumbnail, '缩略图不存在');
|
|
|
assert(content, '内容不存在');
|
|
@@ -15,20 +15,21 @@ class ContentService extends Service {
|
|
|
const slug = text.substring(0, 200);
|
|
|
try {
|
|
|
const year = date.slice(0, 3) + '年';
|
|
|
- await model.create({ title, slug, thumbnail, annex, content, istop, columns, createAt, year, date, annexname, term, hits: 0 });
|
|
|
+ await model.create({ title, slug, thumbnail, annex, content, istop, menus, createAt, year, date, annexname, term, hits: 0 });
|
|
|
return { errmsg: '', errcode: 0 };
|
|
|
} catch (error) {
|
|
|
throw new Error({ errcode: -2001, errmsg: '添加失败' });
|
|
|
}
|
|
|
}
|
|
|
- async update({ title, thumbnail, annex, content, istop, columns, _id, year, date, annexname }) {
|
|
|
+ async update({ title, thumbnail, annex, content, istop, menus, date, annexname, term, _id }) {
|
|
|
assert(_id, 'id不存在');
|
|
|
const { Content: model } = this.ctx.model;
|
|
|
let text = content.replace(new RegExp('</?[^>]+>', 'gm'), '');
|
|
|
text = text.replace('\\s*|\t|\r|\n', '');
|
|
|
const slug = text.substring(0, 200);
|
|
|
+ const year = date.slice(0, 3) + '年';
|
|
|
try {
|
|
|
- await model.findById(_id).update({ title, slug, thumbnail, annex, content, istop, columns, year, date, annexname });
|
|
|
+ await model.findById(_id).update({ title, slug, thumbnail, annex, content, istop, menus, year, date, annexname, term });
|
|
|
return { errmsg: '', errcode: 0 };
|
|
|
} catch (error) {
|
|
|
throw new Error({ errcode: -2001, errmsg: '修改失败' });
|
|
@@ -59,25 +60,28 @@ class ContentService extends Service {
|
|
|
throw new Error({ errcode: -2001, errmsg: '删除失败' });
|
|
|
}
|
|
|
}
|
|
|
- async query({ skip, limit, title, columns }) {
|
|
|
+ async query({ skip, limit, title, code }) {
|
|
|
const { Content: model } = this.ctx.model;
|
|
|
const filter = {};
|
|
|
if (title) filter.title = title;
|
|
|
- if (columns) filter.columns = columns;
|
|
|
+ // 后续修改字段 columns - menus
|
|
|
+ if (code) filter.menus = code;
|
|
|
let total = 0;
|
|
|
try {
|
|
|
let res;
|
|
|
total = await model.find({ ...filter });
|
|
|
if (skip && limit) {
|
|
|
- res = await model.find({ ...filter }, { content: false }).skip(Number(skip) * Number(limit)).limit(Number(limit));
|
|
|
+ res = await model.find({ ...filter }, { content: false }).skip(Number(skip) * Number(limit)).limit(Number(limit))
|
|
|
+ .sort({ date: -1 });
|
|
|
} else {
|
|
|
- res = await model.find({ ...filter }, { content: false });
|
|
|
+ res = await model.find({ ...filter }, { content: false }).sort({ date: -1 });
|
|
|
}
|
|
|
return { errmsg: '', errcode: 0, data: res, total: total.length };
|
|
|
} catch (error) {
|
|
|
throw new Error({ errcode: -2001, errmsg: '查询失败' });
|
|
|
}
|
|
|
}
|
|
|
+ // 数据库添加过滤数据方法
|
|
|
async filepath() {
|
|
|
const { Content: model } = this.ctx.model;
|
|
|
try {
|