@dotconnor/grommet
Version:
focus on the essential experience
140 lines (135 loc) • 4.26 kB
JavaScript
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
import React from 'react';
import { Location } from "grommet-icons/es6/icons/Location";
import { System } from "grommet-icons/es6/icons/System";
import { ShieldSecurity } from "grommet-icons/es6/icons/ShieldSecurity";
import { Tasks } from "grommet-icons/es6/icons/Tasks";
import { User } from "grommet-icons/es6/icons/User";
import { Wifi } from "grommet-icons/es6/icons/Wifi";
import { Box, Card, CardBody, CardFooter, Grid, Grommet, Text } from 'grommet';
var data = [{
color: 'blue',
icon: /*#__PURE__*/React.createElement(Wifi, {
size: "large"
}),
title: 'Remote Access',
subTitle: 'Lights out Management (LOM)',
message: 'Connected'
}, {
color: 'green',
icon: /*#__PURE__*/React.createElement(System, {
size: "large"
}),
title: 'System',
subTitle: 'Sub-system and Devices',
message: 'Composable System'
}, {
color: 'red',
icon: /*#__PURE__*/React.createElement(User, {
size: "large"
}),
title: 'User Sessions',
subTitle: 'User Access on Server',
message: '4 active sessions'
}, {
color: 'purple',
icon: /*#__PURE__*/React.createElement(Tasks, {
size: "large"
}),
title: 'Logs',
subTitle: 'Events, Integration, and Status',
message: '204,353'
}, {
color: 'orange',
icon: /*#__PURE__*/React.createElement(Location, {
size: "large"
}),
title: 'Beacons',
subTitle: 'Unique identification light',
message: '24 beacons connected'
}, {
color: 'teal',
icon: /*#__PURE__*/React.createElement(ShieldSecurity, {
size: "large"
}),
title: 'Security',
subTitle: 'Trusted Platform Module',
message: 'No Module Connected'
}];
var theme = {
global: {
font: {
family: "-apple-system,\n BlinkMacSystemFont, \n \"Segoe UI\""
},
colors: {
blue: '#00C8FF',
green: '#17EBA0',
teal: '#82FFF2',
purple: '#F740FF',
red: '#FC6161',
orange: '#FFBC44',
yellow: '#FFEB59'
}
},
card: {
footer: {
pad: {
horizontal: 'medium',
vertical: 'small'
},
background: '#FFFFFF27'
}
}
};
var Identifier = function Identifier(_ref) {
var children = _ref.children,
title = _ref.title,
subTitle = _ref.subTitle,
size = _ref.size,
rest = _objectWithoutPropertiesLoose(_ref, ["children", "title", "subTitle", "size"]);
return /*#__PURE__*/React.createElement(Box, _extends({
gap: "small",
align: "center"
}, rest), children, /*#__PURE__*/React.createElement(Box, null, /*#__PURE__*/React.createElement(Text, {
size: size,
weight: "bold"
}, title), /*#__PURE__*/React.createElement(Text, {
size: size
}, subTitle)));
};
export var Themed = function Themed() {
return /*#__PURE__*/React.createElement(Grommet, {
theme: theme,
full: true
}, /*#__PURE__*/React.createElement(Box, {
pad: "large"
}, /*#__PURE__*/React.createElement(Grid, {
gap: "medium",
rows: "small",
columns: {
count: 'fit',
size: 'small'
}
}, data.map(function (value) {
return /*#__PURE__*/React.createElement(Card, {
background: value.color,
key: value.message
}, /*#__PURE__*/React.createElement(CardBody, {
pad: "small"
}, /*#__PURE__*/React.createElement(Identifier, {
pad: "small",
title: value.title,
subTitle: value.subTitle,
size: "small",
align: "start"
}, value.icon)), /*#__PURE__*/React.createElement(CardFooter, {
pad: {
horizontal: 'medium',
vertical: 'small'
}
}, /*#__PURE__*/React.createElement(Text, {
size: "xsmall"
}, value.message)));
}))));
};