From 64ccbd24e692568a6b5862e2b3f8855188431c5a Mon Sep 17 00:00:00 2001
From: guange <8863824@gmail.com>
Date: Mon, 6 Jan 2020 16:19:30 +0800
Subject: [PATCH 01/11] =?UTF-8?q?tpi=20active=E4=BC=A0=E9=94=99?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/jupyters_controller.rb | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/app/controllers/jupyters_controller.rb b/app/controllers/jupyters_controller.rb
index ecb411b36..81df43759 100644
--- a/app/controllers/jupyters_controller.rb
+++ b/app/controllers/jupyters_controller.rb
@@ -76,7 +76,7 @@ class JupytersController < ApplicationController
def active_with_tpi
myshixun = Myshixun.find_by(identifier: params[:identifier])
- jupyter_active_tpm(myshixun)
+ jupyter_active_tpi(myshixun)
render json: {status: 0}
end
From 5f1c9ee1ad8ac72ab8b5105d36ab111f11737f9c Mon Sep 17 00:00:00 2001
From: cxt <853663049@qq.com>
Date: Mon, 6 Jan 2020 16:35:10 +0800
Subject: [PATCH 02/11] =?UTF-8?q?=E6=89=93=E5=8D=B0=E6=97=A5=E6=9C=9F?=
=?UTF-8?q?=E7=9A=84=E8=AE=A1=E5=88=92=E4=BB=BB=E5=8A=A1?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
lib/tasks/print_date.rake | 7 +++++++
1 file changed, 7 insertions(+)
create mode 100644 lib/tasks/print_date.rake
diff --git a/lib/tasks/print_date.rake b/lib/tasks/print_date.rake
new file mode 100644
index 000000000..501cd3750
--- /dev/null
+++ b/lib/tasks/print_date.rake
@@ -0,0 +1,7 @@
+namespace :print_date do
+ desc "print date"
+
+ task :print => :environment do
+ Rails.logger.info("#{Time.now}")
+ end
+end
\ No newline at end of file
From 9136c9f53500e1ec9255f8929ad042ad969e0a51 Mon Sep 17 00:00:00 2001
From: tangjiang <465264938@qq.com>
Date: Mon, 6 Jan 2020 16:53:12 +0800
Subject: [PATCH 03/11] update quill
---
.../src/common/quillForEditor/FillBlot.js | 38 ++++++++++
.../react/src/common/quillForEditor/index.js | 57 +++++++++++++--
.../src/common/quillForEditor/index.scss | 17 +++++
.../modules/developer/newOrEditTask/index.js | 2 +-
.../leftpane/editorTab/README.md | 69 +++++++++++++++++++
.../newOrEditTask/leftpane/editorTab/index.js | 4 +-
.../modules/developer/split_pane_resizer.scss | 39 +++++++++++
.../modules/developer/studentStudy/index.js | 4 +-
8 files changed, 221 insertions(+), 9 deletions(-)
create mode 100644 public/react/src/common/quillForEditor/FillBlot.js
create mode 100644 public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/README.md
diff --git a/public/react/src/common/quillForEditor/FillBlot.js b/public/react/src/common/quillForEditor/FillBlot.js
new file mode 100644
index 000000000..d36f2d4b1
--- /dev/null
+++ b/public/react/src/common/quillForEditor/FillBlot.js
@@ -0,0 +1,38 @@
+/*
+ * @Description: 填空
+ * @Author: tangjiang
+ * @Github:
+ * @Date: 2020-01-06 09:02:29
+ * @LastEditors : tangjiang
+ * @LastEditTime : 2020-01-06 16:04:46
+ */
+import Quill from 'quill';
+
+let Inline = Quill.import('blots/inline');
+
+class FillBlot extends Inline {
+ static create (value) {
+ const node = super.cerate();
+ node.classList.add('icon icon-bianji2');
+ node.setAttribute('data-fill', 'fill');
+ node.addEventListener('DOMNodeRemoved', function () {
+ alert(123);
+ }, false);
+ return node;
+ }
+
+ static value (node) {
+ return {
+ dataSet: node.getAttribute('data-fill'),
+ onDOMNodeRemoved: () => {
+ alert('123456');
+ }
+ }
+ }
+}
+
+
+FillBlot.blotName = "fill";
+FillBlot.tagName = "span";
+
+export default FillBlot;
diff --git a/public/react/src/common/quillForEditor/index.js b/public/react/src/common/quillForEditor/index.js
index f3f359a80..326ca21ae 100644
--- a/public/react/src/common/quillForEditor/index.js
+++ b/public/react/src/common/quillForEditor/index.js
@@ -4,7 +4,7 @@
* @Github:
* @Date: 2019-12-18 08:49:30
* @LastEditors : tangjiang
- * @LastEditTime : 2019-12-31 15:11:37
+ * @LastEditTime : 2020-01-06 16:45:50
*/
import './index.scss';
import 'quill/dist/quill.core.css'; // 核心样式
@@ -18,8 +18,11 @@ import deepEqual from './deepEqual.js'
import { fetchUploadImage } from '../../services/ojService.js';
import { getImageUrl } from 'educoder'
import ImageBlot from './ImageBlot';
+// import Toolbar from 'quill/modules/toolbar';
+import FillBlot from './FillBlot';
const Size = Quill.import('attributors/style/size');
const Font = Quill.import('formats/font');
+
// const Color = Quill.import('attributes/style/color');
Size.whitelist = ['12px', '14px', '16px', '18px', '20px', false];
Font.whitelist = ['SimSun', 'SimHei','Microsoft-YaHei','KaiTi','FangSong','Arial','Times-New-Roman','sans-serif'];
@@ -29,6 +32,8 @@ window.katex = katex;
Quill.register(ImageBlot);
Quill.register(Size);
Quill.register(Font, true);
+// Quill.register({'modules/toolbar': Toolbar});
+Quill.register(FillBlot);
// Quill.register(Color);
function QuillForEditor ({
@@ -42,6 +47,7 @@ function QuillForEditor ({
wrapStyle = {},
showUploadImage,
onContentChange,
+ // addFill, // 点击填空成功的回调
// getQuillContent
}) {
// toolbar 默认值
@@ -62,6 +68,8 @@ function QuillForEditor ({
// quill 实例
const [quill, setQuill] = useState(null);
const [selection, setSelection] = useState(null);
+ const [fillCount, setFillCount] = useState(0);
+ const [quillCtx, setQuillCtx] = useState({});
// 文本内容变化时
const handleOnChange = content => {
@@ -70,18 +78,23 @@ function QuillForEditor ({
};
const renderOptions = options || defaultConfig;
+
// quill 配置信息
const quillOption = {
modules: {
toolbar: renderOptions
+ // toolbar: {
+ // container: renderOptions
+ // }
},
readOnly,
placeholder,
- theme: readOnly ? 'bubble' : 'snow'
+ theme: readOnly ? 'bubble' : 'snow',
};
useEffect(() => {
+
const quillNode = document.createElement('div');
editorRef.current.appendChild(quillNode);
const _quill = new Quill(editorRef.current, quillOption);
@@ -121,13 +134,20 @@ function QuillForEditor ({
}
}
});
+
+ _quill.getModule('toolbar').addHandler('fill', (e) => {
+ setFillCount(fillCount + 1);
+ const range = _quill.getSelection(true);
+ _quill.insertText(range.index, '▁');
+ // 点击填空图标时,插入一个下划线
+ // 1. 获取编辑器内容
+ });
}, []);
// 设置值
useEffect(() => {
if (!quill) return
- // debugger;
const previous = quill.getContents()
if (value && value.hasOwnProperty('ops')) {
@@ -173,7 +193,36 @@ function QuillForEditor ({
let handler;
quill.on(
'text-change',
- (handler = () => {
+ (handler = (delta, oldDelta, source) => {
+ // let del = false;
+ // let delLen = 1;
+ // delta.ops.forEach(o => {
+ // // 存在删除并且只删除一个
+ // if (o.delete) {
+ // del = true;
+ // }
+ // });
+ // 删除编辑器内容
+ // if (del) {
+ // delLen = delta.ops[0].retain || 1; // 删除数组的长度
+ // // 获取删除的内容并判断其它是否有填空内容
+ // console.log('原编辑器内容', oldDelta);
+ // console.log('编辑器内容', quillCtx);
+ // }
+ // 获取删除的内容
+ // oldDelta
+ // if (del) {
+ // const ops = oldDelta.ops;
+ // const len = ops.length;
+ // // if (ops[len - 1] && ops[len - 1].insert) {
+ // // const str = ops[len - 1].insert;
+ // // const _len = str.length;
+ // // const _last = str.substr(_len - 1);
+ // // console.log('删除的一项', _last);
+ // // }
+ // }
+ const _ctx = quill.getContents();
+ setQuillCtx(_ctx);
handleOnChange(quill.getContents()); // getContents: 检索编辑器内容
})
);
diff --git a/public/react/src/common/quillForEditor/index.scss b/public/react/src/common/quillForEditor/index.scss
index 96cd45edd..eca8c4485 100644
--- a/public/react/src/common/quillForEditor/index.scss
+++ b/public/react/src/common/quillForEditor/index.scss
@@ -110,4 +110,21 @@
content: "微软雅黑";
font-family: "Microsoft YaHei";
}
+
+ // 填空图标
+ .ql-snow .ql-fill{
+ display: inline-block;
+ position: relative;
+ color: #05101A;
+ // font-size: 18px;
+ vertical-align: top;
+ &::before{
+ position: absolute;
+ left: 50%;
+ top: -1px;
+ content: '\e709';
+ font-family: 'iconfont';
+ margin-left: -7px;
+ }
+ }
}
\ No newline at end of file
diff --git a/public/react/src/modules/developer/newOrEditTask/index.js b/public/react/src/modules/developer/newOrEditTask/index.js
index eb894d1d0..382b91878 100644
--- a/public/react/src/modules/developer/newOrEditTask/index.js
+++ b/public/react/src/modules/developer/newOrEditTask/index.js
@@ -214,7 +214,7 @@ const NewOrEditTask = (props) => {
{ renderQuit() }
-
+
diff --git a/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/README.md b/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/README.md
new file mode 100644
index 000000000..bbec5eb50
--- /dev/null
+++ b/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/README.md
@@ -0,0 +1,69 @@
+
+## QuillForEditor 使用 [https://quilljs.com/]
+
+ ### 导入
+
+ - 目录 src/common/quillForEditor (默认加载当前文件夹下的 index.js 文件)
+
+ ### 参数
+
+ | 字段 | 描述 |
+ | ----- | ----- |
+ | placeholder | 提示信息 |
+ | readOnly | 只读(只读取模式时,没有 工具栏且内容不可编辑,通过用于展示quill内容) |
+ | autoFocus | 自动获得焦点 |
+ | options | 配置参数, 指定工具栏内容 |
+ | value | 文本编辑器内容 |
+ | imgAttrs | 指定上传图片的尺寸 |
+ | style | 指定quill容器样式 |
+ | wrapStyle | 指定包裹quill容器的样式|
+ | onContentChange | 当编辑器内容变化时调用此回调函数 |
+ | showUploadImage | 点击放大上传成功后的图片, 返回上传成功后的图片 url, (评论时点击图片这么大)|
+
+
+
+ ### 添加工具栏
+
+ - 默认所有的
+
+ ```
+ const options = [
+ 'bold', // 加粗
+ 'italic', // 斜体
+ 'underline', // 下划线
+ {size: ['12px', '14px', '16px', '18px', '20px']}, // 字体大小
+ {align: []}, // 对齐方式
+ {list: 'ordered'}, // 有序列表
+ {list: 'bullet'}, // 无序列表
+ {script: 'sub'}, // 下标 x2
+ {script: 'super'}, // 上标 平方 (x2)
+ { 'color': [] }, // 字体颜色
+ { 'background': [] }, // 背景色
+ {header: [1,2,3,4,5,false]}, // H1,H2 ...
+ 'blockquote', // 文件左边加一个边框样式
+ 'code-block', // 块内容
+ 'link', // 链接
+ 'image', // 图片
+ 'video', // 视频
+ 'formula', // 数学公式
+ 'clean' // 清除
+ ]
+ ```
+
+
+ ### 使用
+
+ ````
+ import QuillForEditor from 'xxx';
+
+
+
+ ````
+
diff --git a/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/index.js b/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/index.js
index 85c391b2d..f8b92361b 100644
--- a/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/index.js
+++ b/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/index.js
@@ -4,7 +4,7 @@
* @Github:
* @Date: 2019-11-20 10:35:40
* @LastEditors : tangjiang
- * @LastEditTime : 2020-01-03 19:02:17
+ * @LastEditTime : 2020-01-06 16:17:22
*/
import './index.scss';
// import 'katex/dist/katex.css';
@@ -277,7 +277,7 @@ class EditTab extends React.Component {
const quillConfig = [
{ header: 1}, {header: 2},
// {size: ['12px', '14px', '16px', '18px', '20px', false]},
- 'bold', 'italic', 'underline', 'strike', // 切换按钮
+ 'bold', 'italic', 'underline', 'strike', // 切换按钮
'blockquote', 'code-block', // 代码块
{align: []}, { 'list': 'ordered' }, { 'list': 'bullet' }, // 列表
{ 'script': 'sub'}, { 'script': 'super' },
diff --git a/public/react/src/modules/developer/split_pane_resizer.scss b/public/react/src/modules/developer/split_pane_resizer.scss
index 8d4ad171c..2c1101433 100644
--- a/public/react/src/modules/developer/split_pane_resizer.scss
+++ b/public/react/src/modules/developer/split_pane_resizer.scss
@@ -217,3 +217,42 @@
.Resizer.disabled:hover {
border-color: transparent;
}
+
+.outer-split-pane{
+ & > .Resizer{
+ position: relative;
+ &::before,
+ &::after{
+ position: absolute;
+ right: -12px;
+ top: 50%;
+ transition: opacity, background .3s;
+ }
+ &::before{
+ content: '';
+ border-radius: 50%;
+ background: rgba(235,235,235,.3);
+ width: 24px;
+ height: 24px;
+ // font-size: 12px;
+ }
+ &::after{
+ content: '\e712';
+ font-family: 'iconfont';
+ transform: scale(.7);
+ color: #666;
+ margin-top: -2px;
+ right: -14px;
+ opacity: .3;
+ }
+
+ &:hover{
+ &::before{
+ background: rgba(235,235,235, 1);
+ }
+ &::after{
+ opacity: 1;
+ }
+ }
+ }
+}
diff --git a/public/react/src/modules/developer/studentStudy/index.js b/public/react/src/modules/developer/studentStudy/index.js
index 2ef8c4ba9..0c8c7012f 100644
--- a/public/react/src/modules/developer/studentStudy/index.js
+++ b/public/react/src/modules/developer/studentStudy/index.js
@@ -4,7 +4,7 @@
* @Github:
* @Date: 2019-11-23 10:53:19
* @LastEditors : tangjiang
- * @LastEditTime : 2019-12-27 16:22:47
+ * @LastEditTime : 2020-01-06 15:27:34
*/
import './index.scss';
import React, { useEffect, useState } from 'react';
@@ -144,7 +144,7 @@ function StudentStudy (props) {
-
+
From 2f87b0040adeee1a4b8df26938a7d814f4606f51 Mon Sep 17 00:00:00 2001
From: tangjiang <465264938@qq.com>
Date: Mon, 6 Jan 2020 16:57:17 +0800
Subject: [PATCH 04/11] move file
---
.../leftpane/editorTab => common/quillForEditor}/README.md | 0
1 file changed, 0 insertions(+), 0 deletions(-)
rename public/react/src/{modules/developer/newOrEditTask/leftpane/editorTab => common/quillForEditor}/README.md (100%)
diff --git a/public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/README.md b/public/react/src/common/quillForEditor/README.md
similarity index 100%
rename from public/react/src/modules/developer/newOrEditTask/leftpane/editorTab/README.md
rename to public/react/src/common/quillForEditor/README.md
From 9cc7bafe549cd47a53240bd239389ae9f7a640c2 Mon Sep 17 00:00:00 2001
From: cxt <853663049@qq.com>
Date: Mon, 6 Jan 2020 17:01:43 +0800
Subject: [PATCH 05/11] =?UTF-8?q?=E5=AF=BC=E5=87=BA=E8=B0=83=E6=95=B4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
lib/tasks/zip_pack.rake | 1 +
1 file changed, 1 insertion(+)
diff --git a/lib/tasks/zip_pack.rake b/lib/tasks/zip_pack.rake
index 0452a83e2..54099a2c0 100644
--- a/lib/tasks/zip_pack.rake
+++ b/lib/tasks/zip_pack.rake
@@ -19,6 +19,7 @@ namespace :zip_pack do
student_works = homework.score_student_works
if student_works.size > 0
+ pdfs = []
Zip::File.open(zipfile_name, Zip::File::CREATE) do |zip|
student_works.find_each.map do |student_work|
export = ExportShixunReportService.new(homework, student_work)
From 8aa7d7bd725d9e8ca7f042076ac0d3c745db4ca4 Mon Sep 17 00:00:00 2001
From: daiao <358551898@qq.com>
Date: Mon, 6 Jan 2020 17:10:42 +0800
Subject: [PATCH 06/11] =?UTF-8?q?vnc=20webssh=E5=A4=9A=E5=A2=9E=E5=8A=A0?=
=?UTF-8?q?=E4=B8=80=E4=B8=AA=E5=8F=82=E6=95=B0?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/games_controller.rb | 5 ++++-
app/controllers/myshixuns_controller.rb | 3 ++-
2 files changed, 6 insertions(+), 2 deletions(-)
diff --git a/app/controllers/games_controller.rb b/app/controllers/games_controller.rb
index 938d42c2f..055c656eb 100644
--- a/app/controllers/games_controller.rb
+++ b/app/controllers/games_controller.rb
@@ -962,8 +962,11 @@ class GamesController < ApplicationController
shixun = game.myshixun.shixun
shixun_tomcat = edu_setting('cloud_bridge')
service_host = edu_setting('vnc_url')
+ tpiGitURL = "#{edu_setting('git_address_domain')}/#{game.myshixun.repo_path}"
+
uri = "#{shixun_tomcat}/bridge/vnc/getvnc"
- params = {tpiID: game.myshixun.id, :containers => "#{Base64.urlsafe_encode64(shixun_container_limit(shixun))}"}
+ params = {tpiID: game.myshixun.id, :containers => "#{Base64.urlsafe_encode64(shixun_container_limit(shixun))}",
+ tpiGitURL: tpiGitURL}
res = uri_post uri, params
if res && res['code'].to_i != 0
raise("实训云平台繁忙(繁忙等级:99)")
diff --git a/app/controllers/myshixuns_controller.rb b/app/controllers/myshixuns_controller.rb
index 67bec877b..7847d58ed 100644
--- a/app/controllers/myshixuns_controller.rb
+++ b/app/controllers/myshixuns_controller.rb
@@ -216,10 +216,11 @@ class MyshixunsController < ApplicationController
old_time = Time.now.to_i
begin
shixun_tomcat = edu_setting('tomcat_webssh')
+ tpiGitURL = "#{edu_setting('git_address_domain')}/#{@myshixun.repo_path}"
uri = "#{shixun_tomcat}/bridge/webssh/getConnectInfo"
# 由于中间层采用混合云的方式,因为local参数表示在有文件生成的实训是在本地生成,还是在其他云端生成评测文件
local = @myshixun.shixun.challenges.where.not(show_type: -1).count == 0
- params = {tpiID:@myshixun.id, podType:@myshixun.shixun.try(:webssh), local: local,
+ params = {tpiID:@myshixun.id, podType:@myshixun.shixun.try(:webssh), local: local, tpiGitURL: tpiGitURL,
containers:(Base64.urlsafe_encode64(shixun_container_limit @myshixun.shixun))}
res = uri_post uri, params
if res && res['code'].to_i != 0
From 260c2c2ad93f441108ebe62d0c52fc1973788f0c Mon Sep 17 00:00:00 2001
From: cxt <853663049@qq.com>
Date: Mon, 6 Jan 2020 17:11:33 +0800
Subject: [PATCH 07/11] =?UTF-8?q?=E5=AF=BC=E5=87=BA=E8=B0=83=E6=95=B4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
lib/tasks/zip_pack.rake | 1 +
1 file changed, 1 insertion(+)
diff --git a/lib/tasks/zip_pack.rake b/lib/tasks/zip_pack.rake
index 54099a2c0..6e3140f47 100644
--- a/lib/tasks/zip_pack.rake
+++ b/lib/tasks/zip_pack.rake
@@ -27,6 +27,7 @@ namespace :zip_pack do
pdfs << pdf
begin
zip.add(export.filename, pdf.path)
+ puts "out: #{export.filename}"
rescue => ex
Rails.logger.error(ex.message)
From dcbe49265c2c5a9fc75bb60bbdbc3b22d22fd81a Mon Sep 17 00:00:00 2001
From: cxt <853663049@qq.com>
Date: Mon, 6 Jan 2020 17:13:03 +0800
Subject: [PATCH 08/11] =?UTF-8?q?=E5=AF=BC=E5=87=BA=E8=B0=83=E6=95=B4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
lib/tasks/zip_pack.rake | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/lib/tasks/zip_pack.rake b/lib/tasks/zip_pack.rake
index 6e3140f47..766925571 100644
--- a/lib/tasks/zip_pack.rake
+++ b/lib/tasks/zip_pack.rake
@@ -27,7 +27,7 @@ namespace :zip_pack do
pdfs << pdf
begin
zip.add(export.filename, pdf.path)
- puts "out: #{export.filename}"
+ puts "out: #{export.filename}_#{pdf.path}"
rescue => ex
Rails.logger.error(ex.message)
From 1fba78cd1afdda3a6d3eb9e7c9021dbbda5aab36 Mon Sep 17 00:00:00 2001
From: tangjiang <465264938@qq.com>
Date: Mon, 6 Jan 2020 17:14:20 +0800
Subject: [PATCH 09/11] update quill readme.md
---
.../react/src/common/quillForEditor/README.md | 33 ++++++++++++++++---
1 file changed, 29 insertions(+), 4 deletions(-)
diff --git a/public/react/src/common/quillForEditor/README.md b/public/react/src/common/quillForEditor/README.md
index bbec5eb50..0369164c7 100644
--- a/public/react/src/common/quillForEditor/README.md
+++ b/public/react/src/common/quillForEditor/README.md
@@ -4,7 +4,7 @@
* @Github:
* @Date: 2020-01-06 16:20:03
* @LastEditors : tangjiang
- * @LastEditTime : 2020-01-06 16:46:44
+ * @LastEditTime : 2020-01-06 17:13:19
-->
## QuillForEditor 使用 [https://quilljs.com/]
@@ -17,14 +17,14 @@
| 字段 | 描述 |
| ----- | ----- |
| placeholder | 提示信息 |
- | readOnly | 只读(只读取模式时,没有 工具栏且内容不可编辑,通过用于展示quill内容) |
+ | readOnly | 只读(只读取模式时,没有 工具栏且内容不可编辑,通常用于展示quill内容) |
| autoFocus | 自动获得焦点 |
| options | 配置参数, 指定工具栏内容 |
| value | 文本编辑器内容 |
| imgAttrs | 指定上传图片的尺寸 |
| style | 指定quill容器样式 |
| wrapStyle | 指定包裹quill容器的样式|
- | onContentChange | 当编辑器内容变化时调用此回调函数 |
+ | onContentChange | 当编辑器内容变化时调用此回调函数(注: 此时返回的内容为对象,提交到后台时需要格式成 JSON 字符串: JSON.stringify(xx)) |
| showUploadImage | 点击放大上传成功后的图片, 返回上传成功后的图片 url, (评论时点击图片这么大)|
@@ -63,7 +63,32 @@
````
import QuillForEditor from 'xxx';
-
+ // 指定需要显示的工具栏信息, 不指定加载全部
+ const options = [
+
+ ];
+
+ /**
+ * @description 获取编辑器返回的内容
+ * @params [Object] value 编辑器内容
+ */
+ const handleCtxChange = (value) => {
+ // 编辑器内容非空判断
+ const _text = quill.getText();
+ const reg = /^[\s\S]*.*[^\s][\s\S]*$/;
+ if (!reg.test(_text)) {
+ // 处理编辑器内容为空
+ } else {
+ // 提交到后台的内容需要处理一下;
+ value = JSON.stringify(value)
+ }
+ }
+
+
+
````
From 2fc0587b8c0df0ed9203cd891a14f9faa3c21f15 Mon Sep 17 00:00:00 2001
From: daiao <358551898@qq.com>
Date: Mon, 6 Jan 2020 17:27:06 +0800
Subject: [PATCH 10/11] =?UTF-8?q?=E8=BF=81=E7=A7=BB=E5=AE=9E=E8=B7=B5?=
=?UTF-8?q?=E8=AF=BE=E7=A8=8B=E7=9A=84=E8=AE=BF=E9=97=AE=E4=BA=BA=E6=95=B0?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../20200106092135_modify_viewed_count_for_subjects.rb | 10 ++++++++++
1 file changed, 10 insertions(+)
create mode 100644 db/migrate/20200106092135_modify_viewed_count_for_subjects.rb
diff --git a/db/migrate/20200106092135_modify_viewed_count_for_subjects.rb b/db/migrate/20200106092135_modify_viewed_count_for_subjects.rb
new file mode 100644
index 000000000..ecef2df69
--- /dev/null
+++ b/db/migrate/20200106092135_modify_viewed_count_for_subjects.rb
@@ -0,0 +1,10 @@
+class ModifyViewedCountForSubjects < ActiveRecord::Migration[5.2]
+ def change
+
+ subjects = Subject.where(status: 2).includes(:shixuns)
+ subjects.find_each do |subject|
+ subject.update_attribute(:visits, subject.visits + subject.shixuns.pluck(:myshixuns_count).sum)
+ end
+
+ end
+end
From 2092e2a187cf897cfec2a7ffdfdaa1dccde0dc4d Mon Sep 17 00:00:00 2001
From: cxt <853663049@qq.com>
Date: Mon, 6 Jan 2020 17:38:55 +0800
Subject: [PATCH 11/11] =?UTF-8?q?=E5=AF=BC=E5=87=BA=E8=B0=83=E6=95=B4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/services/export_shixun_report_service.rb | 4 ++--
lib/tasks/zip_pack.rake | 2 +-
2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/app/services/export_shixun_report_service.rb b/app/services/export_shixun_report_service.rb
index b75f031c0..2339b6d56 100644
--- a/app/services/export_shixun_report_service.rb
+++ b/app/services/export_shixun_report_service.rb
@@ -33,8 +33,8 @@ class ExportShixunReportService
base_css = %w(app/templates/shared/main.css app/templates/shixun_work/shixun_work.css app/templates/shared/codemirror.css)
base_css.each { |css| kit.stylesheets << Rails.root.join(css) }
- file = Tempfile.new(filename)
- kit.to_pdf(file.path)
+ file_name = "#{Rails.root}/files/archiveZip/#{filename}"
+ kit.to_pdf(file_name)
file
end
diff --git a/lib/tasks/zip_pack.rake b/lib/tasks/zip_pack.rake
index 766925571..c1a080e36 100644
--- a/lib/tasks/zip_pack.rake
+++ b/lib/tasks/zip_pack.rake
@@ -1,7 +1,7 @@
# 执行示例 bundle exec rake zip_pack:shixun_pack args=123,2323
namespace :zip_pack do
desc "手工打包作品"
- OUTPUT_FOLDER = "/tmp"
+ OUTPUT_FOLDER = "#{Rails.root}/files/archiveZip"
task :shixun_pack => :environment do