computer-scienceangular-roadmapbackend-roadmapblockchain-roadmapdba-roadmapdeveloper-roadmapdevops-roadmapfrontend-roadmapgo-roadmaphactoberfestjava-roadmapjavascript-roadmapnodejs-roadmappython-roadmapqa-roadmapreact-roadmaproadmapstudy-planvue-roadmapweb3-roadmap
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
31 lines
780 B
31 lines
780 B
import { useEffect } from 'react'; |
|
import type { ResourceType } from '../lib/resource-progress'; |
|
|
|
type CallbackType = (data: { |
|
resourceType: ResourceType; |
|
resourceId: string; |
|
topicId: string; |
|
}) => void; |
|
|
|
export function useToggleTopic(callback: CallbackType) { |
|
useEffect(() => { |
|
function handleToggleTopic(e: any) { |
|
const { resourceType, resourceId, topicId } = e.detail; |
|
|
|
callback({ |
|
resourceType, |
|
resourceId, |
|
topicId, |
|
}); |
|
} |
|
|
|
window.addEventListener(`roadmap.topic.toggle`, handleToggleTopic); |
|
window.addEventListener(`best-practice.topic.toggle`, handleToggleTopic); |
|
return () => { |
|
window.removeEventListener( |
|
`best-practice.topic.toggle`, |
|
handleToggleTopic |
|
); |
|
}; |
|
}, []); |
|
}
|
|
|