Shell Editor Personalizzata
Una tipica app Vue con OpenPencil ha tre livelli:
@open-pencil/corecrea l'editor@open-pencil/vuelo adatta in composable Vue e primitive headless- la tua app renderizza la shell, lo stile e la UX specifica del prodotto
Perché questo è importante
L'app OpenPencil integrata è solo una possibile shell.
Puoi costruirne una molto diversa per un flusso di lavoro specifico: un editor integrato in un altro prodotto, uno strumento asset interno, un editor di template, una UI per annotazioni, o una superficie di editing assistita dall'IA con controlli personalizzati.
Questo è il motivo principale per cui esiste l'SDK.
Composizione consigliata
Una shell pratica spesso ha questa forma:
- provider in cima con
provideEditor() - canvas al centro
- navigazione pagine/layer su un lato
- proprietà sull'altro lato
- menu e toolbar guidati da composable
Esempio
vue
<script setup lang="ts">
import { createEditor } from '@open-pencil/core/editor'
import {
provideEditor,
CanvasRoot,
CanvasSurface,
ToolbarRoot,
PageListRoot,
LayerTreeRoot,
} from '@open-pencil/vue'
const editor = createEditor({ width: 1440, height: 900 })
provideEditor(editor)
</script>
<template>
<div class="grid h-screen grid-cols-[240px_1fr_320px] grid-rows-[48px_1fr]">
<ToolbarRoot v-slot="{ tools, activeTool, setTool }">
<header class="col-span-3 flex items-center gap-2 border-b px-3">
<button
v-for="tool in tools"
:key="tool.id"
:data-active="activeTool === tool.id"
@click="setTool(tool.id)"
>
{{ tool.label }}
</button>
</header>
</ToolbarRoot>
<aside class="border-r">
<PageListRoot v-slot="{ pages, currentPageId, switchPage }">
<nav>
<button
v-for="page in pages"
:key="page.id"
:data-active="page.id === currentPageId"
@click="switchPage(page.id)"
>
{{ page.name }}
</button>
</nav>
</PageListRoot>
</aside>
<main>
<CanvasRoot>
<CanvasSurface class="size-full" />
</CanvasRoot>
</main>
<aside class="border-l">
Pannello proprietà qui
</aside>
</div>
</template>Perché questa separazione funziona
- l'SDK possiede l'integrazione con l'editor e la logica headless riutilizzabile
- la tua app possiede layout, stile e azioni specifiche del prodotto
- i composable possono alimentare menu e pannelli senza componenti wrapper aggiuntivi