UNPKG

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

622 lines (615 loc) 23.3 kB
import { $dt } from '@primeuix/styled'; import { find, hasClass, findSingle, focus } from '@primeuix/utils/dom'; import PlusIcon from '@primevue/icons/plus'; import Button from 'primevue/button'; import Ripple from 'primevue/ripple'; import Tooltip from 'primevue/tooltip'; import BaseComponent from '@primevue/core/basecomponent'; import SpeedDialStyle from 'primevue/speeddial/style'; import { resolveComponent, resolveDirective, createElementBlock, openBlock, Fragment, createElementVNode, createCommentVNode, mergeProps, renderSlot, createVNode, withCtx, createBlock, resolveDynamicComponent, renderList, withDirectives, createSlots, normalizeClass } from 'vue'; var script$1 = { name: 'BaseSpeedDial', "extends": BaseComponent, props: { model: null, visible: { type: Boolean, "default": false }, direction: { type: String, "default": 'up' }, transitionDelay: { type: Number, "default": 30 }, type: { type: String, "default": 'linear' }, radius: { type: Number, "default": 0 }, mask: { type: Boolean, "default": false }, disabled: { type: Boolean, "default": false }, hideOnClickOutside: { type: Boolean, "default": true }, buttonClass: null, maskStyle: null, maskClass: null, showIcon: { type: String, "default": undefined }, hideIcon: { type: String, "default": undefined }, rotateAnimation: { type: Boolean, "default": true }, tooltipOptions: null, style: null, "class": null, buttonProps: { type: Object, "default": function _default() { return { rounded: true }; } }, actionButtonProps: { type: Object, "default": function _default() { return { severity: 'secondary', rounded: true, size: 'small' }; } }, ariaLabelledby: { type: String, "default": null }, ariaLabel: { type: String, "default": null } }, style: SpeedDialStyle, provide: function provide() { return { $pcSpeedDial: this, $parentInstance: this }; } }; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), true).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: true, configurable: true, writable: true }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } // Set fix value for SSR. var Math_PI = 3.14159265358979; var script = { name: 'SpeedDial', "extends": script$1, inheritAttrs: false, emits: ['click', 'show', 'hide', 'focus', 'blur'], documentClickListener: null, container: null, list: null, data: function data() { return { d_visible: this.visible, isItemClicked: false, focused: false, focusedOptionIndex: -1 }; }, watch: { visible: function visible(newValue) { this.d_visible = newValue; } }, mounted: function mounted() { if (this.type !== 'linear') { var button = findSingle(this.container, '[data-pc-name="pcbutton"]'); var firstItem = findSingle(this.list, '[data-pc-section="item"]'); if (button && firstItem) { var wDiff = Math.abs(button.offsetWidth - firstItem.offsetWidth); var hDiff = Math.abs(button.offsetHeight - firstItem.offsetHeight); this.list.style.setProperty($dt('item.diff.x').name, "".concat(wDiff / 2, "px")); this.list.style.setProperty($dt('item.diff.y').name, "".concat(hDiff / 2, "px")); } } if (this.hideOnClickOutside) { this.bindDocumentClickListener(); } }, beforeUnmount: function beforeUnmount() { this.unbindDocumentClickListener(); }, methods: { getPTOptions: function getPTOptions(id, key) { return this.ptm(key, { context: { active: this.isItemActive(id), hidden: !this.d_visible } }); }, onFocus: function onFocus(event) { this.$emit('focus', event); }, onBlur: function onBlur(event) { this.focusedOptionIndex = -1; this.$emit('blur', event); }, onItemClick: function onItemClick(e, item) { if (item.command) { item.command({ originalEvent: e, item: item }); } this.hide(); this.isItemClicked = true; e.preventDefault(); }, onClick: function onClick(event) { this.d_visible ? this.hide() : this.show(); this.isItemClicked = true; this.$emit('click', event); }, show: function show() { this.d_visible = true; this.$emit('show'); }, hide: function hide() { this.d_visible = false; this.$emit('hide'); }, calculateTransitionDelay: function calculateTransitionDelay(index) { var length = this.model.length; var visible = this.d_visible; return (visible ? index : length - index - 1) * this.transitionDelay; }, onTogglerKeydown: function onTogglerKeydown(event) { switch (event.code) { case 'ArrowDown': case 'ArrowLeft': this.onTogglerArrowDown(event); break; case 'ArrowUp': case 'ArrowRight': this.onTogglerArrowUp(event); break; case 'Escape': this.onEscapeKey(); break; } }, onKeyDown: function onKeyDown(event) { switch (event.code) { case 'ArrowDown': this.onArrowDown(event); break; case 'ArrowUp': this.onArrowUp(event); break; case 'ArrowLeft': this.onArrowLeft(event); break; case 'ArrowRight': this.onArrowRight(event); break; case 'Enter': case 'NumpadEnter': case 'Space': this.onEnterKey(event); break; case 'Escape': this.onEscapeKey(event); break; case 'Home': this.onHomeKey(event); break; case 'End': this.onEndKey(event); break; } }, onTogglerArrowUp: function onTogglerArrowUp(event) { this.show(); this.navigatePrevItem(event); event.preventDefault(); }, onTogglerArrowDown: function onTogglerArrowDown(event) { this.show(); this.navigateNextItem(event); event.preventDefault(); }, onEnterKey: function onEnterKey(event) { var _this = this; var items = find(this.container, '[data-pc-section="item"]'); var itemIndex = _toConsumableArray(items).findIndex(function (item) { return item.id === _this.focusedOptionIndex; }); var buttonEl = findSingle(this.container, 'button'); this.onItemClick(event, this.model[itemIndex]); this.onBlur(event); buttonEl && focus(buttonEl); }, onEscapeKey: function onEscapeKey() { this.hide(); var buttonEl = findSingle(this.container, 'button'); buttonEl && focus(buttonEl); }, onArrowUp: function onArrowUp(event) { if (this.direction === 'down') { this.navigatePrevItem(event); } else { this.navigateNextItem(event); } }, onArrowDown: function onArrowDown(event) { if (this.direction === 'down') { this.navigateNextItem(event); } else { this.navigatePrevItem(event); } }, onArrowLeft: function onArrowLeft(event) { var leftValidDirections = ['left', 'up-right', 'down-left']; var rightValidDirections = ['right', 'up-left', 'down-right']; if (leftValidDirections.includes(this.direction)) { this.navigateNextItem(event); } else if (rightValidDirections.includes(this.direction)) { this.navigatePrevItem(event); } else { this.navigatePrevItem(event); } }, onArrowRight: function onArrowRight(event) { var leftValidDirections = ['left', 'up-right', 'down-left']; var rightValidDirections = ['right', 'up-left', 'down-right']; if (leftValidDirections.includes(this.direction)) { this.navigatePrevItem(event); } else if (rightValidDirections.includes(this.direction)) { this.navigateNextItem(event); } else { this.navigateNextItem(event); } }, onEndKey: function onEndKey(event) { event.preventDefault(); this.focusedOptionIndex = -1; this.navigatePrevItem(event); }, onHomeKey: function onHomeKey(event) { event.preventDefault(); this.focusedOptionIndex = -1; this.navigateNextItem(event); }, navigateNextItem: function navigateNextItem(event) { var optionIndex = this.findNextOptionIndex(this.focusedOptionIndex); this.changeFocusedOptionIndex(optionIndex); event.preventDefault(); }, navigatePrevItem: function navigatePrevItem(event) { var optionIndex = this.findPrevOptionIndex(this.focusedOptionIndex); this.changeFocusedOptionIndex(optionIndex); event.preventDefault(); }, changeFocusedOptionIndex: function changeFocusedOptionIndex(index) { var items = find(this.container, '[data-pc-section="item"]'); var filteredItems = _toConsumableArray(items).filter(function (item) { return !hasClass(findSingle(item, 'a'), 'p-disabled'); }); if (filteredItems[index]) { this.focusedOptionIndex = filteredItems[index].getAttribute('id'); var buttonEl = findSingle(filteredItems[index], '[type="button"]'); buttonEl && focus(buttonEl); } }, findPrevOptionIndex: function findPrevOptionIndex(index) { var items = find(this.container, '[data-pc-section="item"]'); var filteredItems = _toConsumableArray(items).filter(function (item) { return !hasClass(findSingle(item, 'a'), 'p-disabled'); }); var newIndex = index === -1 ? filteredItems[filteredItems.length - 1].id : index; var matchedOptionIndex = filteredItems.findIndex(function (link) { return link.getAttribute('id') === newIndex; }); matchedOptionIndex = index === -1 ? filteredItems.length - 1 : matchedOptionIndex - 1; return matchedOptionIndex; }, findNextOptionIndex: function findNextOptionIndex(index) { var items = find(this.container, '[data-pc-section="item"]'); var filteredItems = _toConsumableArray(items).filter(function (item) { return !hasClass(findSingle(item, 'a'), 'p-disabled'); }); var newIndex = index === -1 ? filteredItems[0].id : index; var matchedOptionIndex = filteredItems.findIndex(function (link) { return link.getAttribute('id') === newIndex; }); matchedOptionIndex = index === -1 ? 0 : matchedOptionIndex + 1; return matchedOptionIndex; }, calculatePointStyle: function calculatePointStyle(index) { var type = this.type; if (type !== 'linear') { var length = this.model.length; var radius = this.radius || length * 20; if (type === 'circle') { var step = 2 * Math_PI / length; return { left: "calc(".concat(radius * Math.cos(step * index), "px + ").concat($dt('item.diff.x', '0px').variable, ")"), top: "calc(".concat(radius * Math.sin(step * index), "px + ").concat($dt('item.diff.y', '0px').variable, ")") }; } else if (type === 'semi-circle') { var direction = this.direction; var _step = Math_PI / (length - 1); var x = "calc(".concat(radius * Math.cos(_step * index), "px + ").concat($dt('item.diff.x', '0px').variable, ")"); var y = "calc(".concat(radius * Math.sin(_step * index), "px + ").concat($dt('item.diff.y', '0px').variable, ")"); if (direction === 'up') { return { left: x, bottom: y }; } else if (direction === 'down') { return { left: x, top: y }; } else if (direction === 'left') { return { right: y, top: x }; } else if (direction === 'right') { return { left: y, top: x }; } } else if (type === 'quarter-circle') { var _direction = this.direction; var _step2 = Math_PI / (2 * (length - 1)); var _x = "calc(".concat(radius * Math.cos(_step2 * index), "px + ").concat($dt('item.diff.x', '0px').variable, ")"); var _y = "calc(".concat(radius * Math.sin(_step2 * index), "px + ").concat($dt('item.diff.y', '0px').variable, ")"); if (_direction === 'up-left') { return { right: _x, bottom: _y }; } else if (_direction === 'up-right') { return { left: _x, bottom: _y }; } else if (_direction === 'down-left') { return { right: _y, top: _x }; } else if (_direction === 'down-right') { return { left: _y, top: _x }; } } } return {}; }, getItemStyle: function getItemStyle(index) { var transitionDelay = this.calculateTransitionDelay(index); var pointStyle = this.calculatePointStyle(index); return _objectSpread({ transitionDelay: "".concat(transitionDelay, "ms") }, pointStyle); }, bindDocumentClickListener: function bindDocumentClickListener() { var _this2 = this; if (!this.documentClickListener) { this.documentClickListener = function (event) { if (_this2.d_visible && _this2.isOutsideClicked(event)) { _this2.hide(); } _this2.isItemClicked = false; }; document.addEventListener('click', this.documentClickListener); } }, unbindDocumentClickListener: function unbindDocumentClickListener() { if (this.documentClickListener) { document.removeEventListener('click', this.documentClickListener); this.documentClickListener = null; } }, isOutsideClicked: function isOutsideClicked(event) { return this.container && !(this.container.isSameNode(event.target) || this.container.contains(event.target) || this.isItemClicked); }, isItemVisible: function isItemVisible(item) { return typeof item.visible === 'function' ? item.visible() : item.visible !== false; }, isItemActive: function isItemActive(id) { return id === this.focusedOptionId; }, containerRef: function containerRef(el) { this.container = el; }, listRef: function listRef(el) { this.list = el; } }, computed: { containerClass: function containerClass() { return [this.cx('root'), this["class"]]; }, focusedOptionId: function focusedOptionId() { return this.focusedOptionIndex !== -1 ? this.focusedOptionIndex : null; } }, components: { Button: Button, PlusIcon: PlusIcon }, directives: { ripple: Ripple, tooltip: Tooltip } }; var _hoisted_1 = ["id"]; var _hoisted_2 = ["id", "data-p-active"]; function render(_ctx, _cache, $props, $setup, $data, $options) { var _component_Button = resolveComponent("Button"); var _directive_tooltip = resolveDirective("tooltip"); return openBlock(), createElementBlock(Fragment, null, [createElementVNode("div", mergeProps({ ref: $options.containerRef, "class": $options.containerClass, style: [_ctx.style, _ctx.sx('root')] }, _ctx.ptmi('root')), [renderSlot(_ctx.$slots, "button", { visible: $data.d_visible, toggleCallback: $options.onClick }, function () { return [createVNode(_component_Button, mergeProps({ "class": [_ctx.cx('pcButton'), _ctx.buttonClass], disabled: _ctx.disabled, "aria-expanded": $data.d_visible, "aria-haspopup": true, "aria-controls": _ctx.$id + '_list', "aria-label": _ctx.ariaLabel, "aria-labelledby": _ctx.ariaLabelledby, unstyled: _ctx.unstyled, onClick: _cache[0] || (_cache[0] = function ($event) { return $options.onClick($event); }), onKeydown: $options.onTogglerKeydown }, _ctx.buttonProps, { pt: _ctx.ptm('pcButton') }), { icon: withCtx(function (slotProps) { return [renderSlot(_ctx.$slots, "icon", { visible: $data.d_visible }, function () { return [$data.d_visible && !!_ctx.hideIcon ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.hideIcon ? 'span' : 'PlusIcon'), mergeProps({ key: 0, "class": [_ctx.hideIcon, slotProps["class"]] }, _ctx.ptm('pcButton')['icon'], { "data-pc-section": "icon" }), null, 16, ["class"])) : (openBlock(), createBlock(resolveDynamicComponent(_ctx.showIcon ? 'span' : 'PlusIcon'), mergeProps({ key: 1, "class": [$data.d_visible && !!_ctx.hideIcon ? _ctx.hideIcon : _ctx.showIcon, slotProps["class"]] }, _ctx.ptm('pcButton')['icon'], { "data-pc-section": "icon" }), null, 16, ["class"]))]; })]; }), _: 3 }, 16, ["class", "disabled", "aria-expanded", "aria-controls", "aria-label", "aria-labelledby", "unstyled", "onKeydown", "pt"])]; }), createElementVNode("ul", mergeProps({ ref: $options.listRef, id: _ctx.$id + '_list', "class": _ctx.cx('list'), style: _ctx.sx('list'), role: "menu", tabindex: "-1", onFocus: _cache[1] || (_cache[1] = function () { return $options.onFocus && $options.onFocus.apply($options, arguments); }), onBlur: _cache[2] || (_cache[2] = function () { return $options.onBlur && $options.onBlur.apply($options, arguments); }), onKeydown: _cache[3] || (_cache[3] = function () { return $options.onKeyDown && $options.onKeyDown.apply($options, arguments); }) }, _ctx.ptm('list')), [(openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.model, function (item, index) { return openBlock(), createElementBlock(Fragment, { key: index }, [$options.isItemVisible(item) ? (openBlock(), createElementBlock("li", mergeProps({ key: 0, id: "".concat(_ctx.$id, "_").concat(index), "class": _ctx.cx('item', { id: "".concat(_ctx.$id, "_").concat(index) }), style: $options.getItemStyle(index), role: "none", "data-p-active": $options.isItemActive("".concat(_ctx.$id, "_").concat(index)), ref_for: true }, $options.getPTOptions("".concat(_ctx.$id, "_").concat(index), 'item')), [!_ctx.$slots.item ? withDirectives((openBlock(), createBlock(_component_Button, mergeProps({ key: 0, tabindex: -1, role: "menuitem", "class": _ctx.cx('pcAction', { item: item }), "aria-label": item.label, disabled: _ctx.disabled, unstyled: _ctx.unstyled, onClick: function onClick($event) { return $options.onItemClick($event, item); }, ref_for: true }, _ctx.actionButtonProps, { pt: $options.getPTOptions("".concat(_ctx.$id, "_").concat(index), 'pcAction') }), createSlots({ _: 2 }, [item.icon ? { name: "icon", fn: withCtx(function (slotProps) { return [renderSlot(_ctx.$slots, "itemicon", { item: item, "class": normalizeClass(slotProps["class"]) }, function () { return [createElementVNode("span", mergeProps({ "class": [item.icon, slotProps["class"]], ref_for: true }, $options.getPTOptions("".concat(_ctx.$id, "_").concat(index), 'actionIcon')), null, 16)]; })]; }), key: "0" } : undefined]), 1040, ["class", "aria-label", "disabled", "unstyled", "onClick", "pt"])), [[_directive_tooltip, { value: item.label, disabled: !_ctx.tooltipOptions }, _ctx.tooltipOptions]]) : (openBlock(), createBlock(resolveDynamicComponent(_ctx.$slots.item), { key: 1, item: item, onClick: function onClick(event) { return $options.onItemClick(event, item); }, toggleCallback: function toggleCallback(event) { return $options.onItemClick(event, item); } }, null, 8, ["item", "onClick", "toggleCallback"]))], 16, _hoisted_2)) : createCommentVNode("", true)], 64); }), 128))], 16, _hoisted_1)], 16), _ctx.mask ? (openBlock(), createElementBlock("div", mergeProps({ key: 0, "class": [_ctx.cx('mask'), _ctx.maskClass], style: _ctx.maskStyle }, _ctx.ptm('mask')), null, 16)) : createCommentVNode("", true)], 64); } script.render = render; export { script as default }; //# sourceMappingURL=index.mjs.map