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+
2 lines (1 loc) • 18.6 kB
JavaScript
"use strict";var e=require("primevue/icons/chevrondown"),t=require("primevue/overlayeventbus"),n=require("primevue/portal"),r=require("primevue/ripple"),o=require("primevue/tree"),i=require("primevue/utils"),l=require("primevue/basecomponent"),s=require("primevue/treeselect/style"),a=require("vue");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var d=c(e),u=c(t),p=c(n),f=c(r),h=c(o);function y(e){return y="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},y(e)}function m(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function b(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?m(Object(n),!0).forEach((function(t){v(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):m(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function v(e,t,n){var r;return(t="symbol"==y(r=g(t,"string"))?r:String(r))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function g(e,t){if("object"!=y(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=y(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function S(e,t){var n="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!n){if(Array.isArray(e)||(n=O(e))||t&&e&&"number"==typeof e.length){n&&(e=n);var r=0,o=function(){};return{s:o,n:function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}},e:function(e){throw e},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,l=!0,s=!1;return{s:function(){n=n.call(e)},n:function(){var e=n.next();return l=e.done,e},e:function(e){s=!0,i=e},f:function(){try{l||null==n.return||n.return()}finally{if(s)throw i}}}}function k(){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 O(e,t){if(e){if("string"==typeof e)return C(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?C(e,t):void 0}}function w(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function x(e){if(Array.isArray(e))return C(e)}function C(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}var E={name:"TreeSelect",extends:{name:"BaseTreeSelect",extends:c(l).default,props:{modelValue:null,options:Array,scrollHeight:{type:String,default:"400px"},placeholder:{type:String,default:null},invalid:{type:Boolean,default:!1},variant:{type:String,default:null},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:null},selectionMode:{type:String,default:"single"},appendTo:{type:[String,Object],default:"body"},emptyMessage:{type:String,default:null},display:{type:String,default:"comma"},metaKeySelection:{type:Boolean,default:!1},inputId:{type:String,default:null},inputClass:{type:[String,Object],default:null},inputStyle:{type:Object,default:null},inputProps:{type:null,default:null},panelClass:{type:[String,Object],default:null},panelProps:{type:null,default:null},ariaLabelledby:{type:String,default:null},ariaLabel:{type:String,default:null}},style:c(s).default,provide:function(){return{$parentInstance:this}}},inheritAttrs:!1,emits:["update:modelValue","before-show","before-hide","change","show","hide","node-select","node-unselect","node-expand","node-collapse","focus","blur"],data:function(){return{id:this.$attrs.id,focused:!1,overlayVisible:!1,expandedKeys:{}}},watch:{"$attrs.id":function(e){this.id=e||i.UniqueComponentId()},modelValue:{handler:function(){this.selfChange||this.updateTreeState(),this.selfChange=!1},immediate:!0},options:function(){this.updateTreeState()}},outsideClickListener:null,resizeListener:null,scrollHandler:null,overlay:null,selfChange:!1,selfClick:!1,beforeUnmount:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.overlay&&(i.ZIndexUtils.clear(this.overlay),this.overlay=null)},mounted:function(){this.id=this.id||i.UniqueComponentId(),this.updateTreeState()},methods:{show:function(){this.$emit("before-show"),this.overlayVisible=!0},hide:function(){this.$emit("before-hide"),this.overlayVisible=!1,this.$refs.focusInput.focus()},onFocus:function(e){this.focused=!0,this.$emit("focus",e)},onBlur:function(e){this.focused=!1,this.$emit("blur",e)},onClick:function(e){this.disabled||this.disabled||this.overlay&&this.overlay.contains(e.target)||(this.overlayVisible?this.hide():this.show(),i.DomHandler.focus(this.$refs.focusInput))},onSelectionChange:function(e){this.selfChange=!0,this.$emit("update:modelValue",e),this.$emit("change",e)},onNodeSelect:function(e){this.$emit("node-select",e),"single"===this.selectionMode&&this.hide()},onNodeUnselect:function(e){this.$emit("node-unselect",e)},onNodeToggle:function(e){this.expandedKeys=e},onFirstHiddenFocus:function(e){var t=e.relatedTarget===this.$refs.focusInput?i.DomHandler.getFirstFocusableElement(this.overlay,':not([data-p-hidden-focusable="true"])'):this.$refs.focusInput;i.DomHandler.focus(t)},onLastHiddenFocus:function(e){var t=e.relatedTarget===this.$refs.focusInput?i.DomHandler.getLastFocusableElement(this.overlay,':not([data-p-hidden-focusable="true"])'):this.$refs.focusInput;i.DomHandler.focus(t)},onKeyDown:function(e){switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"Space":case"Enter":case"NumpadEnter":this.onEnterKey(e);break;case"Escape":this.onEscapeKey(e);break;case"Tab":this.onTabKey(e)}},onArrowDownKey:function(e){var t=this;this.overlayVisible||(this.show(),this.$nextTick((function(){var e,n=i.DomHandler.find(t.$refs.tree.$el,'[data-pc-section="treeitem"]'),r=(e=n,x(e)||w(e)||O(e)||k()).find((function(e){return"0"===e.getAttribute("tabindex")}));i.DomHandler.focus(r)})),e.preventDefault())},onEnterKey:function(e){this.overlayVisible?this.hide():this.onArrowDownKey(e),e.preventDefault()},onEscapeKey:function(e){this.overlayVisible&&(this.hide(),e.preventDefault())},onTabKey:function(e){arguments.length>1&&void 0!==arguments[1]&&arguments[1]||this.overlayVisible&&this.hasFocusableElements()&&(i.DomHandler.focus(this.$refs.firstHiddenFocusableElementOnOverlay),e.preventDefault())},hasFocusableElements:function(){return i.DomHandler.getFocusableElements(this.overlay,':not([data-p-hidden-focusable="true"])').length>0},onOverlayEnter:function(e){i.ZIndexUtils.set("overlay",e,this.$primevue.config.zIndex.overlay),i.DomHandler.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.focus()},onOverlayAfterEnter:function(){this.bindOutsideClickListener(),this.bindScrollListener(),this.bindResizeListener(),this.scrollValueInView(),this.$emit("show")},onOverlayLeave:function(){this.unbindOutsideClickListener(),this.unbindScrollListener(),this.unbindResizeListener(),this.$emit("hide"),this.overlay=null},onOverlayAfterLeave:function(e){i.ZIndexUtils.clear(e)},focus:function(){var e=i.DomHandler.getFocusableElements(this.overlay);e&&e.length>0&&e[0].focus()},alignOverlay:function(){"self"===this.appendTo?i.DomHandler.relativePosition(this.overlay,this.$el):(this.overlay.style.minWidth=i.DomHandler.getOuterWidth(this.$el)+"px",i.DomHandler.absolutePosition(this.overlay,this.$el))},bindOutsideClickListener:function(){var e=this;this.outsideClickListener||(this.outsideClickListener=function(t){e.overlayVisible&&!e.selfClick&&e.isOutsideClicked(t)&&e.hide(),e.selfClick=!1},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener:function(){var e=this;this.scrollHandler||(this.scrollHandler=new i.ConnectedOverlayScrollHandler(this.$refs.container,(function(){e.overlayVisible&&e.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener:function(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(){e.overlayVisible&&!i.DomHandler.isTouchDevice()&&e.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},isOutsideClicked:function(e){return!(this.$el.isSameNode(e.target)||this.$el.contains(e.target)||this.overlay&&this.overlay.contains(e.target))},overlayRef:function(e){this.overlay=e},onOverlayClick:function(e){u.default.emit("overlay-click",{originalEvent:e,target:this.$el}),this.selfClick=!0},onOverlayKeydown:function(e){"Escape"===e.code&&this.hide()},findSelectedNodes:function(e,t,n){if(e){if(this.isSelected(e,t)&&(n.push(e),delete t[e.key]),Object.keys(t).length&&e.children){var r,o=S(e.children);try{for(o.s();!(r=o.n()).done;){this.findSelectedNodes(r.value,t,n)}}catch(e){o.e(e)}finally{o.f()}}}else{var i,l=S(this.options);try{for(l.s();!(i=l.n()).done;){this.findSelectedNodes(i.value,t,n)}}catch(e){l.e(e)}finally{l.f()}}},isSelected:function(e,t){return"checkbox"===this.selectionMode?t[e.key]&&t[e.key].checked:t[e.key]},updateTreeState:function(){var e=b({},this.modelValue);this.expandedKeys={},e&&this.options&&this.updateTreeBranchState(null,null,e)},updateTreeBranchState:function(e,t,n){if(e){if(this.isSelected(e,n)&&(this.expandPath(t),delete n[e.key]),Object.keys(n).length&&e.children){var r,o=S(e.children);try{for(o.s();!(r=o.n()).done;){var i=r.value;t.push(e.key),this.updateTreeBranchState(i,t,n)}}catch(e){o.e(e)}finally{o.f()}}}else{var l,s=S(this.options);try{for(s.s();!(l=s.n()).done;){this.updateTreeBranchState(l.value,[],n)}}catch(e){s.e(e)}finally{s.f()}}},expandPath:function(e){if(e.length>0){var t,n=S(e);try{for(n.s();!(t=n.n()).done;){this.expandedKeys[t.value]=!0}}catch(e){n.e(e)}finally{n.f()}}},scrollValueInView:function(){if(this.overlay){var e=i.DomHandler.findSingle(this.overlay,'[data-p-highlight="true"]');e&&e.scrollIntoView({block:"nearest",inline:"start"})}}},computed:{selectedNodes:function(){var e=[];if(this.modelValue&&this.options){var t=b({},this.modelValue);this.findSelectedNodes(null,t,e)}return e},label:function(){var e=this.selectedNodes;return e.length?e.map((function(e){return e.label})).join(", "):this.placeholder},emptyMessageText:function(){return this.emptyMessage||this.$primevue.config.locale.emptyMessage},emptyValue:function(){return!this.modelValue||0===Object.keys(this.modelValue).length},emptyOptions:function(){return!this.options||0===this.options.length},listId:function(){return this.id+"_list"}},components:{TSTree:h.default,Portal:p.default,ChevronDownIcon:d.default},directives:{ripple:f.default}};function L(e){return L="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},L(e)}function V(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function P(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?V(Object(n),!0).forEach((function(t){N(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):V(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function N(e,t,n){var r;return(t="symbol"==L(r=$(t,"string"))?r:String(r))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function $(e,t){if("object"!=L(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=L(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}var D=["id","disabled","tabindex","aria-labelledby","aria-label","aria-expanded","aria-controls"],j=["aria-expanded"];E.render=function(e,t,n,r,o,i){var l=a.resolveComponent("TSTree"),s=a.resolveComponent("Portal");return a.openBlock(),a.createElementBlock("div",a.mergeProps({ref:"container",class:e.cx("root"),style:e.sx("root"),onClick:t[9]||(t[9]=function(){return i.onClick&&i.onClick.apply(i,arguments)})},e.ptmi("root")),[a.createElementVNode("div",a.mergeProps({class:"p-hidden-accessible"},e.ptm("hiddenInputWrapper"),{"data-p-hidden-accessible":!0}),[a.createElementVNode("input",a.mergeProps({ref:"focusInput",id:e.inputId,type:"text",role:"combobox",class:e.inputClass,style:e.inputStyle,readonly:"",disabled:e.disabled,tabindex:e.disabled?-1:e.tabindex,"aria-labelledby":e.ariaLabelledby,"aria-label":e.ariaLabel,"aria-haspopup":"tree","aria-expanded":o.overlayVisible,"aria-controls":i.listId,onFocus:t[0]||(t[0]=function(e){return i.onFocus(e)}),onBlur:t[1]||(t[1]=function(e){return i.onBlur(e)}),onKeydown:t[2]||(t[2]=function(e){return i.onKeyDown(e)})},P(P({},e.inputProps),e.ptm("hiddenInput"))),null,16,D)],16),a.createElementVNode("div",a.mergeProps({class:e.cx("labelContainer")},e.ptm("labelContainer")),[a.createElementVNode("div",a.mergeProps({class:e.cx("label")},e.ptm("label")),[a.renderSlot(e.$slots,"value",{value:i.selectedNodes,placeholder:e.placeholder},(function(){return["comma"===e.display?(a.openBlock(),a.createElementBlock(a.Fragment,{key:0},[a.createTextVNode(a.toDisplayString(i.label||"empty"),1)],64)):"chip"===e.display?(a.openBlock(),a.createElementBlock(a.Fragment,{key:1},[(a.openBlock(!0),a.createElementBlock(a.Fragment,null,a.renderList(i.selectedNodes,(function(t){return a.openBlock(),a.createElementBlock("div",a.mergeProps({key:t.key,class:e.cx("token")},e.ptm("token")),[a.createElementVNode("span",a.mergeProps({class:e.cx("tokenLabel")},e.ptm("tokenLabel")),a.toDisplayString(t.label),17)],16)})),128)),i.emptyValue?(a.openBlock(),a.createElementBlock(a.Fragment,{key:0},[a.createTextVNode(a.toDisplayString(e.placeholder||"empty"),1)],64)):a.createCommentVNode("",!0)],64)):a.createCommentVNode("",!0)]}))],16)],16),a.createElementVNode("div",a.mergeProps({class:e.cx("trigger"),role:"button","aria-haspopup":"tree","aria-expanded":o.overlayVisible},e.ptm("trigger")),[a.renderSlot(e.$slots,"triggericon",{class:a.normalizeClass(e.cx("triggerIcon"))},(function(){return[(a.openBlock(),a.createBlock(a.resolveDynamicComponent("ChevronDownIcon"),a.mergeProps({class:e.cx("triggerIcon")},e.ptm("triggerIcon")),null,16,["class"]))]}))],16,j),a.createVNode(s,{appendTo:e.appendTo},{default:a.withCtx((function(){return[a.createVNode(a.Transition,a.mergeProps({name:"p-connected-overlay",onEnter:i.onOverlayEnter,onAfterEnter:i.onOverlayAfterEnter,onLeave:i.onOverlayLeave,onAfterLeave:i.onOverlayAfterLeave},e.ptm("transition")),{default:a.withCtx((function(){return[o.overlayVisible?(a.openBlock(),a.createElementBlock("div",a.mergeProps({key:0,ref:i.overlayRef,onClick:t[7]||(t[7]=function(){return i.onOverlayClick&&i.onOverlayClick.apply(i,arguments)}),class:[e.cx("panel"),e.panelClass],onKeydown:t[8]||(t[8]=function(){return i.onOverlayKeydown&&i.onOverlayKeydown.apply(i,arguments)})},P(P({},e.panelProps),e.ptm("panel"))),[a.createElementVNode("span",a.mergeProps({ref:"firstHiddenFocusableElementOnOverlay",role:"presentation","aria-hidden":"true",class:"p-hidden-accessible p-hidden-focusable",tabindex:0,onFocus:t[3]||(t[3]=function(){return i.onFirstHiddenFocus&&i.onFirstHiddenFocus.apply(i,arguments)})},e.ptm("hiddenFirstFocusableEl"),{"data-p-hidden-accessible":!0,"data-p-hidden-focusable":!0}),null,16),a.renderSlot(e.$slots,"header",{value:e.modelValue,options:e.options}),a.createElementVNode("div",a.mergeProps({class:e.cx("wrapper"),style:{"max-height":e.scrollHeight}},e.ptm("wrapper")),[a.createVNode(l,{ref:"tree",id:i.listId,value:e.options,selectionMode:e.selectionMode,"onUpdate:selectionKeys":i.onSelectionChange,selectionKeys:e.modelValue,expandedKeys:o.expandedKeys,"onUpdate:expandedKeys":i.onNodeToggle,metaKeySelection:e.metaKeySelection,onNodeExpand:t[4]||(t[4]=function(t){return e.$emit("node-expand",t)}),onNodeCollapse:t[5]||(t[5]=function(t){return e.$emit("node-collapse",t)}),onNodeSelect:i.onNodeSelect,onNodeUnselect:i.onNodeUnselect,level:0,unstyled:e.unstyled,pt:e.ptm("tree")},a.createSlots({_:2},[e.$slots.itemtogglericon?{name:"togglericon",fn:a.withCtx((function(t){return[a.renderSlot(e.$slots,"itemtogglericon",{node:t.node,expanded:t.expanded,class:a.normalizeClass(t.class)})]})),key:"0"}:void 0,e.$slots.itemcheckboxicon?{name:"checkboxicon",fn:a.withCtx((function(t){return[a.renderSlot(e.$slots,"itemcheckboxicon",{checked:t.checked,partialChecked:t.partialChecked,class:a.normalizeClass(t.class)})]})),key:"1"}:void 0]),1032,["id","value","selectionMode","onUpdate:selectionKeys","selectionKeys","expandedKeys","onUpdate:expandedKeys","metaKeySelection","onNodeSelect","onNodeUnselect","unstyled","pt"]),i.emptyOptions?(a.openBlock(),a.createElementBlock("div",a.mergeProps({key:0,class:e.cx("emptyMessage")},e.ptm("emptyMessage")),[a.renderSlot(e.$slots,"empty",{},(function(){return[a.createTextVNode(a.toDisplayString(i.emptyMessageText),1)]}))],16)):a.createCommentVNode("",!0)],16),a.renderSlot(e.$slots,"footer",{value:e.modelValue,options:e.options}),a.createElementVNode("span",a.mergeProps({ref:"lastHiddenFocusableElementOnOverlay",role:"presentation","aria-hidden":"true",class:"p-hidden-accessible p-hidden-focusable",tabindex:0,onFocus:t[6]||(t[6]=function(){return i.onLastHiddenFocus&&i.onLastHiddenFocus.apply(i,arguments)})},e.ptm("hiddenLastFocusableEl"),{"data-p-hidden-accessible":!0,"data-p-hidden-focusable":!0}),null,16)],16)):a.createCommentVNode("",!0)]})),_:3},16,["onEnter","onAfterEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo"])],16)},module.exports=E;