Skip to content

Pannelli di Navigazione

Le sidebar di OpenPencil di solito combinano due aspetti:

  • navigazione tra pagine
  • navigazione tra layer

Il Vue SDK fornisce primitive headless per entrambi.

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()">Nuova pagina</button>
  </div>
</PageListRoot>

Usa LayerTreeRoot quando vuoi struttura ad albero gestita dall'SDK ma presentazione di proprietà dell'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>

Pattern pratico

Un layout comune è:

  • le pagine in cima alla sidebar
  • i layer sotto
  • controlli per dettagli o rinomina inline incorporati nei componenti di riga

API correlate

Released under the MIT License.