* Fix issue with closing accordian * Use onSelect * Remove change to AccoridanCard * Fix className typo * Restore conditional
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import Accordion from 'react-bootstrap/Accordion'
 | |
| import AccordionContext from 'react-bootstrap/AccordionContext'
 | |
| import { useAccordionButton } from 'react-bootstrap/AccordionButton'
 | |
| import ArrowRight from '@/svgs/arrow-right-s-fill.svg'
 | |
| import ArrowDown from '@/svgs/arrow-down-s-fill.svg'
 | |
| import { useContext, useEffect, useState } from 'react'
 | |
| 
 | |
| const KEY_ID = '0'
 | |
| 
 | |
| function ContextAwareToggle ({ children, headerColor = 'var(--theme-grey)', eventKey, show }) {
 | |
|   const { activeEventKey } = useContext(AccordionContext)
 | |
|   const decoratedOnClick = useAccordionButton(eventKey)
 | |
| 
 | |
|   useEffect(() => {
 | |
|     // if we want to show the accordian and it's not open, open it
 | |
|     if (show && activeEventKey !== eventKey) {
 | |
|       decoratedOnClick()
 | |
|     }
 | |
|   }, [show])
 | |
| 
 | |
|   const isCurrentEventKey = activeEventKey === eventKey
 | |
| 
 | |
|   return (
 | |
|     <div style={{ cursor: 'pointer', display: 'flex', alignItems: 'center' }} onClick={decoratedOnClick}>
 | |
|       {isCurrentEventKey
 | |
|         ? <ArrowDown style={{ fill: headerColor }} height={20} width={20} />
 | |
|         : <ArrowRight style={{ fill: headerColor }} height={20} width={20} />}
 | |
|       {children}
 | |
|     </div>
 | |
|   )
 | |
| }
 | |
| 
 | |
| export default function AccordianItem ({ header, body, headerColor = 'var(--theme-grey)', show }) {
 | |
|   const [activeKey, setActiveKey] = useState()
 | |
| 
 | |
|   useEffect(() => {
 | |
|     setActiveKey(show ? KEY_ID : null)
 | |
|   }, [show])
 | |
| 
 | |
|   const handleOnSelect = () => {
 | |
|     setActiveKey(activeKey === KEY_ID ? null : KEY_ID)
 | |
|   }
 | |
| 
 | |
|   return (
 | |
|     <Accordion defaultActiveKey={activeKey} activeKey={activeKey} onSelect={handleOnSelect}>
 | |
|       <ContextAwareToggle show={show} eventKey={KEY_ID}><div style={{ color: headerColor }}>{header}</div></ContextAwareToggle>
 | |
|       <Accordion.Collapse eventKey={KEY_ID} className='mt-2'>
 | |
|         <div>{body}</div>
 | |
|       </Accordion.Collapse>
 | |
|     </Accordion>
 | |
|   )
 | |
| }
 | |
| 
 | |
| export function AccordianCard ({ header, children, show }) {
 | |
|   return (
 | |
|     <Accordion defaultActiveKey={show ? '0' : undefined}>
 | |
|       <Accordion.Item eventKey='0'>
 | |
|         <Accordion.Header>{header}</Accordion.Header>
 | |
|         <Accordion.Body>
 | |
|           {children}
 | |
|         </Accordion.Body>
 | |
|       </Accordion.Item>
 | |
|     </Accordion>
 | |
|   )
 | |
| }
 |