mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-10-29 12:41:10 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			36 lines
		
	
	
		
			565 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			565 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { ref, toRefs } from 'vue'
 | |
| 
 | |
| export default function useDropdown(props, context, dep) {
 | |
|   const { disabled } = toRefs(props)
 | |
| 
 | |
|   // ================ DATA ================
 | |
| 
 | |
|   const isOpen = ref(false)
 | |
| 
 | |
|   // =============== METHODS ==============
 | |
| 
 | |
|   const open = () => {
 | |
|     if (isOpen.value || disabled.value) {
 | |
|       return
 | |
|     }
 | |
| 
 | |
|     isOpen.value = true
 | |
|     context.emit('open')
 | |
|   }
 | |
| 
 | |
|   const close = () => {
 | |
|     if (!isOpen.value) {
 | |
|       return
 | |
|     }
 | |
| 
 | |
|     isOpen.value = false
 | |
|     context.emit('close')
 | |
|   }
 | |
| 
 | |
|   return {
 | |
|     isOpen,
 | |
|     open,
 | |
|     close,
 | |
|   }
 | |
| }
 |