Theme

This guide will help you understand the different aspects about Spaceweb Themes.

Spaceweb themes is built from the combination of

  • TailwindCSS providing the basic set of atomic utilities
  • @sprinklr/style-dictionary providing the style-tokens

We provide two themes out of the box, Light and Dark, which style components in light & dark variants.

Toggling light and dark theme

If you want to allow for toggling between the two themes at runtime, you need to allocate some state for determining which theme is passed to SpacewebProvider.

import React, { ReactElement } from 'react';
import SpacewebProvider from '@sprinklrjs/spaceweb/spacewebProvider';
import { Direction, ThemeModule } from '@sprinklrjs/spaceweb-themes/types';
import sprLight from '@sprinklrjs/spaceweb-themes/space/light';
import sprLight from '@sprinklrjs/spaceweb-themes/space/dark';
type State = {
theme: 'light' | 'dark';
direction: Direction;
};
const App = (): ReactElement => {
const [state, setState] = useState<State>({
theme: 'dark',
direction: 'ltr',
});
return (
<SpacewebProvider direction={state.direction} theme={state.theme === 'light' ? sprLight : sprDark}>
{/* your application code here */}
</SpacewebProvider>
);
};
export default App;

Override Theme

You can override the theme with the help of ThemeProvider.

import React, { ReactElement } from 'react';
import SpacewebProvider from '@sprinklrjs/spaceweb/spacewebProvider';
import { ThemeProvider } from '@sprinklrjs/spaceweb/theme';
import { Box } from '@sprinklrjs/spaceweb-themes/box';
import sprLight from '@sprinklrjs/spaceweb-themes/space/light';
import hyperspaceLight from '@sprinklrjs/spaceweb-themes/hyperspace/light';
const App = (): ReactElement => (
<SpacewebProvider theme={sprLight}>
<Box className="spr-text-04">This is text is sprLight themed</Box>
<ThemeProvider theme={hyperspaceLight}>
<Box className="spr-text-04">This is text is hyperspaceLight themed</Box>
</ThemeProvider>
</SpacewebProvider>
);
export default App;

Theme Properties

The theme object organizes its various properties according to their respective concerns.

NOTE: Spaceweb uses a 4px grid for defining the unit sizes. Hence all the utility classes work in multiples of 4px.

m-1 = margin of 4px
p-2 = padding of 8px

Using Theme Properties in Code

Head over to the styling guide on how to use these theme properties to style your code.