| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  | // TODO: META-8742 Add this as a component in the Nacho Component library as part of NachoHoverDropdown
 | 
					
						
							|  |  |  | import Component from '@ember/component'; | 
					
						
							|  |  |  | // @ts-ignore: Ignore import of compiled template
 | 
					
						
							|  |  |  | import template from '../../templates/components/nacho-hover-dropdown/dropdown-option'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-20 10:26:02 -07:00
										 |  |  | import { INachoDropdownOption } from '@nacho-ui/core/types/nacho-dropdown'; | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | import { tagName, classNames, className, layout } from '@ember-decorators/component'; | 
					
						
							|  |  |  | import { equal } from '@ember/object/computed'; | 
					
						
							| 
									
										
										
										
											2020-11-09 12:17:51 -08:00
										 |  |  | import { noop } from 'lodash-es'; | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | @tagName('li') | 
					
						
							|  |  |  | @layout(template) | 
					
						
							|  |  |  | @classNames('nacho-drop-down__options__option') | 
					
						
							|  |  |  | export default class NachoHoverDropdownDropdownOption<T> extends Component { | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * External action invoked when a INachoDropdownOption<T> instance is selected | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   onSelect: (option: INachoDropdownOption<T>) => void = noop; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Computed flag indicating if this option is an equal reference to the selectedOption | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   @className('nacho-drop-down__options__option--selected') | 
					
						
							|  |  |  |   @equal('option', 'selectedOption') | 
					
						
							|  |  |  |   isSelected?: boolean; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * References the drop-down option passed in to this component | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   option?: INachoDropdownOption<T>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * References the selected drop-down option to determine is this option is the selected value | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   selectedOption?: INachoDropdownOption<T>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Invokes the external action onSelect when this component's click event is triggered | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   click(): void { | 
					
						
							|  |  |  |     this.option && this.onSelect(this.option); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |