1
0
Fork 0
mirror of https://gitlab.com/bramw/baserow.git synced 2025-02-20 19:58:43 +00:00
bramw_baserow/web-frontend/modules/builder/components/page/header/PageHeaderMenuItems.vue
2024-11-28 08:47:54 +00:00

42 lines
1 KiB
Vue

<template>
<ul class="header__filter">
<li
v-for="itemType in pageHeaderItemTypes"
:key="itemType.getType()"
class="header__filter-item"
>
<a
:ref="`button_${itemType.type}`"
:data-item-type="itemType.type"
class="header__filter-link"
@click="
itemType.onClick(
$refs[`component_${itemType.type}`][0],
$refs[`button_${itemType.type}`][0]
)
"
>
<i class="header__filter-icon" :class="itemType.icon"></i>
<span class="header__filter-name">{{ itemType.label }}</span>
</a>
<component
:is="itemType.component"
:ref="`component_${itemType.type}`"
:data-item-type="itemType.type"
:page="currentPage"
/>
</li>
</ul>
</template>
<script>
export default {
name: 'PageHeaderMenuItems',
inject: ['currentPage'],
computed: {
pageHeaderItemTypes() {
return this.$registry.getOrderedList('pageHeaderItem')
},
},
}
</script>