|
|
'use strict'
/* global $, siteRoot */
let mde
export default { name: 'editor', props: ['currentPath'], data() { return {} }, computed: { insertContent() { return this.$store.state.editor.insertContent } }, methods: { insert(content) { if (mde.codemirror.doc.somethingSelected()) { mde.codemirror.execCommand('singleSelection') } mde.codemirror.doc.replaceSelection(this.insertContent) }, save() { let self = this this.$http.put(window.location.href, { markdown: mde.value() }).then(resp => { return resp.json() }).then(resp => { if (resp.ok) { window.location.assign(siteRoot + '/' + self.currentPath) } else { self.$store.dispatch('alert', { style: 'red', icon: 'ui-2_square-remove-09', msg: resp.msg }) } }).catch(err => { self.$store.dispatch('alert', { style: 'red', icon: 'ui-2_square-remove-09', msg: 'Error: ' + err.body.msg }) }) } }, mounted() { let self = this FuseBox.import('/js/simplemde/simplemde.min.js', (SimpleMDE) => { mde = new SimpleMDE({ autofocus: true, autoDownloadFontAwesome: false, element: this.$refs.editorTextArea, placeholder: 'Enter Markdown formatted content here...', spellChecker: false, status: false, toolbar: [ { name: 'bold', action: SimpleMDE.toggleBold, className: 'icon-bold', title: 'Bold' }, { name: 'italic', action: SimpleMDE.toggleItalic, className: 'icon-italic', title: 'Italic' }, { name: 'strikethrough', action: SimpleMDE.toggleStrikethrough, className: 'icon-strikethrough', title: 'Strikethrough' }, '|', { name: 'heading-1', action: SimpleMDE.toggleHeading1, className: 'icon-header fa-header-x fa-header-1', title: 'Header (Level 1)' }, { name: 'heading-2', action: SimpleMDE.toggleHeading2, className: 'icon-header fa-header-x fa-header-2', title: 'Header (Level 2)' }, { name: 'heading-3', action: SimpleMDE.toggleHeading3, className: 'icon-header fa-header-x fa-header-3', title: 'Header (Level 3)' }, { name: 'quote', action: SimpleMDE.toggleBlockquote, className: 'nc-icon-outline text_quote', title: 'Quote' }, '|', { name: 'unordered-list', action: SimpleMDE.toggleUnorderedList, className: 'nc-icon-outline text_list-bullet', title: 'Bullet List' }, { name: 'ordered-list', action: SimpleMDE.toggleOrderedList, className: 'nc-icon-outline text_list-numbers', title: 'Numbered List' }, '|', { name: 'link', action: (editor) => { window.alert('Coming soon!') // todo
}, className: 'nc-icon-outline ui-2_link-68', title: 'Insert Link' }, { name: 'image', action: (editor) => { self.$store.dispatch('editorFile/open', { mode: 'image' }) }, className: 'nc-icon-outline design_image', title: 'Insert Image' }, { name: 'file', action: (editor) => { self.$store.dispatch('editorFile/open', { mode: 'file' }) }, className: 'nc-icon-outline files_zip-54', title: 'Insert File' }, { name: 'video', action: (editor) => { self.$store.dispatch('editorVideo/open') }, className: 'nc-icon-outline media-1_video-64', title: 'Insert Video Player' }, '|', { name: 'inline-code', action: (editor) => { if (!editor.codemirror.doc.somethingSelected()) { return self.$store.dispatch('alert', { style: 'orange', icon: 'design_drag', msg: 'Invalid selection. Select at least 1 character.' }) } let curSel = editor.codemirror.doc.getSelections() curSel = self._.map(curSel, (s) => { return '`' + s + '`' }) editor.codemirror.doc.replaceSelections(curSel) }, className: 'nc-icon-outline arrows-4_enlarge-46', title: 'Inline Code' }, { name: 'code-block', action: (editor) => { self.$store.dispatch('editorCodeblock/open', { initialContent: (mde.codemirror.doc.somethingSelected()) ? mde.codemirror.doc.getSelection() : '' }) }, className: 'nc-icon-outline design_code', title: 'Code Block' }, '|', { name: 'table', action: (editor) => { window.alert('Coming soon!') // todo
}, className: 'nc-icon-outline ui-2_grid-square', title: 'Insert Table' }, { name: 'horizontal-rule', action: SimpleMDE.drawHorizontalRule, className: 'nc-icon-outline design_distribute-vertical', title: 'Horizontal Rule' } ], shortcuts: { 'toggleBlockquote': null, 'toggleFullScreen': null } })
// Save
$(window).bind('keydown', (ev) => { if (ev.ctrlKey || ev.metaKey) { switch (String.fromCharCode(ev.which).toLowerCase()) { case 's': ev.preventDefault() self.save() break } } })
// Listeners
this.$root.$on('editor/save', this.save) this.$root.$on('editor/insert', this.insert)
this.$store.dispatch('pageLoader/complete') }) } }
|