primevue
Version:
PrimeVue is an open source UI library for Vue featuring a rich set of 80+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with PrimeBloc
172 lines (166 loc) • 5.88 kB
JavaScript
import { cn } from '@primeuix/utils';
import MinusIcon from '@primevue/icons/minus';
import PlusIcon from '@primevue/icons/plus';
import Button from 'primevue/button';
import Ripple from 'primevue/ripple';
import BaseComponent from '@primevue/core/basecomponent';
import PanelStyle from 'primevue/panel/style';
import { resolveComponent, createElementBlock, openBlock, mergeProps, createElementVNode, createVNode, renderSlot, normalizeClass, createCommentVNode, toDisplayString, withCtx, createBlock, resolveDynamicComponent, Transition, withDirectives, vShow } from 'vue';
var script$1 = {
name: 'BasePanel',
"extends": BaseComponent,
props: {
header: String,
toggleable: Boolean,
collapsed: Boolean,
toggleButtonProps: {
type: Object,
"default": function _default() {
return {
severity: 'secondary',
text: true,
rounded: true
};
}
}
},
style: PanelStyle,
provide: function provide() {
return {
$pcPanel: this,
$parentInstance: this
};
}
};
var script = {
name: 'Panel',
"extends": script$1,
inheritAttrs: false,
emits: ['update:collapsed', 'toggle'],
data: function data() {
return {
d_collapsed: this.collapsed
};
},
watch: {
collapsed: function collapsed(newValue) {
this.d_collapsed = newValue;
}
},
methods: {
toggle: function toggle(event) {
this.d_collapsed = !this.d_collapsed;
this.$emit('update:collapsed', this.d_collapsed);
this.$emit('toggle', {
originalEvent: event,
value: this.d_collapsed
});
},
onKeyDown: function onKeyDown(event) {
if (event.code === 'Enter' || event.code === 'NumpadEnter' || event.code === 'Space') {
this.toggle(event);
event.preventDefault();
}
}
},
computed: {
buttonAriaLabel: function buttonAriaLabel() {
return this.toggleButtonProps && this.toggleButtonProps.ariaLabel ? this.toggleButtonProps.ariaLabel : this.header;
},
dataP: function dataP() {
return cn({
toggleable: this.toggleable
});
}
},
components: {
PlusIcon: PlusIcon,
MinusIcon: MinusIcon,
Button: Button
},
directives: {
ripple: Ripple
}
};
var _hoisted_1 = ["data-p"];
var _hoisted_2 = ["data-p"];
var _hoisted_3 = ["id"];
var _hoisted_4 = ["id", "aria-labelledby"];
function render(_ctx, _cache, $props, $setup, $data, $options) {
var _component_Button = resolveComponent("Button");
return openBlock(), createElementBlock("div", mergeProps({
"class": _ctx.cx('root'),
"data-p": $options.dataP
}, _ctx.ptmi('root')), [createElementVNode("div", mergeProps({
"class": _ctx.cx('header'),
"data-p": $options.dataP
}, _ctx.ptm('header')), [renderSlot(_ctx.$slots, "header", {
id: _ctx.$id + '_header',
"class": normalizeClass(_ctx.cx('title'))
}, function () {
return [_ctx.header ? (openBlock(), createElementBlock("span", mergeProps({
key: 0,
id: _ctx.$id + '_header',
"class": _ctx.cx('title')
}, _ctx.ptm('title')), toDisplayString(_ctx.header), 17, _hoisted_3)) : createCommentVNode("", true)];
}), createElementVNode("div", mergeProps({
"class": _ctx.cx('headerActions')
}, _ctx.ptm('headerActions')), [renderSlot(_ctx.$slots, "icons"), _ctx.toggleable ? renderSlot(_ctx.$slots, "togglebutton", {
key: 0,
collapsed: $data.d_collapsed,
toggleCallback: function toggleCallback(event) {
return $options.toggle(event);
},
keydownCallback: function keydownCallback(event) {
return $options.onKeyDown(event);
}
}, function () {
return [createVNode(_component_Button, mergeProps({
id: _ctx.$id + '_header',
"class": _ctx.cx('pcToggleButton'),
"aria-label": $options.buttonAriaLabel,
"aria-controls": _ctx.$id + '_content',
"aria-expanded": !$data.d_collapsed,
unstyled: _ctx.unstyled,
onClick: _cache[0] || (_cache[0] = function ($event) {
return $options.toggle(_ctx.event);
}),
onKeydown: _cache[1] || (_cache[1] = function ($event) {
return $options.onKeyDown(_ctx.event);
})
}, _ctx.toggleButtonProps, {
pt: _ctx.ptm('pcToggleButton')
}), {
icon: withCtx(function (slotProps) {
return [renderSlot(_ctx.$slots, _ctx.$slots.toggleicon ? 'toggleicon' : 'togglericon', {
collapsed: $data.d_collapsed
}, function () {
return [(openBlock(), createBlock(resolveDynamicComponent($data.d_collapsed ? 'PlusIcon' : 'MinusIcon'), mergeProps({
"class": slotProps["class"]
}, _ctx.ptm('pcToggleButton')['icon']), null, 16, ["class"]))];
})];
}),
_: 3
}, 16, ["id", "class", "aria-label", "aria-controls", "aria-expanded", "unstyled", "pt"])];
}) : createCommentVNode("", true)], 16)], 16, _hoisted_2), createVNode(Transition, mergeProps({
name: "p-toggleable-content"
}, _ctx.ptm('transition')), {
"default": withCtx(function () {
return [withDirectives(createElementVNode("div", mergeProps({
id: _ctx.$id + '_content',
"class": _ctx.cx('contentContainer'),
role: "region",
"aria-labelledby": _ctx.$id + '_header'
}, _ctx.ptm('contentContainer')), [createElementVNode("div", mergeProps({
"class": _ctx.cx('content')
}, _ctx.ptm('content')), [renderSlot(_ctx.$slots, "default")], 16), _ctx.$slots.footer ? (openBlock(), createElementBlock("div", mergeProps({
key: 0,
"class": _ctx.cx('footer')
}, _ctx.ptm('footer')), [renderSlot(_ctx.$slots, "footer")], 16)) : createCommentVNode("", true)], 16, _hoisted_4), [[vShow, !$data.d_collapsed]])];
}),
_: 3
}, 16)], 16, _hoisted_1);
}
script.render = render;
export { script as default };
//# sourceMappingURL=index.mjs.map