From 7142cb40d7dc490ac7816b7cc7c03100ab922df8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Benjamin=20B=C3=A4dorf?= Date: Tue, 22 Mar 2022 21:56:45 +0100 Subject: [PATCH] Push latest docs --- docs/api/@schlechtenburg/core.html | 21 +++++ docs/api/@schlechtenburg/heading.html | 21 +++++ docs/api/@schlechtenburg/image.html | 21 +++++ docs/api/@schlechtenburg/layout.html | 21 +++++ docs/api/@schlechtenburg/paragraph.html | 21 +++++ docs/api/@schlechtenburg/standalone.html | 21 +++++ .../api_@schlechtenburg_core.md.4063a713.js | 1 + ...i_@schlechtenburg_core.md.4063a713.lean.js | 1 + ...api_@schlechtenburg_heading.md.ed89ddd1.js | 1 + ...schlechtenburg_heading.md.ed89ddd1.lean.js | 1 + .../api_@schlechtenburg_image.md.8d0d9fd9.js | 1 + ..._@schlechtenburg_image.md.8d0d9fd9.lean.js | 1 + .../api_@schlechtenburg_layout.md.1da56817.js | 1 + ...@schlechtenburg_layout.md.1da56817.lean.js | 1 + ...i_@schlechtenburg_paragraph.md.8709c1d7.js | 1 + ...hlechtenburg_paragraph.md.8709c1d7.lean.js | 1 + ..._@schlechtenburg_standalone.md.230a9366.js | 1 + ...lechtenburg_standalone.md.230a9366.lean.js | 1 + docs/assets/app.d1307649.js | 1 + docs/assets/chunks/ExampleEditor.08243b7c.js | 1 + docs/assets/chunks/edit.834ae1b2.js | 1 + docs/assets/chunks/edit.a47862d5.js | 1 + docs/assets/chunks/edit.ebdd490e.js | 1 + docs/assets/chunks/edit.f8d11498.js | 1 + docs/assets/chunks/view.0dc125f4.js | 1 + docs/assets/chunks/view.28a7114a.js | 1 + docs/assets/chunks/view.403d8802.js | 1 + docs/assets/chunks/view.52355471.js | 1 + docs/assets/chunks/view.5d50156a.js | 1 + docs/assets/guide_examples.md.f568382d.js | 1 + .../assets/guide_examples.md.f568382d.lean.js | 1 + docs/assets/guide_installation.md.491f5af1.js | 77 +++++++++++++++++ .../guide_installation.md.491f5af1.lean.js | 1 + docs/assets/guide_why.md.1cac0594.js | 9 ++ docs/assets/guide_why.md.1cac0594.lean.js | 1 + docs/assets/index.md.3edeae7e.js | 1 + docs/assets/index.md.3edeae7e.lean.js | 1 + docs/guide/examples.html | 22 +++++ docs/guide/installation.html | 84 +++++++++++++++++-- docs/guide/why.html | 12 +-- docs/hashmap.json | 2 +- docs/index.html | 20 ++--- 42 files changed, 354 insertions(+), 27 deletions(-) create mode 100644 docs/api/@schlechtenburg/core.html create mode 100644 docs/api/@schlechtenburg/heading.html create mode 100644 docs/api/@schlechtenburg/image.html create mode 100644 docs/api/@schlechtenburg/layout.html create mode 100644 docs/api/@schlechtenburg/paragraph.html create mode 100644 docs/api/@schlechtenburg/standalone.html create mode 100644 docs/assets/api_@schlechtenburg_core.md.4063a713.js create mode 100644 docs/assets/api_@schlechtenburg_core.md.4063a713.lean.js create mode 100644 docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.js create mode 100644 docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.lean.js create mode 100644 docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.js create mode 100644 docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.lean.js create mode 100644 docs/assets/api_@schlechtenburg_layout.md.1da56817.js create mode 100644 docs/assets/api_@schlechtenburg_layout.md.1da56817.lean.js create mode 100644 docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.js create mode 100644 docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.lean.js create mode 100644 docs/assets/api_@schlechtenburg_standalone.md.230a9366.js create mode 100644 docs/assets/api_@schlechtenburg_standalone.md.230a9366.lean.js create mode 100644 docs/assets/app.d1307649.js create mode 100644 docs/assets/chunks/ExampleEditor.08243b7c.js create mode 100644 docs/assets/chunks/edit.834ae1b2.js create mode 100644 docs/assets/chunks/edit.a47862d5.js create mode 100644 docs/assets/chunks/edit.ebdd490e.js create mode 100644 docs/assets/chunks/edit.f8d11498.js create mode 100644 docs/assets/chunks/view.0dc125f4.js create mode 100644 docs/assets/chunks/view.28a7114a.js create mode 100644 docs/assets/chunks/view.403d8802.js create mode 100644 docs/assets/chunks/view.52355471.js create mode 100644 docs/assets/chunks/view.5d50156a.js create mode 100644 docs/assets/guide_examples.md.f568382d.js create mode 100644 docs/assets/guide_examples.md.f568382d.lean.js create mode 100644 docs/assets/guide_installation.md.491f5af1.js create mode 100644 docs/assets/guide_installation.md.491f5af1.lean.js create mode 100644 docs/assets/guide_why.md.1cac0594.js create mode 100644 docs/assets/guide_why.md.1cac0594.lean.js create mode 100644 docs/assets/index.md.3edeae7e.js create mode 100644 docs/assets/index.md.3edeae7e.lean.js create mode 100644 docs/guide/examples.html diff --git a/docs/api/@schlechtenburg/core.html b/docs/api/@schlechtenburg/core.html new file mode 100644 index 0000000..f3f9a1e --- /dev/null +++ b/docs/api/@schlechtenburg/core.html @@ -0,0 +1,21 @@ + + + + + + @schlechtenburg/core | Schlechtenburg + + + + + + + + + +

@schlechtenburg/core

SbMode

The mode the Schlechtenburg editor is currently in

  • Type Enumeration

  • Members

    • Edit: undefined
    • View: undefined

IBlockData<T>

Schlechtenburg inputs and outputs a plain JS Object that can be JSON stringified. This is the interface type for that data structure. T will be the data type of the specific block being

  • Type Interface

  • Members

    • data: T
    • id: string
    • name: string

IBlockDefinition<T>

Any Block that you create

  • Type Interface

  • Members

    • edit: Component
    • getDefaultData: T
    • icon: string
    • name: string
    • view: Component

IBlockLibrary

Schlechtenburg maintains a library of blocks that are available

  • Type Interface

IBlockProps<T>

Any Block that you create

  • Type Interface

  • Members

    • blockId: string
    • data: T
    • onActivateNext: OnActivateNextCb
    • onActivatePrevious: OnActivatePreviousCb
    • onAppendBlock: OnAppendBlockCb
    • onPrependBlock: OnPrependBlockCb
    • onRemoveSelf: OnRemoveSelfCb
    • onUpdate: OnUpdateSelfCb

ISbMainProps

  • Type Interface

  • Members

    • availableBlocks: undefined
    • block: IBlockData
    • mode: SbMode
    • onUpdate: OnUpdateBlockCb

ITreeNode

Schlechtenburg keeps track of the rendered block tree. This is useful for e.g. the tree select component in the editor header.

  • Type Interface

  • Members

    • children: undefined
    • icon: string
    • id: string
    • name: string

OnActivateNextCb

  • Type Type alias

OnActivatePreviousCb

  • Type Type alias

OnAppendBlockCb

  • Type Type alias

OnPrependBlockCb

  • Type Type alias

OnRemoveSelfCb

  • Type Type alias

OnUpdateBlockCb

  • Type Type alias

OnUpdateSelfCb<T>

  • Type Type alias

SbBlock

Displays a Schlechtenburg block either the mode of the schlechtenburg instance. You can use this to display child blocks inside your own blocks.

  • Type: Component

Props

block

The state for the block.

  • Type IBlockData<any>

onUpdate

Called when the block should be updated.

  • Type OnUpdateBlockCb

  • Default value () => {}

onPrependBlock

Called when a sibling block should be inserted before the block

  • Type OnPrependBlockCb

  • Default value () => {}

onAppendBlock

Called when a sibling block should be inserted after the block

  • Type OnAppendBlockCb

  • Default value () => {}

onRemoveSelf

Called when the block should be removed

  • Type OnRemoveSelfCb

  • Default value () => {}

onActivatePrevious

Called when the previous sibling block should be activated

  • Type OnActivatePreviousCb

  • Default value () => {}

onActivateNext

Called when the next sibling block should be activated

  • Type OnActivateNextCb

  • Default value () => {}

SbBlockOrdering

  • Type: Component

Props

orientation

  • Type string

  • Default value null

onRemove

  • Type func

  • Default value () => {}

onMoveBackward

  • Type func

  • Default value () => {}

onMoveForward

  • Type func

  • Default value () => {}

SbBlockPicker

  • Type: Component

Props

onPickedBlock

  • Type func

  • Default value () => {}

SbBlockPlaceholder

A placeholder for a block. Displays a placeholder for a block, allowing the user to select a block to insert.

  • Type: Component

Props

onInsertBlock

Called when the user picked a block that should be inserted here.

  • Type func

  • Default value () => {}

SbButton

A button in the schlechtenburg theme

  • Type: Component

Props

SbMain

  • Type Variable

SbSelect

A select input in the schlechtenburg theme

  • Type: Component

Props

SbToolbar

Toolbar in the schlechtenburg theme

  • Type: Component

Props

SymActiveBlock

  • Type Variable

SymBlockDimensions

  • Type Variable

SymBlockLibrary

  • Type Variable

SymEditorDimensions

  • Type Variable

SymMode

  • Type Variable

blockProps

  • Type Variable

model

  • Type Variable

generateBlockId

  • Type Function

useActivation

  • Type Function

useBlockSizing

  • Type Function

useDynamicBlocks

  • Type Function

useResizeObserver

  • Type Function
