2018-09-02 21:13:57 +08:00
|
|
|
<template>
|
2018-10-24 05:12:56 +08:00
|
|
|
<div class="editor">
|
|
|
|
<editor-content class="editor__content" :editor="editor" />
|
2018-09-02 21:13:57 +08:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2018-10-24 05:12:56 +08:00
|
|
|
import { Editor, EditorContent } from 'tiptap'
|
2018-09-02 21:13:57 +08:00
|
|
|
import {
|
|
|
|
CodeBlockHighlightNode,
|
|
|
|
HardBreakNode,
|
|
|
|
HeadingNode,
|
|
|
|
BoldMark,
|
|
|
|
CodeMark,
|
|
|
|
ItalicMark,
|
|
|
|
} from 'tiptap-extensions'
|
|
|
|
|
2018-10-24 05:12:56 +08:00
|
|
|
import javascript from 'highlight.js/lib/languages/javascript'
|
|
|
|
import css from 'highlight.js/lib/languages/css'
|
|
|
|
|
2018-09-07 05:18:30 +08:00
|
|
|
import {
|
2018-10-14 00:43:59 +08:00
|
|
|
JavaScriptExample,
|
|
|
|
CSSExample,
|
|
|
|
ExplicitImportExample,
|
2018-09-07 05:18:30 +08:00
|
|
|
} from './examples'
|
2018-09-02 21:13:57 +08:00
|
|
|
|
|
|
|
export default {
|
|
|
|
components: {
|
2018-10-24 05:12:56 +08:00
|
|
|
EditorContent,
|
2018-09-02 21:13:57 +08:00
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
2018-10-24 05:12:56 +08:00
|
|
|
editor: new Editor({
|
|
|
|
extensions: [
|
|
|
|
new CodeBlockHighlightNode({
|
|
|
|
languages: {
|
|
|
|
javascript,
|
|
|
|
css,
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
new HardBreakNode(),
|
|
|
|
new HeadingNode({ maxLevel: 3 }),
|
|
|
|
new BoldMark(),
|
|
|
|
new CodeMark(),
|
|
|
|
new ItalicMark(),
|
|
|
|
],
|
|
|
|
content: `
|
|
|
|
<h2>
|
|
|
|
Code Highlighting
|
|
|
|
</h2>
|
|
|
|
<p>
|
|
|
|
These are code blocks with <strong>automatic syntax highlighting</strong> based on highlight.js.
|
|
|
|
</p>
|
|
|
|
<pre><code>${JavaScriptExample}</code></pre>
|
|
|
|
<pre><code>${CSSExample}</code></pre>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Note: tiptap doesn't import syntax highlighting language definitions from highlight.js. You
|
|
|
|
<strong>must</strong> import them and initialize the extension with all languages you want to support:
|
|
|
|
</p>
|
|
|
|
<pre><code>${ExplicitImportExample}</code></pre>
|
|
|
|
`,
|
|
|
|
}),
|
2018-09-02 21:13:57 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
2018-09-03 19:55:45 +08:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
|
|
|
|
pre {
|
|
|
|
&::before {
|
|
|
|
content: attr(data-language);
|
|
|
|
text-transform: uppercase;
|
|
|
|
display: block;
|
|
|
|
text-align: right;
|
|
|
|
font-weight: bold;
|
|
|
|
font-size: 0.6rem;
|
|
|
|
}
|
|
|
|
|
|
|
|
code {
|
|
|
|
|
|
|
|
.hljs-comment,
|
|
|
|
.hljs-quote {
|
|
|
|
color: #999999;
|
|
|
|
}
|
|
|
|
|
|
|
|
.hljs-variable,
|
|
|
|
.hljs-template-variable,
|
|
|
|
.hljs-attribute,
|
|
|
|
.hljs-tag,
|
|
|
|
.hljs-name,
|
|
|
|
.hljs-regexp,
|
|
|
|
.hljs-link,
|
|
|
|
.hljs-name,
|
|
|
|
.hljs-selector-id,
|
|
|
|
.hljs-selector-class {
|
|
|
|
color: #f2777a;
|
|
|
|
}
|
|
|
|
|
|
|
|
.hljs-number,
|
|
|
|
.hljs-meta,
|
|
|
|
.hljs-built_in,
|
|
|
|
.hljs-builtin-name,
|
|
|
|
.hljs-literal,
|
|
|
|
.hljs-type,
|
|
|
|
.hljs-params {
|
|
|
|
color: #f99157;
|
|
|
|
}
|
|
|
|
|
|
|
|
.hljs-string,
|
|
|
|
.hljs-symbol,
|
|
|
|
.hljs-bullet {
|
|
|
|
color: #99cc99;
|
|
|
|
}
|
|
|
|
|
|
|
|
.hljs-title,
|
|
|
|
.hljs-section {
|
|
|
|
color: #ffcc66;
|
|
|
|
}
|
|
|
|
|
|
|
|
.hljs-keyword,
|
|
|
|
.hljs-selector-tag {
|
|
|
|
color: #6699cc;
|
|
|
|
}
|
|
|
|
|
|
|
|
.hljs-emphasis {
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
.hljs-strong {
|
|
|
|
font-weight: 700;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|