\n )\n}\nFilterCountLabel.propTypes = {\n filters: PropTypes.array,\n clearFilters: PropTypes.func,\n hasSelectedRecord: PropTypes.bool,\n}\n\nexport default FilterCountLabel\n","import * as React from 'react'\n\nconst context = React.createContext(null)\n\nexport const { Provider } = context\n\nexport function useDiscover(props) {\n return React.useContext(context) ?? props\n}\n","import { useState } from 'react'\nimport { Button } from '@context365/button'\nimport { useFlags } from 'launchdarkly-react-client-sdk'\nimport UpgradeModal from '~/components/UpgradeModal'\nimport { Enterprise, Pro } from '~/constants/tiers'\n\nconst FilterBlurPanel = ({ blurred, children }) => {\n const [upgradeModalVisible, setUpgradeModalVisible] = useState(false)\n const { enterpriseTier } = useFlags()\n\n if (!blurred) {\n return children\n }\n return (\n
\n
\n
Search & Filters
\n
\n {enterpriseTier\n ? `Keyword search and filters are only available on the ${Pro} and ${Enterprise} tiers.`\n : `Keyword search and filters are only available on the ${Pro} tier.`}\n
\n Are you sure you want to{' '}\n {cancelText.indexOf('Meeting') === -1\n ? cancelText.toLowerCase()\n : 'cancel'}{' '}\n the {meetingType} Meeting with {company}?\n
\n \n >\n )\n )\n}\n\nReactionModal.propTypes = {\n reactions: PropTypes.array.isRequired,\n contentEntryId: PropTypes.number.isRequired,\n}\n\nexport default ReactionModal\n","import * as React from 'react'\nimport { useState } from 'react'\nimport { Badge } from '@context365/badge'\nimport { Button } from '@context365/button'\nimport { Input, Radio, RadioGroup } from '@context365/forms'\nimport {\n LightbulbOutlined,\n PsychologyOutlined,\n SearchOutlined,\n ThumbUpAltOutlined,\n} from '@context365/icons'\nimport { Tooltip } from 'antd'\nimport cx from 'classnames'\nimport { useFlags } from 'launchdarkly-react-client-sdk'\nimport filter from 'lodash/filter'\nimport find from 'lodash/find'\nimport head from 'lodash/head'\nimport map from 'lodash/map'\nimport orderBy from 'lodash/orderBy'\nimport reduce from 'lodash/reduce'\nimport moment from 'moment'\nimport qs from 'qs'\nimport { useMutation, useQuery, useQueryClient } from 'react-query'\nimport { useSelector } from 'react-redux'\nimport { Link, useHistory, useLocation, useRouteMatch } from 'react-router-dom'\nimport { useTracking } from 'react-tracking'\nimport * as api from '~/api'\nimport CardButton from '~/components/CardButton'\nimport UpgradeModal from '~/components/UpgradeModal'\nimport { HelpEmail } from '~/config'\nimport MediaTypes from '~/constants/mediaTypes'\nimport { Free } from '~/constants/tiers'\nimport { getTier, getUserCompanyContactId } from '~/selectors/auth'\nimport ContactAvatar from './ContactAvatar'\nimport ContentTemplate from './ContentTemplate'\nimport Loading from './Loading'\nimport MediaViewer from './MediaViewer'\nimport ReactionModal from './ReactionModal'\nimport './content.less'\n\nconst parserOptions = { ignoreQueryPrefix: true }\n\nconst formatDate = (date) => moment(date).format('MMMM DD, YYYY')\n\nconst reactionImages = {\n Like: ,\n Insightful: ,\n Curious: ,\n}\n\nconst Filters = ({ contentCategories }) => (\n
\n {/* list of users taken from the response */}\n {availableColleagues.map((x) => (\n \n ))}\n
\n )}\n\n {/* in case there are no colleagues, the following message is displayed instead of the interface;\n no colleagues means there's nobody else available to be invited to this meeting */}\n {availableColleagues && availableColleagues.length === 0 && (\n
\n There are no new colleagues that can be invited to this meeting\n
\n )\n}\n\nVamiChart.propTypes = {\n fundVami: PropTypes.object,\n customBenchmark: PropTypes.object,\n fundPeriod: PropTypes.number,\n width: PropTypes.number,\n}\n\nexport default VamiChart\n\nfunction getCols(data, fundPeriod) {\n return {\n x: { alias: data.xAxisLabel, mask: 'MM/YYYY', tickCount: fundPeriod },\n y: {\n alias: data.yAxisLabel,\n formatter: (val) => numeral(val).format('0,0[.]00'),\n },\n }\n}\n\nfunction getVamiData(data, customBenchmark) {\n const labelText = data[0].label\n const fund = data[0].data.map((x) => ({\n x: x.x,\n y: x.y,\n label: labelText,\n }))\n\n const fundIndex = data[1].data.map((x) => ({\n x: x.x,\n y: x.y,\n label: 'S&P500',\n }))\n let result = fund.concat(fundIndex)\n if (data[2]) {\n const altLabel = customBenchmark.benchmarkName\n const altIndex = data[2].data.map((x) => ({\n x: x.x,\n y: x.y,\n label: altLabel,\n }))\n result = result.concat(altIndex)\n }\n\n return result\n}\n","import { Button } from '@context365/button'\nimport cx from 'classnames'\nimport { Link } from 'react-router-dom'\n\nconst CardButton = ({ children, className, href, ...rest }) => {\n const as = href ? (href.startsWith('http') ? 'a' : Link) : 'div'\n const props = href\n ? href.startsWith('http')\n ? { href, ...rest }\n : { to: href, ...rest }\n : rest\n\n return (\n \n {children}\n \n )\n}\n\nexport default CardButton\n","import CardButton from './CardButton'\n\nexport default CardButton\n","import PropTypes from 'prop-types'\nimport cx from 'classnames'\n\nconst LabelField = ({ title, className, isRequired = false }) => (\n \n)\n\nLabelField.propTypes = {\n title: PropTypes.string,\n isRequired: PropTypes.bool,\n className: PropTypes.bool,\n}\n\nexport default LabelField\n","/*\n * If this array is empty, its section in the modal will be hidden. Otherwise,\n * a random item will be displayed from the list.\n */\nexport const testimonials = [\n {\n text: 'Context has provided a platform to build relationships with a wide variety of allocators and investors. It has helped us share our story and track record and raise a significant amount of capital.',\n author: 'Managing Director, Fund',\n },\n\n /* Begin test data */\n /* IMPORTANT: These are fake quotes and should not be displayed in production! */\n ...(process.env.NODE_ENV === 'development'\n ? [\n {\n text: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.',\n author: 'Chief Quotation Officer, Definitely a Real Company',\n },\n ]\n : []),\n]\n\n/*\n * If this array is empty, its section in the modal will be hidden. Otherwise,\n * an image will be displayed for each URL in the list. All images are\n * displayed at a set height and the width adjusts to maintain aspect ratio.\n */\nexport const customerLogos = [\n /* Begin test data */\n /* IMPORTANT: These images were randomly pulled from the web and should not be displayed in production! */\n ...(process.env.NODE_ENV === 'development'\n ? [\n 'https://th.bing.com/th/id/OIP.KlkBlgljE5McdSjL7aZWEAAAAA?pid=ImgDet&rs=1',\n 'https://th.bing.com/th/id/R.e730c09a7a534f5f39dc8c94a49826df?rik=fQ3qfO3ftQyJyA&pid=ImgRaw&r=0',\n 'https://th.bing.com/th/id/R.3453922e02205c646a6046aebe70b780?rik=SzBLeytKMtE5zQ&pid=ImgRaw&r=0',\n 'https://th.bing.com/th/id/R.06bb4b4f735ac95f0a65bdafc5e75599?rik=cUZLxjEeQCy%2blA&riu=http%3a%2f%2fimg2.wikia.nocookie.net%2f__cb20120822024149%2flogopedia%2fimages%2f7%2f72%2fPrudential_Financial.svg.png&ehk=Zamvr7DkgL2elZSHk1c8bwAzmZYVvZTlwXprsdFm2PM%3d&risl=&pid=ImgRaw&r=0',\n 'https://th.bing.com/th/id/OIP.HPKuc2OJ_YE760lNzRd0DAHaD3?pid=ImgDet&rs=1',\n ]\n : []),\n]\n","import { useMemo } from 'react'\nimport { CheckCircle } from '@context365/icons'\nimport cx from 'classnames'\nimport isEmpty from 'lodash/isEmpty'\nimport sample from 'lodash/sample'\nimport { customerLogos, testimonials } from './data'\n\nexport function Testimonial({ className }) {\n // useMemo to make sure the quote doesn't change if something else on the\n // page causes a re-render\n const testimonial = useMemo(() => sample(testimonials), [])\n if (!testimonial) {\n return null\n }\n\n const { text, author } = testimonial\n return (\n
\n
From Our Clients
\n
"{text}"
\n
{author}
\n
\n )\n}\n\nexport function CustomerLogos() {\n if (isEmpty(customerLogos)) {\n return null\n }\n\n return (\n
\n
\n Trusted by\n
\n
\n {customerLogos.map((url) => (\n \n ))}\n
\n
\n )\n}\n\nexport function Feature({ children }) {\n return (\n
\n \n {children}\n
\n )\n}\n","import { Button } from '@context365/button'\nimport { CheckCircle, SendOutlined } from '@context365/icons'\nimport { MarketingContactPage } from '~/config'\nimport { Free, Pro } from '~/constants/tiers'\nimport useTracking from '~/hooks/useTracking'\nimport { Testimonial } from './common'\n\nconst Feature = ({ text }) => (\n