+ + + + + \ No newline at end of file diff --git a/docs/api/@schlechtenburg/heading.html b/docs/api/@schlechtenburg/heading.html new file mode 100644 index 0000000..c569a95 --- /dev/null +++ b/docs/api/@schlechtenburg/heading.html @@ -0,0 +1,21 @@ + + + + + + @schlechtenburg/heading | Schlechtenburg + + + + + + + + + +
+ + + + + \ No newline at end of file diff --git a/docs/api/@schlechtenburg/image.html b/docs/api/@schlechtenburg/image.html new file mode 100644 index 0000000..682a935 --- /dev/null +++ b/docs/api/@schlechtenburg/image.html @@ -0,0 +1,21 @@ + + + + + + @schlechtenburg/image | Schlechtenburg + + + + + + + + + +
+ + + + + \ No newline at end of file diff --git a/docs/api/@schlechtenburg/layout.html b/docs/api/@schlechtenburg/layout.html new file mode 100644 index 0000000..dbb5ee9 --- /dev/null +++ b/docs/api/@schlechtenburg/layout.html @@ -0,0 +1,21 @@ + + + + + + @schlechtenburg/layout | Schlechtenburg + + + + + + + + + +
+ + + + + \ No newline at end of file diff --git a/docs/api/@schlechtenburg/paragraph.html b/docs/api/@schlechtenburg/paragraph.html new file mode 100644 index 0000000..8489397 --- /dev/null +++ b/docs/api/@schlechtenburg/paragraph.html @@ -0,0 +1,21 @@ + + + + + + @schlechtenburg/paragraph | Schlechtenburg + + + + + + + + + +
+ + + + + \ No newline at end of file diff --git a/docs/api/@schlechtenburg/standalone.html b/docs/api/@schlechtenburg/standalone.html new file mode 100644 index 0000000..3abf7f2 --- /dev/null +++ b/docs/api/@schlechtenburg/standalone.html @@ -0,0 +1,21 @@ + + + + + + @schlechtenburg/standalone | Schlechtenburg + + + + + + + + + +
+ + + + + \ No newline at end of file diff --git a/docs/assets/api_@schlechtenburg_core.md.4063a713.js b/docs/assets/api_@schlechtenburg_core.md.4063a713.js new file mode 100644 index 0000000..86d81c0 --- /dev/null +++ b/docs/assets/api_@schlechtenburg_core.md.4063a713.js @@ -0,0 +1 @@ +import{_ as e,c as o,o as l,a as r}from"./app.d1307649.js";const g='{"title":"@schlechtenburg/core","description":"","frontmatter":{},"headers":[{"level":2,"title":"SbMode","slug":"sbmode"},{"level":2,"title":"IBlockData","slug":"iblockdata-t"},{"level":2,"title":"IBlockDefinition","slug":"iblockdefinition-t"},{"level":2,"title":"IBlockLibrary","slug":"iblocklibrary"},{"level":2,"title":"IBlockProps","slug":"iblockprops-t"},{"level":2,"title":"ISbMainProps","slug":"isbmainprops"},{"level":2,"title":"ITreeNode","slug":"itreenode"},{"level":2,"title":"OnActivateNextCb","slug":"onactivatenextcb"},{"level":2,"title":"OnActivatePreviousCb","slug":"onactivatepreviouscb"},{"level":2,"title":"OnAppendBlockCb","slug":"onappendblockcb"},{"level":2,"title":"OnPrependBlockCb","slug":"onprependblockcb"},{"level":2,"title":"OnRemoveSelfCb","slug":"onremoveselfcb"},{"level":2,"title":"OnUpdateBlockCb","slug":"onupdateblockcb"},{"level":2,"title":"OnUpdateSelfCb","slug":"onupdateselfcb-t"},{"level":2,"title":"SbBlock","slug":"sbblock"},{"level":3,"title":"Props","slug":"props"},{"level":2,"title":"SbBlockOrdering","slug":"sbblockordering"},{"level":3,"title":"Props","slug":"props-1"},{"level":2,"title":"SbBlockPicker","slug":"sbblockpicker"},{"level":3,"title":"Props","slug":"props-2"},{"level":2,"title":"SbBlockPlaceholder","slug":"sbblockplaceholder"},{"level":3,"title":"Props","slug":"props-3"},{"level":2,"title":"SbButton","slug":"sbbutton"},{"level":3,"title":"Props","slug":"props-4"},{"level":2,"title":"SbMain","slug":"sbmain"},{"level":2,"title":"SbSelect","slug":"sbselect"},{"level":3,"title":"Props","slug":"props-5"},{"level":2,"title":"SbToolbar","slug":"sbtoolbar"},{"level":3,"title":"Props","slug":"props-6"},{"level":2,"title":"SymActiveBlock","slug":"symactiveblock"},{"level":2,"title":"SymBlockDimensions","slug":"symblockdimensions"},{"level":2,"title":"SymBlockLibrary","slug":"symblocklibrary"},{"level":2,"title":"SymEditorDimensions","slug":"symeditordimensions"},{"level":2,"title":"SymMode","slug":"symmode"},{"level":2,"title":"blockProps","slug":"blockprops"},{"level":2,"title":"model","slug":"model"},{"level":2,"title":"generateBlockId","slug":"generateblockid"},{"level":2,"title":"useActivation","slug":"useactivation"},{"level":2,"title":"useBlockSizing","slug":"useblocksizing"},{"level":2,"title":"useDynamicBlocks","slug":"usedynamicblocks"},{"level":2,"title":"useResizeObserver","slug":"useresizeobserver"}],"relativePath":"api/@schlechtenburg/core.md"}',a={},i=r('

@schlechtenburg/core

SbMode

The mode the Schlechtenburg editor is currently in

  • Type Enumeration

  • Members

    • Edit: undefined
    • View: undefined

IBlockData<T>

Schlechtenburg inputs and outputs a plain JS Object that can be JSON stringified. This is the interface type for that data structure. T will be the data type of the specific block being

  • Type Interface

  • Members

    • data: T
    • id: string
    • name: string

IBlockDefinition<T>

Any Block that you create

  • Type Interface

  • Members

    • edit: Component
    • getDefaultData: T
    • icon: string
    • name: string
    • view: Component

IBlockLibrary

Schlechtenburg maintains a library of blocks that are available

  • Type Interface

IBlockProps<T>

Any Block that you create

  • Type Interface

  • Members

    • blockId: string
    • data: T
    • onActivateNext: OnActivateNextCb
    • onActivatePrevious: OnActivatePreviousCb
    • onAppendBlock: OnAppendBlockCb
    • onPrependBlock: OnPrependBlockCb
    • onRemoveSelf: OnRemoveSelfCb
    • onUpdate: OnUpdateSelfCb

ISbMainProps

  • Type Interface

  • Members

    • availableBlocks: undefined
    • block: IBlockData
    • mode: SbMode
    • onUpdate: OnUpdateBlockCb

ITreeNode

Schlechtenburg keeps track of the rendered block tree. This is useful for e.g. the tree select component in the editor header.

  • Type Interface

  • Members

    • children: undefined
    • icon: string
    • id: string
    • name: string

OnActivateNextCb

  • Type Type alias

OnActivatePreviousCb

  • Type Type alias

OnAppendBlockCb

  • Type Type alias

OnPrependBlockCb

  • Type Type alias

OnRemoveSelfCb

  • Type Type alias

OnUpdateBlockCb

  • Type Type alias

OnUpdateSelfCb<T>

  • Type Type alias

SbBlock

Displays a Schlechtenburg block either the mode of the schlechtenburg instance. You can use this to display child blocks inside your own blocks.

  • Type: Component

Props

block

The state for the block.

  • Type IBlockData<any>

onUpdate

Called when the block should be updated.

  • Type OnUpdateBlockCb

  • Default value () => {}

onPrependBlock

Called when a sibling block should be inserted before the block

  • Type OnPrependBlockCb

  • Default value () => {}

onAppendBlock

Called when a sibling block should be inserted after the block

  • Type OnAppendBlockCb

  • Default value () => {}

onRemoveSelf

Called when the block should be removed

  • Type OnRemoveSelfCb

  • Default value () => {}

onActivatePrevious

Called when the previous sibling block should be activated

  • Type OnActivatePreviousCb

  • Default value () => {}

onActivateNext

Called when the next sibling block should be activated

  • Type OnActivateNextCb

  • Default value () => {}

SbBlockOrdering

  • Type: Component

Props

orientation

  • Type string

  • Default value null

onRemove

  • Type func

  • Default value () => {}

onMoveBackward

  • Type func

  • Default value () => {}

onMoveForward

  • Type func

  • Default value () => {}

SbBlockPicker

  • Type: Component

Props

onPickedBlock

  • Type func

  • Default value () => {}

SbBlockPlaceholder

A placeholder for a block. Displays a placeholder for a block, allowing the user to select a block to insert.

  • Type: Component

Props

onInsertBlock

Called when the user picked a block that should be inserted here.

  • Type func

  • Default value () => {}

SbButton

A button in the schlechtenburg theme

  • Type: Component

Props

SbMain

  • Type Variable

SbSelect

A select input in the schlechtenburg theme

  • Type: Component

Props

SbToolbar

Toolbar in the schlechtenburg theme

  • Type: Component

Props

SymActiveBlock

  • Type Variable

SymBlockDimensions

  • Type Variable

SymBlockLibrary

  • Type Variable

SymEditorDimensions

  • Type Variable

SymMode

  • Type Variable

blockProps

  • Type Variable

model

  • Type Variable

generateBlockId

  • Type Function

useActivation

  • Type Function

useBlockSizing

  • Type Function

useDynamicBlocks

  • Type Function

useResizeObserver

  • Type Function
',121),t=[i];function n(d,s,c,h,p,u){return l(),o("div",null,t)}var k=e(a,[["render",n]]);export{g as __pageData,k as default}; diff --git a/docs/assets/api_@schlechtenburg_core.md.4063a713.lean.js b/docs/assets/api_@schlechtenburg_core.md.4063a713.lean.js new file mode 100644 index 0000000..575ba84 --- /dev/null +++ b/docs/assets/api_@schlechtenburg_core.md.4063a713.lean.js @@ -0,0 +1 @@ +import{_ as e,c as o,o as l,a as r}from"./app.d1307649.js";const g='{"title":"@schlechtenburg/core","description":"","frontmatter":{},"headers":[{"level":2,"title":"SbMode","slug":"sbmode"},{"level":2,"title":"IBlockData","slug":"iblockdata-t"},{"level":2,"title":"IBlockDefinition","slug":"iblockdefinition-t"},{"level":2,"title":"IBlockLibrary","slug":"iblocklibrary"},{"level":2,"title":"IBlockProps","slug":"iblockprops-t"},{"level":2,"title":"ISbMainProps","slug":"isbmainprops"},{"level":2,"title":"ITreeNode","slug":"itreenode"},{"level":2,"title":"OnActivateNextCb","slug":"onactivatenextcb"},{"level":2,"title":"OnActivatePreviousCb","slug":"onactivatepreviouscb"},{"level":2,"title":"OnAppendBlockCb","slug":"onappendblockcb"},{"level":2,"title":"OnPrependBlockCb","slug":"onprependblockcb"},{"level":2,"title":"OnRemoveSelfCb","slug":"onremoveselfcb"},{"level":2,"title":"OnUpdateBlockCb","slug":"onupdateblockcb"},{"level":2,"title":"OnUpdateSelfCb","slug":"onupdateselfcb-t"},{"level":2,"title":"SbBlock","slug":"sbblock"},{"level":3,"title":"Props","slug":"props"},{"level":2,"title":"SbBlockOrdering","slug":"sbblockordering"},{"level":3,"title":"Props","slug":"props-1"},{"level":2,"title":"SbBlockPicker","slug":"sbblockpicker"},{"level":3,"title":"Props","slug":"props-2"},{"level":2,"title":"SbBlockPlaceholder","slug":"sbblockplaceholder"},{"level":3,"title":"Props","slug":"props-3"},{"level":2,"title":"SbButton","slug":"sbbutton"},{"level":3,"title":"Props","slug":"props-4"},{"level":2,"title":"SbMain","slug":"sbmain"},{"level":2,"title":"SbSelect","slug":"sbselect"},{"level":3,"title":"Props","slug":"props-5"},{"level":2,"title":"SbToolbar","slug":"sbtoolbar"},{"level":3,"title":"Props","slug":"props-6"},{"level":2,"title":"SymActiveBlock","slug":"symactiveblock"},{"level":2,"title":"SymBlockDimensions","slug":"symblockdimensions"},{"level":2,"title":"SymBlockLibrary","slug":"symblocklibrary"},{"level":2,"title":"SymEditorDimensions","slug":"symeditordimensions"},{"level":2,"title":"SymMode","slug":"symmode"},{"level":2,"title":"blockProps","slug":"blockprops"},{"level":2,"title":"model","slug":"model"},{"level":2,"title":"generateBlockId","slug":"generateblockid"},{"level":2,"title":"useActivation","slug":"useactivation"},{"level":2,"title":"useBlockSizing","slug":"useblocksizing"},{"level":2,"title":"useDynamicBlocks","slug":"usedynamicblocks"},{"level":2,"title":"useResizeObserver","slug":"useresizeobserver"}],"relativePath":"api/@schlechtenburg/core.md"}',a={},i=r("",121),t=[i];function n(d,s,c,h,p,u){return l(),o("div",null,t)}var k=e(a,[["render",n]]);export{g as __pageData,k as default}; diff --git a/docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.js b/docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.js new file mode 100644 index 0000000..c5fdbc3 --- /dev/null +++ b/docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.js @@ -0,0 +1 @@ +import{_ as e,c as a,o as t,a as d}from"./app.d1307649.js";const f='{"title":"@schlechtenburg/heading","description":"","frontmatter":{},"headers":[{"level":2,"title":"IHeadingData","slug":"iheadingdata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/heading.md"}',l={},n=d('

@schlechtenburg/heading

IHeadingData

  • Type Interface

  • Members

    • align: string
    • level: number
    • value: string

default

  • Type Property

name

  • Type Variable

getDefaultData

  • Type Function
',9),r=[n];function i(o,s,c,h,g,u){return t(),a("div",null,r)}var p=e(l,[["render",i]]);export{f as __pageData,p as default}; diff --git a/docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.lean.js b/docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.lean.js new file mode 100644 index 0000000..b97cb6c --- /dev/null +++ b/docs/assets/api_@schlechtenburg_heading.md.ed89ddd1.lean.js @@ -0,0 +1 @@ +import{_ as e,c as a,o as t,a as d}from"./app.d1307649.js";const f='{"title":"@schlechtenburg/heading","description":"","frontmatter":{},"headers":[{"level":2,"title":"IHeadingData","slug":"iheadingdata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/heading.md"}',l={},n=d("",9),r=[n];function i(o,s,c,h,g,u){return t(),a("div",null,r)}var p=e(l,[["render",i]]);export{f as __pageData,p as default}; diff --git a/docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.js b/docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.js new file mode 100644 index 0000000..9dd4323 --- /dev/null +++ b/docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.js @@ -0,0 +1 @@ +import{_ as e,c as a,o as t,a as r}from"./app.d1307649.js";const f='{"title":"@schlechtenburg/image","description":"","frontmatter":{},"headers":[{"level":2,"title":"IImageData","slug":"iimagedata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/image.md"}',l={},i=r('

@schlechtenburg/image

IImageData

  • Type Interface

  • Members

    • alt: string
    • description: IBlockData
    • src: string

default

  • Type Property

name

  • Type Variable

getDefaultData

  • Type Function
',9),d=[i];function n(o,s,c,h,g,u){return t(),a("div",null,d)}var m=e(l,[["render",n]]);export{f as __pageData,m as default}; diff --git a/docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.lean.js b/docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.lean.js new file mode 100644 index 0000000..b0e66dc --- /dev/null +++ b/docs/assets/api_@schlechtenburg_image.md.8d0d9fd9.lean.js @@ -0,0 +1 @@ +import{_ as e,c as a,o as t,a as r}from"./app.d1307649.js";const f='{"title":"@schlechtenburg/image","description":"","frontmatter":{},"headers":[{"level":2,"title":"IImageData","slug":"iimagedata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/image.md"}',l={},i=r("",9),d=[i];function n(o,s,c,h,g,u){return t(),a("div",null,d)}var m=e(l,[["render",n]]);export{f as __pageData,m as default}; diff --git a/docs/assets/api_@schlechtenburg_layout.md.1da56817.js b/docs/assets/api_@schlechtenburg_layout.md.1da56817.js new file mode 100644 index 0000000..7216583 --- /dev/null +++ b/docs/assets/api_@schlechtenburg_layout.md.1da56817.js @@ -0,0 +1 @@ +import{_ as e,c as a,o as t,a as l}from"./app.d1307649.js";const f='{"title":"@schlechtenburg/layout","description":"","frontmatter":{},"headers":[{"level":2,"title":"ILayoutData","slug":"ilayoutdata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/layout.md"}',r={},o=l('

@schlechtenburg/layout

ILayoutData

  • Type Interface

  • Members

    • children: undefined
    • orientation: string

default

  • Type Property

name

  • Type Variable

getDefaultData

  • Type Function
',9),d=[o];function n(i,s,c,u,h,g){return t(),a("div",null,d)}var p=e(r,[["render",n]]);export{f as __pageData,p as default}; diff --git a/docs/assets/api_@schlechtenburg_layout.md.1da56817.lean.js b/docs/assets/api_@schlechtenburg_layout.md.1da56817.lean.js new file mode 100644 index 0000000..7e3b231 --- /dev/null +++ b/docs/assets/api_@schlechtenburg_layout.md.1da56817.lean.js @@ -0,0 +1 @@ +import{_ as e,c as a,o as t,a as l}from"./app.d1307649.js";const f='{"title":"@schlechtenburg/layout","description":"","frontmatter":{},"headers":[{"level":2,"title":"ILayoutData","slug":"ilayoutdata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/layout.md"}',r={},o=l("",9),d=[o];function n(i,s,c,u,h,g){return t(),a("div",null,d)}var p=e(r,[["render",n]]);export{f as __pageData,p as default}; diff --git a/docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.js b/docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.js new file mode 100644 index 0000000..ff1df0e --- /dev/null +++ b/docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.js @@ -0,0 +1 @@ +import{_ as a,c as e,o as t,a as r}from"./app.d1307649.js";const _='{"title":"@schlechtenburg/paragraph","description":"","frontmatter":{},"headers":[{"level":2,"title":"IParagraphData","slug":"iparagraphdata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/paragraph.md"}',l={},d=r('

@schlechtenburg/paragraph

IParagraphData

  • Type Interface

  • Members

    • align: string
    • value: string

default

  • Type Property

name

  • Type Variable

getDefaultData

  • Type Function
',9),n=[d];function i(h,s,o,c,g,u){return t(),e("div",null,n)}var f=a(l,[["render",i]]);export{_ as __pageData,f as default}; diff --git a/docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.lean.js b/docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.lean.js new file mode 100644 index 0000000..94ba402 --- /dev/null +++ b/docs/assets/api_@schlechtenburg_paragraph.md.8709c1d7.lean.js @@ -0,0 +1 @@ +import{_ as a,c as e,o as t,a as r}from"./app.d1307649.js";const _='{"title":"@schlechtenburg/paragraph","description":"","frontmatter":{},"headers":[{"level":2,"title":"IParagraphData","slug":"iparagraphdata"},{"level":2,"title":"default","slug":"default"},{"level":2,"title":"name","slug":"name"},{"level":2,"title":"getDefaultData","slug":"getdefaultdata"}],"relativePath":"api/@schlechtenburg/paragraph.md"}',l={},d=r("",9),n=[d];function i(h,s,o,c,g,u){return t(),e("div",null,n)}var f=a(l,[["render",i]]);export{_ as __pageData,f as default}; diff --git a/docs/assets/api_@schlechtenburg_standalone.md.230a9366.js b/docs/assets/api_@schlechtenburg_standalone.md.230a9366.js new file mode 100644 index 0000000..227613e --- /dev/null +++ b/docs/assets/api_@schlechtenburg_standalone.md.230a9366.js @@ -0,0 +1 @@ +import{_ as a,c as n,o as s,b as e,d as t}from"./app.d1307649.js";const m='{"title":"@schlechtenburg/standalone","description":"","frontmatter":{},"headers":[{"level":2,"title":"startSchlechtenburg","slug":"startschlechtenburg"}],"relativePath":"api/@schlechtenburg/standalone.md"}',c={},r=e("h1",{id:"schlechtenburg-standalone",tabindex:"-1"},[t("@schlechtenburg/standalone "),e("a",{class:"header-anchor",href:"#schlechtenburg-standalone","aria-hidden":"true"},"#")],-1),l=e("h2",{id:"startschlechtenburg",tabindex:"-1"},[t("startSchlechtenburg "),e("a",{class:"header-anchor",href:"#startschlechtenburg","aria-hidden":"true"},"#")],-1),h=e("ul",null,[e("li",null,[e("strong",null,"Type"),t(),e("code",null,"Function")])],-1),o=[r,l,h];function d(i,u,_,b,g,p){return s(),n("div",null,o)}var x=a(c,[["render",d]]);export{m as __pageData,x as default}; diff --git a/docs/assets/api_@schlechtenburg_standalone.md.230a9366.lean.js b/docs/assets/api_@schlechtenburg_standalone.md.230a9366.lean.js new file mode 100644 index 0000000..227613e --- /dev/null +++ b/docs/assets/api_@schlechtenburg_standalone.md.230a9366.lean.js @@ -0,0 +1 @@ +import{_ as a,c as n,o as s,b as e,d as t}from"./app.d1307649.js";const m='{"title":"@schlechtenburg/standalone","description":"","frontmatter":{},"headers":[{"level":2,"title":"startSchlechtenburg","slug":"startschlechtenburg"}],"relativePath":"api/@schlechtenburg/standalone.md"}',c={},r=e("h1",{id:"schlechtenburg-standalone",tabindex:"-1"},[t("@schlechtenburg/standalone "),e("a",{class:"header-anchor",href:"#schlechtenburg-standalone","aria-hidden":"true"},"#")],-1),l=e("h2",{id:"startschlechtenburg",tabindex:"-1"},[t("startSchlechtenburg "),e("a",{class:"header-anchor",href:"#startschlechtenburg","aria-hidden":"true"},"#")],-1),h=e("ul",null,[e("li",null,[e("strong",null,"Type"),t(),e("code",null,"Function")])],-1),o=[r,l,h];function d(i,u,_,b,g,p){return s(),n("div",null,o)}var x=a(c,[["render",d]]);export{m as __pageData,x as default}; diff --git a/docs/assets/app.d1307649.js b/docs/assets/app.d1307649.js new file mode 100644 index 0000000..eb1914b --- /dev/null +++ b/docs/assets/app.d1307649.js @@ -0,0 +1 @@ +function ts(e,t){const n=Object.create(null),s=e.split(",");for(let r=0;r!!n[r.toLowerCase()]:r=>!!n[r]}const Oo="itemscope,allowfullscreen,formnovalidate,ismap,nomodule,novalidate,readonly",Ro=ts(Oo);function pr(e){return!!e||e===""}function ns(e){if(F(e)){const t={};for(let n=0;n{if(n){const s=n.split(So);s.length>1&&(t[s[0].trim()]=s[1].trim())}}),t}function at(e){let t="";if(pe(e))t=e;else if(F(e))for(let n=0;npe(e)?e:e==null?"":F(e)||ae(e)&&(e.toString===vr||!H(e.toString))?JSON.stringify(e,_r,2):String(e),_r=(e,t)=>t&&t.__v_isRef?_r(e,t.value):vt(t)?{[`Map(${t.size})`]:[...t.entries()].reduce((n,[s,r])=>(n[`${s} =>`]=r,n),{})}:gr(t)?{[`Set(${t.size})`]:[...t.values()]}:ae(t)&&!F(t)&&!br(t)?String(t):t,X={},mt=[],Me=()=>{},Ho=()=>!1,Bo=/^on[^a-z]/,zt=e=>Bo.test(e),ss=e=>e.startsWith("onUpdate:"),xe=Object.assign,rs=(e,t)=>{const n=e.indexOf(t);n>-1&&e.splice(n,1)},Uo=Object.prototype.hasOwnProperty,z=(e,t)=>Uo.call(e,t),F=Array.isArray,vt=e=>yn(e)==="[object Map]",gr=e=>yn(e)==="[object Set]",H=e=>typeof e=="function",pe=e=>typeof e=="string",os=e=>typeof e=="symbol",ae=e=>e!==null&&typeof e=="object",mr=e=>ae(e)&&H(e.then)&&H(e.catch),vr=Object.prototype.toString,yn=e=>vr.call(e),jo=e=>yn(e).slice(8,-1),br=e=>yn(e)==="[object Object]",is=e=>pe(e)&&e!=="NaN"&&e[0]!=="-"&&""+parseInt(e,10)===e,Mt=ts(",key,ref,ref_for,ref_key,onVnodeBeforeMount,onVnodeMounted,onVnodeBeforeUpdate,onVnodeUpdated,onVnodeBeforeUnmount,onVnodeUnmounted"),wn=e=>{const t=Object.create(null);return n=>t[n]||(t[n]=e(n))},Do=/-(\w)/g,Ne=wn(e=>e.replace(Do,(t,n)=>n?n.toUpperCase():"")),Wo=/\B([A-Z])/g,$t=wn(e=>e.replace(Wo,"-$1").toLowerCase()),$n=wn(e=>e.charAt(0).toUpperCase()+e.slice(1)),Fn=wn(e=>e?`on${$n(e)}`:""),Ut=(e,t)=>!Object.is(e,t),Sn=(e,t)=>{for(let n=0;n{Object.defineProperty(e,t,{configurable:!0,enumerable:!1,value:n})},Ko=e=>{const t=parseFloat(e);return isNaN(t)?e:t};let Os;const qo=()=>Os||(Os=typeof globalThis!="undefined"?globalThis:typeof self!="undefined"?self:typeof window!="undefined"?window:typeof global!="undefined"?global:{});let Ue;class zo{constructor(t=!1){this.active=!0,this.effects=[],this.cleanups=[],!t&&Ue&&(this.parent=Ue,this.index=(Ue.scopes||(Ue.scopes=[])).push(this)-1)}run(t){if(this.active)try{return Ue=this,t()}finally{Ue=this.parent}}on(){Ue=this}off(){Ue=this.parent}stop(t){if(this.active){let n,s;for(n=0,s=this.effects.length;n{const t=new Set(e);return t.w=0,t.n=0,t},xr=e=>(e.w&Ge)>0,yr=e=>(e.n&Ge)>0,Yo=({deps:e})=>{if(e.length)for(let t=0;t{const{deps:t}=e;if(t.length){let n=0;for(let s=0;s{(f==="length"||f>=s)&&l.push(u)});else switch(n!==void 0&&l.push(i.get(n)),t){case"add":F(e)?is(n)&&l.push(i.get("length")):(l.push(i.get(ot)),vt(e)&&l.push(i.get(Kn)));break;case"delete":F(e)||(l.push(i.get(ot)),vt(e)&&l.push(i.get(Kn)));break;case"set":vt(e)&&l.push(i.get(ot));break}if(l.length===1)l[0]&&qn(l[0]);else{const u=[];for(const f of l)f&&u.push(...f);qn(ls(u))}}function qn(e,t){for(const n of F(e)?e:[...e])(n!==Se||n.allowRecurse)&&(n.scheduler?n.scheduler():n.run())}const Xo=ts("__proto__,__v_isRef,__isVue"),kr=new Set(Object.getOwnPropertyNames(Symbol).map(e=>Symbol[e]).filter(os)),Zo=us(),Qo=us(!1,!0),Go=us(!0),Fs=ei();function ei(){const e={};return["includes","indexOf","lastIndexOf"].forEach(t=>{e[t]=function(...n){const s=V(this);for(let o=0,i=this.length;o{e[t]=function(...n){kt();const s=V(this)[t].apply(this,n);return Ct(),s}}),e}function us(e=!1,t=!1){return function(s,r,o){if(r==="__v_isReactive")return!e;if(r==="__v_isReadonly")return e;if(r==="__v_isShallow")return t;if(r==="__v_raw"&&o===(e?t?gi:Pr:t?Ar:Tr).get(s))return s;const i=F(s);if(!e&&i&&z(Fs,r))return Reflect.get(Fs,r,o);const l=Reflect.get(s,r,o);return(os(r)?kr.has(r):Xo(r))||(e||Ee(s,"get",r),t)?l:he(l)?!i||!is(r)?l.value:l:ae(l)?e?Lr(l):Cn(l):l}}const ti=Cr(),ni=Cr(!0);function Cr(e=!1){return function(n,s,r,o){let i=n[s];if(jt(i)&&he(i)&&!he(r))return!1;if(!e&&!jt(r)&&(Ir(r)||(r=V(r),i=V(i)),!F(n)&&he(i)&&!he(r)))return i.value=r,!0;const l=F(n)&&is(s)?Number(s)e,kn=e=>Reflect.getPrototypeOf(e);function Zt(e,t,n=!1,s=!1){e=e.__v_raw;const r=V(e),o=V(t);t!==o&&!n&&Ee(r,"get",t),!n&&Ee(r,"get",o);const{has:i}=kn(r),l=s?as:n?hs:Dt;if(i.call(r,t))return l(e.get(t));if(i.call(r,o))return l(e.get(o));e!==r&&e.get(t)}function Qt(e,t=!1){const n=this.__v_raw,s=V(n),r=V(e);return e!==r&&!t&&Ee(s,"has",e),!t&&Ee(s,"has",r),e===r?n.has(e):n.has(e)||n.has(r)}function Gt(e,t=!1){return e=e.__v_raw,!t&&Ee(V(e),"iterate",ot),Reflect.get(e,"size",e)}function Ss(e){e=V(e);const t=V(this);return kn(t).has.call(t,e)||(t.add(e),We(t,"add",e,e)),this}function Ns(e,t){t=V(t);const n=V(this),{has:s,get:r}=kn(n);let o=s.call(n,e);o||(e=V(e),o=s.call(n,e));const i=r.call(n,e);return n.set(e,t),o?Ut(t,i)&&We(n,"set",e,t):We(n,"add",e,t),this}function Hs(e){const t=V(this),{has:n,get:s}=kn(t);let r=n.call(t,e);r||(e=V(e),r=n.call(t,e)),s&&s.call(t,e);const o=t.delete(e);return r&&We(t,"delete",e,void 0),o}function Bs(){const e=V(this),t=e.size!==0,n=e.clear();return t&&We(e,"clear",void 0,void 0),n}function en(e,t){return function(s,r){const o=this,i=o.__v_raw,l=V(i),u=t?as:e?hs:Dt;return!e&&Ee(l,"iterate",ot),i.forEach((f,h)=>s.call(r,u(f),u(h),o))}}function tn(e,t,n){return function(...s){const r=this.__v_raw,o=V(r),i=vt(o),l=e==="entries"||e===Symbol.iterator&&i,u=e==="keys"&&i,f=r[e](...s),h=n?as:t?hs:Dt;return!t&&Ee(o,"iterate",u?Kn:ot),{next(){const{value:m,done:b}=f.next();return b?{value:m,done:b}:{value:l?[h(m[0]),h(m[1])]:h(m),done:b}},[Symbol.iterator](){return this}}}}function Ve(e){return function(...t){return e==="delete"?!1:this}}function ci(){const e={get(o){return Zt(this,o)},get size(){return Gt(this)},has:Qt,add:Ss,set:Ns,delete:Hs,clear:Bs,forEach:en(!1,!1)},t={get(o){return Zt(this,o,!1,!0)},get size(){return Gt(this)},has:Qt,add:Ss,set:Ns,delete:Hs,clear:Bs,forEach:en(!1,!0)},n={get(o){return Zt(this,o,!0)},get size(){return Gt(this,!0)},has(o){return Qt.call(this,o,!0)},add:Ve("add"),set:Ve("set"),delete:Ve("delete"),clear:Ve("clear"),forEach:en(!0,!1)},s={get(o){return Zt(this,o,!0,!0)},get size(){return Gt(this,!0)},has(o){return Qt.call(this,o,!0)},add:Ve("add"),set:Ve("set"),delete:Ve("delete"),clear:Ve("clear"),forEach:en(!0,!0)};return["keys","values","entries",Symbol.iterator].forEach(o=>{e[o]=tn(o,!1,!1),n[o]=tn(o,!0,!1),t[o]=tn(o,!1,!0),s[o]=tn(o,!0,!0)}),[e,n,t,s]}const[ui,ai,fi,di]=ci();function fs(e,t){const n=t?e?di:fi:e?ai:ui;return(s,r,o)=>r==="__v_isReactive"?!e:r==="__v_isReadonly"?e:r==="__v_raw"?s:Reflect.get(z(n,r)&&r in s?n:s,r,o)}const hi={get:fs(!1,!1)},pi={get:fs(!1,!0)},_i={get:fs(!0,!1)},Tr=new WeakMap,Ar=new WeakMap,Pr=new WeakMap,gi=new WeakMap;function mi(e){switch(e){case"Object":case"Array":return 1;case"Map":case"Set":case"WeakMap":case"WeakSet":return 2;default:return 0}}function vi(e){return e.__v_skip||!Object.isExtensible(e)?0:mi(jo(e))}function Cn(e){return jt(e)?e:ds(e,!1,Er,hi,Tr)}function bi(e){return ds(e,!1,li,pi,Ar)}function Lr(e){return ds(e,!0,ii,_i,Pr)}function ds(e,t,n,s,r){if(!ae(e)||e.__v_raw&&!(t&&e.__v_isReactive))return e;const o=r.get(e);if(o)return o;const i=vi(e);if(i===0)return e;const l=new Proxy(e,i===2?s:n);return r.set(e,l),l}function bt(e){return jt(e)?bt(e.__v_raw):!!(e&&e.__v_isReactive)}function jt(e){return!!(e&&e.__v_isReadonly)}function Ir(e){return!!(e&&e.__v_isShallow)}function Mr(e){return bt(e)||jt(e)}function V(e){const t=e&&e.__v_raw;return t?V(t):e}function Ot(e){return on(e,"__v_skip",!0),e}const Dt=e=>ae(e)?Cn(e):e,hs=e=>ae(e)?Lr(e):e;function Or(e){Ze&&Se&&(e=V(e),$r(e.dep||(e.dep=ls())))}function Rr(e,t){e=V(e),e.dep&&qn(e.dep)}function he(e){return!!(e&&e.__v_isRef===!0)}function it(e){return Fr(e,!1)}function xi(e){return Fr(e,!0)}function Fr(e,t){return he(e)?e:new yi(e,t)}class yi{constructor(t,n){this.__v_isShallow=n,this.dep=void 0,this.__v_isRef=!0,this._rawValue=n?t:V(t),this._value=n?t:Dt(t)}get value(){return Or(this),this._value}set value(t){t=this.__v_isShallow?t:V(t),Ut(t,this._rawValue)&&(this._rawValue=t,this._value=this.__v_isShallow?t:Dt(t),Rr(this))}}function k(e){return he(e)?e.value:e}const wi={get:(e,t,n)=>k(Reflect.get(e,t,n)),set:(e,t,n,s)=>{const r=e[t];return he(r)&&!he(n)?(r.value=n,!0):Reflect.set(e,t,n,s)}};function Sr(e){return bt(e)?e:new Proxy(e,wi)}function Nr(e){const t=F(e)?new Array(e.length):{};for(const n in e)t[n]=ki(e,n);return t}class $i{constructor(t,n,s){this._object=t,this._key=n,this._defaultValue=s,this.__v_isRef=!0}get value(){const t=this._object[this._key];return t===void 0?this._defaultValue:t}set value(t){this._object[this._key]=t}}function ki(e,t,n){const s=e[t];return he(s)?s:new $i(e,t,n)}class Ci{constructor(t,n,s,r){this._setter=n,this.dep=void 0,this.__v_isRef=!0,this._dirty=!0,this.effect=new cs(t,()=>{this._dirty||(this._dirty=!0,Rr(this))}),this.effect.computed=this,this.effect.active=this._cacheable=!r,this.__v_isReadonly=s}get value(){const t=V(this);return Or(t),(t._dirty||!t._cacheable)&&(t._dirty=!1,t._value=t.effect.run()),t._value}set value(t){this._setter(t)}}function Ei(e,t,n=!1){let s,r;const o=H(e);return o?(s=e,r=Me):(s=e.get,r=e.set),new Ci(s,r,o||!r,n)}Promise.resolve();function Qe(e,t,n,s){let r;try{r=s?e(...s):e()}catch(o){Vt(o,t,n)}return r}function Oe(e,t,n,s){if(H(e)){const o=Qe(e,t,n,s);return o&&mr(o)&&o.catch(i=>{Vt(i,t,n)}),o}const r=[];for(let o=0;o>>1;Wt(Ce[s])De&&Ce.splice(t,1)}function jr(e,t,n,s){F(e)?n.push(...e):(!t||!t.includes(e,e.allowRecurse?s+1:s))&&n.push(e),Ur()}function Li(e){jr(e,It,Rt,_t)}function Ii(e){jr(e,Je,Ft,gt)}function gs(e,t=null){if(Rt.length){for(Vn=t,It=[...new Set(Rt)],Rt.length=0,_t=0;_tWt(n)-Wt(s)),gt=0;gte.id==null?1/0:e.id;function Dr(e){zn=!1,ln=!0,gs(e),Ce.sort((n,s)=>Wt(n)-Wt(s));const t=Me;try{for(De=0;DeE.trim()):m&&(r=n.map(Ko))}let l,u=s[l=Fn(t)]||s[l=Fn(Ne(t))];!u&&o&&(u=s[l=Fn($t(t))]),u&&Oe(u,e,6,r);const f=s[l+"Once"];if(f){if(!e.emitted)e.emitted={};else if(e.emitted[l])return;e.emitted[l]=!0,Oe(f,e,6,r)}}function Wr(e,t,n=!1){const s=t.emitsCache,r=s.get(e);if(r!==void 0)return r;const o=e.emits;let i={},l=!1;if(!H(e)){const u=f=>{const h=Wr(f,t,!0);h&&(l=!0,xe(i,h))};!n&&t.mixins.length&&t.mixins.forEach(u),e.extends&&u(e.extends),e.mixins&&e.mixins.forEach(u)}return!o&&!l?(s.set(e,null),null):(F(o)?o.forEach(u=>i[u]=null):xe(i,o),s.set(e,i),i)}function ms(e,t){return!e||!zt(t)?!1:(t=t.slice(2).replace(/Once$/,""),z(e,t[0].toLowerCase()+t.slice(1))||z(e,$t(t))||z(e,t))}let Ae=null,En=null;function un(e){const t=Ae;return Ae=e,En=e&&e.type.__scopeId||null,t}function Kr(e){En=e}function qr(){En=null}function je(e,t=Ae,n){if(!t||e._n)return e;const s=(...r)=>{s._d&&Js(-1);const o=un(t),i=e(...r);return un(o),s._d&&Js(1),i};return s._n=!0,s._c=!0,s._d=!0,s}function Nn(e){const{type:t,vnode:n,proxy:s,withProxy:r,props:o,propsOptions:[i],slots:l,attrs:u,emit:f,render:h,renderCache:m,data:b,setupState:E,ctx:T,inheritAttrs:j}=e;let p,x;const O=un(e);try{if(n.shapeFlag&4){const U=r||s;p=Ie(h.call(U,U,m,o,E,b,T)),x=u}else{const U=t;p=Ie(U.length>1?U(o,{attrs:u,slots:l,emit:f}):U(o,null)),x=t.props?u:Oi(u)}}catch(U){Ht.length=0,Vt(U,e,1),p=S(Ke)}let M=p;if(x&&j!==!1){const U=Object.keys(x),{shapeFlag:Z}=M;U.length&&Z&7&&(i&&U.some(ss)&&(x=Ri(x,i)),M=qt(M,x))}return n.dirs&&(M.dirs=M.dirs?M.dirs.concat(n.dirs):n.dirs),n.transition&&(M.transition=n.transition),p=M,un(O),p}const Oi=e=>{let t;for(const n in e)(n==="class"||n==="style"||zt(n))&&((t||(t={}))[n]=e[n]);return t},Ri=(e,t)=>{const n={};for(const s in e)(!ss(s)||!(s.slice(9)in t))&&(n[s]=e[s]);return n};function Fi(e,t,n){const{props:s,children:r,component:o}=e,{props:i,children:l,patchFlag:u}=t,f=o.emitsOptions;if(t.dirs||t.transition)return!0;if(n&&u>=0){if(u&1024)return!0;if(u&16)return s?Us(s,i,f):!!i;if(u&8){const h=t.dynamicProps;for(let m=0;me.__isSuspense;function zr(e,t){t&&t.pendingBranch?F(e)?t.effects.push(...e):t.effects.push(e):Ii(e)}function Hi(e,t){if(de){let n=de.provides;const s=de.parent&&de.parent.provides;s===n&&(n=de.provides=Object.create(s)),n[e]=t}}function St(e,t,n=!1){const s=de||Ae;if(s){const r=s.parent==null?s.vnode.appContext&&s.vnode.appContext.provides:s.parent.provides;if(r&&e in r)return r[e];if(arguments.length>1)return n&&H(t)?t.call(s.proxy):t}}function Vr(e,t){return vs(e,null,t)}const js={};function lt(e,t,n){return vs(e,t,n)}function vs(e,t,{immediate:n,deep:s,flush:r,onTrack:o,onTrigger:i}=X){const l=de;let u,f=!1,h=!1;if(he(e)?(u=()=>e.value,f=Ir(e)):bt(e)?(u=()=>e,s=!0):F(e)?(h=!0,f=e.some(bt),u=()=>e.map(x=>{if(he(x))return x.value;if(bt(x))return rt(x);if(H(x))return Qe(x,l,2)})):H(e)?t?u=()=>Qe(e,l,2):u=()=>{if(!(l&&l.isUnmounted))return m&&m(),Oe(e,l,3,[b])}:u=Me,t&&s){const x=u;u=()=>rt(x())}let m,b=x=>{m=p.onStop=()=>{Qe(x,l,4)}};if(yt)return b=Me,t?n&&Oe(t,l,3,[u(),h?[]:void 0,b]):u(),Me;let E=h?[]:js;const T=()=>{if(!!p.active)if(t){const x=p.run();(s||f||(h?x.some((O,M)=>Ut(O,E[M])):Ut(x,E)))&&(m&&m(),Oe(t,l,3,[x,E===js?void 0:E,b]),E=x)}else p.run()};T.allowRecurse=!!t;let j;r==="sync"?j=T:r==="post"?j=()=>$e(T,l&&l.suspense):j=()=>{!l||l.isMounted?Li(T):T()};const p=new cs(u,j);return t?n?T():E=p.run():r==="post"?$e(p.run.bind(p),l&&l.suspense):p.run(),()=>{p.stop(),l&&l.scope&&rs(l.scope.effects,p)}}function Bi(e,t,n){const s=this.proxy,r=pe(e)?e.includes(".")?Yr(s,e):()=>s[e]:e.bind(s,s);let o;H(t)?o=t:(o=t.handler,n=t);const i=de;xt(this);const l=vs(r,o.bind(s),n);return i?xt(i):ut(),l}function Yr(e,t){const n=t.split(".");return()=>{let s=e;for(let r=0;r{rt(n,t)});else if(br(e))for(const n in e)rt(e[n],t);return e}function re(e){return H(e)?{setup:e,name:e.name}:e}const an=e=>!!e.type.__asyncLoader;function ef(e){H(e)&&(e={loader:e});const{loader:t,loadingComponent:n,errorComponent:s,delay:r=200,timeout:o,suspensible:i=!0,onError:l}=e;let u=null,f,h=0;const m=()=>(h++,u=null,b()),b=()=>{let E;return u||(E=u=t().catch(T=>{if(T=T instanceof Error?T:new Error(String(T)),l)return new Promise((j,p)=>{l(T,()=>j(m()),()=>p(T),h+1)});throw T}).then(T=>E!==u&&u?u:(T&&(T.__esModule||T[Symbol.toStringTag]==="Module")&&(T=T.default),f=T,T)))};return re({name:"AsyncComponentWrapper",__asyncLoader:b,get __asyncResolved(){return f},setup(){const E=de;if(f)return()=>Hn(f,E);const T=O=>{u=null,Vt(O,E,13,!s)};if(i&&E.suspense||yt)return b().then(O=>()=>Hn(O,E)).catch(O=>(T(O),()=>s?S(s,{error:O}):null));const j=it(!1),p=it(),x=it(!!r);return r&&setTimeout(()=>{x.value=!1},r),o!=null&&setTimeout(()=>{if(!j.value&&!p.value){const O=new Error(`Async component timed out after ${o}ms.`);T(O),p.value=O}},o),b().then(()=>{j.value=!0,E.parent&&bs(E.parent.vnode)&&_s(E.parent.update)}).catch(O=>{T(O),p.value=O}),()=>{if(j.value&&f)return Hn(f,E);if(p.value&&s)return S(s,{error:p.value});if(n&&!x.value)return S(n)}}})}function Hn(e,{vnode:{ref:t,props:n,children:s}}){const r=S(e,n,s);return r.ref=t,r}const bs=e=>e.type.__isKeepAlive;function Ui(e,t){Jr(e,"a",t)}function ji(e,t){Jr(e,"da",t)}function Jr(e,t,n=de){const s=e.__wdc||(e.__wdc=()=>{let r=n;for(;r;){if(r.isDeactivated)return;r=r.parent}return e()});if(Tn(t,s,n),n){let r=n.parent;for(;r&&r.parent;)bs(r.parent.vnode)&&Di(s,t,n,r),r=r.parent}}function Di(e,t,n,s){const r=Tn(t,e,s,!0);An(()=>{rs(s[t],r)},n)}function Tn(e,t,n=de,s=!1){if(n){const r=n[e]||(n[e]=[]),o=t.__weh||(t.__weh=(...i)=>{if(n.isUnmounted)return;kt(),xt(n);const l=Oe(t,n,e,i);return ut(),Ct(),l});return s?r.unshift(o):r.push(o),o}}const qe=e=>(t,n=de)=>(!yt||e==="sp")&&Tn(e,t,n),Wi=qe("bm"),Et=qe("m"),Ki=qe("bu"),Xr=qe("u"),qi=qe("bum"),An=qe("um"),zi=qe("sp"),Vi=qe("rtg"),Yi=qe("rtc");function Ji(e,t=de){Tn("ec",e,t)}let Yn=!0;function Xi(e){const t=Qr(e),n=e.proxy,s=e.ctx;Yn=!1,t.beforeCreate&&Ds(t.beforeCreate,e,"bc");const{data:r,computed:o,methods:i,watch:l,provide:u,inject:f,created:h,beforeMount:m,mounted:b,beforeUpdate:E,updated:T,activated:j,deactivated:p,beforeDestroy:x,beforeUnmount:O,destroyed:M,unmounted:U,render:Z,renderTracked:Q,renderTriggered:D,errorCaptured:le,serverPrefetch:ne,expose:oe,inheritAttrs:_e,components:K,directives:ie,filters:ye}=t;if(f&&Zi(f,s,null,e.appContext.config.unwrapInjectedRef),i)for(const se in i){const G=i[se];H(G)&&(s[se]=G.bind(n))}if(r){const se=r.call(n,n);ae(se)&&(e.data=Cn(se))}if(Yn=!0,o)for(const se in o){const G=o[se],He=H(G)?G.bind(n,n):H(G.get)?G.get.bind(n,n):Me,Mn=!H(G)&&H(G.set)?G.set.bind(n):Me,Tt=W({get:He,set:Mn});Object.defineProperty(s,se,{enumerable:!0,configurable:!0,get:()=>Tt.value,set:dt=>Tt.value=dt})}if(l)for(const se in l)Zr(l[se],s,n,se);if(u){const se=H(u)?u.call(n):u;Reflect.ownKeys(se).forEach(G=>{Hi(G,se[G])})}h&&Ds(h,e,"c");function we(se,G){F(G)?G.forEach(He=>se(He.bind(n))):G&&se(G.bind(n))}if(we(Wi,m),we(Et,b),we(Ki,E),we(Xr,T),we(Ui,j),we(ji,p),we(Ji,le),we(Yi,Q),we(Vi,D),we(qi,O),we(An,U),we(zi,ne),F(oe))if(oe.length){const se=e.exposed||(e.exposed={});oe.forEach(G=>{Object.defineProperty(se,G,{get:()=>n[G],set:He=>n[G]=He})})}else e.exposed||(e.exposed={});Z&&e.render===Me&&(e.render=Z),_e!=null&&(e.inheritAttrs=_e),K&&(e.components=K),ie&&(e.directives=ie)}function Zi(e,t,n=Me,s=!1){F(e)&&(e=Jn(e));for(const r in e){const o=e[r];let i;ae(o)?"default"in o?i=St(o.from||r,o.default,!0):i=St(o.from||r):i=St(o),he(i)&&s?Object.defineProperty(t,r,{enumerable:!0,configurable:!0,get:()=>i.value,set:l=>i.value=l}):t[r]=i}}function Ds(e,t,n){Oe(F(e)?e.map(s=>s.bind(t.proxy)):e.bind(t.proxy),t,n)}function Zr(e,t,n,s){const r=s.includes(".")?Yr(n,s):()=>n[s];if(pe(e)){const o=t[e];H(o)&<(r,o)}else if(H(e))lt(r,e.bind(n));else if(ae(e))if(F(e))e.forEach(o=>Zr(o,t,n,s));else{const o=H(e.handler)?e.handler.bind(n):t[e.handler];H(o)&<(r,o,e)}}function Qr(e){const t=e.type,{mixins:n,extends:s}=t,{mixins:r,optionsCache:o,config:{optionMergeStrategies:i}}=e.appContext,l=o.get(t);let u;return l?u=l:!r.length&&!n&&!s?u=t:(u={},r.length&&r.forEach(f=>fn(u,f,i,!0)),fn(u,t,i)),o.set(t,u),u}function fn(e,t,n,s=!1){const{mixins:r,extends:o}=t;o&&fn(e,o,n,!0),r&&r.forEach(i=>fn(e,i,n,!0));for(const i in t)if(!(s&&i==="expose")){const l=Qi[i]||n&&n[i];e[i]=l?l(e[i],t[i]):t[i]}return e}const Qi={data:Ws,props:nt,emits:nt,methods:nt,computed:nt,beforeCreate:ve,created:ve,beforeMount:ve,mounted:ve,beforeUpdate:ve,updated:ve,beforeDestroy:ve,beforeUnmount:ve,destroyed:ve,unmounted:ve,activated:ve,deactivated:ve,errorCaptured:ve,serverPrefetch:ve,components:nt,directives:nt,watch:el,provide:Ws,inject:Gi};function Ws(e,t){return t?e?function(){return xe(H(e)?e.call(this,this):e,H(t)?t.call(this,this):t)}:t:e}function Gi(e,t){return nt(Jn(e),Jn(t))}function Jn(e){if(F(e)){const t={};for(let n=0;n0)&&!(i&16)){if(i&8){const h=e.vnode.dynamicProps;for(let m=0;m{u=!0;const[b,E]=eo(m,t,!0);xe(i,b),E&&l.push(...E)};!n&&t.mixins.length&&t.mixins.forEach(h),e.extends&&h(e.extends),e.mixins&&e.mixins.forEach(h)}if(!o&&!u)return s.set(e,mt),mt;if(F(o))for(let h=0;h-1,E[1]=j<0||T-1||z(E,"default"))&&l.push(m)}}}const f=[i,l];return s.set(e,f),f}function Ks(e){return e[0]!=="$"}function qs(e){const t=e&&e.toString().match(/^\s*function (\w+)/);return t?t[1]:e===null?"null":""}function zs(e,t){return qs(e)===qs(t)}function Vs(e,t){return F(t)?t.findIndex(n=>zs(n,e)):H(t)&&zs(t,e)?0:-1}const to=e=>e[0]==="_"||e==="$stable",xs=e=>F(e)?e.map(Ie):[Ie(e)],sl=(e,t,n)=>{const s=je((...r)=>xs(t(...r)),n);return s._c=!1,s},no=(e,t,n)=>{const s=e._ctx;for(const r in e){if(to(r))continue;const o=e[r];if(H(o))t[r]=sl(r,o,s);else if(o!=null){const i=xs(o);t[r]=()=>i}}},so=(e,t)=>{const n=xs(t);e.slots.default=()=>n},rl=(e,t)=>{if(e.vnode.shapeFlag&32){const n=t._;n?(e.slots=V(t),on(t,"_",n)):no(t,e.slots={})}else e.slots={},t&&so(e,t);on(e.slots,Pn,1)},ol=(e,t,n)=>{const{vnode:s,slots:r}=e;let o=!0,i=X;if(s.shapeFlag&32){const l=t._;l?n&&l===1?o=!1:(xe(r,t),!n&&l===1&&delete r._):(o=!t.$stable,no(t,r)),i=t}else t&&(so(e,t),i={default:1});if(o)for(const l in r)!to(l)&&!(l in i)&&delete r[l]};function tf(e,t){const n=Ae;if(n===null)return e;const s=n.proxy,r=e.dirs||(e.dirs=[]);for(let o=0;odn(b,t&&(F(t)?t[E]:t),n,s,r));return}if(an(s)&&!r)return;const o=s.shapeFlag&4?$s(s.component)||s.component.proxy:s.el,i=r?null:o,{i:l,r:u}=e,f=t&&t.r,h=l.refs===X?l.refs={}:l.refs,m=l.setupState;if(f!=null&&f!==u&&(pe(f)?(h[f]=null,z(m,f)&&(m[f]=null)):he(f)&&(f.value=null)),H(u))Qe(u,l,12,[i,h]);else{const b=pe(u),E=he(u);if(b||E){const T=()=>{if(e.f){const j=b?h[u]:u.value;r?F(j)&&rs(j,o):F(j)?j.includes(o)||j.push(o):b?h[u]=[o]:(u.value=[o],e.k&&(h[e.k]=u.value))}else b?(h[u]=i,z(m,u)&&(m[u]=i)):he(u)&&(u.value=i,e.k&&(h[e.k]=i))};i?(T.id=-1,$e(T,n)):T()}}}let Ye=!1;const nn=e=>/svg/.test(e.namespaceURI)&&e.tagName!=="foreignObject",Bn=e=>e.nodeType===8;function cl(e){const{mt:t,p:n,o:{patchProp:s,nextSibling:r,parentNode:o,remove:i,insert:l,createComment:u}}=e,f=(p,x)=>{if(!x.hasChildNodes()){n(null,p,x),cn();return}Ye=!1,h(x.firstChild,p,null,null,null),cn(),Ye&&console.error("Hydration completed but contains mismatches.")},h=(p,x,O,M,U,Z=!1)=>{const Q=Bn(p)&&p.data==="[",D=()=>T(p,x,O,M,U,Q),{type:le,ref:ne,shapeFlag:oe}=x,_e=p.nodeType;x.el=p;let K=null;switch(le){case Kt:_e!==3?K=D():(p.data!==x.children&&(Ye=!0,p.data=x.children),K=r(p));break;case Ke:_e!==8||Q?K=D():K=r(p);break;case Nt:if(_e!==1)K=D();else{K=p;const ie=!x.children.length;for(let ye=0;ye{Z=Z||!!x.dynamicChildren;const{type:Q,props:D,patchFlag:le,shapeFlag:ne,dirs:oe}=x,_e=Q==="input"&&oe||Q==="option";if(_e||le!==-1){if(oe&&Fe(x,null,O,"created"),D)if(_e||!Z||le&48)for(const ie in D)(_e&&ie.endsWith("value")||zt(ie)&&!Mt(ie))&&s(p,ie,null,D[ie],!1,void 0,O);else D.onClick&&s(p,"onClick",null,D.onClick,!1,void 0,O);let K;if((K=D&&D.onVnodeBeforeMount)&&Te(K,O,x),oe&&Fe(x,null,O,"beforeMount"),((K=D&&D.onVnodeMounted)||oe)&&zr(()=>{K&&Te(K,O,x),oe&&Fe(x,null,O,"mounted")},M),ne&16&&!(D&&(D.innerHTML||D.textContent))){let ie=b(p.firstChild,x,p,O,M,U,Z);for(;ie;){Ye=!0;const ye=ie;ie=ie.nextSibling,i(ye)}}else ne&8&&p.textContent!==x.children&&(Ye=!0,p.textContent=x.children)}return p.nextSibling},b=(p,x,O,M,U,Z,Q)=>{Q=Q||!!x.dynamicChildren;const D=x.children,le=D.length;for(let ne=0;ne{const{slotScopeIds:Q}=x;Q&&(U=U?U.concat(Q):Q);const D=o(p),le=b(r(p),x,D,O,M,U,Z);return le&&Bn(le)&&le.data==="]"?r(x.anchor=le):(Ye=!0,l(x.anchor=u("]"),D,le),le)},T=(p,x,O,M,U,Z)=>{if(Ye=!0,x.el=null,Z){const le=j(p);for(;;){const ne=r(p);if(ne&&ne!==le)i(ne);else break}}const Q=r(p),D=o(p);return i(p),n(null,x,D,Q,O,M,nn(D),U),Q},j=p=>{let x=0;for(;p;)if(p=r(p),p&&Bn(p)&&(p.data==="["&&x++,p.data==="]")){if(x===0)return r(p);x--}return p};return[f,h]}const $e=zr;function ul(e){return oo(e)}function al(e){return oo(e,cl)}function oo(e,t){const n=qo();n.__VUE__=!0;const{insert:s,remove:r,patchProp:o,createElement:i,createText:l,createComment:u,setText:f,setElementText:h,parentNode:m,nextSibling:b,setScopeId:E=Me,cloneNode:T,insertStaticContent:j}=e,p=(c,a,d,g=null,_=null,w=null,C=!1,y=null,$=!!a.dynamicChildren)=>{if(c===a)return;c&&!Pt(c,a)&&(g=Xt(c),ze(c,_,w,!0),c=null),a.patchFlag===-2&&($=!1,a.dynamicChildren=null);const{type:v,ref:L,shapeFlag:A}=a;switch(v){case Kt:x(c,a,d,g);break;case Ke:O(c,a,d,g);break;case Nt:c==null&&M(a,d,g,C);break;case fe:ie(c,a,d,g,_,w,C,y,$);break;default:A&1?Q(c,a,d,g,_,w,C,y,$):A&6?ye(c,a,d,g,_,w,C,y,$):(A&64||A&128)&&v.process(c,a,d,g,_,w,C,y,$,ht)}L!=null&&_&&dn(L,c&&c.ref,w,a||c,!a)},x=(c,a,d,g)=>{if(c==null)s(a.el=l(a.children),d,g);else{const _=a.el=c.el;a.children!==c.children&&f(_,a.children)}},O=(c,a,d,g)=>{c==null?s(a.el=u(a.children||""),d,g):a.el=c.el},M=(c,a,d,g)=>{[c.el,c.anchor]=j(c.children,a,d,g,c.el,c.anchor)},U=({el:c,anchor:a},d,g)=>{let _;for(;c&&c!==a;)_=b(c),s(c,d,g),c=_;s(a,d,g)},Z=({el:c,anchor:a})=>{let d;for(;c&&c!==a;)d=b(c),r(c),c=d;r(a)},Q=(c,a,d,g,_,w,C,y,$)=>{C=C||a.type==="svg",c==null?D(a,d,g,_,w,C,y,$):oe(c,a,_,w,C,y,$)},D=(c,a,d,g,_,w,C,y)=>{let $,v;const{type:L,props:A,shapeFlag:I,transition:R,patchFlag:q,dirs:te}=c;if(c.el&&T!==void 0&&q===-1)$=c.el=T(c.el);else{if($=c.el=i(c.type,w,A&&A.is,A),I&8?h($,c.children):I&16&&ne(c.children,$,null,g,_,w&&L!=="foreignObject",C,y),te&&Fe(c,null,g,"created"),A){for(const ee in A)ee!=="value"&&!Mt(ee)&&o($,ee,null,A[ee],w,c.children,g,_,Be);"value"in A&&o($,"value",null,A.value),(v=A.onVnodeBeforeMount)&&Te(v,g,c)}le($,c,c.scopeId,C,g)}te&&Fe(c,null,g,"beforeMount");const J=(!_||_&&!_.pendingBranch)&&R&&!R.persisted;J&&R.beforeEnter($),s($,a,d),((v=A&&A.onVnodeMounted)||J||te)&&$e(()=>{v&&Te(v,g,c),J&&R.enter($),te&&Fe(c,null,g,"mounted")},_)},le=(c,a,d,g,_)=>{if(d&&E(c,d),g)for(let w=0;w{for(let v=$;v{const y=a.el=c.el;let{patchFlag:$,dynamicChildren:v,dirs:L}=a;$|=c.patchFlag&16;const A=c.props||X,I=a.props||X;let R;d&&tt(d,!1),(R=I.onVnodeBeforeUpdate)&&Te(R,d,a,c),L&&Fe(a,c,d,"beforeUpdate"),d&&tt(d,!0);const q=_&&a.type!=="foreignObject";if(v?_e(c.dynamicChildren,v,y,d,g,q,w):C||He(c,a,y,null,d,g,q,w,!1),$>0){if($&16)K(y,a,A,I,d,g,_);else if($&2&&A.class!==I.class&&o(y,"class",null,I.class,_),$&4&&o(y,"style",A.style,I.style,_),$&8){const te=a.dynamicProps;for(let J=0;J{R&&Te(R,d,a,c),L&&Fe(a,c,d,"updated")},g)},_e=(c,a,d,g,_,w,C)=>{for(let y=0;y{if(d!==g){for(const y in g){if(Mt(y))continue;const $=g[y],v=d[y];$!==v&&y!=="value"&&o(c,y,v,$,C,a.children,_,w,Be)}if(d!==X)for(const y in d)!Mt(y)&&!(y in g)&&o(c,y,d[y],null,C,a.children,_,w,Be);"value"in g&&o(c,"value",d.value,g.value)}},ie=(c,a,d,g,_,w,C,y,$)=>{const v=a.el=c?c.el:l(""),L=a.anchor=c?c.anchor:l("");let{patchFlag:A,dynamicChildren:I,slotScopeIds:R}=a;R&&(y=y?y.concat(R):R),c==null?(s(v,d,g),s(L,d,g),ne(a.children,d,L,_,w,C,y,$)):A>0&&A&64&&I&&c.dynamicChildren?(_e(c.dynamicChildren,I,d,_,w,C,y),(a.key!=null||_&&a===_.subTree)&&io(c,a,!0)):He(c,a,d,L,_,w,C,y,$)},ye=(c,a,d,g,_,w,C,y,$)=>{a.slotScopeIds=y,c==null?a.shapeFlag&512?_.ctx.activate(a,d,g,C,$):In(a,d,g,_,w,C,$):we(c,a,$)},In=(c,a,d,g,_,w,C)=>{const y=c.component=yl(c,g,_);if(bs(c)&&(y.ctx.renderer=ht),wl(y),y.asyncDep){if(_&&_.registerDep(y,se),!c.el){const $=y.subTree=S(Ke);O(null,$,a,d)}return}se(y,c,a,d,_,w,C)},we=(c,a,d)=>{const g=a.component=c.component;if(Fi(c,a,d))if(g.asyncDep&&!g.asyncResolved){G(g,a,d);return}else g.next=a,Pi(g.update),g.update();else a.component=c.component,a.el=c.el,g.vnode=a},se=(c,a,d,g,_,w,C)=>{const y=()=>{if(c.isMounted){let{next:L,bu:A,u:I,parent:R,vnode:q}=c,te=L,J;tt(c,!1),L?(L.el=q.el,G(c,L,C)):L=q,A&&Sn(A),(J=L.props&&L.props.onVnodeBeforeUpdate)&&Te(J,R,L,q),tt(c,!0);const ee=Nn(c),Le=c.subTree;c.subTree=ee,p(Le,ee,m(Le.el),Xt(Le),c,_,w),L.el=ee.el,te===null&&Si(c,ee.el),I&&$e(I,_),(J=L.props&&L.props.onVnodeUpdated)&&$e(()=>Te(J,R,L,q),_)}else{let L;const{el:A,props:I}=a,{bm:R,m:q,parent:te}=c,J=an(a);if(tt(c,!1),R&&Sn(R),!J&&(L=I&&I.onVnodeBeforeMount)&&Te(L,te,a),tt(c,!0),A&&Rn){const ee=()=>{c.subTree=Nn(c),Rn(A,c.subTree,c,_,null)};J?a.type.__asyncLoader().then(()=>!c.isUnmounted&&ee()):ee()}else{const ee=c.subTree=Nn(c);p(null,ee,d,g,c,_,w),a.el=ee.el}if(q&&$e(q,_),!J&&(L=I&&I.onVnodeMounted)){const ee=a;$e(()=>Te(L,te,ee),_)}a.shapeFlag&256&&c.a&&$e(c.a,_),c.isMounted=!0,a=d=g=null}},$=c.effect=new cs(y,()=>_s(c.update),c.scope),v=c.update=$.run.bind($);v.id=c.uid,tt(c,!0),v()},G=(c,a,d)=>{a.component=c;const g=c.vnode.props;c.vnode=a,c.next=null,nl(c,a.props,g,d),ol(c,a.children,d),kt(),gs(void 0,c.update),Ct()},He=(c,a,d,g,_,w,C,y,$=!1)=>{const v=c&&c.children,L=c?c.shapeFlag:0,A=a.children,{patchFlag:I,shapeFlag:R}=a;if(I>0){if(I&128){Tt(v,A,d,g,_,w,C,y,$);return}else if(I&256){Mn(v,A,d,g,_,w,C,y,$);return}}R&8?(L&16&&Be(v,_,w),A!==v&&h(d,A)):L&16?R&16?Tt(v,A,d,g,_,w,C,y,$):Be(v,_,w,!0):(L&8&&h(d,""),R&16&&ne(A,d,g,_,w,C,y,$))},Mn=(c,a,d,g,_,w,C,y,$)=>{c=c||mt,a=a||mt;const v=c.length,L=a.length,A=Math.min(v,L);let I;for(I=0;IL?Be(c,_,w,!0,!1,A):ne(a,d,g,_,w,C,y,$,A)},Tt=(c,a,d,g,_,w,C,y,$)=>{let v=0;const L=a.length;let A=c.length-1,I=L-1;for(;v<=A&&v<=I;){const R=c[v],q=a[v]=$?Xe(a[v]):Ie(a[v]);if(Pt(R,q))p(R,q,d,null,_,w,C,y,$);else break;v++}for(;v<=A&&v<=I;){const R=c[A],q=a[I]=$?Xe(a[I]):Ie(a[I]);if(Pt(R,q))p(R,q,d,null,_,w,C,y,$);else break;A--,I--}if(v>A){if(v<=I){const R=I+1,q=RI)for(;v<=A;)ze(c[v],_,w,!0),v++;else{const R=v,q=v,te=new Map;for(v=q;v<=I;v++){const ke=a[v]=$?Xe(a[v]):Ie(a[v]);ke.key!=null&&te.set(ke.key,v)}let J,ee=0;const Le=I-q+1;let pt=!1,Ls=0;const At=new Array(Le);for(v=0;v=Le){ze(ke,_,w,!0);continue}let Re;if(ke.key!=null)Re=te.get(ke.key);else for(J=q;J<=I;J++)if(At[J-q]===0&&Pt(ke,a[J])){Re=J;break}Re===void 0?ze(ke,_,w,!0):(At[Re-q]=v+1,Re>=Ls?Ls=Re:pt=!0,p(ke,a[Re],d,null,_,w,C,y,$),ee++)}const Is=pt?fl(At):mt;for(J=Is.length-1,v=Le-1;v>=0;v--){const ke=q+v,Re=a[ke],Ms=ke+1{const{el:w,type:C,transition:y,children:$,shapeFlag:v}=c;if(v&6){dt(c.component.subTree,a,d,g);return}if(v&128){c.suspense.move(a,d,g);return}if(v&64){C.move(c,a,d,ht);return}if(C===fe){s(w,a,d);for(let A=0;A<$.length;A++)dt($[A],a,d,g);s(c.anchor,a,d);return}if(C===Nt){U(c,a,d);return}if(g!==2&&v&1&&y)if(g===0)y.beforeEnter(w),s(w,a,d),$e(()=>y.enter(w),_);else{const{leave:A,delayLeave:I,afterLeave:R}=y,q=()=>s(w,a,d),te=()=>{A(w,()=>{q(),R&&R()})};I?I(w,q,te):te()}else s(w,a,d)},ze=(c,a,d,g=!1,_=!1)=>{const{type:w,props:C,ref:y,children:$,dynamicChildren:v,shapeFlag:L,patchFlag:A,dirs:I}=c;if(y!=null&&dn(y,null,d,c,!0),L&256){a.ctx.deactivate(c);return}const R=L&1&&I,q=!an(c);let te;if(q&&(te=C&&C.onVnodeBeforeUnmount)&&Te(te,a,c),L&6)Mo(c.component,d,g);else{if(L&128){c.suspense.unmount(d,g);return}R&&Fe(c,null,a,"beforeUnmount"),L&64?c.type.remove(c,a,d,_,ht,g):v&&(w!==fe||A>0&&A&64)?Be(v,a,d,!1,!0):(w===fe&&A&384||!_&&L&16)&&Be($,a,d),g&&As(c)}(q&&(te=C&&C.onVnodeUnmounted)||R)&&$e(()=>{te&&Te(te,a,c),R&&Fe(c,null,a,"unmounted")},d)},As=c=>{const{type:a,el:d,anchor:g,transition:_}=c;if(a===fe){Io(d,g);return}if(a===Nt){Z(c);return}const w=()=>{r(d),_&&!_.persisted&&_.afterLeave&&_.afterLeave()};if(c.shapeFlag&1&&_&&!_.persisted){const{leave:C,delayLeave:y}=_,$=()=>C(d,w);y?y(c.el,w,$):$()}else w()},Io=(c,a)=>{let d;for(;c!==a;)d=b(c),r(c),c=d;r(a)},Mo=(c,a,d)=>{const{bum:g,scope:_,update:w,subTree:C,um:y}=c;g&&Sn(g),_.stop(),w&&(w.active=!1,ze(C,c,a,d)),y&&$e(y,a),$e(()=>{c.isUnmounted=!0},a),a&&a.pendingBranch&&!a.isUnmounted&&c.asyncDep&&!c.asyncResolved&&c.suspenseId===a.pendingId&&(a.deps--,a.deps===0&&a.resolve())},Be=(c,a,d,g=!1,_=!1,w=0)=>{for(let C=w;Cc.shapeFlag&6?Xt(c.component.subTree):c.shapeFlag&128?c.suspense.next():b(c.anchor||c.el),Ps=(c,a,d)=>{c==null?a._vnode&&ze(a._vnode,null,null,!0):p(a._vnode||null,c,a,null,null,null,d),cn(),a._vnode=c},ht={p,um:ze,m:dt,r:As,mt:In,mc:ne,pc:He,pbc:_e,n:Xt,o:e};let On,Rn;return t&&([On,Rn]=t(ht)),{render:Ps,hydrate:On,createApp:ll(Ps,On)}}function tt({effect:e,update:t},n){e.allowRecurse=t.allowRecurse=n}function io(e,t,n=!1){const s=e.children,r=t.children;if(F(s)&&F(r))for(let o=0;o>1,e[n[l]]0&&(t[s]=n[o-1]),n[o]=s)}}for(o=n.length,i=n[o-1];o-- >0;)n[o]=i,i=t[i];return n}const dl=e=>e.__isTeleport,lo="components",hl="directives";function hn(e,t){return co(lo,e,!0,t)||e}const pl=Symbol();function nf(e){return co(hl,e)}function co(e,t,n=!0,s=!1){const r=Ae||de;if(r){const o=r.type;if(e===lo){const l=El(o);if(l&&(l===t||l===Ne(t)||l===$n(Ne(t))))return o}const i=Ys(r[e]||o[e],t)||Ys(r.appContext[e],t);return!i&&s?o:i}}function Ys(e,t){return e&&(e[t]||e[Ne(t)]||e[$n(Ne(t))])}const fe=Symbol(void 0),Kt=Symbol(void 0),Ke=Symbol(void 0),Nt=Symbol(void 0),Ht=[];let ct=null;function P(e=!1){Ht.push(ct=e?null:[])}function _l(){Ht.pop(),ct=Ht[Ht.length-1]||null}let pn=1;function Js(e){pn+=e}function uo(e){return e.dynamicChildren=pn>0?ct||mt:null,_l(),pn>0&&ct&&ct.push(e),e}function N(e,t,n,s,r,o){return uo(B(e,t,n,s,r,o,!0))}function ge(e,t,n,s,r){return uo(S(e,t,n,s,r,!0))}function _n(e){return e?e.__v_isVNode===!0:!1}function Pt(e,t){return e.type===t.type&&e.key===t.key}const Pn="__vInternal",ao=({key:e})=>e!=null?e:null,rn=({ref:e,ref_key:t,ref_for:n})=>e!=null?pe(e)||he(e)||H(e)?{i:Ae,r:e,k:t,f:!!n}:e:null;function B(e,t=null,n=null,s=0,r=null,o=e===fe?0:1,i=!1,l=!1){const u={__v_isVNode:!0,__v_skip:!0,type:e,props:t,key:t&&ao(t),ref:t&&rn(t),scopeId:En,slotScopeIds:null,children:n,component:null,suspense:null,ssContent:null,ssFallback:null,dirs:null,transition:null,el:null,anchor:null,target:null,targetAnchor:null,staticCount:0,shapeFlag:o,patchFlag:s,dynamicProps:r,dynamicChildren:null,appContext:null};return l?(ys(u,n),o&128&&e.normalize(u)):n&&(u.shapeFlag|=pe(n)?8:16),pn>0&&!i&&ct&&(u.patchFlag>0||o&6)&&u.patchFlag!==32&&ct.push(u),u}const S=gl;function gl(e,t=null,n=null,s=0,r=null,o=!1){if((!e||e===pl)&&(e=Ke),_n(e)){const l=qt(e,t,!0);return n&&ys(l,n),l}if(Tl(e)&&(e=e.__vccOpts),t){t=ml(t);let{class:l,style:u}=t;l&&!pe(l)&&(t.class=at(l)),ae(u)&&(Mr(u)&&!F(u)&&(u=xe({},u)),t.style=ns(u))}const i=pe(e)?1:Ni(e)?128:dl(e)?64:ae(e)?4:H(e)?2:0;return B(e,t,n,s,r,i,o,!0)}function ml(e){return e?Mr(e)||Pn in e?xe({},e):e:null}function qt(e,t,n=!1){const{props:s,ref:r,patchFlag:o,children:i}=e,l=t?ws(s||{},t):s;return{__v_isVNode:!0,__v_skip:!0,type:e.type,props:l,key:l&&ao(l),ref:t&&t.ref?n&&r?F(r)?r.concat(rn(t)):[r,rn(t)]:rn(t):r,scopeId:e.scopeId,slotScopeIds:e.slotScopeIds,children:i,target:e.target,targetAnchor:e.targetAnchor,staticCount:e.staticCount,shapeFlag:e.shapeFlag,patchFlag:t&&e.type!==fe?o===-1?16:o|16:o,dynamicProps:e.dynamicProps,dynamicChildren:e.dynamicChildren,appContext:e.appContext,dirs:e.dirs,transition:e.transition,component:e.component,suspense:e.suspense,ssContent:e.ssContent&&qt(e.ssContent),ssFallback:e.ssFallback&&qt(e.ssFallback),el:e.el,anchor:e.anchor}}function Yt(e=" ",t=0){return S(Kt,null,e,t)}function sf(e,t){const n=S(Nt,null,e);return n.staticCount=t,n}function Y(e="",t=!1){return t?(P(),ge(Ke,null,e)):S(Ke,null,e)}function Ie(e){return e==null||typeof e=="boolean"?S(Ke):F(e)?S(fe,null,e.slice()):typeof e=="object"?Xe(e):S(Kt,null,String(e))}function Xe(e){return e.el===null||e.memo?e:qt(e)}function ys(e,t){let n=0;const{shapeFlag:s}=e;if(t==null)t=null;else if(F(t))n=16;else if(typeof t=="object")if(s&65){const r=t.default;r&&(r._c&&(r._d=!1),ys(e,r()),r._c&&(r._d=!0));return}else{n=32;const r=t._;!r&&!(Pn in t)?t._ctx=Ae:r===3&&Ae&&(Ae.slots._===1?t._=1:(t._=2,e.patchFlag|=1024))}else H(t)?(t={default:t,_ctx:Ae},n=32):(t=String(t),s&64?(n=16,t=[Yt(t)]):n=8);e.children=t,e.shapeFlag|=n}function ws(...e){const t={};for(let n=0;nt(i,l,void 0,o&&o[l]));else{const i=Object.keys(e);r=new Array(i.length);for(let l=0,u=i.length;l_n(t)?!(t.type===Ke||t.type===fe&&!fo(t.children)):!0)?e:null}const Zn=e=>e?ho(e)?$s(e)||e.proxy:Zn(e.parent):null,gn=xe(Object.create(null),{$:e=>e,$el:e=>e.vnode.el,$data:e=>e.data,$props:e=>e.props,$attrs:e=>e.attrs,$slots:e=>e.slots,$refs:e=>e.refs,$parent:e=>Zn(e.parent),$root:e=>Zn(e.root),$emit:e=>e.emit,$options:e=>Qr(e),$forceUpdate:e=>()=>_s(e.update),$nextTick:e=>Br.bind(e.proxy),$watch:e=>Bi.bind(e)}),vl={get({_:e},t){const{ctx:n,setupState:s,data:r,props:o,accessCache:i,type:l,appContext:u}=e;let f;if(t[0]!=="$"){const E=i[t];if(E!==void 0)switch(E){case 1:return s[t];case 2:return r[t];case 4:return n[t];case 3:return o[t]}else{if(s!==X&&z(s,t))return i[t]=1,s[t];if(r!==X&&z(r,t))return i[t]=2,r[t];if((f=e.propsOptions[0])&&z(f,t))return i[t]=3,o[t];if(n!==X&&z(n,t))return i[t]=4,n[t];Yn&&(i[t]=0)}}const h=gn[t];let m,b;if(h)return t==="$attrs"&&Ee(e,"get",t),h(e);if((m=l.__cssModules)&&(m=m[t]))return m;if(n!==X&&z(n,t))return i[t]=4,n[t];if(b=u.config.globalProperties,z(b,t))return b[t]},set({_:e},t,n){const{data:s,setupState:r,ctx:o}=e;return r!==X&&z(r,t)?(r[t]=n,!0):s!==X&&z(s,t)?(s[t]=n,!0):z(e.props,t)||t[0]==="$"&&t.slice(1)in e?!1:(o[t]=n,!0)},has({_:{data:e,setupState:t,accessCache:n,ctx:s,appContext:r,propsOptions:o}},i){let l;return!!n[i]||e!==X&&z(e,i)||t!==X&&z(t,i)||(l=o[0])&&z(l,i)||z(s,i)||z(gn,i)||z(r.config.globalProperties,i)},defineProperty(e,t,n){return n.get!=null?this.set(e,t,n.get(),null):n.value!=null&&this.set(e,t,n.value,null),Reflect.defineProperty(e,t,n)}},bl=ro();let xl=0;function yl(e,t,n){const s=e.type,r=(t?t.appContext:e.appContext)||bl,o={uid:xl++,vnode:e,type:s,parent:t,appContext:r,root:null,next:null,subTree:null,effect:null,update:null,scope:new zo(!0),render:null,proxy:null,exposed:null,exposeProxy:null,withProxy:null,provides:t?t.provides:Object.create(r.provides),accessCache:null,renderCache:[],components:null,directives:null,propsOptions:eo(s,r),emitsOptions:Wr(s,r),emit:null,emitted:null,propsDefaults:X,inheritAttrs:s.inheritAttrs,ctx:X,data:X,props:X,attrs:X,slots:X,refs:X,setupState:X,setupContext:null,suspense:n,suspenseId:n?n.pendingId:0,asyncDep:null,asyncResolved:!1,isMounted:!1,isUnmounted:!1,isDeactivated:!1,bc:null,c:null,bm:null,m:null,bu:null,u:null,um:null,bum:null,da:null,a:null,rtg:null,rtc:null,ec:null,sp:null};return o.ctx={_:o},o.root=t?t.root:o,o.emit=Mi.bind(null,o),e.ce&&e.ce(o),o}let de=null;const xt=e=>{de=e,e.scope.on()},ut=()=>{de&&de.scope.off(),de=null};function ho(e){return e.vnode.shapeFlag&4}let yt=!1;function wl(e,t=!1){yt=t;const{props:n,children:s}=e.vnode,r=ho(e);tl(e,n,r,t),rl(e,s);const o=r?$l(e,t):void 0;return yt=!1,o}function $l(e,t){const n=e.type;e.accessCache=Object.create(null),e.proxy=Ot(new Proxy(e.ctx,vl));const{setup:s}=n;if(s){const r=e.setupContext=s.length>1?Cl(e):null;xt(e),kt();const o=Qe(s,e,0,[e.props,r]);if(Ct(),ut(),mr(o)){if(o.then(ut,ut),t)return o.then(i=>{Xs(e,i,t)}).catch(i=>{Vt(i,e,0)});e.asyncDep=o}else Xs(e,o,t)}else po(e,t)}function Xs(e,t,n){H(t)?e.type.__ssrInlineRender?e.ssrRender=t:e.render=t:ae(t)&&(e.setupState=Sr(t)),po(e,n)}let Zs;function po(e,t,n){const s=e.type;if(!e.render){if(!t&&Zs&&!s.render){const r=s.template;if(r){const{isCustomElement:o,compilerOptions:i}=e.appContext.config,{delimiters:l,compilerOptions:u}=s,f=xe(xe({isCustomElement:o,delimiters:l},i),u);s.render=Zs(r,f)}}e.render=s.render||Me}xt(e),kt(),Xi(e),Ct(),ut()}function kl(e){return new Proxy(e.attrs,{get(t,n){return Ee(e,"get","$attrs"),t[n]}})}function Cl(e){const t=s=>{e.exposed=s||{}};let n;return{get attrs(){return n||(n=kl(e))},slots:e.slots,emit:e.emit,expose:t}}function $s(e){if(e.exposed)return e.exposeProxy||(e.exposeProxy=new Proxy(Sr(Ot(e.exposed)),{get(t,n){if(n in t)return t[n];if(n in gn)return gn[n](e)}}))}function El(e){return H(e)&&e.displayName||e.name}function Tl(e){return H(e)&&"__vccOpts"in e}const W=(e,t)=>Ei(e,t,yt);function ft(e,t,n){const s=arguments.length;return s===2?ae(t)&&!F(t)?_n(t)?S(e,null,[t]):S(e,t):S(e,null,t):(s>3?n=Array.prototype.slice.call(arguments,2):s===3&&_n(n)&&(n=[n]),S(e,t,n))}const Al="3.2.31",Pl="http://www.w3.org/2000/svg",st=typeof document!="undefined"?document:null,Qs=st&&st.createElement("template"),Ll={insert:(e,t,n)=>{t.insertBefore(e,n||null)},remove:e=>{const t=e.parentNode;t&&t.removeChild(e)},createElement:(e,t,n,s)=>{const r=t?st.createElementNS(Pl,e):st.createElement(e,n?{is:n}:void 0);return e==="select"&&s&&s.multiple!=null&&r.setAttribute("multiple",s.multiple),r},createText:e=>st.createTextNode(e),createComment:e=>st.createComment(e),setText:(e,t)=>{e.nodeValue=t},setElementText:(e,t)=>{e.textContent=t},parentNode:e=>e.parentNode,nextSibling:e=>e.nextSibling,querySelector:e=>st.querySelector(e),setScopeId(e,t){e.setAttribute(t,"")},cloneNode(e){const t=e.cloneNode(!0);return"_value"in e&&(t._value=e._value),t},insertStaticContent(e,t,n,s,r,o){const i=n?n.previousSibling:t.lastChild;if(r&&(r===o||r.nextSibling))for(;t.insertBefore(r.cloneNode(!0),n),!(r===o||!(r=r.nextSibling)););else{Qs.innerHTML=s?`${e}`:e;const l=Qs.content;if(s){const u=l.firstChild;for(;u.firstChild;)l.appendChild(u.firstChild);l.removeChild(u)}t.insertBefore(l,n)}return[i?i.nextSibling:t.firstChild,n?n.previousSibling:t.lastChild]}};function Il(e,t,n){const s=e._vtc;s&&(t=(t?[t,...s]:[...s]).join(" ")),t==null?e.removeAttribute("class"):n?e.setAttribute("class",t):e.className=t}function Ml(e,t,n){const s=e.style,r=pe(n);if(n&&!r){for(const o in n)Qn(s,o,n[o]);if(t&&!pe(t))for(const o in t)n[o]==null&&Qn(s,o,"")}else{const o=s.display;r?t!==n&&(s.cssText=n):t&&e.removeAttribute("style"),"_vod"in e&&(s.display=o)}}const Gs=/\s*!important$/;function Qn(e,t,n){if(F(n))n.forEach(s=>Qn(e,t,s));else if(t.startsWith("--"))e.setProperty(t,n);else{const s=Ol(e,t);Gs.test(n)?e.setProperty($t(s),n.replace(Gs,""),"important"):e[s]=n}}const er=["Webkit","Moz","ms"],Un={};function Ol(e,t){const n=Un[t];if(n)return n;let s=Ne(t);if(s!=="filter"&&s in e)return Un[t]=s;s=$n(s);for(let r=0;rdocument.createEvent("Event").timeStamp&&(mn=()=>performance.now());const e=navigator.userAgent.match(/firefox\/(\d+)/i);_o=!!(e&&Number(e[1])<=53)}let Gn=0;const Sl=Promise.resolve(),Nl=()=>{Gn=0},Hl=()=>Gn||(Sl.then(Nl),Gn=mn());function Bl(e,t,n,s){e.addEventListener(t,n,s)}function Ul(e,t,n,s){e.removeEventListener(t,n,s)}function jl(e,t,n,s,r=null){const o=e._vei||(e._vei={}),i=o[t];if(s&&i)i.value=s;else{const[l,u]=Dl(t);if(s){const f=o[t]=Wl(s,r);Bl(e,l,f,u)}else i&&(Ul(e,l,i,u),o[t]=void 0)}}const nr=/(?:Once|Passive|Capture)$/;function Dl(e){let t;if(nr.test(e)){t={};let n;for(;n=e.match(nr);)e=e.slice(0,e.length-n[0].length),t[n[0].toLowerCase()]=!0}return[$t(e.slice(2)),t]}function Wl(e,t){const n=s=>{const r=s.timeStamp||mn();(_o||r>=n.attached-1)&&Oe(Kl(s,n.value),t,5,[s])};return n.value=e,n.attached=Hl(),n}function Kl(e,t){if(F(t)){const n=e.stopImmediatePropagation;return e.stopImmediatePropagation=()=>{n.call(e),e._stopped=!0},t.map(s=>r=>!r._stopped&&s&&s(r))}else return t}const sr=/^on[a-z]/,ql=(e,t,n,s,r=!1,o,i,l,u)=>{t==="class"?Il(e,s,r):t==="style"?Ml(e,n,s):zt(t)?ss(t)||jl(e,t,n,s,i):(t[0]==="."?(t=t.slice(1),!0):t[0]==="^"?(t=t.slice(1),!1):zl(e,t,s,r))?Fl(e,t,s,o,i,l,u):(t==="true-value"?e._trueValue=s:t==="false-value"&&(e._falseValue=s),Rl(e,t,s,r))};function zl(e,t,n,s){return s?!!(t==="innerHTML"||t==="textContent"||t in e&&sr.test(t)&&H(n)):t==="spellcheck"||t==="draggable"||t==="form"||t==="list"&&e.tagName==="INPUT"||t==="type"&&e.tagName==="TEXTAREA"||sr.test(t)&&pe(n)?!1:t in e}const go=xe({patchProp:ql},Ll);let Bt,rr=!1;function Vl(){return Bt||(Bt=ul(go))}function Yl(){return Bt=rr?Bt:al(go),rr=!0,Bt}const rf=(...e)=>{const t=Vl().createApp(...e),{mount:n}=t;return t.mount=s=>{const r=mo(s);if(!r)return;const o=t._component;!H(o)&&!o.render&&!o.template&&(o.template=r.innerHTML),r.innerHTML="";const i=n(r,!1,r instanceof SVGElement);return r instanceof Element&&(r.removeAttribute("v-cloak"),r.setAttribute("data-v-app","")),i},t},Jl=(...e)=>{const t=Yl().createApp(...e),{mount:n}=t;return t.mount=s=>{const r=mo(s);if(r)return n(r,!0,r instanceof SVGElement)},t};function mo(e){return pe(e)?document.querySelector(e):e}var Xl='{"lang":"en-US","title":"Schlechtenburg","description":"Experimental WYSIWYG block editor","base":"/schlechtenburg/","head":[],"themeConfig":{"nav":[{"text":"Guide","activeMatch":"^/guide/","link":"/guide/why"},{"text":"API","activeMatch":"^/api/","items":[{"text":"@schlechtenburg/standalone","link":"/api/@schlechtenburg/standalone"},{"text":"@schlechtenburg/core","link":"/api/@schlechtenburg/core"},{"text":"@schlechtenburg/layout","link":"/api/@schlechtenburg/layout"},{"text":"@schlechtenburg/heading","link":"/api/@schlechtenburg/heading"},{"text":"@schlechtenburg/paragraph","link":"/api/@schlechtenburg/paragraph"},{"text":"@schlechtenburg/image","link":"/api/@schlechtenburg/image"}]}],"sidebar":{"/guide/":[{"text":"Getting Started","children":[{"text":"Why Schlechtenburg?","link":"/guide/why"},{"text":"Installation","link":"/guide/installation"},{"text":"Examples","link":"/guide/examples"}]}],"/api/":[{"text":"API","children":[{"text":"@schlechtenburg/standalone","link":"/api/@schlechtenburg/standalone"},{"text":"@schlechtenburg/core","link":"/api/@schlechtenburg/core"},{"text":"@schlechtenburg/layout","link":"/api/@schlechtenburg/layout"},{"text":"@schlechtenburg/heading","link":"/api/@schlechtenburg/heading"},{"text":"@schlechtenburg/paragraph","link":"/api/@schlechtenburg/paragraph"},{"text":"@schlechtenburg/image","link":"/api/@schlechtenburg/image"}]}],"/":false}},"locales":{},"langs":{},"scrollOffset":90}';const vo=/^https?:/i,Pe=typeof window!="undefined";function Zl(e,t){t.sort((n,s)=>{const r=s.split("/").length-n.split("/").length;return r!==0?r:s.length-n.length});for(const n of t)if(e.startsWith(n))return n}function or(e,t){const n=Zl(t,Object.keys(e));return n?e[n]:void 0}function Ql(e){const{locales:t}=e.themeConfig||{},n=e.locales;return t&&n?Object.keys(t).reduce((s,r)=>(s[r]={label:t[r].label,lang:n[r].lang},s),{}):{}}function Gl(e,t){t=ec(e,t);const n=or(e.locales||{},t),s=or(e.themeConfig.locales||{},t);return Object.assign({},e,n,{themeConfig:Object.assign({},e.themeConfig,s,{locales:{}}),lang:(n||e).lang,locales:{},langs:Ql(e)})}function ec(e,t){if(!Pe)return t;const n=e.base,s=n.endsWith("/")?n.slice(0,-1):n;return t.slice(s.length)}const bo=Symbol(),Jt=xi(tc(Xl));function tc(e){return JSON.parse(e)}function nc(e){const t=W(()=>Gl(Jt.value,e.path));return{site:t,theme:W(()=>t.value.themeConfig),page:W(()=>e.data),frontmatter:W(()=>e.data.frontmatter),lang:W(()=>t.value.lang),localePath:W(()=>{const{langs:n,lang:s}=t.value,r=Object.keys(n).find(o=>n[o].lang===s);return wt(r||"/")}),title:W(()=>e.data.title?e.data.title+" | "+t.value.title:t.value.title),description:W(()=>e.data.description||t.value.description)}}function me(){const e=St(bo);if(!e)throw new Error("vitepress data not properly injected in app");return e}function sc(e,t){return`${e}${t}`.replace(/\/+/g,"/")}function wt(e){return vo.test(e)?e:sc(Jt.value.base,e)}function xo(e){let t=e.replace(/\.html$/,"");if(t=decodeURIComponent(t),t.endsWith("/")&&(t+="index"),Pe){const n="/schlechtenburg/";t=t.slice(n.length).replace(/\//g,"_")+".md";const s=__VP_HASH_MAP__[t.toLowerCase()];t=`${n}assets/${t}.${s}.js`}else t=`./${t.slice(1).replace(/\//g,"_")}.md.js`;return t}const yo=Symbol(),ir="http://a.com",wo={relativePath:"",title:"404",description:"Not Found",headers:[],frontmatter:{},lastUpdated:0},rc=()=>({path:"/",component:null,data:wo});function oc(e,t){const n=Cn(rc());function s(i=Pe?location.href:"/"){const l=new URL(i,ir);return!l.pathname.endsWith("/")&&!l.pathname.endsWith(".html")&&(l.pathname+=".html",i=l.pathname+l.search+l.hash),Pe&&(history.replaceState({scrollPosition:window.scrollY},document.title),history.pushState(null,"",i)),o(i)}let r=null;async function o(i,l=0,u=!1){const f=new URL(i,ir),h=r=f.pathname;try{let m=e(h);if("then"in m&&typeof m.then=="function"&&(m=await m),r===h){r=null;const{default:b,__pageData:E}=m;if(!b)throw new Error(`Invalid route component: ${b}`);n.path=h,n.component=Ot(b),n.data=Ot(JSON.parse(E)),Pe&&Br(()=>{if(f.hash&&!l){let T=null;try{T=document.querySelector(decodeURIComponent(f.hash))}catch(j){console.warn(j)}if(T){lr(T,f.hash);return}}window.scrollTo(0,l)})}}catch(m){if(m.message.match(/fetch/)||console.error(m),!u)try{const b=await fetch(Jt.value.base+"hashmap.json");window.__VP_HASH_MAP__=await b.json(),await o(i,l,!0);return}catch{}r===h&&(r=null,n.path=h,n.component=t?Ot(t):null,n.data=wo)}}return Pe&&(window.addEventListener("click",i=>{const l=i.target.closest("a");if(l){const{href:u,protocol:f,hostname:h,pathname:m,hash:b,target:E}=l,T=window.location,j=m.match(/\.\w+$/);!i.ctrlKey&&!i.shiftKey&&!i.altKey&&!i.metaKey&&E!=="_blank"&&f===T.protocol&&h===T.hostname&&!(j&&j[0]!==".html")&&(i.preventDefault(),m===T.pathname?b&&b!==T.hash&&(history.pushState(null,"",b),window.dispatchEvent(new Event("hashchange")),lr(l,b,l.classList.contains("header-anchor"))):s(u))}},{capture:!0}),window.addEventListener("popstate",i=>{o(location.href,i.state&&i.state.scrollPosition||0)}),window.addEventListener("hashchange",i=>{i.preventDefault()})),{route:n,go:s}}function ic(){const e=St(yo);if(!e)throw new Error("useRouter() is called without provider.");return e}function et(){return ic().route}function lr(e,t,n=!1){let s=null;try{s=e.classList.contains("header-anchor")?e:document.querySelector(decodeURIComponent(t))}catch(r){console.warn(r)}if(s){let r=Jt.value.scrollOffset;typeof r=="string"&&(r=document.querySelector(r).getBoundingClientRect().bottom+24);const o=parseInt(window.getComputedStyle(s).paddingTop,10),i=window.scrollY+s.getBoundingClientRect().top-r+o;!n||Math.abs(i-window.scrollY)>window.innerHeight?window.scrollTo(0,i):window.scrollTo({left:0,top:i,behavior:"smooth"})}}function lc(e,t){let n=[],s=!0;const r=o=>{if(s){s=!1;return}const i=[],l=Math.min(n.length,o.length);for(let u=0;udocument.head.removeChild(u)),o.slice(l).forEach(u=>{const f=cr(u);document.head.appendChild(f),i.push(f)}),n=i};Vr(()=>{const o=e.data,i=t.value,l=o&&o.title,u=o&&o.description,f=o&&o.frontmatter.head;document.title=(l?l+" | ":"")+i.title,document.querySelector("meta[name=description]").setAttribute("content",u||i.description),r([...f?uc(f):[]])})}function cr([e,t,n]){const s=document.createElement(e);for(const r in t)s.setAttribute(r,t[r]);return n&&(s.innerHTML=n),s}function cc(e){return e[0]==="meta"&&e[1]&&e[1].name==="description"}function uc(e){return e.filter(t=>!cc(t))}const ac=re({name:"VitePressContent",setup(){const e=et();return()=>ft("div",{style:{position:"relative"}},[e.component?ft(e.component):null])}});var ce=(e,t)=>{const n=e.__vccOpts||e;for(const[s,r]of t)n[s]=r;return n};const fc=/#.*$/,dc=/(index)?\.(md|html)$/,vn=/\/$/,hc=/^[a-z]+:/i;function ks(e){return Array.isArray(e)}function Cs(e){return hc.test(e)}function pc(e,t){if(t===void 0)return!1;const n=ur(`/${e.data.relativePath}`),s=ur(t);return n===s}function ur(e){return decodeURI(e).replace(fc,"").replace(dc,"")}function _c(e,t){const n=e.endsWith("/"),s=t.startsWith("/");return n&&s?e.slice(0,-1)+t:!n&&!s?`${e}/${t}`:e+t}function es(e){return/^\//.test(e)?e:`/${e}`}function $o(e){return e.replace(/(index)?(\.(md|html))?$/,"")||"/"}function gc(e){return e===!1||e==="auto"||ks(e)}function mc(e){return e.children!==void 0}function vc(e){return ks(e)?e.length===0:!e}function Es(e,t){if(gc(e))return e;t=es(t);for(const n in e)if(t.startsWith(es(n)))return e[n];return"auto"}function ko(e){return e.reduce((t,n)=>(n.link&&t.push({text:n.text,link:$o(n.link)}),mc(n)&&(t=[...t,...ko(n.children)]),t),[])}function Co(e){const t=et(),n=Cs(e.value.link);return{props:W(()=>{const r=ar(`/${t.data.relativePath}`);let o=!1;if(e.value.activeMatch)o=new RegExp(e.value.activeMatch).test(r);else{const i=ar(e.value.link);o=i==="/"?i===r:r.startsWith(i)}return{class:{active:o,isExternal:n},href:n?e.value.link:wt(e.value.link),target:e.value.target||(n?"_blank":null),rel:e.value.rel||(n?"noopener noreferrer":null),"aria-label":e.value.ariaLabel}}),isExternal:n}}function ar(e){return e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\.(html|md)$/,"").replace(/\/index$/,"/")}const bc={},xc={class:"icon outbound",xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",x:"0px",y:"0px",viewBox:"0 0 100 100",width:"15",height:"15"},yc=B("path",{fill:"currentColor",d:"M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"},null,-1),wc=B("polygon",{fill:"currentColor",points:"45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"},null,-1),$c=[yc,wc];function kc(e,t){return P(),N("svg",xc,$c)}var Ts=ce(bc,[["render",kc]]);const Cc={class:"nav-link"},Ec=re({props:{item:null},setup(e){const n=Nr(e),{props:s,isExternal:r}=Co(n.item);return(o,i)=>(P(),N("div",Cc,[B("a",ws({class:"item"},k(s)),[Yt(be(e.item.text)+" ",1),k(r)?(P(),ge(Ts,{key:0})):Y("",!0)],16)]))}});var bn=ce(Ec,[["__scopeId","data-v-b8818f8c"]]);const Tc={key:0,class:"home-hero"},Ac={key:0,class:"figure"},Pc=["src","alt"],Lc={key:1,id:"main-title",class:"title"},Ic={key:2,class:"tagline"},Mc=re({setup(e){const{site:t,frontmatter:n}=me(),s=W(()=>{const{heroImage:i,heroText:l,tagline:u,actionLink:f,actionText:h}=n.value;return i||l||u||f&&h}),r=W(()=>n.value.heroText||t.value.title),o=W(()=>n.value.tagline||t.value.description);return(i,l)=>k(s)?(P(),N("header",Tc,[k(n).heroImage?(P(),N("figure",Ac,[B("img",{class:"image",src:k(wt)(k(n).heroImage),alt:k(n).heroAlt},null,8,Pc)])):Y("",!0),k(r)?(P(),N("h1",Lc,be(k(r)),1)):Y("",!0),k(o)?(P(),N("p",Ic,be(k(o)),1)):Y("",!0),k(n).actionLink&&k(n).actionText?(P(),ge(bn,{key:3,item:{link:k(n).actionLink,text:k(n).actionText},class:"action"},null,8,["item"])):Y("",!0),k(n).altActionLink&&k(n).altActionText?(P(),ge(bn,{key:4,item:{link:k(n).altActionLink,text:k(n).altActionText},class:"action alt"},null,8,["item"])):Y("",!0)])):Y("",!0)}});var Oc=ce(Mc,[["__scopeId","data-v-370f18c0"]]);const Rc={key:0,class:"home-features"},Fc={class:"wrapper"},Sc={class:"container"},Nc={class:"features"},Hc={key:0,class:"title"},Bc={key:1,class:"details"},Uc=re({setup(e){const{frontmatter:t}=me(),n=W(()=>t.value.features&&t.value.features.length>0),s=W(()=>t.value.features?t.value.features:[]);return(r,o)=>k(n)?(P(),N("div",Rc,[B("div",Fc,[B("div",Sc,[B("div",Nc,[(P(!0),N(fe,null,Ln(k(s),(i,l)=>(P(),N("section",{key:l,class:"feature"},[i.title?(P(),N("h2",Hc,be(i.title),1)):Y("",!0),i.details?(P(),N("p",Bc,be(i.details),1)):Y("",!0)]))),128))])])])])):Y("",!0)}});var jc=ce(Uc,[["__scopeId","data-v-e39c13e0"]]);const Dc={key:0,class:"footer"},Wc={class:"container"},Kc={class:"text"},qc=re({setup(e){const{frontmatter:t}=me();return(n,s)=>k(t).footer?(P(),N("footer",Dc,[B("div",Wc,[B("p",Kc,be(k(t).footer),1)])])):Y("",!0)}});var zc=ce(qc,[["__scopeId","data-v-30918238"]]);const Vc={class:"home","aria-labelledby":"main-title"},Yc={class:"home-content"},Jc=re({setup(e){return(t,n)=>{const s=hn("Content");return P(),N("main",Vc,[S(Oc),ue(t.$slots,"hero",{},void 0,!0),S(jc),B("div",Yc,[S(s)]),ue(t.$slots,"features",{},void 0,!0),S(zc),ue(t.$slots,"footer",{},void 0,!0)])}}});var Xc=ce(Jc,[["__scopeId","data-v-10122c92"]]);const Zc=["href","aria-label"],Qc=["src"],Gc=re({setup(e){const{site:t,theme:n,localePath:s}=me();return(r,o)=>(P(),N("a",{class:"nav-bar-title",href:k(s),"aria-label":`${k(t).title}, back to home`},[k(n).logo?(P(),N("img",{key:0,class:"logo",src:k(wt)(k(n).logo),alt:"Logo"},null,8,Qc)):Y("",!0),Yt(" "+be(k(t).title),1)],8,Zc))}});var eu=ce(Gc,[["__scopeId","data-v-cc01ef16"]]);function tu(){const{site:e,localePath:t,theme:n}=me();return W(()=>{const s=e.value.langs,r=Object.keys(s);if(r.length<2)return null;const i=et().path.replace(t.value,""),l=r.map(f=>({text:s[f].label,link:`${f}${i}`}));return{text:n.value.selectText||"Languages",items:l}})}const nu=["GitHub","GitLab","Bitbucket"].map(e=>[e,new RegExp(e,"i")]);function su(){const{site:e}=me();return W(()=>{const t=e.value.themeConfig,n=t.docsRepo||t.repo;if(!n)return null;const s=ru(n);return{text:ou(s,t.repoLabel),link:s}})}function ru(e){return vo.test(e)?e:`https://github.com/${e}`}function ou(e,t){if(t)return t;const n=e.match(/^https?:\/\/[^/]+/);if(!n)return"Source";const s=nu.find(([r,o])=>o.test(n[0]));return s&&s[0]?s[0]:"Source"}const iu=e=>(Kr("data-v-bbc27490"),e=e(),qr(),e),lu={class:"nav-dropdown-link-item"},cu=iu(()=>B("span",{class:"arrow"},null,-1)),uu={class:"text"},au={class:"icon"},fu=re({props:{item:null},setup(e){const n=Nr(e),{props:s,isExternal:r}=Co(n.item);return(o,i)=>(P(),N("div",lu,[B("a",ws({class:"item"},k(s)),[cu,B("span",uu,be(e.item.text),1),B("span",au,[k(r)?(P(),ge(Ts,{key:0})):Y("",!0)])],16)]))}});var du=ce(fu,[["__scopeId","data-v-bbc27490"]]);const hu=["aria-label"],pu={class:"button-text"},_u={class:"dialog"},gu=re({props:{item:null},setup(e){const t=et(),n=it(!1);lt(()=>t.path,()=>{n.value=!1});function s(){n.value=!n.value}return(r,o)=>(P(),N("div",{class:at(["nav-dropdown-link",{open:n.value}])},[B("button",{class:"button","aria-label":e.item.ariaLabel,onClick:s},[B("span",pu,be(e.item.text),1),B("span",{class:at(["button-arrow",n.value?"down":"right"])},null,2)],8,hu),B("ul",_u,[(P(!0),N(fe,null,Ln(e.item.items,i=>(P(),N("li",{key:i.text,class:"dialog-item"},[S(du,{item:i},null,8,["item"])]))),128))])],2))}});var fr=ce(gu,[["__scopeId","data-v-56bf3a3f"]]);const mu={key:0,class:"nav-links"},vu={key:1,class:"item"},bu={key:2,class:"item"},xu=re({setup(e){const{theme:t}=me(),n=tu(),s=su(),r=W(()=>t.value.nav||s.value||n.value);return(o,i)=>k(r)?(P(),N("nav",mu,[k(t).nav?(P(!0),N(fe,{key:0},Ln(k(t).nav,l=>(P(),N("div",{key:l.text,class:"item"},[l.items?(P(),ge(fr,{key:0,item:l},null,8,["item"])):(P(),ge(bn,{key:1,item:l},null,8,["item"]))]))),128)):Y("",!0),k(n)?(P(),N("div",vu,[S(fr,{item:k(n)},null,8,["item"])])):Y("",!0),k(s)?(P(),N("div",bu,[S(bn,{item:k(s)},null,8,["item"])])):Y("",!0)])):Y("",!0)}});var Eo=ce(xu,[["__scopeId","data-v-eab3edfe"]]);const yu={emits:["toggle"]},wu=B("svg",{class:"icon",xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",role:"img",viewBox:"0 0 448 512"},[B("path",{fill:"currentColor",d:"M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z",class:""})],-1),$u=[wu];function ku(e,t,n,s,r,o){return P(),N("div",{class:"sidebar-button",onClick:t[0]||(t[0]=i=>e.$emit("toggle"))},$u)}var Cu=ce(yu,[["render",ku]]);const Eu=e=>(Kr("data-v-675d8756"),e=e(),qr(),e),Tu={class:"nav-bar"},Au=Eu(()=>B("div",{class:"flex-grow"},null,-1)),Pu={class:"nav"},Lu=re({emits:["toggle"],setup(e){return(t,n)=>(P(),N("header",Tu,[S(Cu,{onToggle:n[0]||(n[0]=s=>t.$emit("toggle"))}),S(eu),Au,B("div",Pu,[S(Eo)]),ue(t.$slots,"search",{},void 0,!0)]))}});var Iu=ce(Lu,[["__scopeId","data-v-675d8756"]]);function Mu(){let e=null,t=null;const n=Nu(s,300);function s(){const i=Ou(),l=Ru(i);for(let u=0;u ul > li");l&&l!==t.parentElement?(e=l.querySelector("a"),e&&e.classList.add("active")):e=null}function o(i){i&&i.classList.remove("active")}Et(()=>{s(),window.addEventListener("scroll",n)}),Xr(()=>{r(decodeURIComponent(location.hash))}),An(()=>{window.removeEventListener("scroll",n)})}function Ou(){return[].slice.call(document.querySelectorAll(".sidebar a.sidebar-link-item"))}function Ru(e){return[].slice.call(document.querySelectorAll(".header-anchor")).filter(t=>e.some(n=>n.hash===t.hash))}function Fu(){return document.querySelector(".nav-bar").offsetHeight}function dr(e){const t=Fu();return e.parentElement.offsetTop-t-15}function Su(e,t,n){const s=window.scrollY;return e===0&&s===0?[!0,null]:s{n&&clearTimeout(n),s?n=setTimeout(e,t):(e(),s=!0,setTimeout(()=>{s=!1},t))}}function Hu(){const e=et(),{site:t}=me();return Mu(),W(()=>{const n=e.data.headers,s=e.data.frontmatter.sidebar,r=e.data.frontmatter.sidebarDepth;if(s===!1)return[];if(s==="auto")return hr(n,r);const o=Es(t.value.themeConfig.sidebar,e.data.relativePath);return o===!1?[]:o==="auto"?hr(n,r):o})}function hr(e,t){const n=[];if(e===void 0)return[];let s;return e.forEach(({level:r,title:o,slug:i})=>{if(r-1>t)return;const l={text:o,link:`#${i}`};r===2?(s=l,n.push(l)):s&&(s.children||(s.children=[])).push(l)}),n}const To=e=>{const t=et(),{site:n,frontmatter:s}=me(),r=e.depth||1,o=s.value.sidebarDepth||1/0,i=t.data.headers,l=e.item.text,u=Bu(n.value.base,e.item.link),f=e.item.children,h=pc(t,e.item.link),m=r0?ft("ul",{class:"sidebar-links"},t.map(r=>ft(To,{item:r,depth:s}))):e&&n?Ao(!1,Uu(n),void 0,s):null}function Uu(e){return Po(ju(e))}function ju(e){e=e.map(n=>Object.assign({},n));let t;return e.forEach(n=>{n.level===2?t=n:t&&(t.children||(t.children=[])).push(n)}),e.filter(n=>n.level===2)}function Po(e){return e.map(t=>({text:t.title,link:`#${t.slug}`,children:t.children?Po(t.children):void 0}))}const Du={key:0,class:"sidebar-links"},Wu=re({setup(e){const t=Hu();return(n,s)=>k(t).length>0?(P(),N("ul",Du,[(P(!0),N(fe,null,Ln(k(t),r=>(P(),ge(k(To),{item:r},null,8,["item"]))),256))])):Y("",!0)}});const Ku=re({props:{open:{type:Boolean}},setup(e){return(t,n)=>(P(),N("aside",{class:at(["sidebar",{open:e.open}])},[S(Eo,{class:"nav"}),ue(t.$slots,"sidebar-top",{},void 0,!0),S(Wu),ue(t.$slots,"sidebar-bottom",{},void 0,!0)],2))}});var qu=ce(Ku,[["__scopeId","data-v-83e92a68"]]);const zu=/bitbucket.org/;function Vu(){const{page:e,theme:t,frontmatter:n}=me(),s=W(()=>{const{repo:o,docsDir:i="",docsBranch:l="master",docsRepo:u=o,editLinks:f}=t.value,h=n.value.editLink!=null?n.value.editLink:f,{relativePath:m}=e.value;return!h||!m||!o?null:Yu(o,u,i,l,m)}),r=W(()=>t.value.editLinkText||"Edit this page");return{url:s,text:r}}function Yu(e,t,n,s,r){return zu.test(e)?Xu(e,t,n,s,r):Ju(e,t,n,s,r)}function Ju(e,t,n,s,r){return(Cs(t)?t:`https://github.com/${t}`).replace(vn,"")+`/edit/${s}/`+(n?n.replace(vn,"")+"/":"")+r}function Xu(e,t,n,s,r){return(Cs(t)?t:e).replace(vn,"")+`/src/${s}/`+(n?n.replace(vn,"")+"/":"")+r+`?mode=edit&spa=0&at=${s}&fileviewer=file-view-default`}const Zu={class:"edit-link"},Qu=["href"],Gu=re({setup(e){const{url:t,text:n}=Vu();return(s,r)=>(P(),N("div",Zu,[k(t)?(P(),N("a",{key:0,class:"link",href:k(t),target:"_blank",rel:"noopener noreferrer"},[Yt(be(k(n))+" ",1),S(Ts,{class:"icon"})],8,Qu)):Y("",!0)]))}});var ea=ce(Gu,[["__scopeId","data-v-1ed99556"]]);const ta={key:0,class:"last-updated"},na={class:"prefix"},sa={class:"datetime"},ra=re({setup(e){const{theme:t,page:n}=me(),s=W(()=>{const i=t.value.lastUpdated;return i!==void 0&&i!==!1&&n.value.lastUpdated!==0}),r=W(()=>{const i=t.value.lastUpdated;return i===!0?"Last Updated":i}),o=it("");return Et(()=>{Vr(()=>{o.value=new Date(n.value.lastUpdated).toLocaleString("en-US")})}),(i,l)=>k(s)?(P(),N("p",ta,[B("span",na,be(k(r))+":",1),B("span",sa,be(o.value),1)])):Y("",!0)}});var oa=ce(ra,[["__scopeId","data-v-abce3432"]]);const ia={class:"page-footer"},la={class:"edit"},ca={class:"updated"},ua=re({setup(e){const{page:t}=me();return(n,s)=>(P(),N("footer",ia,[B("div",la,[S(ea)]),B("div",ca,[k(t).lastUpdated?(P(),ge(oa,{key:0})):Y("",!0)])]))}});var aa=ce(ua,[["__scopeId","data-v-07c132fc"]]);function fa(){const{page:e,theme:t}=me(),n=W(()=>$o(es(e.value.relativePath))),s=W(()=>{const u=Es(t.value.sidebar,n.value);return ks(u)?ko(u):[]}),r=W(()=>s.value.findIndex(u=>u.link===n.value)),o=W(()=>{if(t.value.nextLinks!==!1&&r.value>-1&&r.value{if(t.value.prevLinks!==!1&&r.value>0)return s.value[r.value-1]}),l=W(()=>!!o.value||!!i.value);return{next:o,prev:i,hasLinks:l}}const da={},ha={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},pa=B("path",{d:"M19,11H7.4l5.3-5.3c0.4-0.4,0.4-1,0-1.4s-1-0.4-1.4,0l-7,7c-0.1,0.1-0.2,0.2-0.2,0.3c-0.1,0.2-0.1,0.5,0,0.8c0.1,0.1,0.1,0.2,0.2,0.3l7,7c0.2,0.2,0.5,0.3,0.7,0.3s0.5-0.1,0.7-0.3c0.4-0.4,0.4-1,0-1.4L7.4,13H19c0.6,0,1-0.4,1-1S19.6,11,19,11z"},null,-1),_a=[pa];function ga(e,t){return P(),N("svg",ha,_a)}var ma=ce(da,[["render",ga]]);const va={},ba={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},xa=B("path",{d:"M19.9,12.4c0.1-0.2,0.1-0.5,0-0.8c-0.1-0.1-0.1-0.2-0.2-0.3l-7-7c-0.4-0.4-1-0.4-1.4,0s-0.4,1,0,1.4l5.3,5.3H5c-0.6,0-1,0.4-1,1s0.4,1,1,1h11.6l-5.3,5.3c-0.4,0.4-0.4,1,0,1.4c0.2,0.2,0.5,0.3,0.7,0.3s0.5-0.1,0.7-0.3l7-7C19.8,12.6,19.9,12.5,19.9,12.4z"},null,-1),ya=[xa];function wa(e,t){return P(),N("svg",ba,ya)}var $a=ce(va,[["render",wa]]);const ka={key:0,class:"next-and-prev-link"},Ca={class:"container"},Ea={class:"prev"},Ta=["href"],Aa={class:"text"},Pa={class:"next"},La=["href"],Ia={class:"text"},Ma=re({setup(e){const{hasLinks:t,prev:n,next:s}=fa();return(r,o)=>k(t)?(P(),N("div",ka,[B("div",Ca,[B("div",Ea,[k(n)?(P(),N("a",{key:0,class:"link",href:k(wt)(k(n).link)},[S(ma,{class:"icon icon-prev"}),B("span",Aa,be(k(n).text),1)],8,Ta)):Y("",!0)]),B("div",Pa,[k(s)?(P(),N("a",{key:0,class:"link",href:k(wt)(k(s).link)},[B("span",Ia,be(k(s).text),1),S($a,{class:"icon icon-next"})],8,La)):Y("",!0)])])])):Y("",!0)}});var Oa=ce(Ma,[["__scopeId","data-v-38ede35f"]]);const Ra={class:"page"},Fa={class:"container"},Sa=re({setup(e){return(t,n)=>{const s=hn("Content");return P(),N("main",Ra,[B("div",Fa,[ue(t.$slots,"top",{},void 0,!0),S(s,{class:"content"}),S(aa),S(Oa),ue(t.$slots,"bottom",{},void 0,!0)])])}}});var Na=ce(Sa,[["__scopeId","data-v-7eddb2c4"]]);const Ha={key:0,id:"ads-container"},Ba=re({setup(e){const t=()=>null,n=t,s=t,r=t,o=et(),{site:i,page:l,theme:u,frontmatter:f}=me(),h=W(()=>!!f.value.customLayout),m=W(()=>!!f.value.home),b=W(()=>Object.keys(i.value.langs).length>1),E=W(()=>{const M=u.value;return f.value.navbar===!1||M.navbar===!1?!1:i.value.title||M.logo||M.repo||M.nav}),T=it(!1),j=W(()=>f.value.home||f.value.sidebar===!1?!1:!vc(Es(u.value.sidebar,o.data.relativePath))),p=M=>{T.value=typeof M=="boolean"?M:!T.value},x=p.bind(null,!1);lt(o,x);const O=W(()=>[{"no-navbar":!E.value,"sidebar-open":T.value,"no-sidebar":!j.value}]);return(M,U)=>{const Z=hn("Content"),Q=hn("Debug");return P(),N(fe,null,[B("div",{class:at(["theme",k(O)])},[k(E)?(P(),ge(Iu,{key:0,onToggle:p},{search:je(()=>[ue(M.$slots,"navbar-search",{},()=>[k(u).algolia?(P(),ge(k(r),{key:0,options:k(u).algolia,multilang:k(b)},null,8,["options","multilang"])):Y("",!0)])]),_:3})):Y("",!0),S(qu,{open:T.value},{"sidebar-top":je(()=>[ue(M.$slots,"sidebar-top")]),"sidebar-bottom":je(()=>[ue(M.$slots,"sidebar-bottom")]),_:3},8,["open"]),B("div",{class:"sidebar-mask",onClick:U[0]||(U[0]=D=>p(!1))}),k(h)?(P(),ge(Z,{key:1})):k(m)?ue(M.$slots,"home",{key:2},()=>[S(Xc,null,{hero:je(()=>[ue(M.$slots,"home-hero")]),features:je(()=>[ue(M.$slots,"home-features")]),footer:je(()=>[ue(M.$slots,"home-footer")]),_:3})]):(P(),ge(Na,{key:3},{top:je(()=>[ue(M.$slots,"page-top-ads",{},()=>[k(u).carbonAds&&k(u).carbonAds.carbon?(P(),N("div",Ha,[(P(),ge(k(n),{key:"carbon"+k(l).relativePath,code:k(u).carbonAds.carbon,placement:k(u).carbonAds.placement},null,8,["code","placement"]))])):Y("",!0)]),ue(M.$slots,"page-top")]),bottom:je(()=>[ue(M.$slots,"page-bottom"),ue(M.$slots,"page-bottom-ads",{},()=>[k(u).carbonAds&&k(u).carbonAds.custom?(P(),ge(k(s),{key:"custom"+k(l).relativePath,code:k(u).carbonAds.custom,placement:k(u).carbonAds.placement},null,8,["code","placement"])):Y("",!0)])]),_:3}))],2),S(Q)],64)}}}),Ua={class:"theme"},ja=B("h1",null,"404",-1),Da=["href"],Wa=re({setup(e){const{site:t}=me(),n=["There's nothing here.","How did we get here?","That's a Four-Oh-Four.","Looks like we've got some broken links."];function s(){return n[Math.floor(Math.random()*n.length)]}return(r,o)=>(P(),N("div",Ua,[ja,B("blockquote",null,be(s()),1),B("a",{href:k(t).base,"aria-label":"go to home"},"Take me home.",8,Da)]))}}),xn={Layout:Ba,NotFound:Wa};const jn=new Set,Lo=()=>document.createElement("link"),Ka=e=>{const t=Lo();t.rel="prefetch",t.href=e,document.head.appendChild(t)},qa=e=>{const t=new XMLHttpRequest;t.open("GET",e,t.withCredentials=!0),t.send()};let sn;const za=Pe&&(sn=Lo())&&sn.relList&&sn.relList.supports&&sn.relList.supports("prefetch")?Ka:qa;function Va(){if(!Pe||!window.IntersectionObserver)return;let e;if((e=navigator.connection)&&(e.saveData||/2g/.test(e.effectiveType)))return;const t=window.requestIdleCallback||setTimeout;let n=null;const s=()=>{n&&n.disconnect(),n=new IntersectionObserver(o=>{o.forEach(i=>{if(i.isIntersecting){const l=i.target;n.unobserve(l);const{pathname:u}=l;if(!jn.has(u)){jn.add(u);const f=xo(u);za(f)}}})}),t(()=>{document.querySelectorAll("#app a").forEach(o=>{const{target:i,hostname:l,pathname:u}=o,f=u.match(/\.\w+$/);f&&f[0]!==".html"||i!=="_blank"&&l===location.hostname&&(u!==location.pathname?n.observe(o):jn.add(u))})})};Et(s);const r=et();lt(()=>r.path,s),An(()=>{n&&n.disconnect()})}const Ya=re({setup(e,{slots:t}){const n=it(!1);return Et(()=>{n.value=!0}),()=>n.value&&t.default?t.default():null}}),Ja=xn.NotFound||(()=>"404 Not Found"),Xa={name:"VitePressApp",setup(){const{site:e}=me();return Et(()=>{lt(()=>e.value.lang,t=>{document.documentElement.lang=t},{immediate:!0})}),Va(),()=>ft(xn.Layout)}};function Za(){const e=Ga(),t=Qa();t.provide(yo,e);const n=nc(e.route);return t.provide(bo,n),Pe&&lc(e.route,n.site),t.component("Content",ac),t.component("ClientOnly",Ya),t.component("Debug",()=>null),Object.defineProperty(t.config.globalProperties,"$frontmatter",{get(){return n.frontmatter.value}}),xn.enhanceApp&&xn.enhanceApp({app:t,router:e,siteData:Jt}),{app:t,router:e}}function Qa(){return Jl(Xa)}function Ga(){let e=Pe,t;return oc(n=>{let s=xo(n);return e&&(t=s),(e||t===s)&&(s=s.replace(/\.js$/,".lean.js")),Pe?(e=!1,import(s)):require(s)},Ja)}if(Pe){const{app:e,router:t}=Za();t.go().then(()=>{e.mount("#app")})}export{fe as F,ce as _,sf as a,B as b,N as c,Za as createApp,Yt as d,re as e,S as f,rf as g,Et as h,St as i,W as j,qi as k,Cn as l,Wi as m,An as n,P as o,Hi as p,ws as q,it as r,ef as s,tf as t,k as u,nf as v,lt as w,bi as x,wt as y,ft as z}; diff --git a/docs/assets/chunks/ExampleEditor.08243b7c.js b/docs/assets/chunks/ExampleEditor.08243b7c.js new file mode 100644 index 0000000..eefb21f --- /dev/null +++ b/docs/assets/chunks/ExampleEditor.08243b7c.js @@ -0,0 +1 @@ +var yA=Object.defineProperty,XA=Object.defineProperties;var LA=Object.getOwnPropertyDescriptors;var Y=Object.getOwnPropertySymbols;var MA=Object.prototype.hasOwnProperty,kA=Object.prototype.propertyIsEnumerable;var Z=(A,e,t)=>e in A?yA(A,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):A[e]=t,d=(A,e)=>{for(var t in e||(e={}))MA.call(e,t)&&Z(A,t,e[t]);if(Y)for(var t of Y(e))kA.call(e,t)&&Z(A,t,e[t]);return A},m=(A,e)=>XA(A,LA(e));import{i as P,r as I,j as L,k as mA,l as M,p as l,m as FA,w as E,n as OA,e as s,f as Q,d as D,q as H,s as u,t as VA,v as jA,x as pA,F as SA}from"../app.d1307649.js";var U=(A=>(A.Edit="edit",A.View="view",A))(U||{});const QA=Symbol("Schlechtenburg mode");var F,GA=new Uint8Array(16);function KA(){if(!F&&(F=typeof crypto!="undefined"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto)||typeof msCrypto!="undefined"&&typeof msCrypto.getRandomValues=="function"&&msCrypto.getRandomValues.bind(msCrypto),!F))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return F(GA)}var HA=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;function xA(A){return typeof A=="string"&&HA.test(A)}var a=[];for(var j=0;j<256;++j)a.push((j+256).toString(16).substr(1));function JA(A){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,t=(a[A[e+0]]+a[A[e+1]]+a[A[e+2]]+a[A[e+3]]+"-"+a[A[e+4]]+a[A[e+5]]+"-"+a[A[e+6]]+a[A[e+7]]+"-"+a[A[e+8]]+a[A[e+9]]+"-"+a[A[e+10]]+a[A[e+11]]+a[A[e+12]]+a[A[e+13]]+a[A[e+14]]+a[A[e+15]]).toLowerCase();if(!xA(t))throw TypeError("Stringified UUID is invalid");return t}function WA(A,e,t){A=A||{};var n=A.random||(A.rng||KA)();if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,e){t=t||0;for(var g=0;g<16;++g)e[t+g]=n[g];return e}return JA(n)}const x=WA,hA={prop:"block",event:"update"},ft={blockId:{type:String,default:x}},BA=Symbol("Schlechtenburg active block");function iA(A=null){const e=P(BA,I(null)),t=L(()=>e.value===A),n=(i=A)=>{e.value===i&&(e.value=null)},g=i=>n();mA(()=>{document.removeEventListener("click",g)});const B=(i=A)=>{document.addEventListener("click",g,{once:!0}),e.value=i};return{activeBlockId:e,isActive:t,activate:B,deactivate:n,requestActivation:()=>{e.value||B()}}}const vA=Symbol("Schlechtenburg block library");function CA(){const A=P(QA,I(U.Edit)),e=P(vA,M({}));return{mode:A,customBlocks:e,getBlock:n=>e[n]}}const aA=Symbol("Schlechtenburg block dimensions"),IA=Symbol("Schlechtenburg editor dimensions");function oA(A,e){const t=I(null);l(e,t);const n=()=>{if(!A.value)return;const g=A.value.getBoundingClientRect();t.value={width:g.width,height:g.height,left:A.value.offsetLeft,top:A.value.offsetTop}};return FA(()=>{const g=new ResizeObserver(n),B=new MutationObserver(n);E(A,()=>{!A.value||(g.observe(A.value),B.observe(A.value,{attributes:!0,childList:!1,subtree:!1}))})}),{triggerSizeCalculation:n,dimensions:t}}function sA(){const A=P(IA,I(null)),e=P(aA,I(null));return{editorDimensions:A,blockDimensions:e}}const fA=Symbol("Schlechtenburg block tree"),S=Symbol("Schlechtenburg block tree register"),G=Symbol("Schlechtenburg block tree unregister");function EA(){const A=P(fA,I(null)),e=P(S,B=>{}),t=P(G,B=>{}),n=M({id:"",name:"",icon:"",children:[]});l(S,B=>{n.children.find(r=>r.id===B.id)||(n.children=[...n.children,B])}),l(G,({id:B})=>{n.children=n.children.filter(r=>r.id!==B)});const g=B=>{if(!B.id)throw new Error(`Cannot register a block without an id: ${JSON.stringify(B)}`);n.id=B.id,n.name=B.name,e(n)};return OA(()=>{n.id&&t(n)}),{blockTree:A,register:g}}const w=s({name:"sb-button",inheritAttrs:!1,setup(A,e){return()=>{var t,n;return Q("button",m(d({},e.attrs),{class:(e.attrs.class||"")+" sb-button"}),[(n=(t=e.slots).default)==null?void 0:n.call(t)])}}});const uA=s({name:"sb-context-menu",props:{onClose:{type:Function,default:()=>{}},onOpen:{type:Function,default:()=>{}}},setup(A,e){const t=I(!1),n=()=>{t.value=!0},g=()=>{t.value=!1},B=i=>{i.key==="Escape"&&g()},r=()=>{t.value?g():n()};return E(t,(i,v)=>{i!==v&&(i?setTimeout(()=>{document.body.addEventListener("click",g),document.body.addEventListener("keypress",B),A.onOpen()}):(document.body.removeEventListener("click",g),document.body.removeEventListener("keypress",B),A.onClose()))}),()=>{var i,v,f,R;return Q("div",{class:"sb-context"},[((v=(i=e.slots).context)==null?void 0:v.call(i,{opened:t,toggle:r,close:g,open:n}))||Q(w,{onClick:r},{default:()=>[D("Menu")]}),Q("dialog",H({class:"sb-context-menu",open:t.value?!0:void 0,onClick:o=>{o.stopPropagation()}},{onClose:g}),[((R=(f=e.slots).default)==null?void 0:R.call(f,{opened:t,toggle:r,close:g,open:n}))||null])])}}});const NA=s({name:"sb-main-menu",setup(){const{blockTree:A}=EA(),{activate:e,activeBlockId:t}=iA(),n=(g,B)=>{var r,i;return Q("li",{class:{"sb-tree-block-select__block":!0,"sb-tree-block-select__block_active":t.value===g.id}},[Q("button",{class:"sb-tree-block-select__block-name",onClick:()=>{e(g.id),B()},onMouseenter:()=>e(g.id)},[g.name]),(r=g.children)!=null&&r.length?Q("ul",{class:"sb-tree-block-select__list"},[(i=g.children)==null?void 0:i.map(v=>n(v,B))]):null])};return()=>A.value?Q(uA,{class:"sb-tree-block-select"},{context:({toggle:g})=>Q(w,{onClick:g},{default:()=>[D("Tree")]}),default:({close:g})=>Q("ul",{class:"sb-tree-block-select__list sb-tree-block-select__list_base"},[n(A.value,g)])}):""}});const YA=s({name:"sb-main-menu",props:{block:{type:null,required:!0}},setup(){return()=>Q("div",{class:"sb-main-menu"},[Q(NA,null,null)])}});const ZA=s({name:"sb-block-toolbar",setup(){return()=>Q("div",{class:"sb-block-toolbar"},null)}});const K=(A,e=[])=>{const t=A.parentElement;return t?t.classList.contains("sb-hover-cover")?K(t,[...e,t]):K(t,e):e},J=new WeakMap,T=A=>{const e=J.get(A.target);for(const t of e)t.classList.add("sb-hover-cover_child-hovered")},_=A=>{const e=J.get(A.target);e&&e.length&&e[0].classList.remove("sb-hover-cover_child-hovered")};var TA={updated(A){A.classList.add("sb-hover-cover")},beforeMount(A){A.classList.add("sb-hover-cover")},mounted(A){A.classList.add("sb-hover-cover");const e=K(A);J.set(A,e),A.addEventListener("mouseenter",T),A.addEventListener("mouseleave",_)},unmounted(A){A.removeEventListener("mouseenter",T),A.removeEventListener("mouseleave",_)}};const _A="modulepreload",$={},$A="/schlechtenburg/",c=function(e,t){return!t||t.length===0?e():Promise.all(t.map(n=>{if(n=`${$A}${n}`,n in $)return;$[n]=!0;const g=n.endsWith(".css"),B=g?'[rel="stylesheet"]':"";if(document.querySelector(`link[href="${n}"]${B}`))return;const r=document.createElement("link");if(r.rel=g?"stylesheet":_A,g||(r.as="script",r.crossOrigin=""),r.href=n,document.head.appendChild(r),g)return new Promise((i,v)=>{r.addEventListener("load",i),r.addEventListener("error",()=>v(new Error(`Unable to preload CSS for ${n}`)))})})).then(()=>e())};var Ae={name:"sb-missing-block",edit:u(()=>c(()=>import("./view.0dc125f4.js"),["assets/chunks/view.0dc125f4.js","assets/app.d1307649.js"])),view:u(()=>c(()=>import("./view.0dc125f4.js"),["assets/chunks/view.0dc125f4.js","assets/app.d1307649.js"]))};const ee=s({name:"sb-block",directives:{hoverCover:TA},props:{block:{type:null,required:!0},onUpdate:{type:null,default:()=>{}},onPrependBlock:{type:null,default:()=>{}},onAppendBlock:{type:null,default:()=>{}},onRemoveSelf:{type:null,default:()=>{}},onActivatePrevious:{type:null,default:()=>{}},onActivateNext:{type:null,default:()=>{}}},setup(A,e){const t=I(null),{mode:n,getBlock:g}=CA(),{isActive:B,activate:r}=iA(A.block.id),i=L(()=>({"sb-block":!0,"sb-block_active":B.value})),{triggerSizeCalculation:v}=oA(t,aA);E(()=>A.block.data,v);const{register:f}=EA();f(A.block),E(A.block,()=>{f(A.block)});const R=o=>{A.onUpdate(m(d({},A.block),{data:d(d({},A.block.data),o)}))};return()=>{var z;const o=(z=g(A.block.name))==null?void 0:z[n.value];if(!o){const q=Ae[n.value];return Q(q,{name:A.block.name,blockId:A.block.id},null)}return n.value===U.View?Q(o,{data:A.block.data,blockId:A.block.id},null):VA(Q("div",{ref:t,class:i.value},[e.slots["context-toolbar"]?e.slots["context-toolbar"]():null,Q(o,H({data:A.block.data,blockId:A.block.id,onUpdate:R,onPrependBlock:A.onPrependBlock,onAppendBlock:A.onAppendBlock,onRemoveSelf:A.onRemoveSelf,onActivatePrevious:A.onActivatePrevious,onActivateNext:A.onActivateNext},d({onClick:q=>{q.stopPropagation(),r()}},e.attrs)),null)]),[[jA("hover-cover")]])}}});const te=s({name:"sb-main",model:hA,props:{availableBlocks:{type:Array,default:()=>[]},block:{type:Object,required:!0},onUpdate:{type:null,default:()=>{}},mode:{type:String,validator(A){return Object.values(U).includes(A)},default:U.Edit}},setup(A){const e=I(null);oA(e,IA);const t=I(A.mode);l(QA,t),E(()=>A.mode,r=>{console.log("Mode update",r),t.value=r});const n=I(null);l(BA,n);const g=I(null);l(fA,g),l(S,r=>{g.value=r}),l(G,()=>{g.value=null});const B=pA(d({},A.availableBlocks.reduce((r,i)=>m(d({},r),{[i.name]:i}),{})));return l(vA,B),()=>Q("div",{class:"sb-main",ref:e},[t.value===U.Edit?Q(SA,null,[Q(YA,{block:A.block},null),Q(ZA,null,null)]):null,Q(ee,{block:A.block,onUpdate:A.onUpdate},null)])}});const ne=s({name:"sb-block-picker",props:{onPickedBlock:{type:Function,default:()=>{}}},setup(A,e){const t=I(!1),{customBlocks:n}=CA(),g=L(()=>Object.keys(n).map(r=>n[r])),B=r=>{t.value=!1,A.onPickedBlock({name:r.name,id:x(),data:r.getDefaultData()})};return()=>Q("div",{class:"sb-block-picker"},[Q(uA,{class:"sb-tree-block-select"},{context:r=>e.slots.context?e.slots.context(r):Q(w,{onClick:r.toggle},{default:()=>[D("Insert a block")]}),default:({close:r})=>g.value.map(i=>Q(w,{type:"button",onClick:()=>{B(i),r()}},{default:()=>[i.name]}))})])}});var O=typeof globalThis!="undefined"?globalThis:typeof window!="undefined"?window:typeof global!="undefined"?global:typeof self!="undefined"?self:{};function ge(A){var e=typeof A;return A!=null&&(e=="object"||e=="function")}var cA=ge,re=typeof O=="object"&&O&&O.Object===Object&&O,Qe=re,Be=Qe,ie=typeof self=="object"&&self&&self.Object===Object&&self,ve=Be||ie||Function("return this")(),dA=ve,Ce=dA,ae=function(){return Ce.Date.now()},Ie=ae,oe=/\s/;function se(A){for(var e=A.length;e--&&oe.test(A.charAt(e)););return e}var fe=se,Ee=fe,ue=/^\s+/;function ce(A){return A&&A.slice(0,Ee(A)+1).replace(ue,"")}var de=ce,le=dA,be=le.Symbol,lA=be,AA=lA,bA=Object.prototype,De=bA.hasOwnProperty,Pe=bA.toString,X=AA?AA.toStringTag:void 0;function Ue(A){var e=De.call(A,X),t=A[X];try{A[X]=void 0;var n=!0}catch{}var g=Pe.call(A);return n&&(e?A[X]=t:delete A[X]),g}var Re=Ue,qe=Object.prototype,we=qe.toString;function ze(A){return we.call(A)}var ye=ze,eA=lA,Xe=Re,Le=ye,Me="[object Null]",ke="[object Undefined]",tA=eA?eA.toStringTag:void 0;function me(A){return A==null?A===void 0?ke:Me:tA&&tA in Object(A)?Xe(A):Le(A)}var Fe=me;function Oe(A){return A!=null&&typeof A=="object"}var Ve=Oe,je=Fe,pe=Ve,Se="[object Symbol]";function Ge(A){return typeof A=="symbol"||pe(A)&&je(A)==Se}var Ke=Ge,He=de,nA=cA,xe=Ke,gA=0/0,Je=/^[-+]0x[0-9a-f]+$/i,We=/^0b[01]+$/i,he=/^0o[0-7]+$/i,Ne=parseInt;function Ye(A){if(typeof A=="number")return A;if(xe(A))return gA;if(nA(A)){var e=typeof A.valueOf=="function"?A.valueOf():A;A=nA(e)?e+"":e}if(typeof A!="string")return A===0?A:+A;A=He(A);var t=We.test(A);return t||he.test(A)?Ne(A.slice(2),t?2:8):Je.test(A)?gA:+A}var Ze=Ye,Te=cA,p=Ie,rA=Ze,_e="Expected a function",$e=Math.max,At=Math.min;function et(A,e,t){var n,g,B,r,i,v,f=0,R=!1,o=!1,z=!0;if(typeof A!="function")throw new TypeError(_e);e=rA(e)||0,Te(t)&&(R=!!t.leading,o="maxWait"in t,B=o?$e(rA(t.maxWait)||0,e):B,z="trailing"in t?!!t.trailing:z);function q(C){var b=n,y=g;return n=g=void 0,f=C,r=A.apply(y,b),r}function RA(C){return f=C,i=setTimeout(k,e),R?q(C):r}function qA(C){var b=C-v,y=C-f,N=e-b;return o?At(N,B-y):N}function W(C){var b=C-v,y=C-f;return v===void 0||b>=e||b<0||o&&y>=B}function k(){var C=p();if(W(C))return h(C);i=setTimeout(k,qA(C))}function h(C){return i=void 0,z&&n?q(C):(n=g=void 0,r)}function wA(){i!==void 0&&clearTimeout(i),f=0,n=v=g=i=void 0}function zA(){return i===void 0?r:h(p())}function V(){var C=p(),b=W(C);if(n=arguments,g=this,v=C,b){if(i===void 0)return RA(v);if(o)return clearTimeout(i),i=setTimeout(k,e),q(v)}return i===void 0&&(i=setTimeout(k,e)),r}return V.cancel=wA,V.flush=zA,V}var DA=et;const Et=s({name:"sb-block-ordering",props:{orientation:{type:String,default:null},onRemove:{type:Function,default:()=>{}},onMoveBackward:{type:Function,default:()=>{}},onMoveForward:{type:Function,default:()=>{}}},setup(A){const e=M({top:"",right:""}),t=L(()=>({"sb-block-ordering":!0,[`sb-block-ordering_${A.orientation}`]:!!A.orientation})),{editorDimensions:n,blockDimensions:g}=sA(),B=DA(()=>{if(!n.value||!g.value)return;const r=n.value.width-g.value.left;e.top=`${g.value.top}px`,e.right=`${r}px`});return E(n,B),E(g,B),E(()=>A.orientation,B),()=>Q("div",{class:t.value,style:e,onClick:r=>r.stopPropagation()},[Q(w,{onClick:A.onMoveBackward},{default:()=>[A.orientation==="vertical"?"\u2191":"\u2190"]}),Q(w,{onClick:A.onRemove},{default:()=>[D("x")]}),Q(w,{onClick:A.onMoveForward},{default:()=>[A.orientation==="vertical"?"\u2193":"\u2192"]})])}});const ut=s({name:"sb-block-placeholder",props:{onInsertBlock:{type:Function,default:()=>{}}},setup(A){return()=>Q("div",{class:"sb-block-placeholder"},[Q(ne,{onPickedBlock:e=>A.onInsertBlock(e)},null)])}});const ct=s({name:"sb-toolbar",setup(A,e){const t=M({bottom:"",left:"",maxWidth:""}),{editorDimensions:n,blockDimensions:g}=sA(),B=DA(()=>{if(!n.value||!g.value)return;const r=n.value.height-g.value.top;t.bottom=`${r}px`,t.left=`${g.value.left}px`,t.maxWidth=`${g.value.width}px`});return E(n,B),E(g,B),()=>{var r,i;return Q("div",{class:"sb-toolbar",style:t,onClick:v=>v.stopPropagation()},[(i=(r=e.slots).default)==null?void 0:i.call(r)])}}});const dt=s({name:"sb-select",inheritAttrs:!1,setup(A,e){return()=>{var t,n;return Q("div",{class:"sb-select"},[Q("select",H({class:"sb-select__input"},e.attrs),[(n=(t=e.slots).default)==null?void 0:n.call(t)])])}}}),tt=()=>({orientation:"vertical",children:[]}),nt="sb-layout";var gt={name:nt,getDefaultData:tt,edit:u(()=>c(()=>import("./edit.f8d11498.js"),["assets/chunks/edit.f8d11498.js","assets/chunks/style.b4010a05.js","assets/app.d1307649.js"])),view:u(()=>c(()=>import("./view.52355471.js"),["assets/chunks/view.52355471.js","assets/chunks/style.b4010a05.js","assets/app.d1307649.js"]))};const rt=()=>({value:"",align:"left",level:1}),Qt="sb-heading";var Bt={name:Qt,getDefaultData:rt,edit:u(()=>c(()=>import("./edit.ebdd490e.js"),["assets/chunks/edit.ebdd490e.js","assets/chunks/style.b4010a052.js","assets/app.d1307649.js"])),view:u(()=>c(()=>import("./view.28a7114a.js"),["assets/chunks/view.28a7114a.js","assets/chunks/style.b4010a052.js","assets/app.d1307649.js"]))};const PA=()=>({value:"",align:"left"}),UA="sb-paragraph";var it={name:UA,getDefaultData:PA,edit:u(()=>c(()=>import("./edit.a47862d5.js"),["assets/chunks/edit.a47862d5.js","assets/chunks/style.b4010a053.js","assets/app.d1307649.js"])),view:u(()=>c(()=>import("./view.5d50156a.js"),["assets/chunks/view.5d50156a.js","assets/chunks/style.b4010a053.js","assets/app.d1307649.js"]))};const vt=()=>({src:"",alt:"",description:{id:x(),name:UA,data:PA()}}),Ct="sb-image";var at={name:Ct,getDefaultData:vt,edit:u(()=>c(()=>import("./edit.834ae1b2.js"),["assets/chunks/edit.834ae1b2.js","assets/chunks/style.b4010a054.js","assets/app.d1307649.js"])),view:u(()=>c(()=>import("./view.403d8802.js"),["assets/chunks/view.403d8802.js","assets/chunks/style.b4010a054.js","assets/app.d1307649.js"]))},It={name:"sb-layout",id:"1590592097800",data:{orientation:"vertical",children:[{name:"sb-heading",id:"1480592112212",data:{value:"A pretty heading",align:"center",level:1}},{name:"sb-paragraph",id:"1590592112200",data:{value:"This is the first paragraph
",align:"left"}},{id:"1590592116800",name:"sb-paragraph",data:{value:"This is the second paragraph
",align:"left"}},{name:"sb-layout",id:"1590592124200",data:{orientation:"horizontal",children:[{name:"sb-image",id:"1590592127200",data:{src:"",alt:"",description:{id:"159059211",name:"sb-paragraph",data:{value:"Other Image Description",align:"center"}}}},{name:"sb-image",id:"1590592767600",data:{src:"",alt:"",description:{id:"1590592",name:"sb-paragraph",data:{value:"Image Description",align:"left"}}}}]}},{name:"sb-paragraph",id:"1590592807200",data:{value:"Centered Text
",align:"center"}}]}};var lt=s({name:"ExampleEditor",setup(){const A=I("edit"),e=M(d({},It)),t=L(()=>{switch(A.value){case"data":return Q("pre",null,[Q("code",null,[JSON.stringify(e,null,2)])]);default:return Q(te,{class:"example-editor--sb",block:e,availableBlocks:[gt,Bt,at,it],mode:A.value},null)}});return()=>Q("div",{class:"example-editor"},[Q("h2",{class:"example-editor--title"},[Q("span",null,[D("Try it yourself")]),Q("select",{class:"example-editor--mode",value:A.value,onChange:n=>{A.value=n.target.value}},[Q("option",{value:U.Edit},[D("Editor mode")]),Q("option",{value:U.View},[D("Viewer mode")]),Q("option",{value:"data"},[D("JSON Data structure")])])]),t.value])}});export{lt as E,U as S,te as a,gt as b,Bt as c,it as d,at as e,It as f,tt as g,ct as h,w as i,ee as j,Et as k,ut as l,hA as m,rt as n,dt as o,x as p,PA as q,vt as r,ft as s,iA as u}; diff --git a/docs/assets/chunks/edit.834ae1b2.js b/docs/assets/chunks/edit.834ae1b2.js new file mode 100644 index 0000000..7694684 --- /dev/null +++ b/docs/assets/chunks/edit.834ae1b2.js @@ -0,0 +1 @@ +var b=Object.defineProperty,S=Object.defineProperties;var p=Object.getOwnPropertyDescriptors;var d=Object.getOwnPropertySymbols;var I=Object.prototype.hasOwnProperty,U=Object.prototype.propertyIsEnumerable;var o=(a,t,e)=>t in a?b(a,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):a[t]=e,r=(a,t)=>{for(var e in t||(t={}))I.call(t,e)&&o(a,e,t[e]);if(d)for(var e of d(t))U.call(t,e)&&o(a,e,t[e]);return a},u=(a,t)=>S(a,p(t));import{m as k,r as w,h as y,i as f,j as D}from"./ExampleEditor.08243b7c.js";import"./style.b4010a054.js";import{e as h,l as C,r as F,w as x,f as n,d as m,F as B}from"../app.d1307649.js";var T=h({name:"sb-image-edit",model:k,props:{onUpdate:{type:null,default:()=>{}},data:{type:null,default:w}},setup(a){const t=C({src:a.data.src,alt:a.data.alt,description:a.data.description}),e=F(null);x(()=>a.data,()=>{t.src=a.data.src,t.alt=a.data.alt,t.description=a.data.description});const i=()=>{e.value&&e.value.click()},g=()=>{if(e.value&&e.value.files&&e.value.files.length){const l=new FileReader;l.addEventListener("load",()=>{var c;const s=(c=l==null?void 0:l.result)==null?void 0:c.toString();if(!s)throw new Error("Couldn't load image src");a.onUpdate({src:s,alt:a.data.alt,description:a.data.description})}),l.readAsDataURL(e.value.files[0])}},v=l=>{a.onUpdate(u(r({},a.data),{description:l}))};return()=>n("figure",{class:"sb-image"},[n(y,null,{default:()=>[t.src?n(f,{onClick:i},{default:()=>[m("Select Image")]}):null,n("input",{type:"file",ref:e,style:"display: none;",onInput:g},null)]}),t.src?n(B,null,[n("img",{src:t.src,alt:t.alt,class:"sb-image__content"},null),n(D,{block:t.description,onUpdate:l=>v(l)},null)]):n(f,{onClick:i},{default:()=>[m("Select Image")]})])}});export{T as default}; diff --git a/docs/assets/chunks/edit.a47862d5.js b/docs/assets/chunks/edit.a47862d5.js new file mode 100644 index 0000000..ce674a2 --- /dev/null +++ b/docs/assets/chunks/edit.a47862d5.js @@ -0,0 +1 @@ +import{m as x,q as g,u as N,h as S,o as B,p as T}from"./ExampleEditor.08243b7c.js";import"./style.b4010a053.js";import{e as D,l as I,r as K,h as U,w as p,j as M,f as l,d as s}from"../app.d1307649.js";var q=D({name:"sb-paragraph-edit",model:x,props:{blockId:{type:String,required:!0},data:{type:null,default:g},onUpdate:{type:null,default:()=>{}},onAppendBlock:{type:null,default:()=>{}},onRemoveSelf:{type:null,default:()=>{}},onActivateNext:{type:null,default:()=>{}},onActivatePrevious:{type:null,default:()=>{}}},setup(a){const e=I({value:a.data.value,align:a.data.align,focused:!1}),t=K(null),{isActive:c,activate:d}=N(a.blockId),i=()=>{t.value&&c.value&&t.value.focus()};U(()=>{i(),t.value&&(t.value.innerHTML=e.value)}),p(c,i),p(()=>a.data,()=>{e.value=a.data.value,e.align=a.data.align,t.value&&(t.value.innerHTML=e.value)});const h=n=>{e.value=n.target.innerHTML},y=M(()=>({"sb-paragraph":!0,"sb-paragraph_focused":e.focused,[`sb-paragraph_align-${e.align}`]:!0})),m=n=>{a.onUpdate({value:e.value,align:n.target.value})},b=()=>{e.focused=!0,d()},A=()=>{e.focused=!1,a.onUpdate({value:e.value,align:e.align})},k=n=>{if(n.key==="Enter"&&!n.shiftKey){const o=T();a.onAppendBlock({id:o,name:"sb-paragraph",data:g()}),d(o),n.preventDefault()}},w=n=>{var v;n.key==="Backspace"&&e.value===""&&a.onRemoveSelf();const o=window.getSelection(),u=o==null?void 0:o.focusNode,r=Array.from(((v=t==null?void 0:t.value)==null?void 0:v.childNodes)||[]),f=u?r.indexOf(u):-1;if(u===t.value||f===0||f===r.length-1)switch(n.key){case"ArrowDown":a.onActivateNext();break;case"ArrowUp":a.onActivatePrevious();break}};return()=>l("div",{class:y.value},[l(S,null,{default:()=>[l(B,{value:e.align,onChange:m},{default:()=>[l("option",null,[s("left")]),l("option",null,[s("center")]),l("option",null,[s("right")])]})]}),l("p",{class:"sb-paragraph__input",ref:t,contenteditable:!0,onInput:h,onFocus:b,onBlur:A,onKeydown:k,onKeyup:w},null)])}});export{q as default}; diff --git a/docs/assets/chunks/edit.ebdd490e.js b/docs/assets/chunks/edit.ebdd490e.js new file mode 100644 index 0000000..5ecc011 --- /dev/null +++ b/docs/assets/chunks/edit.ebdd490e.js @@ -0,0 +1 @@ +var I=Object.defineProperty,T=Object.defineProperties;var U=Object.getOwnPropertyDescriptors;var p=Object.getOwnPropertySymbols;var K=Object.prototype.hasOwnProperty,_=Object.prototype.propertyIsEnumerable;var y=(a,e,t)=>e in a?I(a,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):a[e]=t,d=(a,e)=>{for(var t in e||(e={}))K.call(e,t)&&y(a,t,e[t]);if(p)for(var t of p(e))_.call(e,t)&&y(a,t,e[t]);return a},s=(a,e)=>T(a,U(e));import{m as L,n as M,u as C,h as H,o as b,p as q,q as F}from"./ExampleEditor.08243b7c.js";import"./style.b4010a052.js";import{e as P,l as R,r as V,h as j,w as m,j as O,f as l,d as o}from"../app.d1307649.js";var Q=P({name:"sb-heading-edit",model:L,props:{blockId:{type:String,required:!0},data:{type:null,default:M},onUpdate:{type:null,default:()=>{}},onAppendBlock:{type:null,default:()=>{}},onRemoveSelf:{type:null,default:()=>{}},onActivateNext:{type:null,default:()=>{}},onActivatePrevious:{type:null,default:()=>{}}},setup(a){const e=R({value:a.data.value,align:a.data.align,level:a.data.level,focused:!1}),t=V(null),{isActive:c,activate:v}=C(a.blockId),f=()=>{t.value&&c.value&&t.value.focus()};j(()=>{f(),t.value&&(t.value.innerHTML=e.value)}),m(c,f),m(()=>a.data,()=>{e.value=a.data.value,e.align=a.data.align,e.level=a.data.level,t.value&&(t.value.innerHTML=e.value)});const A=n=>{e.value=n.target.innerHTML},k=O(()=>({"sb-heading":!0,"sb-heading_focused":e.focused,[`sb-heading_align-${e.align}`]:!0,[`sb-heading_${e.level}`]:!0})),w=n=>{a.onUpdate(s(d({},e),{level:parseInt(n.target.value,10)}))},x=n=>{a.onUpdate(s(d({},e),{align:n.target.value}))},D=()=>{e.focused=!0,v()},N=()=>{e.focused=!1,a.onUpdate({value:e.value,align:e.align,level:e.level})},S=n=>{if(n.key==="Enter"&&!n.shiftKey){const u=q();a.onAppendBlock({id:u,name:"sb-paragraph",data:F()}),v(u),n.preventDefault()}},B=n=>{var h;n.key==="Backspace"&&e.value===""&&a.onRemoveSelf();const u=window.getSelection(),i=u==null?void 0:u.focusNode,r=Array.from(((h=t==null?void 0:t.value)==null?void 0:h.childNodes)||[]),g=i?r.indexOf(i):-1;if(i===t.value||g===0||g===r.length-1)switch(n.key){case"ArrowDown":a.onActivateNext();break;case"ArrowUp":a.onActivatePrevious();break}};return()=>l("div",{class:k.value},[l(H,null,{default:()=>[l(b,{value:e.level,onChange:w},{default:()=>[l("option",{value:1},[o("h1")]),l("option",{value:2},[o("h2")]),l("option",{value:3},[o("h3")]),l("option",{value:4},[o("h4")]),l("option",{value:5},[o("h5")]),l("option",{value:6},[o("h6")])]}),l(b,{value:e.align,onChange:x},{default:()=>[l("option",null,[o("left")]),l("option",null,[o("center")]),l("option",null,[o("right")])]})]}),l("p",{class:"sb-heading__input",ref:t,contenteditable:!0,onInput:A,onFocus:D,onBlur:N,onKeydown:S,onKeyup:B},null)])}});export{Q as default}; diff --git a/docs/assets/chunks/edit.f8d11498.js b/docs/assets/chunks/edit.f8d11498.js new file mode 100644 index 0000000..afa075b --- /dev/null +++ b/docs/assets/chunks/edit.f8d11498.js @@ -0,0 +1 @@ +var U=Object.defineProperty;var h=Object.getOwnPropertySymbols;var g=Object.prototype.hasOwnProperty,p=Object.prototype.propertyIsEnumerable;var u=(a,l,e)=>l in a?U(a,l,{enumerable:!0,configurable:!0,writable:!0,value:e}):a[l]=e,r=(a,l)=>{for(var e in l||(l={}))g.call(l,e)&&u(a,e,l[e]);if(h)for(var e of h(l))p.call(l,e)&&u(a,e,l[e]);return a};import{m as w,g as y,u as S,h as A,i as M,j as F,k as P,l as C}from"./ExampleEditor.08243b7c.js";import"./style.b4010a05.js";import{e as D,l as I,w as O,j,f as o,F as N,q as R}from"../app.d1307649.js";var _=D({name:"sb-layout-edit",model:w,props:{onUpdate:{type:null,default:()=>{}},data:{type:null,default:y}},setup(a){const{activate:l}=S(),e=I({orientation:a.data.orientation,children:[...a.data.children]});O(()=>a.data,()=>{e.orientation=a.data.orientation,e.children=[...a.data.children]});const m=j(()=>({"sb-layout":!0,[`sb-layout_${e.orientation}`]:!0})),v=()=>{a.onUpdate({orientation:e.orientation==="vertical"?"horizontal":"vertical"})},f=(t,n)=>{const c=e.children.indexOf(t);c!==-1&&a.onUpdate({children:[...e.children.slice(0,c),r(r({},t),n),...e.children.slice(c+1)]})},k=t=>{e.children=[...e.children,t],a.onUpdate({children:[...e.children]}),l(t.id)},i=(t,n)=>{e.children=[...e.children.slice(0,t+1),n,...e.children.slice(t+1)],a.onUpdate({children:[...e.children]}),l(n.id)},d=t=>{e.children=[...e.children.slice(0,t),...e.children.slice(t+1)],a.onUpdate({children:[...e.children]});const n=Math.max(t-1,0);l(e.children[n].id)},s=t=>{const n=Math.max(Math.min(e.children.length-1,t),0);l(e.children[n].id)},B=t=>{if(t===0)return;const n=e.children[t],c=e.children[t-1];e.children=[...e.children.slice(0,t-1),n,c,...e.children.slice(t+1)],a.onUpdate({children:[...e.children]})},b=t=>{if(t===e.children.length-1)return;const n=e.children[t],c=e.children[t+1];e.children=[...e.children.slice(0,t),c,n,...e.children.slice(t+2)],a.onUpdate({children:[...e.children]})};return()=>o("div",{class:m.value},[o(A,null,{default:()=>[o(M,{type:"button",onClick:v},{default:()=>[e.orientation]})]}),o(N,null,[...e.children.map((t,n)=>o(F,R({key:t.id},{"data-order":n,block:t,onUpdate:c=>f(t,c),onRemoveSelf:()=>d(n),onPrependBlock:c=>i(n-1,c),onAppendBlock:c=>i(n,c),onActivatePrevious:()=>s(n-1),onActivateNext:()=>s(n+1)}),{"context-toolbar":()=>o(P,{onMoveBackward:()=>B(n),onMoveForward:()=>b(n),onRemove:()=>d(n),orientation:e.orientation},null)}))]),o(C,{onInsertBlock:k},null)])}});export{_ as default}; diff --git a/docs/assets/chunks/view.0dc125f4.js b/docs/assets/chunks/view.0dc125f4.js new file mode 100644 index 0000000..6a701d0 --- /dev/null +++ b/docs/assets/chunks/view.0dc125f4.js @@ -0,0 +1 @@ +var i=Object.defineProperty,p=Object.defineProperties;var d=Object.getOwnPropertyDescriptors;var a=Object.getOwnPropertySymbols;var r=Object.prototype.hasOwnProperty,m=Object.prototype.propertyIsEnumerable;var o=(t,e,n)=>e in t?i(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n,s=(t,e)=>{for(var n in e||(e={}))r.call(e,n)&&o(t,n,e[n]);if(a)for(var n of a(e))m.call(e,n)&&o(t,n,e[n]);return t},l=(t,e)=>p(t,d(e));import{m as c,s as u}from"./ExampleEditor.08243b7c.js";import{e as f,f as v,d as b}from"../app.d1307649.js";var F=f({name:"sb-missing-block",model:c,props:l(s({},u),{name:String,data:{type:null,default:null},eventUpdate:{type:Function,default:()=>{}},eventAppendBlock:{type:Function,default:()=>{}},eventRemoveBlock:{type:Function,default:()=>{}}}),setup(t){return()=>v("div",{class:"sb-missing-block"},[b("Missing block: "),t.name])}});export{F as default}; diff --git a/docs/assets/chunks/view.28a7114a.js b/docs/assets/chunks/view.28a7114a.js new file mode 100644 index 0000000..97515da --- /dev/null +++ b/docs/assets/chunks/view.28a7114a.js @@ -0,0 +1 @@ +import{m as t,n as s}from"./ExampleEditor.08243b7c.js";import"./style.b4010a052.js";import{e as d,j as l,z as n}from"../app.d1307649.js";var m=d({name:"sb-heading-display",model:t,props:{data:{type:Object,default:s}},setup(a){const e=l(()=>({"sb-heading":!0,[`sb-heading_align-${a.data.align}`]:!0,[`sb-heading_${a.data.level}`]:!0}));return()=>n(`h${a.data.level}`,{class:e.value,innerHTML:a.data.value})}});export{m as default}; diff --git a/docs/assets/chunks/view.403d8802.js b/docs/assets/chunks/view.403d8802.js new file mode 100644 index 0000000..8eccb44 --- /dev/null +++ b/docs/assets/chunks/view.403d8802.js @@ -0,0 +1 @@ +import{m as t,r as l,j as s}from"./ExampleEditor.08243b7c.js";import"./style.b4010a054.js";import{e as r,f as e}from"../app.d1307649.js";var d=r({name:"sb-image-display",model:t,props:{data:{type:null,default:l}},setup(a){return()=>e("figure",{class:"sb-image"},[e("img",{class:"sb-image__content",src:a.data.src,alt:a.data.alt},null),e(s,{block:a.data.description},null)])}});export{d as default}; diff --git a/docs/assets/chunks/view.52355471.js b/docs/assets/chunks/view.52355471.js new file mode 100644 index 0000000..1ed601f --- /dev/null +++ b/docs/assets/chunks/view.52355471.js @@ -0,0 +1 @@ +import{m as s,g as l,j as r}from"./ExampleEditor.08243b7c.js";import"./style.b4010a05.js";import{e as u,j as d,f as t}from"../app.d1307649.js";var p=u({name:"sb-layout-display",model:s,props:{data:{type:null,default:l}},setup(a){const o=d(()=>({"sb-layout":!0,[`sb-layout_${a.data.orientation}`]:!0}));return()=>t("div",{class:o.value},[...a.data.children.map(e=>t(r,{key:e.id,block:e},null))])}});export{p as default}; diff --git a/docs/assets/chunks/view.5d50156a.js b/docs/assets/chunks/view.5d50156a.js new file mode 100644 index 0000000..7083534 --- /dev/null +++ b/docs/assets/chunks/view.5d50156a.js @@ -0,0 +1 @@ +import{m as t,q as r}from"./ExampleEditor.08243b7c.js";import"./style.b4010a053.js";import{e as s,j as p,f as l,q as o}from"../app.d1307649.js";var d=s({name:"sb-paragraph-display",model:t,props:{data:{type:Object,default:r}},setup(a){const e=p(()=>({"sb-paragraph":!0,[`sb-paragraph_align-${a.data.align}`]:!0}));return()=>l("p",o({class:e.value},{innerHTML:a.data.value}),null)}});export{d as default}; diff --git a/docs/assets/guide_examples.md.f568382d.js b/docs/assets/guide_examples.md.f568382d.js new file mode 100644 index 0000000..f44ad4d --- /dev/null +++ b/docs/assets/guide_examples.md.f568382d.js @@ -0,0 +1 @@ +var _=Object.defineProperty;var u=Object.getOwnPropertySymbols;var f=Object.prototype.hasOwnProperty,S=Object.prototype.propertyIsEnumerable;var p=(a,e,t)=>e in a?_(a,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):a[e]=t,l=(a,e)=>{for(var t in e||(e={}))f.call(e,t)&&p(a,t,e[t]);if(u)for(var t of u(e))S.call(e,t)&&p(a,t,e[t]);return a};import{S as d,a as x,b as k,c as y,d as E,e as B,f as w,E as M}from"./chunks/ExampleEditor.08243b7c.js";import{r as h,e as b,f as r,d as s,g as V,h as A,c as W,u as m,b as n,o as j}from"./app.d1307649.js";function C(){const a=h(null),e=h(d.View);return{SchlechtenburgWrapper:b({name:"SchlechtenburgWrapper",props:{availableBlocks:{type:Array,default:()=>[]},block:{type:Object,required:!0},onUpdate:{type:null,default:()=>{}},mode:{type:String,validator(o){return Object.values(d).includes(o)},default:d.Edit}},setup(o){return a.value=l({},o.block),e.value=o.mode,a.value?()=>r(x,{block:a.value,availableBlocks:o.availableBlocks,mode:e.value,onUpdate:c=>{a.value=l({},c)}},null):()=>r("div",{class:"sb-message sb-message_error"},[s("An Error occurred")])}}),getBlock(){return a.value},setBlock(o){a.value=l({},o)},getMode(){return e.value},setMode(o){e.value=o}}}const N=async(a,e)=>{const{SchlechtenburgWrapper:t,getBlock:o,setBlock:c,getMode:v,setMode:g}=C(),i=V(t,l({},e));return i.mount(a),{app:i,getBlock:o,setBlock:c,getMode:v,setMode:g}};var O=b({name:"ExampleStandaloneEditor",setup(){const a=w;return A(async()=>{await N("#example-editor",{block:a,mode:d.Edit,availableBlocks:[k,y,E,B],onUpdate:e=>{console.log("got update",e)}})}),()=>r("div",{id:"example-editor"},null)}});const U=n("h1",{id:"examples",tabindex:"-1"},[s("Examples "),n("a",{class:"header-anchor",href:"#examples","aria-hidden":"true"},"#")],-1),D=n("h2",{id:"as-a-view-component",tabindex:"-1"},[s("As a View Component "),n("a",{class:"header-anchor",href:"#as-a-view-component","aria-hidden":"true"},"#")],-1),P=n("p",null,"This documentation website already uses Vue under the hood, so Schlechtenburg can just imported as any other component:",-1),T=n("h2",{id:"standalone",tabindex:"-1"},[s("Standalone "),n("a",{class:"header-anchor",href:"#standalone","aria-hidden":"true"},"#")],-1),q=n("p",null,[n("code",null,"@schlechtenburg/standalone"),s(" gives you a wrapped version of the editor in case you don't have Vue already installed in your application")],-1),F='{"title":"Examples","description":"","frontmatter":{},"headers":[{"level":2,"title":"As a View Component","slug":"as-a-view-component"},{"level":2,"title":"Standalone","slug":"standalone"}],"relativePath":"guide/examples.md"}',H={},G=Object.assign(H,{setup(a){return(e,t)=>(j(),W("div",null,[U,D,P,r(m(M)),T,q,r(m(O))]))}});export{F as __pageData,G as default}; diff --git a/docs/assets/guide_examples.md.f568382d.lean.js b/docs/assets/guide_examples.md.f568382d.lean.js new file mode 100644 index 0000000..f44ad4d --- /dev/null +++ b/docs/assets/guide_examples.md.f568382d.lean.js @@ -0,0 +1 @@ +var _=Object.defineProperty;var u=Object.getOwnPropertySymbols;var f=Object.prototype.hasOwnProperty,S=Object.prototype.propertyIsEnumerable;var p=(a,e,t)=>e in a?_(a,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):a[e]=t,l=(a,e)=>{for(var t in e||(e={}))f.call(e,t)&&p(a,t,e[t]);if(u)for(var t of u(e))S.call(e,t)&&p(a,t,e[t]);return a};import{S as d,a as x,b as k,c as y,d as E,e as B,f as w,E as M}from"./chunks/ExampleEditor.08243b7c.js";import{r as h,e as b,f as r,d as s,g as V,h as A,c as W,u as m,b as n,o as j}from"./app.d1307649.js";function C(){const a=h(null),e=h(d.View);return{SchlechtenburgWrapper:b({name:"SchlechtenburgWrapper",props:{availableBlocks:{type:Array,default:()=>[]},block:{type:Object,required:!0},onUpdate:{type:null,default:()=>{}},mode:{type:String,validator(o){return Object.values(d).includes(o)},default:d.Edit}},setup(o){return a.value=l({},o.block),e.value=o.mode,a.value?()=>r(x,{block:a.value,availableBlocks:o.availableBlocks,mode:e.value,onUpdate:c=>{a.value=l({},c)}},null):()=>r("div",{class:"sb-message sb-message_error"},[s("An Error occurred")])}}),getBlock(){return a.value},setBlock(o){a.value=l({},o)},getMode(){return e.value},setMode(o){e.value=o}}}const N=async(a,e)=>{const{SchlechtenburgWrapper:t,getBlock:o,setBlock:c,getMode:v,setMode:g}=C(),i=V(t,l({},e));return i.mount(a),{app:i,getBlock:o,setBlock:c,getMode:v,setMode:g}};var O=b({name:"ExampleStandaloneEditor",setup(){const a=w;return A(async()=>{await N("#example-editor",{block:a,mode:d.Edit,availableBlocks:[k,y,E,B],onUpdate:e=>{console.log("got update",e)}})}),()=>r("div",{id:"example-editor"},null)}});const U=n("h1",{id:"examples",tabindex:"-1"},[s("Examples "),n("a",{class:"header-anchor",href:"#examples","aria-hidden":"true"},"#")],-1),D=n("h2",{id:"as-a-view-component",tabindex:"-1"},[s("As a View Component "),n("a",{class:"header-anchor",href:"#as-a-view-component","aria-hidden":"true"},"#")],-1),P=n("p",null,"This documentation website already uses Vue under the hood, so Schlechtenburg can just imported as any other component:",-1),T=n("h2",{id:"standalone",tabindex:"-1"},[s("Standalone "),n("a",{class:"header-anchor",href:"#standalone","aria-hidden":"true"},"#")],-1),q=n("p",null,[n("code",null,"@schlechtenburg/standalone"),s(" gives you a wrapped version of the editor in case you don't have Vue already installed in your application")],-1),F='{"title":"Examples","description":"","frontmatter":{},"headers":[{"level":2,"title":"As a View Component","slug":"as-a-view-component"},{"level":2,"title":"Standalone","slug":"standalone"}],"relativePath":"guide/examples.md"}',H={},G=Object.assign(H,{setup(a){return(e,t)=>(j(),W("div",null,[U,D,P,r(m(M)),T,q,r(m(O))]))}});export{F as __pageData,G as default}; diff --git a/docs/assets/guide_installation.md.491f5af1.js b/docs/assets/guide_installation.md.491f5af1.js new file mode 100644 index 0000000..5b477c3 --- /dev/null +++ b/docs/assets/guide_installation.md.491f5af1.js @@ -0,0 +1,77 @@ +import{_ as n,c as a,o as s,a as t}from"./app.d1307649.js";const g=`{"title":"Installation","description":"","frontmatter":{},"headers":[{"level":2,"title":"You're not yet using Vue","slug":"you-re-not-yet-using-vue"},{"level":3,"title":"Install npm packages","slug":"install-npm-packages"},{"level":3,"title":"Initializing the editor","slug":"initializing-the-editor"},{"level":2,"title":"You're already using Vue","slug":"you-re-already-using-vue"},{"level":3,"title":"Install npm packages","slug":"install-npm-packages-1"},{"level":3,"title":"Using the editor component","slug":"using-the-editor-component"}],"relativePath":"guide/installation.md"}`,e={},o=t(`

Installation

Schlechtenburg is very modular; consisting of one core package and multiple blocks. All packages are versioned together, meaning that v2.0.3 of one package is guaranteed to work with v2.0.3 of another schlechtenburg package.

Schlechtenburg is basically one Vue component, so if you're already using Vue you can import and use it directly. Otherwise, there's the standalone version that comes prepackaged with Vue.

You're not yet using Vue

Install npm packages

Install the standalone editor and any blocks you want to use:

npm i --save @schlechtenburg/standalone \\
+  @schlechtenburg/layout \\
+  @schlechtenburg/heading \\
+  @schlechtenburg/paragraph
+

Initializing the editor

// Import the initialization function
+import { startSchlechtenburg } from '@schlechtenburg/standalone';
+import { SbMode } from '@schlechtenburg/core';
+
+// The following are some Schlechtenburg blocks that
+// will be available when editing or viewing
+import {
+  SbLayout,
+  getDefaultData as getEmptyLayoutBlock,
+} from '@schlechtenburg/layout';
+import { SbHeading } from '@schlechtenburg/heading';
+import { SbParagraph } from '@schlechtenburg/paragraph';
+import { SbImage } from '@schlechtenburg/image';
+
+// This will be our input state
+const emptyLayout = getEmptyLayoutBlock();
+
+// This call initializes the Schlechtenburg editor and viewer.
+useSchlechtenburg(
+  // Selector of the element the editor should bind to.
+  // Can also the an \`HTMLElement\` reference.
+  '#editor', 
+  {
+    // The input block data
+    block: emptyLayout,
+
+    // Whether Schlechtenburg is in what-you-see (editing)
+    // or in what-you-get (viewing)
+    mode: SbMode.Edit,
+
+    // The list of available blocks in this editor instance
+    availableBlocks: [
+      SbLayout,
+      SbHeading,
+      SbParagraph,
+      SbImage,
+    ],
+
+    // This callback will be alled any time the block data gets updated
+    onUpdate: (blockData) => {
+      console.log('Got new block data', blockData);
+
+    }
+  }, // 
+)
+
+

Note: You need to provide both a root node

You're already using Vue

Install npm packages

Install the editor core and any blocks you want to use:

npm i --save @schlechtenburg/core \\
+  @schlechtenburg/layout \\
+  @schlechtenburg/heading \\
+  @schlechtenburg/paragraph
+

Using the editor component

The following example uses TSX, but SbMain is just a Vue component here and can be imported and used just like any other vue component.

You need to provide a root

// This is the main Schlechtenburg component
+import { SbMain } from '@schlechtenburg/core';
+
+// The following are some Schlechtenburg blocks that will be available when editing or viewing
+import { SbLayout } from '@schlechtenburg/layout';
+import { SbHeading } from '@schlechtenburg/heading';
+import { SbParagraph } from '@schlechtenburg/paragraph';
+import { SbImage } from '@schlechtenburg/image';
+
+// In your component
+setup () {
+  // ..
+
+  return () => <SbMain
+    availableBlocks={[
+      SbLayout,
+      SbHeading,
+      SbParagraph,
+      SbImage,
+    ]}
+  />;
+}
+
`,18),p=[o];function c(l,i,u,r,k,h){return s(),a("div",null,p)}var m=n(e,[["render",c]]);export{g as __pageData,m as default}; diff --git a/docs/assets/guide_installation.md.491f5af1.lean.js b/docs/assets/guide_installation.md.491f5af1.lean.js new file mode 100644 index 0000000..48c8db6 --- /dev/null +++ b/docs/assets/guide_installation.md.491f5af1.lean.js @@ -0,0 +1 @@ +import{_ as n,c as a,o as s,a as t}from"./app.d1307649.js";const g=`{"title":"Installation","description":"","frontmatter":{},"headers":[{"level":2,"title":"You're not yet using Vue","slug":"you-re-not-yet-using-vue"},{"level":3,"title":"Install npm packages","slug":"install-npm-packages"},{"level":3,"title":"Initializing the editor","slug":"initializing-the-editor"},{"level":2,"title":"You're already using Vue","slug":"you-re-already-using-vue"},{"level":3,"title":"Install npm packages","slug":"install-npm-packages-1"},{"level":3,"title":"Using the editor component","slug":"using-the-editor-component"}],"relativePath":"guide/installation.md"}`,e={},o=t("",18),p=[o];function c(l,i,u,r,k,h){return s(),a("div",null,p)}var m=n(e,[["render",c]]);export{g as __pageData,m as default}; diff --git a/docs/assets/guide_why.md.1cac0594.js b/docs/assets/guide_why.md.1cac0594.js new file mode 100644 index 0000000..e0dbaa0 --- /dev/null +++ b/docs/assets/guide_why.md.1cac0594.js @@ -0,0 +1,9 @@ +import{_ as e,c as t,o as a,a as i}from"./app.d1307649.js";const p='{"title":"Why Schlechtenburg?","description":"","frontmatter":{},"headers":[{"level":2,"title":"Block based","slug":"block-based"},{"level":2,"title":"Design system with standardized components","slug":"design-system-with-standardized-components"},{"level":2,"title":"Accessible","slug":"accessible"},{"level":2,"title":"JSON only","slug":"json-only"},{"level":2,"title":"So why not Gutenberg?","slug":"so-why-not-gutenberg"}],"relativePath":"guide/why.md"}',n={},o=i(`

Why Schlechtenburg?

Installing a WYSIWYG editor in your application or on your website is often the easy part. The hard part comes afterwards: extending and customizing the editor to fit your specific needs. There are currently a couple of very good editors, but after reading this text I think you'll agree there's still room for improvement. We'll be looking at the following alternative WYSIWYG editors:

Block based

Though all three are meant for text editing, Quill and CKEditor are a bit more explicit about this in their architecture:

  • They input and output a string
  • They have one global toolbar

Gutenberg is a bit more involved, literally using building "blocks" to create it's editor. Instead of seeing the content as a long string it takes a more component-esque approach. For example, the following things are all their own blocks in the gutenberg editor, which a specific react component that handles the editing mode, and one that handles the display mode.

  • Paragraph
  • Heading
  • List
  • Image
  • Column-based layout
  • External media embeds like YouTube videos

When editing, you are editing, adding or removing one specific block at a time. Blocks can contain other blocks in a tree structure, and they all have their own (but uniform) editing UI.

Schlechtenburg takes a block based approach, just like its namesake Gutenberg. This has a couple of advantages:

  • You can take strong control over the final rendered HTML of a block that you create
  • Blocks are easily published as reusable JS modules
  • You very rarely need blocks inside text, but the reverse has abundant usecases
  • The mental model is closer to how actual HTML works
  • Very complex pages can be handled by the editor
  • If you know React or Vue, you understand a lot about how to write blocks for the editor

Design system with standardized components

Making sure the final rendered data looks correct is always easier than making sure the editing experience is great. Schlechtenburg aims to offer a vast library of reusable components, patterns, variables, and rules for the editing UI. We call this SBUI. Complex blocks require complex editing forms and UIs so most of the work goes into creating this UI. A good Design System should help ease the pain.

Accessible

Toolbars and editing elements are in the correct tab order, SBUI elements are all fully accessible.

JSON only

Input and Output is one standardized, typed, JSON-stringifyable object. For example, a paragraph looks like this:

{
+  id: '1590592116800',
+  name: 'sb-paragraph',
+  data: {
+    value: 'This is the second paragraph<br>',
+    align: 'left'
+  }
+},
+

The main advantage here is that it enables you to write your own tooling around the format, since you don't have to deal with HTML or the DOM directly. This also enables really easy subtree rendering, by just taking that subtree of the JSON and feeding it to a Schlechtenburg instance. if instead of rendering a full page you'd only want to render the images, you could find all of the sb-image nodes in the tree and rendering them all inside an sb-layout block.

So why not Gutenberg?

Gutenberg is tied heavily into the Wordpress ecosystem, making its inclusion in other sites harder than necessary.

`,21),r=[o];function s(l,d,h,c,u,g){return a(),t("div",null,r)}var m=e(n,[["render",s]]);export{p as __pageData,m as default}; diff --git a/docs/assets/guide_why.md.1cac0594.lean.js b/docs/assets/guide_why.md.1cac0594.lean.js new file mode 100644 index 0000000..e74ba04 --- /dev/null +++ b/docs/assets/guide_why.md.1cac0594.lean.js @@ -0,0 +1 @@ +import{_ as e,c as t,o as a,a as i}from"./app.d1307649.js";const p='{"title":"Why Schlechtenburg?","description":"","frontmatter":{},"headers":[{"level":2,"title":"Block based","slug":"block-based"},{"level":2,"title":"Design system with standardized components","slug":"design-system-with-standardized-components"},{"level":2,"title":"Accessible","slug":"accessible"},{"level":2,"title":"JSON only","slug":"json-only"},{"level":2,"title":"So why not Gutenberg?","slug":"so-why-not-gutenberg"}],"relativePath":"guide/why.md"}',n={},o=i("",21),r=[o];function s(l,d,h,c,u,g){return a(),t("div",null,r)}var m=e(n,[["render",s]]);export{p as __pageData,m as default}; diff --git a/docs/assets/index.md.3edeae7e.js b/docs/assets/index.md.3edeae7e.js new file mode 100644 index 0000000..b4175c1 --- /dev/null +++ b/docs/assets/index.md.3edeae7e.js @@ -0,0 +1 @@ +import{c as a,b as e,u as t,y as o,f as s,d as r,o as i}from"./app.d1307649.js";import{E as n}from"./chunks/ExampleEditor.08243b7c.js";const c=e("h1",{id:"yet-another-wysiwyg-editor",tabindex:"-1"},[r("Yet another WYSIWYG editor "),e("a",{class:"header-anchor",href:"#yet-another-wysiwyg-editor","aria-hidden":"true"},"#")],-1),d=e("p",null,"Schlechtenburg is an experimental WYSIWYG editor framework made with Vue 3 and TypeScript. It takes cues from both Wordpress' Gutenberg editor and CKEditor, though it tries to become a best of both worlds; a very lightweight, easily extensible core, written with modern components and the accompanying state management.",-1),h=e("p",null,"It inputs and outputs a tree of JSON-serializable data.",-1),l=e("p",null,"This is still in the Proof-of-concept phase.",-1),_={class:"cta-row"},u=["href"],p=["href"],f=["href"],x='{"title":"Yet another WYSIWYG editor","description":"","frontmatter":{},"headers":[],"relativePath":"index.md"}',m={},W=Object.assign(m,{setup(b){return(g,w)=>(i(),a("div",null,[c,d,h,l,e("div",_,[e("a",{href:t(o)("/guide/why"),class:"button button_cta"},"Why Schlechtenburg?",8,u),e("a",{href:t(o)("guide/introduction"),class:"button"},"Get Started",8,p),e("a",{href:t(o)("api"),class:"button"},"See the API docs",8,f)]),s(t(n))]))}});export{x as __pageData,W as default}; diff --git a/docs/assets/index.md.3edeae7e.lean.js b/docs/assets/index.md.3edeae7e.lean.js new file mode 100644 index 0000000..b4175c1 --- /dev/null +++ b/docs/assets/index.md.3edeae7e.lean.js @@ -0,0 +1 @@ +import{c as a,b as e,u as t,y as o,f as s,d as r,o as i}from"./app.d1307649.js";import{E as n}from"./chunks/ExampleEditor.08243b7c.js";const c=e("h1",{id:"yet-another-wysiwyg-editor",tabindex:"-1"},[r("Yet another WYSIWYG editor "),e("a",{class:"header-anchor",href:"#yet-another-wysiwyg-editor","aria-hidden":"true"},"#")],-1),d=e("p",null,"Schlechtenburg is an experimental WYSIWYG editor framework made with Vue 3 and TypeScript. It takes cues from both Wordpress' Gutenberg editor and CKEditor, though it tries to become a best of both worlds; a very lightweight, easily extensible core, written with modern components and the accompanying state management.",-1),h=e("p",null,"It inputs and outputs a tree of JSON-serializable data.",-1),l=e("p",null,"This is still in the Proof-of-concept phase.",-1),_={class:"cta-row"},u=["href"],p=["href"],f=["href"],x='{"title":"Yet another WYSIWYG editor","description":"","frontmatter":{},"headers":[],"relativePath":"index.md"}',m={},W=Object.assign(m,{setup(b){return(g,w)=>(i(),a("div",null,[c,d,h,l,e("div",_,[e("a",{href:t(o)("/guide/why"),class:"button button_cta"},"Why Schlechtenburg?",8,u),e("a",{href:t(o)("guide/introduction"),class:"button"},"Get Started",8,p),e("a",{href:t(o)("api"),class:"button"},"See the API docs",8,f)]),s(t(n))]))}});export{x as __pageData,W as default}; diff --git a/docs/guide/examples.html b/docs/guide/examples.html new file mode 100644 index 0000000..2ca30ac --- /dev/null +++ b/docs/guide/examples.html @@ -0,0 +1,22 @@ + + + + + + Examples | Schlechtenburg + + + + + + + + + + +

Examples

As a View Component

This documentation website already uses Vue under the hood, so Schlechtenburg can just imported as any other component:

Try it yourself

Standalone

@schlechtenburg/standalone gives you a wrapped version of the editor in case you don't have Vue already installed in your application

+ + + + + \ No newline at end of file diff --git a/docs/guide/installation.html b/docs/guide/installation.html index 27112e8..a55db16 100644 --- a/docs/guide/installation.html +++ b/docs/guide/installation.html @@ -6,20 +6,92 @@ Installation | Schlechtenburg - - + + -

Installation

First, install the editor core and any blocks you want to use:

npm i --save @schlechtenburg/core \
+    

Installation

Schlechtenburg is very modular; consisting of one core package and multiple blocks. All packages are versioned together, meaning that v2.0.3 of one package is guaranteed to work with v2.0.3 of another schlechtenburg package.

Schlechtenburg is basically one Vue component, so if you're already using Vue you can import and use it directly. Otherwise, there's the standalone version that comes prepackaged with Vue.

You're not yet using Vue

Install npm packages

Install the standalone editor and any blocks you want to use:

npm i --save @schlechtenburg/standalone \
+  @schlechtenburg/layout \
+  @schlechtenburg/heading \
+  @schlechtenburg/paragraph
+

Initializing the editor

// Import the initialization function
+import { startSchlechtenburg } from '@schlechtenburg/standalone';
+import { SbMode } from '@schlechtenburg/core';
+
+// The following are some Schlechtenburg blocks that
+// will be available when editing or viewing
+import {
+  SbLayout,
+  getDefaultData as getEmptyLayoutBlock,
+} from '@schlechtenburg/layout';
+import { SbHeading } from '@schlechtenburg/heading';
+import { SbParagraph } from '@schlechtenburg/paragraph';
+import { SbImage } from '@schlechtenburg/image';
+
+// This will be our input state
+const emptyLayout = getEmptyLayoutBlock();
+
+// This call initializes the Schlechtenburg editor and viewer.
+useSchlechtenburg(
+  // Selector of the element the editor should bind to.
+  // Can also the an `HTMLElement` reference.
+  '#editor', 
+  {
+    // The input block data
+    block: emptyLayout,
+
+    // Whether Schlechtenburg is in what-you-see (editing)
+    // or in what-you-get (viewing)
+    mode: SbMode.Edit,
+
+    // The list of available blocks in this editor instance
+    availableBlocks: [
+      SbLayout,
+      SbHeading,
+      SbParagraph,
+      SbImage,
+    ],
+
+    // This callback will be alled any time the block data gets updated
+    onUpdate: (blockData) => {
+      console.log('Got new block data', blockData);
+
+    }
+  }, // 
+)
+
+

Note: You need to provide both a root node

You're already using Vue

Install npm packages

Install the editor core and any blocks you want to use:

npm i --save @schlechtenburg/core \
   @schlechtenburg/layout \
   @schlechtenburg/heading \
   @schlechtenburg/paragraph
-
- - +

Using the editor component

The following example uses TSX, but SbMain is just a Vue component here and can be imported and used just like any other vue component.

You need to provide a root

// This is the main Schlechtenburg component
+import { SbMain } from '@schlechtenburg/core';
+
+// The following are some Schlechtenburg blocks that will be available when editing or viewing
+import { SbLayout } from '@schlechtenburg/layout';
+import { SbHeading } from '@schlechtenburg/heading';
+import { SbParagraph } from '@schlechtenburg/paragraph';
+import { SbImage } from '@schlechtenburg/image';
+
+// In your component
+setup () {
+  // ..
+
+  return () => <SbMain
+    availableBlocks={[
+      SbLayout,
+      SbHeading,
+      SbParagraph,
+      SbImage,
+    ]}
+  />;
+}
+
+ + \ No newline at end of file diff --git a/docs/guide/why.html b/docs/guide/why.html index 1e6465b..18a277b 100644 --- a/docs/guide/why.html +++ b/docs/guide/why.html @@ -6,14 +6,14 @@ Why Schlechtenburg? | Schlechtenburg - - + + -

Why Schlechtenburg?

Installing a WYSIWYG editor in your application or on your website is often the easy part. The hard part comes afterwards: extending and customizing the editor to fit your specific needs. There are currently a couple of very good editors, but after reading this text I think you'll agree there's still room for improvement. We'll be looking at the following alternative WYSIWYG editors:

Block based

Though all three are meant for text editing, Quill and CKEditor are a bit more explicit about this in their architecture:

  • They input and output a string
  • They have one global toolbar

Gutenberg is a bit more involved, literally using building "blocks" to create it's editor. Instead of seeing the content as a long string it takes a more component-esque approach. For example, the following things are all their own blocks in the gutenberg editor, which a specific react component that handles the editing mode, and one that handles the display mode.

  • Paragraph
  • Heading
  • List
  • Image
  • Column-based layout
  • External media embeds like YouTube videos

When editing, you are editing, adding or removing one specific block at a time. Blocks can contain other blocks in a tree structure, and they all have their own (but uniform) editing UI.

Schlechtenburg takes a block based approach, just like its namesake Gutenberg. This has a couple of advantages:

  • You can take strong control over the final rendered HTML of a block that you create
  • Blocks are easily published as reusable JS modules
  • You very rarely need blocks inside text, but the reverse has abundant usecases
  • The mental model is closer to how actual HTML works
  • Very complex pages can be handled by the editor
  • If you know React or Vue, you understand a lot about how to write blocks for the editor

Design system with standardized components

Making sure the final rendered data looks correct is always easier than making sure the editing experience is great. Schlechtenburg aims to offer a vast library of reusable components, patterns, variables, and rules for the editing UI. We call this SBUI. Complex blocks require complex editing forms and UIs so most of the work goes into creating this UI. A good Design System should help ease the pain.

SSR Compatible

Does as it says; drop Schlechtenburg into Nuxt.js, and not just the display mode but also the editor itself will render on the server.

Accessible

Toolbars and editing elements are in the correct tab order, SBUI elements are all fully accessible.

JSON only

Input and Output is one standardized, typed, JSON-stringifyable object. For example, a paragraph looks like this:

{
+    

Why Schlechtenburg?

Installing a WYSIWYG editor in your application or on your website is often the easy part. The hard part comes afterwards: extending and customizing the editor to fit your specific needs. There are currently a couple of very good editors, but after reading this text I think you'll agree there's still room for improvement. We'll be looking at the following alternative WYSIWYG editors:

Block based

Though all three are meant for text editing, Quill and CKEditor are a bit more explicit about this in their architecture:

  • They input and output a string
  • They have one global toolbar

Gutenberg is a bit more involved, literally using building "blocks" to create it's editor. Instead of seeing the content as a long string it takes a more component-esque approach. For example, the following things are all their own blocks in the gutenberg editor, which a specific react component that handles the editing mode, and one that handles the display mode.

  • Paragraph
  • Heading
  • List
  • Image
  • Column-based layout
  • External media embeds like YouTube videos

When editing, you are editing, adding or removing one specific block at a time. Blocks can contain other blocks in a tree structure, and they all have their own (but uniform) editing UI.

Schlechtenburg takes a block based approach, just like its namesake Gutenberg. This has a couple of advantages:

  • You can take strong control over the final rendered HTML of a block that you create
  • Blocks are easily published as reusable JS modules
  • You very rarely need blocks inside text, but the reverse has abundant usecases
  • The mental model is closer to how actual HTML works
  • Very complex pages can be handled by the editor
  • If you know React or Vue, you understand a lot about how to write blocks for the editor

Design system with standardized components

Making sure the final rendered data looks correct is always easier than making sure the editing experience is great. Schlechtenburg aims to offer a vast library of reusable components, patterns, variables, and rules for the editing UI. We call this SBUI. Complex blocks require complex editing forms and UIs so most of the work goes into creating this UI. A good Design System should help ease the pain.

Accessible

Toolbars and editing elements are in the correct tab order, SBUI elements are all fully accessible.

JSON only

Input and Output is one standardized, typed, JSON-stringifyable object. For example, a paragraph looks like this:

{
   id: '1590592116800',
   name: 'sb-paragraph',
   data: {
@@ -21,9 +21,9 @@
     align: 'left'
   }
 },
-

So why not Gutenberg?

Gutenberg is tied heavily into the Wordpress ecosystem, making its inclusion in other sites harder than necessary.

- - +

The main advantage here is that it enables you to write your own tooling around the format, since you don't have to deal with HTML or the DOM directly. This also enables really easy subtree rendering, by just taking that subtree of the JSON and feeding it to a Schlechtenburg instance. if instead of rendering a full page you'd only want to render the images, you could find all of the sb-image nodes in the tree and rendering them all inside an sb-layout block.

So why not Gutenberg?

Gutenberg is tied heavily into the Wordpress ecosystem, making its inclusion in other sites harder than necessary.

+ + \ No newline at end of file diff --git a/docs/hashmap.json b/docs/hashmap.json index 2d771cf..88a2715 100644 --- a/docs/hashmap.json +++ b/docs/hashmap.json @@ -1 +1 @@ -{"guide_installation.md":"3b18651b","guide_introduction.md":"18452135","guide_why.md":"372a6093","index.md":"f2252493"} +{"api_@schlechtenburg_core.md":"4063a713","api_@schlechtenburg_heading.md":"ed89ddd1","api_@schlechtenburg_image.md":"8d0d9fd9","api_@schlechtenburg_layout.md":"1da56817","api_@schlechtenburg_paragraph.md":"8709c1d7","api_@schlechtenburg_standalone.md":"230a9366","guide_examples.md":"f568382d","guide_installation.md":"491f5af1","guide_why.md":"1cac0594","index.md":"3edeae7e"} diff --git a/docs/index.html b/docs/index.html index 5db7a21..a656562 100644 --- a/docs/index.html +++ b/docs/index.html @@ -6,25 +6,17 @@ Yet another WYSIWYG editor | Schlechtenburg - - - - - - - - - - - + + + -

Yet another WYSIWYG editor

Schlechtenburg is an experimental WYSIWYG editor framework made with Vue 3 and TypeScript. It takes cues from both Wordpress' Gutenberg editor and CKEditor, though it tries to become a best of both worlds; a very lightweight, easily extensible core, written with modern components and the accompanying state management.

It inputs and outputs a tree of JSON-serializable data.

This is still in the Proof-of-concept phase.

Try it yourself

- - +

Yet another WYSIWYG editor

Schlechtenburg is an experimental WYSIWYG editor framework made with Vue 3 and TypeScript. It takes cues from both Wordpress' Gutenberg editor and CKEditor, though it tries to become a best of both worlds; a very lightweight, easily extensible core, written with modern components and the accompanying state management.

It inputs and outputs a tree of JSON-serializable data.

This is still in the Proof-of-concept phase.

Try it yourself

+ + \ No newline at end of file