From c7c4aa29be67348cef056e4d7b0ab4a1d62a73c2 Mon Sep 17 00:00:00 2001 From: zkr_liushenlu Date: Wed, 21 Apr 2021 14:51:28 +0800 Subject: [PATCH] =?UTF-8?q?=E5=88=9B=E5=BB=BA=E6=96=87=E7=AB=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/ArticleManageController.java | 5 + .../ruoyi/content/domain/ArticleSendUrl.java | 291 ------ .../content/domain/ArticleSendUrlExample.java | 932 ----------------- .../content/mapper/ArticleSendUrlMapper.java | 99 -- .../service/impl/ArticleServiceImpl.java | 80 +- .../com/ruoyi/content/utils/PathUtil.java | 100 +- .../mapper/content/ArticleSendUrlMapper.xml | 353 ------- .../main/resources/static/css/Eleditor.css | 544 ++++++++++ .../static/css/createArticleBase.css | 7 + .../static/css/createArticleStyle.css | 343 +++++++ .../main/resources/static/js/Eleditor.min.js | 936 ++++++++++++++++++ .../content/article/articleManage.html | 136 ++- .../content/article/createArticle.html | 258 +++++ 13 files changed, 2291 insertions(+), 1793 deletions(-) delete mode 100644 ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrl.java delete mode 100644 ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrlExample.java delete mode 100644 ruoyi-content/src/main/java/com/ruoyi/content/mapper/ArticleSendUrlMapper.java delete mode 100644 ruoyi-content/src/main/resources/mapper/content/ArticleSendUrlMapper.xml create mode 100644 ruoyi-content/src/main/resources/static/css/Eleditor.css create mode 100644 ruoyi-content/src/main/resources/static/css/createArticleBase.css create mode 100644 ruoyi-content/src/main/resources/static/css/createArticleStyle.css create mode 100644 ruoyi-content/src/main/resources/static/js/Eleditor.min.js create mode 100644 ruoyi-content/src/main/resources/templates/content/article/createArticle.html diff --git a/ruoyi-content/src/main/java/com/ruoyi/content/controller/ArticleManageController.java b/ruoyi-content/src/main/java/com/ruoyi/content/controller/ArticleManageController.java index 227b6e7cf..5f4a2f49c 100644 --- a/ruoyi-content/src/main/java/com/ruoyi/content/controller/ArticleManageController.java +++ b/ruoyi-content/src/main/java/com/ruoyi/content/controller/ArticleManageController.java @@ -46,6 +46,11 @@ public class ArticleManageController extends BaseController { return prefix + "/articleList"; } + @GetMapping("createPage") + public String createPage() { + return prefix + "/createArticle"; + } + /** * 查询所有公司发布的文章信息 * diff --git a/ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrl.java b/ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrl.java deleted file mode 100644 index b62d559dc..000000000 --- a/ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrl.java +++ /dev/null @@ -1,291 +0,0 @@ -package com.ruoyi.content.domain; - -public class ArticleSendUrl { - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.PUBLISH_ID - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String publishId; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.VERSION_NUMBER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String versionNumber; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.QYH_ARTICLE_URL - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String qyhArticleUrl; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.CREATE_DATE - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String createDate; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.CREATE_TIME - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String createTime; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.CREATE_USER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String createUser; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.UPDATE_USER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String updateUser; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.UPDATE_DATE - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String updateDate; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database column article_send_url.UPDATE_TIME - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - private String updateTime; - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.PUBLISH_ID - * - * @return the value of article_send_url.PUBLISH_ID - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getPublishId() { - return publishId; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.PUBLISH_ID - * - * @param publishId the value for article_send_url.PUBLISH_ID - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setPublishId(String publishId) { - this.publishId = publishId; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.VERSION_NUMBER - * - * @return the value of article_send_url.VERSION_NUMBER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getVersionNumber() { - return versionNumber; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.VERSION_NUMBER - * - * @param versionNumber the value for article_send_url.VERSION_NUMBER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setVersionNumber(String versionNumber) { - this.versionNumber = versionNumber; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.QYH_ARTICLE_URL - * - * @return the value of article_send_url.QYH_ARTICLE_URL - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getQyhArticleUrl() { - return qyhArticleUrl; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.QYH_ARTICLE_URL - * - * @param qyhArticleUrl the value for article_send_url.QYH_ARTICLE_URL - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setQyhArticleUrl(String qyhArticleUrl) { - this.qyhArticleUrl = qyhArticleUrl; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.CREATE_DATE - * - * @return the value of article_send_url.CREATE_DATE - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getCreateDate() { - return createDate; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.CREATE_DATE - * - * @param createDate the value for article_send_url.CREATE_DATE - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setCreateDate(String createDate) { - this.createDate = createDate; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.CREATE_TIME - * - * @return the value of article_send_url.CREATE_TIME - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getCreateTime() { - return createTime; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.CREATE_TIME - * - * @param createTime the value for article_send_url.CREATE_TIME - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setCreateTime(String createTime) { - this.createTime = createTime; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.CREATE_USER - * - * @return the value of article_send_url.CREATE_USER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getCreateUser() { - return createUser; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.CREATE_USER - * - * @param createUser the value for article_send_url.CREATE_USER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setCreateUser(String createUser) { - this.createUser = createUser; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.UPDATE_USER - * - * @return the value of article_send_url.UPDATE_USER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getUpdateUser() { - return updateUser; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.UPDATE_USER - * - * @param updateUser the value for article_send_url.UPDATE_USER - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setUpdateUser(String updateUser) { - this.updateUser = updateUser; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.UPDATE_DATE - * - * @return the value of article_send_url.UPDATE_DATE - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getUpdateDate() { - return updateDate; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.UPDATE_DATE - * - * @param updateDate the value for article_send_url.UPDATE_DATE - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setUpdateDate(String updateDate) { - this.updateDate = updateDate; - } - - /** - * This method was generated by MyBatis Generator. - * This method returns the value of the database column article_send_url.UPDATE_TIME - * - * @return the value of article_send_url.UPDATE_TIME - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getUpdateTime() { - return updateTime; - } - - /** - * This method was generated by MyBatis Generator. - * This method sets the value of the database column article_send_url.UPDATE_TIME - * - * @param updateTime the value for article_send_url.UPDATE_TIME - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setUpdateTime(String updateTime) { - this.updateTime = updateTime; - } -} \ No newline at end of file diff --git a/ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrlExample.java b/ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrlExample.java deleted file mode 100644 index 7c3b5a455..000000000 --- a/ruoyi-content/src/main/java/com/ruoyi/content/domain/ArticleSendUrlExample.java +++ /dev/null @@ -1,932 +0,0 @@ -package com.ruoyi.content.domain; - -import java.util.ArrayList; -import java.util.List; - -public class ArticleSendUrlExample { - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - protected String orderByClause; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - protected boolean distinct; - - /** - * This field was generated by MyBatis Generator. - * This field corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - protected List oredCriteria; - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public ArticleSendUrlExample() { - oredCriteria = new ArrayList(); - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setOrderByClause(String orderByClause) { - this.orderByClause = orderByClause; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public String getOrderByClause() { - return orderByClause; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void setDistinct(boolean distinct) { - this.distinct = distinct; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public boolean isDistinct() { - return distinct; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public List getOredCriteria() { - return oredCriteria; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void or(Criteria criteria) { - oredCriteria.add(criteria); - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public Criteria or() { - Criteria criteria = createCriteriaInternal(); - oredCriteria.add(criteria); - return criteria; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public Criteria createCriteria() { - Criteria criteria = createCriteriaInternal(); - if (oredCriteria.size() == 0) { - oredCriteria.add(criteria); - } - return criteria; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - protected Criteria createCriteriaInternal() { - Criteria criteria = new Criteria(); - return criteria; - } - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public void clear() { - oredCriteria.clear(); - orderByClause = null; - distinct = false; - } - - /** - * This class was generated by MyBatis Generator. - * This class corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - protected abstract static class GeneratedCriteria { - protected List criteria; - - protected GeneratedCriteria() { - super(); - criteria = new ArrayList(); - } - - public boolean isValid() { - return criteria.size() > 0; - } - - public List getAllCriteria() { - return criteria; - } - - public List getCriteria() { - return criteria; - } - - protected void addCriterion(String condition) { - if (condition == null) { - throw new RuntimeException("Value for condition cannot be null"); - } - criteria.add(new Criterion(condition)); - } - - protected void addCriterion(String condition, Object value, String property) { - if (value == null) { - throw new RuntimeException("Value for " + property + " cannot be null"); - } - criteria.add(new Criterion(condition, value)); - } - - protected void addCriterion(String condition, Object value1, Object value2, String property) { - if (value1 == null || value2 == null) { - throw new RuntimeException("Between values for " + property + " cannot be null"); - } - criteria.add(new Criterion(condition, value1, value2)); - } - - public Criteria andPublishIdIsNull() { - addCriterion("PUBLISH_ID is null"); - return (Criteria) this; - } - - public Criteria andPublishIdIsNotNull() { - addCriterion("PUBLISH_ID is not null"); - return (Criteria) this; - } - - public Criteria andPublishIdEqualTo(String value) { - addCriterion("PUBLISH_ID =", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdNotEqualTo(String value) { - addCriterion("PUBLISH_ID <>", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdGreaterThan(String value) { - addCriterion("PUBLISH_ID >", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdGreaterThanOrEqualTo(String value) { - addCriterion("PUBLISH_ID >=", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdLessThan(String value) { - addCriterion("PUBLISH_ID <", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdLessThanOrEqualTo(String value) { - addCriterion("PUBLISH_ID <=", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdLike(String value) { - addCriterion("PUBLISH_ID like", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdNotLike(String value) { - addCriterion("PUBLISH_ID not like", value, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdIn(List values) { - addCriterion("PUBLISH_ID in", values, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdNotIn(List values) { - addCriterion("PUBLISH_ID not in", values, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdBetween(String value1, String value2) { - addCriterion("PUBLISH_ID between", value1, value2, "publishId"); - return (Criteria) this; - } - - public Criteria andPublishIdNotBetween(String value1, String value2) { - addCriterion("PUBLISH_ID not between", value1, value2, "publishId"); - return (Criteria) this; - } - - public Criteria andVersionNumberIsNull() { - addCriterion("VERSION_NUMBER is null"); - return (Criteria) this; - } - - public Criteria andVersionNumberIsNotNull() { - addCriterion("VERSION_NUMBER is not null"); - return (Criteria) this; - } - - public Criteria andVersionNumberEqualTo(String value) { - addCriterion("VERSION_NUMBER =", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberNotEqualTo(String value) { - addCriterion("VERSION_NUMBER <>", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberGreaterThan(String value) { - addCriterion("VERSION_NUMBER >", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberGreaterThanOrEqualTo(String value) { - addCriterion("VERSION_NUMBER >=", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberLessThan(String value) { - addCriterion("VERSION_NUMBER <", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberLessThanOrEqualTo(String value) { - addCriterion("VERSION_NUMBER <=", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberLike(String value) { - addCriterion("VERSION_NUMBER like", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberNotLike(String value) { - addCriterion("VERSION_NUMBER not like", value, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberIn(List values) { - addCriterion("VERSION_NUMBER in", values, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberNotIn(List values) { - addCriterion("VERSION_NUMBER not in", values, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberBetween(String value1, String value2) { - addCriterion("VERSION_NUMBER between", value1, value2, "versionNumber"); - return (Criteria) this; - } - - public Criteria andVersionNumberNotBetween(String value1, String value2) { - addCriterion("VERSION_NUMBER not between", value1, value2, "versionNumber"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlIsNull() { - addCriterion("QYH_ARTICLE_URL is null"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlIsNotNull() { - addCriterion("QYH_ARTICLE_URL is not null"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlEqualTo(String value) { - addCriterion("QYH_ARTICLE_URL =", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlNotEqualTo(String value) { - addCriterion("QYH_ARTICLE_URL <>", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlGreaterThan(String value) { - addCriterion("QYH_ARTICLE_URL >", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlGreaterThanOrEqualTo(String value) { - addCriterion("QYH_ARTICLE_URL >=", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlLessThan(String value) { - addCriterion("QYH_ARTICLE_URL <", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlLessThanOrEqualTo(String value) { - addCriterion("QYH_ARTICLE_URL <=", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlLike(String value) { - addCriterion("QYH_ARTICLE_URL like", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlNotLike(String value) { - addCriterion("QYH_ARTICLE_URL not like", value, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlIn(List values) { - addCriterion("QYH_ARTICLE_URL in", values, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlNotIn(List values) { - addCriterion("QYH_ARTICLE_URL not in", values, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlBetween(String value1, String value2) { - addCriterion("QYH_ARTICLE_URL between", value1, value2, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andQyhArticleUrlNotBetween(String value1, String value2) { - addCriterion("QYH_ARTICLE_URL not between", value1, value2, "qyhArticleUrl"); - return (Criteria) this; - } - - public Criteria andCreateDateIsNull() { - addCriterion("CREATE_DATE is null"); - return (Criteria) this; - } - - public Criteria andCreateDateIsNotNull() { - addCriterion("CREATE_DATE is not null"); - return (Criteria) this; - } - - public Criteria andCreateDateEqualTo(String value) { - addCriterion("CREATE_DATE =", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateNotEqualTo(String value) { - addCriterion("CREATE_DATE <>", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateGreaterThan(String value) { - addCriterion("CREATE_DATE >", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateGreaterThanOrEqualTo(String value) { - addCriterion("CREATE_DATE >=", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateLessThan(String value) { - addCriterion("CREATE_DATE <", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateLessThanOrEqualTo(String value) { - addCriterion("CREATE_DATE <=", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateLike(String value) { - addCriterion("CREATE_DATE like", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateNotLike(String value) { - addCriterion("CREATE_DATE not like", value, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateIn(List values) { - addCriterion("CREATE_DATE in", values, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateNotIn(List values) { - addCriterion("CREATE_DATE not in", values, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateBetween(String value1, String value2) { - addCriterion("CREATE_DATE between", value1, value2, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateDateNotBetween(String value1, String value2) { - addCriterion("CREATE_DATE not between", value1, value2, "createDate"); - return (Criteria) this; - } - - public Criteria andCreateTimeIsNull() { - addCriterion("CREATE_TIME is null"); - return (Criteria) this; - } - - public Criteria andCreateTimeIsNotNull() { - addCriterion("CREATE_TIME is not null"); - return (Criteria) this; - } - - public Criteria andCreateTimeEqualTo(String value) { - addCriterion("CREATE_TIME =", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeNotEqualTo(String value) { - addCriterion("CREATE_TIME <>", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeGreaterThan(String value) { - addCriterion("CREATE_TIME >", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeGreaterThanOrEqualTo(String value) { - addCriterion("CREATE_TIME >=", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeLessThan(String value) { - addCriterion("CREATE_TIME <", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeLessThanOrEqualTo(String value) { - addCriterion("CREATE_TIME <=", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeLike(String value) { - addCriterion("CREATE_TIME like", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeNotLike(String value) { - addCriterion("CREATE_TIME not like", value, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeIn(List values) { - addCriterion("CREATE_TIME in", values, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeNotIn(List values) { - addCriterion("CREATE_TIME not in", values, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeBetween(String value1, String value2) { - addCriterion("CREATE_TIME between", value1, value2, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateTimeNotBetween(String value1, String value2) { - addCriterion("CREATE_TIME not between", value1, value2, "createTime"); - return (Criteria) this; - } - - public Criteria andCreateUserIsNull() { - addCriterion("CREATE_USER is null"); - return (Criteria) this; - } - - public Criteria andCreateUserIsNotNull() { - addCriterion("CREATE_USER is not null"); - return (Criteria) this; - } - - public Criteria andCreateUserEqualTo(String value) { - addCriterion("CREATE_USER =", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserNotEqualTo(String value) { - addCriterion("CREATE_USER <>", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserGreaterThan(String value) { - addCriterion("CREATE_USER >", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserGreaterThanOrEqualTo(String value) { - addCriterion("CREATE_USER >=", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserLessThan(String value) { - addCriterion("CREATE_USER <", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserLessThanOrEqualTo(String value) { - addCriterion("CREATE_USER <=", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserLike(String value) { - addCriterion("CREATE_USER like", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserNotLike(String value) { - addCriterion("CREATE_USER not like", value, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserIn(List values) { - addCriterion("CREATE_USER in", values, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserNotIn(List values) { - addCriterion("CREATE_USER not in", values, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserBetween(String value1, String value2) { - addCriterion("CREATE_USER between", value1, value2, "createUser"); - return (Criteria) this; - } - - public Criteria andCreateUserNotBetween(String value1, String value2) { - addCriterion("CREATE_USER not between", value1, value2, "createUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserIsNull() { - addCriterion("UPDATE_USER is null"); - return (Criteria) this; - } - - public Criteria andUpdateUserIsNotNull() { - addCriterion("UPDATE_USER is not null"); - return (Criteria) this; - } - - public Criteria andUpdateUserEqualTo(String value) { - addCriterion("UPDATE_USER =", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserNotEqualTo(String value) { - addCriterion("UPDATE_USER <>", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserGreaterThan(String value) { - addCriterion("UPDATE_USER >", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserGreaterThanOrEqualTo(String value) { - addCriterion("UPDATE_USER >=", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserLessThan(String value) { - addCriterion("UPDATE_USER <", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserLessThanOrEqualTo(String value) { - addCriterion("UPDATE_USER <=", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserLike(String value) { - addCriterion("UPDATE_USER like", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserNotLike(String value) { - addCriterion("UPDATE_USER not like", value, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserIn(List values) { - addCriterion("UPDATE_USER in", values, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserNotIn(List values) { - addCriterion("UPDATE_USER not in", values, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserBetween(String value1, String value2) { - addCriterion("UPDATE_USER between", value1, value2, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateUserNotBetween(String value1, String value2) { - addCriterion("UPDATE_USER not between", value1, value2, "updateUser"); - return (Criteria) this; - } - - public Criteria andUpdateDateIsNull() { - addCriterion("UPDATE_DATE is null"); - return (Criteria) this; - } - - public Criteria andUpdateDateIsNotNull() { - addCriterion("UPDATE_DATE is not null"); - return (Criteria) this; - } - - public Criteria andUpdateDateEqualTo(String value) { - addCriterion("UPDATE_DATE =", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateNotEqualTo(String value) { - addCriterion("UPDATE_DATE <>", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateGreaterThan(String value) { - addCriterion("UPDATE_DATE >", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateGreaterThanOrEqualTo(String value) { - addCriterion("UPDATE_DATE >=", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateLessThan(String value) { - addCriterion("UPDATE_DATE <", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateLessThanOrEqualTo(String value) { - addCriterion("UPDATE_DATE <=", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateLike(String value) { - addCriterion("UPDATE_DATE like", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateNotLike(String value) { - addCriterion("UPDATE_DATE not like", value, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateIn(List values) { - addCriterion("UPDATE_DATE in", values, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateNotIn(List values) { - addCriterion("UPDATE_DATE not in", values, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateBetween(String value1, String value2) { - addCriterion("UPDATE_DATE between", value1, value2, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateDateNotBetween(String value1, String value2) { - addCriterion("UPDATE_DATE not between", value1, value2, "updateDate"); - return (Criteria) this; - } - - public Criteria andUpdateTimeIsNull() { - addCriterion("UPDATE_TIME is null"); - return (Criteria) this; - } - - public Criteria andUpdateTimeIsNotNull() { - addCriterion("UPDATE_TIME is not null"); - return (Criteria) this; - } - - public Criteria andUpdateTimeEqualTo(String value) { - addCriterion("UPDATE_TIME =", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeNotEqualTo(String value) { - addCriterion("UPDATE_TIME <>", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeGreaterThan(String value) { - addCriterion("UPDATE_TIME >", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeGreaterThanOrEqualTo(String value) { - addCriterion("UPDATE_TIME >=", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeLessThan(String value) { - addCriterion("UPDATE_TIME <", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeLessThanOrEqualTo(String value) { - addCriterion("UPDATE_TIME <=", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeLike(String value) { - addCriterion("UPDATE_TIME like", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeNotLike(String value) { - addCriterion("UPDATE_TIME not like", value, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeIn(List values) { - addCriterion("UPDATE_TIME in", values, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeNotIn(List values) { - addCriterion("UPDATE_TIME not in", values, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeBetween(String value1, String value2) { - addCriterion("UPDATE_TIME between", value1, value2, "updateTime"); - return (Criteria) this; - } - - public Criteria andUpdateTimeNotBetween(String value1, String value2) { - addCriterion("UPDATE_TIME not between", value1, value2, "updateTime"); - return (Criteria) this; - } - } - - /** - * This class was generated by MyBatis Generator. - * This class corresponds to the database table article_send_url - * - * @mbggenerated do_not_delete_during_merge Tue Sep 04 17:49:40 CST 2018 - */ - public static class Criteria extends GeneratedCriteria { - - protected Criteria() { - super(); - } - } - - /** - * This class was generated by MyBatis Generator. - * This class corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - public static class Criterion { - private String condition; - - private Object value; - - private Object secondValue; - - private boolean noValue; - - private boolean singleValue; - - private boolean betweenValue; - - private boolean listValue; - - private String typeHandler; - - public String getCondition() { - return condition; - } - - public Object getValue() { - return value; - } - - public Object getSecondValue() { - return secondValue; - } - - public boolean isNoValue() { - return noValue; - } - - public boolean isSingleValue() { - return singleValue; - } - - public boolean isBetweenValue() { - return betweenValue; - } - - public boolean isListValue() { - return listValue; - } - - public String getTypeHandler() { - return typeHandler; - } - - protected Criterion(String condition) { - super(); - this.condition = condition; - this.typeHandler = null; - this.noValue = true; - } - - protected Criterion(String condition, Object value, String typeHandler) { - super(); - this.condition = condition; - this.value = value; - this.typeHandler = typeHandler; - if (value instanceof List) { - this.listValue = true; - } else { - this.singleValue = true; - } - } - - protected Criterion(String condition, Object value) { - this(condition, value, null); - } - - protected Criterion(String condition, Object value, Object secondValue, String typeHandler) { - super(); - this.condition = condition; - this.value = value; - this.secondValue = secondValue; - this.typeHandler = typeHandler; - this.betweenValue = true; - } - - protected Criterion(String condition, Object value, Object secondValue) { - this(condition, value, secondValue, null); - } - } -} \ No newline at end of file diff --git a/ruoyi-content/src/main/java/com/ruoyi/content/mapper/ArticleSendUrlMapper.java b/ruoyi-content/src/main/java/com/ruoyi/content/mapper/ArticleSendUrlMapper.java deleted file mode 100644 index 0948c2c9b..000000000 --- a/ruoyi-content/src/main/java/com/ruoyi/content/mapper/ArticleSendUrlMapper.java +++ /dev/null @@ -1,99 +0,0 @@ -package com.ruoyi.content.mapper; - -import com.ruoyi.content.domain.ArticleSendUrl; -import com.ruoyi.content.domain.ArticleSendUrlExample; -import org.apache.ibatis.annotations.Param; -import org.springframework.stereotype.Repository; - -import java.util.List; - -@Repository -public interface ArticleSendUrlMapper { - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int countByExample(ArticleSendUrlExample example); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int deleteByExample(ArticleSendUrlExample example); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int deleteByPrimaryKey(String publishId); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int insert(ArticleSendUrl record); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int insertSelective(ArticleSendUrl record); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - List selectByExample(ArticleSendUrlExample example); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - ArticleSendUrl selectByPrimaryKey(String publishId); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int updateByExampleSelective(@Param("record") ArticleSendUrl record, @Param("example") ArticleSendUrlExample example); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int updateByExample(@Param("record") ArticleSendUrl record, @Param("example") ArticleSendUrlExample example); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int updateByPrimaryKeySelective(ArticleSendUrl record); - - /** - * This method was generated by MyBatis Generator. - * This method corresponds to the database table article_send_url - * - * @mbggenerated Tue Sep 04 17:49:40 CST 2018 - */ - int updateByPrimaryKey(ArticleSendUrl record); -} \ No newline at end of file diff --git a/ruoyi-content/src/main/java/com/ruoyi/content/service/impl/ArticleServiceImpl.java b/ruoyi-content/src/main/java/com/ruoyi/content/service/impl/ArticleServiceImpl.java index 9d1da35cf..08a62cef7 100644 --- a/ruoyi-content/src/main/java/com/ruoyi/content/service/impl/ArticleServiceImpl.java +++ b/ruoyi-content/src/main/java/com/ruoyi/content/service/impl/ArticleServiceImpl.java @@ -1179,7 +1179,7 @@ public class ArticleServiceImpl implements ArticleService { // 文章的发布id String publishId = userId + "a" + articleId; - msg = this.getHtmlUrl(articleId, articleName, shareImgUrl, shareDes, articleContent, ids, publishId, companyId, + msg = this.getHtmlUrl123(articleId, articleName, shareImgUrl, shareDes, articleContent, ids, publishId, companyId, isAuthorization, isReserve, automaticName, introduction, isJoinActive); Map resultMap1 = new HashMap(); resultMap1 = (Map) msg.getObject(); @@ -1212,4 +1212,82 @@ public class ArticleServiceImpl implements ArticleService { return msg; } + /** + * 生成静态页面路径 + */ + public Message getHtmlUrl123(Integer articleId, String shareTitle, String shareImgUrl, String shareDes, + String articleContent, String ids, String publishId, String companyId, String isAuthorization, + String isReserve, String automaticName, String introduction, String isJoinActive) { + Message msg = new Message(); + Map resultMap = new HashMap(); + /*************** 根据链接爬文章***********start ****************************/ + LOGGER.info( + "调用生成静态页面参数articleId[{}],shareTitle[{}],shareImgUrl[{}],shareDes[{}],ids[{}],publishId[{}],companyId[{}],isAuthorization[{}],isReserve[{}],automaticName[{}],introduction[{}],isJoinActive[{}]", + articleId, shareTitle, shareImgUrl, shareDes, ids, publishId, companyId, isAuthorization, isReserve, + automaticName, introduction, isJoinActive); + try { + /**************************** 生成静态页开始 ************************************/ + Configuration conf = new Configuration(); + Map pageData = new HashMap(); + Map articleMap = new HashMap(); + // 时间戳 + String versionNumber = DateUtil.currentDate(DateUtil.yyyyMMddHHmmssSSS) + RandomUtils.randomNumber(3); + // 封装数据 + articleMap.put("shareTitle", shareTitle); + articleMap.put("shareImgUrl", shareImgUrl); + articleMap.put("shareDes", shareDes); + articleMap.put("articleId", String.valueOf(articleId)); + articleMap.put("articleContent", articleContent); + articleMap.put("companyId", companyId); + articleMap.put("versionNumber", versionNumber); + articleMap.put("publishId", publishId); + articleMap.put("isAuthorization", isAuthorization);// 是否授权 + articleMap.put("isReserve", isReserve); + articleMap.put("isJoinActive", isJoinActive); + articleMap.put("automaticName", automaticName); + articleMap.put("introduction", introduction); + if (ids == null || "".equals(ids)) { + articleMap.put("adId", ""); + } else { + articleMap.put("adId", ids); + } + + pageData.put("articleInfo", articleMap); + // 静态页生成路径 + String viewPath = PathUtil.getArticleViewUrl(versionNumber, String.valueOf(articleId)); + String createPath = PathUtil.getArticleCreateUrl(versionNumber, articleId + versionNumber.substring(8, 14)); + FreemakerUtil.generateStaticPage(conf, PropertiesConstants.TEMPLATE_VIEW_PATH, + PropertiesConstants.FILE_PATH + viewPath, pageData); + FreemakerUtil.generateStaticPage(conf, PropertiesConstants.TEMPLATE_CREATE_PATH, + PropertiesConstants.FILE_PATH + createPath, pageData); + // 把静态页上传到oss + OSSUtil.uploadFileHtml(PropertiesConstants.OSSENDPOINT, PropertiesConstants.OSSID, + PropertiesConstants.OSSKEY, PropertiesConstants.BUCKETNAME, + PropertiesConstants.FILE_PATH + viewPath, PropertiesConstants.OSSPATH + viewPath); + OSSUtil.uploadFileHtml(PropertiesConstants.OSSENDPOINT, PropertiesConstants.OSSID, + PropertiesConstants.OSSKEY, PropertiesConstants.BUCKETNAME, + PropertiesConstants.FILE_PATH + createPath, PropertiesConstants.OSSPATH + createPath); + + String articleViewUrl = PropertiesConstants.OSS_URL + PropertiesConstants.OSSPATH + viewPath; // cdn路径 + // 生产 +// String articleEditUrl = PropertiesConstants.OSS_URL_HTTPS + +// PropertiesConstants.OSSPATH + editPath; // cdn路径 + // 测试 + String articleEditUrl = PropertiesConstants.OSS_URL + PropertiesConstants.OSSPATH + createPath; + LOGGER.info("articleEditUrl[{}]===============", articleEditUrl); + + /**************************** 生成静态页结束 ************************************/ + // 保存文章的原始静态页面路径 + resultMap.put("articleEditUrl", articleEditUrl); + resultMap.put("articleViewUrl", articleViewUrl); + resultMap.put("versionNumber", versionNumber); + LOGGER.info("生成静态页面的versionNumber为{}", versionNumber); + } catch (Exception e) { + e.printStackTrace(); + throw new BusinessException("系统繁忙,请稍后再试"); + } + msg.setObject(resultMap); + return msg; + } + } diff --git a/ruoyi-content/src/main/java/com/ruoyi/content/utils/PathUtil.java b/ruoyi-content/src/main/java/com/ruoyi/content/utils/PathUtil.java index 12a7dd8a4..dbd366470 100644 --- a/ruoyi-content/src/main/java/com/ruoyi/content/utils/PathUtil.java +++ b/ruoyi-content/src/main/java/com/ruoyi/content/utils/PathUtil.java @@ -7,50 +7,66 @@ import org.springframework.web.context.request.ServletRequestAttributes; /** * 获取路径方法 - * @author Administrator * + * @author Administrator */ public class PathUtil { - - /** - * 获取web项目访问路径 - * 使用该方法是必须在web.xml中配置了监听 org.springframework.web.context.request.RequestContextListener - * @return - */ - public static String getWebPath(){ - HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); - String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+request.getContextPath()+"/"; - return basePath; - } - - /** - * 获取web项目classes路径 - * @return - */ - public static String getClassesPath(){ - return Thread.currentThread().getContextClassLoader().getResource("").getPath(); - } - - /** - * 获取已发布文章的浏览静态页 - * - * liu.hx - * 2018年4月24日 - * @throws - */ - public static String getArticleViewUrl(String timestamp,String articleId) { - return "template/html/view/"+timestamp.substring(0, 8)+"/"+articleId+"b"+timestamp+".html"; - } - - /** - * 获取文章编辑静态页 - * - * liu.hx - * 2018年4月24日 - * @throws - */ - public static String getArticleEditUrl(String timestamp,String name) { - return "template/html/mkt-ms/edit/"+timestamp.substring(0, 8)+"/"+name+".html"; - } + + /** + * 获取web项目访问路径 + * 使用该方法是必须在web.xml中配置了监听 org.springframework.web.context.request.RequestContextListener + * + * @return + */ + public static String getWebPath() { + HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); + String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath() + "/"; + return basePath; + } + + /** + * 获取web项目classes路径 + * + * @return + */ + public static String getClassesPath() { + return Thread.currentThread().getContextClassLoader().getResource("").getPath(); + } + + /** + * 获取已发布文章的浏览静态页 + *

+ * liu.hx + * 2018年4月24日 + * + * @throws + */ + public static String getArticleViewUrl(String timestamp, String articleId) { + return "template/html/view/" + timestamp.substring(0, 8) + "/" + articleId + "b" + timestamp + ".html"; + } + + /** + * 获取文章编辑静态页 + *

+ * liu.hx + * 2018年4月24日 + * + * @throws + */ + public static String getArticleEditUrl(String timestamp, String name) { + return "template/html/edit/" + timestamp.substring(0, 8) + "/" + name + ".html"; + } + + /** + * 获取文章编辑静态页 + *

+ * liu.hx + * 2018年4月24日 + * + * @throws + */ + public static String getArticleCreateUrl(String timestamp, String name) { + return "template/html/create/" + timestamp.substring(0, 8) + "/" + name + ".html"; + } } diff --git a/ruoyi-content/src/main/resources/mapper/content/ArticleSendUrlMapper.xml b/ruoyi-content/src/main/resources/mapper/content/ArticleSendUrlMapper.xml deleted file mode 100644 index 8e3dd8f5d..000000000 --- a/ruoyi-content/src/main/resources/mapper/content/ArticleSendUrlMapper.xml +++ /dev/null @@ -1,353 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - and ${criterion.condition} - - - and ${criterion.condition} #{criterion.value} - - - and ${criterion.condition} #{criterion.value} and #{criterion.secondValue} - - - and ${criterion.condition} - - #{listItem} - - - - - - - - - - - - - - - - - - - and ${criterion.condition} - - - and ${criterion.condition} #{criterion.value} - - - and ${criterion.condition} #{criterion.value} and #{criterion.secondValue} - - - and ${criterion.condition} - - #{listItem} - - - - - - - - - - - - PUBLISH_ID, VERSION_NUMBER, QYH_ARTICLE_URL, CREATE_DATE, CREATE_TIME, CREATE_USER, - UPDATE_USER, UPDATE_DATE, UPDATE_TIME - - - - - - delete from article_send_url - where PUBLISH_ID = #{publishId,jdbcType=VARCHAR} - - - - delete from article_send_url - - - - - - - - insert into article_send_url (PUBLISH_ID, VERSION_NUMBER, QYH_ARTICLE_URL, - CREATE_DATE, CREATE_TIME, CREATE_USER, - UPDATE_USER, UPDATE_DATE, UPDATE_TIME - ) - values (#{publishId,jdbcType=VARCHAR}, #{versionNumber,jdbcType=VARCHAR}, #{qyhArticleUrl,jdbcType=VARCHAR}, - #{createDate,jdbcType=VARCHAR}, #{createTime,jdbcType=VARCHAR}, #{createUser,jdbcType=VARCHAR}, - #{updateUser,jdbcType=VARCHAR}, #{updateDate,jdbcType=VARCHAR}, #{updateTime,jdbcType=VARCHAR} - ) - - - - - insert into article_send_url - - PUBLISH_ID, - - VERSION_NUMBER, - - - QYH_ARTICLE_URL, - - - CREATE_DATE, - - - CREATE_TIME, - - - CREATE_USER, - - - UPDATE_USER, - - - UPDATE_DATE, - - - UPDATE_TIME, - - - - #{publishId,jdbcType=VARCHAR}, - - #{versionNumber,jdbcType=VARCHAR}, - - - #{qyhArticleUrl,jdbcType=VARCHAR}, - - - #{createDate,jdbcType=VARCHAR}, - - - #{createTime,jdbcType=VARCHAR}, - - - #{createUser,jdbcType=VARCHAR}, - - - #{updateUser,jdbcType=VARCHAR}, - - - #{updateDate,jdbcType=VARCHAR}, - - - #{updateTime,jdbcType=VARCHAR}, - - - - - - - update article_send_url - - - PUBLISH_ID = #{record.publishId,jdbcType=VARCHAR}, - - - VERSION_NUMBER = #{record.versionNumber,jdbcType=VARCHAR}, - - - QYH_ARTICLE_URL = #{record.qyhArticleUrl,jdbcType=VARCHAR}, - - - CREATE_DATE = #{record.createDate,jdbcType=VARCHAR}, - - - CREATE_TIME = #{record.createTime,jdbcType=VARCHAR}, - - - CREATE_USER = #{record.createUser,jdbcType=VARCHAR}, - - - UPDATE_USER = #{record.updateUser,jdbcType=VARCHAR}, - - - UPDATE_DATE = #{record.updateDate,jdbcType=VARCHAR}, - - - UPDATE_TIME = #{record.updateTime,jdbcType=VARCHAR}, - - - - - - - - - update article_send_url - set PUBLISH_ID = #{record.publishId,jdbcType=VARCHAR}, - VERSION_NUMBER = #{record.versionNumber,jdbcType=VARCHAR}, - QYH_ARTICLE_URL = #{record.qyhArticleUrl,jdbcType=VARCHAR}, - CREATE_DATE = #{record.createDate,jdbcType=VARCHAR}, - CREATE_TIME = #{record.createTime,jdbcType=VARCHAR}, - CREATE_USER = #{record.createUser,jdbcType=VARCHAR}, - UPDATE_USER = #{record.updateUser,jdbcType=VARCHAR}, - UPDATE_DATE = #{record.updateDate,jdbcType=VARCHAR}, - UPDATE_TIME = #{record.updateTime,jdbcType=VARCHAR} - - - - - - - update article_send_url - - - VERSION_NUMBER = #{versionNumber,jdbcType=VARCHAR}, - - - QYH_ARTICLE_URL = #{qyhArticleUrl,jdbcType=VARCHAR}, - - - CREATE_DATE = #{createDate,jdbcType=VARCHAR}, - - - CREATE_TIME = #{createTime,jdbcType=VARCHAR}, - - - CREATE_USER = #{createUser,jdbcType=VARCHAR}, - - - UPDATE_USER = #{updateUser,jdbcType=VARCHAR}, - - - UPDATE_DATE = #{updateDate,jdbcType=VARCHAR}, - - - UPDATE_TIME = #{updateTime,jdbcType=VARCHAR}, - - - where PUBLISH_ID = #{publishId,jdbcType=VARCHAR} - - - - update article_send_url - set VERSION_NUMBER = #{versionNumber,jdbcType=VARCHAR}, - QYH_ARTICLE_URL = #{qyhArticleUrl,jdbcType=VARCHAR}, - CREATE_DATE = #{createDate,jdbcType=VARCHAR}, - CREATE_TIME = #{createTime,jdbcType=VARCHAR}, - CREATE_USER = #{createUser,jdbcType=VARCHAR}, - UPDATE_USER = #{updateUser,jdbcType=VARCHAR}, - UPDATE_DATE = #{updateDate,jdbcType=VARCHAR}, - UPDATE_TIME = #{updateTime,jdbcType=VARCHAR} - where PUBLISH_ID = #{publishId,jdbcType=VARCHAR} - - \ No newline at end of file diff --git a/ruoyi-content/src/main/resources/static/css/Eleditor.css b/ruoyi-content/src/main/resources/static/css/Eleditor.css new file mode 100644 index 000000000..82d38b5ad --- /dev/null +++ b/ruoyi-content/src/main/resources/static/css/Eleditor.css @@ -0,0 +1,544 @@ +/** +* Version: 1.6 +* Title: Eleditor 移动端富文本编辑器 +* Site: https://eleditor.fixel.cn +* Author: Try +*/ + +.Eleditor-scrollLocked { + height: 100%; + overflow: hidden +} + +.Eleditor-wrap.Eleditor-mask { + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + background: rgba(0, 0, 0, .5) +} + +.Eleditor-loading { + display: none; + position: absolute; + padding: 15px; + background: rgba(255, 255, 255, .9); + z-index: 999; + width: 100%; + height: 100% +} + +.Eleditor-loading p { + font-size: 12px; + color: #666; + text-align: center; + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + -webkit-transform: translate(-50%, -50%) +} + +.Eleditor-loading p:before { + content: ''; + width: 25px; + height: 25px; + margin: 0 auto; + background: url() no-repeat center top; + background-size: 100%; + display: inline-block; + vertical-align: middle; + margin-right: 10px +} + +.Eleditor-wrap ul { + list-style: none +} + +.Eleditor-area, +.Eleditor-area *, +.Eleditor-wrap, +.Eleditor-wrap * { + cursor: pointer; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); + tap-highlight-color: rgba(0, 0, 0, 0) +} + +.Eleditor-area .Eleditor-active { + background: #cce0f2 !important; + padding: 2% !important +} + +.Eleditor-controller { + background: #fafafa; + position: absolute; + box-sizing: border-box; + transform: translate(-50%, 0); + -webkit-transform: translate(-50%, 0); + left: 50%; + display: none; + margin-top: 5px; + box-shadow: 0 0 20px rgba(0, 0, 0, .2); + -webkit-box-shadow: 0 0 20px rgba(0, 0, 0, .2); + border-bottom: 1px solid #e1e1e1; + border-radius: 3px; + -webkit-border-radius: 3px +} + +.Eleditor-controller ul { + margin-bottom: 2.5%; + /* hrjlhy */ + margin: 0; + margin-bottom: 2.5%; +} + +.Eleditor-controller ul:after { + content: ''; + display: block; + height: 0; + clear: both +} + +.Eleditor-controller ul li { + float: left; + display: inline-block; + width: 30%; + margin: 2% 0 0 2.5%; + height: 42px; + border-radius: 3px; + -webkit-border-radius: 3px; + line-height: 42px; + padding-left: 10%; + box-sizing: border-box; + font-size: 14px; + border-right: 1px solid #ddd; + border-bottom: 1px solid #ddd; + border-top: 1px solid #eee; + border-left: 1px solid #eee; + white-space: nowrap; + position: relative +} + +.Eleditor-controller ul li.Eleditor-undo { + display: none +} + +.Eleditor-controller ul li:before { + background-size: 100%; + background-repeat: no-repeat +} + +.Eleditor-controller ul li:before { + content: ''; + position: absolute; + left: 8px; + top: 12px; + width: 15px; + height: 15px; + display: block; + /* background-image: url() */ +} + +.Eleditor-controller ul li.Eleditor-insertText:before { + background-image: url() +} + +/* .Eleditor-controller ul li.Eleditor-insertImage:before { + background-image: url() +} */ + +.Eleditor-controller ul li.Eleditor-undo:before { + background-image: url() +} + +/* .Eleditor-controller ul li.Eleditor-insertImage div[id^='rt_rt_'] { + left: 0 !important; + width: 100% !important; + opacity: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0) +} */ + +.Eleditor-controller ul li.Eleditor-insertLink:before { + background-image: url() +} + +.Eleditor-controller ul li.Eleditor-insertHr:before { + background-image: url() +} + +.Eleditor-controller ul li.Eleditor-deleteThis:before, +.Eleditor-controller ul li.Eleditor-deleteBefore:before, +.Eleditor-controller ul li.Eleditor-deleteAfter:before { + background-image: url() +} + +.Eleditor-controller ul li.Eleditor-cancel:before { + background-image: url() +} + +.Eleditor-controller ul li.Eleditor-editText:before { + background-image: url() +} + +@media screen and (max-width:300px) { + .Eleditor-controller ul li { + width: 30%; + text-align: center; + padding-left: 0; + font-size: 12px + } + .Eleditor-controller ul li:before { + display: none + } +} + +.Eleditor-textEditor { + display: none; + width: 100%; + height: 100%; + background: #fff; + position: fixed; + left: 0; + top: 0; + /* hrjlhy */ + margin: 15% 0 0 15%; + width: 70%; + height: 40%; +} + +.Eleditor-textEditor-colors, +.Eleditor-textEditor-fontsizes, +.Eleditor-textEditor-lineheight, +.Eleditor-textEditor-linedecorations { + display: none; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + background: #fff; + z-index: 1 +} + +.Eleditor-textEditor-modulePane { + margin: 10px 8px; + border-bottom: 1px solid #ccc; + padding-bottom: 10px +} + +.Eleditor-textEditor-linedecorations .Eleditor-textEditor-modulePane { + margin-bottom: 0 +} + +.Eleditor-textEditor-linedecorations ul li { + text-align: center; + display: block; + color: #555; + font-size: 14px; + letter-spacing: 2px; + padding: 20px 0; + border-bottom: 1px solid #eee +} + +.Eleditor-textEditor-colors ul:after { + content: ''; + display: block; + clear: both; + height: 0 +} + +.Eleditor-textEditor-colors ul li { + float: left; + text-align: center; + width: 20%; + margin-bottom: 10px +} + +.Eleditor-textEditor-colors ul li span { + width: 40px; + height: 40px; + display: inline-block; + border-radius: 3px; + cursor: pointer; + position: relative +} + +.Eleditor-textEditor-colors ul li span.transparent:after, +.Eleditor-textEditor-colors ul li span.transparent:before { + position: absolute; + background: #dedede; + content: ''; + transform: rotate(45deg); + -webkit-transform: rotate(45deg) +} + +.Eleditor-textEditor-colors ul li span.transparent:after { + width: 1px; + height: 100%; + left: 50%; + top: 0 +} + +.Eleditor-textEditor-colors ul li span.transparent:before { + width: 100%; + height: 1px; + left: 0; + top: 50% +} + +.Eleditor-textEditor-fontsizes ul li, +.Eleditor-textEditor-lineheight ul li { + text-align: center; + color: #333; + font-size: 14px; + line-height: 30px +} + +.Eleditor-textStyle { + display: flex; + display: -webkit-flex; + position: relative; + border-bottom: 1px solid #eee; + overflow-x: auto; + overflow-y: hidden; + box-shadow: 0 0 10px rgba(0, 0, 0, .1); + -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, .1) +} + +.Eleditor-textStyle .Eleditor-textStyle-item { + flex: 1; + -webkit-flex: 1; + padding: 10px 0 +} + +.Eleditor-textStyle .Eleditor-textStyle-item div { + width: 24px; + height: 24px; + position: relative; + margin: auto +} + +.Eleditor-textStyle .Eleditor-textStyle-item div:before { + content: ''; + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + display: block; + background-size: 20px; + background-position: center; + background-repeat: no-repeat +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-active { + background-color: #FFE69F !important; + padding: 0; + border: 1px solid #DCAC6C; + border-radius: 2px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-bold:before { + background-image: url() +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-color:before { + background-image: url(); + background-size: 16px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-color:before { + background-position: center 3px; + background-size: 15px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-color span { + display: block; + width: 18px; + height: 1px; + background: #333; + position: absolute; + bottom: 2px; + left: 4px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-linedecoration:before { + background-image: url(); + background-size: 18px; + background-position: center 3px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-bgColor:before { + background-image: url(); + background-position: center 3px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-fontSize:before { + background-image: url(); + background-size: 22px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-lineHeight:before { + background-image: url() +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-alignLeft:before { + background-image: url(); + background-size: 25px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-alignCenter:before { + background-image: url(); + background-size: 25px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-alignRight:before { + background-image: url(); + background-size: 25px +} + +.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-upImg:before { + background-image: url(); + background-size: 22px +} + +.Eleditor-textStyle .Eleditor-textStyle-item-upImg { + display: none; + position: relative +} + +.Eleditor-textStyle .Eleditor-textStyle-item-upImg>:not(.webuploader-pick) { + transform: translate(-50%, -50%); + -webkit-transform: translate(-50%, -50%); + top: 50% !important; + left: 50% !important; + opacity: 0 +} + +.Eleditor-textStyle .Eleditor-textStyle-item-upImg>:not(.webuploader-pick) label { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100% +} + +.Eleditor-textEditor-formats { + display: none; + position: absolute; + right: -60px; + bottom: 20%; + border-radius: 50%; + -webkit-border-radius: 50%; + width: 100px; + height: 100px; + box-shadow: 0 0 5px rgba(0, 0, 0, .1); + background: #fff; + z-index: 1 +} + +.Eleditor-textEditor-formats div { + background-repeat: no-repeat; + width: 100%; + height: 32px; + background-position-x: 12px; + background-position-y: center; + position: absolute +} + +.Eleditor-textEditor-formats .Eleditor-textEditor-format { + background-image: url(); + background-size: 20px; + border-bottom: 1px solid #F5F5F5; + top: 15px +} + +.Eleditor-textEditor-formats .Eleditor-textEditor-clean { + background-image: url(); + background-size: 20px; + bottom: 15px +} + +.Eleditor-inputarea { + position: absolute; + top: 45px; + bottom: 40px; + width: 100% +} + +.Eleditor-textEditor[type=link] .Eleditor-inputarea { + bottom: 95px +} + +.Eleditor-inputarea .textarea { + -webkit-user-select: auto; + overflow-y: auto; + overflow-x: hidden; + height: 100%; + width: 100%; + padding: 10px; + box-sizing: border-box; + font-size: 14px; + color: #555; + border: none; + word-wrap: break-word; + word-break: normal +} + +.Eleditor-inputarea input { + display: none +} + +.Eleditor-inputarea .textarea img { + width: 100%; + height: auto; + box-sizing: border-box +} + +.Eleditor-textEditor[type=link] .Eleditor-inputarea input { + height: 33px; + display: block; + border: none; + border-bottom: 1px solid #ddd; + width: 100%; + margin: 10px; + color: #333; + outline: none +} + +.Eleditor-method { + border-top: 1px solid #eee; + position: absolute; + bottom: 0; + width: 100%; + box-shadow: 0 0 10px rgba(0, 0, 0, .1); + -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, .1) +} + +.Eleditor-method:after { + content: ''; + clear: both; + display: block; + height: 0 +} + +.Eleditor-method button { + width: 50%; + border: none; + padding: 0; + margin: 0; + box-sizing: border-box; + float: left; + background: #fff; + height: 40px; + color: #333 +} + +.Eleditor-method .Eleditor-commit { + border-right: 1px solid #ddd +} + +.Eleditor-placeholder { + color: #999 +} \ No newline at end of file diff --git a/ruoyi-content/src/main/resources/static/css/createArticleBase.css b/ruoyi-content/src/main/resources/static/css/createArticleBase.css new file mode 100644 index 000000000..6d12ba997 --- /dev/null +++ b/ruoyi-content/src/main/resources/static/css/createArticleBase.css @@ -0,0 +1,7 @@ +/** +* Title: Eleditor 移动端富文本编辑器 +* Site: https://eleditor.fixel.cn +* Author: Try +*/ +.Eleditor-scrollLocked{height:100%}.Eleditor-wrap.Eleditor-mask{position:absolute;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,.5)}.Eleditor-loading{display:none;position:absolute;padding:15px;background:rgba(255,255,255,.9);z-index:999;width:100%;height:100%}.Eleditor-loading p{font-size:12px;color:#666;text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);-webkit-transform:translate(-50%,-50%)}.Eleditor-loading p:before{content:'';width:25px;height:25px;margin:0 auto;background:url() no-repeat center top;background-size:100%;display:inline-block;vertical-align:middle;margin-right:10px}.Eleditor-wrap ul{list-style:none}.Eleditor-area,.Eleditor-area *,.Eleditor-wrap,.Eleditor-wrap *{cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0);tap-highlight-color:rgba(0,0,0,0)}.Eleditor-area .Eleditor-active{background:#cce0f2!important;padding:2%!important}.Eleditor-video-area video{width: 100%;}.Eleditor-iframe-area,.Eleditor-video-area,.Eleditor-audio-area{position:relative;width:100%;box-sizing:border-box}.Eleditor-iframe-area iframe{width:100%}.Eleditor-iframe-area:before,.Eleditor-video-area:before,.Eleditor-audio-area:before{position:absolute;content:'';width:100%;opacity:0;height:100%;top:0;left:0;display:block;z-index:1}.Eleditor-controller{background:#fff;position:absolute;box-sizing:border-box;transform:translate(-50%,0);-webkit-transform:translate(-50%,0);left:50%;display:none;margin-top:5px;box-shadow:0 0 20px rgba(0,0,0,.2);-webkit-box-shadow:0 0 20px rgba(0,0,0,.2);border-bottom:1px solid #e1e1e1;border-radius:3px;-webkit-border-radius:3px + background:linear-gradient(top,rgb(255,255,255) 29%,rgb(248,248,248) 74%);background:-o-linear-gradient(top,rgb(255,255,255) 29%,rgb(248,248,248) 74%);background:-moz-linear-gradient(top,rgb(255,255,255) 29%,rgb(248,248,248) 74%);background:-webkit-linear-gradient(top,rgb(255,255,255) 29%,rgb(248,248,248) 74%)}.Eleditor-controller ul{margin-bottom:2.5%}.Eleditor-controller ul:after{content:'';display:block;height:0;clear:both}.Eleditor-controller ul li{float:left;display:inline-block;width:30%;margin:2% 0 0 2.5%;height:42px;border-radius:3px;-webkit-border-radius:3px;line-height:42px;padding-left:10%;box-sizing:border-box;font-size:14px;border-right:1px solid #ddd;border-bottom:1px solid #ddd;white-space:nowrap;position:relative}.Eleditor-controller ul li.Eleditor-undo{display:none}.Eleditor-controller ul li:before{background-size:100%;background-repeat:no-repeat}.Eleditor-controller ul li:before{content:'';position:absolute;left:8px;top:12px;width:15px;height:15px;display:block;background-image:url()}.Eleditor-controller ul li.Eleditor-insertText:before{background-image:url()}.Eleditor-controller ul li.Eleditor-insertImage:before{background-image:url()}.Eleditor-controller ul li.Eleditor-undo:before{background-image:url()}.Eleditor-controller ul li div[id^='rt_rt_']{top:0!important;left:0!important;width:100%!important;height:100%!important;opacity:0;-webkit-tap-highlight-color:rgba(0,0,0,0)}.Eleditor-controller ul li.Eleditor-insertLink:before{background-image:url()}.Eleditor-controller ul li.Eleditor-insertHr:before{background-image:url()}.Eleditor-controller ul li.Eleditor-delete:before{background-image:url()}.Eleditor-controller ul li.Eleditor-cancel:before{background-image:url()}.Eleditor-controller ul li.Eleditor-editText:before{background-image:url()}@media screen and (max-width:300px){.Eleditor-controller ul li{width:30%;text-align:center;padding-left:0;font-size:12px}.Eleditor-controller ul li:before{display:none}}.Eleditor-textEditor{display:none;width:100%;height:100%;background:#fff;position:fixed;left:0;top:0}.Eleditor-textEditor-colors,.Eleditor-textEditor-fontsizes,.Eleditor-textEditor-lineheight,.Eleditor-textEditor-linedecorations{display:none;position:absolute;top:0;left:0;width:100%;height:100%;background:#fff;z-index:1}.Eleditor-textEditor-modulePane{margin:10px 8px;border-bottom:1px solid #ccc;padding-bottom:10px}.Eleditor-textEditor-linedecorations .Eleditor-textEditor-modulePane{margin-bottom:0}.Eleditor-textEditor-linedecorations ul li{text-align:center;display:block;color:#555;font-size:14px;letter-spacing:2px;padding:20px 0;border-bottom:1px solid #eee}.Eleditor-textEditor-colors ul:after{content:'';display:block;clear:both;height:0}.Eleditor-textEditor-colors ul li{float:left;text-align:center;width:20%;margin-bottom:10px}.Eleditor-textEditor-colors ul li span{width:40px;height:40px;display:inline-block;border-radius:3px;cursor:pointer;position:relative}.Eleditor-textEditor-colors ul li span.transparent:after,.Eleditor-textEditor-colors ul li span.transparent:before{position:absolute;background:#dedede;content:'';transform:rotate(45deg);-webkit-transform:rotate(45deg)}.Eleditor-textEditor-colors ul li span.transparent:after{width:1px;height:100%;left:50%;top:0}.Eleditor-textEditor-colors ul li span.transparent:before{width:100%;height:1px;left:0;top:50%}.Eleditor-textEditor-fontsizes ul li,.Eleditor-textEditor-lineheight ul li{text-align:center;color:#333;font-size:14px;line-height:30px}.Eleditor-textStyle{display:flex;display:-webkit-flex;position:relative;border-bottom:1px solid #eee;overflow-x:auto;overflow-y:hidden;box-shadow:0 0 10px rgba(0,0,0,.1);-webkit-box-shadow:0 0 10px rgba(0,0,0,.1)}.Eleditor-textStyle .Eleditor-textStyle-item{flex:1;-webkit-flex:1;padding:10px 0}.Eleditor-textStyle .Eleditor-textStyle-item div{width:24px;height:24px;position:relative;margin:auto}.Eleditor-textStyle .Eleditor-textStyle-item div:before{content:'';position:absolute;left:0;top:0;width:100%;height:100%;display:block;background-size:20px;background-position:center;background-repeat:no-repeat}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-active{background-color:#FFE69F!important;padding:0;border:1px solid #DCAC6C;border-radius:2px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-bold:before{background-image:url()}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-color:before{background-image:url();background-size:16px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-color:before{background-position:center 3px;background-size:15px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-color span{display:block;width:18px;height:1px;background:#333;position:absolute;bottom:2px;left:4px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-linedecoration:before{background-image:url();background-size:18px;background-position:center 3px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-bgColor:before{background-image:url();background-position:center 3px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-fontSize:before{background-image:url();background-size:22px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-lineHeight:before{background-image:url()}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-alignLeft:before{background-image:url();background-size:25px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-alignCenter:before{background-image:url();background-size:25px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-alignRight:before{background-image:url();background-size:25px}.Eleditor-textStyle .Eleditor-textStyle-item .Eleditor-textStyle-upImg:before{background-image:url();background-size:22px}.Eleditor-textStyle .Eleditor-textStyle-item-upImg{position:relative}.Eleditor-textStyle .Eleditor-textStyle-item-upImg-disabled{display:none}.Eleditor-textStyle .Eleditor-webUploader-btn>:not(.webuploader-pick){transform:translate(-50%,-50%);-webkit-transform:translate(-50%,-50%);top:50%!important;left:50%!important;opacity:0}.Eleditor-textStyle .Eleditor-webUploader-btn>:not(.webuploader-pick) label{position:absolute;top:0;left:0;width:100%;height:100%}.Eleditor-textEditor-formats{position:absolute;right:-60px;bottom:20%;border-radius:50%;-webkit-border-radius:50%;width:100px;height:100px;box-shadow:0 0 5px rgba(0,0,0,.1);background:#fff;z-index:1}.Eleditor-textEditor-formats div{background-repeat:no-repeat;width:100%;height:32px;background-position-x:12px;background-position-y:center;position:absolute}.Eleditor-textEditor-formats .Eleditor-textEditor-format{background-image:url();background-size:20px;border-bottom:1px solid #F5F5F5;top:15px}.Eleditor-textEditor-formats .Eleditor-textEditor-clean{background-image:url();background-size:20px;bottom:15px}.Eleditor-inputarea{position:absolute;top:45px;bottom:60px;width:100%}.Eleditor-textEditor[type=link] .Eleditor-inputarea{bottom:95px}.Eleditor-inputarea .textarea{-webkit-user-select:auto;overflow-y:auto;overflow-x:hidden;height:100%;width:100%;padding:10px;box-sizing:border-box;font-size:14px;color:#555;border:none;word-wrap:break-word;word-break:normal}.Eleditor-inputarea .textarea:empty::before{color:lightgrey;content:attr(placeholder)}.Eleditor-inputarea input{display:none}.Eleditor-inputarea .textarea img{width:100%;height:auto;box-sizing:border-box}.Eleditor-textEditor[type=link] .Eleditor-inputarea input{height:33px;display:block;border:none;border-bottom:1px solid #ddd;width:100%;margin:10px;color:#333;outline:none}.Eleditor-method{border-top:1px solid #eee;position:absolute;bottom:0;width:100%;box-shadow:0 0 10px rgba(0,0,0,.1);-webkit-box-shadow:0 0 10px rgba(0,0,0,.1)}.Eleditor-method:after{content:'';clear:both;display:block;height:0}.Eleditor-method button{width:50%;border:none;padding:0;margin:0;box-sizing:border-box;float:left;background:#fff;height:40px;color:#333}.Eleditor-method .Eleditor-commit{border-right:1px solid #ddd}.Eleditor-placeholder{color:#999}.Eleditor-deleteMode *{border:1px dashed red;text-decoration:none!important}.Eleditor-deleteMode *:empty{padding:0 10px;box-sizing:border-box}.Eleditor-delete-layer{display:none;position:fixed;bottom:0;left:0;width:100%;background:#fff;border-top:1px solid #ddd}.Eleditor-delete-tip{position:fixed;top:0;width:100%;text-align:center;line-height:28px;font-size:12px;background:rgba(255,235,59,.95);color:#F44336;border-bottom:1px solid #ffd350}.Eleditor-delete-back{padding:15px;box-sizing:border-box;width:100%;text-align:center;font-size:14px}.Eleditor-delete-back:before{content:'';background-size:100%;background-repeat:no-repeat;background-position:20% center;display:inline-block;vertical-align:bottom;width:16px;height:16px;margin-right:5px}.Eleditor-delete-revoke,.Eleditor-delete-clear{position:fixed;width:50px;height:50px;right:20px;font-size:12px;border-radius:50%;box-shadow:0 0 15px rgba(0,0,0,.2);-webkit-box-shadow:0 0 15px rgba(0,0,0,.2);background:#FF5722}.Eleditor-delete-revoke{bottom:70px;background-image:linear-gradient(to bottom,#ff5165,#ff8f8f);background-image:-webkit-linear-gradient(to bottom,#ff5165,#ff8f8f)}.Eleditor-delete-revoke-disabled{display:none}.Eleditor-delete-clear{bottom:130px;background-image:linear-gradient(to bottom,#9E9E9E,#d6d6d6);background-image:-webkit-linear-gradient(to bottom,#9E9E9E,#d6d6d6)}.Eleditor-delete-revoke:before,.Eleditor-delete-clear:before{position:absolute;left:50%;top:50%;content:'';background-size:100%;display:block;background-repeat:no-repeat}.Eleditor-delete-revoke:before{background-image:url();margin-left:-15px;margin-top:-13px;width:28px;height:28px}.Eleditor-delete-clear:before{background-image:url();margin-left:-12px;margin-top:-12px;width:24px;height:24px}.Eleditor-delete-back:before{background-image:url()} diff --git a/ruoyi-content/src/main/resources/static/css/createArticleStyle.css b/ruoyi-content/src/main/resources/static/css/createArticleStyle.css new file mode 100644 index 000000000..d46edb893 --- /dev/null +++ b/ruoyi-content/src/main/resources/static/css/createArticleStyle.css @@ -0,0 +1,343 @@ +/* 公共 */ + +* { + padding: 0; + margin: 0; + font-family: "微软雅黑"; + transition: all .2s cubic-bezier(.6, .1, .1, .7); +} + +html, +body { + height: 100%; +} + +li { + list-style-type: none; +} + +hr { + height: 1px; + background: #e4e4e4; +} + +body { + display: flex; + flex-direction: column; + background: #f6f7f8; +} + +button { + border: none; + filter: contrast(1); +} + +button:active { + filter: contrast(.9); +} + +textarea { + resize: none; +} + +/* edit页面 */ + +/* 部分css效果在公共组件部分 */ + +/* 包含Eleditor的样式修正*/ + +#edit_head>.b { + padding: 0 0 0 calc(2.36rem - 1.68rem); +} + +#edit_head>.c { + margin: 0 0.4rem 0 0; + width: 2.36rem; + height: 100%; + background: #fff; +} + +#edit_head>.c>img { + width: 2.36rem; +} + +#edit_cue { + font-size: 0.52rem; + line-height: 1.2rem; + text-align: center; + color: #37c7aa; + background: #d8efe9; +} + +#edit_body { + flex-grow: 1; + padding: 0 0.6rem; + width: 13.8rem; +} + +#edit_body .a { + word-break: break-all; + margin: .6rem 0 1.4rem; + padding: 0.6rem 0.5rem; + border: #37c7aa dashed 1px; +} + +#edit_body .b { + font-size: 0.52rem; + color: #37c7aa; + text-align: right; + margin-top: -1rem; + padding: 0 0.1rem; + margin-left: 8.4rem; + padding-bottom: 1rem; + background: #f3f3f3; + width: 4rem; +} + +.Eleditor-controller { + z-index: 10000; + max-width: fit-content; +} +.Eleditor-wrap { + width: 100px; +} +.Eleditor-controller ul li { + font-size: .52rem !important; + width: 90px !important; + margin: 5px 5px 0; + padding-left: 30px; +} +.Eleditor-controller ul { + margin: 0; + margin-bottom: 5px; +} + +/* + * 当前页面的样式 + */ + #div1 { + margin:10px auto; + border:1px solid #ccc; + } + #div1 .title { + width: 100%; + margin: 0 auto; + position: relative; + z-index: 0; + padding: 5px 24px; + border-top:1px solid #ccc; + box-sizing: border-box; + background: #fff; + } + .text{ + min-height: 27.43px; + } + .w-e-text p { + display: none; + } + .head,.author{ + display: block; + width: 100%; + font-size: 20px; + color: #000; + min-height: 30px; + margin-bottom: 5px; + outline: none; + resize: none; + border:none; + } + .head { + font-size: 24px; + } + .head[contenteditable]:empty:before, .author[contenteditable]:empty:before{ + content: attr(placeholder); + color: #D4D4D4; + } + .head[contenteditable]:focus,.author[contenteditable]:focus{ + content:none; + } + .editorcontent{ + width:800px; + font-size: 18px; + line-height: 20px; + height: 370px; + overflow: auto; + padding-top: 10px; + border-top: 1px solid #ccc; + } + .editorcontent div{ + min-height: 27.43px; + line-height: 24px; + font-size: 15px; + } + /* 上传图片*/ + .abstract { + font-size: .26rem; + margin:10px 0; + color: #333; + } + .cover_abstract { + width:100%; + display: flex; + } + .imgload { + position: relative; + width:25%; + text-align: center; + overflow: hidden; + height: 90px; + line-height: 90px; + background-color: #fbfdff; + border: 1px dashed #c0ccda; + border-radius: 6px; + margin: 0 10px; + box-sizing: border-box; + } + .fileImg { + position: absolute; + top: 0; + left: 0; + display: inline-block; + width: 100%; + height: 100%; + background: none; + margin: 0px; + padding: 0px; + opacity: 0; + filter: alpha(opacity=0); + cursor: pointer; + z-index: 2; + } + .avatar { + position: absolute; + top: 0; + left: 0; + display: inline-block; + width: 100%; + height: 100%; + z-index: 1; + } + .addIcon { + position: relative; + top: 0; + left: 0; + display: inline-block; + width: 100%; + height: 100%; + } + .addIcon::before{ + content: ''; + position: absolute; + left: 50%; + top: 50%; + width: 30px; + margin-left: -15px; + margin-top: -2px; + border-top: 2px solid #cccccc; + } + .addIcon::after { + content: ''; + position: absolute; + left: 50%; + top: 50%; + height: 30px; + margin-left: -2px; + margin-top: -15px; + border-left: 2px solid #ccc; + } + :focus { + outline: none; + } + .lables{ + height: 200px; + width: 200px; + border: 1px solid #ccc; + position: fixed; + top: 50%; + left: 50%; + margin-top: -100px; + margin-left: -100px; + background: white; + z-index: 555; + } + .lables p{ + font-size: 14px; + color: #fff; + text-align: center; + background: #409eff; + padding: 0; + height: 30px; + line-height: 30px; + } + .lables label { + display: block; + font-size: 15px; + margin: 5px 0 5px 20px; + } + .lables label input{ + margin: 0 10px 0 0; + } + .lables_box { + height: 135px; + overflow-y: scroll; + } + #sures{ + display: block; + position: absolute; + bottom: 4px; + left: 0; + right: 0; + color: #fff; + width: 90px; + font-size: 14px; + text-align: center; + line-height: 30px; + background: #409eff; + border-radius: 5px; + margin: 0 auto; + } + /*样式修改*/ + .textarea { + width:1000px; + margin: 0 auto; + } + .seldiv { + position: relative; + } + /*.w-e-text-container .label{ + position: absolute; + top: 50%; + right: 5px; + float: right; + background: rgba(0,205,50, 0.4); + display: flex; + font-size: 12px; + line-height: 14px; + color: #fff; + align-items: center; + justify-content: center; + padding: 0 3px; + transform: translateY(-50%); + box-shadow: -1px 1px 1px rgba(0,0,0,0.3); + margin: 10px 3px 0 12px; + }*/ + .w-e-text-container .label{ + display: inline-block; + min-width: 50px; + background: rgba(0,205,50, 0.4); + font-size: 12px; + line-height: 24px; + color: #fff; + padding: 0 6px; + box-shadow: -1px 1px 1px rgba(0,0,0,0.3); + margin: 0 10px 0 0; + } + /*.w-e-text-container .label::after{ + content: ""; + position: absolute; + left: 100%; + top: 2px; + border-style: solid; + border-color: transparent transparent transparent rgba(0,205,50, 0.4); + border-width: 13px; + }*/ \ No newline at end of file diff --git a/ruoyi-content/src/main/resources/static/js/Eleditor.min.js b/ruoyi-content/src/main/resources/static/js/Eleditor.min.js new file mode 100644 index 000000000..7e3bdb038 --- /dev/null +++ b/ruoyi-content/src/main/resources/static/js/Eleditor.min.js @@ -0,0 +1,936 @@ +/** +* Version: 1.8.9 +* Title: Eleditor 移动端富文本编辑器 +* Site: https://eleditor.fixel.cn +* Doc: http://doc.eleditor.fixel.cn +* Author: Try +*/ +(function(w){ + + /*polyfill*/ + if (typeof Object.assign != 'function') { + // Must be writable: true, enumerable: false, configurable: true + Object.defineProperty(Object, "assign", { + value: function assign(target, varArgs) { // .length of function is 2 + 'use strict'; + if (target == null) { // TypeError if undefined or null + throw new TypeError('Cannot convert undefined or null to object'); + } + + var to = Object(target); + + for (var index = 1; index < arguments.length; index++) { + + var nextSource = arguments[index]; + + if (nextSource != null) { // Skip over if undefined or null + for (var nextKey in nextSource) { + // Avoid bugs when hasOwnProperty is shadowed + if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) { + to[nextKey] = nextSource[nextKey]; + } + } + } + } + return to; + }, + writable: true, + configurable: true + }); + } + + var _debug = false; + var _version = '1.8.9' + var _namespace = 'Eleditor'; + var _notctname = ['INPUT', 'IMG', 'TEXTAREA']; + var _toolnames = { + insertText: '插文字', + insertImage: '插图片', + insertLink: '插链接', + insertHr: '水平线', + editText: '改文字', + "delete": '删除', + undo: '撤销', + cancel: '取消', + }; + var _editorTpl = ''; + + w[_namespace] = function(){}; + + if( typeof jQuery === 'undefined' && typeof Zepto === 'undefined' ){ + return console.warn('|--Eleditor 请引入jQuery或者Zepto!模块化环境请把依赖全局安装'); + }else if( typeof $ === 'undefined' ){ + var $ = typeof jQuery != 'undefined' ? jQuery : Zepto; + } + + var _scriptPath = function(func){ + var _js = document.scripts; + _js = _js[ _js.length - 1 ].src.substring(0, _js[ _js.length-1 ].src.lastIndexOf("/") + 1 ); + func(_js); + return _js; + }(function(s){ + var _buildLib = ''; + $('head').append(_buildLib); + }); + + var _inArray = function(s,a){ + for(var i in a){ + if(a[i]==s){ + return true; + } + } + return false; + }; + var _formatInnerText = function (t) { + var s = t.replace(/\ +/g, ""); + s = s.replace(/[ ]/g, ""); + s = s.replace(/[\r\n]/g, ""); + return s.replace(/(^\s*)|(\s*$)/g, ""); + }; + var _getLayerMaxZIndex = function(){ + var _max = Math.max.apply(null, +   $.map($('body *'), function(e) { + var _$e = $(e); + if (_$e.css('position') != 'static') + return parseInt(_$e.css('z-index')) || 1; + })); + return (_max + '').indexOf('Infinity') >= 0 ? 1 : _max + 1; + }; + + var _genEditorUid = function(){ + return _namespace + '' + +new Date; + }; + + + var _correctHtmlStructure = function(){ + + var _$wrap = arguments[0], + _empty = arguments[1]; + + + $.each(_$wrap.find('iframe,audio,video'), function() { + var _$this = $(this), + _tagName = this.tagName.toLocaleLowerCase(); + + if( !_$this.parent().hasClass('Eleditor-'+_tagName+'-area') ){ + $(this).wrap('

