UNPKG

primevue

Version:

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) [![npm version](https://badge.fury.io/js/primevue.svg)](https://badge.fury.io/js/primevue) [![Discord Chat](https://img.shields.io/discord/55794023

420 lines (390 loc) 16.8 kB
import { resolveComponent, openBlock, createBlock, Fragment, renderList, withCtx, createVNode, toDisplayString, createCommentVNode, resolveDynamicComponent, Transition, withDirectives, vShow } from 'vue'; import { UniqueComponentId } from 'primevue/utils'; var script = { name: 'PanelMenuSub', emits: ['item-toggle'], props: { model: { type: null, default: null }, template: { type: Object, default: null }, expandedKeys: { type: null, default: null } }, data() { return { activeItem: null } }, methods: { onItemClick(event, item, navigate) { if (this.isActive(item) && this.activeItem === null) { this.activeItem = item; } if (item.disabled) { event.preventDefault(); return; } if (item.command) { item.command({ originalEvent: event, item: item }); } if (this.activeItem && this.activeItem === item) this.activeItem = null; else this.activeItem = item; this.$emit('item-toggle', {item: item, expanded: this.activeItem != null}); if (item.to && navigate) { navigate(event); } }, getItemClass(item) { return ['p-menuitem', item.className]; }, getLinkClass(item) { return ['p-menuitem-link', {'p-disabled': item.disabled}]; }, isActive(item) { return this.expandedKeys ? this.expandedKeys[item.key] : item === this.activeItem; }, getSubmenuIcon(item) { const active = this.isActive(item); return ['p-panelmenu-icon pi pi-fw', {'pi-angle-right': !active, 'pi-angle-down': active}]; }, visible(item) { return (typeof item.visible === 'function' ? item.visible() : item.visible !== false); } } }; const _hoisted_1 = { class: "p-submenu-list", role: "tree" }; const _hoisted_2 = { class: "p-menuitem-text" }; const _hoisted_3 = { class: "p-menuitem-text" }; const _hoisted_4 = { class: "p-toggleable-content" }; function render(_ctx, _cache, $props, $setup, $data, $options) { const _component_router_link = resolveComponent("router-link"); const _component_PanelMenuSub = resolveComponent("PanelMenuSub", true); return (openBlock(), createBlock("ul", _hoisted_1, [ (openBlock(true), createBlock(Fragment, null, renderList($props.model, (item, i) => { return (openBlock(), createBlock(Fragment, { key: item.label + i.toString() }, [ ($options.visible(item) && !item.separator) ? (openBlock(), createBlock("li", { key: 0, role: "none", class: $options.getItemClass(item), style: item.style }, [ (!$props.template) ? (openBlock(), createBlock(Fragment, { key: 0 }, [ (item.to && !item.disabled) ? (openBlock(), createBlock(_component_router_link, { key: 0, to: item.to, custom: "" }, { default: withCtx(({navigate, href}) => [ createVNode("a", { href: href, class: $options.getLinkClass(item), onClick: $event => ($options.onItemClick($event, item, navigate)), role: "treeitem", "aria-expanded": $options.isActive(item) }, [ createVNode("span", { class: ['p-menuitem-icon', item.icon] }, null, 2), createVNode("span", _hoisted_2, toDisplayString(item.label), 1) ], 10, ["href", "onClick", "aria-expanded"]) ]), _: 2 }, 1032, ["to"])) : (openBlock(), createBlock("a", { key: 1, href: item.url, class: $options.getLinkClass(item), target: item.target, onClick: $event => ($options.onItemClick($event, item)), role: "treeitem", "aria-expanded": $options.isActive(item), tabindex: item.disabled ? null : '0' }, [ (item.items) ? (openBlock(), createBlock("span", { key: 0, class: $options.getSubmenuIcon(item) }, null, 2)) : createCommentVNode("", true), createVNode("span", { class: ['p-menuitem-icon', item.icon] }, null, 2), createVNode("span", _hoisted_3, toDisplayString(item.label), 1) ], 10, ["href", "target", "onClick", "aria-expanded", "tabindex"])) ], 64)) : (openBlock(), createBlock(resolveDynamicComponent($props.template), { key: 1, item: item }, null, 8, ["item"])), createVNode(Transition, { name: "p-toggleable-content" }, { default: withCtx(() => [ withDirectives(createVNode("div", _hoisted_4, [ ($options.visible(item) && item.items) ? (openBlock(), createBlock(_component_PanelMenuSub, { model: item.items, key: item.label + '_sub_', template: $props.template, expandedKeys: $props.expandedKeys, onItemToggle: _cache[1] || (_cache[1] = $event => (_ctx.$emit('item-toggle', $event))) }, null, 8, ["model", "template", "expandedKeys"])) : createCommentVNode("", true) ], 512), [ [vShow, $options.isActive(item)] ]) ]), _: 2 }, 1024) ], 6)) : createCommentVNode("", true), ($options.visible(item) && item.separator) ? (openBlock(), createBlock("li", { class: ['p-menu-separator', item.class], style: item.style, key: 'separator' + i.toString() }, null, 6)) : createCommentVNode("", true) ], 64)) }), 128)) ])) } script.render = render; var script$1 = { name: 'PanelMenu', emits: ['update:expandedKeys'], props: { model: { type: Array, default: null }, expandedKeys: { type: null, default: null } }, data() { return { activeItem: null } }, methods: { onItemClick(event, item, navigate) { if (this.isActive(item) && this.activeItem === null) { this.activeItem = item; } if (item.disabled) { event.preventDefault(); return; } if (item.command) { item.command({ originalEvent: event, item: item }); } if (this.activeItem && this.activeItem === item) this.activeItem = null; else this.activeItem = item; this.updateExpandedKeys({item: item, expanded: this.activeItem != null}); if (item.to && navigate) { navigate(event); } }, updateExpandedKeys(event) { if (this.expandedKeys) { let item = event.item; let _keys = {...this.expandedKeys}; if (event.expanded) _keys[item.key] = true; else delete _keys[item.key]; this.$emit('update:expandedKeys', _keys); } }, getPanelClass(item) { return ['p-panelmenu-panel', item.class]; }, getPanelToggleIcon(item) { const active = this.isActive(item); return ['p-panelmenu-icon pi', {'pi-chevron-right': !active,' pi-chevron-down': active}]; }, getPanelIcon(item) { return ['p-menuitem-icon', item.icon]; }, isActive(item) { return this.expandedKeys ? this.expandedKeys[item.key] : item === this.activeItem; }, getHeaderClass(item) { return ['p-component p-panelmenu-header', {'p-highlight': this.isActive(item), 'p-disabled': item.disabled}]; }, visible(item) { return (typeof item.visible === 'function' ? item.visible() : item.visible !== false); } }, components: { 'PanelMenuSub': script }, computed: { ariaId() { return UniqueComponentId(); } } }; const _hoisted_1$1 = { class: "p-panelmenu p-component" }; const _hoisted_2$1 = { class: "p-menuitem-text" }; const _hoisted_3$1 = { class: "p-menuitem-text" }; const _hoisted_4$1 = { key: 0, class: "p-panelmenu-content" }; function render$1(_ctx, _cache, $props, $setup, $data, $options) { const _component_router_link = resolveComponent("router-link"); const _component_PanelMenuSub = resolveComponent("PanelMenuSub"); return (openBlock(), createBlock("div", _hoisted_1$1, [ (openBlock(true), createBlock(Fragment, null, renderList($props.model, (item, index) => { return (openBlock(), createBlock(Fragment, { key: item.label + '_' + index }, [ ($options.visible(item)) ? (openBlock(), createBlock("div", { key: 0, class: $options.getPanelClass(item), style: item.style }, [ createVNode("div", { class: $options.getHeaderClass(item), style: item.style }, [ (!_ctx.$slots.item) ? (openBlock(), createBlock(Fragment, { key: 0 }, [ (item.to && !item.disabled) ? (openBlock(), createBlock(_component_router_link, { key: 0, to: item.to, custom: "" }, { default: withCtx(({navigate, href}) => [ createVNode("a", { href: href, class: "p-panelmenu-header-link", onClick: $event => ($options.onItemClick($event, item, navigate)), role: "treeitem" }, [ (item.icon) ? (openBlock(), createBlock("span", { key: 0, class: $options.getPanelIcon(item) }, null, 2)) : createCommentVNode("", true), createVNode("span", _hoisted_2$1, toDisplayString(item.label), 1) ], 8, ["href", "onClick"]) ]), _: 2 }, 1032, ["to"])) : (openBlock(), createBlock("a", { key: 1, href: item.url, class: "p-panelmenu-header-link", onClick: $event => ($options.onItemClick($event, item)), tabindex: item.disabled ? null : '0', "aria-expanded": $options.isActive(item), id: $options.ariaId +'_header', "aria-controls": $options.ariaId +'_content' }, [ (item.items) ? (openBlock(), createBlock("span", { key: 0, class: $options.getPanelToggleIcon(item) }, null, 2)) : createCommentVNode("", true), (item.icon) ? (openBlock(), createBlock("span", { key: 1, class: $options.getPanelIcon(item) }, null, 2)) : createCommentVNode("", true), createVNode("span", _hoisted_3$1, toDisplayString(item.label), 1) ], 8, ["href", "onClick", "tabindex", "aria-expanded", "id", "aria-controls"])) ], 64)) : (openBlock(), createBlock(resolveDynamicComponent(_ctx.$slots.item), { key: 1, item: item }, null, 8, ["item"])) ], 6), createVNode(Transition, { name: "p-toggleable-content" }, { default: withCtx(() => [ withDirectives(createVNode("div", { class: "p-toggleable-content", role: "region", id: $options.ariaId +'_content' , "aria-labelledby": $options.ariaId +'_header' }, [ (item.items) ? (openBlock(), createBlock("div", _hoisted_4$1, [ createVNode(_component_PanelMenuSub, { model: item.items, class: "p-panelmenu-root-submenu", template: _ctx.$slots.item, expandedKeys: $props.expandedKeys, onItemToggle: $options.updateExpandedKeys }, null, 8, ["model", "template", "expandedKeys", "onItemToggle"]) ])) : createCommentVNode("", true) ], 8, ["id", "aria-labelledby"]), [ [vShow, $options.isActive(item)] ]) ]), _: 2 }, 1024) ], 6)) : createCommentVNode("", true) ], 64)) }), 128)) ])) } function styleInject(css, ref) { if ( ref === void 0 ) ref = {}; var insertAt = ref.insertAt; if (!css || typeof document === 'undefined') { return; } var head = document.head || document.getElementsByTagName('head')[0]; var style = document.createElement('style'); style.type = 'text/css'; if (insertAt === 'top') { if (head.firstChild) { head.insertBefore(style, head.firstChild); } else { head.appendChild(style); } } else { head.appendChild(style); } if (style.styleSheet) { style.styleSheet.cssText = css; } else { style.appendChild(document.createTextNode(css)); } } var css_248z = "\n.p-panelmenu .p-panelmenu-header-link {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n cursor: pointer;\n position: relative;\n text-decoration: none;\n}\n.p-panelmenu .p-panelmenu-header-link:focus {\n z-index: 1;\n}\n.p-panelmenu .p-submenu-list {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n.p-panelmenu .p-menuitem-link {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n cursor: pointer;\n text-decoration: none;\n}\n.p-panelmenu .p-menuitem-text {\n line-height: 1;\n}\n"; styleInject(css_248z); script$1.render = render$1; export default script$1;