primevue-mirror/src/AppMenu.vue

197 lines
11 KiB
Vue
Raw Normal View History

<template>
<div :class="['layout-sidebar', {'active': active}]">
2018-12-06 19:23:02 +00:00
<div class="layout-menu">
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 0)" @keydown.enter="toggleMenu($event, 0)" :class="{'active-menuitem': activeMenuIndex === 0}">
2018-12-06 19:23:02 +00:00
<img alt="input" class="layout-menu-icon-inactive" src="./assets/images/menu/input.svg" />
<img alt="input" class="layout-menu-icon-active" src="./assets/images/menu/input-active.svg" />
<span>Input</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 0">
<div>
<router-link to="/autocomplete">&#9679; AutoComplete</router-link>
<router-link to="/calendar">&#9679; Calendar</router-link>
<router-link to="/checkbox">&#9679; Checkbox</router-link>
<router-link to="/chips">&#9679; Chips</router-link>
<router-link to="/dropdown">&#9679; Dropdown</router-link>
<router-link to="/editor">&#9679; Editor</router-link>
<router-link to="/inputgroup">&#9679; InputGroup</router-link>
<router-link to="/inputswitch">&#9679; InputSwitch</router-link>
<router-link to="/inputtext">&#9679; InputText</router-link>
<router-link to="/listbox">&#9679; Listbox</router-link>
<router-link to="/multiselect">&#9679; MultiSelect</router-link>
<router-link to="/password">&#9679; Password</router-link>
<router-link to="/radiobutton">&#9679; RadioButton</router-link>
<router-link to="/rating">&#9679; Rating</router-link>
<router-link to="/selectbutton">&#9679; SelectButton</router-link>
<router-link to="/slider">&#9679; Slider</router-link>
<router-link to="/spinner">&#9679; Spinner</router-link>
<router-link to="/textarea">&#9679; Textarea</router-link>
<router-link to="/togglebutton">&#9679; ToggleButton</router-link>
<router-link to="/tristatecheckbox">&#9679; TriCheckbox</router-link>
</div>
2018-12-06 19:23:02 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:23:02 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 1)" @keydown.enter="toggleMenu($event, 1)" :class="{'active-menuitem': activeMenuIndex === 1}">
2018-12-06 19:23:02 +00:00
<img alt="button" class="layout-menu-icon-inactive" src="./assets/images/menu/button.svg" />
<img alt="button" class="layout-menu-icon-active" src="./assets/images/menu/button-active.svg" />
<span>Button</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 1">
<div>
<router-link to="/button">&#9679; Button</router-link>
<router-link to="/splitbutton">&#9679; SplitButton</router-link>
</div>
2018-12-06 19:23:02 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 2)" @keydown.enter="toggleMenu($event, 2)" :class="{'active-menuitem': activeMenuIndex === 2}">
2018-12-06 19:33:54 +00:00
<img alt="data" class="layout-menu-icon-inactive" src="./assets/images/menu/data.svg" />
<img alt="data" class="layout-menu-icon-active" src="./assets/images/menu/data-active.svg" />
<span>Data</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 2">
<div>
2019-06-27 21:17:21 +00:00
<router-link to="/datatable">&#9679; DataTable</router-link>
2019-05-21 15:53:28 +00:00
<router-link to="/dataview">&#9679; DataView</router-link>
<router-link to="/fullcalendar">&#9679; FullCalendar</router-link>
2019-07-16 12:47:00 +00:00
<router-link to="/orderlist">&#9679; OrderList</router-link>
2019-05-21 15:53:28 +00:00
<router-link to="/paginator">&#9679; Paginator</router-link>
2019-07-18 20:29:20 +00:00
<router-link to="/picklist">&#9679; PickList</router-link>
2019-05-21 15:53:28 +00:00
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 3)" @keydown.enter="toggleMenu($event, 3)" :class="{'active-menuitem': activeMenuIndex === 3}">
2018-12-06 19:33:54 +00:00
<img alt="panel" class="layout-menu-icon-inactive" src="./assets/images/menu/panel.svg" />
<img alt="panel" class="layout-menu-icon-active" src="./assets/images/menu/panel-active.svg" />
<span>Panel</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 3">
<div>
<router-link to="/accordion">&#9679; Accordion</router-link>
<router-link to="/card">&#9679; Card</router-link>
2019-07-22 13:09:20 +00:00
<router-link to="/deferredcontent">&#9679; Deferred</router-link>
2019-05-21 15:53:28 +00:00
<router-link to="/fieldset">&#9679; Fieldset</router-link>
<router-link to="/flexgrid">&#9679; FlexGrid</router-link>
2019-07-22 13:09:20 +00:00
<router-link to="/panel">&#9679; Panel</router-link>
2019-05-21 15:53:28 +00:00
<router-link to="/tabview">&#9679; TabView</router-link>
<router-link to="/toolbar">&#9679; Toolbar</router-link>
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 4)" @keydown.enter="toggleMenu($event, 4)" :class="{'active-menuitem': activeMenuIndex === 4}">
2018-12-06 19:33:54 +00:00
<img alt="overlay" class="layout-menu-icon-inactive" src="./assets/images/menu/overlay.svg" />
<img alt="overlay" class="layout-menu-icon-active" src="./assets/images/menu/overlay-active.svg" />
<span>Overlay</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 4">
<div>
<router-link to="/dialog">&#9679; Dialog</router-link>
<router-link to="/overlaypanel">&#9679; OverlayPanel</router-link>
<router-link to="/sidebar">&#9679; Sidebar</router-link>
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 5)" @keydown.enter="toggleMenu($event, 5)" :class="{'active-menuitem': activeMenuIndex === 5}">
2018-12-06 19:33:54 +00:00
<img alt="file" class="layout-menu-icon-inactive" src="./assets/images/menu/file.svg" />
<img alt="file" class="layout-menu-icon-active" src="./assets/images/menu/file-active.svg" />
<span>File</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 5">
<div>
<router-link to="/fileupload">&#9679; Upload</router-link>
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 6)" @keydown.enter="toggleMenu($event, 6)" :class="{'active-menuitem': activeMenuIndex === 6}">
2018-12-06 19:33:54 +00:00
<img alt="menu" class="layout-menu-icon-inactive" src="./assets/images/menu/menu.svg" />
<img alt="menu" class="layout-menu-icon-active" src="./assets/images/menu/menu-active.svg" />
<span>Menu</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 6">
<div>
2019-05-27 08:10:22 +00:00
<router-link to="/menumodel">&#9679; MenuModel</router-link>
<router-link to="/menu">&#9679; Menu</router-link>
2019-05-21 15:53:28 +00:00
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 7)" @keydown.enter="toggleMenu($event, 7)" :class="{'active-menuitem': activeMenuIndex === 7}">
2018-12-06 19:33:54 +00:00
<img alt="charts" class="layout-menu-icon-inactive" src="./assets/images/menu/charts.svg" />
<img alt="charts" class="layout-menu-icon-active" src="./assets/images/menu/charts-active.svg" />
<span>Chart</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 7">
<div>
<router-link to="/chart">&#9679; ChartModel</router-link>
<router-link to="/chart/pie">&#9679; Pie</router-link>
<router-link to="/chart/doughnut">&#9679; Doughnut</router-link>
<router-link to="/chart/bar">&#9679; Bar</router-link>
<router-link to="/chart/line">&#9679; Line</router-link>
<router-link to="/chart/polararea">&#9679; PolarArea</router-link>
<router-link to="/chart/radar">&#9679; Radar</router-link>
<router-link to="/chart/combo">&#9679; Combo</router-link>
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 8)" @keydown.enter="toggleMenu($event, 8)" :class="{'active-menuitem': activeMenuIndex === 8}">
2018-12-06 19:33:54 +00:00
<img alt="message" class="layout-menu-icon-inactive" src="./assets/images/menu/message.svg" />
<img alt="message" class="layout-menu-icon-active" src="./assets/images/menu/message-active.svg" />
<span>Messages</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 8">
<div>
<router-link to="/message">&#9679; Message</router-link>
<router-link to="/toast">&#9679; Toast</router-link>
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:33:54 +00:00
2019-05-24 11:05:42 +00:00
<a tabindex="0" @click="toggleMenu($event, 9)" @keydown.enter="toggleMenu($event, 9)" :class="{'active-menuitem': activeMenuIndex === 9}">
2018-12-06 19:33:54 +00:00
<img alt="misc" class="layout-menu-icon-inactive" src="./assets/images/menu/misc.svg" />
<img alt="misc" class="layout-menu-icon-active" src="./assets/images/menu/misc-active.svg" />
<span>Misc</span>
</a>
2019-05-21 15:53:28 +00:00
<transition name="layout-submenu-wrapper">
<div v-show="activeMenuIndex === 9">
<div>
<router-link to="/inplace">&#9679; Inplace</router-link>
2019-05-21 15:53:28 +00:00
<router-link to="/progressbar">&#9679; ProgressBar</router-link>
</div>
2018-12-06 19:33:54 +00:00
</div>
2019-05-21 15:53:28 +00:00
</transition>
2018-12-06 19:23:02 +00:00
</div>
</div>
</template>
<script>
export default {
2018-12-26 09:36:00 +00:00
props: {
2018-12-26 12:24:18 +00:00
active: Boolean
2018-12-26 09:36:00 +00:00
},
2018-12-06 19:23:02 +00:00
data() {
return {
activeMenuIndex: null
}
},
methods: {
toggleMenu(event, index) {
2018-12-06 19:33:54 +00:00
this.activeMenuIndex = (this.activeMenuIndex === index) ? null : index;
2018-12-06 19:23:02 +00:00
}
}
}
</script>