data:image/s3,"s3://crabby-images/60eb1/60eb1a89121b2fdf1a62a0da02b54b20d9f8d66c" alt=""
MUI Style Variables
Zesty styles-variables with MUI class names
data:image/s3,"s3://crabby-images/04bf6/04bf69b486a802adbab6ab83fb4d5ac2e138ec9f" alt=""
Zesty styles-variables with MUI class names
This feature will help to incorporate zesty instance style variables to Material UI Theme.
Upon installingĀ zesty next starter app, theĀ sync.js
Ā will run for the first time. But there will be always a changes specially in the style variables. Fortunately we can sync the instance styles anytime to next starter app anytime by running the command below to the console.
npm run sync
- styleVariables.jsonĀ - located at folder (
š Ā ".zesty"Ā ). It contains the fetched style variables data from the API. e.g:
{ "brand-primary": "#337ab7", "brand-success": "#5cb85c", "brand-warning": "#f0ad4e", "brand-danger": "#d9534f", "brand-info": "#5bc0de", }
We should create a file where we can configure the MUI theme customization with instance style variables. In this example the file will be named as:Ā zestyStyleVariables.jsĀ under folderĀ
š Ā "components"Ā :After creating the file, we should import first the dependency of our zesty styles configuration:
import { createTheme } from "@mui/material/styles"; // import the createTheme from MUI const styles = require(".zesty/styleVariables") || {}; // assigning the styleVariables.json to the "styles" variable
Accessing a style variable and assigning it to MUI theme:
import { createTheme } from "@mui/material/styles"; const styles = require(".zesty/styleVariables") || {}; // customizing MUI theme colors: export default function ZestyStyleVariables() { const zestySettingsTheme = createTheme({ palette: { primary: { //Accessing the @brand-primary color main:
${styles["brand-primary"]}
, }, }, }); return zestySettingsTheme; }Customizing Header default styles:
import { createTheme } from "@mui/material/styles"; const styles = require(".zesty/styleVariables") || {}; // customizing MUI theme colors: export default function ZestyStyleVariables() { const zestySettingsTheme = createTheme({ typography: { // Header styles h1: { fontSize: parseInt(styles["font-size-h1"]) || 24, }, }, }); return zestySettingsTheme; }
- Adding MUI Theme provider
In order for the custom theme to work,Ā
ThemeProvider
Ā should be imported in a component or in a top level component file.
Importing the MUIĀ ThemeProvider
Ā :
import { ThemeProvider } from "@mui/material/styles";
After importing, the component should be the child of theĀ ThemeProvider
Ā component and useĀ ZestyStyleVariables
Ā as the theme prop value.
<ThemeProvider theme={ZestyStyleVariables()}> <Component /> </ThemeProvider>
Also do not forget to import the theme configuration file
import ZestyStyleVariables from "components/ZestyStyleVariables";
Example of addingĀ ThemeProvider
Ā in Zesty starter appĀ App.js
Ā file:
import ZestyStyleVariables from "components/zestyStyleVariables"; //Importing the custom theme config from the zestyStyleVariables.js import { ThemeProvider } from "@mui/material/styles"; // importing ThemeProvider from MUI styles function MyApp({ Component, pageProps }) { return ( <> {/ logic to run zesty head if it detects zesty meta data patterns in props, else load alternate head for you to edit /} {(pageProps?.meta?.web && <ZestyHead content={pageProps} />) || ( <Head> <meta charSet="utf-8" /> <title>Zesty.io Next.js Marketing Technology Example Starter</title> </Head> )} {/ MUI customized theme will start to effect here /} <ThemeProvider theme={ZestyStyleVariables()}> <Component {...pageProps} /> </ThemeProvider> </> ); } export default MyApp;
ThemeProvider
Ā can be imported exclusively in a specific component, the example above is just a general scenario to apply the theme to the webpage as a whole.
For more details about customizing theme, kindly see in theĀ MUI Documentation.
example component sinkĀ of the MUI-Styles
Please also see theĀ