@dotconnor/grommet
Version:
focus on the essential experience
164 lines (158 loc) • 4.57 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 { Bluetooth as Memory } from "grommet-icons/es6/icons/Bluetooth";
import { Storage } from "grommet-icons/es6/icons/Storage";
import { Trigger } from "grommet-icons/es6/icons/Trigger";
import { Box, Card, CardBody, CardFooter, Chart, Grid, Grommet, Text } from 'grommet';
var theme = {
themeMode: 'dark',
global: {
font: {
family: "-apple-system,\n BlinkMacSystemFont, \n \"Segoe UI\""
}
},
card: {
container: {
background: '#FFFFFF12',
elevation: 'none'
},
footer: {
pad: {
horizontal: 'medium',
vertical: 'small'
},
background: '#FFFFFF06'
}
}
};
var gradient = [{
value: 28,
color: 'status-ok'
}, {
value: 50,
color: 'status-warning'
}, {
value: 80,
color: 'status-critical'
}];
var data = [{
icon: /*#__PURE__*/React.createElement(Memory, {
size: "large"
}),
title: 'Memory (EEC)',
subTitle: '8 GB @ 400Hz',
message: 'Past 24hrs',
type: 'bar'
}, {
icon: /*#__PURE__*/React.createElement(Storage, {
size: "large"
}),
title: 'Storage',
subTitle: 'Sub-system and Devices',
message: '36.8 TB available',
type: 'line'
}, {
icon: /*#__PURE__*/React.createElement(Trigger, {
size: "large"
}),
title: 'Power (Watts)',
subTitle: '720 Watt Service',
message: 'Past 12hrs',
type: 'point'
}];
var ChartPreview = function ChartPreview(_ref) {
var type = _ref.type;
return /*#__PURE__*/React.createElement(Box, null, /*#__PURE__*/React.createElement(Chart, {
type: type,
id: type,
dash: type === 'line',
round: true,
thickness: "xsmall",
bounds: [[0, 6], [0, 100]],
values: [{
value: [6, 100],
label: 'one hundred'
}, {
value: [5, 70],
label: 'seventy'
}, {
value: [4, 40],
label: 'sixty'
}, {
value: [3, 80],
label: 'eighty'
}, {
value: [2, 25],
label: 'forty'
}, {
value: [1, 50],
label: 'thirty'
}, {
value: [0, 25],
label: 'sixty'
}],
"aria-label": "chart card",
color: gradient,
size: {
height: 'xsmall'
}
}));
};
var Identifier = function Identifier(_ref2) {
var children = _ref2.children,
title = _ref2.title,
subTitle = _ref2.subTitle,
size = _ref2.size,
rest = _objectWithoutPropertiesLoose(_ref2, ["children", "title", "subTitle", "size"]);
return /*#__PURE__*/React.createElement(Box, _extends({
gap: "small",
align: "center",
direction: "row",
pad: "small"
}, 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 Clickable = function Clickable() {
return /*#__PURE__*/React.createElement(Grommet, {
theme: theme,
full: true
}, /*#__PURE__*/React.createElement(Box, {
pad: "large",
background: "dark-1",
height: "100%"
}, /*#__PURE__*/React.createElement(Grid, {
gap: "medium",
columns: {
count: 'fit',
size: 'small'
}
}, data.map(function (value) {
return /*#__PURE__*/React.createElement(Card, {
key: value.title,
onClick: function onClick() {
// eslint-disable-next-line no-alert
alert('Card was Clicked!');
}
}, /*#__PURE__*/React.createElement(CardBody, {
pad: "small"
}, /*#__PURE__*/React.createElement(Identifier, {
title: value.title,
subTitle: value.subTitle,
size: "small"
}, value.icon), /*#__PURE__*/React.createElement(ChartPreview, {
type: value.type
})), /*#__PURE__*/React.createElement(CardFooter, {
pad: {
horizontal: 'medium',
vertical: 'small'
}
}, /*#__PURE__*/React.createElement(Text, {
size: "xsmall"
}, value.message)));
}))));
};