'); + } + }); + + + + if( _formatInnerText(_$wrap.text()) == '' && _$wrap.find('img,iframe,video').length === 0 ){ + _$wrap.append(_empty); + } + + if( _$wrap.find('*').length === 0 ){ + _$wrap.html('

'+_$wrap.html()+'

'); + } + }; + + var _buildEditorModule = function(_toolbars, _uid){ + + var _layerZIndex = _getLayerMaxZIndex(); + var _html = '
\ +
\ +
    '; + + for (var i = 0; i < _toolbars.length; i++) { + var _it = _toolbars[i], + _id = typeof _it === 'object' ? _it.id : _it, + _tag = (typeof _it === 'object' && _it.tag) ? _it.tag.toLocaleLowerCase() : null, + _name = typeof _it === 'object' ? _it.name : _toolnames[_it]; + _html += '
  • '+_name+'
  • '; + } + _html += '
\ +
\ +

\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
\ +
    \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ +
  • \ + \ + \ +
  • \ +
\ +
\ +
\ +
字体大小
\ +
    \ +
  • 默认
  • \ +
  • 14px
  • \ +
  • 16px
  • \ +
  • 20px
  • \ +
  • 28px
  • \ +
  • 35px
  • \ +
\ +
\ +
\ +
行高
\ +
    \ +
  • 默认
  • \ +
  • 20px
  • \ +
  • 25px
  • \ +
  • 30px
  • \ +
  • 35px
  • \ +
  • 40px
  • \ +
