Skip to main content

use hooks - useTheme in Material UI

contactPage.js
import { useTheme } from '@material-ui/core/styles'
const useStyles = makeStyles(styles)

export default function ContactList () {
const theme = useTheme()
...
<TableCell>
<strong style={{ color: theme.palette.primary.main }}>
{name}
</strong>
index.js
import { ThemeProvider } from '@material-ui/styles'
import { createMuiTheme } from '@material-ui/core/styles'
import { green, orange, red, blue } from '@material-ui/core/colors'

const theme = createMuiTheme({
palette: {
primary: blue,
secondary: orange
},
status: {
danger: red
}
})
...

ReactDOM.render(
<ApolloProvider client={client}>
<StateProvider>
<ThemeProvider theme={theme}>
<Router history={hist}>
<Switch>
<PublicRoute exact path='/login' component={LoginPage} />
<PrivateRoute path='/admin' component={Admin} />
<Redirect from='/' to='/admin/dashboard' />
</Switch>
</Router>
</ThemeProvider>
</StateProvider>
</ApolloProvider>,
document.getElementById('root')
)
admin.js
const [color, setColor] = React.useState('blue')
<Sidebar
routes={routes}
logoText={'OCCopier'}
logo={logo}
image={image}
handleDrawerToggle={handleDrawerToggle}
open={mobileOpen}
color={color}
{...rest}
/>
material-dashboard-react.js
const primaryColor = ['#ed701b', '#ed701b', '#ed701b', '#ed701b']
const warningColor = ['#ff9800', '#ffa726', '#fb8c00', '#ffa21a']
sidebarStyle.js

blue: {
backgroundColor: primaryColor[0],
boxShadow:
'0 12px 20px -10px rgba(' +
hexToRgb(infoColor[0]) +
',.28), 0 4px 20px 0 rgba(' +
hexToRgb(blackColor) +
',.12), 0 7px 8px -5px rgba(' +
hexToRgb(infoColor[0]) +
',.2)',
'&:hover,&:focus': {
backgroundColor: primaryColor[0],
boxShadow:
'0 12px 20px -10px rgba(' +
hexToRgb(infoColor[0]) +
',.28), 0 4px 20px 0 rgba(' +
hexToRgb(blackColor) +
',.12), 0 7px 8px -5px rgba(' +
hexToRgb(infoColor[0]) +
',.2)'
}
},

Comments

Popular posts from this blog

for loop in javascript - promise - .eslintrc for "for of"

the vast majority of cases  map ,  forEach ,  find  etc. can be used.  async function printFiles () { const files = await getFilePaths(); await Promise.all(files. map (async (file) => { const contents = await fs.readFile(file, 'utf8') console.log(contents) })); } const inventory = [ { name : 'apples' , quantity : 2 } , { name : 'bananas' , quantity : 0 } , { name : 'cherries' , quantity : 5 } ] ; const result = inventory . find ( ( { name } ) => name === 'cherries' ) ;   function getFirstMatching(array) { for (let item of array) { const result = heavyTransform(item); if (result) { return result; } } } Specifically this shuts down the whole no-restricted-syntax. If you want to cherry-pick, here is the current definition: 'no-restricted-syntax' : [ 'error' , { selector : 'ForInStatement' , message...

Apollo client - cache APIs - auto update cache - erase cache - reactive variables - deletion - addition

Apollo Client 3  Local only fields Reactive Variables const cache = new InMemoryCache ( { typePolicies : { Todo : { // If one of the keyFields is an object with fields of its own, you can // include those nested keyFields by using a nested array of strings: keyFields : [ "date" , "user" , [ "email" ] ] , } } , } ) ; This internal data is intended to be easily  JSON-serializable , so you can take a snapshot with  cache.extract() , save it somewhere, and later restore with  cache.restore(snapshot) . Here’s a mutation called  EditTodo  that returns the new  todo  value in the mutation response. mutation EditTodo ( $id : Int ! , $text : String ! ) { editTodo ( id : $id , text : $text ) { success todo { # <- Returning it here id text completed } error { ... on TodoNotFoundError { message } ... on TodoValidationE...

window.URL.createObjectURL is not (yet) available in jest-dom - testing scenario

Since  window.URL.createObjectURL  is not (yet) available in jest-dom, you need to provide a mock implementation for it. Don't forget to reset the mock implementation after each test. describe ( "your test suite" , () => { window . URL . createObjectURL = jest . fn (); afterEach (() => { window . URL . createObjectURL . mockReset (); }); it ( "your test case" , () => { expect ( true ). toBeTruthy (); }); });