Customization Themes

Themes

@status:warning UPDATED

To style your documentation project, NgDoc provides a theming system that allows you to create your own themes or use one of the themes that come out of the box.

By default, NgDoc has 2 themes, dark and light. You can override them or add your own.

We use CSS variables for theming, so you need to create a CSS file that will override the theme variables.

Overriding theme variables

You can override any CSS variable that is used in the NgDoc application. For example, below is a list of variables that are used in the light theme. they are used for backgrounds, borders etc.

:root {
  --ng-doc-base-0: var(--ng-doc-white);
  --ng-doc-base-1: #f6f6f6;
  --ng-doc-base-2: #ebebeb;
  --ng-doc-base-3: #dedede;
  --ng-doc-base-4: #d1d1d1;
  --ng-doc-base-5: #b8b8b8;
  --ng-doc-base-6: #ababab;
  --ng-doc-base-7: #9e9e9e;
  --ng-doc-base-8: #919191;
  --ng-doc-base-9: #858585;
  --ng-doc-base-10: #6e6e6e;
}

Dark mode

NgDoc has a dark mode theme that you can enable by importing the dark.css file from the @ng-doc/app package.

styles.scss
@import '@ng-doc/app/styles/themes/dark.css';

Auto theme

NgDoc can also switch themes automatically based on the user's OS settings. To enable it, you can call the set method of the NgDocThemeService service with the auto value.

main.ts
@Component({})
export class AppComponent {
  constructor(protected readonly themeService: NgDocThemeService) {}

  setTheme(): void {
    this.themeService.set('auto');
  }
}

Theme by default

In order to set the default theme, you need to add the data-theme attribute to the html element in the index.html file.

index.html
<!doctype html>
<html lang="en" data-theme="dark">
  <head> </head>
  <body></body>
</html>

Code highlighting theme

NgDoc uses the shiki library for code highlighting, it has a lot of ready-made themes, and if you want to use a different code theme for your NgDoc theme, then you can simply configure it.

First, you need to provide the themes in the ng-doc.config.ts file to make them available for the builder.

ng-doc.config.ts
import { NgDocConfiguration } from '@ng-doc/builder';

const config: NgDocConfiguration = {
  shiki: {
    themes: {
      dark: 'material-theme-darker',
      light: 'material-theme-lighter',
    },
  },
};

And as a last step, you need to import and configure them on the client side in the main.ts file.

main.ts
import { bootstrapApplication } from '@angular/platform-browser';
import { provideNgDocApp } from '@ng-doc/app';

import { AppComponent } from './app/app.component';

bootstrapApplication(AppComponent, {
  providers: [
    provideNgDocApp({
      shiki: {
        themes: [
          import('shiki/themes/material-theme-darker.mjs'),
          import('shiki/themes/material-theme-lighter.mjs'),
        ],
        theme: {
          dark: 'material-theme-darker',
          light: 'material-theme-lighter',
        },
      },
    }),
  ],
}).catch((err: unknown) => console.error(err));

Custom theme

Let's say you decided to create your own theme and named it my-theme. You need to create a CSS file that will override the theme variables.

When you enable your theme, NgDoc will set data-theme="my-theme" on the html element. So you need to use this attribute in you theme too.

For example, look at the dark.scss file that is used for the dark theme.

dark.scss
// dark theme
@mixin theme {
  --ng-doc-base-rgb: 43 43 43;
  --ng-doc-base-0: #{darken(#2b2b2b, 5%)};
  --ng-doc-base-1: #{darken(#333333, 5%)};
  --ng-doc-base-2: #{darken(#3a3a3a, 5%)};
  --ng-doc-base-3: #{darken(#424242, 5%)};
  --ng-doc-base-4: #{darken(#4b4b4b, 5%)};
  --ng-doc-base-5: #{darken(#555555, 5%)};
  --ng-doc-base-6: #{darken(#5e5e5e, 5%)};
  --ng-doc-base-7: #{darken(#686868, 5%)};
  --ng-doc-base-8: #{darken(#727272, 5%)};
  --ng-doc-base-9: #{darken(#7d7d7d, 5%)};
  --ng-doc-base-10: #{darken(#888888, 5%)};
  --ng-doc-heading-color: #e3e3e3;
  --ng-doc-text: #a9a9a9;
  --ng-doc-text-muted: var(--ng-doc-base-10);
  --ng-doc-text-selection: rgba(110, 110, 110, 0.81);

  --ng-doc-shadow-color: rgba(0, 0, 0, 0.4);
  --ng-doc-link-color: #30a5ff;
  --ng-doc-inline-code-background: #b9b9b9;

  --ng-doc-primary: #faab00;
  --ng-doc-info: #7095ff;

  --ng-doc-mark-background: rgba(48, 165, 255, 0.3);
  --ng-doc-search-result-color: #c6c6c6;

  --ng-doc-api-tag-background: #ff5959;
  --ng-doc-api-tag-color: var(--ng-doc-base-0);
  --ng-doc-guide-tag-background: #faab00;
  --ng-doc-guide-tag-color: var(--ng-doc-base-0);
  --ng-doc-navbar-border: 1px solid var(--ng-doc-base-4);
}

// shiki theme to match dark theme
@mixin shiki-theme {
  .shiki,
  .shiki span {
    color: var(--shiki-dark) !important;
  }
}

// enable dark theme when using auto theme and prefers-color-scheme is dark
:root[data-theme='auto'] {
  @media (prefers-color-scheme: dark) {
    @include theme();
    @include shiki-theme();
  }
}

// apply dark theme when dark theme is selected
:root[data-theme='dark'] {
  @include theme();
  @include shiki-theme();
}