@twohundredcouches/dark-mode

1.1.1 • Public • Published

dark-mode

Table of Contents

Features

  • automatically adds a dark mode widget
  • detects OS
  • can be used programmatically without widget
  • remembers selection

Install

npm

npm install @twohundredcouches/dark-mode

yarn

yarn add @twohundredcouches/dark-mode

Usage

import DarkMode from "@twohundredcouches/dark-mode";

new DarkMode();

or

<script src="path/to/dark-mode.js"></script>
<script>
    new DarkMode();
</script>

Options

const DefaultOptions = {
    container: 'body',
    darkModeClassName: 'dark-mode-active',
    lightModeClassName: null,
    defaultDarkMode: false,
    remember: true,
    usePrefersColorScheme: true,
    widgetContainer: 'body',
    widgetClassName: 'dark-mode-widget',
    widgetBackgroundLight: '#aaa',
    widgetBackgroundDark: '#000',
    widgetToggleLight: '#fff',
    widgetToggleDark: '#fff',
    widgetSize: 3,
    widgetTransitionDuration: '0.1s',
    hideWidget: false,
    ariaLabelText: 'Toggle Dark Mode',
}

container

Type: String Default: 'body'

Query Selector for the element that dark mode will be applied to.

darkModeClassName

Type: String Default: 'dark-mode-active'

The name of the class that will be applied to the container element when dark mode is activated.

lightModeClassName

Type: String Default: null

The name of the class that will be applied to the container element when light mode is activated.

defaultDarkMode

Type: Boolean Default: false

If true start in dark mode by default.

This setting will only be applied when no active mode was stored to localstorage and no preferred color is set.

remember

Type: Boolean Default: true

If true the selected mode will be stored in localstorage.

usePrefersColorScheme

Type: Boolean Default: true

If true the prefers-color-scheme media feature will be used to set the default mode.

This setting will only be applied when no active mode was stored to localstorage.

widgetClassName

Type: String Default: 'dark-mode-widget'

Name of the class, that is given to the container element of the widget. Useful when the default class name conflicts with your naming conventions (or when you just like naming thinkgs).

useStyle

Type: Boolean Default: true

If false no styling for the widget will be added. You will get a plain old checkbox. Useful if you want to do all styling yourself. If hideWidget is true styles won't be added regardless of this option.

widgetBackgroundLight

Type: String Default: '#aaa'

The background color of the widget in light mode.

widgetBackgroundDark

Type: String Default: '#000'

The background color of the widget in dark mode.

widgetToggleLight

Type: String Default: '#fff'

The color of the widget toggle in light mode.

widgetToggleDark

Type: String Default: '#fff'

The color of the widget toggle in dark mode.

widgetSize

Type: Number Default: 3

The width of the widget in rem. The height is calculated in relation to this value.

widgetTransitionDuration

Type: String Default: 0.1s

The duration for the widget transition. Takes any valid value for transition-duration CSS property.

hideWidget

Type: Boolean Default: false

If true the widget will not be rendered.

Use this option, when you want to fully customize a dark mode toggle and/or set the active mode programmatically.

ariaLabelText

Type: String Default: Toggle Dark Mode

Aria label for screen readers and accessibility. Won't be visible unless you have useStyle set to false.

Methods

toggle()

Return: none

Toggles dark mode.

on()

Return: none

Enables dark mode.

off()

Return: none

Disables dark mode.

setMode(mode)

Return: none

Set mode to light or dark.

mode

Type: 'String' Default: null

Required. Must be either light or dark

getMode()

Return: String

Returns active mode (light or dark).

Events

darkModeChanged

Dispatched from container element when dark mode is manually or programmatically enabled or disabled.

Has active mode in default property of the event object.

Testing

Run tests with npm test.

Thanks

I took inspiration from two other javascript dark mode modules:

Check them out, they're great!

/@twohundredcouches/dark-mode/

    Package Sidebar

    Install

    npm i @twohundredcouches/dark-mode

    Weekly Downloads

    6

    Version

    1.1.1

    License

    MIT

    Unpacked Size

    80.7 kB

    Total Files

    21

    Last publish

    Collaborators

    • twohundredcouches