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

173 lines (167 loc) 6.99 kB
import CheckIcon from 'primevue/icons/check'; import ExclamationTriangleIcon from 'primevue/icons/exclamationtriangle'; import InfoCircleIcon from 'primevue/icons/infocircle'; import TimesIcon from 'primevue/icons/times'; import TimesCircleIcon from 'primevue/icons/timescircle'; import Ripple from 'primevue/ripple'; import BaseComponent from 'primevue/basecomponent'; import MessageStyle from 'primevue/message/style'; import { resolveComponent, resolveDirective, openBlock, createBlock, Transition, mergeProps, withCtx, withDirectives, createElementVNode, renderSlot, createElementBlock, resolveDynamicComponent, createCommentVNode, vShow } from 'vue'; var script$1 = { name: 'BaseMessage', "extends": BaseComponent, props: { severity: { type: String, "default": 'info' }, closable: { type: Boolean, "default": true }, sticky: { type: Boolean, "default": true }, life: { type: Number, "default": 3000 }, icon: { type: String, "default": undefined }, closeIcon: { type: String, "default": undefined }, closeButtonProps: { type: null, "default": null } }, style: MessageStyle, provide: function provide() { return { $parentInstance: this }; } }; var script = { name: 'Message', "extends": script$1, emits: ['close'], timeout: null, data: function data() { return { visible: true }; }, watch: { sticky: function sticky(newValue) { if (!newValue) { this.closeAfterDelay(); } } }, mounted: function mounted() { if (!this.sticky) { this.closeAfterDelay(); } }, methods: { close: function close(event) { this.visible = false; this.$emit('close', event); }, closeAfterDelay: function closeAfterDelay() { var _this = this; setTimeout(function () { _this.visible = false; }, this.life); } }, computed: { iconComponent: function iconComponent() { return { info: InfoCircleIcon, success: CheckIcon, warn: ExclamationTriangleIcon, error: TimesCircleIcon }[this.severity]; }, closeAriaLabel: function closeAriaLabel() { return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.close : undefined; } }, directives: { ripple: Ripple }, components: { TimesIcon: TimesIcon, InfoCircleIcon: InfoCircleIcon, CheckIcon: CheckIcon, ExclamationTriangleIcon: ExclamationTriangleIcon, TimesCircleIcon: TimesCircleIcon } }; 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), !0).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(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(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 || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } var _hoisted_1 = ["aria-label"]; function render(_ctx, _cache, $props, $setup, $data, $options) { var _component_TimesIcon = resolveComponent("TimesIcon"); var _directive_ripple = resolveDirective("ripple"); return openBlock(), createBlock(Transition, mergeProps({ name: "p-message", appear: "" }, _ctx.ptm('transition')), { "default": withCtx(function () { return [withDirectives(createElementVNode("div", mergeProps({ "class": _ctx.cx('root'), role: "alert", "aria-live": "assertive", "aria-atomic": "true" }, _ctx.ptm('root'), { "data-pc-name": "message" }), [_ctx.$slots.container ? renderSlot(_ctx.$slots, "container", { key: 0, onClose: $options.close, closeCallback: $options.close }) : (openBlock(), createElementBlock("div", mergeProps({ key: 1, "class": _ctx.cx('wrapper') }, _ctx.ptm('wrapper')), [renderSlot(_ctx.$slots, "messageicon", { "class": "p-message-icon" }, function () { return [(openBlock(), createBlock(resolveDynamicComponent(_ctx.icon ? 'span' : $options.iconComponent), mergeProps({ "class": [_ctx.cx('icon'), _ctx.icon] }, _ctx.ptm('icon')), null, 16, ["class"]))]; }), createElementVNode("div", mergeProps({ "class": ["p-message-text", _ctx.cx('text')] }, _ctx.ptm('text')), [renderSlot(_ctx.$slots, "default")], 16), _ctx.closable ? withDirectives((openBlock(), createElementBlock("button", mergeProps({ key: 0, "class": _ctx.cx('closeButton'), "aria-label": $options.closeAriaLabel, type: "button", onClick: _cache[0] || (_cache[0] = function ($event) { return $options.close($event); }) }, _objectSpread(_objectSpread(_objectSpread({}, _ctx.closeButtonProps), _ctx.ptm('button')), _ctx.ptm('closeButton'))), [renderSlot(_ctx.$slots, "closeicon", {}, function () { return [_ctx.closeIcon ? (openBlock(), createElementBlock("i", mergeProps({ key: 0, "class": [_ctx.cx('closeIcon'), _ctx.closeIcon] }, _objectSpread(_objectSpread({}, _ctx.ptm('buttonIcon')), _ctx.ptm('closeIcon'))), null, 16)) : (openBlock(), createBlock(_component_TimesIcon, mergeProps({ key: 1, "class": [_ctx.cx('closeIcon'), _ctx.closeIcon] }, _objectSpread(_objectSpread({}, _ctx.ptm('buttonIcon')), _ctx.ptm('closeIcon'))), null, 16, ["class"]))]; })], 16, _hoisted_1)), [[_directive_ripple]]) : createCommentVNode("", true)], 16))], 16), [[vShow, $data.visible]])]; }), _: 3 }, 16); } script.render = render; export { script as default };