UNPKG

primevue

Version:

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) [![npm version](https://badge.fury.io/js/primevue.svg)](https://badge.fury.io/js/primevue) [![Discord Chat](https://img.shields.io/discord/55794023

2 lines (1 loc) 2.96 kB
import e from"primevue/basecomponent";import l from"primevue/icons/check";import i from"primevue/icons/times";import{openBlock as a,createElementBlock as o,mergeProps as t,createElementVNode as c,toDisplayString as n,renderSlot as s,createBlock as d,resolveDynamicComponent as u}from"vue";var p={name:"TriStateCheckbox",extends:e,emits:["click","update:modelValue","change","keydown","focus","blur"],props:{modelValue:null,inputId:{type:String,default:null},inputProps:{type:null,default:null},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:0},"aria-labelledby":{type:String,default:null},"aria-label":{type:String,default:null}},data:()=>({focused:!1}),methods:{getPTOptions(e){return this.ptm(e,{context:{active:null!==this.modelValue,focused:this.focused,disabled:this.disabled}})},updateModel(){if(!this.disabled){let e;switch(this.modelValue){case!0:e=!1;break;case!1:e=null;break;default:e=!0}this.$emit("update:modelValue",e)}},onClick(e){this.updateModel(),this.$emit("click",e),this.$emit("change",e),this.$refs.input.focus()},onKeyDown(e){"Enter"===e.code&&(this.updateModel(),this.$emit("keydown",e),e.preventDefault())},onFocus(e){this.focused=!0,this.$emit("focus",e)},onBlur(e){this.focused=!1,this.$emit("blur",e)}},computed:{containerClass(){return["p-checkbox p-component",{"p-checkbox-checked":!0===this.modelValue,"p-checkbox-disabled":this.disabled,"p-checkbox-focused":this.focused}]},ariaValueLabel(){return this.modelValue?this.$primevue.config.locale.aria.trueLabel:!1===this.modelValue?this.$primevue.config.locale.aria.falseLabel:this.$primevue.config.locale.aria.nullLabel}},components:{CheckIcon:l,TimesIcon:i}};const r=["id","checked","tabindex","disabled","aria-labelledby","aria-label"];p.render=function(e,l,i,p,h,b){return a(),o("div",t({class:b.containerClass,onClick:l[3]||(l[3]=e=>b.onClick(e))},e.ptm("root")),[c("div",t({class:"p-hidden-accessible"},e.ptm("hiddenInputWrapper")),[c("input",t({ref:"input",id:i.inputId,type:"checkbox",checked:!0===i.modelValue,tabindex:i.tabindex,disabled:i.disabled,"aria-labelledby":e.ariaLabelledby,"aria-label":e.ariaLabel,onKeydown:l[0]||(l[0]=e=>b.onKeyDown(e)),onFocus:l[1]||(l[1]=e=>b.onFocus(e)),onBlur:l[2]||(l[2]=e=>b.onBlur(e))},{...i.inputProps,...e.ptm("hiddenInput")}),null,16,r)],16),c("span",t({class:"p-sr-only","aria-live":"polite"},e.ptm("srOnlyAria")),n(b.ariaValueLabel),17),c("div",t({ref:"box",class:["p-checkbox-box",{"p-highlight":null!=i.modelValue,"p-disabled":i.disabled,"p-focus":h.focused}]},b.getPTOptions("checbox")),[!0===i.modelValue?s(e.$slots,"checkicon",{key:0},(()=>[(a(),d(u("CheckIcon"),t({class:"p-checkbox-icon"},e.ptm("checkIcon")),null,16))])):!1===i.modelValue?s(e.$slots,"uncheckicon",{key:1},(()=>[(a(),d(u("TimesIcon"),t({class:"p-checkbox-icon"},e.ptm("uncheckIcon")),null,16))])):s(e.$slots,"nullableicon",{key:2},(()=>[c("span",t({class:"p-checkbox-icon"},e.ptm("nullableIcon")),null,16)]))],16)],16)};export{p as default};