guhongwei il y a 2 ans
Parent
commit
97d1ab2cf6

+ 13 - 0
app/controller/banner.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.banner.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 轮播图
+class BannerController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.banner;
+  }
+}
+module.exports = CrudController(BannerController, meta);

+ 13 - 0
app/controller/cases.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.program.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 节目表
+class ProgramController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.program;
+  }
+}
+module.exports = CrudController(ProgramController, meta);

+ 13 - 0
app/controller/company.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.company.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 公司信息
+class CompanyController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.company;
+  }
+}
+module.exports = CrudController(CompanyController, meta);

+ 60 - 0
app/controller/config/.banner.js

@@ -0,0 +1,60 @@
+module.exports = {
+  create: {
+    requestBody: [
+      "place",
+      "name",
+      "origin",
+      "create_time",
+      "img_url",
+      "file_url",
+      "news",
+      "is_use",
+    ],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: [
+      "place",
+      "name",
+      "origin",
+      "create_time",
+      "img_url",
+      "file_url",
+      "news",
+      "is_use",
+    ],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        place: "place",
+        name: "name",
+        origin: "origin",
+        create_time: "create_time",
+        is_use: "is_use",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 57 - 0
app/controller/config/.cases.js

@@ -0,0 +1,57 @@
+module.exports = {
+  create: {
+    requestBody: [
+      "name",
+      "brief",
+      "create_time",
+      "img_url",
+      "file_url",
+      "content",
+      "is_use",
+    ],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: [
+      "name",
+      "brief",
+      "create_time",
+      "img_url",
+      "file_url",
+      "content",
+      "is_use",
+    ],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        name: "name",
+        brief: "brief",
+        create_time: "create_time",
+        is_use: "is_use",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 72 - 0
app/controller/config/.company.js

@@ -0,0 +1,72 @@
+module.exports = {
+  create: {
+    requestBody: [
+      "name",
+      "logo_url",
+      "address",
+      "contact",
+      "phone",
+      "qq",
+      "email",
+      "mobile",
+      "advantage",
+      "programme",
+      "idea",
+      "unique",
+      "join",
+    ],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: [
+      "name",
+      "logo_url",
+      "address",
+      "contact",
+      "phone",
+      "qq",
+      "email",
+      "mobile",
+      "advantage",
+      "programme",
+      "idea",
+      "unique",
+      "join",
+    ],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        name: "name",
+        address: "address",
+        contact: "contact",
+        phone: "phone",
+        qq: "qq",
+        email: "email",
+        mobile: "mobile",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 42 - 0
app/controller/config/.dictdata.js

@@ -0,0 +1,42 @@
+module.exports = {
+  create: {
+    requestBody: ["type", "label", "value", "sort", "is_use", "remark"],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: ["type", "label", "value", "sort", "is_use", "remark"],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        type: "type",
+        label: "label",
+        value: "value",
+        sort: "sort",
+        is_use: "is_use",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["sort"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 41 - 0
app/controller/config/.dicttype.js

@@ -0,0 +1,41 @@
+module.exports = {
+  create: {
+    requestBody: ["name", "type", "is_use", "sort", "remark"],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: ["name", "type", "is_use", "sort", "remark"],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        name: "name",
+        type: "type",
+        is_use: "is_use",
+        sort: "sort",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["sort"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 40 - 0
app/controller/config/.leavemess.js

@@ -0,0 +1,40 @@
+module.exports = {
+  create: {
+    requestBody: ["name", "phone", "email", "content"],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: ["name", "phone", "email", "content"],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        name: "name",
+        phone: "phone",
+        email: "email",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 60 - 0
app/controller/config/.news.js

@@ -0,0 +1,60 @@
+module.exports = {
+  create: {
+    requestBody: [
+      "type",
+      "title",
+      "origin",
+      "create_time",
+      "img_url",
+      "file_url",
+      "content",
+      "is_use",
+    ],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: [
+      "type",
+      "title",
+      "origin",
+      "create_time",
+      "img_url",
+      "file_url",
+      "content",
+      "is_use",
+    ],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        type: "type",
+        title: "title",
+        origin: "origin",
+        create_time: "create_time",
+        is_use: "is_use",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 15 - 0
app/controller/dictdata.js

@@ -0,0 +1,15 @@
+'use strict';
+const meta = require('./config/.dictdata.js');
+const Controller = require('egg').Controller;
+const {
+  CrudController,
+} = require('naf-framework-mongoose-free/lib/controller');
+
+// 字典数据表
+class DictdataController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.dictdata;
+  }
+}
+module.exports = CrudController(DictdataController, meta);

+ 15 - 0
app/controller/dicttype.js

@@ -0,0 +1,15 @@
+'use strict';
+const meta = require('./config/.dicttype.js');
+const Controller = require('egg').Controller;
+const {
+  CrudController,
+} = require('naf-framework-mongoose-free/lib/controller');
+
+// 字典类型表
+class DicttypeController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.dicttype;
+  }
+}
+module.exports = CrudController(DicttypeController, meta);

+ 13 - 0
app/controller/leavemess.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.program.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 节目表
+class ProgramController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.program;
+  }
+}
+module.exports = CrudController(ProgramController, meta);

+ 13 - 0
app/controller/news.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.leavemess.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 留言
+class LeavemessController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.leavemess;
+  }
+}
+module.exports = CrudController(LeavemessController, meta);

+ 1 - 3
app/controller/program.js

@@ -1,9 +1,7 @@
 'use strict';
 const meta = require('./config/.program.js');
 const Controller = require('egg').Controller;
-const {
-  CrudController,
-} = require('naf-framework-mongoose-free/lib/controller');
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
 
 // 节目表
 class ProgramController extends Controller {

+ 31 - 0
app/model/banner.js

@@ -0,0 +1,31 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+
+// 轮播图
+const banner = {
+  place: { type: String, required: false, zh: '展示位置' }, // 字典表:banner_place
+  name: { type: String, required: false, zh: '名称' }, //
+  origin: { type: String, required: false, default: '系统管理员', zh: '来源' }, //
+  create_time: { type: String, required: false, zh: '时间' }, //
+  img_url: { type: Array, required: false, zh: '图片' }, //
+  file_url: { type: Array, required: false, zh: '文件' }, //
+  news: { type: Array, required: false, zh: '新闻' }, //
+  is_use: { type: String, required: false, default: '0', zh: '是否启用' }, // 字典表:is_use
+};
+const schema = new Schema(banner, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ place: 1 });
+schema.index({ name: 1 });
+schema.index({ origin: 1 });
+schema.index({ create_time: 1 });
+schema.index({ is_use: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Banner', schema, 'banner');
+};

+ 29 - 0
app/model/cases.js

@@ -0,0 +1,29 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+
+// 案例
+const cases = {
+  name: { type: String, required: false, zh: '名称' }, //
+  brief: { type: String, required: false, zh: '简介' }, //
+  create_time: { type: String, required: false, zh: '时间' }, //
+  img_url: { type: String, required: false, zh: '图片' }, //
+  file_url: { type: String, required: false, zh: '文件' }, //
+  content: { type: String, required: false, zh: '内容' }, //
+  is_use: { type: String, required: false, default: '0', zh: '是否启用' }, // 字典表:is_use
+};
+const schema = new Schema(cases, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ name: 1 });
+schema.index({ brief: 1 });
+schema.index({ create_time: 1 });
+schema.index({ is_use: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Cases', schema, 'cases');
+};

+ 38 - 0
app/model/company.js

@@ -0,0 +1,38 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+
+// 公司信息
+const company = {
+  name: { type: String, required: false, zh: '公司名称' }, //
+  logo_url: { type: Array, required: false, zh: '公司logo' }, //
+  address: { type: String, required: false, zh: '公司地址' }, //
+  contact: { type: String, required: false, zh: '联系人' }, //
+  phone: { type: String, required: false, zh: '联系电话' }, //
+  qq: { type: String, required: false, zh: 'qq' }, //
+  email: { type: String, required: false, zh: '电子邮箱' }, //
+  mobile: { type: String, required: false, zh: '座机' }, //
+  advantage: { type: Array, required: false, zh: '公司优势' }, //
+  programme: { type: Array, required: false, zh: '解决方案' }, //
+  idea: { type: String, required: false, zh: '品牌理念' }, //
+  unique: { type: String, required: false, zh: '独特优势' }, //
+  join: { type: String, required: false, zh: '加入我们' }, //
+};
+const schema = new Schema(company, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ name: 1 });
+schema.index({ address: 1 });
+schema.index({ contact: 1 });
+schema.index({ phone: 1 });
+schema.index({ qq: 1 });
+schema.index({ email: 1 });
+schema.index({ mobile: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Company', schema, 'company');
+};

+ 30 - 0
app/model/dictdata.js

@@ -0,0 +1,30 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+
+// 字典数据表
+const dictdata = {
+  type: { type: String, required: false, zh: '字典类型' }, //
+  label: { type: String, required: false, zh: '内容名' }, //
+  value: { type: String, required: false, zh: '内容值' }, //
+  sort: { type: Number, required: false, default: 0, zh: '排序' }, //
+  is_use: { type: String, required: false, default: '0', zh: '是否启用' }, //
+  remark: { type: String, required: false, zh: '备注' }, //
+};
+const schema = new Schema(dictdata, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ type: 1 });
+schema.index({ label: 1 });
+schema.index({ value: 1 });
+schema.index({ sort: 1 });
+schema.index({ is_use: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Dictdata', schema, 'dictdata');
+};
+

+ 25 - 0
app/model/dicttype.js

@@ -0,0 +1,25 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+// 字典类型表
+const dicttype = {
+  name: { type: String, required: false, zh: '名称' }, //
+  type: { type: String, required: false, zh: '类型' }, //
+  sort: { type: Number, required: false, default: 0, zh: '排序' }, //
+  is_use: { type: String, required: false, default: '0', zh: '是否启用' }, //
+  remark: { type: String, required: false, zh: '备注' }, //
+};
+const schema = new Schema(dicttype, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ name: 1 });
+schema.index({ type: 1 });
+schema.index({ sort: 1 });
+schema.index({ is_use: 1 });
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Dicttype', schema, 'dicttype');
+};

+ 25 - 0
app/model/leavemess.js

@@ -0,0 +1,25 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+
+// 留言
+const leavemess = {
+  name: { type: String, required: false, zh: '姓名' }, //
+  phone: { type: String, required: false, zh: '联系电话' }, //
+  email: { type: String, required: false, zh: '电子邮箱' }, //
+  content: { type: String, required: false, zh: '留言内容' }, //
+};
+const schema = new Schema(leavemess, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ name: 1 });
+schema.index({ phone: 1 });
+schema.index({ email: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Leavemess', schema, 'leavemess');
+};

+ 31 - 0
app/model/news.js

@@ -0,0 +1,31 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+
+// 新闻资讯
+const news = {
+  type: { type: String, required: false, zh: '新闻类型' }, // 字典表:news_type
+  title: { type: String, required: false, zh: '标题' }, //
+  origin: { type: String, required: false, default: '系统管理员', zh: '来源' }, //
+  create_time: { type: String, required: false, zh: '时间' }, //
+  img_url: { type: Array, required: false, zh: '图片' }, //
+  file_url: { type: Array, required: false, zh: '文件' }, //
+  content: { type: String, required: false, zh: '内容' }, //
+  is_use: { type: String, required: false, default: '0', zh: '是否启用' }, // 字典表:is_use
+};
+const schema = new Schema(news, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ type: 1 });
+schema.index({ title: 1 });
+schema.index({ origin: 1 });
+schema.index({ create_time: 1 });
+schema.index({ is_use: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('News', schema, 'news');
+};

+ 8 - 0
app/router.js

@@ -9,4 +9,12 @@ module.exports = app => {
   router.get('/', controller.home.index);
   require('./z_router/admin')(app); // 管理員
   require('./z_router/program')(app); // 节目表
+  require('./z_router/dicttype')(app); // 字典类型表
+  require('./z_router/dictdata')(app); // 字典数据表
+
+  require('./z_router/company')(app); // 公司信息
+  require('./z_router/banner')(app); // 轮播图
+  require('./z_router/news')(app); // 新闻资讯
+  require('./z_router/cases')(app); // 案例
+  require('./z_router/leavemess')(app); // 留言
 };

+ 15 - 0
app/service/banner.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 轮播图
+class BannerService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'banner');
+    this.model = this.ctx.model.Banner;
+  }
+}
+
+module.exports = BannerService;

+ 15 - 0
app/service/cases.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 案例
+class CasesService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'cases');
+    this.model = this.ctx.model.Cases;
+  }
+}
+
+module.exports = CasesService;

+ 23 - 0
app/service/company.js

@@ -0,0 +1,23 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 公司信息
+class CompanyService extends CrudService {
+  constructor(ctx) {
+    super(ctx, "company");
+    this.model = this.ctx.model.Company;
+  }
+  async query({ ...info }) {
+    let res = {};
+    const data = await this.model.findOne({ ...info });
+    if (data) {
+      res = data;
+    }
+    return res;
+  }
+}
+
+module.exports = CompanyService;

+ 15 - 0
app/service/dictdata.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 字典数据表
+class DictdataService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'dictdata');
+    this.model = this.ctx.model.Dictdata;
+  }
+}
+
+module.exports = DictdataService;

