UNPKG

accessibleprimevue

Version:

Note: This is the forked version of the Primefaces/PrimeVue repository. Since V3 has reached its EOL this is use to fix identified accessibility bugs in the v3 version of primevue. PrimeVue is an open source UI library for Vue featuring a rich set of 80+

186 lines (177 loc) 7.97 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, inheritAttrs: false, emits: ['close', 'life-end'], 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.$emit('life-end'); }, 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.ptmi('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')), [_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;