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

186 lines (177 loc) 7.95 kB
'use strict'; var CheckIcon = require('primevue/icons/check'); var ExclamationTriangleIcon = require('primevue/icons/exclamationtriangle'); var InfoCircleIcon = require('primevue/icons/infocircle'); var TimesIcon = require('primevue/icons/times'); var TimesCircleIcon = require('primevue/icons/timescircle'); var Ripple = require('primevue/ripple'); var BaseComponent = require('primevue/basecomponent'); var MessageStyle = require('primevue/message/style'); var vue = require('vue'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var CheckIcon__default = /*#__PURE__*/_interopDefaultLegacy(CheckIcon); var ExclamationTriangleIcon__default = /*#__PURE__*/_interopDefaultLegacy(ExclamationTriangleIcon); var InfoCircleIcon__default = /*#__PURE__*/_interopDefaultLegacy(InfoCircleIcon); var TimesIcon__default = /*#__PURE__*/_interopDefaultLegacy(TimesIcon); var TimesCircleIcon__default = /*#__PURE__*/_interopDefaultLegacy(TimesCircleIcon); var Ripple__default = /*#__PURE__*/_interopDefaultLegacy(Ripple); var BaseComponent__default = /*#__PURE__*/_interopDefaultLegacy(BaseComponent); var MessageStyle__default = /*#__PURE__*/_interopDefaultLegacy(MessageStyle); var script$1 = { name: 'BaseMessage', "extends": BaseComponent__default["default"], 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__default["default"], 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__default["default"], success: CheckIcon__default["default"], warn: ExclamationTriangleIcon__default["default"], error: TimesCircleIcon__default["default"] }[this.severity]; }, closeAriaLabel: function closeAriaLabel() { return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.close : undefined; } }, directives: { ripple: Ripple__default["default"] }, components: { TimesIcon: TimesIcon__default["default"], InfoCircleIcon: InfoCircleIcon__default["default"], CheckIcon: CheckIcon__default["default"], ExclamationTriangleIcon: ExclamationTriangleIcon__default["default"], TimesCircleIcon: TimesCircleIcon__default["default"] } }; 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 = vue.resolveComponent("TimesIcon"); var _directive_ripple = vue.resolveDirective("ripple"); return vue.openBlock(), vue.createBlock(vue.Transition, vue.mergeProps({ name: "p-message", appear: "" }, _ctx.ptm('transition')), { "default": vue.withCtx(function () { return [vue.withDirectives(vue.createElementVNode("div", vue.mergeProps({ "class": _ctx.cx('root'), role: "alert", "aria-live": "assertive", "aria-atomic": "true" }, _ctx.ptm('root'), { "data-pc-name": "message" }), [_ctx.$slots.container ? vue.renderSlot(_ctx.$slots, "container", { key: 0, onClose: $options.close, closeCallback: $options.close }) : (vue.openBlock(), vue.createElementBlock("div", vue.mergeProps({ key: 1, "class": _ctx.cx('wrapper') }, _ctx.ptm('wrapper')), [vue.renderSlot(_ctx.$slots, "messageicon", { "class": "p-message-icon" }, function () { return [(vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.icon ? 'span' : $options.iconComponent), vue.mergeProps({ "class": [_ctx.cx('icon'), _ctx.icon] }, _ctx.ptm('icon')), null, 16, ["class"]))]; }), vue.createElementVNode("div", vue.mergeProps({ "class": ["p-message-text", _ctx.cx('text')] }, _ctx.ptm('text')), [vue.renderSlot(_ctx.$slots, "default")], 16), _ctx.closable ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("button", vue.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'))), [vue.renderSlot(_ctx.$slots, "closeicon", {}, function () { return [_ctx.closeIcon ? (vue.openBlock(), vue.createElementBlock("i", vue.mergeProps({ key: 0, "class": [_ctx.cx('closeIcon'), _ctx.closeIcon] }, _objectSpread(_objectSpread({}, _ctx.ptm('buttonIcon')), _ctx.ptm('closeIcon'))), null, 16)) : (vue.openBlock(), vue.createBlock(_component_TimesIcon, vue.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]]) : vue.createCommentVNode("", true)], 16))], 16), [[vue.vShow, $data.visible]])]; }), _: 3 }, 16); } script.render = render; module.exports = script;