| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 |
- import { marks } from 'prosemirror-schema-basic'
- import type { MarkSpec } from 'prosemirror-model'
- const subscript: MarkSpec = {
- excludes: 'subscript',
- parseDOM: [
- { tag: 'sub' },
- {
- style: 'vertical-align',
- getAttrs: value => value === 'sub' && null
- },
- ],
- toDOM: () => ['sub', 0],
- }
- const superscript: MarkSpec = {
- excludes: 'superscript',
- parseDOM: [
- { tag: 'sup' },
- {
- style: 'vertical-align',
- getAttrs: value => value === 'super' && null
- },
- ],
- toDOM: () => ['sup', 0],
- }
- const strikethrough: MarkSpec = {
- parseDOM: [
- { tag: 'strike' },
- {
- style: 'text-decoration',
- getAttrs: value => value === 'line-through' && null
- },
- {
- style: 'text-decoration-line',
- getAttrs: value => value === 'line-through' && null
- },
- ],
- toDOM: () => ['span', { style: 'text-decoration-line: line-through;' }, 0],
- }
- const underline: MarkSpec = {
- parseDOM: [
- { tag: 'u' },
- {
- style: 'text-decoration',
- getAttrs: value => value === 'underline' && null
- },
- {
- style: 'text-decoration-line',
- getAttrs: value => value === 'underline' && null
- },
- ],
- toDOM: () => ['span', { style: 'text-decoration: underline;' }, 0],
- }
- const forecolor: MarkSpec = {
- attrs: {
- color: {},
- },
- inline: true,
- group: 'inline',
- parseDOM: [
- {
- style: 'color',
- getAttrs: color => color ? { color } : {}
- },
- ],
- toDOM: mark => {
- const { color } = mark.attrs
- let style = ''
- if (color) style += `color: ${color};`
- return ['span', { style }, 0]
- },
- }
- const backcolor: MarkSpec = {
- attrs: {
- backcolor: {},
- },
- inline: true,
- group: 'inline',
- parseDOM: [
- {
- style: 'background-color',
- getAttrs: backcolor => backcolor ? { backcolor } : {}
- },
- ],
- toDOM: mark => {
- const { backcolor } = mark.attrs
- let style = ''
- if (backcolor) style += `background-color: ${backcolor};`
- return ['span', { style }, 0]
- },
- }
- const fontsize: MarkSpec = {
- attrs: {
- fontsize: {},
- },
- inline: true,
- group: 'inline',
- parseDOM: [
- {
- style: 'font-size',
- getAttrs: fontsize => fontsize ? { fontsize } : {}
- },
- ],
- toDOM: mark => {
- const { fontsize } = mark.attrs
- let style = ''
- if (fontsize) style += `font-size: ${fontsize};`
- return ['span', { style }, 0]
- },
- }
- const fontname: MarkSpec = {
- attrs: {
- fontname: {},
- },
- inline: true,
- group: 'inline',
- parseDOM: [
- {
- style: 'font-family',
- getAttrs: fontname => {
- return { fontname: fontname && typeof fontname === 'string' ? fontname.replace(/[\"\']/g, '') : '' }
- }
- },
- ],
- toDOM: mark => {
- const { fontname } = mark.attrs
- let style = ''
- if (fontname) style += `font-family: ${fontname};`
- return ['span', { style }, 0]
- },
- }
- const link: MarkSpec = {
- attrs: {
- href: {},
- title: { default: null },
- target: { default: '_blank' },
- },
- inclusive: false,
- parseDOM: [
- {
- tag: 'a[href]',
- getAttrs: dom => {
- const href = (dom as HTMLElement).getAttribute('href')
- const title = (dom as HTMLElement).getAttribute('title')
- return { href, title }
- }
- },
- ],
- toDOM: node => ['a', node.attrs, 0],
- }
- const mark: MarkSpec = {
- attrs: {
- index: { default: null },
- },
- parseDOM: [
- {
- tag: 'mark',
- getAttrs: dom => {
- const index = (dom as HTMLElement).dataset.index
- return { index }
- }
- },
- ],
- toDOM: node => ['mark', { 'data-index': node.attrs.index }, 0],
- }
- const { em, strong, code } = marks
- export default {
- em,
- strong,
- fontsize,
- fontname,
- code,
- forecolor,
- backcolor,
- subscript,
- superscript,
- strikethrough,
- underline,
- link,
- mark,
- }
|