From 420b90cd27ea932f64b25f3394967fd532cca186 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 12 Aug 2020 17:57:02 +0800
Subject: [PATCH] 20200812 帮助中心
---
src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterTypeEntity.java | 35 +
src/main/resources/mapper/modules/HelpCenterTypeMapper.xml | 13
src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdate.html | 104 +++++
src/main/java/com/xcong/excoin/modules/helpCenter/service/impl/HelpCenterServiceImpl.java | 181 +++++++++
src/main/java/com/xcong/excoin/common/utils/SpringContextHolder.java | 59 ++
src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterArticleMapper.java | 8
src/main/java/com/xcong/excoin/modules/helpCenter/dto/Base64UploadDto.java | 17
pom.xml | 6
src/main/java/com/xcong/excoin/modules/helpCenter/controller/ViewController.java | 64 +++
src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdateUs.html | 103 +++++
src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterNoticeMapper.java | 15
src/main/resources/mapper/modules/HelpCenterNoticeMapper.xml | 9
src/main/java/com/xcong/excoin/modules/helpCenter/controller/HelpCenterController.java | 133 ++++++
src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterNoticeEntity.java | 58 ++
src/main/java/com/xcong/excoin/modules/helpCenter/service/HelpCenterService.java | 29 +
src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterTypeMapper.java | 8
src/main/java/com/xcong/excoin/common/utils/OssUtils.java | 35 +
src/main/java/com/xcong/excoin/modules/helpCenter/dto/AliOssProperties.java | 20 +
src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterArticleEntity.java | 43 ++
src/main/resources/mapper/modules/HelpCenterArticleMapper.xml | 13
src/main/resources/templates/febs/views/modules/helpCenter/helpCenterAdd.html | 79 +++
src/main/resources/templates/febs/views/modules/helpCenter/helpCenterList.html | 152 +++++++
22 files changed, 1,184 insertions(+), 0 deletions(-)
diff --git a/pom.xml b/pom.xml
index 215cd73..7f8a919 100644
--- a/pom.xml
+++ b/pom.xml
@@ -23,9 +23,15 @@
<swagger.ui>2.9.2</swagger.ui>
<tomcat.version>9.0.31</tomcat.version>
<hutool.version>5.3.1</hutool.version>
+ <aliyun-oss.version>3.8.0</aliyun-oss.version>
</properties>
<dependencies>
+ <dependency>
+ <groupId>com.aliyun.oss</groupId>
+ <artifactId>aliyun-sdk-oss</artifactId>
+ <version>${aliyun-oss.version}</version>
+ </dependency>
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
diff --git a/src/main/java/com/xcong/excoin/common/utils/OssUtils.java b/src/main/java/com/xcong/excoin/common/utils/OssUtils.java
new file mode 100644
index 0000000..cf9de91
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/common/utils/OssUtils.java
@@ -0,0 +1,35 @@
+package com.xcong.excoin.common.utils;
+
+import java.io.ByteArrayInputStream;
+import com.aliyun.oss.OSS;
+import com.aliyun.oss.OSSClientBuilder;
+
+import sun.misc.BASE64Decoder;
+
+import lombok.extern.slf4j.Slf4j;
+
+@Slf4j
+public class OssUtils {
+
+ private static String END_POINT = "https://oss-cn-hangzhou.aliyuncs.com";
+ private static String ACCESS_KEY_ID = "LTAI4GBuydqbJ5bTsDP97Lpd";
+ private static String ACCESS_KEY_SECRET = "vbCjQtPxABWjqtUlQfzjlA0qAY96fh";
+ private static String bucket_name = "https://excoin.oss-cn-hangzhou.aliyuncs.com";
+
+ public static boolean uploadFileWithBase64(String base64, String pathName) {
+ ByteArrayInputStream stream = null;
+ try {
+ OSS ossClient = new OSSClientBuilder().build(END_POINT, ACCESS_KEY_ID,ACCESS_KEY_SECRET);
+ BASE64Decoder decoder = new BASE64Decoder();
+ byte[] bytes = decoder.decodeBuffer(base64);
+ stream = new ByteArrayInputStream(bytes);
+ ossClient.putObject("excoin", pathName, stream);
+ return true;
+ } catch (Exception e) {
+ log.error("#上传失败:{}#", e);
+ return false;
+ }
+ }
+
+
+}
diff --git a/src/main/java/com/xcong/excoin/common/utils/SpringContextHolder.java b/src/main/java/com/xcong/excoin/common/utils/SpringContextHolder.java
new file mode 100644
index 0000000..c4cf12c
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/common/utils/SpringContextHolder.java
@@ -0,0 +1,59 @@
+package com.xcong.excoin.common.utils;
+import org.springframework.beans.BeansException;
+import org.springframework.beans.factory.DisposableBean;
+import org.springframework.context.ApplicationContext;
+import org.springframework.context.ApplicationContextAware;
+import org.springframework.stereotype.Component;
+
+import lombok.extern.slf4j.Slf4j;
+@Component
+@Slf4j
+public class SpringContextHolder implements ApplicationContextAware, DisposableBean {
+
+ private static ApplicationContext applicationContext = null;
+
+ /**
+ * 从静态变量applicationContext中取得Bean, 自动转型为所赋值对象的类型.
+ */
+ @SuppressWarnings("unchecked")
+ public static <T> T getBean(String name) {
+ assertContextInjected();
+ return (T) applicationContext.getBean(name);
+ }
+
+ /**
+ * 从静态变量applicationContext中取得Bean, 自动转型为所赋值对象的类型.
+ */
+ public static <T> T getBean(Class<T> requiredType) {
+ assertContextInjected();
+ return applicationContext.getBean(requiredType);
+ }
+
+ private static void assertContextInjected() {
+ if (applicationContext == null) {
+ throw new IllegalStateException("applicaitonContext属性未注入, 请在applicationContext" +
+ ".xml中定义SpringContextHolder或在SpringBoot启动类中注册SpringContextHolder.");
+ }
+ }
+
+ /**
+ * 检查ApplicationContext不为空.
+ */
+ private static void clearHolder() {
+ log.debug("清除SpringContextHolder中的ApplicationContext:" + applicationContext);
+ applicationContext = null;
+ }
+
+ @Override
+ public void destroy() throws Exception {
+ SpringContextHolder.clearHolder();
+ }
+
+ @Override
+ public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
+ if (SpringContextHolder.applicationContext != null) {
+ log.warn("SpringContextHolder中的ApplicationContext被覆盖, 原有ApplicationContext为:" + SpringContextHolder.applicationContext);
+ }
+ SpringContextHolder.applicationContext = applicationContext;
+ }
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/controller/HelpCenterController.java b/src/main/java/com/xcong/excoin/modules/helpCenter/controller/HelpCenterController.java
new file mode 100644
index 0000000..b33fbc3
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/controller/HelpCenterController.java
@@ -0,0 +1,133 @@
+package com.xcong.excoin.modules.helpCenter.controller;
+
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.validation.Valid;
+import javax.validation.constraints.NotNull;
+
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.multipart.MultipartFile;
+
+import com.xcong.excoin.common.annotation.ControllerEndpoint;
+import com.xcong.excoin.common.controller.BaseController;
+import com.xcong.excoin.common.entity.FebsResponse;
+import com.xcong.excoin.common.entity.QueryRequest;
+import com.xcong.excoin.common.utils.OssUtils;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterArticleEntity;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterNoticeEntity;
+import com.xcong.excoin.modules.helpCenter.service.HelpCenterService;
+import sun.misc.BASE64Encoder;
+
+import cn.hutool.core.util.IdUtil;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+
+@Slf4j
+@Validated
+@RestController
+@RequiredArgsConstructor
+@RequestMapping(value = "/helpCenter")
+public class HelpCenterController extends BaseController {
+
+ private final HelpCenterService helpCenterService;
+
+ /**
+ * 帮助中心---列表
+ * @return
+ */
+ @GetMapping("getHelpCenterList")
+ public FebsResponse getHelpCenterList(HelpCenterNoticeEntity helpCenterNoticeEntity, QueryRequest request) {
+ Map<String, Object> data = getDataTable(helpCenterService.findHelpCenterListInPage(helpCenterNoticeEntity, request));
+ return new FebsResponse().success().data(data);
+ }
+
+ /**
+ * 帮助中心---删除公告
+ * @param id
+ * @return
+ */
+ @GetMapping("helpCenterDelete/{id}")
+ @ControllerEndpoint(operation = "删除公告", exceptionMessage = "删除失败")
+ public FebsResponse helpCenterDelete(@NotNull(message = "{required}") @PathVariable Long id) {
+ return helpCenterService.helpCenterDelete(id);
+ }
+
+ /**
+ * 帮助中心---新增
+ */
+ @PostMapping("helpCenterAdds")
+ @ControllerEndpoint(operation = " 帮助中心---新增", exceptionMessage = "新增失败")
+ public FebsResponse helpCenterAdds(@Valid HelpCenterNoticeEntity helpCenterNoticeEntity) {
+ helpCenterService.helpCenterAdds(helpCenterNoticeEntity);
+ return new FebsResponse().success();
+ }
+
+ /**
+ * 帮助中心---中文确认
+ * @return
+ */
+ @PostMapping("helpCenterConfirm")
+ @ControllerEndpoint(operation = "帮助中心---确认", exceptionMessage = "设置失败")
+ public FebsResponse helpCenterConfirm(@Valid HelpCenterArticleEntity helpCenterArticleEntity) {
+ return helpCenterService.helpCenterConfirm(helpCenterArticleEntity);
+ }
+
+ /**
+ * 帮助中心---英文确认
+ * @return
+ */
+ @PostMapping("helpCenterUsConfirm")
+ @ControllerEndpoint(operation = "帮助中心---确认", exceptionMessage = "设置失败")
+ public FebsResponse helpCenterUsConfirm(@Valid HelpCenterArticleEntity helpCenterArticleEntity) {
+ return helpCenterService.helpCenterUsConfirm(helpCenterArticleEntity);
+ }
+
+ /**
+ * 帮助中心---图片上传
+ * @param uploadDto
+ * @return
+ */
+ @PostMapping(value = "/uploadFileBase64")
+ @ControllerEndpoint(operation = "帮助中心---图片上传", exceptionMessage = "上传失败")
+ public Map<String,Object> uploadFileBase64(@RequestBody @Validated MultipartFile file) {
+ if (file.isEmpty()) {
+ new FebsResponse().message("上传文件为空");
+ }
+
+ //文件加密
+ BASE64Encoder base64Encoder =new BASE64Encoder();
+ String base64EncoderImg = null;
+ try {
+ base64EncoderImg = base64Encoder.encode(file.getBytes());
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+
+ String imageFuffix = ".jpg";
+ String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID() + imageFuffix;
+ String imageName = "uploadeFile/image/" + imageNames;
+ OssUtils.uploadFileWithBase64(base64EncoderImg, imageName);
+ String bucket_name ="https://excoin.oss-cn-hangzhou.aliyuncs.com";
+ String url = bucket_name + "/" + imageName;
+
+ Map<String,Object> map = new HashMap<String,Object>();
+ Map<String,Object> map2 = new HashMap<String,Object>();
+ map.put("code",0);//0表示成功,1失败
+ map.put("msg","上传成功");//提示消息
+ map.put("data",map2);
+ map2.put("src",url);//图片url
+ map2.put("title",imageNames);//图片名称,这个会显示在输入框里
+ return map;
+ }
+
+
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/controller/ViewController.java b/src/main/java/com/xcong/excoin/modules/helpCenter/controller/ViewController.java
new file mode 100644
index 0000000..650f4c4
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/controller/ViewController.java
@@ -0,0 +1,64 @@
+package com.xcong.excoin.modules.helpCenter.controller;
+
+import org.apache.shiro.authz.annotation.RequiresPermissions;
+import org.springframework.stereotype.Controller;
+import org.springframework.ui.Model;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.RequestMapping;
+
+import com.xcong.excoin.common.entity.FebsConstant;
+import com.xcong.excoin.common.utils.FebsUtil;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterArticleEntity;
+import com.xcong.excoin.modules.helpCenter.service.HelpCenterService;
+
+import lombok.RequiredArgsConstructor;
+
+@Controller("helpCenterView")
+@RequestMapping(FebsConstant.VIEW_PREFIX + "modules/helpCenter")
+@RequiredArgsConstructor
+public class ViewController {
+
+ private final HelpCenterService helpCenterService;
+
+ /**
+ * 帮助中心---列表
+ * @return
+ */
+ @GetMapping("helpCenterList")
+ @RequiresPermissions("helpCenterList:view")
+ public String traderUpdate() {
+ return FebsUtil.view("modules/helpCenter/helpCenterList");
+ }
+
+ /**
+ * 帮助中心---中文版修改
+ */
+ @GetMapping("helpCenterUpdate/{id}")
+ @RequiresPermissions("helpCenterUpdate:update")
+ public String helpCenterUpdate(@PathVariable long id, Model model) {
+ HelpCenterArticleEntity data = helpCenterService.selectHelpCenterServiceById(id);
+ model.addAttribute("member", data);
+ return FebsUtil.view("modules/helpCenter/helpCenterUpdate");
+ }
+ /**
+ * 帮助中心---英文版修改
+ */
+ @GetMapping("helpCenterUpdateUs/{id}")
+ @RequiresPermissions("helpCenterUpdateUs:update")
+ public String helpCenterUpdateUs(@PathVariable long id, Model model) {
+ HelpCenterArticleEntity data = helpCenterService.selectHelpCenterUsServiceById(id);
+ model.addAttribute("member", data);
+ return FebsUtil.view("modules/helpCenter/helpCenterUpdateUs");
+ }
+
+ /**
+ * 帮助中心---新增
+ */
+ @GetMapping("helpCenterAdd")
+ @RequiresPermissions("helpCenterAdd:add")
+ public String helpCenterAdd() {
+ return FebsUtil.view("modules/helpCenter/helpCenterAdd");
+ }
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/dto/AliOssProperties.java b/src/main/java/com/xcong/excoin/modules/helpCenter/dto/AliOssProperties.java
new file mode 100644
index 0000000..f766e9c
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/dto/AliOssProperties.java
@@ -0,0 +1,20 @@
+package com.xcong.excoin.modules.helpCenter.dto;
+
+import org.springframework.boot.context.properties.ConfigurationProperties;
+import org.springframework.context.annotation.Configuration;
+
+import lombok.Data;
+
+@Data
+@Configuration
+@ConfigurationProperties(prefix = "aliyun.oss")
+public class AliOssProperties {
+ private String endPoint;
+
+ private String bucketName;
+
+ private String accessKeyId;
+
+ private String accessKeySecret;
+}
+
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/dto/Base64UploadDto.java b/src/main/java/com/xcong/excoin/modules/helpCenter/dto/Base64UploadDto.java
new file mode 100644
index 0000000..d69f845
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/dto/Base64UploadDto.java
@@ -0,0 +1,17 @@
+package com.xcong.excoin.modules.helpCenter.dto;
+
+import javax.validation.constraints.NotBlank;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "Base64UploadDto", description = "base64文件上传参数类")
+public class Base64UploadDto {
+
+ @NotBlank
+ @ApiModelProperty(value = "base64字符串")
+ public String base64Str;
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterArticleEntity.java b/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterArticleEntity.java
new file mode 100644
index 0000000..8edd3d0
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterArticleEntity.java
@@ -0,0 +1,43 @@
+package com.xcong.excoin.modules.helpCenter.entity;
+
+import java.util.Date;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.fasterxml.jackson.annotation.JsonFormat;
+
+import lombok.Data;
+
+/**
+ * 文章内容
+ */
+@Data
+@TableName("help_center_article")
+public class HelpCenterArticleEntity {
+
+ @TableId(value = "id",type = IdType.AUTO)
+ private Long id;
+ /**
+ * 创建者
+ */
+ private String createBy;
+ /**
+ * 创建时间
+ */
+ @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
+ private Date createTime;
+ /**
+ * 语言类型(1:简体中文2:英文)
+ */
+ private int typeLanguage;
+ /**
+ * 标题
+ */
+ private String title;
+ /**
+ * 内容
+ */
+ private String content;
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterNoticeEntity.java b/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterNoticeEntity.java
new file mode 100644
index 0000000..a9464a0
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterNoticeEntity.java
@@ -0,0 +1,58 @@
+package com.xcong.excoin.modules.helpCenter.entity;
+
+import java.util.Date;
+
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.fasterxml.jackson.annotation.JsonFormat;
+
+import lombok.Data;
+
+/**
+ * 帮助中心公告
+ */
+@Data
+@TableName("help_center_notice")
+public class HelpCenterNoticeEntity {
+
+ @TableId(value = "id",type = IdType.AUTO)
+ private Long id;
+ /**
+ * 创建者
+ */
+ private String createBy;
+ /**
+ * 创建时间
+ */
+ @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
+ private Date createTime;
+ /**
+ * 所属类别(1:最新公告2:重要公告)
+ */
+ private int articleNotice;
+ /**
+ * 文章id
+ */
+ private Long articleId;
+ /**
+ *文章标题
+ */
+ private String articleTitle;
+ /**
+ * 文章id
+ */
+ private Long articleIdUs;
+ /**
+ *文章标题
+ */
+ private String articleTitleUs;
+
+ @TableField(exist = false)
+ private String createTimeString;
+
+
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterTypeEntity.java b/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterTypeEntity.java
new file mode 100644
index 0000000..c3744bc
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/entity/HelpCenterTypeEntity.java
@@ -0,0 +1,35 @@
+package com.xcong.excoin.modules.helpCenter.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+
+import lombok.Data;
+
+/**
+ * 帮助中心类别
+ */
+@Data
+@TableName("help_center_type")
+public class HelpCenterTypeEntity {
+
+ @TableId(value = "id",type = IdType.AUTO)
+ private Long id;
+ /**
+ * 所属类别(1:公告类型2:语言类型)
+ */
+ private int status;
+ /**
+ * 类型标识
+ */
+ private int type;
+ /**
+ * 语言类型(1:简体中文2:英文)
+ */
+ private int typeLanguage;
+ /**
+ *类型内容
+ */
+ private String content;
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterArticleMapper.java b/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterArticleMapper.java
new file mode 100644
index 0000000..e072a5b
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterArticleMapper.java
@@ -0,0 +1,8 @@
+package com.xcong.excoin.modules.helpCenter.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterArticleEntity;
+
+public interface HelpCenterArticleMapper extends BaseMapper<HelpCenterArticleEntity> {
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterNoticeMapper.java b/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterNoticeMapper.java
new file mode 100644
index 0000000..207cff3
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterNoticeMapper.java
@@ -0,0 +1,15 @@
+package com.xcong.excoin.modules.helpCenter.mapper;
+
+import org.apache.ibatis.annotations.Param;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterNoticeEntity;
+
+public interface HelpCenterNoticeMapper extends BaseMapper<HelpCenterNoticeEntity> {
+
+ IPage<HelpCenterNoticeEntity> findHelpCenterListInPage(Page<HelpCenterNoticeEntity> page,
+ @Param("record") HelpCenterNoticeEntity helpCenterNoticeEntity);
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterTypeMapper.java b/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterTypeMapper.java
new file mode 100644
index 0000000..7638679
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/mapper/HelpCenterTypeMapper.java
@@ -0,0 +1,8 @@
+package com.xcong.excoin.modules.helpCenter.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterTypeEntity;
+
+public interface HelpCenterTypeMapper extends BaseMapper<HelpCenterTypeEntity> {
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/service/HelpCenterService.java b/src/main/java/com/xcong/excoin/modules/helpCenter/service/HelpCenterService.java
new file mode 100644
index 0000000..06f8f1c
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/service/HelpCenterService.java
@@ -0,0 +1,29 @@
+package com.xcong.excoin.modules.helpCenter.service;
+
+import javax.validation.Valid;
+import javax.validation.constraints.NotNull;
+
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.xcong.excoin.common.entity.FebsResponse;
+import com.xcong.excoin.common.entity.QueryRequest;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterArticleEntity;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterNoticeEntity;
+
+public interface HelpCenterService extends IService<HelpCenterNoticeEntity> {
+
+ IPage<HelpCenterNoticeEntity> findHelpCenterListInPage(HelpCenterNoticeEntity helpCenterNoticeEntity, QueryRequest request);
+
+ FebsResponse helpCenterDelete(@NotNull(message = "{required}") Long id);
+
+ HelpCenterArticleEntity selectHelpCenterServiceById(long id);
+
+ HelpCenterArticleEntity selectHelpCenterUsServiceById(long id);
+
+ void helpCenterAdds(@Valid HelpCenterNoticeEntity helpCenterNoticeEntity);
+
+ FebsResponse helpCenterConfirm(@Valid HelpCenterArticleEntity helpCenterArticleEntity);
+
+ FebsResponse helpCenterUsConfirm(@Valid HelpCenterArticleEntity helpCenterArticleEntity);
+
+}
diff --git a/src/main/java/com/xcong/excoin/modules/helpCenter/service/impl/HelpCenterServiceImpl.java b/src/main/java/com/xcong/excoin/modules/helpCenter/service/impl/HelpCenterServiceImpl.java
new file mode 100644
index 0000000..379a13f
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/helpCenter/service/impl/HelpCenterServiceImpl.java
@@ -0,0 +1,181 @@
+package com.xcong.excoin.modules.helpCenter.service.impl;
+
+
+import java.text.SimpleDateFormat;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import javax.validation.Valid;
+import javax.validation.constraints.NotNull;
+
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.xcong.excoin.common.entity.FebsResponse;
+import com.xcong.excoin.common.entity.QueryRequest;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterArticleEntity;
+import com.xcong.excoin.modules.helpCenter.entity.HelpCenterNoticeEntity;
+import com.xcong.excoin.modules.helpCenter.mapper.HelpCenterArticleMapper;
+import com.xcong.excoin.modules.helpCenter.mapper.HelpCenterNoticeMapper;
+import com.xcong.excoin.modules.helpCenter.service.HelpCenterService;
+
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.ObjectUtil;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+
+@Slf4j
+@Service
+@RequiredArgsConstructor
+public class HelpCenterServiceImpl extends ServiceImpl<HelpCenterNoticeMapper, HelpCenterNoticeEntity> implements HelpCenterService {
+
+ private final HelpCenterNoticeMapper helpCenterNoticeMapper;
+
+ private final HelpCenterArticleMapper helpCenterArticleMapper;
+
+ @Override
+ public IPage<HelpCenterNoticeEntity> findHelpCenterListInPage(HelpCenterNoticeEntity helpCenterNoticeEntity,
+ QueryRequest request) {
+ Page<HelpCenterNoticeEntity> page = new Page<>(request.getPageNum(), request.getPageSize());
+ IPage<HelpCenterNoticeEntity> helpCenterNoticeEntitys = helpCenterNoticeMapper.findHelpCenterListInPage(page, helpCenterNoticeEntity);
+ return helpCenterNoticeEntitys;
+ }
+
+ @Override
+ @Transactional
+ public FebsResponse helpCenterDelete(@NotNull(message = "{required}") Long id) {
+
+ HelpCenterNoticeEntity helpCenterNoticeEntity = helpCenterNoticeMapper.selectById(id);
+ if(ObjectUtil.isEmpty(helpCenterNoticeEntity)) {
+ return new FebsResponse().fail().message("该公告不存在");
+ }
+ Long articleId = helpCenterNoticeEntity.getArticleId();
+ if(ObjectUtil.isNotEmpty(articleId)) {
+ helpCenterArticleMapper.deleteById(articleId);
+ }
+ Long articleIdUs = helpCenterNoticeEntity.getArticleIdUs();
+ if(ObjectUtil.isNotEmpty(articleId)) {
+ helpCenterArticleMapper.deleteById(articleIdUs);
+ }
+
+ helpCenterNoticeMapper.deleteById(id);
+ return new FebsResponse().success();
+ }
+
+ @Override
+ public HelpCenterArticleEntity selectHelpCenterServiceById(long id) {
+ HelpCenterNoticeEntity helpCenterNoticeEntity = helpCenterNoticeMapper.selectById(id);
+ Long articleId = helpCenterNoticeEntity.getArticleId();
+ HelpCenterArticleEntity selectById = helpCenterArticleMapper.selectById(articleId);
+ return selectById;
+ }
+
+ @Override
+ public HelpCenterArticleEntity selectHelpCenterUsServiceById(long id) {
+ HelpCenterNoticeEntity helpCenterNoticeEntity = helpCenterNoticeMapper.selectById(id);
+ Long articleId = helpCenterNoticeEntity.getArticleIdUs();
+ HelpCenterArticleEntity selectById = helpCenterArticleMapper.selectById(articleId);
+ return selectById;
+ }
+
+ @Override
+ @Transactional
+ public void helpCenterAdds(@Valid HelpCenterNoticeEntity helpCenterNoticeEntity) {
+ //新增【文章内容】
+ HelpCenterArticleEntity helpCenterArticleEntity = new HelpCenterArticleEntity();
+ helpCenterArticleEntity.setCreateBy(helpCenterNoticeEntity.getCreateBy());
+
+ Date date = new Date();
+ try {
+ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+ date = sdf.parse(helpCenterNoticeEntity.getCreateTimeString());
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ helpCenterArticleEntity.setCreateTime(date);
+ helpCenterArticleEntity.setTypeLanguage(1);
+ helpCenterArticleMapper.insert(helpCenterArticleEntity);
+ Long articleId = helpCenterArticleEntity.getId();
+
+ helpCenterArticleEntity.setTypeLanguage(2);
+ helpCenterArticleMapper.insert(helpCenterArticleEntity);
+ Long articleIdUs = helpCenterArticleEntity.getId();
+
+ HelpCenterNoticeEntity helpCenterNotice = new HelpCenterNoticeEntity();
+ helpCenterNotice.setCreateBy(helpCenterNoticeEntity.getCreateBy());
+ helpCenterNotice.setCreateTime(date);
+ helpCenterNotice.setArticleNotice(helpCenterNoticeEntity.getArticleNotice());
+ helpCenterNotice.setArticleId(articleId);
+ helpCenterNotice.setArticleTitle(helpCenterNoticeEntity.getArticleTitle() == null ? "":helpCenterNoticeEntity.getArticleTitle());
+ helpCenterNotice.setArticleIdUs(articleIdUs);
+ helpCenterNotice.setArticleTitleUs(helpCenterNoticeEntity.getArticleTitleUs() == null ? "":helpCenterNoticeEntity.getArticleTitleUs());
+ helpCenterNoticeMapper.insert(helpCenterNotice);
+ }
+
+ @Override
+ @Transactional
+ public FebsResponse helpCenterConfirm(@Valid HelpCenterArticleEntity helpCenterArticleEntity) {
+
+ Long id = helpCenterArticleEntity.getId();
+ HelpCenterArticleEntity selectById = helpCenterArticleMapper.selectById(id);
+ selectById.setContent(helpCenterArticleEntity.getContent());
+ selectById.setTitle(helpCenterArticleEntity.getTitle());
+ helpCenterArticleMapper.updateById(selectById);
+
+ Map<String, Object> columnMap = new HashMap<String, Object>();
+ columnMap.put("article_id", id);
+ List<HelpCenterNoticeEntity> selectByMap = helpCenterNoticeMapper.selectByMap(columnMap);
+ if(CollUtil.isNotEmpty(selectByMap)) {
+ HelpCenterNoticeEntity helpCenterNoticeEntity = selectByMap.get(0);
+ String title = selectById.getTitle();
+ helpCenterNoticeEntity.setArticleTitle(title);
+ helpCenterNoticeMapper.updateById(helpCenterNoticeEntity);
+ }
+ return new FebsResponse().success();
+ }
+
+ @Override
+ @Transactional
+ public FebsResponse helpCenterUsConfirm(@Valid HelpCenterArticleEntity helpCenterArticleEntity) {
+
+ Long id = helpCenterArticleEntity.getId();
+ HelpCenterArticleEntity selectById = helpCenterArticleMapper.selectById(id);
+ selectById.setContent(helpCenterArticleEntity.getContent());
+ selectById.setTitle(helpCenterArticleEntity.getTitle());
+ helpCenterArticleMapper.updateById(selectById);
+
+ Map<String, Object> columnMap = new HashMap<String, Object>();
+ columnMap.put("article_id_us", id);
+ List<HelpCenterNoticeEntity> selectByMap = helpCenterNoticeMapper.selectByMap(columnMap);
+ if(CollUtil.isNotEmpty(selectByMap)) {
+ HelpCenterNoticeEntity helpCenterNoticeEntity = selectByMap.get(0);
+ String title = selectById.getTitle();
+ helpCenterNoticeEntity.setArticleTitleUs(title);
+ helpCenterNoticeMapper.updateById(helpCenterNoticeEntity);
+ }
+ return new FebsResponse().success();
+ }
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+}
diff --git a/src/main/resources/mapper/modules/HelpCenterArticleMapper.xml b/src/main/resources/mapper/modules/HelpCenterArticleMapper.xml
new file mode 100644
index 0000000..2b598e0
--- /dev/null
+++ b/src/main/resources/mapper/modules/HelpCenterArticleMapper.xml
@@ -0,0 +1,13 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.xcong.excoin.modules.helpCenter.mapper.HelpCenterArticleMapper">
+
+
+ <select id="findPlatformTradeSettingInPage" resultType="com.xcong.excoin.modules.systemSetting.entity.PlatformTradeSettingEntity">
+ SELECT
+ *
+ FROM
+ platform_trade_setting
+ </select>
+
+</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/HelpCenterNoticeMapper.xml b/src/main/resources/mapper/modules/HelpCenterNoticeMapper.xml
new file mode 100644
index 0000000..8225006
--- /dev/null
+++ b/src/main/resources/mapper/modules/HelpCenterNoticeMapper.xml
@@ -0,0 +1,9 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.xcong.excoin.modules.helpCenter.mapper.HelpCenterNoticeMapper">
+
+ <select id="findHelpCenterListInPage" resultType="com.xcong.excoin.modules.helpCenter.entity.HelpCenterNoticeEntity">
+ select * from help_center_notice order by create_time desc
+ </select>
+
+</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/HelpCenterTypeMapper.xml b/src/main/resources/mapper/modules/HelpCenterTypeMapper.xml
new file mode 100644
index 0000000..6f36fb9
--- /dev/null
+++ b/src/main/resources/mapper/modules/HelpCenterTypeMapper.xml
@@ -0,0 +1,13 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.xcong.excoin.modules.helpCenter.mapper.HelpCenterTypeMapper">
+
+
+ <select id="findPlatformTradeSettingInPage" resultType="com.xcong.excoin.modules.systemSetting.entity.PlatformTradeSettingEntity">
+ SELECT
+ *
+ FROM
+ platform_trade_setting
+ </select>
+
+</mapper>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterAdd.html b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterAdd.html
new file mode 100644
index 0000000..8862b18
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterAdd.html
@@ -0,0 +1,79 @@
+<style>
+ #user-add {
+ padding: 20px 25px 25px 0;
+ }
+
+ #user-add .layui-treeSelect .ztree li a, .ztree li span {
+ margin: 0 0 2px 3px !important;
+ }
+ #user-add #data-permission-tree-block {
+ border: 1px solid #eee;
+ border-radius: 2px;
+ padding: 3px 0;
+ }
+ #user-add .layui-treeSelect .ztree li span.button.switch {
+ top: 1px;
+ left: 3px;
+ }
+
+</style>
+<div class="layui-fluid" id="user-add">
+ <form class="layui-form" action="" lay-filter="user-add-form">
+ <div class="layui-form-item">
+ <label class="layui-form-label febs-form-item-require">创建者:</label>
+ <div class="layui-input-block">
+ <input type="text" name="createBy" minlength="4" maxlength="10"
+ lay-verify="range|createBy" autocomplete="off" class="layui-input" >
+ </div>
+ </div>
+ <div class="layui-form-item">
+ <label class="layui-form-label febs-form-item-require">所属类别:</label>
+ <div class="layui-input-block">
+ <input type="radio" name="articleNotice" value="1" title="最新公告" checked="">
+ <input type="radio" name="articleNotice" value="2" title="重要公告">
+ </div>
+ </div>
+ <div class="layui-inline">
+ <label class="layui-form-label febs-form-item-require">创建时间:</label>
+ <div class="layui-input-inline">
+ <input type="text" name="createTimeString" id="febs-form-group-date"
+ lay-verify="date" placeholder="yyyy-MM-dd" autocomplete="off" class="layui-input">
+ </div>
+ </div>
+ <div class="layui-form-item febs-hide">
+ <button class="layui-btn" lay-submit="" lay-filter="user-add-form-submit" id="submit"></button>
+ </div>
+ </form>
+</div>
+
+<script data-th-inline="javascript">
+layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree', 'laydate'], function () {
+ var $ = layui.$,
+ febs = layui.febs,
+ layer = layui.layer,
+ formSelects = layui.formSelects,
+ treeSelect = layui.treeSelect,
+ form = layui.form,
+ laydate = layui.laydate,
+ eleTree = layui.eleTree,
+ member = [[${member}]],
+ $view = $('#user-add'),
+ validate = layui.validate;
+
+ form.render();
+ laydate.render({
+ elem: '#febs-form-group-date'
+ });
+
+ formSelects.render();
+
+ form.on('submit(user-add-form-submit)', function (data) {
+ febs.post(ctx + 'helpCenter/helpCenterAdds', data.field, function () {
+ layer.closeAll();
+ febs.alert.success('新增成功');
+ $('#febs-user').find('#reset').click();
+ });
+ return false;
+ });
+ });
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterList.html b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterList.html
new file mode 100644
index 0000000..3ea5194
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterList.html
@@ -0,0 +1,152 @@
+<div class="layui-fluid layui-anim febs-anim" id="febs-user" lay-title="帮助中心">
+ <div class="layui-row febs-container">
+ <div class="layui-col-md12">
+ <div class="layui-card">
+ <div class="layui-card-body febs-table-full">
+ <form class="layui-form layui-table-form" lay-filter="user-table-form">
+ <div class="layui-row">
+ <div class="layui-col-md2 layui-col-sm12 layui-col-xs12 table-action-area">
+ <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="add">
+ 新增
+ </div>
+ <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset">
+ <i class="layui-icon"></i>
+ </div>
+ </div>
+ </div>
+ </form>
+ <table lay-filter="userTable" lay-data="{id: 'userTable'}"></table>
+ </div>
+ </div>
+ </div>
+ </div>
+</div>
+
+<!-- 表格操作栏 start -->
+<script type="text/html" id="user-option">
+ <span shiro:lacksPermission="user:view,user:update,user:delete">
+ <span class="layui-badge-dot febs-bg-orange"></span> 无权限
+ </span>
+ <a lay-event="edit" shiro:hasPermission="user:update">编辑
+ <i class="layui-icon febs-edit-area febs-blue"></i>
+ </a>
+ <a lay-event="delete" shiro:hasPermission="user:update">删除
+ <i class="layui-icon febs-edit-area febs-blue"></i>
+ </a>
+</script>
+<!-- 表格操作栏 end -->
+<script data-th-inline="none" type="text/javascript">
+ // 引入组件并初始化
+ layui.use(['jquery', 'form', 'table', 'febs'], function () {
+ var $ = layui.jquery,
+ febs = layui.febs,
+ form = layui.form,
+ table = layui.table,
+ $view = $('#febs-user'),
+ $add = $view.find('#add'),
+ $reset = $view.find('#reset'),
+ $searchForm = $view.find('form'),
+ tableIns
+ ;
+
+ form.render();
+
+ // 表格初始化
+ initTable();
+
+ // 初始化表格操作栏各个按钮功能
+ table.on('tool(userTable)', function (obj) {
+ var data = obj.data,
+ layEvent = obj.event;
+
+ if (layEvent === 'editCN') {
+ febs.modal.open('中文版', 'modules/helpCenter/helpCenterUpdate/' + data.id, {
+ btn: ['提交', '取消'],
+ yes: function (index, layero) {
+ $('#user-update').find('#submit').trigger('click');
+ },
+ btn2: function () {
+ layer.closeAll();
+ }
+ });
+ }
+ if (layEvent === 'editUS') {
+ febs.modal.open('英文版', 'modules/helpCenter/helpCenterUpdateUs/' + data.id, {
+ btn: ['提交', '取消'],
+ yes: function (index, layero) {
+ $('#user-update').find('#submit').trigger('click');
+ },
+ btn2: function () {
+ layer.closeAll();
+ }
+ });
+ }
+ if (layEvent === 'delete') {
+ febs.modal.confirm('删除', '您是否确认删除?', function () {
+ deleteUsers(data.id);
+ });
+ }
+ });
+
+ function deleteUsers(id) {
+ febs.get(ctx + 'helpCenter/helpCenterDelete/' + id, null, function () {
+ febs.alert.success('删除成功');
+ $reset.click();
+ });
+ }
+
+ // 刷新按钮
+ $reset.on('click', function () {
+ tableIns.reload({where: getQueryParams(), page: {curr: 1}});
+ });
+ // 获取查询参数
+ function getQueryParams() {
+ return {};
+ }
+
+ $add.on('click', function () {
+ febs.modal.open('新增', 'modules/helpCenter/helpCenterAdd/', {
+ btn: ['提交', '取消'],
+ yes: function (index, layero) {
+ $('#user-add').find('#submit').trigger('click');
+ },
+ btn2: function () {
+ layer.closeAll();
+ }
+ });
+ });
+
+
+ function initTable() {
+ tableIns = febs.table.init({
+ elem: $view.find('table'),
+ id: 'userTable',
+ url: ctx + 'helpCenter/getHelpCenterList',
+ cols: [[
+ {field: 'createBy', title: '创建者', minWidth: 100,align:'left'},
+ {field: 'createTime', title: '创建时间', minWidth: 200,align:'left'},
+ {field: 'articleTitle', title: '中文标题', minWidth: 200,align:'left'},
+ {field: 'articleTitleUs', title: '英文标题', minWidth: 200,align:'left'},
+ {field: 'articleNotice', title: '所属类别',
+ templet: function (d) {
+ if (d.articleNotice === 1) {
+ return '<span style="color:green;">最新公告</span>'
+ } else if (d.articleNotice === 2) {
+ return '<span style="color:red;">重要公告</span>'
+ }else{
+ return ''
+ }
+ }, minWidth: 80,align:'center'},
+ {title: '操作',
+ templet: function (d) {
+ return '<a lay-event="editCN" shiro:hasPermission="user:update">中文上传</a>'
+ +'<i class="layui-icon febs-edit-area febs-blue"></i>'
+ +'<a lay-event="editUS" shiro:hasPermission="user:update">英文上传</a>'
+ +'<i class="layui-icon febs-edit-area febs-blue"></i>'
+ +'<a lay-event="delete" shiro:hasPermission="user:update">删除</a>'
+ },minWidth: 200,align:'center'}
+ ]]
+ });
+ }
+ })
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdate.html b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdate.html
new file mode 100644
index 0000000..2439535
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdate.html
@@ -0,0 +1,104 @@
+<style>
+ #user-update {
+ padding: 20px 25px 25px 0;
+ }
+
+ #user-update .layui-treeSelect .ztree li a, .ztree li span {
+ margin: 0 0 2px 3px !important;
+ }
+ #user-update #data-permission-tree-block {
+ border: 1px solid #eee;
+ border-radius: 2px;
+ padding: 3px 0;
+ }
+ #user-add .layui-treeSelect .ztree li span.button.switch {
+ top: 1px;
+ left: 3px;
+ }
+
+</style>
+<div class="layui-fluid" id="user-update">
+ <form class="layui-form" action="" lay-filter="user-update-form">
+ <div class="layui-form-item febs-hide">
+ <label class="layui-form-label febs-form-item-require">用户id:</label>
+ <div class="layui-input-block">
+ <input type="text" name="id" data-th-value="${member.id}">
+ </div>
+ </div>
+ <div class="layui-form-item">
+ <label class="layui-form-label febs-form-item-require">标题:</label>
+ <div class="layui-input-block">
+ <input type="text" name="title" minlength="4" maxlength="10" data-th-id="${member.title}"
+ lay-verify="range|title" autocomplete="off" class="layui-input" >
+ </div>
+ </div>
+ <div class="layui-form-item">
+ <label class="layui-form-label febs-form-item-require">内容:</label>
+ <div class="layui-input-block">
+ <textarea id="lay_edit" lay-verify="content" name = "content" class="layui-textarea">${model.content}</textarea>
+ </div>
+ </div>
+ <div class="layui-form-item febs-hide">
+ <button class="layui-btn" lay-submit="" lay-filter="user-update-form-submit" id="submit"></button>
+
+ </div>
+ </form>
+</div>
+
+<script data-th-inline="javascript">
+ layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree', 'layedit'], function () {
+ var $ = layui.$,
+ febs = layui.febs,
+ layer = layui.layer,
+ formSelects = layui.formSelects,
+ treeSelect = layui.treeSelect,
+ form = layui.form,
+ eleTree = layui.eleTree,
+ member = [[${member}]],
+ $view = $('#user-update'),
+ validate = layui.validate,
+ layedit = layui.layedit,
+ _deptTree;
+
+ form.render();
+
+ initUserValue();
+
+ layedit.set({ //设置图片接口
+ uploadImage: {
+ url: 'helpCenter/uploadFileBase64', //接口url
+ type: 'post',
+ }
+ });
+ //创建一个编辑器
+ var index = layedit.build('lay_edit',{
+ height: 400
+ });
+ //提交时把值同步到文本域中
+ form.verify({
+ //content富文本域中的lay-verify值
+ content: function(value) {
+ return layedit.sync(index);
+ }
+ });
+
+ formSelects.render();
+
+ function initUserValue() {
+ form.val("user-update-form", {
+ "id": member.id,
+ "content": member.content,
+ "title": member.title
+ });
+ }
+
+ form.on('submit(user-update-form-submit)', function (data) {
+ febs.post(ctx + 'helpCenter/helpCenterConfirm', data.field, function () {
+ layer.closeAll();
+ febs.alert.success('设置成功');
+ $('#febs-user').find('#reset').click();
+ });
+ return false;
+ });
+ });
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdateUs.html b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdateUs.html
new file mode 100644
index 0000000..e1969c9
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/helpCenter/helpCenterUpdateUs.html
@@ -0,0 +1,103 @@
+<style>
+ #user-update {
+ padding: 20px 25px 25px 0;
+ }
+
+ #user-update .layui-treeSelect .ztree li a, .ztree li span {
+ margin: 0 0 2px 3px !important;
+ }
+ #user-update #data-permission-tree-block {
+ border: 1px solid #eee;
+ border-radius: 2px;
+ padding: 3px 0;
+ }
+ #user-add .layui-treeSelect .ztree li span.button.switch {
+ top: 1px;
+ left: 3px;
+ }
+
+</style>
+<div class="layui-fluid" id="user-update">
+ <form class="layui-form" action="" lay-filter="user-update-form">
+ <div class="layui-form-item febs-hide">
+ <label class="layui-form-label febs-form-item-require">用户id:</label>
+ <div class="layui-input-block">
+ <input type="text" name="id" data-th-value="${member.id}">
+ </div>
+ </div>
+ <div class="layui-form-item">
+ <label class="layui-form-label febs-form-item-require">标题:</label>
+ <div class="layui-input-block">
+ <input type="text" name="title" minlength="4" maxlength="10" data-th-id="${member.title}"
+ lay-verify="range|title" autocomplete="off" class="layui-input" >
+ </div>
+ </div>
+ <div class="layui-form-item">
+ <label class="layui-form-label febs-form-item-require">内容:</label>
+ <div class="layui-input-block">
+ <textarea id="lay_edit" lay-verify="content" name = "content" class="layui-textarea">${model.content}</textarea>
+ </div>
+ </div>
+ <div class="layui-form-item febs-hide">
+ <button class="layui-btn" lay-submit="" lay-filter="user-update-form-submit" id="submit"></button>
+ </div>
+ </form>
+</div>
+
+<script data-th-inline="javascript">
+ layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree', 'layedit'], function () {
+ var $ = layui.$,
+ febs = layui.febs,
+ layer = layui.layer,
+ formSelects = layui.formSelects,
+ treeSelect = layui.treeSelect,
+ form = layui.form,
+ eleTree = layui.eleTree,
+ member = [[${member}]],
+ $view = $('#user-update'),
+ validate = layui.validate,
+ layedit = layui.layedit,
+ _deptTree;
+
+ form.render();
+
+ initUserValue();
+
+ layedit.set({ //设置图片接口
+ uploadImage: {
+ url: 'helpCenter/uploadFileBase64', //接口url
+ type: 'post',
+ }
+ });
+ //创建一个编辑器
+ var index = layedit.build('lay_edit',{
+ height: 400
+ });
+ //提交时把值同步到文本域中
+ form.verify({
+ //content富文本域中的lay-verify值
+ content: function(value) {
+ return layedit.sync(index);
+ }
+ });
+
+ formSelects.render();
+
+ function initUserValue() {
+ form.val("user-update-form", {
+ "id": member.id,
+ "content": member.content,
+ "title": member.title
+ });
+ }
+
+ form.on('submit(user-update-form-submit)', function (data) {
+ febs.post(ctx + 'helpCenter/helpCenterUsConfirm', data.field, function () {
+ layer.closeAll();
+ febs.alert.success('设置成功');
+ $('#febs-user').find('#reset').click();
+ });
+ return false;
+ });
+ });
+</script>
\ No newline at end of file
--
Gitblit v1.9.1