refactor: tidy injections of dropdown
This commit is contained in:
		
							parent
							
								
									4a3cef9a01
								
							
						
					
					
						commit
						ef417f3ccf
					
				
					 5 changed files with 14 additions and 12 deletions
				
			
		|  | @ -1,5 +1,6 @@ | |||
| <script setup lang="ts"> | ||||
| import { dropdownContextKey } from './ctx' | ||||
| import { InjectionKeyDropdownContext } from '~/constants/symbols' | ||||
| 
 | ||||
| defineProps<{ | ||||
|   placement?: string | ||||
| }>() | ||||
|  | @ -8,7 +9,7 @@ const dropdown = $ref<any>() | |||
| const colorMode = useColorMode() | ||||
| 
 | ||||
| const hide = () => dropdown.hide() | ||||
| provide(dropdownContextKey, { | ||||
| provide(InjectionKeyDropdownContext, { | ||||
|   hide, | ||||
| }) | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,6 +1,4 @@ | |||
| <script setup lang="ts"> | ||||
| import { dropdownContextKey } from './ctx' | ||||
| 
 | ||||
| const props = defineProps<{ | ||||
|   text?: string | ||||
|   description?: string | ||||
|  | @ -10,7 +8,7 @@ const props = defineProps<{ | |||
| }>() | ||||
| const emit = defineEmits(['click']) | ||||
| 
 | ||||
| const { hide } = inject(dropdownContextKey, undefined) || {} | ||||
| const { hide } = useDropdownContext() || {} | ||||
| 
 | ||||
| const el = ref<HTMLDivElement>() | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,5 +0,0 @@ | |||
| import type { InjectionKey } from 'vue' | ||||
| 
 | ||||
| export const dropdownContextKey: InjectionKey<{ | ||||
|   hide: () => void | ||||
| }> = Symbol('dropdownContextKey') | ||||
|  | @ -1,5 +1,9 @@ | |||
| import { InjectionKeyFontSize } from '~/constants/symbols' | ||||
| import { InjectionKeyDropdownContext, InjectionKeyFontSize } from '~/constants/symbols' | ||||
| 
 | ||||
| export function useFontSizeRef() { | ||||
|   return inject(InjectionKeyFontSize)! | ||||
| } | ||||
| 
 | ||||
| export function useDropdownContext() { | ||||
|   return inject(InjectionKeyDropdownContext, undefined) | ||||
| } | ||||
|  |  | |||
|  | @ -1,4 +1,8 @@ | |||
| import type { InjectionKey, Ref } from 'vue' | ||||
| import type { FontSize } from '~/types' | ||||
| 
 | ||||
| export const InjectionKeyFontSize = Symbol('font-size') as InjectionKey<Ref<FontSize>> | ||||
| export const InjectionKeyFontSize: InjectionKey<Ref<FontSize>> = Symbol('font-size') | ||||
| 
 | ||||
| export const InjectionKeyDropdownContext: InjectionKey<{ | ||||
|   hide: () => void | ||||
| }> = Symbol('dropdown-context') | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue