{"version":3,"file":"static/chunks/pages/compliance/market-conduct/annual-review-7756fc9ede2b744a.js","mappings":"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","sources":["webpack://_N_E/./pages/compliance/market-conduct/annual-review.js","webpack://_N_E/./src/shared/hooks/useListSearch.js","webpack://_N_E/./utils/searchContent.js","webpack://_N_E/?b2e2"],"sourcesContent":["import React from 'react';\n\nimport ListPage from '@/src/shared/components/ListPage';\nimport useListSearch from '@/src/shared/hooks/useListSearch';\n\nconst AnnualReview = () => {\n const [loading, results] = useListSearch({\n pubCode: 845,\n yearsBack: 5,\n });\n\n return (\n Documents from the last 5 years

}\n results={results}\n loading={loading}\n />\n );\n};\n\nexport default AnnualReview;\n","import { useEffect, useState } from 'react';\nimport { useSelector } from 'react-redux';\n\nimport searchContent, { generatePostData } from '@/utils/searchContent';\nimport { getPathWithParams } from '@/utils/utils';\n\n/**\n *\n * @param {object} searchOptions searchContent options. See utils/searchContent\n * @param {number|String} statecode -\n * @returns {[boolean, Array]} Search Results\n */\nexport default function useListSearch(searchOptions, statecode) {\n const searchPayload = {\n ...searchOptions,\n ...(statecode && { stateCode: statecode }),\n };\n const pathWithData = getPathWithParams({\n baseURL: process.env.NEW_API_URL,\n url: 'cms/search',\n data: generatePostData(searchPayload),\n method: 'post',\n });\n\n const cache = useSelector(\n state => JSON.parse(state?.pageLoad?.pageCaches?.[pathWithData]?.data || '{}')?.Results || []\n );\n const [results, setResults] = useState([]);\n const [loading, setLoading] = useState(false);\n const [cached, setCached] = useState(false);\n\n useEffect(() => {\n if (cache && cache.length) {\n setCached(true);\n return;\n }\n (async function mounted() {\n try {\n setLoading(true);\n const response = await searchContent(searchPayload);\n\n setResults(response.results);\n setCached(response.cached);\n setLoading(false);\n } catch (error) {\n setResults([]);\n setLoading(false);\n }\n })();\n }, []);\n\n useEffect(() => {\n if (cached) {\n (async function reMounted() {\n try {\n const response = await searchContent(searchPayload, {\n triggerLoad: false,\n serveFromCache: false,\n });\n if (JSON.stringify(response.results) !== JSON.stringify(results)) {\n // diff detected\n setResults(response.results);\n } else {\n // results are the same\n }\n setCached(false);\n } catch (error) {\n // noop\n }\n })();\n }\n }, [cached]);\n\n return [loading, results.length ? results : cache];\n}\n","import request from './axios';\nimport { DATE_RANGES_OPTION } from './dateTimeHelpers';\n\n/**\n * @typedef {object} Result\n * @property {number} SitePageId\n * @property {number} Cat1Id\n * @property {string} PageTitle\n * @property {string} DateModified - M/D/YYYY LTS\n * @property {?number} PublicationMasterCode\n * @property {string} PublicationMaster\n * @property {string} PublishDate - M/D/YYYY LTS\n * @property {string} State\n * @property {string} Subject\n * @property {string} MeetingStartDate - M/D/YYYY LTS\n * @property {string} MeetingEndDate - M/D/YYYY LTS\n * @property {?number} MeetingLocationId\n * @property {string} MeetingLocation\n * @property {string} ExecutiveSummary\n * @property {?number} IconId\n * @property {string} Icon\n */\n\n/**\n * Request for content page with ported query params from old urls.\n * Use single = true for one result, otherwise an array or results is returned.\n *\n * @param {object} options - see typedef\n * @param {number|string} options.pubCode -\n * @param {number|string} options.stateCode -\n * @param {number|string} options.statecode -\n * @param {number|string} options.yearsBack -\n * @param {number|string} options.meetingTypeId -\n * @param {string} options.sortField - viable values: [pagetitle, owner, and status]. Otherwise ignored.\n * @param {boolean} [options.single=true] -\n * @param {number|string} [cat1Id=null] - Publications -> 9996, Meetings -> 9997, News Releases -> 9998\n * @returns {Result|Array} - Result(s) -- See typedef\n */\nexport default async function fetchContent(options, axiosConfig = {}) {\n const fetchOptionsKeys = Object.keys(options);\n const onlyFetchOptions =\n fetchOptionsKeys.length === 1 && fetchOptionsKeys[0] === 'fieldOptionsToReturn';\n\n const { single = false, fieldOptionsToReturn = [] } = options;\n\n const body = generatePostData(options);\n\n try {\n let searchResponse = { data: { Results: [] } };\n if (!onlyFetchOptions) {\n searchResponse = await request({\n url: `cms/search`,\n method: 'POST',\n data: body,\n cache: true,\n cacheTime: 15,\n ...axiosConfig,\n });\n }\n const { Results, Count } = searchResponse.data;\n\n const searchOptions = {};\n if (fieldOptionsToReturn.length) {\n const optionsResponse = await request('cms/searchoptions', {\n cache: true,\n cacheTime: 60 * 24,\n ...axiosConfig,\n });\n const { FieldOptions } = optionsResponse.data;\n for (let i = 0; i < fieldOptionsToReturn.length; i += 1) {\n const foKey = fieldOptionsToReturn[i];\n searchOptions[foKey] = FieldOptions[foKey];\n }\n }\n\n if (onlyFetchOptions) return { options: searchOptions };\n\n if (!Results || (Array.isArray(Results) && !Results.length)) {\n throw new Error(\n `Page Data not found with options: ${Object.entries(options)\n .map(([key, val]) => `${key}: ${val}`)\n .join(' | ')}`\n );\n }\n\n return {\n results: single ? Results[0] : Results.filter(result => result.SitePageId !== 0),\n options: searchOptions,\n cached: searchResponse.cached,\n count: Count,\n };\n } catch (error) {\n throw new Error(\n `Catch: Page Data not found with options: ${Object.entries(options)\n .map(([key, val]) => `${key}: ${val}`)\n .join(' | ')}`\n );\n }\n}\n\nexport function generatePostData(options) {\n const {\n pubCode, // PublicationCode in Publications\n stateCode, // StateCode in States\n statecode, // StateCode in States coming from dynamic route segment prop\n yearsBack, // DayRangeCode (number of days to go back; e.g. for 5 years it would be 1825) in the DayRanges array (only one value will be expected)\n meetingTypeId, // MeetingVenueId (4 for conference, 5 for meeting, 6 for webinar) in MeetingVenues\n sortField, // pagetitle, owner, and status (otherwise it defaults to publish date)\n cat1Id = null,\n date = null,\n includeOnHomePage = null,\n dateStart = null,\n dateEnd = null,\n committees = null,\n sortOrder = null,\n pageSize = null,\n page = null,\n } = options;\n\n const _statecode = stateCode !== undefined ? stateCode : statecode;\n const _cat1Id = cat1Id !== undefined && cat1Id !== null ? cat1Id.toString().split(',') : cat1Id;\n\n return JSON.stringify({\n SearchId: null,\n PersonId: null,\n SearchDescription: null,\n FieldOptions: {\n SearchText: '',\n Page: page,\n PageSize: pageSize,\n SortOrder: sortOrder,\n LinesOfBusiness: [],\n Subjects: [],\n Publications: pubCode !== undefined ? [{ PublicationCode: pubCode }] : [],\n States: _statecode ? [{ StateCode: _statecode }] : [],\n DayRanges: yearsBack !== undefined ? [{ DayRangeCode: Number(yearsBack) * 365 }] : [],\n MeetingTypes: meetingTypeId ? [{ MeetingTypeId: meetingTypeId }] : [],\n SortField:\n sortField && ['pagetitle', 'owner', 'status', 'state', 'upcomingevents'].includes(sortField)\n ? sortField\n : null,\n ...(_cat1Id && {\n PostingTypes: _cat1Id.map(Cat1Id => ({ Cat1Id })),\n }),\n IncludeOnHomePage: includeOnHomePage,\n ...(date && {\n DateStart: dateStart,\n DateEnd: dateEnd,\n DateRanges: DATE_RANGES_OPTION,\n }),\n ...(committees && {\n Committees: committees.map(({ CommitteeCode }) => ({ CommitteeCode })),\n }),\n },\n });\n}\n","\n (window.__NEXT_P = window.__NEXT_P || []).push([\n \"/compliance/market-conduct/annual-review\",\n function () {\n return require(\"private-next-pages/compliance/market-conduct/annual-review.js\");\n }\n ]);\n if(module.hot) {\n module.hot.dispose(function () {\n window.__NEXT_P.push([\"/compliance/market-conduct/annual-review\"])\n });\n }\n "],"names":["useListSearch","pubCode","yearsBack","loading","results","title","heroContent","searchOptions","statecode","searchPayload","stateCode","pathWithData","getPathWithParams","baseURL","process","url","data","generatePostData","method","cache","useSelector","state","JSON","parse","pageLoad","pageCaches","Results","useState","setResults","setLoading","cached","setCached","useEffect","length","searchContent","response","triggerLoad","serveFromCache","stringify","fetchContent","options","axiosConfig","fetchOptionsKeys","Object","keys","onlyFetchOptions","single","fieldOptionsToReturn","body","searchResponse","request","cacheTime","Count","optionsResponse","FieldOptions","i","foKey","Array","isArray","Error","entries","map","key","val","join","filter","result","SitePageId","count","meetingTypeId","sortField","cat1Id","date","includeOnHomePage","dateStart","dateEnd","committees","sortOrder","pageSize","page","_statecode","undefined","_cat1Id","toString","split","SearchId","PersonId","SearchDescription","SearchText","Page","PageSize","SortOrder","LinesOfBusiness","Subjects","Publications","PublicationCode","States","StateCode","DayRanges","DayRangeCode","Number","MeetingTypes","MeetingTypeId","SortField","includes","PostingTypes","Cat1Id","IncludeOnHomePage","DateStart","DateEnd","DateRanges","DATE_RANGES_OPTION","Committees","CommitteeCode","window","__NEXT_P","push"],"sourceRoot":""}