API Reference

<ModeWatcher />

API Reference for the ModeWatcher component.

Usage

Add the ModeWatcher component to your root +layout.svelte component.

src/routes/+layout.svelte
	<script lang="ts">
	import { ModeWatcher } from "mode-watcher";
</script>
 
<ModeWatcher />
<slot />	

The ModeWatcher component will automatically detect the user's preferences and apply/remove the "dark" class, along with the corresponding color-scheme style attribute to the html element.

Disable Tracking

ModeWatcher will automatically track operating system preferences and apply these if no user preference is set. If you wish to disable this behavior, set the track prop to false:

	<ModeWatcher track={false} />	

Default Mode

ModeWatcher can be configured with a default mode instead of automatically detecting the user's preference.

To set a default mode, use the defaultMode prop:

	<ModeWatcher defaultMode="dark" />	

Theme Colors

ModeWatcher can manage the theme-color meta tag for you.

To enable this, set the themeColors prop to your preferred colors:

	<ModeWatcher themeColors={{ dark: "#000", light: "#fff" }} />	

Props

The ModeWatcher component accepts the following props:

	export type Mode = "system" | "dark" | "light";
export type ThemeColors = { dark: string; light: string };
 
export type ModeWatcherProps = {
	/**
	 * Whether to automatically track operating system preferences
	 * and update the mode accordingly.
	 *
	 * @defaultValue `true`
	 */
	track?: boolean;
 
	/**
	 * The default mode to use instead of the user's preference.
	 *
	 * @defaultValue `"system"`
	 */
	defaultMode?: Mode;
 
	/**
	 * The theme colors to use for each mode.
	 *
	 * @defaultValue `undefined`
	 */
	themeColors?: ThemeColors;
 
	/**
	 * Whether to disable transitions when the mode changes.
	 *
	 * @defaultValue `true`
	 */
	disableTransitions?: boolean;
};	
MIT

© 2025 Svecosystem Team