+ 15 - 0
app/service/dicttype.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 字典类型表
+class DicttypeService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'dicttype');
+    this.model = this.ctx.model.Dicttype;
+  }
+}
+
+module.exports = DicttypeService;

+ 15 - 0
app/service/leavemess.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 留言
+class LeavemessService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'leavemess');
+    this.model = this.ctx.model.Leavemess;
+  }
+}
+
+module.exports = LeavemessService;

+ 15 - 0
app/service/news.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 新闻资讯
+class NewsService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'news');
+    this.model = this.ctx.model.News;
+  }
+}
+
+module.exports = NewsService;

+ 28 - 0
app/z_router/banner.js

@@ -0,0 +1,28 @@
+'use strict';
+// 测试接口
+const rKey = 'banner'; // routerKey,路由前缀变量
+const cKey = 'banner'; // controllerKey,controller名
+const zhKey = '轮播图';
+const routes = [
+  { method: 'get', path: `/${rKey}`, controller: `${cKey}.index`, name: `${cKey}Query`, zh: `${zhKey}列表查询` },
+  { method: 'get', path: `/${rKey}/:id`, controller: `${cKey}.show`, name: `${cKey}Show`, zh: `${zhKey}查询` },
+  { method: 'post', path: `/${rKey}`, controller: `${cKey}.create`, name: `${cKey}Create`, zh: `创建${zhKey}` },
+  { method: 'post', path: `/${rKey}/:id`, controller: `${cKey}.update`, name: `${cKey}Update`, zh: `修改${zhKey}` },
+  { method: 'delete', path: `/${rKey}/:id`, controller: `${cKey}.destroy`, name: `${cKey}Delete`, zh: `删除${zhKey}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]());
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};

+ 28 - 0
app/z_router/cases.js

@@ -0,0 +1,28 @@
+'use strict';
+// 测试接口
+const rKey = 'cases'; // routerKey,路由前缀变量
+const cKey = 'cases'; // controllerKey,controller名
+const zhKey = '案例';
+const routes = [
+  { method: 'get', path: `/${rKey}`, controller: `${cKey}.index`, name: `${cKey}Query`, zh: `${zhKey}列表查询` },
+  { method: 'get', path: `/${rKey}/:id`, controller: `${cKey}.show`, name: `${cKey}Show`, zh: `${zhKey}查询` },
+  { method: 'post', path: `/${rKey}`, controller: `${cKey}.create`, name: `${cKey}Create`, zh: `创建${zhKey}` },
+  { method: 'post', path: `/${rKey}/:id`, controller: `${cKey}.update`, name: `${cKey}Update`, zh: `修改${zhKey}` },
+  { method: 'delete', path: `/${rKey}/:id`, controller: `${cKey}.destroy`, name: `${cKey}Delete`, zh: `删除${zhKey}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]());
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};

