{"version":3,"sources":["views/TestCategory/TestByCategoryDTO.ts","views/Checkout/Cart/CartDataRow.tsx","views/Checkout/Cart/CartHeaderRow.tsx","views/Checkout/Cart/CartContainer.tsx","views/Checkout/TotalCheckout.tsx","views/Checkout/TestInCart.tsx","../../shared/lib/utils/TestCodeRestrictions.js","views/Checkout/CheckoutContainer.tsx","views/TestCategory/TestCategoryTitle.tsx","views/Checkout/index.ts"],"names":["currencyFormatter","Intl","NumberFormat","style","currency","maximumFractionDigits","appTheme","themes","useStyles","makeStyles","tablerow","_tablerow","textAlign","Object","defineProperty","breakpoints","up","borderBottomWidth","borderBottomColor","colors","grey","borderBottomStyle","datarow","_datarow","alignItems","down","fontWeight","gap","buttonBox","width","buttonLabel","_buttonLabel","textTransform","fontFamily","fontSize","sizes","lg","horizontalRule","icon","padding","iconBox","height","backgroundColor","color","borderRadius","removeButton","powderBlue","white","float","CartDataRow","_ref","headers","cartItem","idx","removeItem","classes","react_default","a","createElement","Grid","container","key","concat","className","Hidden","xsDown","item","xs","src","alt","map","header","field","gridSize","formatter","Button","label","onClick","e","index","toNumber","currentTarget","name","isNaN","toString","smUp","_header","black","headerCell","xxxs","CartHeaderRow","capitalize","_container","marginBottom","md","sm","emptyCart","CartContainer","cart","Paper","elevation","undefined","length","Typography","variant","Fragment","Cart_CartHeaderRow","Cart_CartDataRow","margin","gridRoot","_gridRoot","justifyContent","value","paddingTop","button","deepSeaBlue","&:hover","darken","mediumBlue","buttonDisabled","darkGrey","totalBox","flexBasis","TotalCheckout","total","checkoutUrl","disabled","testsInCart","disabledReason","spacing","gridContainerSpacing","window","appConfig","features","isPriceDisabled","display","format","Tooltip","title","href","appInsights","trackEvent","localStorage","testCodesToBlockOrderingTogether","testCodesThatCanOrderTogether","testCodesWithSpecificAllowedTests","addToCart","test","JSON","parse","getItem","newCartTest","testCode","code","price","displayTestCode","push","setItem","stringify","dispatchEvent","Event","getDisabledReason","testCodes","conflictingTests","karyotypeTestCodeInCart","duplicateMessage","x","disableAddToCartReason","tags","retVal","find","karyotypeCmaTests","includes","testsCantBeOrderTogetherBlock","blockGroup","some","blockedTest","t","ct","indexOfBlockingTest","findIndex","indexOfDuplicateTc","testsInCartToBeOrderedTogether","filter","block","exclusiveTestsToBeOrderedTogether","listsOfOrderTogetherTests","list","y","forEach","listThatCanBeOrderTogether","togetherTestsInCart","cartTest","_conflictingTests","listsOfTestsToBeOrderedTogetherWithAddedTC","testsInCartThatCannotBeOrderedWithAddedTC","apply","toConsumableArray","Set","Boolean","shouldExcludeTestCode","CheckoutContainer","history","pop","document","_useState","useState","_useState2","slicedToArray","setCart","_useState3","_useState4","setCheckoutUrl","useEffect","tests","ctc","isNil","isEmpty","toLowerCase","buildOrderUrlQuery","ordersUrl","join","theme","useTheme","mobileWidth","useMediaQuery","disabledCheckoutReason","testsInCartThatNeedToBeOrderedTogether","testsInCartThatAreNotInTheTogetherList","exclusiveTest","components","hideLogin","centerStyle","TestCategoryTitle","category","ShoppingCartOutlined","flexWrap","Cart_CartContainer","cartData","assign","splice","position","bottom","marginLeft","Checkout_TotalCheckout","values","reduce","_ref2","_material_ui_core__WEBPACK_IMPORTED_MODULE_0__","__webpack_require__","_material_ui_core__WEBPACK_IMPORTED_MODULE_1__","react__WEBPACK_IMPORTED_MODULE_2__","react__WEBPACK_IMPORTED_MODULE_2___default","n","font","marginRight","Icon","r","__webpack_exports__","_CheckoutContainer__WEBPACK_IMPORTED_MODULE_0__","Checkout"],"mappings":"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","file":"static/js/8.c3497616.chunk.js","sourcesContent":["import { Category, Test, TestSummaryBriefDTO } from \"@bg/shared/lib/dal/tests\";\r\nimport { GridSize } from \"@material-ui/core\";\r\n\r\nexport const mainCategoriesHardCoded = [\r\n \"Pregnancy\",\r\n \"NICU\",\r\n \"Pediatric\",\r\n \"Oncology\",\r\n \"Reproductive\",\r\n];\r\n\r\nexport class TestByCategoryDTO {\r\n name: string;\r\n testCode: string;\r\n categories?: Category[];\r\n mainCategoryName: string;\r\n displayCategory?: string;\r\n subCategories?: string[];\r\n shortDescription?: string;\r\n cptCodes?: string; // comma separated\r\n price?: number;\r\n\r\n constructor(test: Test) {\r\n // need to add price and short description to [PlatformTestCatalog].[dbo].[Tests]\r\n this.name = test.name;\r\n this.testCode = test.code;\r\n if (test.description) {\r\n this.shortDescription = `${test.description\r\n .split(\" \")\r\n .slice(0, 14)\r\n .join(\" \")}...`;\r\n }\r\n this.cptCodes = test.cptCodes;\r\n this.mainCategoryName = \"\";\r\n if (test.categories) {\r\n this.subCategories = test.categories\r\n .map((category) => category.name)\r\n .filter((category) => !mainCategoriesHardCoded.includes(category));\r\n // assuming only one main category per test\r\n const mainCategory = test.categories.find((category) =>\r\n mainCategoriesHardCoded.includes(category.name),\r\n );\r\n this.mainCategoryName = (mainCategory && mainCategory.name) || \"\";\r\n }\r\n }\r\n}\r\n\r\nexport const currencyFormatter = new Intl.NumberFormat(\"en-US\", {\r\n style: \"currency\",\r\n currency: \"USD\",\r\n maximumFractionDigits: 0,\r\n});\r\n\r\nexport interface TestCategoryTableHeaders {\r\n field: keyof Omit<TestSummaryBriefDTO, \"tags\">;\r\n label?: string;\r\n gridSize?: GridSize;\r\n formatter?: (value: any) => string;\r\n}\r\n","import { colors, themes } from '@bg/shared/lib/theme';\r\nimport { sizes } from '@bg/shared/lib/theme/fonts';\r\nimport { Button, Grid, Hidden, makeStyles } from '@material-ui/core';\r\nimport { toNumber } from 'lodash';\r\nimport React, { FunctionComponent } from 'react';\r\n\r\nimport { CartHeader, TestInCart } from './../TestInCart';\r\n\r\nconst appTheme = themes.appTheme;\r\nconst useStyles = makeStyles({\r\n tablerow: {\r\n textAlign: \"center\",\r\n [appTheme.breakpoints.up(\"sm\")]: {\r\n borderBottomWidth: \"1px\",\r\n borderBottomColor: colors.grey,\r\n borderBottomStyle: \"solid\",\r\n },\r\n padding: \"1rem\",\r\n },\r\n datarow: {\r\n [appTheme.breakpoints.up(\"sm\")]: {\r\n alignItems: \"center\",\r\n },\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n textAlign: \"start\",\r\n fontWeight: \"bold\",\r\n // this is a bit of a hack, if we put price back we'll need to reassess this\r\n gap: \"3rem\",\r\n },\r\n },\r\n buttonBox: {\r\n width: \"100%\",\r\n },\r\n buttonLabel: {\r\n textTransform: \"capitalize\",\r\n fontFamily: \"Roboto Condensed\",\r\n [appTheme.breakpoints.up(\"sm\")]: {\r\n fontSize: sizes.lg,\r\n },\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n fontSize: \"initial\",\r\n },\r\n },\r\n horizontalRule: {\r\n width: \"100%\",\r\n },\r\n icon: { padding: \"1rem\" },\r\n iconBox: {\r\n width: \"96px\",\r\n height: \"99px\",\r\n backgroundColor: \"#C0EBFE\",\r\n color: \"#626262\",\r\n borderRadius: \"6px\",\r\n },\r\n removeButton: {\r\n color: colors.powderBlue,\r\n backgroundColor: colors.white,\r\n float: \"right\",\r\n },\r\n});\r\n\r\ninterface CartDataRowProps {\r\n headers: CartHeader[];\r\n cartItem: TestInCart;\r\n idx: number;\r\n removeItem: (index: number) => void;\r\n}\r\n\r\nconst CartDataRow: FunctionComponent<CartDataRowProps> = ({\r\n headers,\r\n cartItem,\r\n idx,\r\n removeItem,\r\n}) => {\r\n const classes = useStyles();\r\n const handleRemoveClick = (e: React.MouseEvent<HTMLButtonElement>) => {\r\n const index = toNumber(e.currentTarget.name);\r\n if (!isNaN(index)) {\r\n removeItem(index);\r\n }\r\n };\r\n\r\n return (\r\n <Grid container key={`row-${idx}`} className={classes.tablerow}>\r\n <Grid container className={classes.datarow}>\r\n <Hidden xsDown>\r\n <Grid item key={`data-${idx}-icon`} xs={3}>\r\n <div className={classes.iconBox}>\r\n <img\r\n src={\"/images/cartIcon-default.svg\"}\r\n alt=\"dna_icon\"\r\n className={classes.icon}\r\n />\r\n </div>\r\n </Grid>\r\n </Hidden>\r\n {headers.map((header) => (\r\n <Grid\r\n item\r\n key={`data-${idx}-${header.field}`}\r\n xs={header.gridSize || true}\r\n >\r\n {header.formatter\r\n ? header.formatter(cartItem[header.field])\r\n : cartItem[header.field]}\r\n </Grid>\r\n ))}\r\n </Grid>\r\n <Grid key={`remove-button-${idx}`} className={classes.buttonBox}>\r\n <Button\r\n className={classes.removeButton}\r\n classes={{ label: classes.buttonLabel }}\r\n onClick={handleRemoveClick}\r\n name={idx.toString()}\r\n >\r\n Remove\r\n </Button>\r\n </Grid>\r\n <Hidden smUp>\r\n <hr className={classes.horizontalRule} />\r\n </Hidden>\r\n </Grid>\r\n );\r\n};\r\n\r\nexport default CartDataRow;\r\n","import { colors, themes } from '@bg/shared/lib/theme';\r\nimport { sizes } from '@bg/shared/lib/theme/fonts';\r\nimport { Grid, Hidden, makeStyles } from '@material-ui/core';\r\nimport { capitalize } from 'lodash';\r\nimport React, { FunctionComponent } from 'react';\r\n\r\nimport { CartHeader } from '../TestInCart';\r\n\r\nconst appTheme = themes.appTheme;\r\nconst useStyles = makeStyles({\r\n header: {\r\n color: colors.black,\r\n padding: \"0.5rem 1rem\",\r\n [appTheme.breakpoints.up(\"sm\")]: {\r\n backgroundColor: colors.grey,\r\n fontWeight: \"bold\",\r\n textAlign: \"center\",\r\n },\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n textAlign: \"start\",\r\n gap: \"3rem\",\r\n },\r\n },\r\n headerCell: {\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n fontSize: sizes.xxxs,\r\n },\r\n },\r\n});\r\n\r\ninterface CartHeaderRowProps {\r\n headers: CartHeader[];\r\n}\r\n\r\nconst CartHeaderRow: FunctionComponent<CartHeaderRowProps> = ({ headers }) => {\r\n const classes = useStyles();\r\n return (\r\n <Grid container className={classes.header}>\r\n <Hidden xsDown>\r\n <Grid item key=\"header-icon\" xs={3} />\r\n </Hidden>\r\n {headers.map((header) => (\r\n <Grid\r\n item\r\n key={`header-${header.field}`}\r\n xs={header.gridSize || true}\r\n className={classes.headerCell}\r\n >\r\n {header.label || capitalize(header.field)}\r\n </Grid>\r\n ))}\r\n </Grid>\r\n );\r\n};\r\n\r\nexport default CartHeaderRow;\r\n","import { themes } from '@bg/shared/lib/theme';\r\nimport { sizes } from '@bg/shared/lib/theme/fonts';\r\nimport { Grid, makeStyles, Paper, Typography } from '@material-ui/core';\r\nimport React, { FunctionComponent } from 'react';\r\n\r\nimport { CartHeader, TestInCart } from '../TestInCart';\r\nimport CartDataRow from './CartDataRow';\r\nimport CartHeaderRow from './CartHeaderRow';\r\n\r\nconst appTheme = themes.appTheme;\r\nconst useStyles = makeStyles({\r\n container: {\r\n width: \"648px\",\r\n marginBottom: \"3rem\",\r\n [appTheme.breakpoints.up(\"sm\")]: {\r\n fontSize: sizes.md,\r\n },\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n fontSize: sizes.sm,\r\n },\r\n },\r\n emptyCart: {\r\n textAlign: \"center\",\r\n width: \"100%\",\r\n padding: \"2rem\",\r\n },\r\n});\r\n\r\ninterface CartContainerProps {\r\n headers: CartHeader[];\r\n cart: TestInCart[];\r\n removeItem: (index: number) => void;\r\n}\r\n\r\nconst CartContainer: FunctionComponent<CartContainerProps> = ({\r\n headers,\r\n cart,\r\n removeItem,\r\n}) => {\r\n const classes = useStyles();\r\n\r\n return (\r\n <Paper elevation={3} className={classes.container}>\r\n <Grid container>\r\n {(cart === undefined || cart.length === 0) && (\r\n <Typography variant=\"h4\" className={classes.emptyCart}>\r\n Your Cart is Empty\r\n </Typography>\r\n )}\r\n {cart.length > 0 && (\r\n <>\r\n <CartHeaderRow headers={headers} />\r\n <Grid container>\r\n {cart.map((cartItem, idx) => (\r\n <CartDataRow\r\n key={idx}\r\n headers={headers}\r\n cartItem={cartItem}\r\n idx={idx}\r\n removeItem={removeItem}\r\n />\r\n ))}\r\n </Grid>\r\n </>\r\n )}\r\n </Grid>\r\n </Paper>\r\n );\r\n};\r\n\r\nexport default CartContainer;\r\n","import { colors, themes } from \"@bg/shared/lib/theme\";\r\nimport { sizes } from \"@bg/shared/lib/theme/fonts\";\r\nimport { gridContainerSpacing } from \"@bg/shared/lib/theme/themes\";\r\nimport { Button, Grid, makeStyles, Paper, Tooltip } from \"@material-ui/core\";\r\nimport { darken } from \"@material-ui/core/styles\";\r\nimport React, { FunctionComponent } from \"react\";\r\nimport { currencyFormatter } from \"../TestCategory/TestByCategoryDTO\";\r\nimport { TestInCart, cartKey } from \"./TestInCart\";\r\nimport { appInsights } from \"../../AppInsights\";\r\n\r\nconst appTheme = themes.appTheme;\r\nconst useStyles = makeStyles({\r\n container: {\r\n height: \"fit-content\",\r\n fontSize: sizes.sm,\r\n [appTheme.breakpoints.up(\"sm\")]: {\r\n width: \"210px\",\r\n margin: \"0 3rem\",\r\n },\r\n },\r\n gridRoot: {\r\n width: \"auto\",\r\n justifyContent: \"center\",\r\n [appTheme.breakpoints.up(\"sm\")]: {\r\n margin: \"0.5rem\",\r\n },\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n padding: \"0.5rem\",\r\n },\r\n },\r\n label: { fontWeight: \"bold\" },\r\n value: {},\r\n buttonBox: {\r\n paddingTop: \"0.75rem\",\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n width: \"90%\",\r\n },\r\n },\r\n button: {\r\n backgroundColor: colors.deepSeaBlue,\r\n borderRadius: \"9px\",\r\n width: \"160px\",\r\n height: \"27px\",\r\n \"&:hover\": {\r\n backgroundColor: darken(colors.mediumBlue, 0.1),\r\n },\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n width: \"100%\",\r\n },\r\n },\r\n buttonDisabled: {\r\n backgroundColor: colors.darkGrey,\r\n },\r\n buttonLabel: {\r\n textTransform: \"capitalize\",\r\n color: colors.white,\r\n fontFamily: \"Roboto Condensed\",\r\n fontSize: sizes.sm,\r\n },\r\n totalBox: {\r\n padding: \"1rem 3rem\",\r\n [appTheme.breakpoints.down(\"sm\")]: {\r\n flexBasis: \"80%\",\r\n },\r\n },\r\n});\r\n\r\ninterface TotalCheckoutProps {\r\n total: number;\r\n checkoutUrl: string;\r\n disabled?: boolean;\r\n testsInCart?: TestInCart[];\r\n disabledReason: string;\r\n}\r\n\r\nconst TotalCheckout: FunctionComponent<TotalCheckoutProps> = ({\r\n total,\r\n checkoutUrl,\r\n disabled,\r\n testsInCart,\r\n disabledReason,\r\n}) => {\r\n const classes = useStyles();\r\n // TODO: only clear cart when req is filled out on orders\r\n // https://stackoverflow.com/questions/33957477/cross-domain-localstorage-with-javascript\r\n const handleClick = () => {\r\n appInsights.trackEvent({ name: \"moveToOrder\" }, testsInCart);\r\n localStorage.removeItem(cartKey);\r\n };\r\n\r\n return (\r\n <Paper elevation={3} className={classes.container}>\r\n <Grid\r\n container\r\n spacing={gridContainerSpacing}\r\n className={classes.gridRoot}\r\n >\r\n <Grid\r\n container\r\n item\r\n xs={12}\r\n justifyContent=\"space-between\"\r\n className={classes.totalBox}\r\n style={\r\n window.appConfig.features.isPriceDisabled ? { display: \"none\" } : {}\r\n }\r\n >\r\n <Grid className={classes.label}>Total</Grid>\r\n <Grid className={classes.value}>\r\n {currencyFormatter.format(total)}\r\n </Grid>\r\n </Grid>\r\n <Grid item className={classes.buttonBox}>\r\n <Tooltip title={disabledReason}>\r\n <span>\r\n <Button\r\n classes={{\r\n label: classes.buttonLabel,\r\n disabled: classes.buttonDisabled,\r\n }}\r\n className={classes.button}\r\n href={checkoutUrl}\r\n disabled={disabled}\r\n onClick={handleClick}\r\n >\r\n Move to Order\r\n </Button>\r\n </span>\r\n </Tooltip>\r\n </Grid>\r\n </Grid>\r\n </Paper>\r\n );\r\n};\r\n\r\nexport default TotalCheckout;\r\n","import { GridSize } from \"@material-ui/core\";\r\n\r\nexport interface TestInCart {\r\n\tname: string;\r\n\ttestCode: string;\r\n\tprice: number;\r\n\tdisplayTestCode?: string;\r\n}\r\n\r\nexport interface CartHeader {\r\n\tlabel?: string;\r\n\tfield: keyof TestInCart;\r\n\tgridSize?: GridSize;\r\n\tformatter?: (value: any) => string;\r\n}\r\n\r\nexport const cartKey = \"cart\";\r\n","export var testCodesToBlockOrderingTogether = [[\"8676\", \"8675\", \"8673\", \"8672\", \"8671\", \"8670\", \"8657\", \"8656\"], [\"1300\", \"1360\", \"1600\", \"1603\", \"1500\", \"1605\", \"1722\", \"1533\", \"1729\", \"1723\", \"1530\"], [\"1810\", \"1803\", \"1800\", \"1829\", \"1823\", \"1822\", \"1605\", \"1723\", \"1729\", \"1530\", \"1533\", \"1722\", \"1500\", \"1603\" // it seems like we don't want to restrict ordering wes and wgs tests together, just wes-wes and wgs-wgs\n], [\"1897\", \"1900\"], [\"8700\", \"8540\", \"8530\", \"8500\"], [\"6373\", \"6376\"], [\"64000\", \"64005\"]];\nexport var testCodesThatCanOrderTogether = [[\"8800\", \"8639\", \"1600\"], [\"1897\"], [\"1900\"]]; // TODO: if this list is extended to include overlapping order together blocks, the exclusion logic in catalog will need to be reworked\n\nexport var testCodesWithSpecificAllowedTests = [\"8800\", \"8639\", \"1897\", \"1900\"];","import { DefaultLayout } from \"@bg/shared/lib/components\";\r\nimport { TestSummaryBriefDTO } from \"@bg/shared/lib/dal/tests\";\r\nimport { useMediaQuery, useTheme } from \"@material-ui/core\";\r\nimport { ShoppingCartOutlined } from \"@material-ui/icons\";\r\nimport React, { FunctionComponent, useEffect, useState } from \"react\";\r\nimport { RouteComponentProps } from \"react-router-dom\";\r\nimport { appInsights } from \"../../AppInsights\";\r\nimport { currencyFormatter } from \"../TestCategory/TestByCategoryDTO\";\r\nimport TestCategoryTitle from \"../TestCategory/TestCategoryTitle\";\r\nimport CartContainer from \"./Cart/CartContainer\";\r\nimport { CartHeader, cartKey, TestInCart } from \"./TestInCart\";\r\nimport TotalCheckout from \"./TotalCheckout\";\r\nimport { isEmpty, isNil } from \"lodash\";\r\nimport {\r\n testCodesThatCanOrderTogether,\r\n testCodesToBlockOrderingTogether,\r\n testCodesWithSpecificAllowedTests,\r\n} from \"@bg/shared/lib/utils/TestCodeRestrictions\";\r\n\r\nexport const addToCart = (test: TestSummaryBriefDTO) => {\r\n const cart: TestInCart[] = JSON.parse(localStorage.getItem(cartKey) || \"[]\");\r\n const newCartTest: TestInCart = {\r\n name: test.name,\r\n testCode: test.code,\r\n price: test.price || 0,\r\n displayTestCode: test.displayTestCode,\r\n };\r\n appInsights.trackEvent({ name: \"addToCart\" }, newCartTest);\r\n cart.push(newCartTest);\r\n localStorage.setItem(cartKey, JSON.stringify(cart));\r\n window.dispatchEvent(new Event(\"storage\"));\r\n};\r\n\r\nconst shouldExcludeTestCode = (test: TestSummaryBriefDTO) => {\r\n // returning a non-empty string will disable the add to cart button and show the string in the tooltip\r\n // 1. Need to disable button for same TC (two different CTCs with same TC)\r\n // 2. Need to disable button for testCodesToBlockOrderingTogether\r\n // 3. Need to disable button if two or more TCs from testCodesThatCanOrderTogether are added as only they can be ordered together\r\n\r\n const { code, displayTestCode, tags } = test;\r\n let retVal: string | undefined = undefined;\r\n const cart: TestInCart[] = JSON.parse(localStorage.getItem(cartKey) || \"[]\");\r\n\r\n const karyotypeTestCodeInCart = cart.find((item) =>\r\n window.appConfig.karyotypeCmaTests.includes(item.testCode),\r\n );\r\n\r\n const testsCantBeOrderTogetherBlock = testCodesToBlockOrderingTogether.find(\r\n (blockGroup) =>\r\n blockGroup.some(\r\n (blockedTest) =>\r\n blockedTest === code &&\r\n blockGroup.some((t) => cart.some((ct) => ct.testCode === t)),\r\n ),\r\n );\r\n\r\n const indexOfBlockingTest = cart.findIndex(\r\n (item) =>\r\n testsCantBeOrderTogetherBlock &&\r\n testsCantBeOrderTogetherBlock.some(\r\n (blockedTest) =>\r\n item.testCode === blockedTest || item.displayTestCode === blockedTest,\r\n ),\r\n );\r\n\r\n const indexOfDuplicateTc = cart.findIndex(\r\n (item) =>\r\n item.testCode.includes(code) ||\r\n (item.displayTestCode &&\r\n displayTestCode &&\r\n item.displayTestCode.includes(displayTestCode)) ||\r\n (displayTestCode && item.testCode.includes(displayTestCode)),\r\n );\r\n\r\n const testsInCartToBeOrderedTogether = cart.filter((item) =>\r\n testCodesThatCanOrderTogether.some((block) =>\r\n block.includes(item.testCode),\r\n ),\r\n );\r\n\r\n const exclusiveTestsToBeOrderedTogether = cart.filter((item) =>\r\n testCodesThatCanOrderTogether.some(\r\n (block) =>\r\n block.includes(item.testCode) &&\r\n testCodesWithSpecificAllowedTests.includes(item.testCode),\r\n ),\r\n );\r\n\r\n const listsOfOrderTogetherTests = testCodesThatCanOrderTogether.filter(\r\n (list) =>\r\n list.some((x) =>\r\n testsInCartToBeOrderedTogether.some(\r\n (y) => y.displayTestCode === x || y.testCode === x,\r\n ),\r\n ),\r\n );\r\n\r\n let conflictingTests: string[] = [];\r\n if (indexOfDuplicateTc > -1) {\r\n conflictingTests.push(cart[indexOfDuplicateTc].testCode);\r\n }\r\n\r\n if (indexOfBlockingTest > -1) {\r\n conflictingTests.push(cart[indexOfBlockingTest].testCode);\r\n }\r\n if (\r\n testsInCartToBeOrderedTogether.length > 0 &&\r\n listsOfOrderTogetherTests.length > 0 &&\r\n exclusiveTestsToBeOrderedTogether.length > 0 &&\r\n conflictingTests.length == 0\r\n // order together tests are only blocking if one of the tests inside of the cart is an exclusive test\r\n ) {\r\n // TODO: This logic will need to be rewritten to be clearer about which tests are the actual blocking tests\r\n listsOfOrderTogetherTests.forEach((listThatCanBeOrderTogether) => {\r\n if (cart.some((x) => x.displayTestCode === code || x.testCode === code)) {\r\n conflictingTests.push(code);\r\n }\r\n const togetherTestsInCart = listThatCanBeOrderTogether.filter((test) =>\r\n testsInCartToBeOrderedTogether.some(\r\n (cartTest) =>\r\n cartTest.displayTestCode === test || cartTest.testCode === test,\r\n ),\r\n );\r\n if (!listThatCanBeOrderTogether.some((x) => x === code)) {\r\n togetherTestsInCart.forEach((x) => {\r\n conflictingTests.push(x);\r\n });\r\n }\r\n });\r\n }\r\n\r\n if (\r\n testCodesWithSpecificAllowedTests.includes(code) ||\r\n testCodesWithSpecificAllowedTests.includes(displayTestCode || \"\")\r\n ) {\r\n const listsOfTestsToBeOrderedTogetherWithAddedTC =\r\n listsOfOrderTogetherTests.filter((block) => block.includes(code));\r\n const testsInCartThatCannotBeOrderedWithAddedTC = cart.filter(\r\n (item) =>\r\n !listsOfTestsToBeOrderedTogetherWithAddedTC.some((block) =>\r\n block.includes(item.testCode),\r\n ),\r\n );\r\n conflictingTests.push(\r\n ...testsInCartThatCannotBeOrderedWithAddedTC.map((test) => test.testCode),\r\n );\r\n }\r\n\r\n conflictingTests = [...new Set(conflictingTests)];\r\n if (conflictingTests.length > 0) {\r\n retVal = getDisabledReason(\r\n [code],\r\n conflictingTests,\r\n Boolean(karyotypeTestCodeInCart),\r\n );\r\n }\r\n\r\n if (tags !== undefined && tags.includes(\"reanalysisTestCodes\")) {\r\n retVal =\r\n \"To place a reanalysis order, go to the report details page for the patient, and select Reanalyze Test there.\";\r\n }\r\n\r\n return retVal;\r\n};\r\n\r\nconst getDisabledReason = (\r\n testCodes: string[],\r\n conflictingTests: string[],\r\n karyotypeTestCodeInCart: boolean,\r\n) => {\r\n const duplicateMessage = `Test ${\r\n testCodes.length < 2\r\n ? `code ${testCodes\r\n .map((x) => {\r\n return x;\r\n })\r\n .toString()}`\r\n : `codes ${testCodes\r\n .map((x) => {\r\n return x;\r\n })\r\n .toString()}`\r\n } cannot be combined with ${\r\n conflictingTests.length > 0\r\n ? conflictingTests\r\n .map((item) => {\r\n return item;\r\n })\r\n .toString()\r\n : \"current cart\"\r\n } as they are conflicting or duplicate orders`;\r\n if (karyotypeTestCodeInCart) {\r\n return `${duplicateMessage}; please select whether a 5 cell karyotype or a complete karyotype analysis is required.`;\r\n } else {\r\n return `${duplicateMessage}.`;\r\n }\r\n};\r\n\r\nexport const disableAddToCartReason = (test: TestSummaryBriefDTO) => {\r\n return shouldExcludeTestCode(test) || \"\";\r\n};\r\n\r\nconst CheckoutContainer: FunctionComponent<RouteComponentProps> = ({\r\n history,\r\n}) => {\r\n const headers: CartHeader[] = [\r\n {\r\n field: \"name\",\r\n label: \"Test Name\",\r\n },\r\n {\r\n field: \"testCode\",\r\n label: \"Test Code\",\r\n formatter: (value: number) => value.toString(),\r\n },\r\n {\r\n field: \"price\",\r\n gridSize: 1,\r\n formatter: (value: number) =>\r\n value === undefined ? \"\" : currencyFormatter.format(value),\r\n },\r\n ];\r\n\r\n window.appConfig.features.isPriceDisabled && headers.pop();\r\n\r\n document.title = \"Checkout - Baylor Genetics\";\r\n const [cart, setCart] = useState(\r\n JSON.parse(localStorage.getItem(cartKey) || \"[]\") as TestInCart[],\r\n );\r\n const [checkoutUrl, setCheckoutUrl] = useState(\"\");\r\n\r\n useEffect(() => {\r\n localStorage.setItem(cartKey, JSON.stringify(cart));\r\n window.dispatchEvent(new Event(\"storage\"));\r\n const tests: string[] = [];\r\n\r\n const buildOrderUrlQuery = (test: TestInCart): string => {\r\n let testCode = test.testCode;\r\n let ctc = test.testCode;\r\n if (\r\n !isNil(test.displayTestCode) &&\r\n !isEmpty(test.displayTestCode) &&\r\n test.displayTestCode.toLowerCase() !== \"none\"\r\n ) {\r\n testCode = test.displayTestCode || test.testCode;\r\n }\r\n let retVal = `test=${testCode}`;\r\n if (testCode !== ctc) {\r\n retVal += `&ctc=${ctc}`;\r\n }\r\n return retVal;\r\n };\r\n\r\n cart.forEach((test) => {\r\n tests.push(buildOrderUrlQuery(test));\r\n });\r\n setCheckoutUrl(\r\n `${window.appConfig.ordersUrl}/create?${tests.join(\",\")}&new-cart=true`,\r\n );\r\n }, [cart, setCart, setCheckoutUrl]);\r\n\r\n const removeItem = (index: number) => {\r\n const cartData = Object.assign([], cart);\r\n cartData.splice(index, 1);\r\n setCart(cartData);\r\n };\r\n\r\n const theme = useTheme();\r\n const mobileWidth = useMediaQuery(theme.breakpoints.down(\"xs\"));\r\n const getCartTotal = () => {\r\n return Object.values(cart).reduce((total, { price }) => total + price, 0);\r\n };\r\n\r\n const disabledCheckoutReason = () => {\r\n if (cart.length <= 0) {\r\n return \"There are no tests in your cart.\";\r\n }\r\n\r\n const testsInCartThatNeedToBeOrderedTogether = cart.filter((item) =>\r\n testCodesThatCanOrderTogether.some(\r\n (block) =>\r\n block.includes(item.testCode) &&\r\n testCodesWithSpecificAllowedTests.includes(item.testCode),\r\n ),\r\n );\r\n\r\n const testsInCartThatAreNotInTheTogetherList = cart.filter((item) =>\r\n testCodesThatCanOrderTogether.some(\r\n (block) =>\r\n !block.includes(item.testCode) &&\r\n testsInCartThatNeedToBeOrderedTogether.some((exclusiveTest) =>\r\n block.includes(exclusiveTest.testCode),\r\n ),\r\n ),\r\n );\r\n\r\n if (\r\n testsInCartThatNeedToBeOrderedTogether.length > 0 &&\r\n testsInCartThatAreNotInTheTogetherList.length > 0\r\n ) {\r\n return getDisabledReason(\r\n testsInCartThatAreNotInTheTogetherList.map((x) => x.testCode),\r\n testsInCartThatNeedToBeOrderedTogether.map((x) => x.testCode),\r\n Boolean(\r\n cart.find((item) =>\r\n window.appConfig.karyotypeCmaTests.includes(item.testCode),\r\n ),\r\n ),\r\n );\r\n }\r\n\r\n return \"\";\r\n };\r\n\r\n const disableCheckout = () => {\r\n return Boolean(disabledCheckoutReason());\r\n };\r\n\r\n return (\r\n <>\r\n <DefaultLayout\r\n hideLogin={true}\r\n centerStyle={{\r\n backgroundColor: \"#f5fbff\",\r\n padding: \"0 1em 1em 1em\",\r\n fontFamily: \"'Roboto Condensed', 'Helvetica', 'Arial', sans-serif\",\r\n }}\r\n >\r\n <TestCategoryTitle category=\"Order\" icon={ShoppingCartOutlined} />\r\n <div style={{ display: \"flex\", flexWrap: \"wrap\" }}>\r\n <CartContainer\r\n headers={headers}\r\n cart={cart}\r\n removeItem={removeItem}\r\n />\r\n </div>\r\n <div\r\n style={\r\n mobileWidth\r\n ? {\r\n position: \"fixed\",\r\n bottom: 0,\r\n marginLeft: \"-1em\",\r\n width: \"100%\",\r\n }\r\n : {}\r\n }\r\n >\r\n <TotalCheckout\r\n total={getCartTotal()}\r\n checkoutUrl={checkoutUrl}\r\n disabled={disableCheckout()}\r\n testsInCart={cart}\r\n disabledReason={disabledCheckoutReason()}\r\n />\r\n </div>\r\n </DefaultLayout>\r\n </>\r\n );\r\n};\r\n\r\nexport default CheckoutContainer;\r\n","import { makeStyles, SvgIconProps, Typography } from \"@material-ui/core\";\r\nimport React, { ComponentType, FunctionComponent } from \"react\";\r\n\r\nconst useStyles = makeStyles({\r\n title: {\r\n padding: \"1rem\",\r\n fontFamily: \"inherit\",\r\n fontWeight: \"bold\",\r\n fontSize: \"36px\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n },\r\n icon: {\r\n font: \"inherit\",\r\n marginRight: \"0.25rem\",\r\n },\r\n});\r\n\r\ninterface TestCategoryTitleProps {\r\n category: string;\r\n icon?: ComponentType<SvgIconProps>;\r\n}\r\n\r\nconst TestCategoryTitle: FunctionComponent<TestCategoryTitleProps> = ({\r\n category,\r\n icon,\r\n}) => {\r\n const classes = useStyles();\r\n if (icon) {\r\n const Icon = icon;\r\n\r\n return (\r\n <Typography variant=\"h4\" className={classes.title}>\r\n {<Icon className={classes.icon}>{icon}</Icon>}\r\n {category}\r\n </Typography>\r\n );\r\n }\r\n return (\r\n <Typography variant=\"h4\" className={classes.title}>\r\n {category}\r\n </Typography>\r\n );\r\n};\r\n\r\nexport default TestCategoryTitle;\r\n","import Checkout from \"./CheckoutContainer\";\r\n\r\nexport default Checkout;\r\n"],"sourceRoot":""}