vxe-pc-ui
Version:
A vue based PC component library
1 lines • 2.27 kB
JavaScript
;Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _vue=require("vue"),_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,_vue.defineComponent)({name:"VxeRadio",props:{modelValue:[String,Number,Boolean],label:{type:[String,Number,Boolean],default:null},title:[String,Number],content:[String,Number],disabled:{type:Boolean,default:null},name:String,strict:{type:Boolean,default:()=>(0,_ui.getConfig)().radio.strict},size:{type:String,default:()=>(0,_ui.getConfig)().radio.size||(0,_ui.getConfig)().size}},emits:["update:modelValue","change"],setup(i,e){const{slots:r,emit:l}=e,u=(0,_vue.inject)("$xeForm",null),a=(0,_vue.inject)("xeFormItemInfo",null),n=(0,_vue.inject)("$xeRadioGroup",null);var t=_xeUtils.default.uniqueId(),o=(0,_vue.reactive)({});const d={xID:t,props:i,context:e,reactData:o},s=(0,_ui.useSize)(i)["computeSize"],c=(0,_vue.computed)(()=>{var e,t=i["disabled"];if(null===t&&n)return e=n.getComputeMaps()["computeIsDisabled"],e.value;return t}),v=(0,_vue.computed)(()=>(n||i).name),p=(0,_vue.computed)(()=>(n?n.props:i).strict),_=(0,_vue.computed)(()=>{var e=i["label"];return n?n.props.modelValue===e:i.modelValue===e}),m=(e,t)=>{n?n.handleChecked({label:e},t):(l("update:modelValue",e),b("change",{label:e},t),u&&a&&u.triggerItemEvent(t,a.itemConfig.field,e))},f=e=>{c.value||m(i.label,e)},g=e=>{var t=c.value,u=p.value;t||u||i.label===(n?n.props:i).modelValue&&m(null,e)},b=(e,t,u)=>{l(e,(0,_ui.createEvent)(u,{$radio:d},t))};t={dispatchEvent:b};Object.assign(d,t,{});return d.renderVN=()=>{var e=i["label"],t=s.value,u=c.value,l=v.value,a=_.value;return(0,_vue.h)("label",{key:e,class:["vxe-radio",{["size--"+t]:t,"is--checked":a,"is--disabled":u}],title:i.title},[(0,_vue.h)("input",{class:"vxe-radio--input",type:"radio",name:l,checked:a,disabled:u,onChange:f,onClick:g}),(0,_vue.h)("span",{class:["vxe-radio--icon",a?(0,_ui.getIcon)().RADIO_CHECKED:(0,_ui.getIcon)().RADIO_UNCHECKED]}),(0,_vue.h)("span",{class:"vxe-radio--label"},r.default?r.default({}):(0,_utils.getFuncText)(i.content))])},d},render(){return this.renderVN()}});