\ +
\ +
\ +
文本修饰
\ +
    \ +
  • \ +
  • 上划线修饰
  • \ +
  • 删除线修饰
  • \ +
  • 下划线修饰
  • \ +
\ +
\ +
\ +
\ +
\ +
\ +
\ + \ +
\ +
\ +
\ + \ + \ +
\ +
\ +
\ +
进入批量删除模式,点击段落进行删除
\ +
\ +
\ +
返回继续编辑
\ +
\ +
'; + return _html; + }; + + w[_namespace] = function(){ + + console.log('|--Eleditor Initing'); + + var _args = arguments[0]; + _args.upload = _args.upload || {}; + _args.mounted = _args.mounted || function(){}; + _args.changer = _args.changer || function(){}; + _args.toolbars = _args.toolbars || [], + // _undolen = isNaN(_args._undolen) ? 10 : _args._undolen; + _editorUid = _genEditorUid(), + _historys = [], + _placeHolder = _args.placeHolder || '

点击此处编辑内容

', + _uploadRole = null; + + if( _args.toolbars.length === 0 ){ + _args.toolbars = [ + 'insertText', + 'editText', + 'insertImage', + 'insertLink', + 'insertHr', + 'delete', + 'undo', + 'cancel', + ]; + } + + if( _args.el instanceof jQuery ){ + var _$wrap = _args.el; + }else{ + var _$wrap = $(_args.el); + + if( _$wrap.length === 0 ){ + return console.warn('|--Eleditor '+_args.el+'元素不存在,请在DOMContentLoaded后初始化Eleditor'); + }else if( _$wrap.length != 1 ){ + var _$wrap = $(_$wrap[0]); + } + + } + + if( _$wrap.attr('Eleditor-Inited') === 'true' ){ + return console.warn('|--Eleditor '+_args.el+'已经绑定了Eleditor'); + } + + _$wrap.attr({'Eleditor-Inited': 'true', 'Eleditor-Uid': _editorUid}); + + _correctHtmlStructure(_$wrap, _placeHolder); + + /*insert editor*/ + var _lastScrollH = null; + var _$window = $(w); + var _$scrollWrap = $('html,body'); + var _$editorWrap = $(_buildEditorModule(_args.toolbars, _editorUid)); + var _$editorController = _$editorWrap.find('.Eleditor-controller'); + var _$editorLoadingMask = _$editorWrap.find('.Eleditor-loading'); + var _$editorTextModule = _$editorWrap.find('.Eleditor-textEditor'); + var _$editorTextArea = _$editorTextModule.find(".Eleditor-inputarea .textarea"); + var _$editorUploadImageBtn = _$editorController.find(".Eleditor-insertImage"); + var _$editorBarUploadImageBtn = _$editorTextModule.find('.Eleditor-textStyle-item-upImg'); + var _$editorTextLinkArea = _$editorTextModule.find(".Eleditor-inputarea input"); + var _$editorColorModule = _$editorTextModule.find(".Eleditor-textEditor-colors"); + var _$editorFontsizeModule = _$editorTextModule.find(".Eleditor-textEditor-fontsizes"); + var _$editorUndoBtn = _$editorWrap.find(".Eleditor-undo"); + var _$editorLineheightModule = _$editorTextModule.find(".Eleditor-textEditor-lineheight"); + var _$editorLinedecorationsModule = _$editorTextModule.find(".Eleditor-textEditor-linedecorations"); + var _$editorDeleteLayer = _$editorWrap.find(".Eleditor-delete-layer"); + + _$wrap.addClass('Eleditor-area'); + _$wrap.after(_$editorWrap); + + console.log('|--Eleditor Mounted To', _$wrap); + + /*bindEvent*/ + var _$selected = null, + _imageUploader = null; + + var _showEditorControllerLayer = function(_$e){ + _$selected = _$e; + _$e.addClass('Eleditor-active'); + + var _calTop = _$e.offset().top + _$e.outerHeight(); + + $.each(_$editorController.find('li'), function(i, e){ + var _$e = $(e), + _tgs = _$e.attr('bind-tags'); + if( _tgs ){ + _tgs = _tgs.toLocaleLowerCase().split(','); + if( _inArray(_$selected[0].tagName.toLocaleLowerCase(), _tgs) ){ + _$e.show(); + }else{ + _$e.hide(); + } + } + }); + + _$editorController.show(); + _flushEditorControllerLayerPosi(); + + if( typeof _$scrollWrap.animate === 'function' ){ + _$scrollWrap.stop().animate({scrollTop: (_calTop - 150) + 'px'}, 500); + }else{ + _$scrollWrap.scrollTop((_calTop - 150) + 'px'); + } + + _imageUploader && _imageUploader.refresh(); + }; + + var _flushEditorControllerLayerPosi = function(){ + if( _$selected ){ + _$editorController.css({ + top: _$selected.offset().top + _$selected.outerHeight(), + width: _$wrap.width() - 5 + }); + } + }, + _hideEditorControllerLayer = function(){ + + _$wrap.find('.Eleditor-active').removeClass('Eleditor-active'); + _$editorController.hide(); + _$selected = null; + }; + + var _showEditorDeleteLayer = function(){ + + _flushEditorDeleteLayerHistoryBtn(); + + _$wrap.addClass('Eleditor-deleteMode'); + _$editorDeleteLayer.show(); + }, + _flushEditorDeleteLayerHistoryBtn = function(){ + + if( _historys.length > 0 ){ + _$editorWrap.find('.Eleditor-delete-revoke').removeClass('Eleditor-delete-revoke-disabled') + }else{ + _$editorWrap.find('.Eleditor-delete-revoke').addClass('Eleditor-delete-revoke-disabled') + } + }, + _hideEditorDeleteLayer = function(){ + _$wrap.removeClass('Eleditor-deleteMode'); + _$editorDeleteLayer.hide(); + }; + + var _showEditorWrapMask = function(){ + _$editorController.hide(); + _$editorWrap.addClass('Eleditor-mask'); + _lastScrollH = _$window.scrollTop(); + _$scrollWrap.addClass('Eleditor-scrollLocked'); + }, + _hideEditorWrapMask = function(){ + _$editorWrap.removeClass('Eleditor-mask'); + _$scrollWrap.removeClass('Eleditor-scrollLocked'); + _$window.scrollTop(_lastScrollH); + }; + + var _showLoadingMask = function(){ + _showEditorWrapMask(); + _$editorLoadingMask.show(); + _$editorLoadingMask.html('

