cloudhubui
Version:
Various components to use in react projects
267 lines (234 loc) • 12.5 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _styles = require("@material-ui/styles");
var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
var _ChevronLeft = _interopRequireDefault(require("@material-ui/icons/ChevronLeft"));
var _ChevronRight = _interopRequireDefault(require("@material-ui/icons/ChevronRight"));
var _hexToRgb = _interopRequireDefault(require("./theme/hexToRgb"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
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; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
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); }
var useStyles = (0, _styles.makeStyles)(function (_ref) {
var colors = _ref.colors;
return {
pagination: {
display: 'flex',
paddingLeft: '0',
listStyle: 'none',
borderRadius: '0.25rem'
},
paginationItem: {
display: 'inline'
},
paginationLink: {
':first-of-type': {
marginleft: '0'
},
border: '0',
borderRadius: '30px !important',
transition: 'all .3s',
padding: '0px 11px',
margin: '0 3px',
minWidth: '30px',
height: '30px',
minHeight: 'auto',
lineHeight: '30px',
fontWeight: '400',
fontSize: '12px',
textTransform: 'none',
background: 'transparent',
position: 'relative',
float: 'left',
textDecoration: 'none',
boxSizing: 'border-box',
'&,&:hover,&:focus': {
color: colors.grayColor[0]
},
'&:hover,&:focus': {
zIndex: '3',
backgroundColor: colors.grayColor[2],
borderColor: colors.grayColor[6]
},
'&:hover': {
cursor: 'pointer'
}
},
primary: {
'&,&:hover,&:focus': {
backgroundColor: colors.primary,
borderColor: colors.primary,
color: colors.whiteColor,
boxShadow: "0 4px 5px 0 rgba(".concat((0, _hexToRgb.default)(colors.primary), ", 0.14), 0 1px 10px 0 rgba(").concat((0, _hexToRgb.default)(colors.primary), ", 0.12), 0 2px 4px -1px rgba(").concat((0, _hexToRgb.default)(colors.primary), ", 0.2)")
},
'&:hover,&:focus': {
zIndex: '2',
cursor: 'default'
}
},
info: {
'&,&:hover,&:focus': {
backgroundColor: colors.infoColor[0],
borderColor: colors.infoColor[0],
color: colors.whiteColor,
boxShadow: "0 4px 5px 0 rgba(".concat((0, _hexToRgb.default)(colors.infoColor[0]), ", 0.14), 0 1px 10px 0 rgba(").concat((0, _hexToRgb.default)(colors.infoColor[0]), ", 0.12), 0 2px 4px -1px rgba(").concat((0, _hexToRgb.default)(colors.infoColor[0]), ", 0.2)")
},
'&:hover,&:focus': {
zIndex: '2',
cursor: 'default'
}
},
success: {
'&,&:hover,&:focus': {
backgroundColor: colors.successColor[0],
borderColor: colors.successColor[0],
color: colors.whiteColor,
boxShadow: "0 4px 5px 0 rgba(".concat((0, _hexToRgb.default)(colors.successColor[0]), ", 0.14), 0 1px 10px 0 rgba(").concat((0, _hexToRgb.default)(colors.successColor[0]), ", 0.12), 0 2px 4px -1px rgba(").concat((0, _hexToRgb.default)(colors.successColor[0]), ", 0.2)")
},
'&:hover,&:focus': {
zIndex: '2',
cursor: 'default'
}
},
warning: {
'&,&:hover,&:focus': {
backgroundColor: colors.warningColor[0],
borderColor: colors.warningColor[0],
color: colors.whiteColor,
boxShadow: "0 4px 5px 0 rgba(".concat((0, _hexToRgb.default)(colors.warningColor[0]), ", 0.14), 0 1px 10px 0 rgba(").concat((0, _hexToRgb.default)(colors.warningColor[0]), ", 0.12), 0 2px 4px -1px rgba(").concat((0, _hexToRgb.default)(colors.warningColor[0]), ", 0.2)")
},
'&:hover,&:focus': {
zIndex: '2',
cursor: 'default'
}
},
danger: {
'&,&:hover,&:focus': {
backgroundColor: colors.dangerColor[0],
borderColor: colors.dangerColor[0],
color: colors.whiteColor,
boxShadow: "0 4px 5px 0 rgba(".concat((0, _hexToRgb.default)(colors.dangerColor[0]), ", 0.14), 0 1px 10px 0 rgba(").concat((0, _hexToRgb.default)(colors.dangerColor[0]), ", 0.12), 0 2px 4px -1px rgba(").concat((0, _hexToRgb.default)(colors.dangerColor[0]), ", 0.2)")
},
'&:hover,&:focus': {
zIndex: '2',
cursor: 'default'
}
},
disabled: {
'&,&:hover,&:focus': {
color: colors.grayColor[10],
cursor: 'not-allowed',
backgroundColor: colors.whiteColor,
borderColor: colors.grayColor[6]
}
}
};
});
function Pagination(_ref2) {
var _classNames, _classNames2;
var props = _extends({}, _ref2);
var count = props.count,
rowsPerPage = props.rowsPerPage,
color = props.color,
className = props.className;
var classes = useStyles();
var paginationClasses = (0, _classnames.default)(classes.pagination, className);
var _useState = (0, _react.useState)(0),
_useState2 = _slicedToArray(_useState, 2),
currentPage = _useState2[0],
setPage = _useState2[1];
(0, _react.useEffect)(function () {
setPage(currentPage);
}, [currentPage]);
var totalpages = Math.ceil(count / rowsPerPage) - 1;
var firstPage = 0;
var lastPage = Math.max(0, totalpages);
var pages = [totalpages > 1 && currentPage === lastPage ? currentPage - 2 : null, currentPage > 0 ? currentPage - 1 : null, currentPage, totalpages > currentPage ? currentPage + 1 : null, totalpages > 1 && currentPage === 0 ? currentPage + 2 : null];
var handleButtoClick = function handleButtoClick(page) {
if (Number(page) || page === 0) {
setPage(page);
props.onChangePage(page);
}
if (page === 'last') {
setPage(lastPage);
props.onChangePage(lastPage);
}
if (page === 'first') {
setPage(firstPage);
props.onChangePage(firstPage);
}
};
var firstpaginationLink = (0, _classnames.default)((_classNames = {}, _defineProperty(_classNames, classes.paginationLink, true), _defineProperty(_classNames, classes.disabled, currentPage === 0), _classNames));
var lastpaginationLink = (0, _classnames.default)((_classNames2 = {}, _defineProperty(_classNames2, classes.paginationLink, true), _defineProperty(_classNames2, classes.disabled, currentPage === lastPage), _classNames2));
return /*#__PURE__*/_react.default.createElement("ul", {
className: paginationClasses
}, /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement(_Button.default, {
onClick: function onClick() {
return handleButtoClick('first');
},
className: firstpaginationLink,
disabled: currentPage === 0
}, "First")), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement(_Button.default, {
onClick: function onClick() {
return handleButtoClick(currentPage > 0 ? currentPage - 1 : 0);
},
className: firstpaginationLink,
disabled: currentPage === 0
}, /*#__PURE__*/_react.default.createElement(_ChevronLeft.default, null))), pages.filter(function (p) {
return p !== null;
}).map(function (page, index) {
var _classNames3;
var paginationLink = (0, _classnames.default)((_classNames3 = {}, _defineProperty(_classNames3, classes.paginationLink, true), _defineProperty(_classNames3, classes[color], page === currentPage), _defineProperty(_classNames3, classes.disabled, false), _classNames3));
return (
/*#__PURE__*/
// eslint-disable-next-line react/no-array-index-key
_react.default.createElement("li", {
className: classes.paginationItem,
key: "i".concat(index)
}, /*#__PURE__*/_react.default.createElement(_Button.default, {
onClick: function onClick() {
return handleButtoClick(page);
},
className: paginationLink,
disabled: false
}, page + 1))
);
}), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement(_Button.default, {
onClick: function onClick() {
return handleButtoClick(currentPage + 1);
},
className: lastpaginationLink,
disabled: currentPage === lastPage
}, /*#__PURE__*/_react.default.createElement(_ChevronRight.default, null))), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement(_Button.default, {
onClick: function onClick() {
return handleButtoClick('last');
},
className: lastpaginationLink,
disabled: currentPage === lastPage
}, "Last")));
}
Pagination.defaultProps = {
color: 'primary',
onChangePage: function onChangePage() {}
};
Pagination.propTypes = {
classes: _propTypes.default.object.isRequired,
color: _propTypes.default.oneOf(['primary', 'info', 'success', 'warning', 'danger']),
onChangePage: _propTypes.default.func
};
var _default = Pagination;
exports.default = _default;