UNPKG

vxe-pc-ui

Version:
1 lines 2.56 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _vue=require("vue"),_comp=require("../../ui/src/comp"),_xeUtils=_interopRequireDefault(require("xe-utils")),_utils=require("../../ui/src/utils"),_ui=require("../../ui");function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}var _default=exports.default=(0,_comp.defineVxeComponent)({name:"VxeRadioButton",props:{modelValue:[String,Number,Boolean],checkedValue:{type:[String,Number,Boolean],default:void 0},title:[String,Number],content:[String,Number],disabled:{type:Boolean,default:null},strict:{type:Boolean,default:()=>(0,_ui.getConfig)().radioButton.strict},size:{type:String,default:()=>(0,_ui.getConfig)().radioButton.size||(0,_ui.getConfig)().size},label:{type:[String,Number,Boolean],default:null}},emits:["update:modelValue","change"],setup(i,e){const{slots:n,emit:l}=e,a=(0,_vue.inject)("$xeForm",null),r=(0,_vue.inject)("xeFormItemInfo",null),o=(0,_vue.inject)("$xeRadioGroup",null);var t=_xeUtils.default.uniqueId(),u=(0,_vue.reactive)({});const d=(0,_ui.useSize)(i)["computeSize"];t={xID:t,props:i,context:e,reactData:u};const s=(0,_vue.computed)(()=>{var e,t=i["disabled"];if(null===t&&o)return e=o.getComputeMaps()["computeIsDisabled"],e.value;return t}),c=(0,_vue.computed)(()=>o?o.name:null),p=(0,_vue.computed)(()=>(o?o.props:i).strict),v=(0,_vue.computed)(()=>{var{label:e,checkedValue:t}=i,e=_xeUtils.default.isUndefined(t)?e:t;return o?o.props.modelValue===e:i.modelValue===e}),_=(e,t,u)=>{l(e,(0,_ui.createEvent)(u,{$radioGroup:o},t))};e={dispatchEvent:_};Object.assign(t,e,{});const f=(e,t)=>{var u=i["content"];o?o.handleChecked({label:e,checkedValue:e,checkedLabel:u},t):(l("update:modelValue",e),_("change",{value:e,label:e,checkedValue:e,checkedLabel:u},t),a&&r&&a.triggerItemEvent(t,r.itemConfig.field,e))},m=e=>{var t,u;s.value||({label:u,checkedValue:t}=i,u=_xeUtils.default.isUndefined(t)?u:t,f(u,e))},b=e=>{var t=s.value,u=p.value;t||u||({label:t,checkedValue:u}=i,(_xeUtils.default.isUndefined(u)?t:u)===(o?o.props:i).modelValue&&f(null,e))};u=()=>{var{label:e,checkedValue:t}=i,e=_xeUtils.default.isUndefined(t)?e:t,t=d.value,u=s.value,l=c.value,a=v.value;return(0,_vue.h)("label",{key:e,class:["vxe-radio vxe-radio--button",{["size--"+t]:t,"is--disabled":u}],title:i.title},[(0,_vue.h)("input",{class:"vxe-radio--input",type:"radio",name:l,checked:a,disabled:u,onChange:m,onClick:b}),(0,_vue.h)("span",{class:"vxe-radio--label"},n.default?n.default({}):(0,_utils.getFuncText)(i.content))])};return t.renderVN=u}});