'+arguments[0]+'

') + }, + _hideLoadingMask = function(){ + _hideEditorWrapMask(); + _$editorLoadingMask.hide(); + }; + + var _appendHistory = function(){ + + _historys.push( _$wrap.html() ); + + // if( _historys.length > _undolen ){ + // _historys.splice(0, 1) + // } + + _flushHistoryBtn(); + _flushEditorDeleteLayerHistoryBtn(); + return true; + }, + _revokeEdit = function(){ + + if( _historys.length === 0 ){ + return; + } + + _$wrap.html(_historys.pop()); + _args.changer(); + + _flushHistoryBtn(); + _flushEditorDeleteLayerHistoryBtn(); + _hideEditorControllerLayer(); + }, + _flushHistoryBtn = function(){ + + if( _historys.length == 0 ){ + _$editorUndoBtn.hide(); + }else{ + _$editorUndoBtn.show(); + } + + }; + + var _syncRenderTextEditorView = function(){ + _$editorTextModule.attr('role', 'edit').show(); + _$editorTextArea.html( _$selected.hasClass('Eleditor-placeholder') ? '' : _$selected.html() ); + _$editorTextArea.attr('style', _$selected.attr('style')); + if( _$selected.css('font-weight') == 'bold' ){ + _$editorTextModule.find('.Eleditor-textStyle-bold').addClass('Eleditor-active'); + } + + if( _inArray(_$selected.css('text-decoration'), ['overline', 'line-through', 'underline']) ){ + _$editorTextModule.find('.Eleditor-textStyle-linedecoration').addClass('Eleditor-active'); + } + if( _$selected[0].tagName == 'A' ){ + _$editorTextModule.attr('type', 'link'); + _$editorTextLinkArea.val(_$selected.attr('href')); + }else{ + _$editorTextModule.attr('type', 'word'); + } + + var _selectAlign = _$selected.css('text-align'); + if( _inArray(_selectAlign, ['left', 'center', 'right']) ){ + _$editorTextModule.find('.Eleditor-textStyle-align[align='+_selectAlign+']').addClass('Eleditor-active'); + }else{ + _$editorTextModule.find('.Eleditor-textStyle-align').removeClass('Eleditor-active'); + } + _$editorTextModule.find('.Eleditor-textStyle-color span').css('background-color', _$selected.css('color')); + }; + + if( typeof WebUploader != 'undefined' && typeof _args.uploader != 'function' ){ + + //controller + _imageUploader = WebUploader.create({ + auto: true, + server: _args.upload.server || '/upload', + pick: _$editorUploadImageBtn, + resize: false, + headers: _args.upload.headers || {}, + formData: _args.upload.formData || {}, + duplicate: true, + fileSingleSizeLimit: _args.upload.fileSizeLimit ? _args.upload.fileSizeLimit*1024*1024 : undefined, + accept: Object.assign({ + title: 'Images', + extensions: 'gif,jpg,jpeg,bmp,png,webp', + mimeTypes: 'image/gif,image/jpg,image/jpeg,image/bmp,image/png,image/webp' + }, _args.upload.accept || {}), + fileVal: _args.upload.formName, + }); + _imageUploader.on( 'uploadStart', function( _file, _percentage ) { + _showLoadingMask('上传图片中1%'); + }); + _imageUploader.on( 'uploadProgress', function( _file, _percentage ) { + $('#uploadProgress').html( parseFloat((_percentage * 100).toFixed(2)) ); + }); + // _uploadRole + _imageUploader.on( 'error', function() { + if( arguments[0]=="Q_TYPE_DENIED" ) w.alert("请上传图片格式文件"); + if( arguments[0]=="F_EXCEED_SIZE" ) w.alert("文件大小不能超过"+(arguments[1] / 1048576)+"M"); + }); + _imageUploader.on( 'uploadComplete', function() { _hideLoadingMask(); }); + _imageUploader.on( 'uploadSuccess', function( _file, _call ) { + + var _hasStyleBarBtn = $('#rt_'+_file.source.ruid).parents('.Eleditor-textStyle-item-upImg').length > 0; + + if( _call.status == 1 ){ + + if( _hasStyleBarBtn ){ + _$editorTextArea.append(''); + }else{ + _appendHistory(); + + _$selected.after( $('') ); + + if( _$selected.hasClass('Eleditor-placeholder') ){ + _$selected.remove(); + } + } + _args.changer(); + }else{ + w.alert('上传失败:['+_call.msg+']'); + } + if( !_hasStyleBarBtn ){ + _hideEditorControllerLayer(); + } + }); + + _imageUploader.addButton({ id: _$editorBarUploadImageBtn }); + _$editorBarUploadImageBtn.addClass('Eleditor-webUploader-btn'); + + }else if( typeof _args.uploader == 'function' ){ + + var _uploaderHanlder = function(){ + + var _hasStyleBarBtn = $(this).hasClass('Eleditor-textStyle-item-upImg'); + + try{ + _args.uploader.call(this).then(function(_url){ + + var _urls = typeof _url === 'object' && _url.length ? _url : [_url] + + if( _hasStyleBarBtn ){ + + for (var _uindex = 0; _uindex < _urls.length; _uindex++) { + _$editorTextArea.append(''); + } + }else{ + _appendHistory(); + + for (var _uindex = 0; _uindex < _urls.length; _uindex++) { + _$selected.after( $('') ); + } + + if( _$selected.hasClass('Eleditor-placeholder') ){ + _$selected.remove(); + } + _hideEditorControllerLayer(); + } + _args.changer(); + }, function(_err){ + w.alert('上传失败:['+_err+']'); + }); + }catch(_e){ + console.warn(_e); + console.warn('|--Eleditor 请检查uploader函数返回是否是标准Promise对象!'); + } + + } + + _$editorUploadImageBtn.click(_uploaderHanlder); + _$editorBarUploadImageBtn.click(_uploaderHanlder); + + }else{ + _$editorBarUploadImageBtn.addClass('Eleditor-textStyle-item-upImg-disabled') + } + + var _editorModuleEvents = { + insertText: function(){ + _showEditorWrapMask(); + _$editorTextModule.attr({'role': 'insert', 'type': 'word'}).show(); + }, + insertLink: function(){ + alert(444) + _showEditorWrapMask(); + _$editorTextModule.attr({'role': 'insert', 'type': 'link'}).show(); + }, + insertImage: function(){ + if( typeof WebUploader === 'undefined' && typeof _args.uploader != 'function' ){ + window.alert('上传参数未定义.'); + } + }, + insertHr: function(){ + + _appendHistory(); + + var _$hr = $('
'); + _$selected.after(_$hr); + _args.changer(); + _hideEditorControllerLayer(); + }, + editText: function(){ + if( _inArray(_$selected[0].tagName, _notctname) ){ + return this.insertText(); + } + _showEditorWrapMask(); + _syncRenderTextEditorView(); + }, + "delete": function(){ + + if( _$wrap.find('*').length == 1 ){ + _appendHistory(); + _args.changer(); + _$selected.remove(); + }else{ + _showEditorDeleteLayer(); + } + _hideEditorControllerLayer(); + _correctHtmlStructure(_$wrap, _placeHolder); + }, + undo: function(){ + _revokeEdit(); + }, + cancel: function(){ + _hideEditorControllerLayer(); + } + }; + + for (var i = 0; i < _args.toolbars.length; i++) { + if( typeof _args.toolbars[i] === 'object' ){ + _editorModuleEvents[_args.toolbars[i].id] = _args.toolbars[i].handle; + } + }; + + /*text area click*/ + _$window.on('resize', function(){ + _flushEditorControllerLayerPosi(); + }); + + _$editorController.on('click', 'ul li', function() { + var _$this = $(this), + _event = _$this.attr('event'); + if( typeof _editorModuleEvents[_event] === 'function' ){ + if( typeof _toolnames[_event] != 'undefined' ){ + _editorModuleEvents[_event](); + }else{ + _editorModuleEvents[_event](_$selected, _$this) !== false && _editorModuleEvents.cancel(); + } + } + }); + + _$editorWrap.on('click', '.Eleditor-delete-revoke', function() { + _revokeEdit(); + }); + _$editorDeleteLayer.on('click', '.Eleditor-delete-clear', function() { + + if( !confirm('确定清空内容吗?') ){ + return; + } + + var _$cloneNode = _$wrap.clone(); + _$cloneNode.find('.Eleditor-placeholder').remove(); + + if( _formatInnerText(_$cloneNode.text()) != '' ){ + _appendHistory(); + _$wrap.html(''); + _args.changer(); + _correctHtmlStructure(_$wrap, _placeHolder); + } + }); + _$editorDeleteLayer.on('click', '.Eleditor-delete-back', function() { + _hideEditorDeleteLayer(); + }); + + /*textEditor*/ + _$editorTextModule.on('click', '.Eleditor-textStyle-bold', function() { + _$editorTextArea.css("font-weight", $(this).hasClass("Eleditor-active") ? "normal" : "bold"); + $(this).toggleClass("Eleditor-active"); + }); + _$editorTextModule.on('click', '.Eleditor-textStyle-linedecoration', function() { + _$editorLinedecorationsModule.show(); + $(this).addClass('Eleditor-active'); + }); + _$editorTextModule.on('click', '.Eleditor-textStyle-color,.Eleditor-textStyle-bgColor', function() { + var _$this = $(this); + var _role = _$this.hasClass('Eleditor-textStyle-bgColor') ? 'bgcolor' : 'color'; + _$editorColorModule.find('.Eleditor-textEditor-modulePane span').html(_role == 'bgcolor' ? '文字背景颜色' : '文字颜色'); + _$editorColorModule.attr('role', _role).show(); + $(this).addClass('Eleditor-active'); + }); + _$editorTextModule.on('click', '.Eleditor-textStyle-fontSize', function() { + _$editorFontsizeModule.show(); + $(this).addClass('Eleditor-active'); + }); + _$editorTextModule.on('click', '.Eleditor-textStyle-lineHeight', function() { + _$editorLineheightModule.show(); + $(this).addClass('Eleditor-active'); + }); + _$editorLinedecorationsModule.on('click', 'ul li', function() { + if( !$(this).hasClass('Eleditor-inheritValue') ){ + _$editorTextArea.css("text-decoration", $(this).css('text-decoration')); + }else{ + _$editorTextArea.css("text-decoration", 'inherit'); + _$editorTextModule.find('.Eleditor-textStyle-linedecoration').removeClass('Eleditor-active'); + } + _$editorLinedecorationsModule.hide(); + }); + _$editorLineheightModule.on('click', 'ul li', function() { + if( !$(this).hasClass('Eleditor-inheritValue') ){ + _$editorTextArea.css("line-height", $(this).html()); + }else{ + _$editorTextArea.css("line-height", 'inherit'); + _$editorTextModule.find('.Eleditor-textStyle-lineHeight').removeClass('Eleditor-active'); + } + _$editorLineheightModule.hide(); + }); + _$editorFontsizeModule.on('click', 'ul li', function() { + if( !$(this).hasClass('Eleditor-inheritValue') ){ + _$editorTextArea.css("font-size", $(this).html()); + }else{ + _$editorTextArea.css("font-size", 'inherit'); + _$editorTextModule.find('.Eleditor-textStyle-fontSize').removeClass('Eleditor-active'); + } + _$editorFontsizeModule.hide(); + }); + + _$editorTextModule.on('click', ".Eleditor-textStyle-align", function() { + var _align = $(this).attr('align'); + _$editorTextArea.css({"text-align": _align, "display": 'block'}); + _$editorTextModule.find(".Eleditor-textStyle-align.Eleditor-active").removeClass('Eleditor-active'); + $(this).addClass('Eleditor-active'); + }); + + _$editorTextModule.on('click', ".Eleditor-textEditor-format", function() { + var _$cloneTextArea = _$editorTextArea, + _removeAttrs = 'style width height border bgcolor align color'; + + _$cloneTextArea.removeAttr(_removeAttrs); + $.each(_$cloneTextArea.find('*'), function(_i, _e) { + var _$eachElm = _$cloneTextArea.find(_e); + if( _inArray(_e.tagName.toLocaleLowerCase(), ['script', 'style']) ){ + _$eachElm.remove(); + }else{ + _$eachElm.removeAttr(_removeAttrs); + } + }); + + _$editorTextArea.html(_$cloneTextArea.html()); + _$editorTextModule.find('.Eleditor-active').removeClass('Eleditor-active'); + }); + + _$editorTextModule.on('click', ".Eleditor-textEditor-clean", function() { + confirm('确定清空内容(不可恢复)?') && _$editorTextArea.html(""); + }); + + _$editorTextModule.on('click', ".Eleditor-cancel,.Eleditor-commit", function() { + + arguments[0].preventDefault(); + + if( $(this).hasClass('Eleditor-commit') ){ + var _style = _$editorTextArea.attr('style') || ''; + var _content = _$editorTextArea.html(); + var _editAct = _$editorTextModule.attr('role') == 'edit'; + var _hasPlaceHolder = _$selected.hasClass('Eleditor-placeholder'); + + if( !_content ){ + return alert('请输入内容文字'); + } + + _appendHistory(); + + if( _editAct || (_hasPlaceHolder && _$editorTextModule.attr('type') != 'link') ){ + if( _$editorTextModule.attr('type') == 'link' ){ + _$selected.attr('href', _$editorTextLinkArea.val()); + } + _$selected.attr('style', _style).removeClass('Eleditor-placeholder').html( _content ); + }else{ + + var _buildWordHtml = ''; + if( _$editorTextModule.attr('type') == 'link' ){ + var _link = _$editorTextLinkArea.val(); + _buildWordHtml = ''+_content+''; + }else{ + _buildWordHtml = '

