提交 00e9ed9c 编写于 作者: G guoweijia

feat:upload

上级 8c049a9a
<template>
<div :class="['md_container', { active: isFocus }]">
<markdown-header />
<markdownPreview v-if="showPreview" />
<markdown-editor v-else />
<markdownPreview v-show="showPreview" />
<markdown-editor v-show="!showPreview" />
<markdown-footer
:can-attach-file="canAttachFile"
v-if="!showPreview && canAttachFile"
......@@ -22,9 +22,33 @@ export default {
markdownEditor,
markdownPreview
},
computed: {
...mapState(["showPreview", "isFocus", "canAttachFile"])
...mapState([
"showPreview",
"isFocus",
"canAttachFile",
"text",
"html",
"fileList"
])
},
watch: {
html: {
immediate: true,
handler: function(val) {
this.$emit("change", {
text: this.text,
html: this.html
});
}
},
fileList: {
immediate: false,
deep: true,
handler: function(val) {
this.$emit("upload", val);
}
}
}
};
</script>
......
import store from '@/store'
// 获取选中文本信息
export function getSelectionInfo(selectorId) {
const selector = document.getElementById(selectorId);
// const selection = window.getSelection();
......@@ -22,6 +25,15 @@ export function formatText(text, selectionInfo, startStr = "", endStr = "") {
);
}
//
export function updateText(startStr, endStr) {
const selectionInfo = store.state.selectionInfo;
const originalText = store.state.text;
const newText = formatText(originalText, selectionInfo, startStr, endStr);
if (!newText) return;
store.commit("setText", newText);
}
// 初始化样式
export function initStyle({
borderColor,
......
......@@ -5,6 +5,7 @@
@change="setText(textContent)"
@focus="setFocus(true)"
@blur="setFocus(false)"
@paste="pasteFile"
v-model="textContent"
rows="10"
>
......@@ -55,6 +56,19 @@ export default {
const info = getSelectionInfo(this.id);
if (!info) return;
this.setSelectionInfo(info);
},
pasteFile(event) {
let fileList = [];
const items = (event.clipboardData || window.clipboardData).items;
for (let i = 0; i < items.length; i++) {
console.log(items[i]);
if (items[i].type.indexOf("image") !== -1) {
fileList.push(items[i].getAsFile());
break;
}
}
if (!fileList.length) return;
console.log(fileList);
}
}
};
......@@ -63,6 +77,7 @@ export default {
.md_textarea {
position: relative;
padding: 10px 0;
background: #fff;
&.fullScreen {
position: fixed;
width: 100vw;
......
......@@ -15,7 +15,7 @@
</template>
<script>
import { mapState, mapMutations } from "vuex";
import { formatText } from "@/assets/js/utils";
export default {
data() {
return {};
......@@ -24,26 +24,10 @@ export default {
...mapState(["text", "selectionInfo"])
},
methods: {
...mapMutations(["setText"]),
...mapMutations(["setText", "setFileList"]),
upload(e) {
const fileList = Array.from(e.target.files);
console.log(fileList);
fileList.forEach(item => {
console.log(item);
// const formData = new formData();
// formData.append("file", item);
this.updateText(
"![",
"]()"
);
});
},
updateText(startStr, endStr) {
const selectionInfo = this.selectionInfo;
const originalText = this.text;
const newText = formatText(originalText, selectionInfo, startStr, endStr);
if (!newText) return;
this.setText(newText);
this.setFileList(fileList);
}
}
};
......
......@@ -9,7 +9,7 @@
</template>
<script>
import { mapMutations, mapState } from "vuex";
import { formatText } from "@/assets/js/utils";
import { updateText } from "@/assets/js/utils";
export default {
props: {
info: {
......@@ -32,11 +32,11 @@ export default {
case "ul":
case "task":
case "table":
this.updateText(startStr, endStr);
updateText(startStr, endStr);
break;
case "ol":
let ulNum = this.ulNum;
this.updateText(`\n${ulNum++}. `, "");
updateText(`\n${ulNum++}. `, "");
this.setUlNum(ulNum);
break;
case "fullScreen":
......@@ -45,13 +45,6 @@ export default {
default:
break;
}
},
updateText(startStr, endStr) {
const selectionInfo = this.selectionInfo;
const originalText = this.text;
const newText = formatText(originalText, selectionInfo, startStr, endStr);
if (!newText) return;
this.setText(newText);
}
}
};
......
......@@ -3,13 +3,13 @@ import App from "./App";
import store from "./store";
import Vtip from "vtip";
import "vtip/lib/index.min.css";
import { initStyle, isNotEmpty } from "@/assets/js/utils";
import { initStyle, isNotEmpty, updateText } from "@/assets/js/utils";
import "@/assets/style/global.less";
Vue.use(Vtip.directive);
function initMdEditor(obj) {
const { el, onChange, canAttachFile, themeOptions } = obj;
const { el, onChange, onUpload, canAttachFile, themeOptions } = obj;
if (!el || !document.querySelector(el)) throw new Error("请指定容器");
if (isNotEmpty(themeOptions)) initStyle(themeOptions);
if (isNotEmpty(canAttachFile))
......@@ -17,11 +17,16 @@ function initMdEditor(obj) {
new Vue({
store,
render: h =>
render: (h) =>
h(App, {
on: {
change(val) {
onChange(val);
},
upload(val) {
onUpload(val, function(res) {
updateText("\n\n![img](", `${res})\n`);
});
}
}
})
......
import Vue from "vue";
import Vuex from "vuex";
import { formatText } from "@/assets/js/utils";
Vue.use(Vuex);
......@@ -79,6 +80,7 @@ export default new Vuex.Store({
tip: "全屏模式"
}
],
fileList: "",
ulNum: 1,
text: `
# 标题一标题一标题一
......@@ -150,6 +152,9 @@ _斜体文字_
},
setCanAttachFile(state, val) {
state.canAttachFile = val;
},
setFileList(state, val) {
state.fileList = val;
}
}
});
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册