UNPKG

cloudhubui

Version:

Various components to use in react projects

267 lines (234 loc) 12.5 kB
"use strict"; 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;