'+_content+"

"; + } + _$selected.after( $(_buildWordHtml) ); + + if( _hasPlaceHolder ){ + _$selected.remove(); + } + } + _args.changer(); + _flushEditorControllerLayerPosi(); + } + + _$editorTextModule.find('.Eleditor-active').removeClass('Eleditor-active'); + _$editorTextModule.find('.Eleditor-textStyle-color span').removeAttr('style'); + _$editorTextArea.removeAttr('style').html(''); + _$editorTextLinkArea.val(''); + _hideEditorWrapMask(); + _$editorTextModule.hide(); + _hideEditorControllerLayer(); + + }); + + _$editorColorModule.on('click', 'ul li span', function() { + var _color = $(this).css('background-color'); + if( _$editorColorModule.attr('role') == 'color' ){ + if( !$(this).hasClass('Eleditor-inheritValue') ){ + _$editorTextArea.css("color", _color); + _$editorTextModule.find('.Eleditor-textStyle-color span').css("background-color", _color); + }else{ + _$editorTextArea.css("color", 'inherit'); + _$editorTextModule.find('.Eleditor-textStyle-color').removeClass('Eleditor-active').find('span').removeAttr('style'); + } + }else{ + if( !$(this).hasClass('Eleditor-inheritValue') ){ + _$editorTextArea.css("background-color", _color); + }else{ + _$editorTextArea.css("background-color", 'inherit'); + _$editorTextModule.find('.Eleditor-textStyle-bgColor').removeClass('Eleditor-active'); + } + } + _$editorColorModule.hide(); + }); + + /*controller*/ + _$wrap.on('dblclick', '*', function(_e) { + + var _$this = $(this); + + if( _$wrap.hasClass('Eleditor-deleteMode') ){ + + if( !_$this.hasClass('Eleditor-placeholder') ){ + + _appendHistory(); + + if( typeof _$this.fadeOut === 'function' ){ + _$this.fadeOut('fast', function(){ + _$this.remove(); + _correctHtmlStructure(_$wrap, _placeHolder); + }); + }else{ + _$this.remove(); + _correctHtmlStructure(_$wrap, _placeHolder); + } + _args.changer(); + } + + }else if( !_$this.hasClass('Eleditor-active') ){ + _hideEditorControllerLayer(); + _hideEditorDeleteLayer(); + _showEditorControllerLayer(_$this); + } + + return _e.preventDefault() == 0; + }); + + /*call*/ + _args.mounted(); + + return { + clear: function(){ + _args.changer(); + _$wrap.html(''); + _correctHtmlStructure(_$wrap, _placeHolder); + }, + revoke: function(){ + _revokeEdit(); + }, + append: function(){ + + _hideEditorControllerLayer(); + + var _object = arguments[0]; + + if( !_object ){ + return; + } + + var _$content = $(_object); + + if( typeof _object == 'string' && _$content.length == 0 ){ + _$content = $('

