The best way to change the overall look and feel of the OpenBMC Web UI is to update the following files in a downstream repository. This section discusses the structure and purpose of the theme files and how to customize the application using Bootstrap theming.
Read more about Bootstrap Theming
.
├─ src
   ├─ assets
      ├─ styles
         ├─ bmc
            ├─ custom
            └─ helpers
         ├─ bootstrap
         ├─ _helpers.scss
         └─ _obmc-custom.scss
This folder contains Sass helpers and default styles for customizing the OpenBMC Web UI.
.
├─ src
   ├─ assets
      ├─ styles
         ├─ bmc
            ├─ custom
               ├─ alert.scss
               ├─ _badge.scss
               ├─ _base.scss
               ├─ _bootstrap-grid.scss
               ├─ _buttons.scss
               ├─ _calendar.scss
               ├─ _dropdown.scss
               ├─ _forms.scss
               ├─ _index.scss
               ├─ _modal.scss
               ├─ _pagination.scss
               ├─ _tables.scss
               └─ _toasts.scss
            └─  helpers
               ├─ _colors.scss
               ├─ _index.scss
               ├─ _motion.scss
               └─ _variables.scss
The custom directory imports all the styles needed to customize the UI. These are small changes used to reach parity with the OpenBMC Design Workgroup's agreed-upon design. The file naming convention closely follows the Bootstrap or Boostrap-vue library file naming since most of the ruleset selectors in these files are based on these two libraries.
The helper's folder contains a set of Sass helper files containing Sass variables that establish the custom theme of the application.
The colors.scss file sets all the SASS variables and color maps for the OpenBMC Web UI. Any color settings needed to meet company brand guidelines will happen in this file.
$black: #000; $white: #fff; $blue-100: #eff2fb; $blue-500: #2d60e5; $green-100: #ecfdf1; $green-500: #0a7d06; $red-100: #feeeed; $red-500: #da1416; $yellow-100: #fff8e4; $yellow-500: #efc100; $gray-100: #f4f4f4; $gray-200: #e6e6e6; $gray-300: #d8d8d8; $gray-400: #cccccc; $gray-500: #b3b3b3; $gray-600: #999999; $gray-700: #666666; $gray-800: #3f3f3f; $gray-900: #161616;
// Sass Base Color Variables $blue: $blue-500; $green: $green-500; $red: $red-500; $yellow: $yellow-500;
$colors: ( "blue": $blue, "green": $green, "red": $red, "yellow": $yellow, );
// Sass Theme Color Variables // Can be used as variants $danger: $red; $dark: $gray-900; $info: $blue; $light: $gray-100; $primary: $blue; $secondary: $gray-800; $success: $green; $warning: $yellow; // Sass Color Variable Accents // Used for component styles and are // not available as variants $danger-light: $red-100; $info-light: $blue-100; $warning-light: $yellow-100; $success-light: $green-100;
$theme-colors: ( "primary": $primary, "secondary": $secondary, "dark": $dark, "light": $light, "danger": $danger, "info": $info "success": $success "warning": $warning, );
This bezier curves and durations in this file determine the motion styles throughout the application. These guidelines from the Cabon Design System avoid easing curves that are unnatural, distracting, or purely decorative.
$duration--fast-01: 70ms; //Micro-interactions such as button and toggle $duration--fast-02: 110ms; //Micro-interactions such as fade $duration--moderate-01: 150ms; //Micro-interactions, small expansion, short distance movements $duration--moderate-02: 240ms; //Expansion, system communication, toast $duration--slow-01: 400ms; //Large expansion, important system notifications $duration--slow-02: 700ms; //Background dimming $standard-easing--productive: cubic-bezier(0.2, 0, 0.38, 0.9); $standard-easing--expressive: cubic-bezier(0.4, 0.14, 0.3, 1); $entrance-easing--productive: cubic-bezier(0, 0, 0.38, 0.9); $entrance-easing--expressive: cubic-bezier(0, 0, 0.3, 1); $exit-easing--productive: cubic-bezier(0.2, 0, 1, 0.9); $exit-easing--expressive: cubic-bezier(0.4, 0.14, 1, 1);
.link-skip-nav { position: absolute; top: -60px; left: 0.5rem; z-index: $zindex-popover; transition: $duration--moderate-01 $exit-easing--expressive; &:focus { top: 0.5rem; transition-timing-function: $entrance-easing--expressive; } }
This file contains all the global Sass options. There are Bootstrap option overrides, Bootstrap global variable overrides, and custom BMC global variables. Read more about these in the theme customization section.
The bootstrap directory contains all the import references. The references are split into multiple files to support import order based on dependency. Helper styles need to be imported before all other styles.
.
├─ src
   ├─ assets
      ├─ styles
         ├─ bootstrap
            ├─ _helpers.scss
            └─ _index.scss
This file contains all the helper import references for Bootstrap.
This file contains all the import references needed to support the base, components, and utility styles.
.
├─ src
   ├─ assets
      ├─ styles
         ├─ _helpers.scss
The _helpers.scss file is an import file needed when building single-file components that require the use of BMC or Bootstrap Sass variables and functions. This file needs to be imported as part of the <style> block to support Sass compilation. Although it is possible to prepend these helpers in webpack, it will break any use of imported single-file components used in the Vuepress documentation.
.
├─ src
   ├─ assets
      ├─ styles
         └─ _obmc-custom.scss
The obmc-custom.scss file defines all of the presentational layer dependencies.
Some stylistic changes only apply to a single-file component or view instance. In this case, rather than adding a Sass file, the scoped styles include the styles in the component's <style> block. It is required to import the _helpers Sass file when using a BMC or Bootstrap variable in the component's <style> block. Without this import, webpack cannot  compile the OpenBMC Web UI CSS styles correctly.
<style scoped lang="scss"> ... </style>
<style scoped> ... </style>
<style lang="scss" scoped> .page-section { margin-bottom: $spacer * 2; } h2 { @include font-size($h3-font-size); margin-bottom: $spacer; &::after { content: ''; display: block; width: 100px; border: 1px solid $gray-300; margin-top: 10px; } } </style>
:::tip You might notice that there is an HTML element, <h2>, used in the example. This is an anti-pattern in global .scss files. However, in a single file component that generates the markup it is acceptable. :::