|
@@ -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, menus, date, annexname, term, sort }) {
|
|
|
+ async create({ title, thumbnail, annex, content, istop, menus, date, annexname, term, sort, columns }) {
|
|
|
assert(title, '标题不存在');
|
|
|
// assert(thumbnail, '缩略图不存在');
|
|
|
assert(content, '内容不存在');
|
|
@@ -16,13 +16,13 @@ class ContentService extends Service {
|
|
|
const slug = text.substring(0, 200);
|
|
|
try {
|
|
|
const year = date.slice(0, 4) + '年';
|
|
|
- await model.create({ title, slug, thumbnail, annex, content, istop, menus, createAt, year, date, annexname, term, hits: 0, sort });
|
|
|
+ await model.create({ title, slug, thumbnail, annex, content, istop, menus, createAt, year, date, annexname, term, hits: 0, sort, columns });
|
|
|
return { errmsg: '', errcode: 0 };
|
|
|
} catch (error) {
|
|
|
throw new Error('添加失败');
|
|
|
}
|
|
|
}
|
|
|
- async update({ title, thumbnail, annex, content, istop, menus, date, annexname, term, _id, sort }) {
|
|
|
+ async update({ title, thumbnail, annex, content, istop, menus, date, annexname, term, _id, sort, columns }) {
|
|
|
assert(_id, 'id不存在');
|
|
|
const { Content: model } = this.ctx.model;
|
|
|
let text = content.replace(new RegExp('</?[^>]+>', 'gm'), '');
|
|
@@ -30,7 +30,7 @@ class ContentService extends Service {
|
|
|
const slug = text.substring(0, 200);
|
|
|
const year = date.slice(0, 4) + '年';
|
|
|
try {
|
|
|
- await model.findById(_id).update({ title, slug, thumbnail, annex, content, istop, menus, year, date, annexname, term, sort });
|
|
|
+ await model.findById(_id).update({ title, slug, thumbnail, annex, content, istop, menus, year, date, annexname, term, sort, columns });
|
|
|
return { errmsg: '', errcode: 0 };
|
|
|
} catch (error) {
|
|
|
throw new Error('修改失败');
|
|
@@ -61,12 +61,23 @@ class ContentService extends Service {
|
|
|
throw new Error('删除失败');
|
|
|
}
|
|
|
}
|
|
|
- async query({ skip, limit, title, code }) {
|
|
|
+ async query({ skip, limit, title, code, columns }) {
|
|
|
const { Content: model } = this.ctx.model;
|
|
|
const filter = {};
|
|
|
- if (title) filter.title = title;
|
|
|
- // 后续修改字段 columns - menus
|
|
|
- if (code) filter.menus = code;
|
|
|
+ const arr = { title, code, columns };
|
|
|
+ for (const e in arr) {
|
|
|
+ let datas;
|
|
|
+ if (e === 'columns') {
|
|
|
+ console.log(arr[e]);
|
|
|
+ datas = `{ "${e}": { "$elemMatch": { "$eq": "${arr[e]}" } } }`;
|
|
|
+ } else {
|
|
|
+ datas = `{ "${e}": { "$regex": "${arr[e]}" } }`;
|
|
|
+ }
|
|
|
+ if (arr[e]) {
|
|
|
+ filter.$or = [];
|
|
|
+ filter.$or.push(JSON.parse(datas));
|
|
|
+ }
|
|
|
+ }
|
|
|
let total = 0;
|
|
|
try {
|
|
|
let res;
|
|
@@ -88,12 +99,10 @@ class ContentService extends Service {
|
|
|
try {
|
|
|
const res = await model.find();
|
|
|
for (let i = 0; i < res.length; i++) {
|
|
|
- const content = res[i].content;
|
|
|
- let txet = content.replace(new RegExp(/\/files\/images\/\d{6}\//, 'gm'), '/filespath/resource/');
|
|
|
- txet = txet.replace(new RegExp(/JPG/, 'gm'), 'jpg');
|
|
|
- await model.findById(res[i]._id).update({ ...res, content: txet });
|
|
|
+ const columns = [ res[i].menus ];
|
|
|
+ await model.findById(res[i]._id).update({ ...res, columns });
|
|
|
}
|
|
|
- return { errmsg: '', errcode: 0, res };
|
|
|
+ return { errmsg: '', errcode: 0 };
|
|
|
} catch (error) {
|
|
|
throw new Error('删除失败');
|
|
|
}
|