@dotconnor/grommet
Version:
focus on the essential experience
121 lines (108 loc) • 4.96 kB
JavaScript
"use strict";
exports.__esModule = true;
exports.HeaderActions = void 0;
var _react = _interopRequireWildcard(require("react"));
var _grommet = require("grommet");
var _grommetIcons = require("grommet-icons");
var _data = require("../../DataTable/stories/data");
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
// Source code for the data can be found here
// https://github.com/grommet/grommet/blob/master/src/js/components/DataTable/stories/data.js
var TipContent = function TipContent(_ref) {
var message = _ref.message,
icon = _ref.icon;
return /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
direction: "row",
gap: "small"
}, icon && /*#__PURE__*/_react["default"].createElement(_grommetIcons.Info, {
color: "accent-4"
}), /*#__PURE__*/_react["default"].createElement(_grommet.Text, {
color: "accent-1"
}, message));
};
var HeaderActions = function HeaderActions() {
var _useState = (0, _react.useState)(_data.storageData),
data = _useState[0],
setData = _useState[1];
var _useState2 = (0, _react.useState)(),
selected = _useState2[0],
setSelected = _useState2[1];
var removeRow = function removeRow() {
var filteredData = data.filter(function (item) {
return item.id !== selected.id;
});
setData(filteredData);
setSelected(undefined);
};
return /*#__PURE__*/_react["default"].createElement(_grommet.Grommet, {
full: true,
theme: _grommet.grommet
}, /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
align: "center",
background: "dark-1",
gap: "large",
height: {
min: '100%'
}
}, /*#__PURE__*/_react["default"].createElement(_grommet.Paragraph, {
textAlign: "center"
}, /*#__PURE__*/_react["default"].createElement("b", null, "Follow"), " the Tips of the Trash & Reload icons for directions. Those Tooltips ", /*#__PURE__*/_react["default"].createElement("b", null, "change"), " according to the actions the user perform on the table. The Table meters are also using the Tip component."), /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
gap: "small"
}, /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
fill: true,
direction: "row",
justify: "between",
align: "center"
}, /*#__PURE__*/_react["default"].createElement(_grommet.Heading, {
level: 2
}, " Storage Pools with tooltips"), /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
gap: "small",
direction: "row"
}, /*#__PURE__*/_react["default"].createElement(_grommet.Tip, {
dropProps: {
align: {
bottom: 'top'
}
},
content: /*#__PURE__*/_react["default"].createElement(TipContent, {
message: !selected ? 'Select a table row to enable' : 'Delete table Row',
icon: !selected
})
}, /*#__PURE__*/_react["default"].createElement(_grommet.Anchor, {
disabled: !selected,
icon: /*#__PURE__*/_react["default"].createElement(_grommetIcons.Trash, null),
onClick: removeRow
})), /*#__PURE__*/_react["default"].createElement(_grommet.Tip, {
dropProps: {
align: {
bottom: 'top'
}
},
content: /*#__PURE__*/_react["default"].createElement(TipContent, {
message: data.length < _data.storageData.length ? 'Reload Data' : 'Delete items before reload action is enabled',
icon: !selected
})
}, /*#__PURE__*/_react["default"].createElement(_grommet.Anchor, {
icon: /*#__PURE__*/_react["default"].createElement(_grommetIcons.Refresh, null),
onClick: function onClick() {
return setData(_data.storageData);
},
disabled: data.length === _data.storageData.length
})))), /*#__PURE__*/_react["default"].createElement(_grommet.DataTable, {
columns: _data.storageColumns,
data: data,
step: 10,
onClickRow: function onClickRow(event) {
return setSelected(event.datum);
}
}))));
};
exports.HeaderActions = HeaderActions;
HeaderActions.story = {
parameters: {
chromatic: {
disable: true
}
}
};