-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCardHeader.js
More file actions
47 lines (43 loc) · 1.23 KB
/
CardHeader.js
File metadata and controls
47 lines (43 loc) · 1.23 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import React from "react";
// nodejs library that concatenates classes
import classNames from "classnames";
// nodejs library to set properties for components
import PropTypes from "prop-types";
// @material-ui/core components
import { makeStyles } from "@material-ui/core/styles";
// @material-ui/icons
// core components
import styles from "../../assets/jss/material-dashboard-react/components/cardHeaderStyle.js";
const useStyles = makeStyles(styles);
export default function CardHeader(props) {
const classes = useStyles();
const { className, children, color, plain, stats, icon, ...rest } = props;
const cardHeaderClasses = classNames({
[classes.cardHeader]: true,
[classes[color + "CardHeader"]]: color,
[classes.cardHeaderPlain]: plain,
[classes.cardHeaderStats]: stats,
[classes.cardHeaderIcon]: icon,
[className]: className !== undefined
});
return (
<div className={cardHeaderClasses} {...rest}>
{children}
</div>
);
}
CardHeader.propTypes = {
className: PropTypes.string,
color: PropTypes.oneOf([
"warning",
"success",
"danger",
"info",
"primary",
"rose"
]),
plain: PropTypes.bool,
stats: PropTypes.bool,
icon: PropTypes.bool,
children: PropTypes.node
};