|
|
@ -10,13 +10,13 @@ |
|
|
|
<el-form-item :label="$t('note.table.original_text')"> |
|
|
|
<el-form-item :label="$t('note.table.original_text')"> |
|
|
|
<el-input autosize type="textarea" v-model="note_form.original_text" disabled></el-input> |
|
|
|
<el-input autosize type="textarea" v-model="note_form.original_text" disabled></el-input> |
|
|
|
</el-form-item> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item :label="$t('read.form.note_title')" prop="note_title"> |
|
|
|
<el-form-item :label="$t('note.table.note_title')" prop="note_title"> |
|
|
|
<el-input v-model="note_form.note_title" |
|
|
|
<el-input v-model="note_form.note_title" |
|
|
|
:placeholder="$t('input_please', { keyword: this.$t('read.form.note_title') })"></el-input> |
|
|
|
:placeholder="$t('input_please', { keyword: this.$t('note.table.note_title') })"></el-input> |
|
|
|
</el-form-item> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item :label="$t('read.form.note_content')" prop="note_content"> |
|
|
|
<el-form-item :label="$t('note.table.note_content')" prop="note_content"> |
|
|
|
<el-input autosize type="textarea" v-model="note_form.note_content" |
|
|
|
<el-input autosize type="textarea" v-model="note_form.note_content" |
|
|
|
:placeholder="$t('input_please', { keyword: this.$t('read.form.note_content') })"></el-input> |
|
|
|
:placeholder="$t('input_please', { keyword: this.$t('note.table.note_content') })"></el-input> |
|
|
|
</el-form-item> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item> |
|
|
|
<el-form-item> |
|
|
|
<el-button @click="addNote">{{$t('button.add')}}</el-button> |
|
|
|
<el-button @click="addNote">{{$t('button.add')}}</el-button> |
|
|
@ -80,6 +80,8 @@ |
|
|
|
> |
|
|
|
> |
|
|
|
<el-button size="mini" type="danger" slot="reference" icon="el-icon-delete"></el-button> |
|
|
|
<el-button size="mini" type="danger" slot="reference" icon="el-icon-delete"></el-button> |
|
|
|
</el-popconfirm> |
|
|
|
</el-popconfirm> |
|
|
|
|
|
|
|
<el-button size="mini" type="success" @click="download(item)" |
|
|
|
|
|
|
|
icon="el-icon-download"></el-button> |
|
|
|
</el-button-group> |
|
|
|
</el-button-group> |
|
|
|
</el-row> |
|
|
|
</el-row> |
|
|
|
</div> |
|
|
|
</div> |
|
|
@ -165,12 +167,12 @@ |
|
|
|
rules: { |
|
|
|
rules: { |
|
|
|
note_title: [{ |
|
|
|
note_title: [{ |
|
|
|
required: true, |
|
|
|
required: true, |
|
|
|
message: this.$t('input_please', { keyword: this.$t('read.form.note_title') }), |
|
|
|
message: this.$t('input_please', { keyword: this.$t('note.table.note_title') }), |
|
|
|
trigger: 'blur' |
|
|
|
trigger: 'blur' |
|
|
|
}], |
|
|
|
}], |
|
|
|
note_content: [{ |
|
|
|
note_content: [{ |
|
|
|
required: true, |
|
|
|
required: true, |
|
|
|
message: this.$t('input_please', { keyword: this.$t('read.form.note_content') }), |
|
|
|
message: this.$t('input_please', { keyword: this.$t('note.table.note_content') }), |
|
|
|
trigger: 'blur' |
|
|
|
trigger: 'blur' |
|
|
|
}] |
|
|
|
}] |
|
|
|
}, |
|
|
|
}, |
|
|
@ -232,31 +234,53 @@ |
|
|
|
}, |
|
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
methods: { |
|
|
|
methods: { |
|
|
|
|
|
|
|
//导出笔记 |
|
|
|
|
|
|
|
download(item) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
console.info(item) |
|
|
|
|
|
|
|
let ele = document.createElement('a') |
|
|
|
|
|
|
|
//设置下载文件名 |
|
|
|
|
|
|
|
ele.download = `${this.$t('note.table.note_title')}.txt` |
|
|
|
|
|
|
|
//隐藏元素 |
|
|
|
|
|
|
|
ele.style.display = 'none' |
|
|
|
|
|
|
|
//字符内容转变成blob地址 |
|
|
|
|
|
|
|
let blob = new Blob([`${this.$t('note.table.note_title')}:${item.title} |
|
|
|
|
|
|
|
${this.$t('note.table.paper_name')}:《${this.activeContent.title}》 |
|
|
|
|
|
|
|
${this.$t('note.table.original_text')}:${item.originalText} |
|
|
|
|
|
|
|
${this.$t('note.table.note_content')}:${item.content}`]) |
|
|
|
|
|
|
|
//如果是链接,这里也可以直接设置链接地址 |
|
|
|
|
|
|
|
ele.href = URL.createObjectURL(blob) |
|
|
|
|
|
|
|
document.body.appendChild(ele) |
|
|
|
|
|
|
|
//模拟点击 |
|
|
|
|
|
|
|
ele.click() |
|
|
|
|
|
|
|
//移除元素 |
|
|
|
|
|
|
|
document.body.removeChild(ele) |
|
|
|
|
|
|
|
}, |
|
|
|
//收藏 |
|
|
|
//收藏 |
|
|
|
star(e,item){ |
|
|
|
star(e, item) { |
|
|
|
e.stopPropagation() |
|
|
|
e.stopPropagation() |
|
|
|
let that=this |
|
|
|
let that = this |
|
|
|
this.GLOBAL.fetchJSON(`/v1/api/collect/${item.id}`,'POST',{},function(res) { |
|
|
|
this.GLOBAL.fetchJSON(`/v1/api/collect/${item.id}`, 'POST', {}, function(res) { |
|
|
|
if(res.code==='200'){ |
|
|
|
if (res.code === '200') { |
|
|
|
that.$store.commit('read/updateCollect',item.title) |
|
|
|
that.$store.commit('read/updateCollect', item.title) |
|
|
|
that.$message.info(that.$t(res.msg)) |
|
|
|
that.$message.info(that.$t(res.msg)) |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
that.$message.error(that.$t(res.msg)) |
|
|
|
that.$message.error(that.$t(res.msg)) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
|
}, |
|
|
|
}, |
|
|
|
//查找评价记录 |
|
|
|
//查找评价记录 |
|
|
|
queryRating(){ |
|
|
|
queryRating() { |
|
|
|
let that=this |
|
|
|
let that = this |
|
|
|
this.GLOBAL.fetchGet('/v1/api/paper/findRating', { paperId:this.activeContent.id },function(res) { |
|
|
|
this.GLOBAL.fetchGet('/v1/api/paper/findRating', { paperId: this.activeContent.id }, function(res) { |
|
|
|
if(res.code==='200'){ |
|
|
|
if (res.code === '200') { |
|
|
|
if(res.data===null){ |
|
|
|
if (res.data === null) { |
|
|
|
that.stars=[{ value: 0 }, { value: 0 }, { value: 0 }] |
|
|
|
that.stars = [{ value: 0 }, { value: 0 }, { value: 0 }] |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
that.stars=[{ value: res.data.score1 }, { value: res.data.score2 }, { value: res.data.score3 }] |
|
|
|
that.stars = [{ value: res.data.score1 }, { value: res.data.score2 }, { value: res.data.score3 }] |
|
|
|
} |
|
|
|
} |
|
|
|
that.show_star_button=res.data===null |
|
|
|
that.show_star_button = res.data === null |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
@ -387,15 +411,15 @@ |
|
|
|
}, |
|
|
|
}, |
|
|
|
//保存笔记 |
|
|
|
//保存笔记 |
|
|
|
save(item: any) { |
|
|
|
save(item: any) { |
|
|
|
let that=this |
|
|
|
let that = this |
|
|
|
this.GLOBAL.fetchJSON('/v1/api/notes/update','PUT',{ |
|
|
|
this.GLOBAL.fetchJSON('/v1/api/notes/update', 'PUT', { |
|
|
|
noteId:item.id, |
|
|
|
noteId: item.id, |
|
|
|
noteContent:item.content |
|
|
|
noteContent: item.content |
|
|
|
},function(res) { |
|
|
|
}, function(res) { |
|
|
|
if(res.code==='200'){ |
|
|
|
if (res.code === '200') { |
|
|
|
that.$set(item, 'type', 'success') |
|
|
|
that.$set(item, 'type', 'success') |
|
|
|
that.$set(item, 'message', that.$t('read.tip.update_note_ok')) |
|
|
|
that.$set(item, 'message', that.$t('read.tip.update_note_ok')) |
|
|
|
}else { |
|
|
|
} else { |
|
|
|
that.$set(item, 'type', 'error') |
|
|
|
that.$set(item, 'type', 'error') |
|
|
|
that.$set(item, 'message', that.$t('read.tip.update_note_fail')) |
|
|
|
that.$set(item, 'message', that.$t('read.tip.update_note_fail')) |
|
|
|
} |
|
|
|
} |
|
|
@ -403,9 +427,9 @@ |
|
|
|
}, |
|
|
|
}, |
|
|
|
//删除笔记 |
|
|
|
//删除笔记 |
|
|
|
del(item: any, index: number) { |
|
|
|
del(item: any, index: number) { |
|
|
|
let that=this |
|
|
|
let that = this |
|
|
|
let span=document.getElementById(item.id) |
|
|
|
let span = document.getElementById(item.id) |
|
|
|
if(span) { |
|
|
|
if (span) { |
|
|
|
let text = document.createTextNode(span.innerText) |
|
|
|
let text = document.createTextNode(span.innerText) |
|
|
|
span.replaceWith(text) |
|
|
|
span.replaceWith(text) |
|
|
|
that.pre.normalize() |
|
|
|
that.pre.normalize() |
|
|
@ -416,12 +440,12 @@ |
|
|
|
}, function(res) { |
|
|
|
}, function(res) { |
|
|
|
if (res.code === '200') { |
|
|
|
if (res.code === '200') { |
|
|
|
that.noteList.splice(index, 1) |
|
|
|
that.noteList.splice(index, 1) |
|
|
|
that.$store.commit('read/updateContent',that.pre.innerHTML) |
|
|
|
that.$store.commit('read/updateContent', that.pre.innerHTML) |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -429,17 +453,17 @@ |
|
|
|
//提交评分 |
|
|
|
//提交评分 |
|
|
|
submitRating() { |
|
|
|
submitRating() { |
|
|
|
console.info(this.stars) |
|
|
|
console.info(this.stars) |
|
|
|
let that=this |
|
|
|
let that = this |
|
|
|
this.GLOBAL.fetchJSON('/v1/api/paper/rating','POST',{ |
|
|
|
this.GLOBAL.fetchJSON('/v1/api/paper/rating', 'POST', { |
|
|
|
paperId:this.activeContent.id, |
|
|
|
paperId: this.activeContent.id, |
|
|
|
score1:this.stars[0].value, |
|
|
|
score1: this.stars[0].value, |
|
|
|
score2:this.stars[1].value, |
|
|
|
score2: this.stars[1].value, |
|
|
|
score3:this.stars[2].value, |
|
|
|
score3: this.stars[2].value |
|
|
|
},function(res) { |
|
|
|
}, function(res) { |
|
|
|
if(res.code==='200'){ |
|
|
|
if (res.code === '200') { |
|
|
|
that.queryRating() |
|
|
|
that.queryRating() |
|
|
|
that.$message.info(that.$t('read.tip.rating_ok').toString()) |
|
|
|
that.$message.info(that.$t('read.tip.rating_ok').toString()) |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
@ -459,12 +483,12 @@ |
|
|
|
}, |
|
|
|
}, |
|
|
|
//跳转到笔记位置 |
|
|
|
//跳转到笔记位置 |
|
|
|
jump(item: any) { |
|
|
|
jump(item: any) { |
|
|
|
this.noteList.forEach(i=>{ |
|
|
|
this.noteList.forEach(i => { |
|
|
|
if(i.id!==item.id){ |
|
|
|
if (i.id !== item.id) { |
|
|
|
this.$set(i,'isActive',false) |
|
|
|
this.$set(i, 'isActive', false) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
|
this.$set(item,'isActive',true) |
|
|
|
this.$set(item, 'isActive', true) |
|
|
|
let ele = document.getElementById(item.id) |
|
|
|
let ele = document.getElementById(item.id) |
|
|
|
if (ele) { |
|
|
|
if (ele) { |
|
|
|
ele.scrollIntoView({ |
|
|
|
ele.scrollIntoView({ |
|
|
@ -512,22 +536,22 @@ |
|
|
|
that.replace.replaceVal[index - 1].after(that.replace.replaceVal[index]) |
|
|
|
that.replace.replaceVal[index - 1].after(that.replace.replaceVal[index]) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
that.GLOBAL.fetchJSON('/v1/api/notes/add','POST',{ |
|
|
|
that.GLOBAL.fetchJSON('/v1/api/notes/add', 'POST', { |
|
|
|
noteId: this.note_form.note_id, |
|
|
|
noteId: this.note_form.note_id, |
|
|
|
noteTitle: this.note_form.note_title, |
|
|
|
noteTitle: this.note_form.note_title, |
|
|
|
noteContent: this.note_form.note_content, |
|
|
|
noteContent: this.note_form.note_content, |
|
|
|
paperId: that.activeContent.id, |
|
|
|
paperId: that.activeContent.id, |
|
|
|
fileId: that.activeContent.fileId, |
|
|
|
fileId: that.activeContent.fileId, |
|
|
|
originalText:that.note_form.original_text, |
|
|
|
originalText: that.note_form.original_text, |
|
|
|
content: that.pre.innerHTML |
|
|
|
content: that.pre.innerHTML |
|
|
|
},function(res) { |
|
|
|
}, function(res) { |
|
|
|
if(res.code==='200'){ |
|
|
|
if (res.code === '200') { |
|
|
|
that.$message.info({ |
|
|
|
that.$message.info({ |
|
|
|
message: that.$t('read.tip.add_tip_ok').toString(), |
|
|
|
message: that.$t('read.tip.add_tip_ok').toString(), |
|
|
|
showClose: true, |
|
|
|
showClose: true, |
|
|
|
duration: 1000, |
|
|
|
duration: 1000, |
|
|
|
onClose:function() { |
|
|
|
onClose: function() { |
|
|
|
that.$store.commit('read/updateContent',that.pre.innerHTML) |
|
|
|
that.$store.commit('read/updateContent', that.pre.innerHTML) |
|
|
|
that.noteList.unshift({ |
|
|
|
that.noteList.unshift({ |
|
|
|
id: that.note_form.note_id, |
|
|
|
id: that.note_form.note_id, |
|
|
|
title: that.note_form.note_title, |
|
|
|
title: that.note_form.note_title, |
|
|
@ -536,7 +560,7 @@ |
|
|
|
that.resetNote() |
|
|
|
that.resetNote() |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
@ -590,21 +614,22 @@ |
|
|
|
} |
|
|
|
} |
|
|
|
}, |
|
|
|
}, |
|
|
|
//查找笔记 |
|
|
|
//查找笔记 |
|
|
|
findNote(){ |
|
|
|
findNote() { |
|
|
|
let that=this |
|
|
|
let that = this |
|
|
|
this.GLOBAL.fetchGet(`/v1/api/notes/list/${this.activeContent.id}`,{},function(res) { |
|
|
|
this.GLOBAL.fetchGet(`/v1/api/notes/list/${this.activeContent.id}`, {}, function(res) { |
|
|
|
if(res.code==='200'){ |
|
|
|
if (res.code === '200') { |
|
|
|
that.noteList=[] |
|
|
|
that.noteList = [] |
|
|
|
|
|
|
|
|
|
|
|
res.data.data.forEach(item=>{ |
|
|
|
res.data.data.forEach(item => { |
|
|
|
let obj={ |
|
|
|
let obj = { |
|
|
|
id: item.noteId, |
|
|
|
id: item.noteId, |
|
|
|
title: item.noteTitle, |
|
|
|
title: item.noteTitle, |
|
|
|
content: item.noteContent, |
|
|
|
content: item.noteContent, |
|
|
|
isActive:item.noteId===that.$route.query.noteId |
|
|
|
isActive: item.noteId === that.$route.query.noteId, |
|
|
|
|
|
|
|
originalText: item.originalText |
|
|
|
} |
|
|
|
} |
|
|
|
that.noteList.push(obj) |
|
|
|
that.noteList.push(obj) |
|
|
|
if(item.noteId===that.$route.query.noteId){ |
|
|
|
if (item.noteId === that.$route.query.noteId) { |
|
|
|
that.jump(obj) |
|
|
|
that.jump(obj) |
|
|
|
that.$nextTick(() => { |
|
|
|
that.$nextTick(() => { |
|
|
|
let ele = document.querySelector('div[class$=active_card]') |
|
|
|
let ele = document.querySelector('div[class$=active_card]') |
|
|
@ -616,7 +641,7 @@ |
|
|
|
}) |
|
|
|
}) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
that.$message.error(that.$t('error_500').toString()) |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
@ -625,7 +650,7 @@ |
|
|
|
mounted() { |
|
|
|
mounted() { |
|
|
|
let that = this |
|
|
|
let that = this |
|
|
|
this.$nextTick(() => { |
|
|
|
this.$nextTick(() => { |
|
|
|
if(this.activeContent) { |
|
|
|
if (this.activeContent) { |
|
|
|
that.queryRating() |
|
|
|
that.queryRating() |
|
|
|
that.findNote() |
|
|
|
that.findNote() |
|
|
|
} |
|
|
|
} |
|
|
@ -643,7 +668,7 @@ |
|
|
|
} else if ('ESCAPE' === event.key.toUpperCase()) { |
|
|
|
} else if ('ESCAPE' === event.key.toUpperCase()) { |
|
|
|
that.showSearch = false |
|
|
|
that.showSearch = false |
|
|
|
} |
|
|
|
} |
|
|
|
if(that.activeContent) { |
|
|
|
if (that.activeContent) { |
|
|
|
that.updateFind(that.showSearch) |
|
|
|
that.updateFind(that.showSearch) |
|
|
|
} |
|
|
|
} |
|
|
|
}, true) |
|
|
|
}, true) |
|
|
@ -657,7 +682,7 @@ |
|
|
|
font-size: larger; |
|
|
|
font-size: larger; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
.active_card{ |
|
|
|
.active_card { |
|
|
|
border: 1px solid black; |
|
|
|
border: 1px solid black; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|