+ 28 - 0
app/z_router/company.js

@@ -0,0 +1,28 @@
+'use strict';
+// 测试接口
+const rKey = 'company'; // routerKey,路由前缀变量
+const cKey = 'company'; // controllerKey,controller名
+const zhKey = '公司信息';
+const routes = [
+  { method: 'get', path: `/${rKey}`, controller: `${cKey}.index`, name: `${cKey}Query`, zh: `${zhKey}列表查询` },
+  { method: 'get', path: `/${rKey}/:id`, controller: `${cKey}.show`, name: `${cKey}Show`, zh: `${zhKey}查询` },
+  { method: 'post', path: `/${rKey}`, controller: `${cKey}.create`, name: `${cKey}Create`, zh: `创建${zhKey}` },
+  { method: 'post', path: `/${rKey}/:id`, controller: `${cKey}.update`, name: `${cKey}Update`, zh: `修改${zhKey}` },
+  { method: 'delete', path: `/${rKey}/:id`, controller: `${cKey}.destroy`, name: `${cKey}Delete`, zh: `删除${zhKey}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]());
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};

+ 28 - 0
app/z_router/dictdata.js

@@ -0,0 +1,28 @@
+'use strict';
+// 测试接口
+const rKey = 'dictdata'; // routerKey,路由前缀变量
+const cKey = 'dictdata'; // controllerKey,controller名
+const zhKey = '字典数据表';
+const routes = [
+  { method: 'get', path: `/${rKey}`, controller: `${cKey}.index`, name: `${cKey}Query`, zh: `${zhKey}列表查询` },
+  { method: 'get', path: `/${rKey}/:id`, controller: `${cKey}.show`, name: `${cKey}Show`, zh: `${zhKey}查询` },
+  { method: 'post', path: `/${rKey}`, controller: `${cKey}.create`, name: `${cKey}Create`, zh: `创建${zhKey}` },
+  { method: 'post', path: `/${rKey}/:id`, controller: `${cKey}.update`, name: `${cKey}Update`, zh: `修改${zhKey}` },
+  { method: 'delete', path: `/${rKey}/:id`, controller: `${cKey}.destroy`, name: `${cKey}Delete`, zh: `删除${zhKey}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]());
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};

