summaryrefslogtreecommitdiff
path: root/source/features/close-out-of-view-modals.tsx
blob: 3de7c8d4ac41b1f51640470f7c8db4b12d68297d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
import features from '.';

const observer = new IntersectionObserver(([{intersectionRatio, target}]) => {
	if (intersectionRatio === 0) {
		observer.unobserve(target);
		target.closest('details')!.open = false;
	}
});

function menuActivatedHandler(event: CustomEvent): void {
	const details = event.target as HTMLElement;
	const modalBox = details.querySelector('details-menu')!;

	// Avoid silently breaking the interface: #2701
	if (modalBox.getBoundingClientRect().width === 0) {
		features.error(__filebasename, 'Modal element was not correctly detected for', details);
	} else {
		observer.observe(modalBox);
	}
}

function init(): void {
	document.addEventListener('menu:activated', menuActivatedHandler);
}

void features.add({
	id: __filebasename,
	description: 'Automatically closes dropdown menus when they’re no longer visible.',
	screenshot: 'https://user-images.githubusercontent.com/1402241/37022353-531c676e-2155-11e8-96cc-80d934bb22e0.gif'
}, {
	waitForDomReady: false,
	init
});