mirror of
				https://github.com/youzan/vant.git
				synced 2025-10-20 18:54:24 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			87 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * Common part of Checkbox & Radio
 | |
|  */
 | |
| import Icon from '../icon';
 | |
| import { ChildrenMixin } from './relation';
 | |
| import { suffixPx } from '../utils';
 | |
| 
 | |
| export const CheckboxMixin = ({ parent, bem, role }) => ({
 | |
|   mixins: [ChildrenMixin(parent)],
 | |
| 
 | |
|   props: {
 | |
|     name: null,
 | |
|     value: null,
 | |
|     iconSize: [String, Number],
 | |
|     disabled: Boolean,
 | |
|     checkedColor: String,
 | |
|     labelPosition: String,
 | |
|     labelDisabled: Boolean,
 | |
|     shape: {
 | |
|       type: String,
 | |
|       default: 'round'
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   computed: {
 | |
|     isDisabled() {
 | |
|       return (this.parent && this.parent.disabled) || this.disabled;
 | |
|     },
 | |
| 
 | |
|     iconStyle() {
 | |
|       const { checkedColor } = this;
 | |
|       if (checkedColor && this.checked && !this.isDisabled) {
 | |
|         return {
 | |
|           borderColor: checkedColor,
 | |
|           backgroundColor: checkedColor
 | |
|         };
 | |
|       }
 | |
|     },
 | |
| 
 | |
|     tabindex() {
 | |
|       if (this.isDisabled || (role === 'radio' && !this.checked)) {
 | |
|         return -1;
 | |
|       }
 | |
| 
 | |
|       return 0;
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   render(h) {
 | |
|     const { slots, checked } = this;
 | |
| 
 | |
|     const CheckIcon = slots('icon', { checked }) || (
 | |
|       <Icon name="success" style={this.iconStyle} />
 | |
|     );
 | |
| 
 | |
|     const Label = slots() && (
 | |
|       <span
 | |
|         class={bem('label', [this.labelPosition, { disabled: this.isDisabled }])}
 | |
|         onClick={this.onClickLabel}
 | |
|       >
 | |
|         {slots()}
 | |
|       </span>
 | |
|     );
 | |
| 
 | |
|     return (
 | |
|       <div
 | |
|         role={role}
 | |
|         class={bem()}
 | |
|         tabindex={this.tabindex}
 | |
|         aria-checked={String(this.checked)}
 | |
|         onClick={event => {
 | |
|           this.$emit('click', event);
 | |
|         }}
 | |
|       >
 | |
|         <div
 | |
|           class={bem('icon', [this.shape, { disabled: this.isDisabled, checked }])}
 | |
|           style={{ fontSize: suffixPx(this.iconSize) }}
 | |
|           onClick={this.onClickIcon}
 | |
|         >
 | |
|           {CheckIcon}
 | |
|         </div>
 | |
|         {Label}
 | |
|       </div>
 | |
|     );
 | |
|   }
 | |
| });
 | 