+ 28 - 0
app/z_router/dicttype.js

@@ -0,0 +1,28 @@
+'use strict';
+// 测试接口
+const rKey = 'dicttype'; // routerKey,路由前缀变量
+const cKey = 'dicttype'; // controllerKey,controller名
+const zhKey = '字典类型表';
+const routes = [
+  { method: 'get', path: `/${rKey}`, controller: `${cKey}.index`, name: `${cKey}Query`, zh: `${zhKey}列表查询` },
+  { method: 'get', path: `/${rKey}/:id`, controller: `${cKey}.show`, name: `${cKey}Show`, zh: `${zhKey}查询` },
+  { method: 'post', path: `/${rKey}`, controller: `${cKey}.create`, name: `${cKey}Create`, zh: `创建${zhKey}` },
+  { method: 'post', path: `/${rKey}/:id`, controller: `${cKey}.update`, name: `${cKey}Update`, zh: `修改${zhKey}` },
+  { method: 'delete', path: `/${rKey}/:id`, controller: `${cKey}.destroy`, name: `${cKey}Delete`, zh: `删除${zhKey}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]());
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};

+ 28 - 0
app/z_router/leavemess.js

@@ -0,0 +1,28 @@
+'use strict';
+// 测试接口
+const rKey = 'leavemess'; // routerKey,路由前缀变量
+const cKey = 'leavemess'; // controllerKey,controller名
+const zhKey = '留言';
+const routes = [
+  { method: 'get', path: `/${rKey}`, controller: `${cKey}.index`, name: `${cKey}Query`, zh: `${zhKey}列表查询` },
+  { method: 'get', path: `/${rKey}/:id`, controller: `${cKey}.show`, name: `${cKey}Show`, zh: `${zhKey}查询` },
+  { method: 'post', path: `/${rKey}`, controller: `${cKey}.create`, name: `${cKey}Create`, zh: `创建${zhKey}` },
+  { method: 'post', path: `/${rKey}/:id`, controller: `${cKey}.update`, name: `${cKey}Update`, zh: `修改${zhKey}` },
+  { method: 'delete', path: `/${rKey}/:id`, controller: `${cKey}.destroy`, name: `${cKey}Delete`, zh: `删除${zhKey}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]());
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};

+ 28 - 0
app/z_router/news.js

@@ -0,0 +1,28 @@
+'use strict';
+// 测试接口
+const rKey = 'news'; // routerKey,路由前缀变量
+const cKey = 'news'; // controllerKey,controller名
+const zhKey = '新闻资讯';
+const routes = [
+  { method: 'get', path: `/${rKey}`, controller: `${cKey}.index`, name: `${cKey}Query`, zh: `${zhKey}列表查询` },
+  { method: 'get', path: `/${rKey}/:id`, controller: `${cKey}.show`, name: `${cKey}Show`, zh: `${zhKey}查询` },
+  { method: 'post', path: `/${rKey}`, controller: `${cKey}.create`, name: `${cKey}Create`, zh: `创建${zhKey}` },
+  { method: 'post', path: `/${rKey}/:id`, controller: `${cKey}.update`, name: `${cKey}Update`, zh: `修改${zhKey}` },
+  { method: 'delete', path: `/${rKey}/:id`, controller: `${cKey}.destroy`, name: `${cKey}Delete`, zh: `删除${zhKey}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]());
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};