mirror of
https://github.com/linsa-io/linsa.git
synced 2026-01-12 12:20:23 +01:00
Move to TanStack Start from Next.js (#184)
This commit is contained in:
33
web/shared/la-editor/extensions/heading/heading.ts
Normal file
33
web/shared/la-editor/extensions/heading/heading.ts
Normal file
@@ -0,0 +1,33 @@
|
||||
/*
|
||||
* Add heading level validation. decimal (0-9)
|
||||
* Add heading class to heading element
|
||||
*/
|
||||
import { mergeAttributes } from "@tiptap/core"
|
||||
import TiptapHeading from "@tiptap/extension-heading"
|
||||
import type { Level } from "@tiptap/extension-heading"
|
||||
|
||||
export const Heading = TiptapHeading.extend({
|
||||
addOptions() {
|
||||
return {
|
||||
...this.parent?.(),
|
||||
levels: [1, 2, 3] as Level[],
|
||||
HTMLAttributes: {
|
||||
class: "heading-node",
|
||||
},
|
||||
}
|
||||
},
|
||||
|
||||
renderHTML({ node, HTMLAttributes }) {
|
||||
const nodeLevel = parseInt(node.attrs.level, 10) as Level
|
||||
const hasLevel = this.options.levels.includes(nodeLevel)
|
||||
const level = hasLevel ? nodeLevel : this.options.levels[0]
|
||||
|
||||
return [
|
||||
`h${level}`,
|
||||
mergeAttributes(this.options.HTMLAttributes, HTMLAttributes),
|
||||
0,
|
||||
]
|
||||
},
|
||||
})
|
||||
|
||||
export default Heading
|
||||
1
web/shared/la-editor/extensions/heading/index.ts
Normal file
1
web/shared/la-editor/extensions/heading/index.ts
Normal file
@@ -0,0 +1 @@
|
||||
export * from "./heading"
|
||||
Reference in New Issue
Block a user