Skip to content

Paneles de Navegación

Las barras laterales de OpenPencil suelen combinar dos preocupaciones:

  • navegación de páginas
  • navegación de capas

El SDK de Vue proporciona primitivos headless para ambas.

Usa PageListRoot o usePageList().

vue
<PageListRoot v-slot="{ pages, currentPageId, switchPage, addPage }">
  <div>
    <button v-for="page in pages" :key="page.id" @click="switchPage(page.id)">
      {{ page.name }}
    </button>
    <button @click="addPage()">Nueva página</button>
  </div>
</PageListRoot>

Usa LayerTreeRoot cuando quieras estructura de árbol gestionada por el SDK pero presentación propia de la app.

vue
<LayerTreeRoot v-slot="{ items, selectedIds, select, toggleExpand, getKey, getChildren }">
  <TreeView
    :items="items"
    :selected-ids="selectedIds"
    :get-key="getKey"
    :get-children="getChildren"
    @select="select"
    @toggle-expand="toggleExpand"
  />
</LayerTreeRoot>

Patrón práctico

Un layout habitual es:

  • páginas en la parte superior de la barra lateral
  • capas debajo
  • detalles o controles de renombrado inline integrados en los componentes de fila

APIs relacionadas

Released under the MIT License.