Created
          June 23, 2020 10:44 
        
      - 
      
- 
        Save waaronking/0e1712e1c1aea1d73b0cc2cb4129edde to your computer and use it in GitHub Desktop. 
    TipTap Align-Text Example
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | <!-- This file is mainly pseudo code with parts copied from a working project to illustrate how tiptap-aligntext.plugin.js can be implemented into your project --> | |
| <template> | |
| <div> | |
| <editor-menu-bar :editor="editor" v-slot="{ commands }"> | |
| <div class="menubar"> | |
| <i class="fas fa-align-left" :class="{ 'is-active': editor.activeMarkAttrs.aligntext.align === 'left' }" @click="commands.aligntext({ align: 'left' })"></i> | |
| <i class="fas fa-align-center" :class="{ 'is-active': editor.activeMarkAttrs.aligntext.align === 'center' }" @click="commands.aligntext({ align: 'center' })"></i> | |
| <i class="fas fa-align-right" :class="{ 'is-active': editor.activeMarkAttrs.aligntext.align === 'right' }" @click="commands.aligntext({ align: 'right' })"></i> | |
| <i class="fas fa-align-justify" :class="{ 'is-active': editor.activeMarkAttrs.aligntext.align === 'justify' }" @click="commands.aligntext({ align: 'justify' })"></i> | |
| </div> | |
| </editor-menu-bar> | |
| <editor-content :editor="editor" /> | |
| </div> | |
| </template> | |
| <script> | |
| import { Editor, EditorContent, EditorMenuBar } from 'tiptap'; | |
| import { Heading, Bold, Italic, Strike, Underline, History } from 'tiptap-extensions'; | |
| import AlignText from './path/tiptap-aligntext.plugin.js'; | |
| export default { | |
| name: 'example-tiptap-aligntext', | |
| components: { EditorContent, EditorMenuBar }, | |
| mounted: function () { | |
| this.$nextTick(() => this.init()); | |
| }, | |
| data: () => ({ | |
| editor: null | |
| }), | |
| methods: { | |
| async init() { | |
| this.editor = new Editor({ | |
| extensions: [ | |
| new Heading({ levels: [1, 2, 3] }), | |
| new Bold(), | |
| new Italic(), | |
| new Strike(), | |
| new Underline(), | |
| new History(), | |
| new AlignText() | |
| ], | |
| content: "Type your text here" | |
| }); | |
| } | |
| } | |
| } | |
| </script> | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | /* Working MARK example BASED ON: https://github.com/scrumpy/tiptap/issues/157 AND https://github.com/scrumpy/tiptap/issues/180 */ | |
| import { Mark } from 'tiptap'; | |
| import { updateMark, markInputRule } from 'tiptap-commands'; | |
| export default class AlignText extends Mark { | |
| get name() { | |
| return 'aligntext'; | |
| } | |
| get schema() { | |
| return { | |
| attrs: { | |
| align: { | |
| default: 'left', | |
| }, | |
| }, | |
| parseDOM: [ | |
| { | |
| style: 'text-align', | |
| getAttrs: value => ({ align: value }), | |
| }, | |
| ], | |
| toDOM: mark => ['span', { style: `text-align: ${mark.attrs.align}; display: block` }, 0], | |
| }; | |
| } | |
| commands({ type }) { | |
| return attrs => updateMark(type, attrs); | |
| } | |
| inputRules({ type }) { | |
| return [ | |
| markInputRule(/(?:\*\*|__)([^*_]+)(?:\*\*|__)$/, type), | |
| ]; | |
| } | |
| } | 
@Yiddishe-Kop @waaronking These are great, do you know how I could continue the alignment from previous line when hitting enter?
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
Thanks a lot! 🎉