(callback: (isDark: boolean) => void)
| 8 | const listeners = new Set<(isDark: boolean) => void>(); |
| 9 | |
| 10 | export function runColorSchemeChangeDetector(callback: (isDark: boolean) => void): void { |
| 11 | listeners.add(callback); |
| 12 | if (query) { |
| 13 | return; |
| 14 | } |
| 15 | query = matchMedia('(prefers-color-scheme: dark)'); |
| 16 | if (isMatchMediaChangeEventListenerSupported) { |
| 17 | // MediaQueryList change event is not cancellable and does not bubble |
| 18 | query.addEventListener('change', onChange); |
| 19 | } else { |
| 20 | query.addListener(onChange); |
| 21 | } |
| 22 | } |
| 23 | |
| 24 | export function stopColorSchemeChangeDetector(): void { |
| 25 | if (!query || !onChange) { |
no test coverage detected