import {Schema, NodeSpec, MarkSpec, DOMOutputSpec} from "prosemirror-model" const pDOM: DOMOutputSpec = ["p", 0], blockquoteDOM: DOMOutputSpec = ["blockquote", 0], hrDOM: DOMOutputSpec = ["hr"], preDOM: DOMOutputSpec = ["pre", ["code", 0]], brDOM: DOMOutputSpec = ["br"] /// [Specs](#model.NodeSpec) for the nodes defined in this schema. export const nodes = { /// NodeSpec The top level document node. doc: { content: "block+" } as NodeSpec, /// A plain paragraph textblock. Represented in the DOM /// as a `

` element. paragraph: { content: "inline*", group: "block", parseDOM: [{tag: "p"}], toDOM() { return pDOM } } as NodeSpec, /// A blockquote (`

`) wrapping one or more blocks. blockquote: { content: "block+", group: "block", defining: true, parseDOM: [{tag: "blockquote"}], toDOM() { return blockquoteDOM } } as NodeSpec, /// A horizontal rule (`
`). horizontal_rule: { group: "block", parseDOM: [{tag: "hr"}], toDOM() { return hrDOM } } as NodeSpec, /// A heading textblock, with a `level` attribute that /// should hold the number 1 to 6. Parsed and serialized as `

` to /// `

` elements. heading: { attrs: {level: {default: 1}}, content: "inline*", group: "block", defining: true, parseDOM: [{tag: "h1", attrs: {level: 1}}, {tag: "h2", attrs: {level: 2}}, {tag: "h3", attrs: {level: 3}}, {tag: "h4", attrs: {level: 4}}, {tag: "h5", attrs: {level: 5}}, {tag: "h6", attrs: {level: 6}}], toDOM(node) { return ["h" + node.attrs.level, 0] } } as NodeSpec, /// A code listing. Disallows marks or non-text inline /// nodes by default. Represented as a `
` element with a
  /// `` element inside of it.
  code_block: {
    content: "text*",
    marks: "",
    group: "block",
    code: true,
    defining: true,
    parseDOM: [{tag: "pre", preserveWhitespace: "full"}],
    toDOM() { return preDOM }
  } as NodeSpec,

  /// The text node.
  text: {
    group: "inline"
  } as NodeSpec,

  /// An inline image (``) node. Supports `src`,
  /// `alt`, and `href` attributes. The latter two default to the empty
  /// string.
  image: {
    inline: true,
    attrs: {
      src: {},
      alt: {default: null},
      title: {default: null}
    },
    group: "inline",
    draggable: true,
    parseDOM: [{tag: "img[src]", getAttrs(dom: HTMLElement) {
      return {
        src: dom.getAttribute("src"),
        title: dom.getAttribute("title"),
        alt: dom.getAttribute("alt")
      }
    }}],
    toDOM(node) { let {src, alt, title} = node.attrs; return ["img", {src, alt, title}] }
  } as NodeSpec,

  /// A hard line break, represented in the DOM as `
`. hard_break: { inline: true, group: "inline", selectable: false, parseDOM: [{tag: "br"}], toDOM() { return brDOM } } as NodeSpec } const emDOM: DOMOutputSpec = ["em", 0], strongDOM: DOMOutputSpec = ["strong", 0], codeDOM: DOMOutputSpec = ["code", 0] /// [Specs](#model.MarkSpec) for the marks in the schema. export const marks = { /// A link. Has `href` and `title` attributes. `title` /// defaults to the empty string. Rendered and parsed as an `` /// element. link: { attrs: { href: {}, title: {default: null} }, inclusive: false, parseDOM: [{tag: "a[href]", getAttrs(dom: HTMLElement) { return {href: dom.getAttribute("href"), title: dom.getAttribute("title")} }}], toDOM(node) { let {href, title} = node.attrs; return ["a", {href, title}, 0] } } as MarkSpec, /// An emphasis mark. Rendered as an `` element. Has parse rules /// that also match `` and `font-style: italic`. em: { parseDOM: [ {tag: "i"}, {tag: "em"}, {style: "font-style=italic"}, {style: "font-style=normal", clearMark: m => m.type.name == "em"} ], toDOM() { return emDOM } } as MarkSpec, /// A strong mark. Rendered as ``, parse rules also match /// `` and `font-weight: bold`. strong: { parseDOM: [ {tag: "strong"}, // This works around a Google Docs misbehavior where // pasted content will be inexplicably wrapped in `` // tags with a font-weight normal. {tag: "b", getAttrs: (node: HTMLElement) => node.style.fontWeight != "normal" && null}, {style: "font-weight=400", clearMark: m => m.type.name == "strong"}, {style: "font-weight", getAttrs: (value: string) => /^(bold(er)?|[5-9]\d{2,})$/.test(value) && null}, ], toDOM() { return strongDOM } } as MarkSpec, /// Code font mark. Represented as a `` element. code: { parseDOM: [{tag: "code"}], toDOM() { return codeDOM } } as MarkSpec } /// This schema roughly corresponds to the document schema used by /// [CommonMark](http://commonmark.org/), minus the list elements, /// which are defined in the [`prosemirror-schema-list`](#schema-list) /// module. /// /// To reuse elements from this schema, extend or read from its /// `spec.nodes` and `spec.marks` [properties](#model.Schema.spec). export const schema = new Schema({nodes, marks})