'+_object+'

'); + } + + _$wrap.find('.Eleditor-placeholder').remove(); + _appendHistory(); + + return _$wrap.append(_$content); + }, + trigger: function(){ + + var _event = arguments[0]; + + if( _event == 'insertText' ){ + _$selected = _$wrap.find('>:last'); + _editorModuleEvents.insertText(); + }else if( _event == 'insertLink' ){ + _$selected = _$wrap.find('>:last'); + _editorModuleEvents.insertLink(); + } + }, + saveState: function(){ + return _appendHistory(); + }, + getEditNode: function(){ + return _$selected; + }, + getContent: function(){ + var _$cloneNode = _$wrap.clone(); + _$cloneNode.find('.Eleditor-placeholder').remove(); + _$cloneNode.find('.Eleditor-active').removeClass('Eleditor-active'); + return _$cloneNode.html(); + }, + getContentText: function(){ + var _$cloneNode = _$wrap.clone(); + _$cloneNode.find('.Eleditor-placeholder').remove(); + + return _formatInnerText(_$cloneNode.text()); + }, + hideEditorControllerLayer: _hideEditorControllerLayer, + destory: function(){ + _$wrap.removeAttr('Eleditor-Inited Eleditor-Uid'); + _$wrap.removeClass('Eleditor-area'); + _$wrap.find('.Eleditor-placeholder').remove() + _$wrap.off().find('.Eleditor-active').removeClass('Eleditor-active'); + _$editorWrap.find('*').off(); + _$editorWrap.remove(); + console.log('|--Eleditor '+_editorUid+' destoryed'); + } + + } + } + +})(window); diff --git a/ruoyi-content/src/main/resources/templates/content/article/articleManage.html b/ruoyi-content/src/main/resources/templates/content/article/articleManage.html index 3993d4d92..55f4482a8 100644 --- a/ruoyi-content/src/main/resources/templates/content/article/articleManage.html +++ b/ruoyi-content/src/main/resources/templates/content/article/articleManage.html @@ -402,56 +402,56 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -739,17 +739,18 @@ } function createArticle() { - $('.head').html(''); - $('.author').html(''); - $('.el-textarea__inner').val(''); - $('.editorcontent').html('
'); - - - filePath = ''; - $(".avatar").attr('src', '') - $(".avatar").css('display', 'none'); - $(".addIcon").css('display', 'block'); - $('#myModal5').modal('show'); + // $('.head').html(''); + // $('.author').html(''); + // $('.el-textarea__inner').val(''); + // $('.editorcontent').html('
'); + // + // + // filePath = ''; + // $(".avatar").attr('src', '') + // $(".avatar").css('display', 'none'); + // $(".addIcon").css('display', 'block'); + // $('#myModal5').modal('show'); + $.modal.parentTab('文章创建', prefix + "/createPage"); } function createArticleL() { @@ -778,21 +779,6 @@ '
' + title + '
' + '
' + author + '
' + body + '
'; - body = body + ''; - $('#myModal5').modal('hide'); $.modal.loading("创建文章中请等待。。。"); $.ajax({ diff --git a/ruoyi-content/src/main/resources/templates/content/article/createArticle.html b/ruoyi-content/src/main/resources/templates/content/article/createArticle.html new file mode 100644 index 000000000..2cd6688d8 --- /dev/null +++ b/ruoyi-content/src/main/resources/templates/content/article/createArticle.html @@ -0,0 +1,258 @@ + + + + + + + + + + + + + + +
+
+
+
+
+
+
+
+
+
+
+
+
+

封面摘要:

+

分享描述:

+
+
+ + + +
+ +
+
+
+ +
+ +
+
+ + + + + + + + \ No newline at end of file