@oc-digital/react-component-library 2.0.8-beta.0 → 2.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/index.js +1 -1
- package/build/index.js.map +1 -1
- package/package.json +1 -1
package/build/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../node_modules/tslib/tslib.es6.js","../src/globals/index.ts","../src/styles/spacing.ts","../src/styles/font.ts","../src/styles/layout.ts","../src/Button/Button.tsx","../src/ContentLabel/ContentLabel.tsx","../src/ContentBox/ContentBox.tsx","../src/LoadingSpinner/LoadingSpinner.tsx","../src/StaticTable/StaticTable.tsx","../src/Breadcrumbs/Breadcrumbs.tsx","../src/EntityList/EntityList.tsx","../src/ErrorIndicator/ErrorIndicator.tsx","../src/LeftNavigation/NavListItem.tsx","../src/utils/index.ts","../src/LeftNavigation/SecondaryLeftNavigation.tsx","../src/LeftNavigation/PrimaryLeftNavigation.tsx","../src/LeftNavigation/LeftNavigation.tsx","../src/MainLayout/MainLayout.tsx","../src/hooks/useDebounceEffect.tsx","../src/hooks/useInterval.ts","../src/hooks/useWhyDidYouUpdate.tsx","../src/AlphabeticalList/AlphabeticalList.tsx","../src/SearchBar/SearchBar.tsx","../src/TextField/TextField.tsx","../src/Select/Select.tsx","../src/DatePicker/DatePicker.tsx","../src/KeyboardDatePicker/KeyboardDatePicker.tsx","../src/ButtonWithConfirm/ButtonWithConfirm.tsx","../src/EditableTable/defaultCells.tsx","../src/EditableTable/EditableTable.tsx","../src/Alert/Alert.tsx","../src/ImageDisplayAndUpload/ImageDisplayAndUpload.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import { string } from \"yup\";\n\nexport const HALF_REM = \"0.5rem\";\nexport const ONE_REM = \"1rem\";\nexport const ONE_AND_HALF_REM = \"1.5rem\";\nexport const TWO_REM = \"3rem\";\nexport const THREE_REM = \"3rem\";\n\nexport const EDITED_STATUS = \"EDITED\";\nexport const NEW_STATUS = \"NEW\";\n\nexport const VALIDATION_MESSAGE_REQUIRED = \"Required\";\nexport const REGEX_NUMBER_WITH_DECIMALS = /^\\d*\\.?\\d*$/;\n\nexport const YUP_REQUIRED_STRING_SHORT_MESSAGE = string()\n .trim()\n .required(VALIDATION_MESSAGE_REQUIRED);\n\nexport const YUP_STRING_NUMBER_WITH_DECIMALS = string()\n .trim()\n .required(VALIDATION_MESSAGE_REQUIRED)\n .matches(REGEX_NUMBER_WITH_DECIMALS, \"Must be a Number\");\n\nexport const FORM_SUCCESS = \"success\";\nexport const FORM_ERROR = \"error\";\nexport const FORM_LOADING = \"loading\";\nexport const FORM_ENABLED = \"enabled\";\nexport const FORM_WARNING = \"warning\";\n\nexport type FormStatuses =\n | typeof FORM_SUCCESS\n | typeof FORM_ERROR\n | typeof FORM_LOADING\n | typeof FORM_ENABLED\n | typeof FORM_WARNING;\n\nexport const READ_LEVEL = \"read\";\nexport const WRITE_LEVEL = \"write\";\nexport const NO_ACCESS_LEVEL = \"noAccess\";\n\nexport interface IAuthoriserProp {\n accessLevel?: typeof READ_LEVEL | typeof WRITE_LEVEL | typeof NO_ACCESS_LEVEL;\n}\n\nexport const BORDER_RADIUS = \"14px\";\n","import { makeStyles } from \"@material-ui/core\";\nimport { HALF_REM, ONE_AND_HALF_REM, THREE_REM, ONE_REM } from \"../globals\";\n\nexport const useSpacingStyles = makeStyles(\n {\n labelBreak: {\n marginBottom: HALF_REM,\n },\n contentBreak: {\n marginBottom: ONE_REM,\n },\n sectionBreak: {\n marginBottom: ONE_AND_HALF_REM,\n },\n doubleSectionBreak: {\n marginBottom: THREE_REM,\n },\n rightSpacer1: {\n marginRight: HALF_REM,\n },\n rightSpacer2: {\n marginRight: ONE_REM,\n },\n leftSpacer1: {\n marginLeft: HALF_REM,\n },\n leftSpacer2: {\n marginLeft: ONE_REM,\n },\n buttonSpacing: {\n marginLeft: HALF_REM,\n marginRight: HALF_REM,\n marginBottom: ONE_REM,\n },\n leftRightPadding1: {\n paddingLeft: HALF_REM,\n paddingRight: HALF_REM,\n },\n leftRightPadding2: {\n paddingLeft: ONE_REM,\n paddingRight: ONE_REM,\n },\n topBottomPadding1: {\n paddingTop: HALF_REM,\n paddingBottom: HALF_REM,\n },\n topBottomPadding2: {\n paddingTop: ONE_REM,\n paddingBottom: ONE_REM,\n },\n },\n { classNamePrefix: \"spacing\", index: 2 }\n);\n","import { makeStyles } from \"@material-ui/core\";\n\nexport const useFontStyles = makeStyles(\n (theme) => ({\n boldText: {\n fontWeight: 700,\n },\n bolderText: {\n fontWeight: 500,\n },\n smallText: {\n fontSize: \"0.7rem\",\n },\n warningColor: {\n color: theme.palette.warning.main,\n },\n centerText: {\n textAlign: \"center\",\n },\n }),\n { classNamePrefix: \"font\" }\n);\n","import { makeStyles } from \"@material-ui/core\";\nimport { BORDER_RADIUS, ONE_REM, THREE_REM } from \"../globals\";\n\nexport const useLayoutStyles = makeStyles(\n {\n contentBox: {\n background: \"white\",\n borderRadius: BORDER_RADIUS,\n marginBottom: ONE_REM,\n padding: THREE_REM,\n },\n limitWidth60rem: {\n maxWidth: \"60rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth50rem: {\n maxWidth: \"50rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth45rem: {\n maxWidth: \"45rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth40rem: {\n maxWidth: \"40rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth35rem: {\n maxWidth: \"35rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth30rem: {\n maxWidth: \"30rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth25rem: {\n maxWidth: \"25rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n centeredText: {\n textAlign: \"center\",\n },\n startAlignedText: {\n textAlign: \"start\",\n },\n width20: {\n width: \"20%\",\n },\n width49: {\n width: \"49%\",\n },\n width50: {\n width: \"50%\",\n },\n width60: {\n width: \"60%\",\n },\n width100: {\n width: \"100%\",\n },\n flexCenter: {\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n },\n centerJustify: {\n justifyContent: \"center\",\n },\n leftJustify: {\n justifyContent: \"left\",\n },\n rightJustify: {\n justifyContent: \"right\",\n },\n },\n { classNamePrefix: \"layout\", index: 2 }\n);\n","import React from \"react\";\nimport {\n makeStyles,\n Button as MaterialButton,\n CircularProgress,\n} from \"@material-ui/core\";\nimport { useSpacingStyles } from \"../styles\";\nimport { IButtonProps } from \"./Button.types\";\nimport { NO_ACCESS_LEVEL, ONE_AND_HALF_REM, READ_LEVEL } from \"../globals\";\n\nconst useButtonStyles = makeStyles((theme) => ({\n submitButton: {\n borderRadius: ONE_AND_HALF_REM,\n padding: `0.4rem 1rem`,\n textTransform: \"none\",\n },\n containedText: {\n color: \"white\",\n },\n spinnerColour: {\n color: theme.palette.grey[500],\n },\n}));\n\nconst Button: React.FC<IButtonProps> = ({\n loading = false,\n children,\n errors = false,\n type = \"submit\",\n onClick,\n disabled = false,\n variant = \"outlined\",\n styling = \"\",\n color = \"primary\",\n accessLevel = \"\",\n ...rest\n}) => {\n const classes = { ...useSpacingStyles(), ...useButtonStyles() };\n\n if ([NO_ACCESS_LEVEL, READ_LEVEL].includes(accessLevel)) return null;\n\n let disabledProp = disabled;\n\n if (!disabled && (loading || errors)) {\n disabledProp = true;\n }\n\n return (\n <MaterialButton\n {...rest}\n variant={variant}\n color={color}\n type={type}\n className={`${classes.submitButton} ${\n variant === \"contained\" && classes.containedText\n } ${styling}`}\n disabled={disabledProp}\n onClick={onClick}\n >\n {children}\n {loading ? (\n <CircularProgress\n className={`${classes.leftSpacer1} ${classes.spinnerColour}`}\n size=\"1.1rem\"\n thickness={6}\n />\n ) : (\n \"\"\n )}\n </MaterialButton>\n );\n};\n\nexport default Button;\n","import React from \"react\";\nimport { Typography } from \"@material-ui/core\";\nimport { useFontStyles } from \"../styles\";\nimport { IContentLabelProps } from \"./ContentLabel.types\";\n\nconst ContentLabel: React.FC<IContentLabelProps> = ({ children, styling = null }) => {\n const classes = useFontStyles();\n return (\n <Typography variant=\"h6\" className={`${classes.bolderText} ${styling || \"\"}`}>\n {children}\n </Typography>\n );\n};\n\nexport default ContentLabel;\n","import React from \"react\";\nimport { Box } from \"@material-ui/core\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { IContentBoxProps } from \"./ContentBox.types\";\n\nconst ContentBox: React.FC<IContentBoxProps> = ({\n limitWidth = false,\n children,\n styling,\n}) => {\n const classes = { ...useSpacingStyles(), ...useLayoutStyles() };\n return (\n <Box boxShadow={3} className={`${classes.contentBox} ${styling || \"\"}`}>\n <Box\n className={`${classes.centeredText} ${limitWidth ? classes.limitWidth50rem : \"\"}`}\n >\n {children}\n </Box>\n </Box>\n );\n};\nexport default ContentBox;\n","import React from \"react\";\nimport { Box, Typography, CircularProgress } from \"@material-ui/core\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { ILoadingSpinnerProps } from \"./LoadingSpinner.types\";\n\nconst LoadingSpinner: React.FC<ILoadingSpinnerProps> = ({\n text = \"Loading data...\",\n styling,\n}) => {\n const classes = { ...useSpacingStyles(), ...useLayoutStyles() };\n\n return (\n <Box className={`${classes.flexCenter} ${styling || \"\"}`}>\n <Typography variant=\"body2\" color=\"textSecondary\" className={classes.rightSpacer1}>\n {text}\n </Typography>\n <CircularProgress size=\"1.5rem\" />\n </Box>\n );\n};\n\nexport default LoadingSpinner;\n","import React, { ReactNode, useCallback, useEffect, useMemo, useState } from \"react\";\nimport {\n createStyles,\n makeStyles,\n Table,\n TableBody,\n TableCell as MUITableCell,\n TableHead,\n TableRow as MUITableRow,\n withStyles,\n TableRowProps,\n TableCellProps,\n} from \"@material-ui/core\";\nimport {\n cellAlignmentOptions,\n headerColours,\n IStaticTableProps,\n} from \"./StaticTable.types\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport { BORDER_RADIUS } from \"../globals\";\nimport { Pagination } from \"@material-ui/lab\";\n\nconst StyledTableRow = withStyles(\n createStyles({\n root: {\n \"&:hover td\": {\n backgroundColor: \"rgba(0, 0, 0, 0.06)\",\n },\n },\n })\n)(MUITableRow);\n\nconst ShadedTableRow = withStyles(\n createStyles({\n root: {\n \"&:nth-of-type(even) td\": {\n backgroundColor: \"rgba(0, 0, 0, 0.03)\",\n },\n \"&:hover td\": {\n backgroundColor: \"rgba(0, 0, 0, 0.06)\",\n },\n },\n })\n)(MUITableRow);\n\nconst useTableCellStyles = makeStyles((theme) => ({\n root: {\n borderBottom: \"none\",\n paddingTop: \"8px\",\n paddingBottom: \"8px\",\n \"&:first-child\": {\n borderTopLeftRadius: BORDER_RADIUS,\n borderBottomLeftRadius: BORDER_RADIUS,\n },\n \"&:last-child\": {\n borderTopRightRadius: BORDER_RADIUS,\n borderBottomRightRadius: BORDER_RADIUS,\n },\n },\n head: ({ background, border, text }: headerColours) => ({\n backgroundColor: background || \"HSLA(204, 58.3%, 81.2%, 0.1)\",\n borderTop: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n borderBottom: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n color: text || theme.palette.text.primary,\n fontWeight: 500,\n \"&:first-child\": {\n borderLeft: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n },\n \"&:last-child\": {\n borderRight: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n },\n }),\n}));\n\ninterface ITableCellProps extends Omit<TableCellProps, \"align\"> {\n align?: cellAlignmentOptions;\n headerColours?: headerColours;\n withoutHeaders?: boolean;\n}\n\nconst TableCell = ({\n children,\n align = \"centerJustify\",\n headerColours,\n ...rest\n}: ITableCellProps) => {\n const classes = {\n ...useLayoutStyles(),\n ...useTableCellStyles({ ...(headerColours || {}) }),\n };\n return (\n <MUITableCell\n {...rest}\n classes={{\n root: classes.root,\n head: classes.head,\n }}\n >\n <div className={`${classes.flexCenter} ${classes[align]}`}>{children}</div>\n </MUITableCell>\n );\n};\n\ninterface ITableRow extends TableRowProps {\n rowBorderSeparation?: boolean;\n}\n\nconst TableRow = ({ rowBorderSeparation = false, children, ...rest }: ITableRow) => {\n if (rowBorderSeparation) {\n return <StyledTableRow {...rest}>{children}</StyledTableRow>;\n }\n return <ShadedTableRow {...rest}>{children}</ShadedTableRow>;\n};\n\ninterface ISingleCellRowProps {\n colSpan: number;\n children: ReactNode;\n}\n\nconst SingleCellRow = ({ colSpan, children }: ISingleCellRowProps) => {\n const classes = useStaticTableStyles();\n return (\n <TableRow>\n <TableCell className={classes.adjustedCellPadding} colSpan={colSpan}>\n {children}\n </TableCell>\n </TableRow>\n );\n};\n\nconst useStaticTableStyles = makeStyles({\n tableStyles: {\n borderCollapse: \"separate\",\n borderBottom: \"1px solid rgb(224, 224, 224)\",\n },\n pointer: {\n cursor: \"pointer\",\n },\n bottomBorder: {\n borderBottom: \"1px solid rgba(224, 224, 224, 1)\",\n },\n noShading: {\n backgroundColor: \"transparent !important\",\n },\n adjustedCellPadding: {\n paddingTop: \"11px\",\n paddingBottom: \"11px\",\n },\n});\n\nconst StaticTable: React.FC<IStaticTableProps> = ({\n rowBorderSeparation = false,\n headers,\n rows,\n headerCellAlignment = [],\n rowCellAlignment = [],\n styling,\n headerColours,\n paginate = false,\n itemsPerPage = 30,\n}) => {\n const classes = {\n ...useLayoutStyles(),\n ...useSpacingStyles(),\n ...useStaticTableStyles(),\n };\n const [page, setPage] = useState(1);\n\n const hasRowsAndPaginated = useMemo(\n () => !!(paginate && (rows?.length || 0) > itemsPerPage),\n [itemsPerPage, paginate, rows]\n );\n\n const [visibleRows, setVisibleRows] = useState<typeof rows>(\n hasRowsAndPaginated ? rows!.slice(0, itemsPerPage) : rows\n );\n\n const handlePageChange = useCallback(\n (event: React.ChangeEvent<unknown>, value: number) => {\n setPage(value);\n },\n []\n );\n\n useEffect(() => {\n setVisibleRows(\n hasRowsAndPaginated\n ? rows!.slice(itemsPerPage * (page - 1), itemsPerPage * page)\n : rows\n );\n }, [hasRowsAndPaginated, itemsPerPage, page, rows]);\n\n return (\n <>\n <Table\n className={`${classes.tableStyles} ${\n hasRowsAndPaginated ? classes.contentBreak : \"\"\n } ${styling || \"\"}`}\n >\n {headers ? (\n <TableHead>\n <MUITableRow>\n {headers.map((header: ReactNode, i) => (\n <TableCell\n align={headerCellAlignment[i] || \"centerJustify\"}\n key={`header-cell-${i}`}\n headerColours={headerColours}\n >\n {header}\n </TableCell>\n ))}\n </MUITableRow>\n </TableHead>\n ) : null}\n\n <TableBody>\n {visibleRows ? (\n visibleRows.length ? (\n visibleRows.map((data, i) => {\n const containsOnClick = !!data.onClick;\n return (\n <TableRow\n rowBorderSeparation={rowBorderSeparation}\n className={containsOnClick ? classes.pointer : undefined}\n key={`row-${i}`}\n onClick={containsOnClick ? data.onClick : undefined}\n >\n {data.row.map((cell: ReactNode, n) => (\n <TableCell\n align={rowCellAlignment[n] || \"centerJustify\"}\n className={\n rowBorderSeparation && visibleRows.length !== i + 1\n ? classes.bottomBorder\n : undefined\n }\n key={`row-${i}-cell-${n}`}\n >\n {cell}\n </TableCell>\n ))}\n </TableRow>\n );\n })\n ) : (\n <SingleCellRow colSpan={headers?.length || 0}>Table is empty</SingleCellRow>\n )\n ) : (\n <SingleCellRow colSpan={headers?.length || 0}>\n <LoadingSpinner />\n </SingleCellRow>\n )}\n </TableBody>\n </Table>\n {hasRowsAndPaginated ? (\n <Pagination\n className={classes.flexCenter}\n count={Math.ceil(rows!.length / itemsPerPage)}\n page={page}\n onChange={handlePageChange}\n shape=\"rounded\"\n showFirstButton\n showLastButton\n />\n ) : null}\n </>\n );\n};\n\nexport default StaticTable;\n","import React from \"react\";\nimport { makeStyles, Typography, Link, Box, ButtonBase } from \"@material-ui/core\";\nimport { Link as RouterLink } from \"react-router-dom\";\nimport { IBreadcrumbColors, IBreadcrumbsProps } from \"./Breadcrumbs.types\";\n\nconst useStyles = makeStyles((theme) => ({\n logoContainer: {\n width: \"3rem\",\n height: \"3rem\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n },\n logo: {\n width: \"100%\",\n height: \"100%\",\n \"& > div\": {\n width: \"100%\",\n height: \"100%\",\n },\n \"& > svg\": {\n width: \"100%\",\n height: \"100%\",\n },\n },\n logoInBreadcrumb: {\n width: \"2rem\",\n height: \"2rem\",\n margin: \"0.125rem 0 0.125rem 0.313rem\",\n },\n logoSpacing: {\n marginRight: theme.spacing(1),\n },\n flexItemsCenter: {\n display: \"flex\",\n alignItems: \"center\",\n },\n nonPrimaryBreadcrumbOffset: {\n marginLeft: \"2.5rem\",\n },\n BreadcrumbsContainer: {\n height: \"2.25rem\",\n marginLeft: \"0.875rem\",\n marginRight: \"1.5rem\",\n },\n primaryBreadcrumbItem: ({ primary }: IBreadcrumbColors) => ({\n backgroundColor: primary?.background || theme.palette.common.white,\n color: primary?.color || theme.palette.text.primary,\n borderRadius: \"2rem\",\n zIndex: 3,\n height: \"100%\",\n display: \"flex\",\n alignItems: \"center\",\n }),\n secondaryBreadcrumbItem: ({ secondary }: IBreadcrumbColors) => ({\n height: \"2.25rem\",\n backgroundColor: secondary?.background || \"#D7D4E4\",\n borderRadius: \"2rem\",\n zIndex: 2,\n marginLeft: \"-2rem\",\n color: secondary?.color || theme.palette.text.primary,\n }),\n tertiaryBreadcrumbItem: ({ tertiary }: IBreadcrumbColors) => ({\n height: \"2.25rem\",\n backgroundColor: tertiary?.background || \"#D7D4E4\",\n borderRadius: \"2rem\",\n zIndex: 1,\n marginLeft: \"-2rem\",\n color: tertiary?.color || theme.palette.common.white,\n }),\n breadCrumbShadow: {\n boxShadow: theme.shadows[2],\n },\n breadcrumbRightMargin: {\n marginRight: \"1rem\",\n },\n breadcrumbTextOverflow: {\n display: \"block\",\n overflow: \"hidden\",\n textOverflow: \"ellipsis\",\n maxWidth: \"12rem\",\n },\n boldText: {\n fontWeight: 500,\n },\n activeBreadcrumb: ({ tertiary }: IBreadcrumbColors) => ({\n backgroundColor: tertiary?.background || \"#D7D4E4\",\n color: tertiary?.color || theme.palette.common.white,\n }),\n noWrap: {\n whiteSpace: \"nowrap\",\n },\n fullBorderRadius: {\n borderRadius: \"100%\",\n },\n}));\n\nconst Breadcrumbs: React.FC<IBreadcrumbsProps> = ({ logo, content, colors }) => {\n const classes = useStyles({ ...(colors || {}) });\n\n const { first = null, second = null, third = null } = content;\n\n return (\n <Box className={`${classes.BreadcrumbsContainer} ${classes.flexItemsCenter}`}>\n <Box\n className={`${\n first ? `${classes.primaryBreadcrumbItem} ${classes.breadCrumbShadow}` : \"\"\n } ${classes.flexItemsCenter}`}\n >\n <Link component={RouterLink} to=\"/\" className={classes.logoSpacing}>\n <Box\n className={`${classes.logoContainer} \n ${first ? classes.logoInBreadcrumb : \"\"}`}\n >\n <ButtonBase className={`${classes.logo} ${classes.fullBorderRadius}`}>\n {logo}\n </ButtonBase>\n </Box>\n </Link>\n {first && (\n <Typography\n color=\"textPrimary\"\n className={`${classes.boldText} ${classes.noWrap} ${classes.primaryBreadcrumbItem}`}\n >\n <Link\n underline=\"none\"\n component={RouterLink}\n to={first.link}\n color=\"inherit\"\n className={`${classes.breadcrumbRightMargin} ${classes.breadcrumbTextOverflow}`}\n >\n {first.name}\n </Link>\n </Typography>\n )}\n </Box>\n\n {second && (\n <Box\n className={`${classes.flexItemsCenter} ${classes.secondaryBreadcrumbItem} ${\n classes.breadCrumbShadow\n } ${!third ? classes.activeBreadcrumb : \"\"}`}\n >\n <Typography color=\"inherit\" className={`${classes.boldText} ${classes.noWrap}`}>\n <Link\n component={RouterLink}\n underline=\"none\"\n to={second.link}\n color=\"inherit\"\n className={`${classes.nonPrimaryBreadcrumbOffset} ${classes.breadcrumbRightMargin} ${classes.breadcrumbTextOverflow}`}\n >\n {second.name}\n </Link>\n </Typography>\n </Box>\n )}\n {third && (\n <Box\n className={`${classes.flexItemsCenter} ${classes.tertiaryBreadcrumbItem} ${classes.breadCrumbShadow}`}\n >\n <Typography color=\"inherit\" className={`${classes.boldText} ${classes.noWrap}`}>\n <Link\n component={RouterLink}\n underline=\"none\"\n to={third.link}\n color=\"inherit\"\n className={`${classes.nonPrimaryBreadcrumbOffset} ${classes.breadcrumbRightMargin} ${classes.breadcrumbTextOverflow}`}\n >\n {third.name}\n </Link>\n </Typography>\n </Box>\n )}\n </Box>\n );\n};\n\nexport default Breadcrumbs;\n","import { Box, Button, Grid, makeStyles, Typography } from \"@material-ui/core\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport React from \"react\";\nimport { Link as RouterLink } from \"react-router-dom\";\nimport { useFontStyles, useSpacingStyles } from \"../styles\";\nimport { IEntityListProps } from \"./EntityList.types\";\nimport { BORDER_RADIUS } from \"../globals\";\n\nconst useStyles = makeStyles((theme) => ({\n container: {\n marginRight: theme.spacing(-1.5),\n marginLeft: theme.spacing(-1.5),\n },\n svgContainer: {\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n button: {\n display: \"block\",\n textDecoration: \"none\",\n borderRadius: BORDER_RADIUS,\n height: \"100%\",\n width: \"100%\",\n textAlign: \"center\",\n },\n orgLabel: {\n padding: theme.spacing(1),\n paddingTop: 0,\n },\n}));\n\nconst EntityList: React.FC<IEntityListProps> = ({\n entities,\n icon,\n loadingMessage = \"Loading list...\",\n emptyMessage = \"List is empty\",\n onClick,\n}) => {\n const classes = {\n ...useStyles(),\n ...useSpacingStyles(),\n ...useFontStyles(),\n };\n\n return (\n <Box className={classes.container}>\n {!entities ? (\n <LoadingSpinner text={loadingMessage} />\n ) : entities.length ? (\n <Grid container spacing={3}>\n {entities.map((entity, index) => (\n <Grid key={`${entity.name}-${index}`} item xs={4} md={3}>\n <Button\n className={classes.button}\n key={entity.name}\n {...(onClick\n ? { onClick: () => onClick(entity) }\n : {\n component: RouterLink,\n to: entity.link,\n })}\n >\n <Box className={`${classes.svgContainer} ${classes.labelBreak}`}>\n {icon(entity)}\n </Box>\n <Typography className={classes.orgLabel} variant=\"body1\">\n {entity.name}\n </Typography>\n </Button>\n </Grid>\n ))}\n </Grid>\n ) : (\n <Typography className={classes.centerText} variant=\"body2\" color=\"textSecondary\">\n {emptyMessage}\n </Typography>\n )}\n </Box>\n );\n};\n\nexport default EntityList;\n","import React from \"react\";\nimport ErrorIcon from \"@material-ui/icons/Error\";\nimport { Typography, Box } from \"@material-ui/core\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { IErrorIndicatorProps } from \"./ErrorIndicator.types\";\n\nconst ErrorIndicator: React.FC<IErrorIndicatorProps> = ({\n text = \"Something went wrong\",\n}) => {\n const classes = { ...useSpacingStyles(), ...useLayoutStyles() };\n\n return (\n <Box className={classes.flexCenter}>\n <ErrorIcon fontSize=\"medium\" className={classes.rightSpacer1} color=\"error\" />\n <Typography variant=\"body2\" color=\"textSecondary\">\n {text}\n </Typography>\n </Box>\n );\n};\n\nexport default ErrorIndicator;\n","import React, { useState } from \"react\";\nimport {\n makeStyles,\n List,\n ListItem,\n ListItemIcon,\n ListItemText,\n Collapse,\n Typography,\n Box,\n} from \"@material-ui/core\";\nimport { ExpandLess, ExpandMore } from \"@material-ui/icons\";\nimport { useLocation, Link as RouterLink } from \"react-router-dom\";\nimport { useFontStyles, useSpacingStyles } from \"../styles\";\nimport { IListItemProps, INavListItemStyleProps } from \"./LeftNavigation.types\";\n\nconst useNavListStyles = makeStyles((theme) => ({\n listIcon: {\n minWidth: \"auto\",\n paddingRight: \"0.25rem\",\n },\n mainIconSize: {\n fontSize: \"1rem\",\n },\n mainIconMarginAdjustment: {\n marginTop: \"3px\",\n },\n textOverflowElipsis: {\n overflow: \"hidden\",\n textOverflow: \"ellipsis\",\n },\n mainListItem: (props: INavListItemStyleProps) => ({\n padding: \"8px 24px 8px 16px\",\n alignItems: \"flex-start\",\n backgroundColor: props.mainBackground || theme.palette.common.white,\n color: props.mainText || theme.palette.text.primary,\n borderRadius: theme.spacing(0.6),\n \"&:hover\": {\n backgroundColor: props.mainHover || theme.palette.action.hover,\n },\n }),\n mainIconColor: (props: INavListItemStyleProps) => ({\n color: props.mainIcon || theme.palette.grey[500],\n }),\n\n activeMainIconColor: (props: INavListItemStyleProps) => ({\n color: props.mainActiveText || \"#8FC1FF\",\n }),\n\n subListItem: (props: INavListItemStyleProps) => ({\n backgroundColor: props.subItemBackground || \"#FFFFFF\",\n color: props.subItemText || theme.palette.text.secondary,\n borderRadius: \"8px\",\n \"&:hover\": {\n backgroundColor: props.subItemHover || \"rgba(143,193,255,0.3)\",\n },\n }),\n\n activeSubListItem: (props: INavListItemStyleProps) => ({\n backgroundColor: props.subItemActiveBackground || \"#FFFFFF\",\n color: props.subItemActiveText || \"#8FC1FF\",\n \"&:hover\": {\n backgroundColor: props.subItemActiveHover || \"rgba(143,193,255,0.3)\",\n },\n }),\n\n subItemBorder: {\n borderLeft: `1px solid ${theme.palette.grey[600]}`,\n marginLeft: \"1px\",\n marginRight: \"1px\",\n width: \"100%\",\n height: \"100%\",\n },\n relativeWrapper: {\n position: \"relative\",\n },\n subItemBorderMask: (props: INavListItemStyleProps) => ({\n borderLeft: `3px solid ${props.subItemActiveText || \"#8FC1FF\"}`,\n borderRadius: \"1px\",\n position: \"absolute\",\n top: \"50%\",\n bottom: \"50%\",\n transition: \"all 0.2s ease-in-out\",\n }),\n activeSubItemBorder: {\n top: \"0 !important\",\n bottom: \"0 !important\",\n },\n subItemWrapper: {\n display: \"flex\",\n marginLeft: \"13px\",\n marginRight: \"16px\",\n },\n noYMargin: {\n marginTop: \"unset\",\n marginBottom: \"unset\",\n },\n}));\n\nconst isItemActive = (currentPathname: string, id: string) => {\n if (currentPathname.split(\"/\").includes(id)) {\n return true;\n }\n return false;\n};\n\nconst NavListItem: React.FC<IListItemProps> = ({ mainItem, subItems, config, Icon }) => {\n const classes = {\n ...useFontStyles(),\n ...useSpacingStyles(),\n ...useNavListStyles({\n ...(config.secondary?.mainItemColors || {}),\n ...(config.secondary?.subItemColors || {}),\n }),\n };\n const location = useLocation();\n\n const activeMainItem = isItemActive(location.pathname, mainItem.id);\n const [subExpanded, setSubExpanded] = useState<boolean>(\n subItems?.length ? activeMainItem : false\n );\n\n return (\n <>\n <ListItem\n button\n dense\n className={classes.mainListItem}\n component={RouterLink}\n to={mainItem.route}\n >\n <ListItemIcon\n className={`${classes.listIcon} ${classes.mainIconMarginAdjustment} ${classes.rightSpacer1}`}\n >\n <Icon\n id=\"second-nav-item\"\n styling={`${classes.mainIconSize} ${classes.mainIconColor} ${\n activeMainItem ? classes.activeMainIconColor : \"\"\n }`}\n />\n </ListItemIcon>\n <ListItemText\n disableTypography\n className={classes.noYMargin}\n primary={\n <Typography\n variant=\"body2\"\n className={`${classes.bolderText} ${classes.textOverflowElipsis}`}\n color=\"inherit\"\n >\n {mainItem.name}\n {subItems?.length ? (\n <Typography\n component=\"span\"\n variant=\"body2\"\n className={classes.bolderText}\n color=\"inherit\"\n >\n {\" \"}\n ({subItems.length})\n </Typography>\n ) : null}\n </Typography>\n }\n />\n {subItems?.length ? (\n <ListItemIcon\n className={classes.listIcon}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n setSubExpanded((expanded) => !expanded);\n }}\n >\n {subExpanded ? <ExpandLess /> : <ExpandMore />}\n </ListItemIcon>\n ) : null}\n </ListItem>\n {subItems?.length ? (\n <Collapse in={subExpanded} timeout=\"auto\" unmountOnExit>\n <List component=\"div\" disablePadding>\n {subItems.map(({ name, route, id }) => (\n <Box key={id} className={classes.subItemWrapper}>\n <Box className={`${classes.relativeWrapper} ${classes.rightSpacer1}`}>\n <Box className={`${classes.subItemBorder} `} />\n <Box\n className={`${classes.subItemBorderMask} ${\n isItemActive(location.pathname, id)\n ? classes.activeSubItemBorder\n : \"\"\n } `}\n />\n </Box>\n\n <ListItem\n key={route}\n component={RouterLink}\n to={route}\n button\n dense\n className={`${classes.subListItem} ${\n isItemActive(location.pathname, id) ? classes.activeSubListItem : \"\"\n }`}\n >\n <ListItemText\n disableTypography\n primary={\n <Typography\n variant=\"body2\"\n className={classes.textOverflowElipsis}\n color=\"inherit\"\n >\n {name}\n </Typography>\n }\n />\n </ListItem>\n </Box>\n ))}\n </List>\n </Collapse>\n ) : null}\n </>\n );\n};\n\nexport default NavListItem;\n","import { isValid } from \"date-fns\";\nimport { TableCellValues } from \"../EditableTable/EditableTable.types\";\n\nexport function sortDescendingStartDateString<T extends { startDate: string }>(\n array: T[]\n): T[] {\n return array.sort(\n (a, b) =>\n +b.startDate.split(\"T\")[0].replaceAll(\"-\", \"\") -\n +a.startDate.split(\"T\")[0].replaceAll(\"-\", \"\")\n );\n}\n\nexport const didCellValueChange = (\n oldVal: TableCellValues,\n newVal: TableCellValues,\n isDateValue?: boolean\n) =>\n isDateValue\n ? ((oldVal && isValid(oldVal) ? oldVal : new Date(0)) as Date).getTime() ===\n ((newVal && isValid(newVal) ? newVal : new Date(0)) as Date).getTime()\n : oldVal === newVal;\n","import React from \"react\";\nimport { Box, IconButton, makeStyles, Typography, List } from \"@material-ui/core\";\nimport NavListItem from \"./NavListItem\";\nimport { useHistory } from \"react-router-dom\";\nimport {\n ISecondaryLeftNavContainerProps,\n ISecondaryNavigationItem,\n} from \"./LeftNavigation.types\";\nimport { sortDescendingStartDateString } from \"../utils\";\nimport CloseIcon from \"@material-ui/icons/Close\";\nimport AddBoxOutlinedIcon from \"@material-ui/icons/AddBoxOutlined\";\nimport { useFontStyles, useSpacingStyles } from \"../styles\";\nimport { BORDER_RADIUS } from \"../globals\";\n\ntype SecondaryNavStyles = {\n titleColor?: string;\n titleIconColor?: string;\n};\n\nconst useSecondaryNavStyles = makeStyles((theme) => ({\n secondaryNavWrapper: {\n height: \"100%\",\n width: \"300px\",\n background: \"white\",\n overflowY: \"auto\",\n overflowX: \"hidden\",\n borderTopRightRadius: BORDER_RADIUS,\n borderBottomRightRadius: BORDER_RADIUS,\n marginLeft: \"-16px\",\n paddingLeft: \"16px\",\n border: `1px solid ${theme.palette.grey[300]}`,\n boxShadow: \"0 2px 4px 0 rgba(0, 0, 0, 0.3)\",\n boxSizing: \"border-box\",\n },\n titleWrapper: {\n marginTop: \"24px\",\n display: \"flex\",\n alignItems: \"center\",\n paddingLeft: \"16px\",\n paddingRight: \"16px\",\n },\n title: {\n fontSize: \"18px\",\n fontWeight: 500,\n color: (props: SecondaryNavStyles) => props.titleColor || \"#8FC1FF\",\n },\n titleIcons: {\n color: (props: SecondaryNavStyles) => props.titleIconColor || \"#8FC1FF\",\n },\n closeButton: {\n marginLeft: \"auto\",\n },\n archivedSeparator: {\n paddingLeft: \"8px\",\n color: theme.palette.grey[500],\n },\n archivedBorder: {\n marginTop: \"3rem\",\n border: `1px solid ${theme.palette.grey[200]}`,\n width: \"33%\",\n marginLeft: \"8px\",\n },\n listWrapper: {\n marginLeft: theme.spacing(1),\n marginRight: theme.spacing(1),\n },\n}));\n\nconst SecondaryLeftNavContainer: React.FC<ISecondaryLeftNavContainerProps> = ({\n secondaryNavItems,\n primaryNavItems,\n expandedOptions,\n setExpandedOptions,\n config,\n}) => {\n const stylesProps = {\n titleColor: config.secondary?.titleColor,\n titleIconColor: config.secondary?.titleIconColor,\n };\n const classes = {\n ...useSpacingStyles(),\n ...useFontStyles(),\n ...useSecondaryNavStyles(stylesProps),\n };\n const history = useHistory();\n\n const navItem = secondaryNavItems[expandedOptions.view];\n\n if (!navItem) return null;\n\n const mainItemIcon = primaryNavItems.find(\n (item) => item.field === expandedOptions.view\n )!.Icon;\n\n return (\n <Box className={classes.secondaryNavWrapper}>\n <Box className={classes.titleWrapper}>\n <Typography className={`${classes.rightSpacer1} ${classes.title}`}>\n {expandedOptions.view}\n </Typography>\n {navItem.button ? (\n <IconButton\n className={classes.titleIcons}\n size=\"small\"\n type=\"button\"\n onClick={() => history.push(navItem.button!.url)}\n >\n <AddBoxOutlinedIcon />\n </IconButton>\n ) : null}\n <IconButton\n className={`${classes.titleIcons} ${classes.closeButton}`}\n size=\"small\"\n type=\"button\"\n onClick={() => setExpandedOptions({ view: \"\", expanded: false })}\n >\n {config.secondary?.closeButtonSvg || <CloseIcon />}\n </IconButton>\n </Box>\n\n <List className={classes.listWrapper} component=\"div\">\n {sortDescendingStartDateString<ISecondaryNavigationItem>(navItem.items).map(\n (item) => (\n <NavListItem\n key={item.mainItem.route}\n {...item}\n config={config}\n Icon={mainItemIcon}\n />\n )\n )}\n {navItem.archivedItems?.length ? (\n <>\n <Box className={`${classes.archivedBorder} ${classes.contentBreak}`} />\n <Typography\n variant=\"body2\"\n className={`${classes.archivedSeparator} ${classes.bolderText}`}\n >\n Archived {expandedOptions.view}\n </Typography>\n {sortDescendingStartDateString<ISecondaryNavigationItem>(\n navItem.archivedItems\n ).map((item) => (\n <NavListItem\n key={item.mainItem.route}\n {...item}\n config={config}\n Icon={mainItemIcon}\n />\n ))}\n </>\n ) : null}\n </List>\n </Box>\n );\n};\n\nexport default SecondaryLeftNavContainer;\n","import React from \"react\";\nimport { useLocation, Link as RouterLink } from \"react-router-dom\";\nimport {\n Box,\n List,\n ListItem,\n ListItemIcon,\n makeStyles,\n Typography,\n} from \"@material-ui/core\";\nimport { IPrimaryConfig, IPrimaryLeftNavContainerProps } from \"./LeftNavigation.types\";\nimport { BORDER_RADIUS } from \"../globals\";\n\nconst usePrimaryLeftNavStyles = makeStyles((theme) => ({\n primaryNavContainer: (props: IPrimaryConfig) => ({\n background: props.background || \"linear-gradient(to bottom, #253a68 40%, #73c4ca)\",\n border: `2px solid ${props.activeBorderColor || \"#8FC1FF\"}`,\n borderLeft: \"none\",\n borderTopRightRadius: BORDER_RADIUS,\n borderBottomRightRadius: BORDER_RADIUS,\n minWidth: \"4.5rem\",\n overflowY: \"auto\",\n overflowX: \"hidden\",\n }),\n listWrapper: {\n display: \"flex\",\n flexDirection: \"column\",\n paddingTop: 0,\n },\n itemWrapper: {\n display: \"flex\",\n flexDirection: \"column\",\n padding: \"0.75rem 0.5rem 0.5rem 0.5rem\",\n },\n itemBorder: {\n borderRight: (props: IPrimaryConfig) =>\n `6px solid ${props.activeBorderColor || \"#8FC1FF\"}`,\n position: \"absolute\",\n bottom: \"50%\",\n top: \"50%\",\n transition: \"all 0.2s ease-in-out\",\n right: \"-3px\",\n },\n activeBorder: {\n top: \"15%\",\n bottom: \"15%\",\n },\n iconWrapper: {\n minWidth: 0,\n marginBottom: \"4px\",\n position: \"relative\",\n },\n itemName: {\n fontSize: \"0.7rem\",\n maxWidth: \"3.5rem\",\n textAlign: \"center\",\n textOverflow: \"ellipsis\",\n overflow: \"hidden\",\n },\n textColour: {\n color: (props: IPrimaryConfig) => props.text || \"#FFFFFF\",\n },\n activeTextColour: {\n color: (props: IPrimaryConfig) => props.activeText || \"#8FC1FF\",\n },\n lastItem: {\n marginTop: \"auto\",\n },\n}));\n\nconst PrimaryLeftNavContainer: React.FC<IPrimaryLeftNavContainerProps> = ({\n expandedOptions,\n setExpandedOptions,\n navigationLinks,\n config,\n}) => {\n const location = useLocation();\n const classes = usePrimaryLeftNavStyles({ ...(config.primary || {}) });\n\n const applyActiveBackground = (fieldName: string, path: string) => {\n if (expandedOptions.view === \"\") {\n if (location.pathname === path) {\n return true;\n } else if (\n fieldName !== config.rootRouteName &&\n location.pathname.startsWith(path)\n ) {\n return true;\n } else return false;\n } else if (expandedOptions.view === fieldName) {\n return true;\n } else return false;\n };\n\n return (\n <List className={`${classes.primaryNavContainer} ${classes.listWrapper}`}>\n {navigationLinks.map((item, index, arr) => (\n <ListItem\n key={item.field}\n button\n className={`${classes.itemWrapper} ${classes.textColour} ${\n config.primary?.moveLastItemToBottom && index === arr.length - 1\n ? classes.lastItem\n : \"\"\n }`}\n {...(!!item.hasSecondary ? {} : { component: RouterLink, to: item.path })}\n onClick={() => {\n setExpandedOptions({ view: item.field, expanded: !!item.hasSecondary });\n }}\n >\n <ListItemIcon className={classes.iconWrapper}>\n <item.Icon\n styling={`${classes.textColour} ${\n applyActiveBackground(item.field, item.path)\n ? classes.activeTextColour\n : \"\"\n }`}\n />\n </ListItemIcon>\n <Typography\n variant=\"caption\"\n className={`${classes.itemName} ${classes.textColour} ${\n applyActiveBackground(item.field, item.path) ? classes.activeTextColour : \"\"\n }`}\n >\n {item.field}\n </Typography>\n <Box\n className={`${classes.itemBorder} ${\n applyActiveBackground(item.field, item.path) ? classes.activeBorder : \"\"\n }`}\n />\n </ListItem>\n ))}\n </List>\n );\n};\n\nexport default PrimaryLeftNavContainer;\n","import React, { useState, useEffect } from \"react\";\nimport { useLocation } from \"react-router-dom\";\nimport SecondaryLeftNavContainer from \"./SecondaryLeftNavigation\";\nimport PrimaryLeftNavContainer from \"./PrimaryLeftNavigation\";\nimport { Box, makeStyles } from \"@material-ui/core\";\nimport { ILeftNavigationProps } from \"./LeftNavigation.types\";\n\nconst useLeftNavStyles = makeStyles({\n leftNavContainer: {\n height: \"100%\",\n display: \"flex\",\n position: \"relative\",\n width: \"max-content\",\n },\n});\n\nconst LeftNavigation: React.FC<ILeftNavigationProps> = ({\n primaryNavItems,\n secondaryNavItems,\n config,\n}) => {\n const [expandedOptions, setExpandedOptions] = useState({\n view: \"\",\n expanded: false,\n });\n\n const styles = useLeftNavStyles();\n const location = useLocation();\n\n const navsWithSecondary = primaryNavItems.reduce(\n (navs, nav) => (nav.hasSecondary ? [...navs, nav.field] : navs),\n [] as string[]\n );\n\n useEffect(() => {\n setExpandedOptions((prev) => {\n if (navsWithSecondary.includes(prev.view) && prev.expanded === true) {\n return prev;\n } else return { view: \"\", expanded: false };\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [location.pathname]);\n\n return (\n <Box component=\"nav\" className={styles.leftNavContainer}>\n <PrimaryLeftNavContainer\n expandedOptions={expandedOptions}\n setExpandedOptions={setExpandedOptions}\n navigationLinks={primaryNavItems}\n config={config}\n />\n\n {expandedOptions.expanded && (\n <SecondaryLeftNavContainer\n secondaryNavItems={secondaryNavItems}\n primaryNavItems={primaryNavItems}\n expandedOptions={expandedOptions}\n setExpandedOptions={setExpandedOptions}\n config={config}\n />\n )}\n </Box>\n );\n};\nexport default LeftNavigation;\n","import React from \"react\";\nimport { Box, Container, makeStyles } from \"@material-ui/core\";\nimport { IMainLayoutProps, IMainLayoutStyleProps } from \"./MainLayout.types\";\n\nconst useMainLayoutStyles = makeStyles((theme) => ({\n remainingHeightBox: {\n position: \"absolute\",\n top: (props: IMainLayoutStyleProps) => props.topOffset ?? \"4rem\",\n bottom: 0,\n left: 0,\n right: 0,\n display: \"flex\",\n },\n fullHeightFlexbox: {\n display: \"flex\",\n height: \"100%\",\n },\n relativeContainer: {\n position: \"relative\",\n },\n scrollWrapper: {\n overflow: \"auto\",\n },\n componentWrapper: {\n padding: theme.spacing(2),\n paddingBottom: theme.spacing(2),\n position: \"relative\",\n },\n}));\n\nconst MainLayout: React.FC<IMainLayoutProps> = ({\n sideNavigation,\n children,\n desktopWidth,\n topOffset,\n}) => {\n const classes = useMainLayoutStyles({ topOffset });\n return (\n <Box className={classes.remainingHeightBox}>\n {sideNavigation ? (\n <Box className={`${classes.fullHeightFlexbox} ${classes.relativeContainer}`}>\n {sideNavigation}\n </Box>\n ) : null}\n <Container disableGutters maxWidth={false} className={classes.scrollWrapper}>\n <Container\n disableGutters\n maxWidth={desktopWidth ? \"xl\" : \"lg\"}\n className={classes.componentWrapper}\n >\n {children}\n </Container>\n </Container>\n </Box>\n );\n};\n\nexport default MainLayout;\n","import { useCallback, useEffect } from \"react\";\n\nconst useDebounceEffect = (\n effect: (query: string) => void,\n deps: any[],\n delay: number = 250\n) => {\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const callback = useCallback(effect, deps);\n\n useEffect(() => {\n const timeout = setTimeout(callback, delay);\n return () => clearTimeout(timeout);\n }, [callback, delay]);\n};\n\nexport default useDebounceEffect;\n","import { useEffect, useRef } from \"react\";\n\nconst useInterval = (callback: () => void, delay: number | null) => {\n const savedCallback = useRef<() => void | undefined>();\n\n useEffect(() => {\n savedCallback.current = callback;\n });\n\n useEffect(() => {\n const tick = () => {\n if (savedCallback.current) savedCallback.current();\n };\n\n if (delay !== null) {\n const id = setInterval(tick, delay);\n return () => clearInterval(id);\n }\n }, [delay]);\n};\n\nexport default useInterval;\n","import { isEqual } from \"lodash\";\nimport { useRef, useEffect } from \"react\";\n\nexport default function useWhyDidYouUpdate(name: string, props: Record<string, any>) {\n const latestProps = useRef(props);\n\n useEffect(() => {\n const allKeys = Object.keys({ ...latestProps.current, ...props });\n\n const changesObj: Record<\n string,\n { from: any; to: any; isDeepEqual: boolean; changedKeys?: string[] }\n > = {};\n allKeys.forEach((key) => {\n if (latestProps.current[key] !== props[key]) {\n changesObj[key] = {\n from: latestProps.current[key],\n to: props[key],\n changedKeys:\n props[key] && typeof props[key] === \"object\"\n ? Object.keys(latestProps.current[key])\n .map((k) => (latestProps.current[key][k] === props[key][k] ? \"\" : k))\n .filter(Boolean)\n : undefined,\n isDeepEqual: isEqual(latestProps.current[key], props[key]),\n };\n }\n });\n\n if (Object.keys(changesObj).length) {\n console.log(\"[why-did-you-update]\", name, {\n changes: changesObj,\n props: { from: latestProps.current, to: props },\n });\n }\n\n latestProps.current = props;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, Object.values(props));\n}\n","import { Divider, List, ListItem, makeStyles, Typography } from \"@material-ui/core\";\nimport React from \"react\";\nimport { Link as RouterLink } from \"react-router-dom\";\nimport { BORDER_RADIUS } from \"../globals\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { IAlphabeticalListProps } from \"./AlphabeticalList.types\";\n\nconst useAlphabeticalListStyles = makeStyles((theme) => ({\n divider: {\n background: theme.palette.primary.main,\n height: \"0.2rem\",\n },\n letterHeader: {\n cursor: \"default\",\n color: theme.palette.primary.main,\n marginTop: \"1rem\",\n },\n listItem: {\n borderRadius: BORDER_RADIUS,\n border: `1px solid ${theme.palette.grey[300]}`,\n marginBottom: \"0.5rem\",\n paddingLeft: \"24px\",\n boxShadow: theme.shadows[1],\n },\n topMargin: {\n marginTop: theme.spacing(2),\n display: \"block\",\n },\n}));\n\nconst AlphabeticalList: React.FC<IAlphabeticalListProps> = ({\n array,\n sortFn,\n sortKey = \"name\",\n buttonClick,\n linkTo,\n ItemTemplate,\n arrayKey = \"id\",\n loadingMessage = \"Loading list...\",\n emptyMessage = \"List is empty\",\n alphabetisedHeader = true,\n}) => {\n const classes = {\n ...useAlphabeticalListStyles(),\n ...useSpacingStyles(),\n ...useLayoutStyles(),\n };\n\n if (array === undefined) {\n return <LoadingSpinner styling={classes.topMargin} text={loadingMessage} />;\n }\n\n if (!array?.length) {\n return (\n <Typography\n className={classes.topMargin}\n align=\"center\"\n variant=\"body2\"\n color=\"textSecondary\"\n >\n {emptyMessage}\n </Typography>\n );\n }\n\n const result = sortFn ? [...array].sort(sortFn) : array;\n let lastSection = \"\";\n\n return (\n <List className={classes.limitWidth50rem}>\n {result.map((item, index) => {\n let showHeader = false;\n if (alphabetisedHeader) {\n const currentKey = (item[sortKey]?.[0] || \"???\").toLowerCase();\n\n if (currentKey !== lastSection) {\n lastSection = currentKey;\n showHeader = true;\n }\n }\n\n return (\n <React.Fragment key={item[arrayKey] || `alphabetical-list-${index}`}>\n {alphabetisedHeader && showHeader ? (\n <>\n <Typography className={`${classes.letterHeader}`} align=\"left\">\n {lastSection.toUpperCase()}\n </Typography>\n <Divider className={`${classes.contentBreak} ${classes.divider}`} />\n </>\n ) : null}\n\n <ListItem\n className={classes.listItem}\n alignItems=\"flex-start\"\n button={(buttonClick || linkTo ? true : undefined) as true & undefined}\n onClick={buttonClick ? () => buttonClick(item) : undefined}\n {...(linkTo && !buttonClick\n ? { component: RouterLink, to: linkTo(item) }\n : {})}\n >\n <ItemTemplate item={item} />\n </ListItem>\n </React.Fragment>\n );\n })}\n </List>\n );\n};\n\nexport default AlphabeticalList;\n","import React, { useEffect, useState } from \"react\";\nimport { Box, InputBase, InputAdornment, makeStyles } from \"@material-ui/core\";\nimport SearchIcon from \"@material-ui/icons/Search\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { useDebounceEffect } from \"../hooks\";\nimport { ISearchBarProps } from \"./SearchBar.types\";\nimport { BORDER_RADIUS } from \"../globals\";\nimport AlphabeticalList from \"../AlphabeticalList/AlphabeticalList\";\n\ntype StylesProps = {\n background: string | undefined;\n};\n\nconst useSearchBarStyles = makeStyles((theme) => ({\n searchBox: {\n display: \"flex\",\n alignContent: \"center\",\n alignItems: \"center\",\n padding: \"8px\",\n border: `2px solid ${theme.palette.grey[300]}`,\n borderRadius: BORDER_RADIUS,\n },\n searchField: {\n borderRadius: BORDER_RADIUS,\n width: \"100%\",\n background: ({ background }: StylesProps) => background || \"RGBA(179, 213, 235, 0.1)\",\n height: \"46px\",\n paddingLeft: \"24px\",\n color: theme.palette.grey[600],\n },\n searchIcon: {\n color: theme.palette.grey[600],\n },\n}));\n\nconst SearchBar: React.FC<ISearchBarProps> = ({\n array,\n sortFn,\n sortKey = \"name\",\n buttonClick,\n linkTo,\n ItemTemplate,\n arrayKey = \"id\",\n loadingMessage = \"Loading list...\",\n emptyMessage = \"List is empty\",\n inputBackgroundColor,\n placeholder,\n disabledSearch,\n delay = 500,\n minQueryLength = 3,\n handleOnChange,\n searchKeys = [\"name\"],\n alphabetisedHeader = true,\n}) => {\n const classes = {\n ...useSpacingStyles(),\n ...useLayoutStyles(),\n ...useSearchBarStyles({ background: inputBackgroundColor }),\n };\n const [searchInput, setSearchInput] = useState(\"\");\n const [blockSearch, setBlockSearch] = useState(false);\n const [result, setResult] = useState(array);\n\n useDebounceEffect(\n () => {\n if (!blockSearch && searchInput.length >= minQueryLength) {\n if (handleOnChange) {\n handleOnChange(searchInput);\n } else {\n setResult(\n array?.filter((item) => {\n const itemIsFound = searchKeys.some((key) =>\n item[key]?.toLowerCase().includes(searchInput.toLowerCase())\n );\n return itemIsFound;\n })\n );\n }\n }\n },\n [searchInput],\n delay\n );\n\n useEffect(() => {\n setResult(array);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [array]);\n\n return (\n <>\n <Box className={`${classes.searchBox} ${classes.limitWidth50rem}`}>\n <InputBase\n disabled={disabledSearch}\n type=\"text\"\n value={searchInput}\n placeholder={placeholder || \"Enter to search\"}\n onChange={(event) => {\n if (blockSearch) setBlockSearch(false);\n setSearchInput(event.target.value);\n }}\n className={classes.searchField}\n endAdornment={\n <InputAdornment position=\"end\" className={classes.rightSpacer2}>\n <SearchIcon className={classes.searchIcon} />\n </InputAdornment>\n }\n />\n </Box>\n {array !== null && (\n <AlphabeticalList\n array={result}\n sortFn={sortFn}\n sortKey={sortKey}\n buttonClick={buttonClick}\n linkTo={linkTo}\n ItemTemplate={ItemTemplate}\n arrayKey={arrayKey}\n loadingMessage={loadingMessage}\n emptyMessage={emptyMessage}\n alphabetisedHeader={alphabetisedHeader}\n />\n )}\n </>\n );\n};\n\nexport default SearchBar;\n","import React from \"react\";\nimport { TextField as MaterialTextField, makeStyles } from \"@material-ui/core\";\nimport NumberFormat, { NumberFormatProps } from \"react-number-format\";\nimport { ITextFieldProps } from \"./TextField.types\";\nimport { BORDER_RADIUS, NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\n\nconst useStyles = makeStyles((theme) => ({\n inputField: ({ size }: { size: \"small\" | \"medium\" }) => ({\n borderRadius: BORDER_RADIUS,\n ...(size === \"small\" ? theme.typography.body2 : {}),\n }),\n labelStyles: ({ size }: { size: \"small\" | \"medium\" }) => ({\n ...(size === \"small\"\n ? {\n transform: \"translate(14px, 9px) scale(1) !important\",\n ...theme.typography.body2,\n \"&.MuiInputLabel-outlined.MuiInputLabel-shrink\": {\n transform: \"translate(15px, -9px) scale(0.75) !important\",\n },\n }\n : {}),\n }),\n}));\n\nconst TextField: React.FC<ITextFieldProps> = ({\n size = \"small\",\n styling,\n numberField,\n inputProps = {},\n InputProps = {},\n accessLevel,\n disabled,\n fixedDecimalScale,\n ...rest\n}) => {\n const classes = useStyles({ size });\n\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n const inputPropsForNumberField = {\n ...(numberField && { fixedDecimalScale: !!fixedDecimalScale }),\n };\n\n return (\n <MaterialTextField\n className={styling || \"\"}\n disabled={disabledProp}\n {...rest}\n inputProps={{\n ...inputProps,\n ...inputPropsForNumberField,\n }}\n InputProps={{\n ...InputProps,\n className: classes.inputField,\n inputComponent: numberField ? (NumberFormatField as any) : undefined,\n }}\n InputLabelProps={{\n className: classes.labelStyles,\n }}\n variant=\"outlined\"\n size={size}\n />\n );\n};\n\nexport default TextField;\n\ninterface INumberFormatProps extends Omit<NumberFormatProps, \"onChange\"> {\n onChange: (event: { target: { name: string; value: string } }) => void;\n inputRef: (instance: NumberFormat | null) => void;\n fixedDecimalScale: boolean;\n}\n\nexport const NumberFormatField = (props: INumberFormatProps) => {\n const { inputRef, onChange, ...other } = props;\n\n return (\n <NumberFormat\n {...other}\n getInputRef={inputRef}\n onValueChange={(values) => {\n onChange({\n target: {\n name: props.name || \"\",\n value: values.value,\n },\n });\n }}\n thousandSeparator\n decimalScale={2}\n isNumericString\n />\n );\n};\n","import { makeStyles, MenuItem } from \"@material-ui/core\";\nimport React from \"react\";\nimport { BORDER_RADIUS, NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\nimport TextField from \"../TextField/TextField\";\nimport { ISelectProps, IStyleProps } from \"./Select.types\";\n\nconst useSelectStyles = makeStyles((theme) => ({\n listItem: ({ background, size }: IStyleProps) => ({\n overflow: \"auto\",\n scrollbarWidth: \"thin\",\n ...(size === \"small\" ? theme.typography.body2 : {}),\n \"&:hover\": {\n backgroundColor: `${background} !important`,\n },\n }),\n inputStyles: ({ background, size }: IStyleProps) => ({\n borderRadius: `${BORDER_RADIUS} !important`,\n ...(size === \"small\"\n ? { paddingTop: \"9.5px\", paddingBottom: \"8.5px\", ...theme.typography.body2 }\n : {}),\n \"&:focus\": {\n backgroundColor: background,\n },\n }),\n selectedListItem: ({ background }: IStyleProps) => ({\n \"&:focus\": {\n background: `${background} !important`,\n },\n }),\n}));\n\nconst Select: React.FC<ISelectProps> = ({\n selectOptions,\n background = \"#EFEDFF\",\n size = \"small\",\n styling,\n disabled,\n accessLevel,\n ...rest\n}) => {\n const classes = useSelectStyles({ background, size });\n\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n return (\n <TextField\n className={styling || \"\"}\n {...rest}\n disabled={disabledProp}\n size={size}\n SelectProps={{\n inputProps: {\n className: classes.inputStyles,\n },\n }}\n select\n >\n {selectOptions.map((option) => (\n <MenuItem\n key={option.value}\n value={option.value}\n className={classes.listItem}\n classes={{ selected: classes.selectedListItem }}\n >\n {option.description}\n </MenuItem>\n ))}\n </TextField>\n );\n};\n\nexport default Select;\n","import React from \"react\";\nimport {\n DatePicker as MaterialDatePicker,\n MuiPickersUtilsProvider,\n} from \"@material-ui/pickers\";\nimport DateFnsUtils from \"@date-io/date-fns\";\nimport TextField from \"../TextField/TextField\";\nimport { IDatePickerProps } from \"./DatePicker.types\";\nimport { NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\n\nconst DatePicker: React.FC<IDatePickerProps> = ({\n styling,\n format = \"dd MMM yyyy\",\n minDate = new Date(\"1856-09-25\"),\n accessLevel,\n disabled,\n ...rest\n}) => {\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n return (\n <MuiPickersUtilsProvider utils={DateFnsUtils}>\n <MaterialDatePicker\n className={styling || \"\"}\n {...rest}\n disabled={disabledProp}\n inputVariant=\"outlined\"\n autoOk\n format={format}\n minDate={minDate}\n TextFieldComponent={TextField}\n />\n </MuiPickersUtilsProvider>\n );\n};\n\nexport default DatePicker;\n","import React from \"react\";\nimport {\n KeyboardDatePicker as MaterialDatePicker,\n MuiPickersUtilsProvider,\n} from \"@material-ui/pickers\";\nimport DateFnsUtils from \"@date-io/date-fns\";\nimport TextField from \"../TextField/TextField\";\nimport { IKeyboardDatePickerProps } from \"./KeyboardDatePicker.types\";\nimport { NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\n\nconst KeyboardDatePicker: React.FC<IKeyboardDatePickerProps> = ({\n styling,\n format = \"dd/MM/yyyy\",\n minDate = new Date(\"1856-09-25\"),\n accessLevel,\n disabled,\n ...rest\n}) => {\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n return (\n <MuiPickersUtilsProvider utils={DateFnsUtils}>\n <MaterialDatePicker\n className={styling || \"\"}\n {...rest}\n disabled={disabledProp}\n inputVariant=\"outlined\"\n autoOk\n allowKeyboardControl\n format={format}\n minDate={minDate}\n TextFieldComponent={TextField}\n />\n </MuiPickersUtilsProvider>\n );\n};\n\nexport default KeyboardDatePicker;\n","import { Box, makeStyles, Typography } from \"@material-ui/core\";\nimport React, { useEffect, useState } from \"react\";\nimport Button from \"../Button/Button\";\nimport { NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\nimport { useInterval } from \"../hooks\";\nimport { useSpacingStyles } from \"../styles\";\nimport { IButtonWithConfirmProps } from \"./ButtonWithConfirm.types\";\n\nconst useButtonWithConfirmStyles = makeStyles((theme) => ({\n confirmWrapper: {\n display: \"inline-block\",\n },\n confirmContainer: {\n display: \"flex\",\n alignItems: \"center\",\n },\n whiteText: {\n color: theme.palette.common.white,\n },\n}));\n\nconst ButtonWithConfirm: React.FC<IButtonWithConfirmProps> = ({\n children,\n onClick,\n styling,\n disabled = false,\n variant = \"outlined\",\n color = \"primary\",\n accessLevel = \"\",\n ...rest\n}) => {\n const classes = { ...useSpacingStyles(), ...useButtonWithConfirmStyles() };\n const [confirmView, setConfirmView] = useState(false);\n const [stopInterval, setStopInterval] = useState<boolean>(false);\n\n useInterval(() => setConfirmView(false), !confirmView || stopInterval ? null : 4500);\n\n useEffect(() => {\n setStopInterval(rest.loading);\n setConfirmView(rest.loading);\n }, [rest.loading]);\n\n if ([NO_ACCESS_LEVEL, READ_LEVEL].includes(accessLevel)) return null;\n\n if (confirmView)\n return (\n <Box className={classes.confirmWrapper}>\n <Box className={classes.confirmContainer}>\n <Typography className={classes.rightSpacer1} variant=\"body1\">\n Are you sure?\n </Typography>\n <Button\n {...rest}\n type=\"button\"\n onClick={(e) => {\n setStopInterval(true);\n onClick(e);\n }}\n variant={\"contained\"}\n styling={classes.whiteText}\n disabled={disabled}\n color={color}\n >\n Confirm{rest.loading ? \"ing\" : \"\"}\n </Button>\n </Box>\n </Box>\n );\n\n return (\n <Button\n type=\"button\"\n variant={variant}\n disabled={disabled}\n styling={styling}\n color={color}\n onClick={() => setConfirmView(true)}\n >\n {children}\n </Button>\n );\n};\n\nexport default ButtonWithConfirm;\n","import React, { ReactChild, ReactNode } from \"react\";\nimport {\n Box,\n Checkbox,\n createStyles,\n FormControl,\n FormHelperText,\n InputAdornment,\n makeStyles,\n MenuItem,\n Select,\n TextField,\n Typography,\n withStyles,\n} from \"@material-ui/core\";\nimport { NumberFormatField } from \"../TextField/TextField\";\nimport {\n IAlignment,\n ICustomRenderFnProps,\n IEssentialRenderFnProps,\n} from \"./EditableTable.types\";\nimport { DatePicker, MuiPickersUtilsProvider } from \"@material-ui/pickers\";\nimport DateFnsUtils from \"@date-io/date-fns\";\nimport NumberFormat from \"react-number-format\";\n\nconst determineWidth = (value: string | number, fixedDecimalScale: boolean) => {\n const valueLength = value.toString().length;\n if (!valueLength) return \"6ch\";\n return `${\n valueLength + (fixedDecimalScale ? 3 : 1) + Math.floor(valueLength / 3) / 3\n }ch`;\n};\n\nconst useDefaultTableCellsStyles = makeStyles((theme) => ({\n inputBase: ({ textAlign }: { textAlign?: IAlignment }) => ({\n height: \"unset\",\n padding: 0,\n textAlign: textAlign || \"center\",\n }),\n input: ({ textAlign }: { textAlign?: IAlignment }) => ({\n textAlign: textAlign || \"center\",\n marginRight: \"0.4rem\",\n marginLeft: \"0.4rem\",\n }),\n startAdornment: {\n color: theme.palette.text.secondary,\n },\n modifiedUnderline: {\n \"&:not(.Mui-disabled):before\": {\n borderBottom: \"none\",\n transition: \"none\",\n },\n \"&:hover:not(.Mui-disabled):before\": {\n borderBottom: `1px solid ${theme.palette.grey[\"500\"]} !important`,\n },\n },\n body2Text: {\n ...theme.typography.body2,\n },\n dateFieldWidth: {\n width: \"8ch\",\n },\n fullDateWidth: {\n width: \"11ch\",\n },\n justifyStart: {\n justifyContent: \"flex-start\",\n },\n justifyCenter: {\n justifyContent: \"center\",\n },\n justifyEnd: {\n justifyContent: \"flex-end\",\n },\n totalContainer: {\n display: \"flex\",\n alignItems: \"center\",\n cursor: \"default\",\n },\n selectFocusBackground: {\n \"&:focus\": {\n backgroundColor: \"unset\",\n },\n },\n}));\n\nexport const TableTextField: React.FC<IEssentialRenderFnProps> = ({\n error,\n disabled,\n value,\n onBlur,\n onChange,\n prefix,\n suffix,\n numberField = false,\n textAlign,\n fixedDecimalScale,\n}) => {\n const classes = useDefaultTableCellsStyles({ textAlign });\n\n const inputPropsForNumberField = {\n ...(numberField && { fixedDecimalScale: !!fixedDecimalScale }),\n };\n\n if (typeof value === \"string\" || typeof value === \"number\") {\n return (\n <TextField\n error={!!error}\n inputProps={{\n className: classes.inputBase,\n style: { width: determineWidth(value, !!fixedDecimalScale) },\n ...inputPropsForNumberField,\n }}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n InputProps={{\n startAdornment: prefix ? (\n <InputAdornment position=\"end\" className={classes.startAdornment}>\n {prefix}\n </InputAdornment>\n ) : null,\n endAdornment: suffix ? (\n <InputAdornment position=\"start\" className={classes.startAdornment}>\n {suffix}\n </InputAdornment>\n ) : null,\n inputComponent: numberField ? (NumberFormatField as any) : undefined,\n className: `${classes.body2Text} ${classes.modifiedUnderline}`,\n classes: { input: classes.input },\n }}\n helperText={error || undefined}\n disabled={disabled}\n />\n );\n } else return <Typography variant=\"body2\">Incorrect value type</Typography>;\n};\n\nexport const tableTextField = (tableProps: ICustomRenderFnProps) => {\n return <TableTextField {...{ ...tableProps }} />;\n};\n\nexport const tableNumericStringField = (tableProps: ICustomRenderFnProps) => {\n return <TableTextField {...{ ...tableProps, numberField: true }} />;\n};\n\nexport const tableNumericStringFixedDecimalField = (tableProps: ICustomRenderFnProps) => {\n return (\n <TableTextField {...{ ...tableProps, numberField: true, fixedDecimalScale: true }} />\n );\n};\n\nexport const SelectionCheckbox = withStyles(\n createStyles({\n root: {\n padding: \"3px\",\n },\n })\n)(Checkbox);\n\ninterface ITableDatePicker extends IEssentialRenderFnProps {\n fullDate?: boolean;\n}\n\nexport const TableDatePicker: React.FC<ITableDatePicker> = ({\n disabled,\n fullDate = false,\n value,\n error,\n onChange,\n onBlur,\n textAlign,\n}) => {\n const classes = useDefaultTableCellsStyles({ textAlign });\n\n return (\n <MuiPickersUtilsProvider utils={DateFnsUtils}>\n <DatePicker\n disabled={disabled}\n views={fullDate ? undefined : [\"year\", \"month\"]}\n value={value as string | Date}\n autoOk\n format={fullDate ? \"dd MMM yyyy\" : \"MMM yyyy\"}\n InputProps={{\n className: `${classes.body2Text} ${classes.modifiedUnderline}`,\n }}\n inputProps={{\n className: `${classes.inputBase} ${\n fullDate ? classes.fullDateWidth : classes.dateFieldWidth\n }`,\n classes: { input: classes.input },\n }}\n error={!!error}\n helperText={error || undefined}\n onChange={onChange}\n onBlur={onBlur}\n />\n </MuiPickersUtilsProvider>\n );\n};\n\nexport const tableDateField = (tableProps: ICustomRenderFnProps) => {\n return <TableDatePicker {...tableProps} />;\n};\n\nexport const tableInvoiceDateField = (tableProps: ICustomRenderFnProps) => {\n return <TableDatePicker {...tableProps} fullDate />;\n};\n\nconst TableCheckbox: React.FC<IEssentialRenderFnProps> = ({\n value,\n disabled,\n onChange,\n}) => {\n return (\n <Checkbox\n disabled={disabled}\n checked={value as boolean}\n onChange={onChange}\n color=\"primary\"\n size=\"small\"\n />\n );\n};\n\nexport const tableCheckbox = (tableProps: ICustomRenderFnProps) => {\n return <TableCheckbox {...tableProps} />;\n};\n\ninterface INonEditableField\n extends Pick<\n IEssentialRenderFnProps,\n \"numberField\" | \"prefix\" | \"suffix\" | \"textAlign\" | \"fixedDecimalScale\"\n > {\n text: React.ReactText;\n}\n\nexport const NonEditableField: React.FC<INonEditableField> = ({\n text,\n numberField = false,\n prefix = null,\n suffix = null,\n textAlign,\n fixedDecimalScale,\n}) => {\n const classes = useDefaultTableCellsStyles({});\n return (\n <Box\n className={`${classes.totalContainer} ${classes.body2Text} ${\n textAlign === \"left\"\n ? classes.justifyStart\n : textAlign === \"right\"\n ? classes.justifyEnd\n : classes.justifyCenter\n }`}\n >\n {prefix && prefix}\n <Box className={classes.body2Text}>\n {numberField ? (\n <NumberFormat\n value={text}\n displayType={\"text\"}\n thousandSeparator\n isNumericString\n decimalScale={2}\n fixedDecimalScale={fixedDecimalScale}\n />\n ) : (\n text\n )}\n </Box>\n {suffix && suffix}\n </Box>\n );\n};\n\ninterface ITableSelect extends IEssentialRenderFnProps {\n selectOptions: { [key: string]: ReactChild };\n}\n\nexport const TableSelect: React.FC<ITableSelect> = ({\n error,\n value,\n onBlur,\n onChange,\n selectOptions,\n disabled,\n}) => {\n const classes = useDefaultTableCellsStyles({});\n return (\n <FormControl margin=\"none\" error={!!error}>\n <Select\n className={`${classes.body2Text} ${classes.modifiedUnderline}`}\n inputProps={{ className: classes.selectFocusBackground }}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n disabled={disabled}\n >\n {Object.entries(selectOptions).map(([key, value]) => (\n <MenuItem className={classes.body2Text} key={key} value={key}>\n {value}\n </MenuItem>\n ))}\n </Select>\n {error && <FormHelperText>{error}</FormHelperText>}\n </FormControl>\n );\n};\n\ninterface IMultipleTableSelect extends Omit<IEssentialRenderFnProps, \"value\"> {\n selectOptions: { [key: string]: ReactChild };\n value: string[];\n renderValue?: (value: any) => ReactNode;\n}\n\nexport const TableMultipleSelect: React.FC<IMultipleTableSelect> = ({\n error,\n value,\n onBlur,\n onChange,\n selectOptions,\n disabled,\n renderValue,\n}) => {\n const classes = useDefaultTableCellsStyles({});\n return (\n <FormControl margin=\"none\" error={!!error}>\n <Select\n className={`${classes.body2Text} ${classes.modifiedUnderline}`}\n inputProps={{ className: classes.selectFocusBackground }}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n disabled={disabled}\n renderValue={renderValue}\n multiple={true}\n >\n {Object.entries(selectOptions).map(([key, value]) => (\n <MenuItem className={classes.body2Text} key={key} value={key}>\n {value}\n </MenuItem>\n ))}\n </Select>\n {error && <FormHelperText>{error}</FormHelperText>}\n </FormControl>\n );\n};\n","import React, {\n FC,\n forwardRef,\n Fragment,\n memo,\n useCallback,\n useEffect,\n useState,\n} from \"react\";\nimport {\n useTable,\n useRowSelect,\n useFilters,\n CellProps,\n HeaderProps,\n HeaderGroup,\n usePagination,\n useGlobalFilter,\n useAsyncDebounce,\n} from \"react-table\";\nimport {\n Table as MUITable,\n TableBody,\n TableCell,\n TableHead,\n TableRow,\n makeStyles,\n Typography,\n Box,\n Tooltip,\n InputBase,\n} from \"@material-ui/core\";\nimport SearchIcon from \"@material-ui/icons/Search\";\nimport { EDITED_STATUS, NEW_STATUS } from \"../globals\";\nimport { SelectionCheckbox, tableTextField } from \"./defaultCells\";\nimport { didCellValueChange } from \"../utils\";\nimport {\n IEditableTableProps,\n RowData,\n ExtendedCellProps,\n TableCellValues,\n ITableContentProps,\n IGlobalFilterProps,\n} from \"./EditableTable.types\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport { Pagination } from \"@material-ui/lab\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { useVirtual } from \"react-virtual\";\n\nconst useStyles = makeStyles((theme) => ({\n newRowHighlight: {\n backgroundColor: \"#73c4ca30\",\n },\n editedCellHighlight: {\n backgroundColor: \"#5840f52e\",\n backgroundClip: \"padding-box\",\n },\n editedBorder: {\n border: \"3px solid #5840f52e\",\n borderWidth: \"2px 4px\",\n },\n errorBorder: {\n border: `3px solid ${theme.palette.error.light}`,\n borderWidth: \"2px 4px\",\n },\n emptyLoadingPadding: {\n paddingTop: \"0.75rem\",\n paddingBottom: \"0.75rem\",\n },\n centeredText: {\n textAlign: \"center\",\n },\n disabled: {\n backgroundColor: theme.palette.action.hover,\n },\n pagination: {\n marginTop: \"1rem\",\n marginBottom: \"1rem\",\n },\n virtualisationContainer: {\n maxHeight: \"500px\",\n overflow: \"auto\",\n },\n}));\n\nconst EditableCell: FC<ExtendedCellProps> = ({\n value: initialValue = \"\",\n row: { index, values, original },\n column: { id },\n syncCellWithState,\n setRows,\n fieldConfig,\n disabled,\n}) => {\n const {\n validationRule,\n dependentValidationRule,\n isCheckbox,\n isDateField,\n customRenderFn,\n prefix,\n suffix,\n textAlign,\n onBlur: configOnBlur,\n onChangeValueModifier,\n } = fieldConfig[id];\n const [error, setError] = useState<false | string>(false);\n // We need to keep and update the state of the cell normally\n const [value, setValue] = useState<TableCellValues>(initialValue);\n const checkbox = isCheckbox;\n\n const validateValue = (value: TableCellValues) => {\n let returnValue = false;\n if (validationRule) {\n try {\n validationRule.validateSync(value);\n if (error) setError(false);\n } catch (e) {\n returnValue = true;\n !error && setError(e.message);\n }\n }\n if (dependentValidationRule) {\n try {\n dependentValidationRule(values).validateSync(value);\n if (error) setError(false);\n } catch (e) {\n returnValue = true;\n !error && setError(e.message);\n }\n }\n return returnValue;\n };\n\n // We'll only update the external data when the input is blurred\n const onBlur = async (fieldValue: TableCellValues) => {\n if (checkbox) {\n syncCellWithState(index, id, fieldValue, false);\n } else syncCellWithState(index, id, value, !!error);\n if (\n configOnBlur &&\n setRows &&\n !error &&\n !didCellValueChange(values[id], value, isDateField)\n ) {\n await configOnBlur!({\n rowIndex: index,\n value: value as string,\n setRows,\n values: original,\n });\n }\n };\n\n const onChange = (e: string | React.ChangeEvent<HTMLInputElement>) => {\n let event;\n if (isDateField) {\n event = e as string;\n const adjustedDateValue = onChangeValueModifier\n ? onChangeValueModifier(event)\n : event;\n setValue(adjustedDateValue);\n validateValue(adjustedDateValue);\n return;\n }\n event = e as React.ChangeEvent<HTMLInputElement>;\n const eventValue = checkbox ? event.target.checked : event.target.value;\n\n if (checkbox) {\n setValue(eventValue);\n onBlur(eventValue);\n } else {\n setValue(eventValue);\n validateValue(eventValue);\n }\n };\n\n // If the initialValue is changed external, sync it up with our state\n useEffect(() => {\n setValue(initialValue);\n const errorStatus = validateValue(initialValue);\n if (error !== errorStatus) {\n syncCellWithState(index, id, initialValue, errorStatus, true);\n }\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [initialValue]);\n\n useEffect(() => {\n if (original.errors && !!original.errors[id] !== !!error) {\n validateValue(initialValue);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [original.errors]);\n\n const renderFnProps = {\n value,\n values,\n disabled: disabled || original.disabledRow,\n error,\n onChange,\n onBlur,\n prefix,\n suffix,\n textAlign,\n originalValues: original,\n };\n\n if (customRenderFn) {\n return customRenderFn(renderFnProps);\n } else return tableTextField(renderFnProps);\n};\n\ninterface ITableRowContentsProps {\n row: RowData;\n classes: ReturnType<typeof useStyles>;\n disabled: boolean;\n includeRowSelect: boolean;\n}\n\nconst TableRowContents = forwardRef<HTMLTableRowElement, ITableRowContentsProps>(\n ({ row, classes, disabled, includeRowSelect, ...rest }, ref) => (\n <TableRow\n {...rest}\n ref={ref}\n hover={true}\n className={`${\n row.original.rowStatus === NEW_STATUS ? classes.newRowHighlight : \"\"\n } ${row.original.rowStatus === EDITED_STATUS ? classes.editedBorder : \"\"}\n${Object.values(row.original.errors || {}).includes(true) ? classes.errorBorder : \"\"} ${\n row.original.disabledRow || disabled ? classes.disabled : \"\"\n }`}\n >\n {row.cells.map((cell: any, n: number) => (\n <TableCell\n {...cell.getCellProps()}\n //@ts-ignore FIX REQUIRED incorrect use of react table props\n align={cell.column.textAlign || \"center\"}\n className={\n cell.row.original.rowStatus === EDITED_STATUS &&\n cell.row.original.edited[cell.column.id]\n ? classes.editedCellHighlight\n : \"\"\n }\n padding={includeRowSelect && n === 0 ? \"checkbox\" : \"normal\"}\n >\n {cell.render(\"Cell\")}\n </TableCell>\n ))}\n </TableRow>\n )\n);\n\n// emptyRows is needed for when incoming data is null (loading state).\n// useTable requires memoised row data to be defined at all times.\nconst emptyRows: RowData[] = [];\n\nconst EditableTable: React.FC<IEditableTableProps> = memo(\n ({\n tableRows,\n tableHeaders,\n syncCellWithState,\n setRows = undefined,\n skipPageReset = false,\n fieldConfig,\n disabled = false,\n setSelectedRows,\n includeRowSelect = true,\n filterData,\n filterTypes,\n emptyTableText = \"Table is empty\",\n paginate = false,\n defaultPageSize = 50,\n virtContainerStyling,\n overscan,\n rowHeight,\n includeGlobalSearch,\n disableHeaderSelect,\n }) => {\n const classes = { ...useStyles(), ...useLayoutStyles() };\n const parentRef = React.useRef<HTMLDivElement | null>(null);\n\n // Set our editable cell renderer as the default Cell renderer\n const defaultColumn = React.useMemo(\n () => ({\n Cell: EditableCell,\n }),\n []\n );\n\n const {\n getTableProps, // props to use in table, supplied by react-table\n getTableBodyProps, // props to use in table, supplied by react-table\n headerGroups, // headers enriched with methods by react-table\n rows, // rows enriched with methods by react-table\n page, // selected slice of data subset of rows. Visible paginated data\n prepareRow, // row optimisation function that must be called when rendering rows\n state: { selectedRowIds, pageIndex }, // ids of selected rows and page index from internal table state\n state,\n setFilter, // manipulate filter criteria\n pageCount,\n gotoPage,\n preGlobalFilteredRows,\n setGlobalFilter,\n isAllRowsSelected, // used only to induce re-render in the header and update checkbox state\n selectedFlatRows, // used only to induce re-render in the rows and update checkbox state\n } = useTable<RowData>(\n {\n columns: tableHeaders,\n data: tableRows || emptyRows,\n defaultColumn, // custom cell renderer, that we defined above\n autoResetPage: paginate ? !skipPageReset : false, // value that is used internally to control page number resets\n filterTypes, // fileting config for useFilters hook\n initialState: { pageSize: paginate ? defaultPageSize : undefined }, // setting up initial state for\n\n // below are custom methods and variables that will be supplied to EditableCell\n syncCellWithState, // state function used that controls the state of table\n setRows, // similar to syncCellWithState but you can manipulate whole state\n fieldConfig, //configuration for each of the cells\n disabled,\n autoResetGlobalFilter: false,\n },\n useFilters, // plugging in useFilters hook\n useGlobalFilter, // plugging in useGlobalFilters hook\n usePagination, // plugging in usePagination hook\n useRowSelect, // plugging in useRowSelect hook\n (hooks) => {\n if (includeRowSelect) {\n hooks.visibleColumns.push((columns) => [\n // Let's make a column for selection\n {\n id: \"selection\",\n // The header can use the table's getToggleAllRowsSelectedProps method\n // to render a checkbox\n Header: ({\n getToggleAllRowsSelectedProps,\n getToggleAllPageRowsSelectedProps,\n }: HeaderProps<RowData>) =>\n !disableHeaderSelect ? (\n <SelectionCheckbox\n {...(paginate\n ? getToggleAllPageRowsSelectedProps()\n : getToggleAllRowsSelectedProps())}\n disabled={disabled}\n size=\"small\"\n />\n ) : (\n \"Select\"\n ),\n // The cell can use the individual row's getToggleRowSelectedProps method\n // to the render a checkbox\n Cell: ({ row }: CellProps<RowData>) => (\n <SelectionCheckbox\n {...row.getToggleRowSelectedProps()}\n disabled={disabled || row.original.disableSelection}\n size=\"small\"\n />\n ),\n },\n ...columns,\n ]);\n }\n }\n );\n\n /* Few resources that helped the most with virtualisation work\n * https://github.com/TanStack/virtual/issues/10\n * https://codesandbox.io/s/poc-react-virtual-table-forked-857kdi?file=/src/index.js:2037-2101\n */\n const rowVirtualizer = useVirtual({\n size: (paginate ? page : rows).length,\n parentRef,\n // amount of rows to render above and below visible rows\n overscan: overscan || 5,\n // estimated row size to determine how many rows are visible\n estimateSize: useCallback(() => rowHeight || 54, [rowHeight]),\n });\n\n const rowsToRender = paginate ? page : rows;\n\n const items = rowVirtualizer.virtualItems;\n const paddingTop = items.length > 0 ? items[0].start : 0;\n const paddingBottom =\n items.length > 0 ? rowVirtualizer.totalSize - items[items.length - 1].end : 0;\n\n const handlePageChange = useCallback(\n (event: React.ChangeEvent<unknown>, value: number) => {\n gotoPage(value - 1);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n []\n );\n\n // provide the data to filter on, if filter types is not present the default filter will be used\n useEffect(() => {\n if (filterData) {\n setFilter(filterData.filterRow, filterData.filterValues);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [filterData]);\n\n useEffect(() => {\n if (setSelectedRows) {\n setSelectedRows(Object.keys(selectedRowIds).map((id) => +id));\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [selectedRowIds]);\n\n return (\n <>\n {includeGlobalSearch ? (\n <GlobalSearch\n preGlobalFilteredRows={preGlobalFilteredRows}\n globalFilter={\n (state as unknown as { globalFilter: string | undefined }).globalFilter\n }\n setGlobalFilter={setGlobalFilter}\n />\n ) : null}\n <div\n ref={parentRef}\n className={virtContainerStyling || classes.virtualisationContainer}\n >\n <TableContent\n {...{\n disabled,\n includeRowSelect,\n getTableProps,\n headerGroups,\n getTableBodyProps,\n rowsToRender,\n prepareRow,\n paddingTop,\n paddingBottom,\n virtualRows: items,\n isAllRowsSelected,\n selectedFlatRows,\n }}\n />\n </div>\n {tableRows === null ? (\n <Box className={classes.emptyLoadingPadding}>\n <LoadingSpinner />\n </Box>\n ) : null}\n {tableRows && !tableRows.length ? (\n <Box className={`${classes.emptyLoadingPadding} ${classes.centeredText}`}>\n <Typography variant=\"body2\">{emptyTableText}</Typography>\n </Box>\n ) : null}\n {paginate && tableRows?.length ? (\n <Pagination\n className={`${classes.flexCenter} ${classes.pagination}`}\n count={pageCount}\n page={pageIndex + 1}\n onChange={handlePageChange}\n shape=\"rounded\"\n showFirstButton\n showLastButton\n />\n ) : null}\n </>\n );\n }\n);\n\nexport default EditableTable;\n\nconst useGlobalSearchStyles = makeStyles((theme) => ({\n container: {\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n border: `1px solid ${theme.palette.grey[600]}`,\n borderRadius: \"8px\",\n width: \"100%\",\n maxWidth: \"20rem\",\n marginInline: \"auto\",\n color: theme.palette.grey[600],\n \"&:hover\": {\n borderColor: theme.palette.grey[800],\n color: theme.palette.grey[800],\n },\n \"&:focus-within\": {\n borderColor: theme.palette.grey[800],\n color: theme.palette.grey[800],\n },\n },\n input: {\n width: \"100%\",\n maxWidth: \"18rem\",\n color: \"inherit\",\n ...theme.typography.body2,\n },\n}));\n\nconst GlobalSearch: React.FC<IGlobalFilterProps> = memo(\n ({ preGlobalFilteredRows, globalFilter, setGlobalFilter }) => {\n const [value, setValue] = useState(globalFilter);\n\n const classes = { ...useSpacingStyles(), ...useGlobalSearchStyles() };\n\n const onChange = useAsyncDebounce((value: string) => {\n setGlobalFilter(value || undefined);\n }, 200);\n\n const count = preGlobalFilteredRows.length;\n\n return (\n <div className={`${classes.container} ${classes.contentBreak}`}>\n <SearchIcon className={`${classes.rightSpacer1} ${classes.leftSpacer1}`} />\n\n <InputBase\n className={`${classes.input}`}\n value={value || \"\"}\n onChange={(e) => {\n setValue(e.target.value);\n onChange(e.target.value);\n }}\n placeholder={`Search ${count} records...`}\n inputProps={{ \"aria-label\": \"search\" }}\n />\n </div>\n );\n }\n);\n\nconst TableContent: FC<ITableContentProps> = memo(\n ({\n disabled,\n includeRowSelect,\n getTableProps,\n headerGroups,\n getTableBodyProps,\n rowsToRender,\n prepareRow,\n paddingTop,\n paddingBottom,\n virtualRows,\n isAllRowsSelected,\n selectedFlatRows,\n }) => {\n return (\n <MUITable {...getTableProps()} stickyHeader style={{ borderCollapse: \"collapse\" }}>\n <TableHeaderContent\n headerGroups={headerGroups}\n includeRowSelect={includeRowSelect}\n isAllRowsSelected={isAllRowsSelected}\n />\n <TableBody {...getTableBodyProps()}>\n {paddingTop > 0 && (\n <tr>\n <td style={{ height: `${paddingTop}px` }} />\n </tr>\n )}\n\n <TableRows\n {...{\n disabled,\n includeRowSelect,\n rowsToRender,\n prepareRow,\n virtualRows,\n selectedFlatRows,\n }}\n />\n\n {paddingBottom > 0 && (\n <tr>\n <td style={{ height: `${paddingBottom}px` }} />\n </tr>\n )}\n </TableBody>\n </MUITable>\n );\n }\n);\n\nconst TableHeaderContent: FC<\n Pick<ITableContentProps, \"headerGroups\" | \"includeRowSelect\" | \"isAllRowsSelected\">\n> = memo(({ headerGroups, includeRowSelect, isAllRowsSelected }) => {\n return (\n <TableHead>\n {headerGroups.map((headerGroup: HeaderGroup<RowData>) => (\n <TableRow {...headerGroup.getHeaderGroupProps()}>\n {headerGroup.headers.map((column, i) => (\n <TableCell\n {...column.getHeaderProps()}\n //@ts-ignore FIX REQUIRED incorrect use of react table props\n align={column.textAlign || \"center\"}\n padding={includeRowSelect && i === 0 ? \"checkbox\" : \"normal\"}\n >\n {column.render(\"Header\")}\n </TableCell>\n ))}\n </TableRow>\n ))}\n </TableHead>\n );\n});\n\nconst TableRows: FC<\n Pick<\n ITableContentProps,\n | \"rowsToRender\"\n | \"prepareRow\"\n | \"disabled\"\n | \"includeRowSelect\"\n | \"virtualRows\"\n | \"selectedFlatRows\"\n >\n> = memo(({ rowsToRender, virtualRows, prepareRow, ...rest }) => {\n const classes = { ...useStyles(), ...useLayoutStyles() };\n\n return (\n <>\n {virtualRows.map((virtualRow) => {\n const row = rowsToRender[virtualRow.index];\n prepareRow(row);\n return (\n <Fragment key={row.original.rowKey || row.getRowProps().key}>\n {row.original.disabledRow ? (\n //At the moment disabledRow prop is only passed on xero costs so this check is fine\n // If this changes will need to change the check to be more specific\n <Tooltip title={row.original.tooltipText || \"This row is disabled\"} arrow>\n <TableRowContents {...{ ...rest, row, classes }} />\n </Tooltip>\n ) : (\n <TableRowContents {...{ ...rest, row, classes }} />\n )}\n </Fragment>\n );\n })}\n </>\n );\n});\n","import React from \"react\";\nimport { Collapse, Button, makeStyles } from \"@material-ui/core\";\nimport { Alert as MUIAlert } from \"@material-ui/lab\";\nimport { useSpacingStyles } from \"../styles\";\nimport { BORDER_RADIUS, FORM_ERROR, FORM_SUCCESS, FORM_WARNING } from \"../globals\";\nimport { IAlertProps } from \"./Alert.types\";\n\nconst useAlertStyles = makeStyles((theme) => ({\n alertStyling: {\n borderRadius: BORDER_RADIUS,\n },\n closeButton: {\n color: theme.palette.text.secondary,\n marginRight: theme.spacing(2),\n },\n showCursor: {\n cursor: \"pointer\",\n },\n}));\n\nconst Alert: React.FC<IAlertProps> = ({\n alertActionHandler,\n formStatus,\n actionButton,\n alertMessage,\n addBreak = true,\n styling,\n}) => {\n const classes = { ...useSpacingStyles(), ...useAlertStyles() };\n return (\n <Collapse in={[FORM_SUCCESS, FORM_ERROR, FORM_WARNING].includes(formStatus)}>\n <MUIAlert\n onClick={alertActionHandler}\n className={`${classes.alertStyling} ${addBreak ? classes.sectionBreak : \"\"} ${\n styling || \"\"\n } ${alertActionHandler ? classes.showCursor : \"\"}`}\n severity={\n formStatus === FORM_ERROR\n ? FORM_ERROR\n : formStatus === FORM_SUCCESS\n ? FORM_SUCCESS\n : FORM_WARNING\n }\n action={\n actionButton ? (\n <Button\n className={classes.closeButton}\n aria-label=\"close\"\n color=\"inherit\"\n size=\"small\"\n onClick={(event) => {\n event.stopPropagation();\n actionButton.handler();\n }}\n >\n {actionButton.text}\n </Button>\n ) : null\n }\n >\n {alertMessage}\n </MUIAlert>\n </Collapse>\n );\n};\n\nexport default Alert;\n","import {\n Box,\n makeStyles,\n IconButton,\n Typography,\n Button as MUIButton,\n CircularProgress,\n Avatar,\n} from \"@material-ui/core\";\nimport React, { useEffect, useState } from \"react\";\nimport { CloudUpload, Forward } from \"@material-ui/icons\";\nimport { useSpacingStyles } from \"../styles\";\nimport { IImageDisplayAndUploadProps } from \"./ImageDisplayAndUpload.types\";\nimport Alert from \"../Alert/Alert\";\nimport {\n BORDER_RADIUS,\n FormStatuses,\n FORM_ENABLED,\n FORM_ERROR,\n FORM_LOADING,\n FORM_SUCCESS,\n NO_ACCESS_LEVEL,\n READ_LEVEL,\n} from \"../globals\";\n\nconst useImageDisplayAndUploadStyles = makeStyles((theme) => ({\n greyBox: {\n backgroundColor: theme.palette.grey[200],\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n padding: \"1.5rem\",\n borderRadius: BORDER_RADIUS,\n position: \"relative\",\n height: \"13.25rem\",\n },\n widthLimiter: {\n width: \"100%\",\n maxWidth: \"28rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n hiddenInput: {\n display: \"none\",\n },\n buttonColor: {\n backgroundColor: theme.palette.primary.main,\n },\n iconStyling: {\n color: theme.palette.common.white,\n fontSize: \"3rem\",\n },\n sectionBreak: {\n marginBottom: theme.spacing(3),\n },\n dropBox: {\n height: \"100%\",\n width: \"100%\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n },\n dropArrowStyling: {\n color: theme.palette.text.secondary,\n fontSize: \"3rem\",\n },\n topLeftArrow: {\n position: \"absolute\",\n top: 0,\n left: 0,\n transform: \"rotate(45deg)\",\n },\n topRightArrow: {\n position: \"absolute\",\n top: 0,\n right: 0,\n transform: \"rotate(135deg)\",\n },\n bottomLeftArrow: {\n position: \"absolute\",\n bottom: 0,\n left: 0,\n transform: \"rotate(-45deg)\",\n },\n bottomRightArrow: {\n position: \"absolute\",\n bottom: 0,\n right: 0,\n transform: \"rotate(225deg)\",\n },\n hiddenDisplay: {\n display: \"none\",\n },\n loadingCircle: {\n marginLeft: theme.spacing(1),\n },\n roundedAvatarButton: {\n borderRadius: \"100%\",\n },\n roundedAvatar: {\n width: \"16vmax\",\n height: \"16vmax\",\n maxWidth: \"13rem\",\n maxHeight: \"13rem\",\n },\n organisationImage: {\n maxWidth: \"8rem\",\n minWidth: \"5rem\",\n maxHeight: \"8rem\",\n },\n}));\n\nconst DRAG_ENTER = \"dragEnter\";\nconst INPUT = \"input\";\nconst DRAG_DROP = \"dragDrop\";\n\nconst ImageDisplayAndUpload: React.FC<IImageDisplayAndUploadProps> = ({\n id = \"image-upload\",\n url,\n roundedAvatar = false,\n handleSaveImage,\n alt,\n accessLevel,\n}) => {\n const classes = { ...useImageDisplayAndUploadStyles(), ...useSpacingStyles() };\n const [displayImage, setDisplayImage] = useState<boolean>(!!url);\n const [uploadState, setUploadState] = useState<FormStatuses | typeof DRAG_ENTER>(\n FORM_ENABLED\n );\n const [infoMessage, setInfoMessage] = useState<null | string>(null);\n\n useEffect(() => {\n if (!!url) {\n setDisplayImage(true);\n }\n }, [url]);\n\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = false;\n if (accessLevel === READ_LEVEL) disabledProp = true;\n\n const handleImageUpload = async (\n type: typeof INPUT | typeof DRAG_DROP,\n e: React.ChangeEvent<HTMLInputElement> | React.DragEvent<HTMLElement>\n ) => {\n if (disabledProp) return;\n setInfoMessage(null);\n if (type === INPUT) {\n const target = (e as React.ChangeEvent<HTMLInputElement>).target;\n if (target.files && target.files[0]) {\n await imageUpload(target.files[0]);\n } else {\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n }\n } else if (type === DRAG_DROP) {\n const dataTransfer = (e as React.DragEvent<HTMLElement>).dataTransfer;\n if (dataTransfer.files && dataTransfer.files[0]) {\n await imageUpload(dataTransfer.files[0]);\n } else {\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n }\n }\n };\n\n const imageUpload = async (file: File) => {\n setUploadState(FORM_LOADING);\n if (file.size >= 1024 * 1024 * 0.5) {\n setInfoMessage(\"Image size should be less than 0.5MB\");\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n return;\n }\n const format = file.name.split(\".\")[1].toLowerCase();\n\n if (![\"png\", \"jpg\", \"jpeg\"].includes(format)) {\n setInfoMessage(\"Please provide an image in png, jpg or jpeg format\");\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n\n return;\n }\n const buffer = await file.arrayBuffer();\n try {\n await handleSaveImage(format, buffer, file);\n setUploadState(FORM_SUCCESS);\n setDisplayImage(true);\n } catch (e) {\n console.log(e);\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n }\n };\n\n let htmlToDisplay;\n switch (uploadState) {\n case DRAG_ENTER:\n htmlToDisplay = (\n <Box className={classes.dropBox} style={{ pointerEvents: \"none\" }}>\n <Forward className={`${classes.dropArrowStyling} ${classes.topLeftArrow}`} />\n <Forward className={`${classes.dropArrowStyling} ${classes.topRightArrow}`} />\n <Typography variant=\"h5\" color=\"textSecondary\">\n Drop Here\n </Typography>\n <Forward className={`${classes.dropArrowStyling} ${classes.bottomLeftArrow}`} />\n <Forward\n className={`${classes.dropArrowStyling} ${classes.bottomRightArrow}`}\n />\n </Box>\n );\n break;\n\n case FORM_LOADING:\n htmlToDisplay = (\n <Box className={classes.dropBox}>\n <Typography color=\"textSecondary\">Loading...</Typography>\n <CircularProgress className={classes.loadingCircle} size={25} />\n </Box>\n );\n break;\n\n default:\n htmlToDisplay = (\n <label htmlFor={id}>\n <IconButton\n className={`${classes.buttonColor} ${classes.sectionBreak}`}\n aria-label=\"upload picture\"\n component=\"span\"\n >\n <CloudUpload className={classes.iconStyling} />\n </IconButton>\n <Typography variant=\"body2\" color=\"textSecondary\">\n Drag and drop or browse to upload your image or logo.\n </Typography>\n </label>\n );\n break;\n }\n\n return (\n <Box\n className={classes.labelBreak}\n onDragEnter={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setDisplayImage(false);\n }}\n onDragOver={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setDisplayImage(false);\n }}\n >\n {displayImage && (\n <Box className={classes.labelBreak}>\n <label htmlFor={id}>\n <MUIButton\n className={`${roundedAvatar ? classes.roundedAvatarButton : \"\"}`}\n aria-label=\"upload picture\"\n component=\"span\"\n >\n {roundedAvatar ? (\n <Avatar\n className={classes.roundedAvatar}\n src={url!}\n alt={alt || \"Profile Avatar\"}\n />\n ) : (\n <img\n className={classes.organisationImage}\n src={url!}\n alt={alt || \"Company Logo\"}\n />\n )}\n </MUIButton>\n </label>\n </Box>\n )}\n\n <Box\n className={`${classes.greyBox} ${classes.widthLimiter} ${classes.sectionBreak} ${\n displayImage ? classes.hiddenDisplay : \"\"\n }`}\n onDragEnter={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setUploadState(DRAG_ENTER);\n }}\n onDragLeave={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setUploadState(FORM_ENABLED);\n setDisplayImage(url ? true : false);\n }}\n onDragOver={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setUploadState(DRAG_ENTER);\n }}\n onDrop={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n handleImageUpload(DRAG_DROP, e);\n }}\n >\n <input\n id={id}\n className={classes.hiddenInput}\n type=\"file\"\n accept=\".png, .jpg, .jpeg\"\n disabled={disabledProp}\n onChange={(e) => handleImageUpload(INPUT, e)}\n />\n\n {htmlToDisplay}\n </Box>\n\n <Box className={classes.widthLimiter}>\n <Alert\n formStatus={uploadState as FormStatuses}\n alertMessage={\n infoMessage ||\n (uploadState === FORM_SUCCESS\n ? \"Uploaded successfully!\"\n : \"Something went wrong.\")\n }\n />\n </Box>\n </Box>\n );\n};\n\nexport default ImageDisplayAndUpload;\n"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","rejected","result","done","then","__generator","body","f","y","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","v","op","TypeError","pop","push","__spreadArray","to","from","pack","ar","l","Array","slice","concat","string","trim","required","matches","FORM_SUCCESS","FORM_ERROR","FORM_WARNING","READ_LEVEL","NO_ACCESS_LEVEL","useSpacingStyles","makeStyles","labelBreak","marginBottom","contentBreak","sectionBreak","doubleSectionBreak","rightSpacer1","marginRight","rightSpacer2","leftSpacer1","marginLeft","leftSpacer2","buttonSpacing","leftRightPadding1","paddingLeft","paddingRight","leftRightPadding2","topBottomPadding1","paddingTop","paddingBottom","topBottomPadding2","classNamePrefix","index","useFontStyles","theme","boldText","fontWeight","bolderText","smallText","fontSize","warningColor","color","palette","warning","main","centerText","textAlign","useLayoutStyles","contentBox","background","borderRadius","padding","limitWidth60rem","maxWidth","limitWidth50rem","limitWidth45rem","limitWidth40rem","limitWidth35rem","limitWidth30rem","limitWidth25rem","centeredText","startAlignedText","width20","width","width49","width50","width60","width100","flexCenter","display","alignItems","justifyContent","centerJustify","leftJustify","rightJustify","useButtonStyles","submitButton","textTransform","containedText","spinnerColour","grey","Button","_a","_b","loading","children","_c","errors","_d","type","onClick","_e","disabled","_f","variant","_g","styling","_h","_j","accessLevel","rest","classes","includes","disabledProp","React","MaterialButton","className","CircularProgress","size","thickness","ContentLabel","Typography","ContentBox","limitWidth","Box","boxShadow","LoadingSpinner","text","StyledTableRow","withStyles","createStyles","root","backgroundColor","MUITableRow","ShadedTableRow","useTableCellStyles","borderBottom","borderTopLeftRadius","borderBottomLeftRadius","borderTopRightRadius","borderBottomRightRadius","head","border","borderTop","primary","borderLeft","borderRight","TableCell","align","headerColours","MUITableCell","TableRow","rowBorderSeparation","SingleCellRow","colSpan","useStaticTableStyles","adjustedCellPadding","tableStyles","borderCollapse","pointer","cursor","bottomBorder","noShading","StaticTable","headers","rows","headerCellAlignment","rowCellAlignment","paginate","itemsPerPage","useState","page","setPage","hasRowsAndPaginated","useMemo","visibleRows","setVisibleRows","handlePageChange","useCallback","event","useEffect","Table","TableHead","map","header","key","TableBody","data","containsOnClick","undefined","row","cell","Pagination","count","Math","ceil","onChange","shape","showFirstButton","showLastButton","useStyles","logoContainer","height","logo","logoInBreadcrumb","margin","logoSpacing","spacing","flexItemsCenter","nonPrimaryBreadcrumbOffset","BreadcrumbsContainer","primaryBreadcrumbItem","common","white","zIndex","secondaryBreadcrumbItem","secondary","tertiaryBreadcrumbItem","tertiary","breadCrumbShadow","shadows","breadcrumbRightMargin","breadcrumbTextOverflow","overflow","textOverflow","activeBreadcrumb","noWrap","whiteSpace","fullBorderRadius","Breadcrumbs","content","colors","first","second","third","Link","component","RouterLink","ButtonBase","underline","link","name","container","svgContainer","button","textDecoration","orgLabel","EntityList","entities","icon","loadingMessage","emptyMessage","Grid","entity","item","xs","md","ErrorIndicator","ErrorIcon","useNavListStyles","listIcon","minWidth","mainIconSize","mainIconMarginAdjustment","marginTop","textOverflowElipsis","mainListItem","props","mainBackground","mainText","mainHover","action","hover","mainIconColor","mainIcon","activeMainIconColor","mainActiveText","subListItem","subItemBackground","subItemText","subItemHover","activeSubListItem","subItemActiveBackground","subItemActiveText","subItemActiveHover","subItemBorder","relativeWrapper","position","subItemBorderMask","top","bottom","transition","activeSubItemBorder","subItemWrapper","noYMargin","isItemActive","currentPathname","id","split","NavListItem","mainItem","subItems","config","Icon","mainItemColors","subItemColors","location","useLocation","activeMainItem","pathname","subExpanded","setSubExpanded","ListItem","dense","route","ListItemIcon","ListItemText","disableTypography","preventDefault","stopPropagation","expanded","ExpandLess","ExpandMore","Collapse","in","timeout","unmountOnExit","List","disablePadding","sortDescendingStartDateString","array","sort","a","b","startDate","replaceAll","didCellValueChange","oldVal","newVal","isDateValue","isValid","Date","getTime","useSecondaryNavStyles","secondaryNavWrapper","overflowY","overflowX","boxSizing","titleWrapper","title","titleColor","titleIcons","titleIconColor","closeButton","archivedSeparator","archivedBorder","listWrapper","SecondaryLeftNavContainer","secondaryNavItems","primaryNavItems","expandedOptions","setExpandedOptions","stylesProps","history","useHistory","navItem","view","mainItemIcon","find","field","IconButton","url","AddBoxOutlinedIcon","closeButtonSvg","CloseIcon","items","archivedItems","usePrimaryLeftNavStyles","primaryNavContainer","activeBorderColor","flexDirection","itemWrapper","itemBorder","right","activeBorder","iconWrapper","itemName","textColour","activeTextColour","activeText","lastItem","PrimaryLeftNavContainer","navigationLinks","applyActiveBackground","fieldName","path","rootRouteName","startsWith","arr","moveLastItemToBottom","hasSecondary","useLeftNavStyles","leftNavContainer","LeftNavigation","styles","navsWithSecondary","reduce","navs","nav","prev","useMainLayoutStyles","remainingHeightBox","topOffset","left","fullHeightFlexbox","relativeContainer","scrollWrapper","componentWrapper","MainLayout","sideNavigation","desktopWidth","Container","disableGutters","useDebounceEffect","effect","deps","delay","callback","setTimeout","clearTimeout","useInterval","savedCallback","useRef","current","id_1","setInterval","clearInterval","useWhyDidYouUpdate","latestProps","allKeys","keys","changesObj","forEach","changedKeys","k","filter","Boolean","isDeepEqual","isEqual","console","log","changes","values","useAlphabeticalListStyles","divider","letterHeader","listItem","topMargin","AlphabeticalList","sortFn","sortKey","buttonClick","linkTo","ItemTemplate","arrayKey","alphabetisedHeader","lastSection","showHeader","currentKey","toLowerCase","Fragment","toUpperCase","Divider","useSearchBarStyles","searchBox","alignContent","searchField","searchIcon","SearchBar","inputBackgroundColor","placeholder","disabledSearch","minQueryLength","handleOnChange","searchKeys","_k","searchInput","setSearchInput","_l","blockSearch","setBlockSearch","_m","setResult","itemIsFound","some","InputBase","target","endAdornment","InputAdornment","SearchIcon","inputField","typography","body2","labelStyles","transform","TextField","numberField","inputProps","InputProps","fixedDecimalScale","inputPropsForNumberField","MaterialTextField","inputComponent","NumberFormatField","InputLabelProps","inputRef","other","NumberFormat","getInputRef","onValueChange","thousandSeparator","decimalScale","isNumericString","useSelectStyles","scrollbarWidth","inputStyles","BORDER_RADIUS","selectedListItem","Select","selectOptions","SelectProps","select","option","MenuItem","selected","description","DatePicker","format","minDate","MuiPickersUtilsProvider","utils","DateFnsUtils","MaterialDatePicker","inputVariant","autoOk","TextFieldComponent","KeyboardDatePicker","allowKeyboardControl","useButtonWithConfirmStyles","confirmWrapper","confirmContainer","whiteText","ButtonWithConfirm","confirmView","setConfirmView","stopInterval","setStopInterval","determineWidth","valueLength","toString","floor","useDefaultTableCellsStyles","inputBase","input","startAdornment","modifiedUnderline","body2Text","dateFieldWidth","fullDateWidth","justifyStart","justifyCenter","justifyEnd","totalContainer","selectFocusBackground","TableTextField","error","onBlur","prefix","suffix","style","helperText","tableNumericStringField","tableProps","tableNumericStringFixedDecimalField","SelectionCheckbox","Checkbox","TableDatePicker","fullDate","views","tableDateField","tableInvoiceDateField","TableCheckbox","checked","tableCheckbox","NonEditableField","displayType","TableSelect","FormControl","entries","FormHelperText","TableMultipleSelect","renderValue","multiple","newRowHighlight","editedCellHighlight","backgroundClip","editedBorder","borderWidth","errorBorder","light","emptyLoadingPadding","pagination","virtualisationContainer","maxHeight","EditableCell","initialValue","original","syncCellWithState","setRows","fieldConfig","validationRule","dependentValidationRule","isCheckbox","isDateField","customRenderFn","configOnBlur","onChangeValueModifier","setError","setValue","checkbox","validateValue","returnValue","validateSync","message","fieldValue","rowIndex","errorStatus","renderFnProps","disabledRow","adjustedDateValue","eventValue","originalValues","TableRowContents","forwardRef","ref","includeRowSelect","rowStatus","cells","getCellProps","column","edited","render","emptyRows","EditableTable","memo","tableRows","tableHeaders","skipPageReset","setSelectedRows","filterData","filterTypes","emptyTableText","defaultPageSize","virtContainerStyling","overscan","rowHeight","includeGlobalSearch","disableHeaderSelect","parentRef","defaultColumn","Cell","useTable","columns","autoResetPage","initialState","pageSize","autoResetGlobalFilter","useFilters","useGlobalFilter","usePagination","useRowSelect","hooks","visibleColumns","Header","getToggleAllRowsSelectedProps","getToggleAllPageRowsSelectedProps","getToggleRowSelectedProps","disableSelection","getTableProps","getTableBodyProps","headerGroups","prepareRow","selectedRowIds","pageIndex","state","setFilter","pageCount","gotoPage","preGlobalFilteredRows","setGlobalFilter","isAllRowsSelected","selectedFlatRows","rowVirtualizer","useVirtual","estimateSize","rowsToRender","virtualItems","start","totalSize","end","filterRow","filterValues","GlobalSearch","globalFilter","TableContent","virtualRows","useGlobalSearchStyles","marginInline","borderColor","useAsyncDebounce","MUITable","stickyHeader","TableHeaderContent","TableRows","headerGroup","getHeaderGroupProps","getHeaderProps","virtualRow","rowKey","getRowProps","Tooltip","tooltipText","arrow","useAlertStyles","alertStyling","showCursor","Alert","alertActionHandler","formStatus","actionButton","alertMessage","addBreak","MUIAlert","severity","handler","useImageDisplayAndUploadStyles","greyBox","widthLimiter","hiddenInput","buttonColor","iconStyling","dropBox","dropArrowStyling","topLeftArrow","topRightArrow","bottomLeftArrow","bottomRightArrow","hiddenDisplay","loadingCircle","roundedAvatarButton","roundedAvatar","organisationImage","ImageDisplayAndUpload","handleSaveImage","alt","displayImage","setDisplayImage","uploadState","setUploadState","infoMessage","setInfoMessage","htmlToDisplay","handleImageUpload","files","imageUpload","dataTransfer","file","arrayBuffer","buffer","e_1","pointerEvents","Forward","htmlFor","CloudUpload","onDragEnter","onDragOver","MUIButton","Avatar","src","onDragLeave","onDrop","accept"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../node_modules/tslib/tslib.es6.js","../src/globals/index.ts","../src/styles/spacing.ts","../src/styles/font.ts","../src/styles/layout.ts","../src/Button/Button.tsx","../src/ContentLabel/ContentLabel.tsx","../src/ContentBox/ContentBox.tsx","../src/LoadingSpinner/LoadingSpinner.tsx","../src/StaticTable/StaticTable.tsx","../src/Breadcrumbs/Breadcrumbs.tsx","../src/EntityList/EntityList.tsx","../src/ErrorIndicator/ErrorIndicator.tsx","../src/LeftNavigation/NavListItem.tsx","../src/utils/index.ts","../src/LeftNavigation/SecondaryLeftNavigation.tsx","../src/LeftNavigation/PrimaryLeftNavigation.tsx","../src/LeftNavigation/LeftNavigation.tsx","../src/MainLayout/MainLayout.tsx","../src/hooks/useDebounceEffect.tsx","../src/hooks/useInterval.ts","../src/hooks/useWhyDidYouUpdate.tsx","../src/AlphabeticalList/AlphabeticalList.tsx","../src/SearchBar/SearchBar.tsx","../src/TextField/TextField.tsx","../src/Select/Select.tsx","../src/DatePicker/DatePicker.tsx","../src/KeyboardDatePicker/KeyboardDatePicker.tsx","../src/ButtonWithConfirm/ButtonWithConfirm.tsx","../src/EditableTable/defaultCells.tsx","../src/EditableTable/EditableTable.tsx","../src/Alert/Alert.tsx","../src/ImageDisplayAndUpload/ImageDisplayAndUpload.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import { string } from \"yup\";\n\nexport const HALF_REM = \"0.5rem\";\nexport const ONE_REM = \"1rem\";\nexport const ONE_AND_HALF_REM = \"1.5rem\";\nexport const TWO_REM = \"3rem\";\nexport const THREE_REM = \"3rem\";\n\nexport const EDITED_STATUS = \"EDITED\";\nexport const NEW_STATUS = \"NEW\";\n\nexport const VALIDATION_MESSAGE_REQUIRED = \"Required\";\nexport const REGEX_NUMBER_WITH_DECIMALS = /^\\d*\\.?\\d*$/;\n\nexport const YUP_REQUIRED_STRING_SHORT_MESSAGE = string()\n .trim()\n .required(VALIDATION_MESSAGE_REQUIRED);\n\nexport const YUP_STRING_NUMBER_WITH_DECIMALS = string()\n .trim()\n .required(VALIDATION_MESSAGE_REQUIRED)\n .matches(REGEX_NUMBER_WITH_DECIMALS, \"Must be a Number\");\n\nexport const FORM_SUCCESS = \"success\";\nexport const FORM_ERROR = \"error\";\nexport const FORM_LOADING = \"loading\";\nexport const FORM_ENABLED = \"enabled\";\nexport const FORM_WARNING = \"warning\";\n\nexport type FormStatuses =\n | typeof FORM_SUCCESS\n | typeof FORM_ERROR\n | typeof FORM_LOADING\n | typeof FORM_ENABLED\n | typeof FORM_WARNING;\n\nexport const READ_LEVEL = \"read\";\nexport const WRITE_LEVEL = \"write\";\nexport const NO_ACCESS_LEVEL = \"noAccess\";\n\nexport interface IAuthoriserProp {\n accessLevel?: typeof READ_LEVEL | typeof WRITE_LEVEL | typeof NO_ACCESS_LEVEL;\n}\n\nexport const BORDER_RADIUS = \"14px\";\n","import { makeStyles } from \"@material-ui/core\";\nimport { HALF_REM, ONE_AND_HALF_REM, THREE_REM, ONE_REM } from \"../globals\";\n\nexport const useSpacingStyles = makeStyles(\n {\n labelBreak: {\n marginBottom: HALF_REM,\n },\n contentBreak: {\n marginBottom: ONE_REM,\n },\n sectionBreak: {\n marginBottom: ONE_AND_HALF_REM,\n },\n doubleSectionBreak: {\n marginBottom: THREE_REM,\n },\n rightSpacer1: {\n marginRight: HALF_REM,\n },\n rightSpacer2: {\n marginRight: ONE_REM,\n },\n leftSpacer1: {\n marginLeft: HALF_REM,\n },\n leftSpacer2: {\n marginLeft: ONE_REM,\n },\n buttonSpacing: {\n marginLeft: HALF_REM,\n marginRight: HALF_REM,\n marginBottom: ONE_REM,\n },\n leftRightPadding1: {\n paddingLeft: HALF_REM,\n paddingRight: HALF_REM,\n },\n leftRightPadding2: {\n paddingLeft: ONE_REM,\n paddingRight: ONE_REM,\n },\n topBottomPadding1: {\n paddingTop: HALF_REM,\n paddingBottom: HALF_REM,\n },\n topBottomPadding2: {\n paddingTop: ONE_REM,\n paddingBottom: ONE_REM,\n },\n },\n { classNamePrefix: \"spacing\", index: 2 }\n);\n","import { makeStyles } from \"@material-ui/core\";\n\nexport const useFontStyles = makeStyles(\n (theme) => ({\n boldText: {\n fontWeight: 700,\n },\n bolderText: {\n fontWeight: 500,\n },\n smallText: {\n fontSize: \"0.7rem\",\n },\n warningColor: {\n color: theme.palette.warning.main,\n },\n centerText: {\n textAlign: \"center\",\n },\n }),\n { classNamePrefix: \"font\" }\n);\n","import { makeStyles } from \"@material-ui/core\";\nimport { BORDER_RADIUS, ONE_REM, THREE_REM } from \"../globals\";\n\nexport const useLayoutStyles = makeStyles(\n {\n contentBox: {\n background: \"white\",\n borderRadius: BORDER_RADIUS,\n marginBottom: ONE_REM,\n padding: THREE_REM,\n },\n limitWidth60rem: {\n maxWidth: \"60rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth50rem: {\n maxWidth: \"50rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth45rem: {\n maxWidth: \"45rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth40rem: {\n maxWidth: \"40rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth35rem: {\n maxWidth: \"35rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth30rem: {\n maxWidth: \"30rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n limitWidth25rem: {\n maxWidth: \"25rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n centeredText: {\n textAlign: \"center\",\n },\n startAlignedText: {\n textAlign: \"start\",\n },\n width20: {\n width: \"20%\",\n },\n width49: {\n width: \"49%\",\n },\n width50: {\n width: \"50%\",\n },\n width60: {\n width: \"60%\",\n },\n width100: {\n width: \"100%\",\n },\n flexCenter: {\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n },\n centerJustify: {\n justifyContent: \"center\",\n },\n leftJustify: {\n justifyContent: \"left\",\n },\n rightJustify: {\n justifyContent: \"right\",\n },\n },\n { classNamePrefix: \"layout\", index: 2 }\n);\n","import React from \"react\";\nimport {\n makeStyles,\n Button as MaterialButton,\n CircularProgress,\n} from \"@material-ui/core\";\nimport { useSpacingStyles } from \"../styles\";\nimport { IButtonProps } from \"./Button.types\";\nimport { NO_ACCESS_LEVEL, ONE_AND_HALF_REM, READ_LEVEL } from \"../globals\";\n\nconst useButtonStyles = makeStyles((theme) => ({\n submitButton: {\n borderRadius: ONE_AND_HALF_REM,\n padding: `0.4rem 1rem`,\n textTransform: \"none\",\n },\n containedText: {\n color: \"white\",\n },\n spinnerColour: {\n color: theme.palette.grey[500],\n },\n}));\n\nconst Button: React.FC<IButtonProps> = ({\n loading = false,\n children,\n errors = false,\n type = \"submit\",\n onClick,\n disabled = false,\n variant = \"outlined\",\n styling = \"\",\n color = \"primary\",\n accessLevel = \"\",\n ...rest\n}) => {\n const classes = { ...useSpacingStyles(), ...useButtonStyles() };\n\n if ([NO_ACCESS_LEVEL, READ_LEVEL].includes(accessLevel)) return null;\n\n let disabledProp = disabled;\n\n if (!disabled && (loading || errors)) {\n disabledProp = true;\n }\n\n return (\n <MaterialButton\n {...rest}\n variant={variant}\n color={color}\n type={type}\n className={`${classes.submitButton} ${\n variant === \"contained\" && classes.containedText\n } ${styling}`}\n disabled={disabledProp}\n onClick={onClick}\n >\n {children}\n {loading ? (\n <CircularProgress\n className={`${classes.leftSpacer1} ${classes.spinnerColour}`}\n size=\"1.1rem\"\n thickness={6}\n />\n ) : (\n \"\"\n )}\n </MaterialButton>\n );\n};\n\nexport default Button;\n","import React from \"react\";\nimport { Typography } from \"@material-ui/core\";\nimport { useFontStyles } from \"../styles\";\nimport { IContentLabelProps } from \"./ContentLabel.types\";\n\nconst ContentLabel: React.FC<IContentLabelProps> = ({ children, styling = null }) => {\n const classes = useFontStyles();\n return (\n <Typography variant=\"h6\" className={`${classes.bolderText} ${styling || \"\"}`}>\n {children}\n </Typography>\n );\n};\n\nexport default ContentLabel;\n","import React from \"react\";\nimport { Box } from \"@material-ui/core\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { IContentBoxProps } from \"./ContentBox.types\";\n\nconst ContentBox: React.FC<IContentBoxProps> = ({\n limitWidth = false,\n children,\n styling,\n}) => {\n const classes = { ...useSpacingStyles(), ...useLayoutStyles() };\n return (\n <Box boxShadow={3} className={`${classes.contentBox} ${styling || \"\"}`}>\n <Box\n className={`${classes.centeredText} ${limitWidth ? classes.limitWidth50rem : \"\"}`}\n >\n {children}\n </Box>\n </Box>\n );\n};\nexport default ContentBox;\n","import React from \"react\";\nimport { Box, Typography, CircularProgress } from \"@material-ui/core\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { ILoadingSpinnerProps } from \"./LoadingSpinner.types\";\n\nconst LoadingSpinner: React.FC<ILoadingSpinnerProps> = ({\n text = \"Loading data...\",\n styling,\n}) => {\n const classes = { ...useSpacingStyles(), ...useLayoutStyles() };\n\n return (\n <Box className={`${classes.flexCenter} ${styling || \"\"}`}>\n <Typography variant=\"body2\" color=\"textSecondary\" className={classes.rightSpacer1}>\n {text}\n </Typography>\n <CircularProgress size=\"1.5rem\" />\n </Box>\n );\n};\n\nexport default LoadingSpinner;\n","import React, { memo, ReactNode, useCallback, useEffect, useMemo, useState } from \"react\";\nimport {\n createStyles,\n makeStyles,\n Table,\n TableBody,\n TableCell as MUITableCell,\n TableHead,\n TableRow as MUITableRow,\n withStyles,\n TableRowProps,\n TableCellProps,\n} from \"@material-ui/core\";\nimport {\n cellAlignmentOptions,\n headerColours,\n IStaticTableProps,\n} from \"./StaticTable.types\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport { BORDER_RADIUS } from \"../globals\";\nimport { Pagination } from \"@material-ui/lab\";\n\nconst StyledTableRow = withStyles(\n createStyles({\n root: {\n \"&:hover td\": {\n backgroundColor: \"rgba(0, 0, 0, 0.06)\",\n },\n },\n })\n)(MUITableRow);\n\nconst ShadedTableRow = withStyles(\n createStyles({\n root: {\n \"&:nth-of-type(even) td\": {\n backgroundColor: \"rgba(0, 0, 0, 0.03)\",\n },\n \"&:hover td\": {\n backgroundColor: \"rgba(0, 0, 0, 0.06)\",\n },\n },\n })\n)(MUITableRow);\n\nconst useTableCellStyles = makeStyles((theme) => ({\n root: {\n borderBottom: \"none\",\n paddingTop: \"8px\",\n paddingBottom: \"8px\",\n \"&:first-child\": {\n borderTopLeftRadius: BORDER_RADIUS,\n borderBottomLeftRadius: BORDER_RADIUS,\n },\n \"&:last-child\": {\n borderTopRightRadius: BORDER_RADIUS,\n borderBottomRightRadius: BORDER_RADIUS,\n },\n },\n head: ({ background, border, text }: headerColours) => ({\n backgroundColor: background || \"HSLA(204, 58.3%, 81.2%, 0.1)\",\n borderTop: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n borderBottom: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n color: text || theme.palette.text.primary,\n fontWeight: 500,\n \"&:first-child\": {\n borderLeft: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n },\n \"&:last-child\": {\n borderRight: `1px solid ${border || \"HSLA(204, 58.3%, 81.2%, 0.3)\"}`,\n },\n }),\n}));\n\ninterface ITableCellProps extends Omit<TableCellProps, \"align\"> {\n align?: cellAlignmentOptions;\n headerColours?: headerColours;\n withoutHeaders?: boolean;\n}\n\nconst TableCell = ({\n children,\n align = \"centerJustify\",\n headerColours,\n ...rest\n}: ITableCellProps) => {\n const classes = {\n ...useLayoutStyles(),\n ...useTableCellStyles({ ...(headerColours || {}) }),\n };\n return (\n <MUITableCell\n {...rest}\n classes={{\n root: classes.root,\n head: classes.head,\n }}\n >\n <div className={`${classes.flexCenter} ${classes[align]}`}>{children}</div>\n </MUITableCell>\n );\n};\n\ninterface ITableRow extends TableRowProps {\n rowBorderSeparation?: boolean;\n}\n\nconst TableRow = ({ rowBorderSeparation = false, children, ...rest }: ITableRow) => {\n if (rowBorderSeparation) {\n return <StyledTableRow {...rest}>{children}</StyledTableRow>;\n }\n return <ShadedTableRow {...rest}>{children}</ShadedTableRow>;\n};\n\ninterface ISingleCellRowProps {\n colSpan: number;\n children: ReactNode;\n}\n\nconst SingleCellRow = ({ colSpan, children }: ISingleCellRowProps) => {\n const classes = useStaticTableStyles();\n return (\n <TableRow>\n <TableCell className={classes.adjustedCellPadding} colSpan={colSpan}>\n {children}\n </TableCell>\n </TableRow>\n );\n};\n\nconst useStaticTableStyles = makeStyles({\n tableStyles: {\n borderCollapse: \"separate\",\n borderBottom: \"1px solid rgb(224, 224, 224)\",\n },\n pointer: {\n cursor: \"pointer\",\n },\n bottomBorder: {\n borderBottom: \"1px solid rgba(224, 224, 224, 1)\",\n },\n noShading: {\n backgroundColor: \"transparent !important\",\n },\n adjustedCellPadding: {\n paddingTop: \"11px\",\n paddingBottom: \"11px\",\n },\n});\n\ntype StaticTableHeadersProps = Pick<\n IStaticTableProps,\n \"headers\" | \"headerCellAlignment\" | \"headerColours\"\n>;\n\nconst StaticTableHeaders: React.FC<StaticTableHeadersProps> = memo(\n ({ headers, headerCellAlignment = [], headerColours }) => {\n if (!headers) return null;\n\n return (\n <TableHead>\n <MUITableRow>\n {headers.map((header: ReactNode, i) => (\n <TableCell\n align={headerCellAlignment[i] || \"centerJustify\"}\n key={`header-cell-${i}`}\n headerColours={headerColours}\n >\n {header}\n </TableCell>\n ))}\n </MUITableRow>\n </TableHead>\n );\n }\n);\n\nconst StaticTable: React.FC<IStaticTableProps> = memo(\n ({\n rowBorderSeparation = false,\n headers,\n rows,\n headerCellAlignment = [],\n rowCellAlignment = [],\n styling,\n headerColours,\n paginate = false,\n itemsPerPage = 30,\n }) => {\n const classes = {\n ...useLayoutStyles(),\n ...useSpacingStyles(),\n ...useStaticTableStyles(),\n };\n const [page, setPage] = useState(1);\n\n const hasRowsAndPaginated = useMemo(\n () => !!(paginate && (rows?.length || 0) > itemsPerPage),\n [itemsPerPage, paginate, rows]\n );\n\n const [visibleRows, setVisibleRows] = useState<typeof rows>(\n hasRowsAndPaginated ? rows!.slice(0, itemsPerPage) : rows\n );\n\n const handlePageChange = useCallback(\n (event: React.ChangeEvent<unknown>, value: number) => {\n setPage(value);\n },\n []\n );\n\n useEffect(() => {\n setVisibleRows(\n hasRowsAndPaginated\n ? rows!.slice(itemsPerPage * (page - 1), itemsPerPage * page)\n : rows\n );\n }, [hasRowsAndPaginated, itemsPerPage, page, rows]);\n\n return (\n <>\n <Table\n className={`${classes.tableStyles} ${\n hasRowsAndPaginated ? classes.contentBreak : \"\"\n } ${styling || \"\"}`}\n >\n <StaticTableHeaders\n headers={headers}\n headerCellAlignment={headerCellAlignment}\n headerColours={headerColours}\n />\n\n <TableBody>\n {visibleRows ? (\n visibleRows.length ? (\n visibleRows.map((data, i) => {\n const containsOnClick = !!data.onClick;\n return (\n <TableRow\n rowBorderSeparation={rowBorderSeparation}\n className={containsOnClick ? classes.pointer : undefined}\n key={`row-${i}`}\n onClick={containsOnClick ? data.onClick : undefined}\n >\n {data.row.map((cell: ReactNode, n) => (\n <TableCell\n align={rowCellAlignment[n] || \"centerJustify\"}\n className={\n rowBorderSeparation && visibleRows.length !== i + 1\n ? classes.bottomBorder\n : undefined\n }\n key={`row-${i}-cell-${n}`}\n >\n {cell}\n </TableCell>\n ))}\n </TableRow>\n );\n })\n ) : (\n <SingleCellRow colSpan={headers?.length || 0}>\n Table is empty\n </SingleCellRow>\n )\n ) : (\n <SingleCellRow colSpan={headers?.length || 0}>\n <LoadingSpinner />\n </SingleCellRow>\n )}\n </TableBody>\n </Table>\n {hasRowsAndPaginated ? (\n <Pagination\n className={classes.flexCenter}\n count={Math.ceil(rows!.length / itemsPerPage)}\n page={page}\n onChange={handlePageChange}\n shape=\"rounded\"\n showFirstButton\n showLastButton\n />\n ) : null}\n </>\n );\n }\n);\n\nexport default StaticTable;\n","import React from \"react\";\nimport { makeStyles, Typography, Link, Box, ButtonBase } from \"@material-ui/core\";\nimport { Link as RouterLink } from \"react-router-dom\";\nimport { IBreadcrumbColors, IBreadcrumbsProps } from \"./Breadcrumbs.types\";\n\nconst useStyles = makeStyles((theme) => ({\n logoContainer: {\n width: \"3rem\",\n height: \"3rem\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n },\n logo: {\n width: \"100%\",\n height: \"100%\",\n \"& > div\": {\n width: \"100%\",\n height: \"100%\",\n },\n \"& > svg\": {\n width: \"100%\",\n height: \"100%\",\n },\n },\n logoInBreadcrumb: {\n width: \"2rem\",\n height: \"2rem\",\n margin: \"0.125rem 0 0.125rem 0.313rem\",\n },\n logoSpacing: {\n marginRight: theme.spacing(1),\n },\n flexItemsCenter: {\n display: \"flex\",\n alignItems: \"center\",\n },\n nonPrimaryBreadcrumbOffset: {\n marginLeft: \"2.5rem\",\n },\n BreadcrumbsContainer: {\n height: \"2.25rem\",\n marginLeft: \"0.875rem\",\n marginRight: \"1.5rem\",\n },\n primaryBreadcrumbItem: ({ primary }: IBreadcrumbColors) => ({\n backgroundColor: primary?.background || theme.palette.common.white,\n color: primary?.color || theme.palette.text.primary,\n borderRadius: \"2rem\",\n zIndex: 3,\n height: \"100%\",\n display: \"flex\",\n alignItems: \"center\",\n }),\n secondaryBreadcrumbItem: ({ secondary }: IBreadcrumbColors) => ({\n height: \"2.25rem\",\n backgroundColor: secondary?.background || \"#D7D4E4\",\n borderRadius: \"2rem\",\n zIndex: 2,\n marginLeft: \"-2rem\",\n color: secondary?.color || theme.palette.text.primary,\n }),\n tertiaryBreadcrumbItem: ({ tertiary }: IBreadcrumbColors) => ({\n height: \"2.25rem\",\n backgroundColor: tertiary?.background || \"#D7D4E4\",\n borderRadius: \"2rem\",\n zIndex: 1,\n marginLeft: \"-2rem\",\n color: tertiary?.color || theme.palette.common.white,\n }),\n breadCrumbShadow: {\n boxShadow: theme.shadows[2],\n },\n breadcrumbRightMargin: {\n marginRight: \"1rem\",\n },\n breadcrumbTextOverflow: {\n display: \"block\",\n overflow: \"hidden\",\n textOverflow: \"ellipsis\",\n maxWidth: \"12rem\",\n },\n boldText: {\n fontWeight: 500,\n },\n activeBreadcrumb: ({ tertiary }: IBreadcrumbColors) => ({\n backgroundColor: tertiary?.background || \"#D7D4E4\",\n color: tertiary?.color || theme.palette.common.white,\n }),\n noWrap: {\n whiteSpace: \"nowrap\",\n },\n fullBorderRadius: {\n borderRadius: \"100%\",\n },\n}));\n\nconst Breadcrumbs: React.FC<IBreadcrumbsProps> = ({ logo, content, colors }) => {\n const classes = useStyles({ ...(colors || {}) });\n\n const { first = null, second = null, third = null } = content;\n\n return (\n <Box className={`${classes.BreadcrumbsContainer} ${classes.flexItemsCenter}`}>\n <Box\n className={`${\n first ? `${classes.primaryBreadcrumbItem} ${classes.breadCrumbShadow}` : \"\"\n } ${classes.flexItemsCenter}`}\n >\n <Link component={RouterLink} to=\"/\" className={classes.logoSpacing}>\n <Box\n className={`${classes.logoContainer} \n ${first ? classes.logoInBreadcrumb : \"\"}`}\n >\n <ButtonBase className={`${classes.logo} ${classes.fullBorderRadius}`}>\n {logo}\n </ButtonBase>\n </Box>\n </Link>\n {first && (\n <Typography\n color=\"textPrimary\"\n className={`${classes.boldText} ${classes.noWrap} ${classes.primaryBreadcrumbItem}`}\n >\n <Link\n underline=\"none\"\n component={RouterLink}\n to={first.link}\n color=\"inherit\"\n className={`${classes.breadcrumbRightMargin} ${classes.breadcrumbTextOverflow}`}\n >\n {first.name}\n </Link>\n </Typography>\n )}\n </Box>\n\n {second && (\n <Box\n className={`${classes.flexItemsCenter} ${classes.secondaryBreadcrumbItem} ${\n classes.breadCrumbShadow\n } ${!third ? classes.activeBreadcrumb : \"\"}`}\n >\n <Typography color=\"inherit\" className={`${classes.boldText} ${classes.noWrap}`}>\n <Link\n component={RouterLink}\n underline=\"none\"\n to={second.link}\n color=\"inherit\"\n className={`${classes.nonPrimaryBreadcrumbOffset} ${classes.breadcrumbRightMargin} ${classes.breadcrumbTextOverflow}`}\n >\n {second.name}\n </Link>\n </Typography>\n </Box>\n )}\n {third && (\n <Box\n className={`${classes.flexItemsCenter} ${classes.tertiaryBreadcrumbItem} ${classes.breadCrumbShadow}`}\n >\n <Typography color=\"inherit\" className={`${classes.boldText} ${classes.noWrap}`}>\n <Link\n component={RouterLink}\n underline=\"none\"\n to={third.link}\n color=\"inherit\"\n className={`${classes.nonPrimaryBreadcrumbOffset} ${classes.breadcrumbRightMargin} ${classes.breadcrumbTextOverflow}`}\n >\n {third.name}\n </Link>\n </Typography>\n </Box>\n )}\n </Box>\n );\n};\n\nexport default Breadcrumbs;\n","import { Box, Button, Grid, makeStyles, Typography } from \"@material-ui/core\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport React from \"react\";\nimport { Link as RouterLink } from \"react-router-dom\";\nimport { useFontStyles, useSpacingStyles } from \"../styles\";\nimport { IEntityListProps } from \"./EntityList.types\";\nimport { BORDER_RADIUS } from \"../globals\";\n\nconst useStyles = makeStyles((theme) => ({\n container: {\n marginRight: theme.spacing(-1.5),\n marginLeft: theme.spacing(-1.5),\n },\n svgContainer: {\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n button: {\n display: \"block\",\n textDecoration: \"none\",\n borderRadius: BORDER_RADIUS,\n height: \"100%\",\n width: \"100%\",\n textAlign: \"center\",\n },\n orgLabel: {\n padding: theme.spacing(1),\n paddingTop: 0,\n },\n}));\n\nconst EntityList: React.FC<IEntityListProps> = ({\n entities,\n icon,\n loadingMessage = \"Loading list...\",\n emptyMessage = \"List is empty\",\n onClick,\n}) => {\n const classes = {\n ...useStyles(),\n ...useSpacingStyles(),\n ...useFontStyles(),\n };\n\n return (\n <Box className={classes.container}>\n {!entities ? (\n <LoadingSpinner text={loadingMessage} />\n ) : entities.length ? (\n <Grid container spacing={3}>\n {entities.map((entity, index) => (\n <Grid key={`${entity.name}-${index}`} item xs={4} md={3}>\n <Button\n className={classes.button}\n key={entity.name}\n {...(onClick\n ? { onClick: () => onClick(entity) }\n : {\n component: RouterLink,\n to: entity.link,\n })}\n >\n <Box className={`${classes.svgContainer} ${classes.labelBreak}`}>\n {icon(entity)}\n </Box>\n <Typography className={classes.orgLabel} variant=\"body1\">\n {entity.name}\n </Typography>\n </Button>\n </Grid>\n ))}\n </Grid>\n ) : (\n <Typography className={classes.centerText} variant=\"body2\" color=\"textSecondary\">\n {emptyMessage}\n </Typography>\n )}\n </Box>\n );\n};\n\nexport default EntityList;\n","import React from \"react\";\nimport ErrorIcon from \"@material-ui/icons/Error\";\nimport { Typography, Box } from \"@material-ui/core\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { IErrorIndicatorProps } from \"./ErrorIndicator.types\";\n\nconst ErrorIndicator: React.FC<IErrorIndicatorProps> = ({\n text = \"Something went wrong\",\n}) => {\n const classes = { ...useSpacingStyles(), ...useLayoutStyles() };\n\n return (\n <Box className={classes.flexCenter}>\n <ErrorIcon fontSize=\"medium\" className={classes.rightSpacer1} color=\"error\" />\n <Typography variant=\"body2\" color=\"textSecondary\">\n {text}\n </Typography>\n </Box>\n );\n};\n\nexport default ErrorIndicator;\n","import React, { useState } from \"react\";\nimport {\n makeStyles,\n List,\n ListItem,\n ListItemIcon,\n ListItemText,\n Collapse,\n Typography,\n Box,\n} from \"@material-ui/core\";\nimport { ExpandLess, ExpandMore } from \"@material-ui/icons\";\nimport { useLocation, Link as RouterLink } from \"react-router-dom\";\nimport { useFontStyles, useSpacingStyles } from \"../styles\";\nimport { IListItemProps, INavListItemStyleProps } from \"./LeftNavigation.types\";\n\nconst useNavListStyles = makeStyles((theme) => ({\n listIcon: {\n minWidth: \"auto\",\n paddingRight: \"0.25rem\",\n },\n mainIconSize: {\n fontSize: \"1rem\",\n },\n mainIconMarginAdjustment: {\n marginTop: \"3px\",\n },\n textOverflowElipsis: {\n overflow: \"hidden\",\n textOverflow: \"ellipsis\",\n },\n mainListItem: (props: INavListItemStyleProps) => ({\n padding: \"8px 24px 8px 16px\",\n alignItems: \"flex-start\",\n backgroundColor: props.mainBackground || theme.palette.common.white,\n color: props.mainText || theme.palette.text.primary,\n borderRadius: theme.spacing(0.6),\n \"&:hover\": {\n backgroundColor: props.mainHover || theme.palette.action.hover,\n },\n }),\n mainIconColor: (props: INavListItemStyleProps) => ({\n color: props.mainIcon || theme.palette.grey[500],\n }),\n\n activeMainIconColor: (props: INavListItemStyleProps) => ({\n color: props.mainActiveText || \"#8FC1FF\",\n }),\n\n subListItem: (props: INavListItemStyleProps) => ({\n backgroundColor: props.subItemBackground || \"#FFFFFF\",\n color: props.subItemText || theme.palette.text.secondary,\n borderRadius: \"8px\",\n \"&:hover\": {\n backgroundColor: props.subItemHover || \"rgba(143,193,255,0.3)\",\n },\n }),\n\n activeSubListItem: (props: INavListItemStyleProps) => ({\n backgroundColor: props.subItemActiveBackground || \"#FFFFFF\",\n color: props.subItemActiveText || \"#8FC1FF\",\n \"&:hover\": {\n backgroundColor: props.subItemActiveHover || \"rgba(143,193,255,0.3)\",\n },\n }),\n\n subItemBorder: {\n borderLeft: `1px solid ${theme.palette.grey[600]}`,\n marginLeft: \"1px\",\n marginRight: \"1px\",\n width: \"100%\",\n height: \"100%\",\n },\n relativeWrapper: {\n position: \"relative\",\n },\n subItemBorderMask: (props: INavListItemStyleProps) => ({\n borderLeft: `3px solid ${props.subItemActiveText || \"#8FC1FF\"}`,\n borderRadius: \"1px\",\n position: \"absolute\",\n top: \"50%\",\n bottom: \"50%\",\n transition: \"all 0.2s ease-in-out\",\n }),\n activeSubItemBorder: {\n top: \"0 !important\",\n bottom: \"0 !important\",\n },\n subItemWrapper: {\n display: \"flex\",\n marginLeft: \"13px\",\n marginRight: \"16px\",\n },\n noYMargin: {\n marginTop: \"unset\",\n marginBottom: \"unset\",\n },\n}));\n\nconst isItemActive = (currentPathname: string, id: string) => {\n if (currentPathname.split(\"/\").includes(id)) {\n return true;\n }\n return false;\n};\n\nconst NavListItem: React.FC<IListItemProps> = ({ mainItem, subItems, config, Icon }) => {\n const classes = {\n ...useFontStyles(),\n ...useSpacingStyles(),\n ...useNavListStyles({\n ...(config.secondary?.mainItemColors || {}),\n ...(config.secondary?.subItemColors || {}),\n }),\n };\n const location = useLocation();\n\n const activeMainItem = isItemActive(location.pathname, mainItem.id);\n const [subExpanded, setSubExpanded] = useState<boolean>(\n subItems?.length ? activeMainItem : false\n );\n\n return (\n <>\n <ListItem\n button\n dense\n className={classes.mainListItem}\n component={RouterLink}\n to={mainItem.route}\n >\n <ListItemIcon\n className={`${classes.listIcon} ${classes.mainIconMarginAdjustment} ${classes.rightSpacer1}`}\n >\n <Icon\n id=\"second-nav-item\"\n styling={`${classes.mainIconSize} ${classes.mainIconColor} ${\n activeMainItem ? classes.activeMainIconColor : \"\"\n }`}\n />\n </ListItemIcon>\n <ListItemText\n disableTypography\n className={classes.noYMargin}\n primary={\n <Typography\n variant=\"body2\"\n className={`${classes.bolderText} ${classes.textOverflowElipsis}`}\n color=\"inherit\"\n >\n {mainItem.name}\n {subItems?.length ? (\n <Typography\n component=\"span\"\n variant=\"body2\"\n className={classes.bolderText}\n color=\"inherit\"\n >\n {\" \"}\n ({subItems.length})\n </Typography>\n ) : null}\n </Typography>\n }\n />\n {subItems?.length ? (\n <ListItemIcon\n className={classes.listIcon}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n setSubExpanded((expanded) => !expanded);\n }}\n >\n {subExpanded ? <ExpandLess /> : <ExpandMore />}\n </ListItemIcon>\n ) : null}\n </ListItem>\n {subItems?.length ? (\n <Collapse in={subExpanded} timeout=\"auto\" unmountOnExit>\n <List component=\"div\" disablePadding>\n {subItems.map(({ name, route, id }) => (\n <Box key={id} className={classes.subItemWrapper}>\n <Box className={`${classes.relativeWrapper} ${classes.rightSpacer1}`}>\n <Box className={`${classes.subItemBorder} `} />\n <Box\n className={`${classes.subItemBorderMask} ${\n isItemActive(location.pathname, id)\n ? classes.activeSubItemBorder\n : \"\"\n } `}\n />\n </Box>\n\n <ListItem\n key={route}\n component={RouterLink}\n to={route}\n button\n dense\n className={`${classes.subListItem} ${\n isItemActive(location.pathname, id) ? classes.activeSubListItem : \"\"\n }`}\n >\n <ListItemText\n disableTypography\n primary={\n <Typography\n variant=\"body2\"\n className={classes.textOverflowElipsis}\n color=\"inherit\"\n >\n {name}\n </Typography>\n }\n />\n </ListItem>\n </Box>\n ))}\n </List>\n </Collapse>\n ) : null}\n </>\n );\n};\n\nexport default NavListItem;\n","import { isValid } from \"date-fns\";\nimport { TableCellValues } from \"../EditableTable/EditableTable.types\";\n\nexport function sortDescendingStartDateString<T extends { startDate: string }>(\n array: T[]\n): T[] {\n return array.sort(\n (a, b) =>\n +b.startDate.split(\"T\")[0].replaceAll(\"-\", \"\") -\n +a.startDate.split(\"T\")[0].replaceAll(\"-\", \"\")\n );\n}\n\nexport const didCellValueChange = (\n oldVal: TableCellValues,\n newVal: TableCellValues,\n isDateValue?: boolean\n) =>\n isDateValue\n ? ((oldVal && isValid(oldVal) ? oldVal : new Date(0)) as Date).getTime() ===\n ((newVal && isValid(newVal) ? newVal : new Date(0)) as Date).getTime()\n : oldVal === newVal;\n","import React from \"react\";\nimport { Box, IconButton, makeStyles, Typography, List } from \"@material-ui/core\";\nimport NavListItem from \"./NavListItem\";\nimport { useHistory } from \"react-router-dom\";\nimport {\n ISecondaryLeftNavContainerProps,\n ISecondaryNavigationItem,\n} from \"./LeftNavigation.types\";\nimport { sortDescendingStartDateString } from \"../utils\";\nimport CloseIcon from \"@material-ui/icons/Close\";\nimport AddBoxOutlinedIcon from \"@material-ui/icons/AddBoxOutlined\";\nimport { useFontStyles, useSpacingStyles } from \"../styles\";\nimport { BORDER_RADIUS } from \"../globals\";\n\ntype SecondaryNavStyles = {\n titleColor?: string;\n titleIconColor?: string;\n};\n\nconst useSecondaryNavStyles = makeStyles((theme) => ({\n secondaryNavWrapper: {\n height: \"100%\",\n width: \"300px\",\n background: \"white\",\n overflowY: \"auto\",\n overflowX: \"hidden\",\n borderTopRightRadius: BORDER_RADIUS,\n borderBottomRightRadius: BORDER_RADIUS,\n marginLeft: \"-16px\",\n paddingLeft: \"16px\",\n border: `1px solid ${theme.palette.grey[300]}`,\n boxShadow: \"0 2px 4px 0 rgba(0, 0, 0, 0.3)\",\n boxSizing: \"border-box\",\n },\n titleWrapper: {\n marginTop: \"24px\",\n display: \"flex\",\n alignItems: \"center\",\n paddingLeft: \"16px\",\n paddingRight: \"16px\",\n },\n title: {\n fontSize: \"18px\",\n fontWeight: 500,\n color: (props: SecondaryNavStyles) => props.titleColor || \"#8FC1FF\",\n },\n titleIcons: {\n color: (props: SecondaryNavStyles) => props.titleIconColor || \"#8FC1FF\",\n },\n closeButton: {\n marginLeft: \"auto\",\n },\n archivedSeparator: {\n paddingLeft: \"8px\",\n color: theme.palette.grey[500],\n },\n archivedBorder: {\n marginTop: \"3rem\",\n border: `1px solid ${theme.palette.grey[200]}`,\n width: \"33%\",\n marginLeft: \"8px\",\n },\n listWrapper: {\n marginLeft: theme.spacing(1),\n marginRight: theme.spacing(1),\n },\n}));\n\nconst SecondaryLeftNavContainer: React.FC<ISecondaryLeftNavContainerProps> = ({\n secondaryNavItems,\n primaryNavItems,\n expandedOptions,\n setExpandedOptions,\n config,\n}) => {\n const stylesProps = {\n titleColor: config.secondary?.titleColor,\n titleIconColor: config.secondary?.titleIconColor,\n };\n const classes = {\n ...useSpacingStyles(),\n ...useFontStyles(),\n ...useSecondaryNavStyles(stylesProps),\n };\n const history = useHistory();\n\n const navItem = secondaryNavItems[expandedOptions.view];\n\n if (!navItem) return null;\n\n const mainItemIcon = primaryNavItems.find(\n (item) => item.field === expandedOptions.view\n )!.Icon;\n\n return (\n <Box className={classes.secondaryNavWrapper}>\n <Box className={classes.titleWrapper}>\n <Typography className={`${classes.rightSpacer1} ${classes.title}`}>\n {expandedOptions.view}\n </Typography>\n {navItem.button ? (\n <IconButton\n className={classes.titleIcons}\n size=\"small\"\n type=\"button\"\n onClick={() => history.push(navItem.button!.url)}\n >\n <AddBoxOutlinedIcon />\n </IconButton>\n ) : null}\n <IconButton\n className={`${classes.titleIcons} ${classes.closeButton}`}\n size=\"small\"\n type=\"button\"\n onClick={() => setExpandedOptions({ view: \"\", expanded: false })}\n >\n {config.secondary?.closeButtonSvg || <CloseIcon />}\n </IconButton>\n </Box>\n\n <List className={classes.listWrapper} component=\"div\">\n {sortDescendingStartDateString<ISecondaryNavigationItem>(navItem.items).map(\n (item) => (\n <NavListItem\n key={item.mainItem.route}\n {...item}\n config={config}\n Icon={mainItemIcon}\n />\n )\n )}\n {navItem.archivedItems?.length ? (\n <>\n <Box className={`${classes.archivedBorder} ${classes.contentBreak}`} />\n <Typography\n variant=\"body2\"\n className={`${classes.archivedSeparator} ${classes.bolderText}`}\n >\n Archived {expandedOptions.view}\n </Typography>\n {sortDescendingStartDateString<ISecondaryNavigationItem>(\n navItem.archivedItems\n ).map((item) => (\n <NavListItem\n key={item.mainItem.route}\n {...item}\n config={config}\n Icon={mainItemIcon}\n />\n ))}\n </>\n ) : null}\n </List>\n </Box>\n );\n};\n\nexport default SecondaryLeftNavContainer;\n","import React from \"react\";\nimport { useLocation, Link as RouterLink } from \"react-router-dom\";\nimport {\n Box,\n List,\n ListItem,\n ListItemIcon,\n makeStyles,\n Typography,\n} from \"@material-ui/core\";\nimport { IPrimaryConfig, IPrimaryLeftNavContainerProps } from \"./LeftNavigation.types\";\nimport { BORDER_RADIUS } from \"../globals\";\n\nconst usePrimaryLeftNavStyles = makeStyles((theme) => ({\n primaryNavContainer: (props: IPrimaryConfig) => ({\n background: props.background || \"linear-gradient(to bottom, #253a68 40%, #73c4ca)\",\n border: `2px solid ${props.activeBorderColor || \"#8FC1FF\"}`,\n borderLeft: \"none\",\n borderTopRightRadius: BORDER_RADIUS,\n borderBottomRightRadius: BORDER_RADIUS,\n minWidth: \"4.5rem\",\n overflowY: \"auto\",\n overflowX: \"hidden\",\n }),\n listWrapper: {\n display: \"flex\",\n flexDirection: \"column\",\n paddingTop: 0,\n },\n itemWrapper: {\n display: \"flex\",\n flexDirection: \"column\",\n padding: \"0.75rem 0.5rem 0.5rem 0.5rem\",\n },\n itemBorder: {\n borderRight: (props: IPrimaryConfig) =>\n `6px solid ${props.activeBorderColor || \"#8FC1FF\"}`,\n position: \"absolute\",\n bottom: \"50%\",\n top: \"50%\",\n transition: \"all 0.2s ease-in-out\",\n right: \"-3px\",\n },\n activeBorder: {\n top: \"15%\",\n bottom: \"15%\",\n },\n iconWrapper: {\n minWidth: 0,\n marginBottom: \"4px\",\n position: \"relative\",\n },\n itemName: {\n fontSize: \"0.7rem\",\n maxWidth: \"3.5rem\",\n textAlign: \"center\",\n textOverflow: \"ellipsis\",\n overflow: \"hidden\",\n },\n textColour: {\n color: (props: IPrimaryConfig) => props.text || \"#FFFFFF\",\n },\n activeTextColour: {\n color: (props: IPrimaryConfig) => props.activeText || \"#8FC1FF\",\n },\n lastItem: {\n marginTop: \"auto\",\n },\n}));\n\nconst PrimaryLeftNavContainer: React.FC<IPrimaryLeftNavContainerProps> = ({\n expandedOptions,\n setExpandedOptions,\n navigationLinks,\n config,\n}) => {\n const location = useLocation();\n const classes = usePrimaryLeftNavStyles({ ...(config.primary || {}) });\n\n const applyActiveBackground = (fieldName: string, path: string) => {\n if (expandedOptions.view === \"\") {\n if (location.pathname === path) {\n return true;\n } else if (\n fieldName !== config.rootRouteName &&\n location.pathname.startsWith(path)\n ) {\n return true;\n } else return false;\n } else if (expandedOptions.view === fieldName) {\n return true;\n } else return false;\n };\n\n return (\n <List className={`${classes.primaryNavContainer} ${classes.listWrapper}`}>\n {navigationLinks.map((item, index, arr) => (\n <ListItem\n key={item.field}\n button\n className={`${classes.itemWrapper} ${classes.textColour} ${\n config.primary?.moveLastItemToBottom && index === arr.length - 1\n ? classes.lastItem\n : \"\"\n }`}\n {...(!!item.hasSecondary ? {} : { component: RouterLink, to: item.path })}\n onClick={() => {\n setExpandedOptions({ view: item.field, expanded: !!item.hasSecondary });\n }}\n >\n <ListItemIcon className={classes.iconWrapper}>\n <item.Icon\n styling={`${classes.textColour} ${\n applyActiveBackground(item.field, item.path)\n ? classes.activeTextColour\n : \"\"\n }`}\n />\n </ListItemIcon>\n <Typography\n variant=\"caption\"\n className={`${classes.itemName} ${classes.textColour} ${\n applyActiveBackground(item.field, item.path) ? classes.activeTextColour : \"\"\n }`}\n >\n {item.field}\n </Typography>\n <Box\n className={`${classes.itemBorder} ${\n applyActiveBackground(item.field, item.path) ? classes.activeBorder : \"\"\n }`}\n />\n </ListItem>\n ))}\n </List>\n );\n};\n\nexport default PrimaryLeftNavContainer;\n","import React, { useState, useEffect } from \"react\";\nimport { useLocation } from \"react-router-dom\";\nimport SecondaryLeftNavContainer from \"./SecondaryLeftNavigation\";\nimport PrimaryLeftNavContainer from \"./PrimaryLeftNavigation\";\nimport { Box, makeStyles } from \"@material-ui/core\";\nimport { ILeftNavigationProps } from \"./LeftNavigation.types\";\n\nconst useLeftNavStyles = makeStyles({\n leftNavContainer: {\n height: \"100%\",\n display: \"flex\",\n position: \"relative\",\n width: \"max-content\",\n },\n});\n\nconst LeftNavigation: React.FC<ILeftNavigationProps> = ({\n primaryNavItems,\n secondaryNavItems,\n config,\n}) => {\n const [expandedOptions, setExpandedOptions] = useState({\n view: \"\",\n expanded: false,\n });\n\n const styles = useLeftNavStyles();\n const location = useLocation();\n\n const navsWithSecondary = primaryNavItems.reduce(\n (navs, nav) => (nav.hasSecondary ? [...navs, nav.field] : navs),\n [] as string[]\n );\n\n useEffect(() => {\n setExpandedOptions((prev) => {\n if (navsWithSecondary.includes(prev.view) && prev.expanded === true) {\n return prev;\n } else return { view: \"\", expanded: false };\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [location.pathname]);\n\n return (\n <Box component=\"nav\" className={styles.leftNavContainer}>\n <PrimaryLeftNavContainer\n expandedOptions={expandedOptions}\n setExpandedOptions={setExpandedOptions}\n navigationLinks={primaryNavItems}\n config={config}\n />\n\n {expandedOptions.expanded && (\n <SecondaryLeftNavContainer\n secondaryNavItems={secondaryNavItems}\n primaryNavItems={primaryNavItems}\n expandedOptions={expandedOptions}\n setExpandedOptions={setExpandedOptions}\n config={config}\n />\n )}\n </Box>\n );\n};\nexport default LeftNavigation;\n","import React from \"react\";\nimport { Box, Container, makeStyles } from \"@material-ui/core\";\nimport { IMainLayoutProps, IMainLayoutStyleProps } from \"./MainLayout.types\";\n\nconst useMainLayoutStyles = makeStyles((theme) => ({\n remainingHeightBox: {\n position: \"absolute\",\n top: (props: IMainLayoutStyleProps) => props.topOffset ?? \"4rem\",\n bottom: 0,\n left: 0,\n right: 0,\n display: \"flex\",\n },\n fullHeightFlexbox: {\n display: \"flex\",\n height: \"100%\",\n },\n relativeContainer: {\n position: \"relative\",\n },\n scrollWrapper: {\n overflow: \"auto\",\n },\n componentWrapper: {\n padding: theme.spacing(2),\n paddingBottom: theme.spacing(2),\n position: \"relative\",\n },\n}));\n\nconst MainLayout: React.FC<IMainLayoutProps> = ({\n sideNavigation,\n children,\n desktopWidth,\n topOffset,\n}) => {\n const classes = useMainLayoutStyles({ topOffset });\n return (\n <Box className={classes.remainingHeightBox}>\n {sideNavigation ? (\n <Box className={`${classes.fullHeightFlexbox} ${classes.relativeContainer}`}>\n {sideNavigation}\n </Box>\n ) : null}\n <Container disableGutters maxWidth={false} className={classes.scrollWrapper}>\n <Container\n disableGutters\n maxWidth={desktopWidth ? \"xl\" : \"lg\"}\n className={classes.componentWrapper}\n >\n {children}\n </Container>\n </Container>\n </Box>\n );\n};\n\nexport default MainLayout;\n","import { useCallback, useEffect } from \"react\";\n\nconst useDebounceEffect = (\n effect: (query: string) => void,\n deps: any[],\n delay: number = 250\n) => {\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const callback = useCallback(effect, deps);\n\n useEffect(() => {\n const timeout = setTimeout(callback, delay);\n return () => clearTimeout(timeout);\n }, [callback, delay]);\n};\n\nexport default useDebounceEffect;\n","import { useEffect, useRef } from \"react\";\n\nconst useInterval = (callback: () => void, delay: number | null) => {\n const savedCallback = useRef<() => void | undefined>();\n\n useEffect(() => {\n savedCallback.current = callback;\n });\n\n useEffect(() => {\n const tick = () => {\n if (savedCallback.current) savedCallback.current();\n };\n\n if (delay !== null) {\n const id = setInterval(tick, delay);\n return () => clearInterval(id);\n }\n }, [delay]);\n};\n\nexport default useInterval;\n","import { isEqual } from \"lodash\";\nimport { useRef, useEffect } from \"react\";\n\nexport default function useWhyDidYouUpdate(name: string, props: Record<string, any>) {\n const latestProps = useRef(props);\n\n useEffect(() => {\n const allKeys = Object.keys({ ...latestProps.current, ...props });\n\n const changesObj: Record<\n string,\n { from: any; to: any; isDeepEqual: boolean; changedKeys?: string[] }\n > = {};\n allKeys.forEach((key) => {\n if (latestProps.current[key] !== props[key]) {\n changesObj[key] = {\n from: latestProps.current[key],\n to: props[key],\n changedKeys:\n props[key] && typeof props[key] === \"object\"\n ? Object.keys(latestProps.current[key])\n .map((k) => (latestProps.current[key][k] === props[key][k] ? \"\" : k))\n .filter(Boolean)\n : undefined,\n isDeepEqual: isEqual(latestProps.current[key], props[key]),\n };\n }\n });\n\n if (Object.keys(changesObj).length) {\n console.log(\"[why-did-you-update]\", name, {\n changes: changesObj,\n props: { from: latestProps.current, to: props },\n });\n }\n\n latestProps.current = props;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, Object.values(props));\n}\n","import { Divider, List, ListItem, makeStyles, Typography } from \"@material-ui/core\";\nimport React from \"react\";\nimport { Link as RouterLink } from \"react-router-dom\";\nimport { BORDER_RADIUS } from \"../globals\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { IAlphabeticalListProps } from \"./AlphabeticalList.types\";\n\nconst useAlphabeticalListStyles = makeStyles((theme) => ({\n divider: {\n background: theme.palette.primary.main,\n height: \"0.2rem\",\n },\n letterHeader: {\n cursor: \"default\",\n color: theme.palette.primary.main,\n marginTop: \"1rem\",\n },\n listItem: {\n borderRadius: BORDER_RADIUS,\n border: `1px solid ${theme.palette.grey[300]}`,\n marginBottom: \"0.5rem\",\n paddingLeft: \"24px\",\n boxShadow: theme.shadows[1],\n },\n topMargin: {\n marginTop: theme.spacing(2),\n display: \"block\",\n },\n}));\n\nconst AlphabeticalList: React.FC<IAlphabeticalListProps> = ({\n array,\n sortFn,\n sortKey = \"name\",\n buttonClick,\n linkTo,\n ItemTemplate,\n arrayKey = \"id\",\n loadingMessage = \"Loading list...\",\n emptyMessage = \"List is empty\",\n alphabetisedHeader = true,\n}) => {\n const classes = {\n ...useAlphabeticalListStyles(),\n ...useSpacingStyles(),\n ...useLayoutStyles(),\n };\n\n if (array === undefined) {\n return <LoadingSpinner styling={classes.topMargin} text={loadingMessage} />;\n }\n\n if (!array?.length) {\n return (\n <Typography\n className={classes.topMargin}\n align=\"center\"\n variant=\"body2\"\n color=\"textSecondary\"\n >\n {emptyMessage}\n </Typography>\n );\n }\n\n const result = sortFn ? [...array].sort(sortFn) : array;\n let lastSection = \"\";\n\n return (\n <List className={classes.limitWidth50rem}>\n {result.map((item, index) => {\n let showHeader = false;\n if (alphabetisedHeader) {\n const currentKey = (item[sortKey]?.[0] || \"???\").toLowerCase();\n\n if (currentKey !== lastSection) {\n lastSection = currentKey;\n showHeader = true;\n }\n }\n\n return (\n <React.Fragment key={item[arrayKey] || `alphabetical-list-${index}`}>\n {alphabetisedHeader && showHeader ? (\n <>\n <Typography className={`${classes.letterHeader}`} align=\"left\">\n {lastSection.toUpperCase()}\n </Typography>\n <Divider className={`${classes.contentBreak} ${classes.divider}`} />\n </>\n ) : null}\n\n <ListItem\n className={classes.listItem}\n alignItems=\"flex-start\"\n button={(buttonClick || linkTo ? true : undefined) as true & undefined}\n onClick={buttonClick ? () => buttonClick(item) : undefined}\n {...(linkTo && !buttonClick\n ? { component: RouterLink, to: linkTo(item) }\n : {})}\n >\n <ItemTemplate item={item} />\n </ListItem>\n </React.Fragment>\n );\n })}\n </List>\n );\n};\n\nexport default AlphabeticalList;\n","import React, { useEffect, useState } from \"react\";\nimport { Box, InputBase, InputAdornment, makeStyles } from \"@material-ui/core\";\nimport SearchIcon from \"@material-ui/icons/Search\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { useDebounceEffect } from \"../hooks\";\nimport { ISearchBarProps } from \"./SearchBar.types\";\nimport { BORDER_RADIUS } from \"../globals\";\nimport AlphabeticalList from \"../AlphabeticalList/AlphabeticalList\";\n\ntype StylesProps = {\n background: string | undefined;\n};\n\nconst useSearchBarStyles = makeStyles((theme) => ({\n searchBox: {\n display: \"flex\",\n alignContent: \"center\",\n alignItems: \"center\",\n padding: \"8px\",\n border: `2px solid ${theme.palette.grey[300]}`,\n borderRadius: BORDER_RADIUS,\n },\n searchField: {\n borderRadius: BORDER_RADIUS,\n width: \"100%\",\n background: ({ background }: StylesProps) => background || \"RGBA(179, 213, 235, 0.1)\",\n height: \"46px\",\n paddingLeft: \"24px\",\n color: theme.palette.grey[600],\n },\n searchIcon: {\n color: theme.palette.grey[600],\n },\n}));\n\nconst SearchBar: React.FC<ISearchBarProps> = ({\n array,\n sortFn,\n sortKey = \"name\",\n buttonClick,\n linkTo,\n ItemTemplate,\n arrayKey = \"id\",\n loadingMessage = \"Loading list...\",\n emptyMessage = \"List is empty\",\n inputBackgroundColor,\n placeholder,\n disabledSearch,\n delay = 500,\n minQueryLength = 3,\n handleOnChange,\n searchKeys = [\"name\"],\n alphabetisedHeader = true,\n}) => {\n const classes = {\n ...useSpacingStyles(),\n ...useLayoutStyles(),\n ...useSearchBarStyles({ background: inputBackgroundColor }),\n };\n const [searchInput, setSearchInput] = useState(\"\");\n const [blockSearch, setBlockSearch] = useState(false);\n const [result, setResult] = useState(array);\n\n useDebounceEffect(\n () => {\n if (!blockSearch && searchInput.length >= minQueryLength) {\n if (handleOnChange) {\n handleOnChange(searchInput);\n } else {\n setResult(\n array?.filter((item) => {\n const itemIsFound = searchKeys.some((key) =>\n item[key]?.toLowerCase().includes(searchInput.toLowerCase())\n );\n return itemIsFound;\n })\n );\n }\n }\n },\n [searchInput],\n delay\n );\n\n useEffect(() => {\n setResult(array);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [array]);\n\n return (\n <>\n <Box className={`${classes.searchBox} ${classes.limitWidth50rem}`}>\n <InputBase\n disabled={disabledSearch}\n type=\"text\"\n value={searchInput}\n placeholder={placeholder || \"Enter to search\"}\n onChange={(event) => {\n if (blockSearch) setBlockSearch(false);\n setSearchInput(event.target.value);\n }}\n className={classes.searchField}\n endAdornment={\n <InputAdornment position=\"end\" className={classes.rightSpacer2}>\n <SearchIcon className={classes.searchIcon} />\n </InputAdornment>\n }\n />\n </Box>\n {array !== null && (\n <AlphabeticalList\n array={result}\n sortFn={sortFn}\n sortKey={sortKey}\n buttonClick={buttonClick}\n linkTo={linkTo}\n ItemTemplate={ItemTemplate}\n arrayKey={arrayKey}\n loadingMessage={loadingMessage}\n emptyMessage={emptyMessage}\n alphabetisedHeader={alphabetisedHeader}\n />\n )}\n </>\n );\n};\n\nexport default SearchBar;\n","import React from \"react\";\nimport { TextField as MaterialTextField, makeStyles } from \"@material-ui/core\";\nimport NumberFormat, { NumberFormatProps } from \"react-number-format\";\nimport { ITextFieldProps } from \"./TextField.types\";\nimport { BORDER_RADIUS, NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\n\nconst useStyles = makeStyles((theme) => ({\n inputField: ({ size }: { size: \"small\" | \"medium\" }) => ({\n borderRadius: BORDER_RADIUS,\n ...(size === \"small\" ? theme.typography.body2 : {}),\n }),\n labelStyles: ({ size }: { size: \"small\" | \"medium\" }) => ({\n ...(size === \"small\"\n ? {\n transform: \"translate(14px, 9px) scale(1) !important\",\n ...theme.typography.body2,\n \"&.MuiInputLabel-outlined.MuiInputLabel-shrink\": {\n transform: \"translate(15px, -9px) scale(0.75) !important\",\n },\n }\n : {}),\n }),\n}));\n\nconst TextField: React.FC<ITextFieldProps> = ({\n size = \"small\",\n styling,\n numberField,\n inputProps = {},\n InputProps = {},\n accessLevel,\n disabled,\n fixedDecimalScale,\n ...rest\n}) => {\n const classes = useStyles({ size });\n\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n const inputPropsForNumberField = {\n ...(numberField && { fixedDecimalScale: !!fixedDecimalScale }),\n };\n\n return (\n <MaterialTextField\n className={styling || \"\"}\n disabled={disabledProp}\n {...rest}\n inputProps={{\n ...inputProps,\n ...inputPropsForNumberField,\n }}\n InputProps={{\n ...InputProps,\n className: classes.inputField,\n inputComponent: numberField ? (NumberFormatField as any) : undefined,\n }}\n InputLabelProps={{\n className: classes.labelStyles,\n }}\n variant=\"outlined\"\n size={size}\n />\n );\n};\n\nexport default TextField;\n\ninterface INumberFormatProps extends Omit<NumberFormatProps, \"onChange\"> {\n onChange: (event: { target: { name: string; value: string } }) => void;\n inputRef: (instance: NumberFormat | null) => void;\n fixedDecimalScale: boolean;\n}\n\nexport const NumberFormatField = (props: INumberFormatProps) => {\n const { inputRef, onChange, ...other } = props;\n\n return (\n <NumberFormat\n {...other}\n getInputRef={inputRef}\n onValueChange={(values) => {\n onChange({\n target: {\n name: props.name || \"\",\n value: values.value,\n },\n });\n }}\n thousandSeparator\n decimalScale={2}\n isNumericString\n />\n );\n};\n","import { makeStyles, MenuItem } from \"@material-ui/core\";\nimport React from \"react\";\nimport { BORDER_RADIUS, NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\nimport TextField from \"../TextField/TextField\";\nimport { ISelectProps, IStyleProps } from \"./Select.types\";\n\nconst useSelectStyles = makeStyles((theme) => ({\n listItem: ({ background, size }: IStyleProps) => ({\n overflow: \"auto\",\n scrollbarWidth: \"thin\",\n ...(size === \"small\" ? theme.typography.body2 : {}),\n \"&:hover\": {\n backgroundColor: `${background} !important`,\n },\n }),\n inputStyles: ({ background, size }: IStyleProps) => ({\n borderRadius: `${BORDER_RADIUS} !important`,\n ...(size === \"small\"\n ? { paddingTop: \"9.5px\", paddingBottom: \"8.5px\", ...theme.typography.body2 }\n : {}),\n \"&:focus\": {\n backgroundColor: background,\n },\n }),\n selectedListItem: ({ background }: IStyleProps) => ({\n \"&:focus\": {\n background: `${background} !important`,\n },\n }),\n}));\n\nconst Select: React.FC<ISelectProps> = ({\n selectOptions,\n background = \"#EFEDFF\",\n size = \"small\",\n styling,\n disabled,\n accessLevel,\n ...rest\n}) => {\n const classes = useSelectStyles({ background, size });\n\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n return (\n <TextField\n className={styling || \"\"}\n {...rest}\n disabled={disabledProp}\n size={size}\n SelectProps={{\n inputProps: {\n className: classes.inputStyles,\n },\n }}\n select\n >\n {selectOptions.map((option) => (\n <MenuItem\n key={option.value}\n value={option.value}\n className={classes.listItem}\n classes={{ selected: classes.selectedListItem }}\n >\n {option.description}\n </MenuItem>\n ))}\n </TextField>\n );\n};\n\nexport default Select;\n","import React from \"react\";\nimport {\n DatePicker as MaterialDatePicker,\n MuiPickersUtilsProvider,\n} from \"@material-ui/pickers\";\nimport DateFnsUtils from \"@date-io/date-fns\";\nimport TextField from \"../TextField/TextField\";\nimport { IDatePickerProps } from \"./DatePicker.types\";\nimport { NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\n\nconst DatePicker: React.FC<IDatePickerProps> = ({\n styling,\n format = \"dd MMM yyyy\",\n minDate = new Date(\"1856-09-25\"),\n accessLevel,\n disabled,\n ...rest\n}) => {\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n return (\n <MuiPickersUtilsProvider utils={DateFnsUtils}>\n <MaterialDatePicker\n className={styling || \"\"}\n {...rest}\n disabled={disabledProp}\n inputVariant=\"outlined\"\n autoOk\n format={format}\n minDate={minDate}\n TextFieldComponent={TextField}\n />\n </MuiPickersUtilsProvider>\n );\n};\n\nexport default DatePicker;\n","import React from \"react\";\nimport {\n KeyboardDatePicker as MaterialDatePicker,\n MuiPickersUtilsProvider,\n} from \"@material-ui/pickers\";\nimport DateFnsUtils from \"@date-io/date-fns\";\nimport TextField from \"../TextField/TextField\";\nimport { IKeyboardDatePickerProps } from \"./KeyboardDatePicker.types\";\nimport { NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\n\nconst KeyboardDatePicker: React.FC<IKeyboardDatePickerProps> = ({\n styling,\n format = \"dd/MM/yyyy\",\n minDate = new Date(\"1856-09-25\"),\n accessLevel,\n disabled,\n ...rest\n}) => {\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = disabled;\n\n if (accessLevel === READ_LEVEL) {\n disabledProp = true;\n }\n\n return (\n <MuiPickersUtilsProvider utils={DateFnsUtils}>\n <MaterialDatePicker\n className={styling || \"\"}\n {...rest}\n disabled={disabledProp}\n inputVariant=\"outlined\"\n autoOk\n allowKeyboardControl\n format={format}\n minDate={minDate}\n TextFieldComponent={TextField}\n />\n </MuiPickersUtilsProvider>\n );\n};\n\nexport default KeyboardDatePicker;\n","import { Box, makeStyles, Typography } from \"@material-ui/core\";\nimport React, { useEffect, useState } from \"react\";\nimport Button from \"../Button/Button\";\nimport { NO_ACCESS_LEVEL, READ_LEVEL } from \"../globals\";\nimport { useInterval } from \"../hooks\";\nimport { useSpacingStyles } from \"../styles\";\nimport { IButtonWithConfirmProps } from \"./ButtonWithConfirm.types\";\n\nconst useButtonWithConfirmStyles = makeStyles((theme) => ({\n confirmWrapper: {\n display: \"inline-block\",\n },\n confirmContainer: {\n display: \"flex\",\n alignItems: \"center\",\n },\n whiteText: {\n color: theme.palette.common.white,\n },\n}));\n\nconst ButtonWithConfirm: React.FC<IButtonWithConfirmProps> = ({\n children,\n onClick,\n styling,\n disabled = false,\n variant = \"outlined\",\n color = \"primary\",\n accessLevel = \"\",\n ...rest\n}) => {\n const classes = { ...useSpacingStyles(), ...useButtonWithConfirmStyles() };\n const [confirmView, setConfirmView] = useState(false);\n const [stopInterval, setStopInterval] = useState<boolean>(false);\n\n useInterval(() => setConfirmView(false), !confirmView || stopInterval ? null : 4500);\n\n useEffect(() => {\n setStopInterval(rest.loading);\n setConfirmView(rest.loading);\n }, [rest.loading]);\n\n if ([NO_ACCESS_LEVEL, READ_LEVEL].includes(accessLevel)) return null;\n\n if (confirmView)\n return (\n <Box className={classes.confirmWrapper}>\n <Box className={classes.confirmContainer}>\n <Typography className={classes.rightSpacer1} variant=\"body1\">\n Are you sure?\n </Typography>\n <Button\n {...rest}\n type=\"button\"\n onClick={(e) => {\n setStopInterval(true);\n onClick(e);\n }}\n variant={\"contained\"}\n styling={classes.whiteText}\n disabled={disabled}\n color={color}\n >\n Confirm{rest.loading ? \"ing\" : \"\"}\n </Button>\n </Box>\n </Box>\n );\n\n return (\n <Button\n type=\"button\"\n variant={variant}\n disabled={disabled}\n styling={styling}\n color={color}\n onClick={() => setConfirmView(true)}\n >\n {children}\n </Button>\n );\n};\n\nexport default ButtonWithConfirm;\n","import React, { ReactChild, ReactNode } from \"react\";\nimport {\n Box,\n Checkbox,\n createStyles,\n FormControl,\n FormHelperText,\n InputAdornment,\n makeStyles,\n MenuItem,\n Select,\n TextField,\n Typography,\n withStyles,\n} from \"@material-ui/core\";\nimport { NumberFormatField } from \"../TextField/TextField\";\nimport {\n IAlignment,\n ICustomRenderFnProps,\n IEssentialRenderFnProps,\n} from \"./EditableTable.types\";\nimport { DatePicker, MuiPickersUtilsProvider } from \"@material-ui/pickers\";\nimport DateFnsUtils from \"@date-io/date-fns\";\nimport NumberFormat from \"react-number-format\";\n\nconst determineWidth = (value: string | number, fixedDecimalScale: boolean) => {\n const valueLength = value.toString().length;\n if (!valueLength) return \"6ch\";\n return `${\n valueLength + (fixedDecimalScale ? 3 : 1) + Math.floor(valueLength / 3) / 3\n }ch`;\n};\n\nconst useDefaultTableCellsStyles = makeStyles((theme) => ({\n inputBase: ({ textAlign }: { textAlign?: IAlignment }) => ({\n height: \"unset\",\n padding: 0,\n textAlign: textAlign || \"center\",\n }),\n input: ({ textAlign }: { textAlign?: IAlignment }) => ({\n textAlign: textAlign || \"center\",\n marginRight: \"0.4rem\",\n marginLeft: \"0.4rem\",\n }),\n startAdornment: {\n color: theme.palette.text.secondary,\n },\n modifiedUnderline: {\n \"&:not(.Mui-disabled):before\": {\n borderBottom: \"none\",\n transition: \"none\",\n },\n \"&:hover:not(.Mui-disabled):before\": {\n borderBottom: `1px solid ${theme.palette.grey[\"500\"]} !important`,\n },\n },\n body2Text: {\n ...theme.typography.body2,\n },\n dateFieldWidth: {\n width: \"8ch\",\n },\n fullDateWidth: {\n width: \"11ch\",\n },\n justifyStart: {\n justifyContent: \"flex-start\",\n },\n justifyCenter: {\n justifyContent: \"center\",\n },\n justifyEnd: {\n justifyContent: \"flex-end\",\n },\n totalContainer: {\n display: \"flex\",\n alignItems: \"center\",\n cursor: \"default\",\n },\n selectFocusBackground: {\n \"&:focus\": {\n backgroundColor: \"unset\",\n },\n },\n}));\n\nexport const TableTextField: React.FC<IEssentialRenderFnProps> = ({\n error,\n disabled,\n value,\n onBlur,\n onChange,\n prefix,\n suffix,\n numberField = false,\n textAlign,\n fixedDecimalScale,\n}) => {\n const classes = useDefaultTableCellsStyles({ textAlign });\n\n const inputPropsForNumberField = {\n ...(numberField && { fixedDecimalScale: !!fixedDecimalScale }),\n };\n\n if (typeof value === \"string\" || typeof value === \"number\") {\n return (\n <TextField\n error={!!error}\n inputProps={{\n className: classes.inputBase,\n style: { width: determineWidth(value, !!fixedDecimalScale) },\n ...inputPropsForNumberField,\n }}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n InputProps={{\n startAdornment: prefix ? (\n <InputAdornment position=\"end\" className={classes.startAdornment}>\n {prefix}\n </InputAdornment>\n ) : null,\n endAdornment: suffix ? (\n <InputAdornment position=\"start\" className={classes.startAdornment}>\n {suffix}\n </InputAdornment>\n ) : null,\n inputComponent: numberField ? (NumberFormatField as any) : undefined,\n className: `${classes.body2Text} ${classes.modifiedUnderline}`,\n classes: { input: classes.input },\n }}\n helperText={error || undefined}\n disabled={disabled}\n />\n );\n } else return <Typography variant=\"body2\">Incorrect value type</Typography>;\n};\n\nexport const tableTextField = (tableProps: ICustomRenderFnProps) => {\n return <TableTextField {...{ ...tableProps }} />;\n};\n\nexport const tableNumericStringField = (tableProps: ICustomRenderFnProps) => {\n return <TableTextField {...{ ...tableProps, numberField: true }} />;\n};\n\nexport const tableNumericStringFixedDecimalField = (tableProps: ICustomRenderFnProps) => {\n return (\n <TableTextField {...{ ...tableProps, numberField: true, fixedDecimalScale: true }} />\n );\n};\n\nexport const SelectionCheckbox = withStyles(\n createStyles({\n root: {\n padding: \"3px\",\n },\n })\n)(Checkbox);\n\ninterface ITableDatePicker extends IEssentialRenderFnProps {\n fullDate?: boolean;\n}\n\nexport const TableDatePicker: React.FC<ITableDatePicker> = ({\n disabled,\n fullDate = false,\n value,\n error,\n onChange,\n onBlur,\n textAlign,\n}) => {\n const classes = useDefaultTableCellsStyles({ textAlign });\n\n return (\n <MuiPickersUtilsProvider utils={DateFnsUtils}>\n <DatePicker\n disabled={disabled}\n views={fullDate ? undefined : [\"year\", \"month\"]}\n value={value as string | Date}\n autoOk\n format={fullDate ? \"dd MMM yyyy\" : \"MMM yyyy\"}\n InputProps={{\n className: `${classes.body2Text} ${classes.modifiedUnderline}`,\n }}\n inputProps={{\n className: `${classes.inputBase} ${\n fullDate ? classes.fullDateWidth : classes.dateFieldWidth\n }`,\n classes: { input: classes.input },\n }}\n error={!!error}\n helperText={error || undefined}\n onChange={onChange}\n onBlur={onBlur}\n />\n </MuiPickersUtilsProvider>\n );\n};\n\nexport const tableDateField = (tableProps: ICustomRenderFnProps) => {\n return <TableDatePicker {...tableProps} />;\n};\n\nexport const tableInvoiceDateField = (tableProps: ICustomRenderFnProps) => {\n return <TableDatePicker {...tableProps} fullDate />;\n};\n\nconst TableCheckbox: React.FC<IEssentialRenderFnProps> = ({\n value,\n disabled,\n onChange,\n}) => {\n return (\n <Checkbox\n disabled={disabled}\n checked={value as boolean}\n onChange={onChange}\n color=\"primary\"\n size=\"small\"\n />\n );\n};\n\nexport const tableCheckbox = (tableProps: ICustomRenderFnProps) => {\n return <TableCheckbox {...tableProps} />;\n};\n\ninterface INonEditableField\n extends Pick<\n IEssentialRenderFnProps,\n \"numberField\" | \"prefix\" | \"suffix\" | \"textAlign\" | \"fixedDecimalScale\"\n > {\n text: React.ReactText;\n}\n\nexport const NonEditableField: React.FC<INonEditableField> = ({\n text,\n numberField = false,\n prefix = null,\n suffix = null,\n textAlign,\n fixedDecimalScale,\n}) => {\n const classes = useDefaultTableCellsStyles({});\n return (\n <Box\n className={`${classes.totalContainer} ${classes.body2Text} ${\n textAlign === \"left\"\n ? classes.justifyStart\n : textAlign === \"right\"\n ? classes.justifyEnd\n : classes.justifyCenter\n }`}\n >\n {prefix && prefix}\n <Box className={classes.body2Text}>\n {numberField ? (\n <NumberFormat\n value={text}\n displayType={\"text\"}\n thousandSeparator\n isNumericString\n decimalScale={2}\n fixedDecimalScale={fixedDecimalScale}\n />\n ) : (\n text\n )}\n </Box>\n {suffix && suffix}\n </Box>\n );\n};\n\ninterface ITableSelect extends IEssentialRenderFnProps {\n selectOptions: { [key: string]: ReactChild };\n}\n\nexport const TableSelect: React.FC<ITableSelect> = ({\n error,\n value,\n onBlur,\n onChange,\n selectOptions,\n disabled,\n}) => {\n const classes = useDefaultTableCellsStyles({});\n return (\n <FormControl margin=\"none\" error={!!error}>\n <Select\n className={`${classes.body2Text} ${classes.modifiedUnderline}`}\n inputProps={{ className: classes.selectFocusBackground }}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n disabled={disabled}\n >\n {Object.entries(selectOptions).map(([key, value]) => (\n <MenuItem className={classes.body2Text} key={key} value={key}>\n {value}\n </MenuItem>\n ))}\n </Select>\n {error && <FormHelperText>{error}</FormHelperText>}\n </FormControl>\n );\n};\n\ninterface IMultipleTableSelect extends Omit<IEssentialRenderFnProps, \"value\"> {\n selectOptions: { [key: string]: ReactChild };\n value: string[];\n renderValue?: (value: any) => ReactNode;\n}\n\nexport const TableMultipleSelect: React.FC<IMultipleTableSelect> = ({\n error,\n value,\n onBlur,\n onChange,\n selectOptions,\n disabled,\n renderValue,\n}) => {\n const classes = useDefaultTableCellsStyles({});\n return (\n <FormControl margin=\"none\" error={!!error}>\n <Select\n className={`${classes.body2Text} ${classes.modifiedUnderline}`}\n inputProps={{ className: classes.selectFocusBackground }}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n disabled={disabled}\n renderValue={renderValue}\n multiple={true}\n >\n {Object.entries(selectOptions).map(([key, value]) => (\n <MenuItem className={classes.body2Text} key={key} value={key}>\n {value}\n </MenuItem>\n ))}\n </Select>\n {error && <FormHelperText>{error}</FormHelperText>}\n </FormControl>\n );\n};\n","import React, {\n FC,\n forwardRef,\n Fragment,\n memo,\n useCallback,\n useEffect,\n useState,\n} from \"react\";\nimport {\n useTable,\n useRowSelect,\n useFilters,\n CellProps,\n HeaderProps,\n HeaderGroup,\n usePagination,\n useGlobalFilter,\n useAsyncDebounce,\n} from \"react-table\";\nimport {\n Table as MUITable,\n TableBody,\n TableCell,\n TableHead,\n TableRow,\n makeStyles,\n Typography,\n Box,\n Tooltip,\n InputBase,\n} from \"@material-ui/core\";\nimport SearchIcon from \"@material-ui/icons/Search\";\nimport { EDITED_STATUS, NEW_STATUS } from \"../globals\";\nimport { SelectionCheckbox, tableTextField } from \"./defaultCells\";\nimport { didCellValueChange } from \"../utils\";\nimport {\n IEditableTableProps,\n RowData,\n ExtendedCellProps,\n TableCellValues,\n ITableContentProps,\n IGlobalFilterProps,\n} from \"./EditableTable.types\";\nimport LoadingSpinner from \"../LoadingSpinner/LoadingSpinner\";\nimport { Pagination } from \"@material-ui/lab\";\nimport { useLayoutStyles, useSpacingStyles } from \"../styles\";\nimport { useVirtual } from \"react-virtual\";\n\nconst useStyles = makeStyles((theme) => ({\n newRowHighlight: {\n backgroundColor: \"#73c4ca30\",\n },\n editedCellHighlight: {\n backgroundColor: \"#5840f52e\",\n backgroundClip: \"padding-box\",\n },\n editedBorder: {\n border: \"3px solid #5840f52e\",\n borderWidth: \"2px 4px\",\n },\n errorBorder: {\n border: `3px solid ${theme.palette.error.light}`,\n borderWidth: \"2px 4px\",\n },\n emptyLoadingPadding: {\n paddingTop: \"0.75rem\",\n paddingBottom: \"0.75rem\",\n },\n centeredText: {\n textAlign: \"center\",\n },\n disabled: {\n backgroundColor: theme.palette.action.hover,\n },\n pagination: {\n marginTop: \"1rem\",\n marginBottom: \"1rem\",\n },\n virtualisationContainer: {\n maxHeight: \"500px\",\n overflow: \"auto\",\n },\n}));\n\nconst EditableCell: FC<ExtendedCellProps> = ({\n value: initialValue = \"\",\n row: { index, values, original },\n column: { id },\n syncCellWithState,\n setRows,\n fieldConfig,\n disabled,\n}) => {\n const {\n validationRule,\n dependentValidationRule,\n isCheckbox,\n isDateField,\n customRenderFn,\n prefix,\n suffix,\n textAlign,\n onBlur: configOnBlur,\n onChangeValueModifier,\n } = fieldConfig[id];\n const [error, setError] = useState<false | string>(false);\n // We need to keep and update the state of the cell normally\n const [value, setValue] = useState<TableCellValues>(initialValue);\n const checkbox = isCheckbox;\n\n const validateValue = (value: TableCellValues) => {\n let returnValue = false;\n if (validationRule) {\n try {\n validationRule.validateSync(value);\n if (error) setError(false);\n } catch (e) {\n returnValue = true;\n !error && setError(e.message);\n }\n }\n if (dependentValidationRule) {\n try {\n dependentValidationRule(values).validateSync(value);\n if (error) setError(false);\n } catch (e) {\n returnValue = true;\n !error && setError(e.message);\n }\n }\n return returnValue;\n };\n\n // We'll only update the external data when the input is blurred\n const onBlur = async (fieldValue: TableCellValues) => {\n if (checkbox) {\n syncCellWithState(index, id, fieldValue, false);\n } else syncCellWithState(index, id, value, !!error);\n if (\n configOnBlur &&\n setRows &&\n !error &&\n !didCellValueChange(values[id], value, isDateField)\n ) {\n await configOnBlur!({\n rowIndex: index,\n value: value as string,\n setRows,\n values: original,\n });\n }\n };\n\n const onChange = (e: string | React.ChangeEvent<HTMLInputElement>) => {\n let event;\n if (isDateField) {\n event = e as string;\n const adjustedDateValue = onChangeValueModifier\n ? onChangeValueModifier(event)\n : event;\n setValue(adjustedDateValue);\n validateValue(adjustedDateValue);\n return;\n }\n event = e as React.ChangeEvent<HTMLInputElement>;\n const eventValue = checkbox ? event.target.checked : event.target.value;\n\n if (checkbox) {\n setValue(eventValue);\n onBlur(eventValue);\n } else {\n setValue(eventValue);\n validateValue(eventValue);\n }\n };\n\n // If the initialValue is changed external, sync it up with our state\n useEffect(() => {\n setValue(initialValue);\n const errorStatus = validateValue(initialValue);\n if (error !== errorStatus) {\n syncCellWithState(index, id, initialValue, errorStatus, true);\n }\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [initialValue]);\n\n useEffect(() => {\n if (original.errors && !!original.errors[id] !== !!error) {\n validateValue(initialValue);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [original.errors]);\n\n const renderFnProps = {\n value,\n values,\n disabled: disabled || original.disabledRow,\n error,\n onChange,\n onBlur,\n prefix,\n suffix,\n textAlign,\n originalValues: original,\n };\n\n if (customRenderFn) {\n return customRenderFn(renderFnProps);\n } else return tableTextField(renderFnProps);\n};\n\ninterface ITableRowContentsProps {\n row: RowData;\n classes: ReturnType<typeof useStyles>;\n disabled: boolean;\n includeRowSelect: boolean;\n}\n\nconst TableRowContents = forwardRef<HTMLTableRowElement, ITableRowContentsProps>(\n ({ row, classes, disabled, includeRowSelect, ...rest }, ref) => (\n <TableRow\n {...rest}\n ref={ref}\n hover={true}\n className={`${\n row.original.rowStatus === NEW_STATUS ? classes.newRowHighlight : \"\"\n } ${row.original.rowStatus === EDITED_STATUS ? classes.editedBorder : \"\"}\n${Object.values(row.original.errors || {}).includes(true) ? classes.errorBorder : \"\"} ${\n row.original.disabledRow || disabled ? classes.disabled : \"\"\n }`}\n >\n {row.cells.map((cell: any, n: number) => (\n <TableCell\n {...cell.getCellProps()}\n //@ts-ignore FIX REQUIRED incorrect use of react table props\n align={cell.column.textAlign || \"center\"}\n className={\n cell.row.original.rowStatus === EDITED_STATUS &&\n cell.row.original.edited[cell.column.id]\n ? classes.editedCellHighlight\n : \"\"\n }\n padding={includeRowSelect && n === 0 ? \"checkbox\" : \"normal\"}\n >\n {cell.render(\"Cell\")}\n </TableCell>\n ))}\n </TableRow>\n )\n);\n\n// emptyRows is needed for when incoming data is null (loading state).\n// useTable requires memoised row data to be defined at all times.\nconst emptyRows: RowData[] = [];\n\nconst EditableTable: React.FC<IEditableTableProps> = memo(\n ({\n tableRows,\n tableHeaders,\n syncCellWithState,\n setRows = undefined,\n skipPageReset = false,\n fieldConfig,\n disabled = false,\n setSelectedRows,\n includeRowSelect = true,\n filterData,\n filterTypes,\n emptyTableText = \"Table is empty\",\n paginate = false,\n defaultPageSize = 50,\n virtContainerStyling,\n overscan,\n rowHeight,\n includeGlobalSearch,\n disableHeaderSelect,\n }) => {\n const classes = { ...useStyles(), ...useLayoutStyles() };\n const parentRef = React.useRef<HTMLDivElement | null>(null);\n\n // Set our editable cell renderer as the default Cell renderer\n const defaultColumn = React.useMemo(\n () => ({\n Cell: EditableCell,\n }),\n []\n );\n\n const {\n getTableProps, // props to use in table, supplied by react-table\n getTableBodyProps, // props to use in table, supplied by react-table\n headerGroups, // headers enriched with methods by react-table\n rows, // rows enriched with methods by react-table\n page, // selected slice of data subset of rows. Visible paginated data\n prepareRow, // row optimisation function that must be called when rendering rows\n state: { selectedRowIds, pageIndex }, // ids of selected rows and page index from internal table state\n state,\n setFilter, // manipulate filter criteria\n pageCount,\n gotoPage,\n preGlobalFilteredRows,\n setGlobalFilter,\n isAllRowsSelected, // used only to induce re-render in the header and update checkbox state\n selectedFlatRows, // used only to induce re-render in the rows and update checkbox state\n } = useTable<RowData>(\n {\n columns: tableHeaders,\n data: tableRows || emptyRows,\n defaultColumn, // custom cell renderer, that we defined above\n autoResetPage: paginate ? !skipPageReset : false, // value that is used internally to control page number resets\n filterTypes, // fileting config for useFilters hook\n initialState: { pageSize: paginate ? defaultPageSize : undefined }, // setting up initial state for\n\n // below are custom methods and variables that will be supplied to EditableCell\n syncCellWithState, // state function used that controls the state of table\n setRows, // similar to syncCellWithState but you can manipulate whole state\n fieldConfig, //configuration for each of the cells\n disabled,\n autoResetGlobalFilter: false,\n },\n useFilters, // plugging in useFilters hook\n useGlobalFilter, // plugging in useGlobalFilters hook\n usePagination, // plugging in usePagination hook\n useRowSelect, // plugging in useRowSelect hook\n (hooks) => {\n if (includeRowSelect) {\n hooks.visibleColumns.push((columns) => [\n // Let's make a column for selection\n {\n id: \"selection\",\n // The header can use the table's getToggleAllRowsSelectedProps method\n // to render a checkbox\n Header: ({\n getToggleAllRowsSelectedProps,\n getToggleAllPageRowsSelectedProps,\n }: HeaderProps<RowData>) =>\n !disableHeaderSelect ? (\n <SelectionCheckbox\n {...(paginate\n ? getToggleAllPageRowsSelectedProps()\n : getToggleAllRowsSelectedProps())}\n disabled={disabled}\n size=\"small\"\n />\n ) : (\n \"Select\"\n ),\n // The cell can use the individual row's getToggleRowSelectedProps method\n // to the render a checkbox\n Cell: ({ row }: CellProps<RowData>) => (\n <SelectionCheckbox\n {...row.getToggleRowSelectedProps()}\n disabled={disabled || row.original.disableSelection}\n size=\"small\"\n />\n ),\n },\n ...columns,\n ]);\n }\n }\n );\n\n /* Few resources that helped the most with virtualisation work\n * https://github.com/TanStack/virtual/issues/10\n * https://codesandbox.io/s/poc-react-virtual-table-forked-857kdi?file=/src/index.js:2037-2101\n */\n const rowVirtualizer = useVirtual({\n size: (paginate ? page : rows).length,\n parentRef,\n // amount of rows to render above and below visible rows\n overscan: overscan || 5,\n // estimated row size to determine how many rows are visible\n estimateSize: useCallback(() => rowHeight || 54, [rowHeight]),\n });\n\n const rowsToRender = paginate ? page : rows;\n\n const items = rowVirtualizer.virtualItems;\n const paddingTop = items.length > 0 ? items[0].start : 0;\n const paddingBottom =\n items.length > 0 ? rowVirtualizer.totalSize - items[items.length - 1].end : 0;\n\n const handlePageChange = useCallback(\n (event: React.ChangeEvent<unknown>, value: number) => {\n gotoPage(value - 1);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n []\n );\n\n // provide the data to filter on, if filter types is not present the default filter will be used\n useEffect(() => {\n if (filterData) {\n setFilter(filterData.filterRow, filterData.filterValues);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [filterData]);\n\n useEffect(() => {\n if (setSelectedRows) {\n setSelectedRows(Object.keys(selectedRowIds).map((id) => +id));\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [selectedRowIds]);\n\n return (\n <>\n {includeGlobalSearch ? (\n <GlobalSearch\n preGlobalFilteredRows={preGlobalFilteredRows}\n globalFilter={\n (state as unknown as { globalFilter: string | undefined }).globalFilter\n }\n setGlobalFilter={setGlobalFilter}\n />\n ) : null}\n <div\n ref={parentRef}\n className={virtContainerStyling || classes.virtualisationContainer}\n >\n <TableContent\n {...{\n disabled,\n includeRowSelect,\n getTableProps,\n headerGroups,\n getTableBodyProps,\n rowsToRender,\n prepareRow,\n paddingTop,\n paddingBottom,\n virtualRows: items,\n isAllRowsSelected,\n selectedFlatRows,\n }}\n />\n </div>\n {tableRows === null ? (\n <Box className={classes.emptyLoadingPadding}>\n <LoadingSpinner />\n </Box>\n ) : null}\n {tableRows && !tableRows.length ? (\n <Box className={`${classes.emptyLoadingPadding} ${classes.centeredText}`}>\n <Typography variant=\"body2\">{emptyTableText}</Typography>\n </Box>\n ) : null}\n {paginate && tableRows?.length ? (\n <Pagination\n className={`${classes.flexCenter} ${classes.pagination}`}\n count={pageCount}\n page={pageIndex + 1}\n onChange={handlePageChange}\n shape=\"rounded\"\n showFirstButton\n showLastButton\n />\n ) : null}\n </>\n );\n }\n);\n\nexport default EditableTable;\n\nconst useGlobalSearchStyles = makeStyles((theme) => ({\n container: {\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n border: `1px solid ${theme.palette.grey[600]}`,\n borderRadius: \"8px\",\n width: \"100%\",\n maxWidth: \"20rem\",\n marginInline: \"auto\",\n color: theme.palette.grey[600],\n \"&:hover\": {\n borderColor: theme.palette.grey[800],\n color: theme.palette.grey[800],\n },\n \"&:focus-within\": {\n borderColor: theme.palette.grey[800],\n color: theme.palette.grey[800],\n },\n },\n input: {\n width: \"100%\",\n maxWidth: \"18rem\",\n color: \"inherit\",\n ...theme.typography.body2,\n },\n}));\n\nconst GlobalSearch: React.FC<IGlobalFilterProps> = memo(\n ({ preGlobalFilteredRows, globalFilter, setGlobalFilter }) => {\n const [value, setValue] = useState(globalFilter);\n\n const classes = { ...useSpacingStyles(), ...useGlobalSearchStyles() };\n\n const onChange = useAsyncDebounce((value: string) => {\n setGlobalFilter(value || undefined);\n }, 200);\n\n const count = preGlobalFilteredRows.length;\n\n return (\n <div className={`${classes.container} ${classes.contentBreak}`}>\n <SearchIcon className={`${classes.rightSpacer1} ${classes.leftSpacer1}`} />\n\n <InputBase\n className={`${classes.input}`}\n value={value || \"\"}\n onChange={(e) => {\n setValue(e.target.value);\n onChange(e.target.value);\n }}\n placeholder={`Search ${count} records...`}\n inputProps={{ \"aria-label\": \"search\" }}\n />\n </div>\n );\n }\n);\n\nconst TableContent: FC<ITableContentProps> = memo(\n ({\n disabled,\n includeRowSelect,\n getTableProps,\n headerGroups,\n getTableBodyProps,\n rowsToRender,\n prepareRow,\n paddingTop,\n paddingBottom,\n virtualRows,\n isAllRowsSelected,\n selectedFlatRows,\n }) => {\n return (\n <MUITable {...getTableProps()} stickyHeader style={{ borderCollapse: \"collapse\" }}>\n <TableHeaderContent\n headerGroups={headerGroups}\n includeRowSelect={includeRowSelect}\n isAllRowsSelected={isAllRowsSelected}\n />\n <TableBody {...getTableBodyProps()}>\n {paddingTop > 0 && (\n <tr>\n <td style={{ height: `${paddingTop}px` }} />\n </tr>\n )}\n\n <TableRows\n {...{\n disabled,\n includeRowSelect,\n rowsToRender,\n prepareRow,\n virtualRows,\n selectedFlatRows,\n }}\n />\n\n {paddingBottom > 0 && (\n <tr>\n <td style={{ height: `${paddingBottom}px` }} />\n </tr>\n )}\n </TableBody>\n </MUITable>\n );\n }\n);\n\nconst TableHeaderContent: FC<\n Pick<ITableContentProps, \"headerGroups\" | \"includeRowSelect\" | \"isAllRowsSelected\">\n> = memo(({ headerGroups, includeRowSelect, isAllRowsSelected }) => {\n return (\n <TableHead>\n {headerGroups.map((headerGroup: HeaderGroup<RowData>) => (\n <TableRow {...headerGroup.getHeaderGroupProps()}>\n {headerGroup.headers.map((column, i) => (\n <TableCell\n {...column.getHeaderProps()}\n //@ts-ignore FIX REQUIRED incorrect use of react table props\n align={column.textAlign || \"center\"}\n padding={includeRowSelect && i === 0 ? \"checkbox\" : \"normal\"}\n >\n {column.render(\"Header\")}\n </TableCell>\n ))}\n </TableRow>\n ))}\n </TableHead>\n );\n});\n\nconst TableRows: FC<\n Pick<\n ITableContentProps,\n | \"rowsToRender\"\n | \"prepareRow\"\n | \"disabled\"\n | \"includeRowSelect\"\n | \"virtualRows\"\n | \"selectedFlatRows\"\n >\n> = memo(({ rowsToRender, virtualRows, prepareRow, ...rest }) => {\n const classes = { ...useStyles(), ...useLayoutStyles() };\n\n return (\n <>\n {virtualRows.map((virtualRow) => {\n const row = rowsToRender[virtualRow.index];\n prepareRow(row);\n return (\n <Fragment key={row.original.rowKey || row.getRowProps().key}>\n {row.original.disabledRow ? (\n //At the moment disabledRow prop is only passed on xero costs so this check is fine\n // If this changes will need to change the check to be more specific\n <Tooltip title={row.original.tooltipText || \"This row is disabled\"} arrow>\n <TableRowContents {...{ ...rest, row, classes }} />\n </Tooltip>\n ) : (\n <TableRowContents {...{ ...rest, row, classes }} />\n )}\n </Fragment>\n );\n })}\n </>\n );\n});\n","import React from \"react\";\nimport { Collapse, Button, makeStyles } from \"@material-ui/core\";\nimport { Alert as MUIAlert } from \"@material-ui/lab\";\nimport { useSpacingStyles } from \"../styles\";\nimport { BORDER_RADIUS, FORM_ERROR, FORM_SUCCESS, FORM_WARNING } from \"../globals\";\nimport { IAlertProps } from \"./Alert.types\";\n\nconst useAlertStyles = makeStyles((theme) => ({\n alertStyling: {\n borderRadius: BORDER_RADIUS,\n },\n closeButton: {\n color: theme.palette.text.secondary,\n marginRight: theme.spacing(2),\n },\n showCursor: {\n cursor: \"pointer\",\n },\n}));\n\nconst Alert: React.FC<IAlertProps> = ({\n alertActionHandler,\n formStatus,\n actionButton,\n alertMessage,\n addBreak = true,\n styling,\n}) => {\n const classes = { ...useSpacingStyles(), ...useAlertStyles() };\n return (\n <Collapse in={[FORM_SUCCESS, FORM_ERROR, FORM_WARNING].includes(formStatus)}>\n <MUIAlert\n onClick={alertActionHandler}\n className={`${classes.alertStyling} ${addBreak ? classes.sectionBreak : \"\"} ${\n styling || \"\"\n } ${alertActionHandler ? classes.showCursor : \"\"}`}\n severity={\n formStatus === FORM_ERROR\n ? FORM_ERROR\n : formStatus === FORM_SUCCESS\n ? FORM_SUCCESS\n : FORM_WARNING\n }\n action={\n actionButton ? (\n <Button\n className={classes.closeButton}\n aria-label=\"close\"\n color=\"inherit\"\n size=\"small\"\n onClick={(event) => {\n event.stopPropagation();\n actionButton.handler();\n }}\n >\n {actionButton.text}\n </Button>\n ) : null\n }\n >\n {alertMessage}\n </MUIAlert>\n </Collapse>\n );\n};\n\nexport default Alert;\n","import {\n Box,\n makeStyles,\n IconButton,\n Typography,\n Button as MUIButton,\n CircularProgress,\n Avatar,\n} from \"@material-ui/core\";\nimport React, { useEffect, useState } from \"react\";\nimport { CloudUpload, Forward } from \"@material-ui/icons\";\nimport { useSpacingStyles } from \"../styles\";\nimport { IImageDisplayAndUploadProps } from \"./ImageDisplayAndUpload.types\";\nimport Alert from \"../Alert/Alert\";\nimport {\n BORDER_RADIUS,\n FormStatuses,\n FORM_ENABLED,\n FORM_ERROR,\n FORM_LOADING,\n FORM_SUCCESS,\n NO_ACCESS_LEVEL,\n READ_LEVEL,\n} from \"../globals\";\n\nconst useImageDisplayAndUploadStyles = makeStyles((theme) => ({\n greyBox: {\n backgroundColor: theme.palette.grey[200],\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n padding: \"1.5rem\",\n borderRadius: BORDER_RADIUS,\n position: \"relative\",\n height: \"13.25rem\",\n },\n widthLimiter: {\n width: \"100%\",\n maxWidth: \"28rem\",\n marginLeft: \"auto\",\n marginRight: \"auto\",\n },\n hiddenInput: {\n display: \"none\",\n },\n buttonColor: {\n backgroundColor: theme.palette.primary.main,\n },\n iconStyling: {\n color: theme.palette.common.white,\n fontSize: \"3rem\",\n },\n sectionBreak: {\n marginBottom: theme.spacing(3),\n },\n dropBox: {\n height: \"100%\",\n width: \"100%\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n },\n dropArrowStyling: {\n color: theme.palette.text.secondary,\n fontSize: \"3rem\",\n },\n topLeftArrow: {\n position: \"absolute\",\n top: 0,\n left: 0,\n transform: \"rotate(45deg)\",\n },\n topRightArrow: {\n position: \"absolute\",\n top: 0,\n right: 0,\n transform: \"rotate(135deg)\",\n },\n bottomLeftArrow: {\n position: \"absolute\",\n bottom: 0,\n left: 0,\n transform: \"rotate(-45deg)\",\n },\n bottomRightArrow: {\n position: \"absolute\",\n bottom: 0,\n right: 0,\n transform: \"rotate(225deg)\",\n },\n hiddenDisplay: {\n display: \"none\",\n },\n loadingCircle: {\n marginLeft: theme.spacing(1),\n },\n roundedAvatarButton: {\n borderRadius: \"100%\",\n },\n roundedAvatar: {\n width: \"16vmax\",\n height: \"16vmax\",\n maxWidth: \"13rem\",\n maxHeight: \"13rem\",\n },\n organisationImage: {\n maxWidth: \"8rem\",\n minWidth: \"5rem\",\n maxHeight: \"8rem\",\n },\n}));\n\nconst DRAG_ENTER = \"dragEnter\";\nconst INPUT = \"input\";\nconst DRAG_DROP = \"dragDrop\";\n\nconst ImageDisplayAndUpload: React.FC<IImageDisplayAndUploadProps> = ({\n id = \"image-upload\",\n url,\n roundedAvatar = false,\n handleSaveImage,\n alt,\n accessLevel,\n}) => {\n const classes = { ...useImageDisplayAndUploadStyles(), ...useSpacingStyles() };\n const [displayImage, setDisplayImage] = useState<boolean>(!!url);\n const [uploadState, setUploadState] = useState<FormStatuses | typeof DRAG_ENTER>(\n FORM_ENABLED\n );\n const [infoMessage, setInfoMessage] = useState<null | string>(null);\n\n useEffect(() => {\n if (!!url) {\n setDisplayImage(true);\n }\n }, [url]);\n\n if (accessLevel === NO_ACCESS_LEVEL) return null;\n\n let disabledProp = false;\n if (accessLevel === READ_LEVEL) disabledProp = true;\n\n const handleImageUpload = async (\n type: typeof INPUT | typeof DRAG_DROP,\n e: React.ChangeEvent<HTMLInputElement> | React.DragEvent<HTMLElement>\n ) => {\n if (disabledProp) return;\n setInfoMessage(null);\n if (type === INPUT) {\n const target = (e as React.ChangeEvent<HTMLInputElement>).target;\n if (target.files && target.files[0]) {\n await imageUpload(target.files[0]);\n } else {\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n }\n } else if (type === DRAG_DROP) {\n const dataTransfer = (e as React.DragEvent<HTMLElement>).dataTransfer;\n if (dataTransfer.files && dataTransfer.files[0]) {\n await imageUpload(dataTransfer.files[0]);\n } else {\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n }\n }\n };\n\n const imageUpload = async (file: File) => {\n setUploadState(FORM_LOADING);\n if (file.size >= 1024 * 1024 * 0.5) {\n setInfoMessage(\"Image size should be less than 0.5MB\");\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n return;\n }\n const format = file.name.split(\".\")[1].toLowerCase();\n\n if (![\"png\", \"jpg\", \"jpeg\"].includes(format)) {\n setInfoMessage(\"Please provide an image in png, jpg or jpeg format\");\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n\n return;\n }\n const buffer = await file.arrayBuffer();\n try {\n await handleSaveImage(format, buffer, file);\n setUploadState(FORM_SUCCESS);\n setDisplayImage(true);\n } catch (e) {\n console.log(e);\n setUploadState(FORM_ERROR);\n setDisplayImage(url ? true : false);\n }\n };\n\n let htmlToDisplay;\n switch (uploadState) {\n case DRAG_ENTER:\n htmlToDisplay = (\n <Box className={classes.dropBox} style={{ pointerEvents: \"none\" }}>\n <Forward className={`${classes.dropArrowStyling} ${classes.topLeftArrow}`} />\n <Forward className={`${classes.dropArrowStyling} ${classes.topRightArrow}`} />\n <Typography variant=\"h5\" color=\"textSecondary\">\n Drop Here\n </Typography>\n <Forward className={`${classes.dropArrowStyling} ${classes.bottomLeftArrow}`} />\n <Forward\n className={`${classes.dropArrowStyling} ${classes.bottomRightArrow}`}\n />\n </Box>\n );\n break;\n\n case FORM_LOADING:\n htmlToDisplay = (\n <Box className={classes.dropBox}>\n <Typography color=\"textSecondary\">Loading...</Typography>\n <CircularProgress className={classes.loadingCircle} size={25} />\n </Box>\n );\n break;\n\n default:\n htmlToDisplay = (\n <label htmlFor={id}>\n <IconButton\n className={`${classes.buttonColor} ${classes.sectionBreak}`}\n aria-label=\"upload picture\"\n component=\"span\"\n >\n <CloudUpload className={classes.iconStyling} />\n </IconButton>\n <Typography variant=\"body2\" color=\"textSecondary\">\n Drag and drop or browse to upload your image or logo.\n </Typography>\n </label>\n );\n break;\n }\n\n return (\n <Box\n className={classes.labelBreak}\n onDragEnter={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setDisplayImage(false);\n }}\n onDragOver={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setDisplayImage(false);\n }}\n >\n {displayImage && (\n <Box className={classes.labelBreak}>\n <label htmlFor={id}>\n <MUIButton\n className={`${roundedAvatar ? classes.roundedAvatarButton : \"\"}`}\n aria-label=\"upload picture\"\n component=\"span\"\n >\n {roundedAvatar ? (\n <Avatar\n className={classes.roundedAvatar}\n src={url!}\n alt={alt || \"Profile Avatar\"}\n />\n ) : (\n <img\n className={classes.organisationImage}\n src={url!}\n alt={alt || \"Company Logo\"}\n />\n )}\n </MUIButton>\n </label>\n </Box>\n )}\n\n <Box\n className={`${classes.greyBox} ${classes.widthLimiter} ${classes.sectionBreak} ${\n displayImage ? classes.hiddenDisplay : \"\"\n }`}\n onDragEnter={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setUploadState(DRAG_ENTER);\n }}\n onDragLeave={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setUploadState(FORM_ENABLED);\n setDisplayImage(url ? true : false);\n }}\n onDragOver={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n setUploadState(DRAG_ENTER);\n }}\n onDrop={(e) => {\n if (disabledProp) return;\n e.preventDefault();\n e.stopPropagation();\n handleImageUpload(DRAG_DROP, e);\n }}\n >\n <input\n id={id}\n className={classes.hiddenInput}\n type=\"file\"\n accept=\".png, .jpg, .jpeg\"\n disabled={disabledProp}\n onChange={(e) => handleImageUpload(INPUT, e)}\n />\n\n {htmlToDisplay}\n </Box>\n\n <Box className={classes.widthLimiter}>\n <Alert\n formStatus={uploadState as FormStatuses}\n alertMessage={\n infoMessage ||\n (uploadState === FORM_SUCCESS\n ? \"Uploaded successfully!\"\n : \"Something went wrong.\")\n }\n />\n </Box>\n </Box>\n );\n};\n\nexport default ImageDisplayAndUpload;\n"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","rejected","result","done","then","__generator","body","f","y","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","v","op","TypeError","pop","push","__spreadArray","to","from","pack","ar","l","Array","slice","concat","string","trim","required","matches","FORM_SUCCESS","FORM_ERROR","FORM_WARNING","READ_LEVEL","NO_ACCESS_LEVEL","useSpacingStyles","makeStyles","labelBreak","marginBottom","contentBreak","sectionBreak","doubleSectionBreak","rightSpacer1","marginRight","rightSpacer2","leftSpacer1","marginLeft","leftSpacer2","buttonSpacing","leftRightPadding1","paddingLeft","paddingRight","leftRightPadding2","topBottomPadding1","paddingTop","paddingBottom","topBottomPadding2","classNamePrefix","index","useFontStyles","theme","boldText","fontWeight","bolderText","smallText","fontSize","warningColor","color","palette","warning","main","centerText","textAlign","useLayoutStyles","contentBox","background","borderRadius","padding","limitWidth60rem","maxWidth","limitWidth50rem","limitWidth45rem","limitWidth40rem","limitWidth35rem","limitWidth30rem","limitWidth25rem","centeredText","startAlignedText","width20","width","width49","width50","width60","width100","flexCenter","display","alignItems","justifyContent","centerJustify","leftJustify","rightJustify","useButtonStyles","submitButton","textTransform","containedText","spinnerColour","grey","Button","_a","_b","loading","children","_c","errors","_d","type","onClick","_e","disabled","_f","variant","_g","styling","_h","_j","accessLevel","rest","classes","includes","disabledProp","React","MaterialButton","className","CircularProgress","size","thickness","ContentLabel","Typography","ContentBox","limitWidth","Box","boxShadow","LoadingSpinner","text","StyledTableRow","withStyles","createStyles","root","backgroundColor","MUITableRow","ShadedTableRow","useTableCellStyles","borderBottom","borderTopLeftRadius","borderBottomLeftRadius","borderTopRightRadius","borderBottomRightRadius","head","border","borderTop","primary","borderLeft","borderRight","TableCell","align","headerColours","MUITableCell","TableRow","rowBorderSeparation","SingleCellRow","colSpan","useStaticTableStyles","adjustedCellPadding","tableStyles","borderCollapse","pointer","cursor","bottomBorder","noShading","StaticTableHeaders","memo","headers","headerCellAlignment","TableHead","map","header","key","StaticTable","rows","rowCellAlignment","paginate","itemsPerPage","useState","page","setPage","hasRowsAndPaginated","useMemo","visibleRows","setVisibleRows","handlePageChange","useCallback","event","useEffect","Table","TableBody","data","containsOnClick","undefined","row","cell","Pagination","count","Math","ceil","onChange","shape","showFirstButton","showLastButton","useStyles","logoContainer","height","logo","logoInBreadcrumb","margin","logoSpacing","spacing","flexItemsCenter","nonPrimaryBreadcrumbOffset","BreadcrumbsContainer","primaryBreadcrumbItem","common","white","zIndex","secondaryBreadcrumbItem","secondary","tertiaryBreadcrumbItem","tertiary","breadCrumbShadow","shadows","breadcrumbRightMargin","breadcrumbTextOverflow","overflow","textOverflow","activeBreadcrumb","noWrap","whiteSpace","fullBorderRadius","Breadcrumbs","content","colors","first","second","third","Link","component","RouterLink","ButtonBase","underline","link","name","container","svgContainer","button","textDecoration","orgLabel","EntityList","entities","icon","loadingMessage","emptyMessage","Grid","entity","item","xs","md","ErrorIndicator","ErrorIcon","useNavListStyles","listIcon","minWidth","mainIconSize","mainIconMarginAdjustment","marginTop","textOverflowElipsis","mainListItem","props","mainBackground","mainText","mainHover","action","hover","mainIconColor","mainIcon","activeMainIconColor","mainActiveText","subListItem","subItemBackground","subItemText","subItemHover","activeSubListItem","subItemActiveBackground","subItemActiveText","subItemActiveHover","subItemBorder","relativeWrapper","position","subItemBorderMask","top","bottom","transition","activeSubItemBorder","subItemWrapper","noYMargin","isItemActive","currentPathname","id","split","NavListItem","mainItem","subItems","config","Icon","mainItemColors","subItemColors","location","useLocation","activeMainItem","pathname","subExpanded","setSubExpanded","ListItem","dense","route","ListItemIcon","ListItemText","disableTypography","preventDefault","stopPropagation","expanded","ExpandLess","ExpandMore","Collapse","in","timeout","unmountOnExit","List","disablePadding","sortDescendingStartDateString","array","sort","a","b","startDate","replaceAll","didCellValueChange","oldVal","newVal","isDateValue","isValid","Date","getTime","useSecondaryNavStyles","secondaryNavWrapper","overflowY","overflowX","boxSizing","titleWrapper","title","titleColor","titleIcons","titleIconColor","closeButton","archivedSeparator","archivedBorder","listWrapper","SecondaryLeftNavContainer","secondaryNavItems","primaryNavItems","expandedOptions","setExpandedOptions","stylesProps","history","useHistory","navItem","view","mainItemIcon","find","field","IconButton","url","AddBoxOutlinedIcon","closeButtonSvg","CloseIcon","items","archivedItems","usePrimaryLeftNavStyles","primaryNavContainer","activeBorderColor","flexDirection","itemWrapper","itemBorder","right","activeBorder","iconWrapper","itemName","textColour","activeTextColour","activeText","lastItem","PrimaryLeftNavContainer","navigationLinks","applyActiveBackground","fieldName","path","rootRouteName","startsWith","arr","moveLastItemToBottom","hasSecondary","useLeftNavStyles","leftNavContainer","LeftNavigation","styles","navsWithSecondary","reduce","navs","nav","prev","useMainLayoutStyles","remainingHeightBox","topOffset","left","fullHeightFlexbox","relativeContainer","scrollWrapper","componentWrapper","MainLayout","sideNavigation","desktopWidth","Container","disableGutters","useDebounceEffect","effect","deps","delay","callback","setTimeout","clearTimeout","useInterval","savedCallback","useRef","current","id_1","setInterval","clearInterval","useWhyDidYouUpdate","latestProps","allKeys","keys","changesObj","forEach","changedKeys","k","filter","Boolean","isDeepEqual","isEqual","console","log","changes","values","useAlphabeticalListStyles","divider","letterHeader","listItem","topMargin","AlphabeticalList","sortFn","sortKey","buttonClick","linkTo","ItemTemplate","arrayKey","alphabetisedHeader","lastSection","showHeader","currentKey","toLowerCase","Fragment","toUpperCase","Divider","useSearchBarStyles","searchBox","alignContent","searchField","searchIcon","SearchBar","inputBackgroundColor","placeholder","disabledSearch","minQueryLength","handleOnChange","searchKeys","_k","searchInput","setSearchInput","_l","blockSearch","setBlockSearch","_m","setResult","itemIsFound","some","InputBase","target","endAdornment","InputAdornment","SearchIcon","inputField","typography","body2","labelStyles","transform","TextField","numberField","inputProps","InputProps","fixedDecimalScale","inputPropsForNumberField","MaterialTextField","inputComponent","NumberFormatField","InputLabelProps","inputRef","other","NumberFormat","getInputRef","onValueChange","thousandSeparator","decimalScale","isNumericString","useSelectStyles","scrollbarWidth","inputStyles","BORDER_RADIUS","selectedListItem","Select","selectOptions","SelectProps","select","option","MenuItem","selected","description","DatePicker","format","minDate","MuiPickersUtilsProvider","utils","DateFnsUtils","MaterialDatePicker","inputVariant","autoOk","TextFieldComponent","KeyboardDatePicker","allowKeyboardControl","useButtonWithConfirmStyles","confirmWrapper","confirmContainer","whiteText","ButtonWithConfirm","confirmView","setConfirmView","stopInterval","setStopInterval","determineWidth","valueLength","toString","floor","useDefaultTableCellsStyles","inputBase","input","startAdornment","modifiedUnderline","body2Text","dateFieldWidth","fullDateWidth","justifyStart","justifyCenter","justifyEnd","totalContainer","selectFocusBackground","TableTextField","error","onBlur","prefix","suffix","style","helperText","tableNumericStringField","tableProps","tableNumericStringFixedDecimalField","SelectionCheckbox","Checkbox","TableDatePicker","fullDate","views","tableDateField","tableInvoiceDateField","TableCheckbox","checked","tableCheckbox","NonEditableField","displayType","TableSelect","FormControl","entries","FormHelperText","TableMultipleSelect","renderValue","multiple","newRowHighlight","editedCellHighlight","backgroundClip","editedBorder","borderWidth","errorBorder","light","emptyLoadingPadding","pagination","virtualisationContainer","maxHeight","EditableCell","initialValue","original","syncCellWithState","setRows","fieldConfig","validationRule","dependentValidationRule","isCheckbox","isDateField","customRenderFn","configOnBlur","onChangeValueModifier","setError","setValue","checkbox","validateValue","returnValue","validateSync","message","fieldValue","rowIndex","errorStatus","renderFnProps","disabledRow","adjustedDateValue","eventValue","originalValues","TableRowContents","forwardRef","ref","includeRowSelect","rowStatus","cells","getCellProps","column","edited","render","emptyRows","EditableTable","tableRows","tableHeaders","skipPageReset","setSelectedRows","filterData","filterTypes","emptyTableText","defaultPageSize","virtContainerStyling","overscan","rowHeight","includeGlobalSearch","disableHeaderSelect","parentRef","defaultColumn","Cell","useTable","columns","autoResetPage","initialState","pageSize","autoResetGlobalFilter","useFilters","useGlobalFilter","usePagination","useRowSelect","hooks","visibleColumns","Header","getToggleAllRowsSelectedProps","getToggleAllPageRowsSelectedProps","getToggleRowSelectedProps","disableSelection","getTableProps","getTableBodyProps","headerGroups","prepareRow","selectedRowIds","pageIndex","state","setFilter","pageCount","gotoPage","preGlobalFilteredRows","setGlobalFilter","isAllRowsSelected","selectedFlatRows","rowVirtualizer","useVirtual","estimateSize","rowsToRender","virtualItems","start","totalSize","end","filterRow","filterValues","GlobalSearch","globalFilter","TableContent","virtualRows","useGlobalSearchStyles","marginInline","borderColor","useAsyncDebounce","MUITable","stickyHeader","TableHeaderContent","TableRows","headerGroup","getHeaderGroupProps","getHeaderProps","virtualRow","rowKey","getRowProps","Tooltip","tooltipText","arrow","useAlertStyles","alertStyling","showCursor","Alert","alertActionHandler","formStatus","actionButton","alertMessage","addBreak","MUIAlert","severity","handler","useImageDisplayAndUploadStyles","greyBox","widthLimiter","hiddenInput","buttonColor","iconStyling","dropBox","dropArrowStyling","topLeftArrow","topRightArrow","bottomLeftArrow","bottomRightArrow","hiddenDisplay","loadingCircle","roundedAvatarButton","roundedAvatar","organisationImage","ImageDisplayAndUpload","handleSaveImage","alt","displayImage","setDisplayImage","uploadState","setUploadState","infoMessage","setInfoMessage","htmlToDisplay","handleImageUpload","files","imageUpload","dataTransfer","file","arrayBuffer","buffer","e_1","pointerEvents","Forward","htmlFor","CloudUpload","onDragEnter","onDragOver","MUIButton","Avatar","src","onDragLeave","onDrop","accept"],"mappings":"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"}
|