{"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":""}