md/assets/scripts/editor.js

235 lines
6.7 KiB
JavaScript
Raw Normal View History

let app = new Vue({
el: '#app',
data: function () {
let d = {
aboutOutput: '',
output: '',
source: '',
editorThemes: [
2019-11-10 15:52:46 +08:00
{ label: '淡雅', value: 'xq-light' },
{ label: '精致', value: 'eclipse' },
2019-11-10 15:52:46 +08:00
{ label: '暗绿', value: 'oceanic-next' }
],
editor: null,
builtinFonts: [
{
label: '无衬线',
value: "-apple-system-font,BlinkMacSystemFont, Helvetica Neue, PingFang SC, Hiragino Sans GB , Microsoft YaHei UI , Microsoft YaHei ,Arial,sans-serif"
},
{
label: '衬线',
value: "Optima-Regular, Optima, PingFangSC-light, PingFangTC-light, 'PingFang SC', Cambria, Cochin, Georgia, Times, 'Times New Roman', serif"
}
],
sizeOption: [
{ label: '13px', value: '13px', desc: '稍小' },
2019-11-03 16:05:04 +08:00
{ label: '14px', value: '14px', desc: '推荐' },
2019-11-10 16:59:23 +08:00
{ label: '15px', value: '15px', desc: '稍大' }
],
colorOption: [
{ label: '经典蓝', value: 'rgba(15, 76, 129, 0.9)', hex: '最新流行色' },
{ label: '翡翠绿', value: 'rgba(0, 152, 116, 0.9)', hex: '清新且优雅' },
{ label: '辣椒红', value: 'rgba(155, 35, 53, 0.9)', hex: '自信且迷人' }
],
aboutDialogVisible: false
};
d.currentEditorTheme = d.editorThemes[0].value;
d.currentFont = d.builtinFonts[0].value;
d.currentSize = d.sizeOption[1].value;
d.currentColor = d.colorOption[0].value;
d.status = '1';
return d;
},
mounted() {
this.editor = CodeMirror.fromTextArea(
document.getElementById('editor'),
{
lineNumbers: false,
lineWrapping: true,
styleActiveLine: true,
autoCloseBrackets: true,
theme: this.currentEditorTheme,
2019-11-10 16:59:23 +08:00
mode: 'text/x-markdown'
}
);
2019-11-10 15:52:46 +08:00
this.editor.on("change", (cm, change) => {
this.refresh();
this.saveEditorContent();
});
this.wxRenderer = new WxRenderer({
theme: setColor(this.currentColor),
fonts: this.currentFont,
size: this.currentSize,
status: this.status
});
// 如果有编辑内容被保存则读取,否则加载默认文档
if (localStorage.getItem("__editor_content")) {
this.editor.setValue(localStorage.getItem("__editor_content"));
} else {
this.setDefaultContent();
}
},
methods: {
2019-11-10 15:52:46 +08:00
renderWeChat(source) {
let output = marked(source, { renderer: this.wxRenderer.getRenderer(this.status) });
// 去除第一行的 margin-top
output = output.replace(/(style=".*?)"/, '$1;margin-top: 0"');
if (this.status) {
// 引用脚注
output += this.wxRenderer.buildFootnotes();
// 附加的一些 style
output += this.wxRenderer.buildAddition();
}
2019-11-10 16:59:23 +08:00
return output;
},
2019-11-10 15:52:46 +08:00
editorThemeChanged(editorTheme) {
2019-11-10 16:59:23 +08:00
this.editor.setOption('theme', editorTheme);
},
2019-11-10 15:52:46 +08:00
fontChanged(fonts) {
this.wxRenderer.setOptions({
fonts: fonts
});
2019-11-10 16:59:23 +08:00
this.refresh();
},
2019-11-10 15:52:46 +08:00
sizeChanged(size) {
this.wxRenderer.setOptions({
size: size
});
2019-11-10 16:59:23 +08:00
this.refresh();
},
2019-11-10 15:52:46 +08:00
colorChanged(color) {
let theme = setColor(color)
this.wxRenderer.setOptions({
theme: theme
2019-11-10 16:59:23 +08:00
});
this.refresh();
},
// 图片上传结束
uploaded(response, file, fileList) {
if (response.success) {
// 上传成功,获取光标
const cursor = this.editor.getCursor();
const imageUrl = response.data.url
const markdownImage = `![](${imageUrl})`
// 将 Markdown 形式的 URL 插入编辑框光标所在位置
this.editor.replaceSelection(`\n${markdownImage}\n`, cursor);
this.$message({
showClose: true,
message: '图片插入成功',
type: 'success'
});
this.refresh();
} else {
// 上传失败
this.$message({
showClose: true,
message: response.message,
type: 'error'
});
}
},
failed(error, file, fileList) {
console.log(error)
},
uploading(event, file, fileList) {
this.$message({
showClose: true,
message: '图片上传中...',
type: 'info'
});
},
// 刷新右侧预览
2019-11-10 15:52:46 +08:00
refresh() {
2019-11-10 16:59:23 +08:00
this.output = this.renderWeChat(this.editor.getValue(0));
},
// 重置页面
reset() {
this.$confirm('此操作将丢失本地缓存的文本和自定义样式,是否继续?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
center: true
}).then(() => {
localStorage.removeItem('__editor_content');
localStorage.removeItem('__css_content');
this.setDefaultContent();
this.editor.focus();
this.refresh();
}).catch(() => {
this.editor.focus();
});
},
statusChanged() {
this.refresh();
},
// 将左侧编辑器内容保存到 LocalStorage
2019-11-10 15:52:46 +08:00
saveEditorContent() {
let content = this.editor.getValue(0);
2019-11-10 15:52:46 +08:00
if (content) {
localStorage.setItem("__editor_content", content);
} else {
localStorage.removeItem("__editor_content");
}
},
setDefaultContent() {
axios({
method: 'get',
url: './assets/default-content.md'
}).then(resp => {
this.editor.setValue(resp.data);
}).catch(err => {
this.editor.setValue('# Your markdown here\n');
})
},
2019-11-10 15:52:46 +08:00
copy() {
let clipboardDiv = document.getElementById('output');
clipboardDiv.focus();
window.getSelection().removeAllRanges();
let range = document.createRange();
range.setStartBefore(clipboardDiv.firstChild);
range.setEndAfter(clipboardDiv.lastChild);
window.getSelection().addRange(range);
this.refresh()
try {
if (document.execCommand('copy')) {
this.$notify({
2019-11-05 19:31:36 +08:00
showClose: true,
message: '已复制文章到剪贴板,可直接到公众号后台粘贴',
offset: 80,
duration: 1600,
2019-11-05 19:31:36 +08:00
type: 'success'
});
} else {
this.$notify({
2019-11-05 19:31:36 +08:00
showClose: true,
message: '未能复制文章到剪贴板,请全选后右键复制',
offset: 80,
duration: 1600,
2019-11-05 19:31:36 +08:00
type: 'warning'
});
}
} catch (err) {
this.$notify({
2019-11-05 19:31:36 +08:00
showClose: true,
message: '未能复制文章到剪贴板,请全选后右键复制',
offset: 80,
duration: 1600,
2019-11-05 19:31:36 +08:00
type: 'warning'
});
}
},
2019-11-10 16:59:23 +08:00
visit(url) {
window.open(url);
}
},
2019-11-10 15:52:46 +08:00
updated() {
this.$nextTick(() => {
prettyPrint();
})
}
});