If you are using this library and you don't have uswds as an existing dependency in your project, you will need to import the uswds css in the root of your React application. Our library exports a version for this purpose.
import '@trussworks/react-uswds/lib/uswds.css'
import '@trussworks/react-uswds/lib/index.css'
If you already have uswds as a dependency (this is most likely already the case) you only need import '@trussworks/react-uswds/lib/index.css'
in your application.
If you want to use USWDS SCSS (mixins, functions, variables, etc.), you will need to define some required SCSS variables (even if you aren't going to use them):
// your-project/_uswds-theme.scss
@use 'uswds-core' with (
$theme-image-path: '@uswds/uswds/img',
$theme-font-path: '@uswds/uswds/fonts',
$theme-hero-image: '@uswds/uswds/img/hero.png'
);
Then, import the following into your SCSS:
// your-project/index.scss
// Custom theme settings/USWDS overrides go here <-- the settings you defined above
@forward 'uswds-theme';
@forward 'uswds';
@forward 'uswds-custom-styles';
After you've completed the above, you should be able to use USWDS SCSS in your own SCSS files:
// your-project/myProject.scss
.myProjectElement {
@include u-bg('info-lighter');
}
You can also customize any of the variables used in USWDS SCSS in the your-project/settings.scss
file. However, the order in which they are defined is very important and needs to match the same order as in uswds/src/stylesheets/theme/styles.scss
. For example, the below file defines both the required variables mentioned above, as well as overwrites some other settings:
// your-project/_uswds-theme.scss
@use 'uswds-core' with (
<!-- GENERAL -->
$theme-image-path: '@uswds/uswds/img',
<!-- TYPOGRAPHY -->
$theme-respect-user-font-size: false,
$theme-root-font-size: 14px,
$theme-font-path: '@uswds/uswds/fonts',
$theme-font-type-sans: 'public-sans',
$theme-style-body-element: true,
<!-- SPACING -->
$theme-grid-container-max-width: 'desktop-lg',
<!-- COMPONENTS -->
$theme-hero-image: '@uswds/uswds/img/hero.png',
);
USWDS now includes a defined set of icons. We have implemented these as React components using React SVGR, so that each icon can be rendered using inline SVG instead of loading a sprite file (which is what USWDS does).