{"version":3,"file":"quote-portal-components.e16552f5.js","mappings":"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","sources":["webpack://@finviz/website/./js/app/backtest/utils.tsx","webpack://@finviz/website/./js/app/shared/chartLayoutConfig.ts","webpack://@finviz/website/./js/app/shared/components/Ads.tsx","webpack://@finviz/website/./js/app/shared/getInitChartConfig.ts","webpack://@finviz/website/./js/main/components/chart/CartesianGrid.tsx","webpack://@finviz/website/./js/main/components/chart/Label.tsx","webpack://@finviz/website/./js/main/components/chart/XAxis.tsx","webpack://@finviz/website/./js/main/hooks/use-check-non-idea-chart-missing-config.ts","webpack://@finviz/website/./js/main/hooks/use-window-size.tsx","webpack://@finviz/website/./js/main/modules/charts/util.ts","webpack://@finviz/website/./js/main/modules/quote/QuoteContext.tsx","webpack://@finviz/website/./js/main/modules/quote/components/QuoteChart.tsx","webpack://@finviz/website/./js/main/modules/quote/components/Portal.tsx","webpack://@finviz/website/./js/main/hooks/useToggleStaticElement.ts","webpack://@finviz/website/./js/main/modules/quote/components/Navigation/QuoteLinksWrapper.tsx","webpack://@finviz/website/./js/main/modules/quote/hooks/use-chart-timeframe-path-watch.ts","webpack://@finviz/website/./js/main/modules/quote/components/Navigation/QuoteLinkComponent.tsx","webpack://@finviz/website/./js/main/modules/quote/components/Navigation/CreateAlertLink.tsx","webpack://@finviz/website/./js/main/modules/quote/components/Navigation/SaveToPortfolioLink.tsx","webpack://@finviz/website/./js/main/modules/quote/Navigation.tsx","webpack://@finviz/website/./js/main/modules/quote/components/ComparePerformance.tsx","webpack://@finviz/website/./js/main/components/chart/ChartBox.tsx","webpack://@finviz/website/./js/main/modules/quote/components/FundFlowsChart.tsx","webpack://@finviz/website/./js/main/components/chart/utils.ts","webpack://@finviz/website/./js/main/modules/quote/components/InsiderTradingChart/constants.ts","webpack://@finviz/website/./js/main/modules/quote/components/InsiderTradingChart/InsiderVolumeBar.tsx","webpack://@finviz/website/./js/main/modules/quote/components/InsiderTradingChart/utils.tsx","webpack://@finviz/website/./js/main/modules/quote/components/InsiderTradingChart/InsiderTradingVolumeChart.tsx","webpack://@finviz/website/./js/main/modules/quote/components/InstitutionalOwnership.tsx","webpack://@finviz/website/./js/main/modules/quote/components/QuotePrice.tsx","webpack://@finviz/website/./js/main/modules/quote/components/Price/hooks.ts","webpack://@finviz/website/./js/main/modules/quote/components/Price/QuoteHeader.tsx","webpack://@finviz/website/./js/main/modules/quote/components/barChart.tsx","webpack://@finviz/website/./js/main/modules/quote/components/Statements/constants.ts","webpack://@finviz/website/./js/main/modules/quote/components/Statements/statements.tsx","webpack://@finviz/website/./js/main/modules/quote/components/StaticChartHeader.tsx","webpack://@finviz/website/./js/main/modules/quote/components/fundamentalCharts.tsx","webpack://@finviz/website/./js/main/modules/quote/etf-holdings/async-modules.ts","webpack://@finviz/website/./js/main/modules/quote/etf-holdings/index.tsx","webpack://@finviz/website/./js/main/modules/quote/PortalComponents.tsx","webpack://@finviz/website/./js/main/modules/quote/hooks/use-stock-detail-updater.tsx","webpack://@finviz/website/./js/main/modules/quote/components/QuoteSharedWrapper.tsx","webpack://@finviz/website/./js/main/modules/quote/hooks/useToggleRatings.ts","webpack://@finviz/website/./js/main/modules/quote/hooks/use-chart-layout-width-watch.ts"],"sourcesContent":["export function round(n: number, places: number = 2) {\r\n return (+(Math.round(Number(n + 'e+' + places)) + 'e-' + places)).toFixed(places)\r\n}\r\n\r\nexport const format = {\r\n totalReturn: (totalReturn: number | string) => round(Number(totalReturn) * 100) + '%',\r\n maxDrawdown: (maxDrawdown: number | string) => round(Number(maxDrawdown) * 100) + '%',\r\n sharpeRatio: (sharpeRatio: number) => round(sharpeRatio),\r\n calmarRatio: (calmarRatio: number) => round(calmarRatio),\r\n CAGR: (CAGR: number) => round(CAGR * 100) + '%',\r\n cagr: (CAGR: number) => round(CAGR * 100) + '%',\r\n volatility: (volatility: number) => round(volatility * 100) + '%',\r\n numberOfTrades: (numberOfTrades: any) => numberOfTrades,\r\n positiveDays: (positiveDays: any) => positiveDays,\r\n negativeDays: (negativeDays: any) => negativeDays,\r\n bestMonth: (bestMonth: number) => round(bestMonth * 100) + '%',\r\n worstMonth: (worstMonth: number) => round(worstMonth * 100) + '%',\r\n}\r\n\r\nexport const figureSpace = ' '\r\n\r\nexport const BACKTEST_MIN_MAX_DATES = Object.freeze({\r\n min: new Date(1996, 5, 3),\r\n max: new Date(2023, 0, 31),\r\n})\r\n","import { SpecificChartFunctionality } from '../../main/constants'\r\nimport { ChartConfigChartPaneElement, Instrument, LayoutType, ScaleType, TIMEFRAME, Theme } from '../charts-lib'\r\nimport { getParsedCookies } from './cookie'\r\n\r\ninterface PaneElementProps extends ChartConfigChartPaneElement {\r\n label?: string\r\n fromDate?: string\r\n toDate?: string\r\n min?: number\r\n tickers: string[]\r\n}\r\n\r\ninterface StaticChartConfigProps {\r\n width?: number\r\n height?: number\r\n ticker: string\r\n timeframe: TIMEFRAME\r\n paneElements: PaneElementProps[]\r\n specificChartFunctionality?: SpecificChartFunctionality\r\n colorsOverride?: Array\r\n theme?: Theme\r\n colors?: ReturnType\r\n refreshData?: boolean\r\n}\r\n\r\nexport function getStaticChartConfig({\r\n width = 800,\r\n height = 400,\r\n ticker,\r\n timeframe,\r\n paneElements,\r\n specificChartFunctionality = SpecificChartFunctionality.default,\r\n colorsOverride,\r\n theme,\r\n colors = getCustomColorsFromCookies(),\r\n refreshData = false,\r\n}: StaticChartConfigProps) {\r\n return {\r\n layout: LayoutType['1h1v'],\r\n width,\r\n height,\r\n barWidth: 1,\r\n barMargin: 0,\r\n scrollable: false,\r\n editable: false,\r\n specificChartFunctionality,\r\n colorsOverride,\r\n theme,\r\n colors,\r\n charts: [\r\n {\r\n width: 0,\r\n premarket: false,\r\n aftermarket: false,\r\n dateRange: null,\r\n height,\r\n timeframe,\r\n scale: ScaleType.Linear,\r\n ticker: ticker,\r\n leftOffset: 0,\r\n instrument: Instrument.Stock,\r\n refreshData,\r\n stretch: true,\r\n panes: [\r\n {\r\n height,\r\n elements: paneElements,\r\n },\r\n ],\r\n },\r\n ],\r\n }\r\n}\r\n\r\nexport function getCustomColorsFromCookies() {\r\n try {\r\n return JSON.parse(getParsedCookies('customColors') as string)\r\n } catch {\r\n return undefined\r\n }\r\n}\r\n","import * as React from 'react'\r\n\r\nimport * as tracking from '../tracking'\r\n\r\nexport const IC_PUBLISHER_ID = 'df0d0d52-cc7f-11e8-82a5-0abbb61c4a6a'\r\n\r\nenum AdTagName {\r\n IC_TickerInContent = 'IC_D_3x3',\r\n IC_MapsLeftRail = 'IC_D_125x125',\r\n IC_Statements = 'IC_D_300x60',\r\n IC_Groups = 'IC_D_300x250',\r\n}\r\n\r\nconst tagDefinition = {\r\n [AdTagName.IC_TickerInContent]: { placements: 3, style: { width: 970, minHeight: 250 } },\r\n [AdTagName.IC_MapsLeftRail]: { placements: 2, style: { width: 125, minHeight: 125 } },\r\n [AdTagName.IC_Statements]: { placements: 1, style: { width: 300, minHeight: 60 } },\r\n [AdTagName.IC_Groups]: { placements: 1, style: { width: 336, minHeight: 280 } },\r\n}\r\n\r\nconst hasInvestingChannelAds = tracking.getAdsProvider() === tracking.AdsProvider.InvestingChannel\r\n\r\n/**\r\n * Get create/destroy methods to control ads insertion\r\n */\r\nexport function getInvestingChannelPage() {\r\n var page: ICPageReturn\r\n\r\n function create() {\r\n try {\r\n if (hasInvestingChannelAds) {\r\n window.InvestingChannelQueue?.push(() => {\r\n let config = window['FINVIZ_IC_UAT_CONFIG'] ?? {}\r\n page = window.InvestingChannel?.UAT.Run(IC_PUBLISHER_ID, config)\r\n })\r\n }\r\n } catch (e) {\r\n console.error(e)\r\n }\r\n }\r\n\r\n function destroy() {\r\n try {\r\n if (hasInvestingChannelAds) {\r\n window.InvestingChannelQueue?.push(() => {\r\n page?.destroy()\r\n })\r\n }\r\n } catch (e) {\r\n console.error(e)\r\n }\r\n }\r\n\r\n return { create, destroy }\r\n}\r\n\r\n/**\r\n * Hook which recreates ads on deps change (SPA navigation,…)\r\n */\r\nexport function useInvestingChannelAds(deps: unknown[] = []) {\r\n React.useLayoutEffect(() => {\r\n const page = getInvestingChannelPage()\r\n\r\n page.create()\r\n\r\n return () => page.destroy()\r\n // eslint cannot statically check the dependencies and complains about it\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, deps)\r\n\r\n return hasInvestingChannelAds\r\n}\r\n\r\ninterface AdTagProps extends Omit, 'name'> {\r\n /**\r\n * Name of the ad tag\r\n */\r\n name: keyof typeof AdTagName\r\n\r\n /**\r\n * Manually set the placement position for this tag\r\n *\r\n * @default 1\r\n */\r\n position?: number\r\n\r\n /**\r\n * Additional class names for the wrapper div\r\n */\r\n className?: string\r\n}\r\n\r\nexport function AdTag({ name, position = 1, ...props }: AdTagProps) {\r\n const tagName = AdTagName[name]\r\n const tagProps = tagDefinition[tagName]\r\n const placementName = `${tagName}_${Math.min(Math.max(position, 1), tagProps.placements)}`\r\n\r\n if (!hasInvestingChannelAds) return null\r\n\r\n return
\r\n}\r\n","import { type RootChartConfigObject, Utils, convertTa } from '../charts-lib'\r\n\r\nexport function getInitChartConfig(initialConfig: RootChartConfigObject, initialTA = FinvizSettings.TA) {\r\n const config: RootChartConfigObject = JSON.parse(JSON.stringify(initialConfig))\r\n\r\n config.scrollable = false\r\n if (FinvizSettings.hasUserPremium) {\r\n config.scrollable = config.editable || !Utils.isMobile()\r\n }\r\n\r\n if (initialTA) {\r\n const COTs = FinvizSettings.COTs\r\n convertTa.mergeChartAndTAConfig(config, initialTA, COTs ? { COTs } : undefined)\r\n }\r\n\r\n return config\r\n}\r\n","import classNames from 'classnames'\r\nimport * as React from 'react'\r\nimport { CartesianGrid as RechartsCartesianGrid } from 'recharts'\r\n\r\nexport function CartesianGrid({\r\n vertical = false,\r\n ...props\r\n}: React.PropsWithoutRef>) {\r\n return (\r\n \r\n )\r\n}\r\n\r\nCartesianGrid.displayName = RechartsCartesianGrid.displayName\r\n","import classNames from 'classnames'\r\nimport * as React from 'react'\r\nimport { Label as RechartsLabel } from 'recharts'\r\n\r\nimport { CHART_ITEM_COLORS, ChartItemColorType } from './constants'\r\n\r\ninterface LabelInnerProps extends LabelProps {\r\n dx?: number\r\n dy?: number\r\n viewBox?: { x: number; y: number; width: number; height: number }\r\n color?: ChartItemColorType\r\n}\r\n\r\nfunction LabelInner({\r\n color,\r\n viewBox,\r\n dx = 0,\r\n dy = 0,\r\n angle = -90,\r\n children,\r\n ...props\r\n}: React.PropsWithChildren) {\r\n if (!viewBox) return\r\n\r\n const x = viewBox.x + viewBox.width / 2 + dx\r\n const y = viewBox.y + viewBox.height / 2 + dy\r\n\r\n return (\r\n \r\n {color && }\r\n {children}\r\n \r\n )\r\n}\r\n\r\ninterface LabelProps extends React.PropsWithoutRef> {\r\n color?: ChartItemColorType\r\n}\r\n\r\nexport function Label({ children, color, ...props }: LabelProps) {\r\n return } {...props} />\r\n}\r\n\r\nLabel.displayName = RechartsLabel.displayName\r\n","import { format } from 'date-fns'\r\nimport { XAxis as RechartsXAxis } from 'recharts'\r\n\r\nimport { getDate } from '../../../app/header/utils'\r\n\r\nexport enum DateFormat {\r\n MonthSingleChar = 'MMMMM',\r\n MonthShort = 'MMM',\r\n MonthShortDayNum = 'MMM dd',\r\n MonthShortDayNumYearFull = 'MMM dd yyyy',\r\n}\r\n\r\nconst TICK_STYLE = {\r\n fontSize: 10,\r\n fontWeight: 400, // Different from YAxis\r\n fill: '',\r\n}\r\n\r\nexport function dateAxisFormatter({\r\n value,\r\n outFormat,\r\n parseAsNY = true,\r\n breakOnYear = false,\r\n}: {\r\n value: any\r\n outFormat: string\r\n parseAsNY?: boolean\r\n breakOnYear?: boolean\r\n}) {\r\n if (!Number.isFinite(new Date(value).getTime())) return ''\r\n\r\n const date = parseAsNY ? getDate(value) : new Date(value)\r\n\r\n if (breakOnYear && date.getMonth() === 0) {\r\n if (outFormat === DateFormat.MonthSingleChar) return date.getFullYear().toString().substring(2)\r\n return date.getFullYear().toString()\r\n }\r\n\r\n return format(date, outFormat)\r\n}\r\n\r\nexport class XAxis extends RechartsXAxis {\r\n static defaultProps = {\r\n ...RechartsXAxis.defaultProps,\r\n className: 'fill-gray-500 dark:fill-gray-300',\r\n tickLine: false,\r\n axisLine: false,\r\n dy: 5,\r\n tick: TICK_STYLE,\r\n dataKey: 'date',\r\n scale: 'time',\r\n type: 'number',\r\n interval: 'equidistantPreserveStart',\r\n }\r\n}\r\n","import * as React from 'react'\r\nimport { useLocation } from 'react-router-dom'\r\n\r\nimport { decodeQueryString } from '../../app/queryString'\r\n\r\nexport function useCheckNonIdeaChartMissingConfig() {\r\n const location = useLocation()\r\n\r\n React.useEffect(() => {\r\n // Navigation (back/forward) from nonexisting idea page doesn't fully reload the page\r\n // So if we're on non idea page and have still isIdeaNotFoundPage flag we want to reload the page\r\n const { i } = decodeQueryString(location.search)\r\n if (!i && window.isIdeaNotFoundPage) {\r\n window.location.reload()\r\n }\r\n }, [location.search])\r\n}\r\n","import throttle from 'lodash.throttle'\r\nimport * as React from 'react'\r\n\r\ninterface Props {\r\n throttleWaitInMs?: number\r\n isWatching?: boolean\r\n}\r\n\r\nexport function useWindowSize({ throttleWaitInMs = 300, isWatching = true }: Props = {}) {\r\n const [size, setSize] = React.useState({\r\n clientWidth: document.documentElement.clientWidth,\r\n innerWidth: window.innerWidth,\r\n innerHeight: window.innerHeight,\r\n })\r\n\r\n React.useEffect(() => {\r\n if (!isWatching) return\r\n\r\n const handleResize = throttle(() => {\r\n setSize({\r\n clientWidth: document.documentElement.clientWidth,\r\n innerWidth: window.innerWidth,\r\n innerHeight: window.innerHeight,\r\n })\r\n }, throttleWaitInMs)\r\n\r\n window.addEventListener('resize', handleResize)\r\n\r\n return () => {\r\n handleResize.cancel()\r\n window.removeEventListener('resize', handleResize)\r\n }\r\n }, [throttleWaitInMs, isWatching])\r\n\r\n return size\r\n}\r\n","import Quote from 'finviz-charts/app/models/quote'\r\n\r\nimport { convertTa } from '../../../app/charts-lib'\r\nimport { ObjectHash } from '../../components/types'\r\nimport { getInstrumentForTicker } from '../../util'\r\n\r\nconst PADDING = 2 // Border widths\r\n\r\nexport function getChartsDimensions(chartElementId: string) {\r\n const containerElement = document.getElementById(chartElementId)\r\n\r\n const box = containerElement?.getBoundingClientRect()\r\n\r\n return {\r\n width: Math.max((box?.width ?? 0) - PADDING, 0),\r\n height: Math.max((box?.height ?? 0) - PADDING, 0),\r\n }\r\n}\r\n\r\nexport function getChartConfig(idea: any, chartElementId: string) {\r\n const chartsDimensions = getChartsDimensions(chartElementId)\r\n\r\n if (idea) {\r\n const chartConfig = Object.assign({}, FinvizChartsSettings.ideaChart, {\r\n colors: FinvizChartsSettings.colors,\r\n width: chartsDimensions.width,\r\n height: chartsDimensions.height,\r\n scrollable: true,\r\n editors: ['layout', 'settings', 'publish', 'tools'],\r\n })\r\n for (let i = 0; i < chartConfig.charts.length; i++) {\r\n if (!chartConfig.charts[i].instrument) {\r\n chartConfig.charts[i].instrument = 'stock'\r\n }\r\n }\r\n\r\n return chartConfig\r\n }\r\n\r\n return {\r\n newCharts: true,\r\n width: chartsDimensions.width,\r\n height: chartsDimensions.height,\r\n barWidth: 3,\r\n barMargin: 1,\r\n scrollable: true,\r\n alignChartsToRight: true,\r\n theme: FinvizChartsSettings.theme,\r\n colors: FinvizChartsSettings.colors,\r\n editors: ['layout', 'settings', 'publish', 'tools'],\r\n layout: FinvizChartsSettings.layout,\r\n charts: FinvizChartsSettings.tickers.map(function (ticker: string, index: number) {\r\n return {\r\n timeframe: FinvizChartsSettings.periods[index],\r\n dateRange: FinvizChartsSettings.ranges[index],\r\n scale: FinvizChartsSettings.taConfig.scale || 'linear',\r\n ticker: ticker,\r\n instrument: getInstrumentForTicker(ticker),\r\n premarket: FinvizChartsSettings.taConfig.premarket,\r\n aftermarket: FinvizChartsSettings.taConfig.aftermarket,\r\n hasChartEvents: FinvizChartsSettings.taConfig.hasChartEvents,\r\n refreshData: true,\r\n panes: convertTa.getPanes(FinvizChartsSettings.taConfig),\r\n }\r\n }),\r\n }\r\n}\r\n\r\nexport const initIdeaQuotes = (quotes: Array, ideaChart: ObjectHash) => {\r\n const hasPatterns = JSON.stringify(ideaChart).includes('patterns')\r\n\r\n for (let i = 0; i < quotes.length; i++) {\r\n const quote = quotes[i]\r\n\r\n if (quote.timeframe === 'i1' || quote.timeframe === 'i3' || quote.timeframe === 'i5' || quote.timeframe === 'i15') {\r\n if (!quote.hasOwnProperty('drawMinutesPerDay')) {\r\n quote.drawMinutesPerDay = quote.timeframe === 'i15' ? 390 : 420\r\n }\r\n\r\n if (!quote.hasOwnProperty('marketStartMinutes')) {\r\n quote.marketStartMinutes = quote.timeframe === 'i15' ? 570 : 540\r\n }\r\n\r\n if (!quote.hasOwnProperty('premarketLengthMinutes')) {\r\n quote.premarketLengthMinutes = quote.timeframe === 'i15' ? 0 : 30\r\n }\r\n\r\n if (!quote.hasOwnProperty('aftermarketLengthMinutes')) {\r\n quote.aftermarketLengthMinutes = 0\r\n }\r\n }\r\n\r\n if (!quote.hasOwnProperty('hasPatterns')) {\r\n quote.hasPatterns = hasPatterns\r\n }\r\n\r\n quote.ideaID = ideaChart.idea.id\r\n\r\n Quote.create(quote)\r\n }\r\n}\r\n","import * as React from 'react'\r\nimport { useSearchParams } from 'react-router-dom'\r\n\r\nimport { TIMEFRAME } from '../../../app/charts-lib'\r\nimport { QuoteQuery, QuoteSubview, QuoteView } from './types'\r\nimport { getQuoteSubview, getQuoteView } from './utils'\r\n\r\nexport const QuoteContext = React.createContext<{\r\n index: number\r\n ticker: string\r\n period: TIMEFRAME\r\n view: QuoteView | null\r\n subview: QuoteSubview | null\r\n}>({ index: -1, ticker: '', period: TIMEFRAME.d, view: null, subview: null })\r\n\r\nexport function QuoteContextProvider({\r\n ticker,\r\n index,\r\n children,\r\n}: React.PropsWithChildren<{ ticker: string; index: number }>) {\r\n const [query] = useSearchParams()\r\n const type = query.get(QuoteQuery.Type) as QuoteView | QuoteSubview\r\n const period = query.get(QuoteQuery.Period) as TIMEFRAME\r\n const contextValue = React.useMemo(\r\n () => ({ index, ticker, period, view: getQuoteView(type), subview: getQuoteSubview(type) }),\r\n [index, period, ticker, type]\r\n )\r\n\r\n return {children}\r\n}\r\n","import { CHART_ELEMENT_ID } from 'finviz-charts/app/constants/common'\r\nimport * as React from 'react'\r\nimport ReactDOM from 'react-dom'\r\n\r\nimport {\r\n ChartLayoutWithGlobalState,\r\n FREE_DATE_RANGES,\r\n Quote,\r\n RootChartConfigObject,\r\n Theme,\r\n} from '../../../../app/charts-lib'\r\nimport { decodeQueryString } from '../../../../app/queryString'\r\nimport { getInitChartConfig } from '../../../../app/shared/getInitChartConfig'\r\nimport { SpecificChartFunctionality, TIMEFRAME } from '../../../constants'\r\nimport { initIdeaQuotes } from '../../charts/util'\r\nimport { getChartLayoutSizeConfig, useChartLayoutWidthWatch } from '../hooks/use-chart-layout-width-watch'\r\n\r\nexport function QuoteChart({\r\n configOverride,\r\n TAOverride,\r\n}: {\r\n configOverride?: Partial\r\n TAOverride?: any\r\n}) {\r\n const chartEl = React.useRef(document.getElementById(CHART_ELEMENT_ID))\r\n useChartLayoutWidthWatch()\r\n\r\n const config = React.useMemo(() => {\r\n let chartConfig = window.globalChartConfig\r\n\r\n if (!chartConfig) return\r\n\r\n if (chartConfig.ideaQuotes) {\r\n // Load idea quote data\r\n initIdeaQuotes(chartConfig.ideaQuotes, chartConfig)\r\n } else {\r\n // Create Quote from inlined data so we don’t have to fetch it\r\n if (chartConfig.quoteData) Quote.create(chartConfig.quoteData)\r\n chartConfig = getInitChartConfig(chartConfig, TAOverride)\r\n }\r\n\r\n const { p = FinvizSettings.defaultPeriod } = decodeQueryString()\r\n const sizeConfig = getChartLayoutSizeConfig(chartConfig, p as TIMEFRAME)\r\n\r\n return {\r\n ...chartConfig,\r\n ...sizeConfig,\r\n theme: FinvizSettings.hasDarkTheme ? Theme.dark : Theme.light,\r\n specificChartFunctionality: SpecificChartFunctionality.quotePage,\r\n charts: chartConfig.charts.map((chart) => ({\r\n ...chart,\r\n dateRange:\r\n FinvizSettings.hasUserPremium || FREE_DATE_RANGES.includes(chart.dateRange ?? '') ? chart.dateRange : null,\r\n })),\r\n ...configOverride,\r\n }\r\n }, [TAOverride, configOverride])\r\n\r\n if (!config || !chartEl.current) return null\r\n\r\n return ReactDOM.createPortal(, chartEl.current)\r\n}\r\n","import * as React from 'react'\r\nimport * as ReactDOM from 'react-dom'\r\nimport { ErrorBoundary } from 'react-error-boundary'\r\n\r\nimport { useToggleStaticElements } from '../../../hooks/useToggleStaticElement'\r\nimport { QuoteContext } from '../QuoteContext'\r\n\r\ntype AnyElement = Element | Element[] | NodeListOf\r\n\r\ninterface PortalContextProps {\r\n /**\r\n * The root element this component will get rendered into\r\n */\r\n rootElement?: HTMLElement\r\n\r\n /**\r\n * Static (server rendered) element associated with this component.\r\n * Hide this element when the component gets rendered\r\n */\r\n staticElement?: HTMLElement\r\n\r\n toggleStaticElement: (isEnabled?: boolean) => void\r\n}\r\n\r\nexport const QuotePortalContext = React.createContext({\r\n rootElement: undefined,\r\n staticElement: undefined,\r\n toggleStaticElement: () => {},\r\n})\r\n\r\n/**\r\n * Portal component props\r\n */\r\ninterface QuotePortalProps {\r\n /**\r\n * Override the ticker index from context if you need to skip the first ticker\r\n */\r\n index?: number\r\n\r\n /**\r\n * Server rendered elements to replace with react components\r\n */\r\n staticElements?: AnyElement\r\n\r\n /**\r\n * Immediately replace the static element with react children.\r\n * Turn this off if the child component is suspended\r\n *\r\n * @default true (if root exists)\r\n */\r\n toggleStaticElement?: boolean\r\n\r\n /**\r\n * Elements to render the react components into\r\n */\r\n roots: AnyElement\r\n\r\n /**\r\n * Intentionally restricted to JSX element so that we don’t have to check children is valid react element\r\n */\r\n children: JSX.Element\r\n}\r\n\r\nexport function QuotePortal({ index, toggleStaticElement, staticElements, roots, children }: QuotePortalProps) {\r\n // We might need to offset the index if we want to skip the first ticker (eg. static image chart)\r\n const context = React.useContext(QuoteContext)\r\n const elementIndex = index ?? context.index\r\n\r\n // Get the root and associated static html element, get them by index if array\r\n const staticElement =\r\n staticElements instanceof NodeList || Array.isArray(staticElements) ? staticElements[elementIndex] : staticElements\r\n const rootElement = roots instanceof NodeList || Array.isArray(roots) ? roots[elementIndex] : roots\r\n\r\n /**\r\n * Set up element switching. We might want to hold off if we’re passing a suspendable component.\r\n * We can’t catch the promise here, it might have already been caught down the tree\r\n * and we want to avoid hiding the server-rendered element before the react content is ready\r\n */\r\n const [isEnabled, setIsEnabled] = React.useState(toggleStaticElement ?? (!!staticElement && !!rootElement))\r\n useToggleStaticElements(staticElement, rootElement, isEnabled)\r\n\r\n const portalContextValue = React.useMemo(\r\n () => ({\r\n // Cast here to make it easier to pass any `Element`s as props\r\n rootElement: rootElement as HTMLElement,\r\n staticElement: staticElement as HTMLElement,\r\n // A way to get notified when children get rendered, because they could be suspended and waiting for requests\r\n toggleStaticElement: (enabled?: boolean) => setIsEnabled((prevValue) => enabled ?? !prevValue),\r\n }),\r\n [rootElement, staticElement]\r\n )\r\n\r\n if (!rootElement) return null\r\n\r\n return (\r\n setIsEnabled(false)}>\r\n \r\n {ReactDOM.createPortal(children, rootElement)}\r\n \r\n \r\n )\r\n}\r\n","import * as React from 'react'\r\n\r\ntype QuerySelectorReturn = Element | null\r\ntype AnyElement = QuerySelectorReturn | QuerySelectorReturn[] | NodeListOf\r\n\r\nexport function useToggleStaticElements(elementToHide?: AnyElement, elementToShow: AnyElement = [], enabled = true) {\r\n React.useEffect(() => {\r\n if (!elementToHide) return\r\n\r\n const hideElement = (element?: QuerySelectorReturn) => element?.classList.add('hidden')\r\n const showElement = (element?: QuerySelectorReturn) => element?.classList.remove('hidden')\r\n const toggleElements = (element: AnyElement | undefined, toggleFn: typeof hideElement) => {\r\n if (element instanceof NodeList || Array.isArray(element)) {\r\n element.forEach(toggleFn)\r\n } else {\r\n toggleFn(element)\r\n }\r\n }\r\n\r\n toggleElements(elementToHide, enabled ? hideElement : showElement)\r\n toggleElements(elementToShow, enabled ? showElement : hideElement)\r\n\r\n return () => {\r\n toggleElements(elementToHide, showElement)\r\n toggleElements(elementToShow, hideElement)\r\n }\r\n }, [elementToHide, elementToShow, enabled])\r\n}\r\n","import React from 'react'\r\n\r\nimport { useChartTimeframePathWatch } from '../../hooks/use-chart-timeframe-path-watch'\r\nimport { QuotePortalContext } from '../Portal'\r\n\r\nexport type QuoteLinksContextType = ReturnType\r\n\r\nfunction getDefaultContextValue() {\r\n const urlObject = new URL(window.location.href)\r\n\r\n return {\r\n chartLayoutModel: null,\r\n location: urlObject,\r\n }\r\n}\r\n\r\nexport const QuoteLinksContext = React.createContext(getDefaultContextValue())\r\n\r\nexport function QuoteLinksWrapper({ children }: React.PropsWithChildren) {\r\n const { toggleStaticElement } = React.useContext(QuotePortalContext)\r\n const info = useChartTimeframePathWatch()\r\n\r\n React.useEffect(() => toggleStaticElement(), [toggleStaticElement])\r\n\r\n return {children}\r\n}\r\n","import { useChartModelCustomDateRangeValues } from 'finviz-charts/app/controllers/chart-controls/use-chart-model-custom-date-range-values'\r\nimport { useChartLayoutGlobalModelAsync, useModelState } from 'finviz-charts/app/lib-export'\r\n\r\nexport function useChartTimeframePathWatch() {\r\n const isPremium = window.FinvizSettings.hasUserPremium\r\n const { chartLayoutModel } = useChartLayoutGlobalModelAsync()\r\n const chartModel = useModelState(chartLayoutModel?.activeChart ?? null, {\r\n watchProperties: ['timeframe', 'dateRange'],\r\n })\r\n const { generateChartLayoutRouterPath } = useChartModelCustomDateRangeValues({\r\n chartModel,\r\n isPremium,\r\n })\r\n\r\n if (!chartModel)\r\n return {\r\n location: new URL(`${window.location.pathname}${window.location.search}`, window.location.origin),\r\n chartLayoutModel,\r\n }\r\n\r\n const location = generateChartLayoutRouterPath({\r\n ticker: chartModel?.ticker,\r\n timeframe: chartModel?.timeframe,\r\n dateRange: chartModel?.dateRange,\r\n })\r\n\r\n return { location: new URL(`${location.pathname}${location.search}`, window.location.origin), chartLayoutModel }\r\n}\r\n","import classNames from 'classnames'\r\nimport React from 'react'\r\nimport { Link, LinkProps, To } from 'react-router-dom'\r\n\r\nimport { getElitePageLink, getNavigationLinkUrl } from '../../../../util'\r\nimport { QuoteContext } from '../../QuoteContext'\r\nimport { QuoteQuery, QuoteSubview, QuoteView } from '../../types'\r\nimport { QuoteLinksContext, QuoteLinksContextType } from './QuoteLinksWrapper'\r\n\r\nconst isPremium = FinvizSettings.hasUserPremium\r\n\r\ninterface SharedNavigationLinkProps {\r\n /**\r\n * Mark as only available to elite users. When se to `true`, free users will be\r\n * redirected to elite landing when clicking the link\r\n */\r\n isEliteOnly?: boolean\r\n\r\n /**\r\n * Used together with isEliteOnly to set the correct utm campaign param\r\n */\r\n utmCampaign?: string\r\n}\r\n\r\ninterface NavigationLinkProps extends SharedNavigationLinkProps, Omit {\r\n /**\r\n * Keys to preserve from the current URL query. Runs first when manipulating the URL\r\n *\r\n * @default [Ticker, Type, Period, DateRange]\r\n */\r\n preserveQueryKeys?: Array\r\n\r\n /**\r\n * Keys to omit from the current URL query. Runs after `preserveQueryKeys`\r\n */\r\n removeQueryKeys?: Array\r\n\r\n /**\r\n * Additional values to set to the URL query after preserving/removing\r\n *\r\n * @default { Type: props.view }\r\n */\r\n additionalQueryValues?: Partial>\r\n\r\n /**\r\n * The view the component links to\r\n */\r\n view: QuoteView | QuoteSubview\r\n\r\n getLink?: never\r\n}\r\n\r\ninterface CustomNavigationLinkProps extends SharedNavigationLinkProps, Omit {\r\n view?: never\r\n preserveQueryKeys?: never\r\n removeQueryKeys?: never\r\n additionalQueryValues?: never\r\n\r\n /**\r\n * Custom function to get the link\r\n */\r\n getLink: (context: QuoteLinksContextType) => To\r\n}\r\n\r\nexport function NavigationLink({\r\n isEliteOnly,\r\n utmCampaign,\r\n view,\r\n getLink,\r\n reloadDocument = true,\r\n preserveQueryKeys = [QuoteQuery.Ticker, QuoteQuery.Type, QuoteQuery.Period, QuoteQuery.DateRange],\r\n removeQueryKeys,\r\n additionalQueryValues,\r\n ...props\r\n}: React.PropsWithChildren) {\r\n const quoteContext = React.useContext(QuoteContext)\r\n const linkContext = React.useContext(QuoteLinksContext)\r\n\r\n const linkUrl = React.useMemo(() => {\r\n if (isEliteOnly && !isPremium) return getElitePageLink(utmCampaign)\r\n if (typeof getLink === 'function') return getLink(linkContext)\r\n\r\n return getNavigationLinkUrl(\r\n linkContext.location,\r\n preserveQueryKeys,\r\n removeQueryKeys,\r\n additionalQueryValues ?? { [QuoteQuery.Type]: view }\r\n ).toString()\r\n }, [isEliteOnly, utmCampaign, getLink, linkContext, preserveQueryKeys, removeQueryKeys, additionalQueryValues, view])\r\n\r\n return (\r\n \r\n {props.children}\r\n \r\n )\r\n}\r\n","import * as React from 'react'\r\n\r\nimport { Dialog, useDialogState } from '../../../../components/dialog'\r\nimport { Spinner } from '../../../../components/spinner'\r\nimport { useAsyncModule } from '../../../../services/async-modules-utils'\r\nimport { createAlertAsyncModule } from '../../../create-alert/async-modules'\r\nimport { QuoteContext } from '../../QuoteContext'\r\nimport { NavigationLink } from './QuoteLinkComponent'\r\n\r\nexport function CreateAlertLink() {\r\n const { ticker } = React.useContext(QuoteContext)\r\n const dialog = useDialogState()\r\n const isVisible = dialog.useState('open')\r\n\r\n const [createAlertModule] = useAsyncModule({\r\n ...createAlertAsyncModule,\r\n shouldLoadModule: isVisible,\r\n })\r\n const CreateAlert = createAlertModule?.CreateAlert\r\n\r\n return (\r\n <>\r\n `/create_alert.ashx?t=${ticker}`}\r\n onClick={(e) => {\r\n if (!FinvizSettings.hasUserPremium) return\r\n window.gtag?.('event', 'click', { event_category: 'create-alert' })\r\n if (e.ctrlKey || e.metaKey) return\r\n e.preventDefault() // needed to prevent opening parent link\r\n dialog.show()\r\n }}\r\n data-testid=\"set-alert-link\"\r\n >\r\n Set Alert\r\n \r\n \r\n {CreateAlert ? (\r\n \r\n ) : (\r\n
\r\n \r\n
\r\n )}\r\n
\r\n \r\n )\r\n}\r\n","import React from 'react'\r\n\r\nimport { Dialog, useDialogState } from '../../../../components/dialog'\r\nimport { Spinner } from '../../../../components/spinner'\r\nimport { useAsyncModule } from '../../../../services/async-modules-utils'\r\nimport { saveToPortfolioAsyncModule } from '../../../save-to-portfolio/async-modules'\r\nimport { QuoteContext } from '../../QuoteContext'\r\nimport { NavigationLink } from './QuoteLinkComponent'\r\n\r\nexport function SaveToPortfolioLink() {\r\n const { ticker } = React.useContext(QuoteContext)\r\n const dialog = useDialogState()\r\n const isVisible = dialog.useState('open')\r\n\r\n const [saveToPortfolioModule] = useAsyncModule({\r\n ...saveToPortfolioAsyncModule,\r\n shouldLoadModule: isVisible,\r\n })\r\n const SaveToPortfolio = saveToPortfolioModule?.SaveToPortfolio\r\n\r\n return (\r\n <>\r\n `/save_to_portfolio.ashx?t=${ticker}`}\r\n onClick={(e) => {\r\n if (!FinvizSettings.email.length) return\r\n window.gtag?.('event', 'click', { event_category: 'save-to-portfolio' })\r\n if (e.ctrlKey || e.metaKey) return\r\n e.preventDefault() // needed to prevent opening parent link\r\n dialog.show()\r\n }}\r\n >\r\n Add to Portfolio\r\n \r\n \r\n {SaveToPortfolio ? (\r\n \r\n ) : (\r\n
\r\n \r\n
\r\n )}\r\n
\r\n \r\n )\r\n}\r\n","import * as React from 'react'\r\n\r\nimport { CreateAlertLink } from './components/Navigation/CreateAlertLink'\r\nimport { NavigationLink } from './components/Navigation/QuoteLinkComponent'\r\nimport { QuoteLinksWrapper } from './components/Navigation/QuoteLinksWrapper'\r\nimport { SaveToPortfolioLink } from './components/Navigation/SaveToPortfolioLink'\r\nimport { QuotePortalContext } from './components/Portal'\r\nimport { QuoteQuery, QuoteSubview, QuoteView } from './types'\r\n\r\nexport function QuoteNavigation() {\r\n const { rootElement } = React.useContext(QuotePortalContext)\r\n const hasShortInterest = rootElement!.dataset.shortinterest === 'true'\r\n\r\n return (\r\n \r\n \r\n
\r\n \r\n Chart\r\n Stock Detail\r\n \r\n \r\n\r\n \r\n Compare\r\n Compare Perf.\r\n \r\n \r\n\r\n {hasShortInterest && (\r\n <>\r\n Short Interest\r\n \r\n \r\n )}\r\n\r\n Financials\r\n \r\n\r\n {FinvizSettings.hasTrafficPageEnabled && (\r\n <>\r\n Traffic\r\n \r\n \r\n )}\r\n\r\n \r\n Options\r\n \r\n \r\n\r\n \r\n Filings\r\n Latest Filings\r\n \r\n \r\n\r\n \r\n \r\n\r\n \r\n
\r\n
\r\n
\r\n )\r\n}\r\n","/* global FinvizQuoteTickers */\r\nimport classnames from 'classnames'\r\nimport * as dateFns from 'date-fns'\r\nimport React, { ChangeEvent, Component, FormEvent } from 'react'\r\n\r\nimport {\r\n ChartElementType,\r\n ChartLayout,\r\n Instrument,\r\n Quote,\r\n QuoteFetchType,\r\n TIMEFRAME,\r\n Theme,\r\n Utils,\r\n} from '../../../../app/charts-lib'\r\nimport { decodeQueryString } from '../../../../app/queryString'\r\nimport { getStaticChartConfig } from '../../../../app/shared/chartLayoutConfig'\r\nimport { getSanitizedTicker } from '../../../../app/shared/ticker-sanitizer'\r\nimport { formatDateToStringUS } from '../../../../app/shared/utils'\r\nimport { DatePicker } from '../../../components/date-picker'\r\nimport { SpecificChartFunctionality } from '../../../constants'\r\n\r\nconst redesignEnabled = !!FinvizSettings.hasRedesignEnabled\r\n\r\nconst colorScaleClass = function (value: number) {\r\n if (value < 0) {\r\n return 'color-text is-negative'\r\n } else if (value > 0) {\r\n return 'color-text is-positive'\r\n }\r\n return ''\r\n}\r\n\r\nconst monthNames = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']\r\n\r\nconst arraysEqual = function (arr1: unknown[], arr2: unknown[]) {\r\n if (arr1.length !== arr2.length) {\r\n return false\r\n }\r\n for (let i = 0; i < arr1.length; i++) {\r\n if (arr1[i] !== arr2[i]) {\r\n return false\r\n }\r\n }\r\n return true\r\n}\r\n\r\ninterface ChartProps {\r\n tickers: string[]\r\n fromDay: string\r\n toDay: string\r\n}\r\n\r\nclass Chart extends Component {\r\n containerRef = React.createRef()\r\n\r\n shouldComponentUpdate(nextProps: ChartProps) {\r\n return !arraysEqual(this.props.tickers, nextProps.tickers)\r\n }\r\n\r\n render() {\r\n const theme = FinvizSettings.hasDarkTheme ? Theme.dark : Theme.light\r\n const tickerQuote = Quote.select((q) => q.close.length > 0 && this.props.tickers.includes(q.ticker))\r\n const chartConfig = getStaticChartConfig({\r\n ticker: tickerQuote[0]?.ticker ?? '',\r\n timeframe: TIMEFRAME.d,\r\n paneElements: [\r\n {\r\n type: ChartElementType.PerfChart,\r\n tickers: this.props.tickers,\r\n fromDate: this.props.fromDay,\r\n toDate: this.props.toDay,\r\n overlays: [],\r\n },\r\n ],\r\n width: 1000,\r\n height: 450,\r\n refreshData: false,\r\n specificChartFunctionality: SpecificChartFunctionality.quotePerf,\r\n theme,\r\n })\r\n return (\r\n
\r\n \r\n
\r\n )\r\n }\r\n}\r\n\r\ninterface TableProps {\r\n months: string[]\r\n rows: Array<{\r\n ticker: string\r\n months: string[]\r\n total: string\r\n }>\r\n}\r\n\r\n// mozno vyfarbovat tabulku?\r\nclass Table extends Component {\r\n render() {\r\n const { months, rows } = this.props\r\n const groupsCount = Math.ceil(months.length / 12)\r\n const tdClasses = classnames('text-center', {\r\n 'body-table-nw font-bold': !redesignEnabled,\r\n })\r\n\r\n const trs = []\r\n for (let g = 0; g < groupsCount; g++) {\r\n trs.push(\r\n \r\n \r\n {months.splice(0, 12).map((month) => (\r\n \r\n {month}\r\n \r\n ))}\r\n {g === groupsCount - 1 && Total}\r\n \r\n )\r\n rows.forEach((row, i) => {\r\n trs.push(\r\n \r\n {row.ticker}\r\n {row.months.splice(0, 12).map((col, monthIndex) => (\r\n \r\n {col}\r\n \r\n ))}\r\n {g === groupsCount - 1 && (\r\n \r\n {row.total}\r\n \r\n )}\r\n \r\n )\r\n })\r\n }\r\n\r\n return (\r\n \r\n {trs}\r\n \r\n )\r\n }\r\n}\r\n\r\ninterface PerfState {\r\n tickersInput: string\r\n tickers: string[]\r\n months: Array<{\r\n value: string\r\n label: string\r\n }>\r\n fromMonth: {\r\n value: string\r\n label: string\r\n }\r\n toMonth: {\r\n value: string\r\n label: string\r\n }\r\n minDate: string\r\n maxDate: string\r\n fromDay: string\r\n toDay: string\r\n loading: boolean\r\n}\r\n\r\nexport class Perf extends Component {\r\n constructor(props: any) {\r\n super(props)\r\n const now = new Date(),\r\n months = []\r\n const startYear = new Date().getFullYear() - 36 // We have 37.25 years of data in DB, so leaving some offset\r\n for (let year = startYear; year <= now.getFullYear(); year++) {\r\n for (let month = 1; month <= 12; month++) {\r\n if (year === now.getFullYear() && month > now.getMonth() + 1) {\r\n break\r\n }\r\n months.push({\r\n value: month.toString().padStart(2, '0') + '/01/' + year,\r\n label: monthNames[month - 1] + ' ' + year.toString().substring(2),\r\n })\r\n }\r\n }\r\n\r\n this.state = {\r\n tickersInput: FinvizQuoteTickers.join(','),\r\n tickers: FinvizQuoteTickers,\r\n months: months,\r\n fromMonth: months[months.length - 12],\r\n toMonth: months[months.length - 1],\r\n /**\r\n * DB_BARS_LIMIT - code below is dependent on amount of data we store for specific timeframes\r\n * Search DB_BARS_LIMIT in the project to find other places with such code.\r\n */\r\n // 2510 bars = ±10 years\r\n minDate: formatDateToStringUS(dateFns.sub(new Date(), { years: 9, months: 11 })),\r\n maxDate: formatDateToStringUS(new Date()),\r\n fromDay: formatDateToStringUS(dateFns.subYears(new Date(), 1)),\r\n toDay: formatDateToStringUS(new Date()),\r\n loading: true,\r\n }\r\n }\r\n\r\n render() {\r\n if (this.state.loading) {\r\n return (\r\n \r\n Loading...\r\n
\r\n )\r\n }\r\n\r\n const from = new Date(this.state.fromMonth.value)\r\n const to = new Date(this.state.toMonth.value)\r\n const monthsToShow = this.state.months\r\n .map((month) => month.value)\r\n .filter((month) => new Date(month) >= from && new Date(month) <= to)\r\n\r\n const quotes = Quote.select((q: any) => q.timeframe === 'm')\r\n const quotesPerf = quotes.map((q: any) => {\r\n const obj: { ticker: string; perf: Record } = { ticker: q.ticker, perf: {} }\r\n q.date.forEach((d: any, i: number) => {\r\n if (i === 0) {\r\n return\r\n }\r\n const date = Utils.dateFromUnixTimestamp(d)\r\n const perf = (q.close[i] * 100) / q.close[i - 1] - 100\r\n obj.perf[(date.getMonth() + 1).toString().padStart(2, '0') + '/01/' + date.getFullYear()] = perf\r\n })\r\n return obj\r\n })\r\n\r\n const months = monthsToShow.map(\r\n (month) => monthNames[new Date(month).getMonth()] + ' ' + new Date(month).getFullYear().toString().substring(2)\r\n )\r\n const rows = quotesPerf.map((quote: any) => {\r\n const cols: string[] = []\r\n let total = 1\r\n monthsToShow.forEach((month) => {\r\n const perf = Math.round(quote.perf[month] * 100) / 100\r\n if (!isNaN(perf)) {\r\n total *= quote.perf[month] / 100 + 1\r\n cols.push((perf > 0 ? '+' : '') + perf.toFixed(2) + '%')\r\n } else {\r\n cols.push('N/A')\r\n }\r\n })\r\n total = (total - 1) * 100\r\n return { ticker: quote.ticker, months: cols, total: (total > 0 ? '+' : '') + total.toFixed(2) + '%' }\r\n })\r\n\r\n return (\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
Tickers:\r\n {\r\n this.setState({ tickersInput: e.target.value })\r\n }}\r\n style={{ width: '100%' }}\r\n data-testid=\"quote-compare-perf-tickers-input\"\r\n />\r\n \r\n \r\n
\r\n
\r\n\r\n \r\n\r\n \r\n
\r\n {\r\n this._onDatePickerChange('from', formatDateToStringUS(newValue))\r\n }}\r\n >\r\n \r\n \r\n
\r\n {' - '}\r\n
\r\n {\r\n this._onDatePickerChange('to', formatDateToStringUS(newValue))\r\n }}\r\n >\r\n \r\n \r\n
\r\n \r\n\r\n

\r\n Monthly performance from  \r\n \r\n {this.state.months.map((option) => (\r\n \r\n ))}\r\n \r\n   to  \r\n \r\n {this.state.months.map((option) => (\r\n \r\n ))}\r\n \r\n

\r\n \r\n\r\n
\r\n \r\n )\r\n }\r\n\r\n refetchQuotes = () => {\r\n this._fetch(this.state.tickers, false)\r\n }\r\n\r\n componentDidMount() {\r\n this._fetch(this.state.tickers)\r\n\r\n // We have to listen to these events to synchrnously update quote data, if we do after awaiting Quote.getAll in _fetch\r\n // there's a visual glitch because it rerenders with new data from the server (there's a complete refetch after 15 requests with no new data)\r\n // and then it rerenders again after updateQuoteData\r\n Quote.bind('refetch newerData', this.updateQuoteData)\r\n document.addEventListener('quoteFetchEvent', this.refetchQuotes)\r\n }\r\n\r\n componentWillUnmount() {\r\n Quote.unbind('refetch newerData', this.updateQuoteData)\r\n document.removeEventListener('quoteFetchEvent', this.refetchQuotes)\r\n }\r\n\r\n updateQuoteData = () => {\r\n const { fromDay, toDay } = this.state\r\n\r\n if (!fromDay || !toDay) {\r\n return\r\n }\r\n\r\n const dailyQuotes = Quote.select((q: any) => q.timeframe === 'd')\r\n const fromDate = new Date(fromDay + ' 00:00')\r\n const toDate = new Date(toDay + ' 23:59')\r\n dailyQuotes.forEach((q: any) => {\r\n const o = [],\r\n h = [],\r\n l = [],\r\n c = [],\r\n d = [],\r\n v = []\r\n for (let i = 0; i < q.close.length; i++) {\r\n const date = Utils.dateFromUnixTimestamp(q.date[i])\r\n if (fromDate <= date && date <= toDate) {\r\n o.push(q.open[i])\r\n h.push(q.high[i])\r\n l.push(q.low[i])\r\n c.push(q.close[i])\r\n d.push(q.date[i])\r\n v.push(q.volume[i])\r\n }\r\n }\r\n // Clear cache so we'll recalculate values after updating quote data on next line\r\n // Cache invalidates only on quote.fetchedAt change and in this case we mutate quote values and don't change fetchedAt (which is correct)\r\n // Updating quote this way should be an edge case and that's why we have to clear the cache manually\r\n q.clearCachedData()\r\n q.updateAttributes({\r\n open: o,\r\n high: h,\r\n low: l,\r\n close: c,\r\n date: d,\r\n volume: v,\r\n })\r\n })\r\n\r\n // This is to rerender perf table on quote update\r\n this.forceUpdate()\r\n }\r\n\r\n _fetch = async (tickers: string[], isRefetch = true) => {\r\n const { t } = decodeQueryString<{ t: string; p?: TIMEFRAME }>()\r\n if (isRefetch) {\r\n this.setState({ loading: true })\r\n }\r\n\r\n Quote.all().forEach(async (quote) => {\r\n if (quote.ticker === t && quote.timeframe === 'd' && !isRefetch) {\r\n // We don't want to trigger main ticker quote newer data fetch because it's done in withQuotePolling which also triggers this function\r\n // by emmiting quoteFetchEvent\r\n return\r\n }\r\n if (tickers.includes(quote.ticker)) {\r\n await quote.fetchData({ fetchType: isRefetch ? QuoteFetchType.Refetch : QuoteFetchType.NewerData })\r\n this.updateQuoteData()\r\n } else {\r\n quote.destroy()\r\n }\r\n })\r\n\r\n if (isRefetch) {\r\n const d = tickers.map((ticker) => ({ ticker: ticker, timeframe: TIMEFRAME.d, instrument: Instrument.Stock }))\r\n const m = tickers.map((ticker) => ({ ticker: ticker, timeframe: TIMEFRAME.m, instrument: Instrument.Stock }))\r\n await Quote.getAll(d.concat(m))\r\n\r\n this.setState({ loading: false })\r\n }\r\n\r\n this.updateQuoteData()\r\n }\r\n\r\n _onSubmit = (e: FormEvent) => {\r\n e.preventDefault()\r\n const tickersInput = getSanitizedTicker(this.state.tickersInput, true)\r\n const tickers = tickersInput.split(',')\r\n this.setState({ tickers, tickersInput }, () => {\r\n this._fetch(tickers)\r\n })\r\n }\r\n\r\n _onMonthChange = (type: string, e: ChangeEvent) => {\r\n const state: any = {}\r\n state[type + 'Month'] = this.state.months.filter((m) => m.value === e.target.value)[0]\r\n this.setState(state)\r\n }\r\n\r\n _onDatePickerChange = (type: string, date: any) => {\r\n const formattedDate = formatDateToStringUS(new Date(date))\r\n\r\n const state: any = {}\r\n state[type + 'Day'] = formattedDate\r\n state[type + 'DatePickerOpen'] = false\r\n this.setState(state, () => {\r\n this._fetch(this.state.tickers)\r\n })\r\n }\r\n}\r\n","import classNames from 'classnames'\r\nimport * as React from 'react'\r\n\r\ninterface ChartBoxProps extends Omit, 'label'> {\r\n label?: React.ReactNode\r\n}\r\n\r\nexport function ChartBox({ label, children, ...props }: React.PropsWithChildren) {\r\n return (\r\n \r\n
\r\n {label}\r\n
\r\n {children}\r\n \r\n )\r\n}\r\n","import * as React from 'react'\r\nimport { ComposedChart } from 'recharts'\r\n\r\nimport { RedGreenText } from '../../../components/RedGreenText'\r\nimport { Bar } from '../../../components/chart/Bar'\r\nimport { CartesianGrid } from '../../../components/chart/CartesianGrid'\r\nimport { ChartBox } from '../../../components/chart/ChartBox'\r\nimport { ChartWrapper } from '../../../components/chart/ChartWrapper'\r\nimport { Label } from '../../../components/chart/Label'\r\nimport { Line } from '../../../components/chart/Line'\r\nimport { Tooltip, TooltipRow } from '../../../components/chart/Tooltip'\r\nimport { DateFormat, XAxis, dateAxisFormatter } from '../../../components/chart/XAxis'\r\nimport { YAxis } from '../../../components/chart/YAxis'\r\nimport { getMonthlyTicks } from '../../../components/chart/utils'\r\nimport { dateStrToTimestamp, shortFormatDollar } from '../../../util'\r\nimport { parseRouteInitData } from '../../../util-routing'\r\nimport { QuoteContext } from '../QuoteContext'\r\n\r\ninterface FundFlowsRow {\r\n date: string\r\n aum: number | null\r\n flow: number | null\r\n}\r\n\r\nenum FlowsChartDataKeys {\r\n Aum = 'aum',\r\n Flows = 'flow',\r\n}\r\n\r\nconst AXIS_LABEL_OFFSET = 38\r\n\r\nfunction tooltipValueFormatter(value: number, { dataKey }: { dataKey: string }) {\r\n const formatted = shortFormatDollar(value)\r\n if (dataKey === FlowsChartDataKeys.Aum) return formatted\r\n\r\n return (\r\n \r\n {formatted}\r\n \r\n )\r\n}\r\n\r\nexport function FundFlowsChart(props: React.HTMLProps) {\r\n const { index } = React.useContext(QuoteContext)\r\n const initData = React.useMemo(() => {\r\n const routeData = parseRouteInitData({\r\n elementId: `route-init-data-fundflows-${index}`,\r\n removeElement: false,\r\n })\r\n\r\n return routeData?.map((row) => ({ ...row, date: dateStrToTimestamp(row.date) }))\r\n }, [index])\r\n\r\n const monthlyTicks = React.useMemo(\r\n () => (initData ? getMonthlyTicks(initData[0].date, initData[initData?.length - 1].date) : undefined),\r\n [initData]\r\n )\r\n\r\n if (!initData?.length) return null\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n dateAxisFormatter({ value, outFormat: DateFormat.MonthShort, parseAsNY: false, breakOnYear: true })\r\n }\r\n />\r\n \r\n \r\n \r\n {\r\n const absMax = Math.max(Math.abs(dataMin), Math.abs(dataMax)) * 1.2\r\n return [-absMax, absMax]\r\n }}\r\n >\r\n \r\n \r\n \r\n dateAxisFormatter({ value, outFormat: DateFormat.MonthShortDayNumYearFull, parseAsNY: false })\r\n }\r\n formatValue={tooltipValueFormatter}\r\n >\r\n \r\n \r\n \r\n\r\n \r\n \r\n yAxisId=\"flowAxis\"\r\n dataKey={FlowsChartDataKeys.Flows}\r\n radius={[1, 1, 0, 0]}\r\n color={(value) => (value == null ? 'blue' : value > 0 ? 'green' : 'red')}\r\n />\r\n \r\n \r\n \r\n )\r\n}\r\n","import * as dateFns from 'date-fns'\r\n\r\nexport function getMonthlyTicks(startingTimestamp: number, endingTimestamp: number, dayOfMonth = 1) {\r\n const ticks: number[] = []\r\n const endingDate = new Date(endingTimestamp)\r\n const initTimestamp = new Date(startingTimestamp)\r\n const startDate = dateFns.setDay(initTimestamp, dayOfMonth)\r\n let date = dateFns.isBefore(startDate, initTimestamp) ? initTimestamp : startDate\r\n\r\n while (date <= endingDate) {\r\n ticks.push(date.getTime())\r\n date = new Date(date.getFullYear(), date.getMonth() + 1, dayOfMonth)\r\n }\r\n\r\n return ticks\r\n}\r\n","export const CHART_HEIGHT = 300\r\nexport const BAR_WIDTH = 8\r\n\r\nexport enum BarType {\r\n Buy = 'buyAggregated',\r\n Sale = 'saleAggregated',\r\n}\r\n","import * as React from 'react'\r\nimport { Rectangle } from 'recharts'\r\n\r\nimport { BarInner } from '../../../../components/chart/Bar'\r\nimport { BAR_WIDTH, BarType } from './constants'\r\n\r\nexport function InsiderVolumeBar({ x, width, ...props }: any) {\r\n let newX = x\r\n const value = props.payload[props.dataKey]\r\n const isCenteredBar = props.payload.saleAggregated === 0 || props.payload.buyAggregated === 0\r\n if (isCenteredBar) {\r\n if (props.dataKey === BarType.Sale) newX += width / 2\r\n else newX -= width / 2\r\n }\r\n\r\n if (value === 0 || !Number.isFinite(value)) {\r\n // Needs to return an element, so return an empty node\r\n return \r\n }\r\n\r\n return (\r\n \r\n \r\n {props.dataKey === BarType.Sale && (\r\n \r\n )}\r\n {props.dataKey === BarType.Buy && (\r\n \r\n )}\r\n \r\n )\r\n}\r\n","import classNames from 'classnames'\r\nimport { endOfMonth, startOfMonth } from 'date-fns'\r\nimport { type Quote } from 'finviz-charts/server/offScreenCanvasRender'\r\n\r\nimport { getDate } from '../../../../../app/header/utils'\r\nimport { RedGreenText } from '../../../../components/RedGreenText'\r\nimport { shortFormatDollar } from '../../../../util'\r\nimport { BarType } from './constants'\r\nimport { ChartBaseData, VolumeChartDataPerTimeframe } from './types'\r\n\r\n/**\r\n * Only get data between from/to range\r\n */\r\nexport function filterDataForChart(quote: Quote, [fromDate, toDate]: number[]) {\r\n const monthlyData: ChartBaseData[] = []\r\n\r\n const fromTimestamp = getDate(startOfMonth(getDate(fromDate))).getTime()\r\n const toTimestamp = getDate(endOfMonth(getDate(toDate))).getTime()\r\n for (let index = 0; index < quote.date.length; index++) {\r\n const currentTimestamp = quote.date[index] * 1000\r\n const currentClose = quote.close[quote.barToDataIndex[index]]\r\n\r\n if (fromTimestamp > currentTimestamp || currentTimestamp > toTimestamp) continue\r\n\r\n monthlyData.push({ date: currentTimestamp, close: currentClose })\r\n }\r\n\r\n return monthlyData\r\n}\r\n\r\nexport function tooltipTitleFormatter(date: number) {\r\n const startDate = startOfMonth(date)\r\n const endDate = endOfMonth(startDate)\r\n\r\n const month = startDate.toLocaleString('en-US', { month: 'short' })\r\n const startDay = startDate.getDate()\r\n const year = startDate.getFullYear()\r\n const endDay = endDate.getDate()\r\n return `${month} ${startDay}-${endDay}, ${year}`\r\n}\r\n\r\nexport function tooltipDataFormatter(\r\n _: unknown,\r\n {\r\n dataKey,\r\n fullTooltipPayload,\r\n }: { dataKey: string; fullTooltipPayload: { payload?: { insider: VolumeChartDataPerTimeframe } }[] }\r\n) {\r\n const { insider } = fullTooltipPayload[0]?.payload ?? {}\r\n\r\n if (!insider) return null\r\n\r\n const tradeCount = dataKey === BarType.Buy ? insider?.buyTransactionCount : insider?.saleTransactionCount\r\n const value = dataKey === BarType.Buy ? insider?.buyAggregated : insider?.saleAggregated\r\n const isZeroValue = value === 0\r\n const valueToUse = isZeroValue ? null : dataKey === BarType.Buy ? value : -value\r\n\r\n return (\r\n \r\n {shortFormatDollar(isZeroValue ? null : value, { defaultValue: '—' })} \r\n {!isZeroValue && (\r\n \r\n ({tradeCount ?? 0} Trade{tradeCount === 1 ? '' : 's'})\r\n \r\n )}\r\n \r\n )\r\n}\r\n","import { endOfMonth, startOfMonth } from 'date-fns'\r\nimport { getInstrument } from 'finviz-charts/app/utils/chart'\r\nimport * as React from 'react'\r\nimport { ComposedChart } from 'recharts'\r\n\r\nimport { Quote, TIMEFRAME } from '../../../../../app/charts-lib'\r\nimport { getDate } from '../../../../../app/header/utils'\r\nimport { Bar } from '../../../../components/chart/Bar'\r\nimport { CartesianGrid } from '../../../../components/chart/CartesianGrid'\r\nimport { ChartBox } from '../../../../components/chart/ChartBox'\r\nimport { ChartWrapper } from '../../../../components/chart/ChartWrapper'\r\nimport { CursorBar } from '../../../../components/chart/Cursor'\r\nimport { Label } from '../../../../components/chart/Label'\r\nimport { Line } from '../../../../components/chart/Line'\r\nimport { Tooltip, TooltipRow } from '../../../../components/chart/Tooltip'\r\nimport { DateFormat, XAxis, dateAxisFormatter } from '../../../../components/chart/XAxis'\r\nimport { YAxis } from '../../../../components/chart/YAxis'\r\nimport { shortFormatDollar } from '../../../../util'\r\nimport { parseRouteInitData } from '../../../../util-routing'\r\nimport { QuoteContext } from '../../QuoteContext'\r\nimport { InsiderVolumeBar } from './InsiderVolumeBar'\r\nimport { BarType, CHART_HEIGHT } from './constants'\r\nimport { ChartData, TradingVolumeChartInit } from './types'\r\nimport { filterDataForChart, tooltipDataFormatter, tooltipTitleFormatter } from './utils'\r\n\r\nexport function InsiderTradingVolumeChart({ className }: { className?: string }) {\r\n const { ticker, index } = React.useContext(QuoteContext)\r\n const [chartData, setChartData] = React.useState([])\r\n\r\n const initData = React.useMemo(() => {\r\n const data = parseRouteInitData({\r\n elementId: `insider-init-data-${index}`,\r\n removeElement: false,\r\n })\r\n\r\n return {\r\n data,\r\n domain: data?.length\r\n ? [\r\n getDate(startOfMonth(getDate(data[0].date))).getTime(),\r\n getDate(endOfMonth(getDate(data[data.length - 1].date))).getTime(),\r\n ]\r\n : [],\r\n }\r\n }, [index])\r\n\r\n const hasInsiderTradingHistory = React.useMemo(\r\n () => initData.data?.some((x) => x.saleTransactionCount > 0 || x.buyTransactionCount > 0),\r\n [initData]\r\n )\r\n\r\n React.useEffect(() => {\r\n if (!hasInsiderTradingHistory) return\r\n\r\n async function fetchQuoteData() {\r\n if (!initData.data?.length) return\r\n const quote = await Quote.get({\r\n ticker,\r\n instrument: getInstrument(ticker),\r\n timeframe: TIMEFRAME.d,\r\n // Do not reuse idea quote, it doesn’t have the current data\r\n options: { cachePredicate: (quote) => !quote.ideaID },\r\n })\r\n const dateFrom = initData.data[0].date\r\n const dateTo = initData.data[initData.data.length - 1]!.date\r\n const data = filterDataForChart(quote, [dateFrom, dateTo])\r\n\r\n setChartData(data.map((row, index) => ({ ...row, insider: initData.data?.[index] })))\r\n }\r\n\r\n fetchQuoteData()\r\n }, [initData, hasInsiderTradingHistory, index, ticker])\r\n\r\n if (!initData.data?.length || !hasInsiderTradingHistory) return null\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n dateAxisFormatter({ value, outFormat: DateFormat.MonthShort, parseAsNY: false, breakOnYear: true })\r\n }\r\n />\r\n \r\n \r\n \r\n shortFormatDollar(value)} domain={['dataMin', 'auto']}>\r\n \r\n \r\n }\r\n >\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n \r\n )\r\n}\r\n","import classnames from 'classnames'\r\nimport * as React from 'react'\r\n\r\nimport { Heading } from '../../../components'\r\nimport { ChipSwitch, ChipSwitchButton } from '../../../components/ChipSwitch'\r\nimport { RedGreenText } from '../../../components/RedGreenText'\r\nimport { Table, TableAlign, TableBody, TableCell, TableRow } from '../../../components/Table'\r\nimport { formatNumber } from '../../../util'\r\nimport { parseRouteInitData } from '../../../util-routing'\r\nimport { QuoteContext } from '../QuoteContext'\r\n\r\ntype InstitutionalOwnershipInitData = {\r\n managersOwnership: Array | null\r\n fundsOwnership: Array | null\r\n}\r\n\r\ninterface InstitutionalOwnershipItem {\r\n investorId: string\r\n name: string\r\n percOwnership: number\r\n}\r\n\r\nenum InstitutionalOwnershipType {\r\n Managers,\r\n Funds,\r\n}\r\n\r\nfunction getInvestorLink(investorId: string, type: InstitutionalOwnershipType) {\r\n const view = type === InstitutionalOwnershipType.Funds ? 'fund-details' : 'manager-details'\r\n return `/insidertrading.ashx?view=${view}&investorId=${investorId}`\r\n}\r\n\r\nconst isRedesignEnabled = FinvizSettings.hasRedesignEnabled\r\n\r\nconst commonTdClassName = {\r\n '!px-0.5': !isRedesignEnabled,\r\n}\r\n\r\nexport function InstitutionalOwnership() {\r\n const { index } = React.useContext(QuoteContext)\r\n const { managersItems, hasManagersItems, fundsItems, hasFundsItems } = React.useMemo(() => {\r\n const initData = parseRouteInitData({\r\n elementId: `institutional-ownership-init-data-${index}`,\r\n removeElement: false,\r\n })\r\n\r\n const managersItems = initData?.managersOwnership ?? []\r\n const fundsItems = initData?.fundsOwnership ?? []\r\n\r\n return {\r\n managersItems,\r\n hasManagersItems: managersItems.length > 0,\r\n fundsItems,\r\n hasFundsItems: fundsItems.length > 0,\r\n }\r\n }, [index])\r\n\r\n const [institutionalOwnership, setInstitutionalOwnership] = React.useState(\r\n hasManagersItems ? InstitutionalOwnershipType.Managers : InstitutionalOwnershipType.Funds\r\n )\r\n const items = institutionalOwnership === InstitutionalOwnershipType.Managers ? managersItems : fundsItems\r\n\r\n return (\r\n \r\n \r\n \r\n Institutional Ownership\r\n \r\n \r\n {\r\n setInstitutionalOwnership(InstitutionalOwnershipType.Managers)\r\n }}\r\n >\r\n Managers\r\n \r\n {\r\n setInstitutionalOwnership(InstitutionalOwnershipType.Funds)\r\n }}\r\n >\r\n Funds\r\n \r\n \r\n \r\n
\r\n \r\n \r\n {items.map(({ investorId, name, percOwnership }) => (\r\n \r\n \r\n \r\n {name ?? '-'}\r\n \r\n \r\n \r\n \r\n {formatNumber(percOwnership, { suffix: '%' })}\r\n \r\n \r\n \r\n ))}\r\n \r\n
\r\n
\r\n )\r\n}\r\n","import classnames from 'classnames'\r\n\r\nimport { formatDate } from '../../../../app/header/utils'\r\nimport { RedGreenMultiline, RedGreenText } from '../../../components/RedGreenText'\r\nimport { formatNumber } from '../../../util'\r\n\r\nexport interface QuotePriceProps {\r\n title?: string\r\n date?: Date | null\r\n dateLabel?: string | null\r\n price: number\r\n changeUsd: number\r\n changePct: number\r\n}\r\n\r\nexport function QuotePrice({ title, date, dateLabel, price, changeUsd, changePct }: QuotePriceProps) {\r\n const fractions = !isNaN(price) && price < 1 ? 4 : 2\r\n const hasValue = changeUsd && Number.isFinite(changeUsd)\r\n\r\n return (\r\n
\r\n {title &&
{title}
}\r\n\r\n {(date || dateLabel) && (\r\n \r\n {dateLabel ?? formatDate(date, '', 'MMM dd')}\r\n {date && (\r\n <>\r\n {' '}\r\n {formatDate(date, '', 'hh:mmaa')} ET\r\n \r\n )}\r\n \r\n )}\r\n\r\n
\r\n {formatNumber(price, { defaultValue: '—', fractions })}\r\n
\r\n \r\n \r\n
Dollar change
\r\n {formatNumber(changeUsd, { showPlusSign: true, fractions })}\r\n
\r\n %}\r\n >\r\n
Percentage change
\r\n {formatNumber(changePct)}\r\n \r\n
\r\n
\r\n
\r\n
\r\n )\r\n}\r\n","import { useModelState } from '../../../../../app/charts-lib'\r\n\r\nconst CHANGE_UPATE_EVENTS = ['change', 'update']\r\nconst QUOTE_MODEL_CHANGE_EVENTS = [...CHANGE_UPATE_EVENTS, 'refetch', 'newerData']\r\n\r\nexport interface HeaderPricesContext {\r\n prevClose: number\r\n lastClose: number\r\n lastTime: number\r\n lastDate?: number\r\n afterClose: number\r\n afterTime: number\r\n}\r\n\r\nexport function useChartContextPrices(chartLayoutModel: any): HeaderPricesContext | null {\r\n const chartModel = useModelState(chartLayoutModel?.charts().first(), {\r\n watchProperties: ['quote'],\r\n listenOnEvents: CHANGE_UPATE_EVENTS,\r\n })\r\n const quoteModel = useModelState(chartModel?.quote() ?? null, {\r\n watchProperties: ['lastClose', 'prevClose', 'afterClose', 'afterTime'],\r\n listenOnEvents: QUOTE_MODEL_CHANGE_EVENTS,\r\n })\r\n\r\n if (!quoteModel) return null\r\n\r\n return {\r\n prevClose: quoteModel.prevClose,\r\n lastClose: quoteModel.lastClose,\r\n lastTime: quoteModel.lastTime,\r\n lastDate: quoteModel.lastDate,\r\n afterClose: quoteModel.afterClose,\r\n afterTime: quoteModel.afterTime,\r\n }\r\n}\r\n","import * as dateFns from 'date-fns'\r\nimport React from 'react'\r\n\r\nimport {\r\n Quote,\r\n useChartLayoutGlobalModelAsync,\r\n withCompleteLayoutModelInit,\r\n withQuotePolling,\r\n} from '../../../../../app/charts-lib'\r\nimport { formatDate, getDate } from '../../../../../app/header/utils'\r\nimport { QuotePortalContext } from '../Portal'\r\nimport { QuotePrice } from '../QuotePrice'\r\nimport { HeaderPricesContext, useChartContextPrices } from './hooks'\r\n\r\nexport function ChartContextQuoteHeader() {\r\n const { toggleStaticElement } = React.useContext(QuotePortalContext)\r\n const { chartLayoutModel } = useChartLayoutGlobalModelAsync()\r\n const data = useChartContextPrices(chartLayoutModel)\r\n const hasData = !!data\r\n\r\n React.useEffect(() => {\r\n if (hasData) toggleStaticElement(true)\r\n\r\n return () => toggleStaticElement(false)\r\n }, [hasData, toggleStaticElement])\r\n\r\n return \r\n}\r\n\r\ninterface QuoteHeaderWithManualInitProps {\r\n chartLayoutModel: any\r\n config: any\r\n}\r\n\r\nfunction ManualInitQuoteHeaderComponent({ chartLayoutModel, config }: QuoteHeaderWithManualInitProps) {\r\n const { toggleStaticElement } = React.useContext(QuotePortalContext)\r\n const data = useChartContextPrices(chartLayoutModel)\r\n\r\n /**\r\n * We need to instantiate layout model in order to use quote refetch on page\r\n * without an actual chart (options.) We also need to manually create a chart model\r\n *\r\n * It is then correctly caught in `useChartContextPrices`\r\n */\r\n React.useEffect(() => {\r\n async function fetchAndMapInitialQuote() {\r\n for (const chartConfig of config.charts) {\r\n const modelProperties = Object.assign({}, chartConfig)\r\n\r\n modelProperties.chart_layout = chartLayoutModel\r\n delete modelProperties.panes\r\n if (modelProperties.refreshData == null) {\r\n modelProperties.refreshData = true\r\n }\r\n chartLayoutModel.charts().create(modelProperties)\r\n }\r\n\r\n const chart = chartLayoutModel.charts().first()\r\n\r\n const quote = await Quote.get({\r\n ticker: chart.ticker,\r\n instrument: chart.instrument,\r\n timeframe: chart.timeframe,\r\n options: { maxBars: 0 },\r\n })\r\n\r\n chart.updateAttributes({ quote })\r\n toggleStaticElement()\r\n }\r\n\r\n fetchAndMapInitialQuote()\r\n }, [chartLayoutModel, config.charts, toggleStaticElement])\r\n\r\n return \r\n}\r\n\r\nexport const ManualInitQuoteHeader = withCompleteLayoutModelInit(withQuotePolling(ManualInitQuoteHeaderComponent))\r\n\r\nexport function QuoteHeaderContent({ data }: { data: HeaderPricesContext | null }) {\r\n if (!data) return null\r\n\r\n const isChange = Number.isFinite(data.prevClose)\r\n const isAfterChange = Number.isFinite(data.afterClose) && data.afterClose !== data.lastClose\r\n const lastTime = data.lastTime ? getDate(data.lastTime * 1000) : null\r\n const lastDate = !lastTime && data.lastDate ? formatDate(data.lastDate, 'yyyyMMdd', 'MMM dd, yyyy') : null\r\n const afterDate = data.afterTime ? getDate(data.afterTime * 1000) : null\r\n\r\n let afterhoursTitle\r\n if (lastTime && afterDate) {\r\n if (dateFns.isBefore(afterDate, lastTime)) afterhoursTitle = 'Premarket'\r\n else afterhoursTitle = 'Aftermarket'\r\n }\r\n\r\n return (\r\n <>\r\n {isChange && (\r\n \r\n )}\r\n {isAfterChange && (\r\n \r\n )}\r\n \r\n )\r\n}\r\n","import * as d3 from 'd3'\r\nimport { Component, RefObject, createRef } from 'react'\r\n\r\nexport interface Bar {\r\n name: string\r\n value: number\r\n}\r\n\r\ninterface BarChartProps {\r\n title?: string\r\n data: Bar[]\r\n width?: number\r\n height?: number\r\n valueFormatter?: (value: number) => string\r\n xAxisRotate?: boolean\r\n marginRight?: number\r\n className?: string\r\n}\r\n\r\nexport default class BarChart extends Component {\r\n svgRef: RefObject = createRef()\r\n\r\n declare _prevData: Bar[]\r\n\r\n componentDidMount() {\r\n this.renderChart()\r\n }\r\n\r\n componentDidUpdate() {\r\n this.renderChart()\r\n }\r\n\r\n renderChart() {\r\n const { data, title } = this.props\r\n if (data === this._prevData) {\r\n return\r\n }\r\n this._prevData = data\r\n this.svgRef.current!.innerHTML = ''\r\n\r\n const xAxisRotate = this.props.xAxisRotate === true\r\n\r\n const margin = {\r\n top: title ? 20 : 10,\r\n right: this.props.marginRight || 60,\r\n bottom: xAxisRotate ? 70 : 20,\r\n left: 15,\r\n }\r\n const totalWidth = this.props.width || 440\r\n const totalHeight = this.props.height || 330\r\n const width = totalWidth - margin.left - margin.right\r\n const height = totalHeight - margin.top - margin.bottom\r\n\r\n const x = d3\r\n .scaleBand()\r\n .domain(data.map((d) => d.name))\r\n .rangeRound([0, width])\r\n .padding(0.1)\r\n\r\n let min = d3.min(data, (d: Bar) => d.value)!\r\n if (min < 0) {\r\n min = d3.min(data, (d: Bar) => Math.min(d.value, -d.value))!\r\n } else {\r\n min = 0\r\n }\r\n\r\n const y = d3\r\n .scaleLinear()\r\n .range([height, 0])\r\n .domain([min, d3.max(data, (d: Bar) => Math.abs(d.value))!])\r\n .nice()\r\n const yFormat = this.props.valueFormatter ? this.props.valueFormatter : y.tickFormat()\r\n\r\n const svg = d3\r\n .select(this.svgRef.current)\r\n .property('value', [])\r\n .append('g')\r\n .attr('transform', 'translate(' + margin.left + ',' + margin.top + ')')\r\n\r\n const xAxis = d3.axisBottom(x)\r\n const yAxis = d3.axisRight(y).ticks(height > 200 ? 10 : 5)\r\n\r\n const makeYLines = () => d3.axisLeft(y)\r\n // @ts-expect-error - tickFormat arg can be any string\r\n svg.append('g').attr('class', 'grid').call(makeYLines().tickSize(-width).tickSizeOuter(0).tickFormat(''))\r\n\r\n svg\r\n .append('g')\r\n .attr('class', 'x-axis axis')\r\n .attr('transform', 'translate(0,' + height + ')')\r\n .call(xAxis)\r\n\r\n svg\r\n .selectAll('.x-axis text')\r\n .style('text-anchor', xAxisRotate ? 'end' : 'middle')\r\n .attr('dx', xAxisRotate ? '-.8em' : 0)\r\n .attr('dy', xAxisRotate ? '.15em' : '0.8em')\r\n .attr('transform', 'rotate(' + (xAxisRotate ? -65 : 0) + ')')\r\n\r\n svg\r\n .append('g')\r\n .attr('class', 'y-axis axis')\r\n .attr('transform', 'translate(' + width + ', 0)')\r\n .call(yAxis)\r\n\r\n if (title) {\r\n svg\r\n .append('text')\r\n .attr('class', 'bar-chart-title')\r\n .attr('x', 4)\r\n .attr('y', -5)\r\n .attr('text-anchor', 'start')\r\n .text(title)\r\n }\r\n\r\n const getHeight = (d: Bar) => {\r\n let height = Math.abs(y(d.value ?? 0) - y(0))\r\n if (d.value > 0 || d.value < 0) {\r\n height = Math.max(height, 0.5)\r\n }\r\n return height\r\n }\r\n const isOutside = (height: number) => height < 14\r\n const bars = svg.selectAll('.bar').data(data)\r\n bars\r\n .enter()\r\n .append('rect')\r\n .attr('class', function (d: Bar) {\r\n return 'bar bar--' + (d.value < 0 ? 'negative' : 'positive')\r\n })\r\n .attr('x', (d: Bar) => x(d.name)!)\r\n .attr('y', (d: Bar) => y(Math.max(0, d.value)))\r\n .attr('height', getHeight)\r\n .attr('width', x.bandwidth())\r\n .attr('ry', FinvizSettings?.hasRedesignEnabled ? 2 : 0)\r\n\r\n svg\r\n .selectAll('.bar-label')\r\n .data(data)\r\n .enter()\r\n .append('text')\r\n .attr('class', 'divergence')\r\n .attr('x', (d: Bar) => x(d.name)! + x.bandwidth() / 2)\r\n .attr('y', (d: Bar) => {\r\n const height = getHeight(d)\r\n const outside = isOutside(height)\r\n if (d.value < 0) {\r\n return y(Math.max(0, d.value)) + height + (outside ? 12 : -4)\r\n }\r\n return y(Math.max(0, d.value)) + (outside ? -4 : 12)\r\n })\r\n .attr('fill', (d: Bar) => (!FinvizSettings.hasDarkTheme && isOutside(getHeight(d)) ? 'black' : 'white'))\r\n .attr('text-anchor', 'middle')\r\n .attr('font-size', '10px')\r\n .text((d: Bar) => (d.value !== null ? yFormat(d.value) : ''))\r\n\r\n this.svgRef.current!.style.width = totalWidth + 'px'\r\n this.svgRef.current!.style.height = totalHeight + 'px'\r\n }\r\n\r\n render() {\r\n return \r\n }\r\n}\r\n","export enum StatementsDataEnum {\r\n yoyChange = 'yoyChange',\r\n yoyChangePct = 'yoyChangePct',\r\n}\r\n\r\nexport enum StatementsTimeframeEnum {\r\n annual = 'annual',\r\n quarterly = 'quarterly',\r\n}\r\n\r\nexport const SETTINGS_COOKIE_KEY = 'quoteStatementsTableSettings'\r\n\r\nexport const DEFAULT_SETTINGS = {\r\n [StatementsDataEnum.yoyChange]: false,\r\n [StatementsDataEnum.yoyChangePct]: false,\r\n statementsTimeframe: StatementsTimeframeEnum.annual,\r\n}\r\n\r\nexport type StatementsType = {\r\n [StatementsDataEnum.yoyChange]: boolean\r\n [StatementsDataEnum.yoyChangePct]: boolean\r\n statementsTimeframe: StatementsTimeframeEnum\r\n}\r\n","import * as Ariakit from '@ariakit/react'\r\nimport classnames from 'classnames'\r\nimport * as d3 from 'd3'\r\nimport { isRedesignEnabled } from 'finviz-charts/app/utils'\r\nimport { decodeQueryString } from 'finviz-charts/app/utils/query_string'\r\nimport * as React from 'react'\r\nimport { Component, RefObject, createRef } from 'react'\r\n\r\nimport { AdTag, getInvestingChannelPage } from '../../../../../app/shared/components/Ads'\r\nimport { Icon } from '../../../../components'\r\nimport { ChipSwitch, ChipSwitchButton } from '../../../../components/ChipSwitch'\r\nimport { RedGreenText } from '../../../../components/RedGreenText'\r\nimport { FinancialsTableContextProvider, useFinancialsTableContext } from '../../../../components/financials-table'\r\nimport { getValue, setValue } from '../../../../services/local-storage'\r\nimport { shortFormatNumber } from '../../../../util'\r\nimport BarChartBig from '../barChart'\r\nimport {\r\n DEFAULT_SETTINGS,\r\n SETTINGS_COOKIE_KEY,\r\n StatementsDataEnum,\r\n StatementsTimeframeEnum,\r\n StatementsType,\r\n} from './constants'\r\n\r\ninterface Bar {\r\n name: string\r\n value: number\r\n}\r\n\r\ninterface BarChartProps {\r\n data: Bar[]\r\n}\r\n\r\nclass BarChart extends Component {\r\n svgRef: RefObject\r\n\r\n constructor(props: BarChartProps) {\r\n super(props)\r\n this.svgRef = createRef()\r\n }\r\n\r\n componentDidMount() {\r\n this.renderChart()\r\n }\r\n\r\n componentDidUpdate() {\r\n this.renderChart()\r\n }\r\n\r\n renderChart() {\r\n const data = this.props.data\r\n\r\n const barWidth = 3\r\n const width = data.length * (barWidth + 1)\r\n const height = 16\r\n\r\n const x = d3\r\n .scaleBand()\r\n .domain(data.map((d) => d.name))\r\n .range([0, width])\r\n\r\n let min = d3.min(data, (d: Bar) => d.value)!\r\n if (min < 0) {\r\n min = d3.min(data, (d: Bar) => Math.min(d.value, -d.value))!\r\n } else {\r\n min = 0\r\n }\r\n\r\n const y = d3\r\n .scaleLinear()\r\n .range([height, 0])\r\n .domain([min, d3.max(data, (d: Bar) => Math.abs(d.value))] as [number, number])\r\n .nice()\r\n .unknown(height / 2)\r\n\r\n const svg = d3.select(this.svgRef.current).property('value', [])\r\n\r\n const bars = svg.selectAll('.bar').data(data)\r\n bars\r\n .enter()\r\n .append('rect')\r\n .attr('class', function (d: Bar) {\r\n return 'bar bar--' + (d.value < 0 ? 'negative' : 'positive')\r\n })\r\n .attr('x', function (d: Bar) {\r\n return x(d.name)!\r\n })\r\n .attr('y', function (d: Bar) {\r\n return y(Math.max(0, d.value))\r\n })\r\n .attr('height', function (d: Bar) {\r\n let height = Math.abs(y(d.value) - y(0))\r\n if (d.value > 0 || d.value < 0) {\r\n height = Math.max(height, 0.5)\r\n }\r\n return height\r\n })\r\n .attr('width', barWidth)\r\n bars\r\n .transition()\r\n .attr('class', function (d: Bar) {\r\n return 'bar bar--' + (d.value < 0 ? 'negative' : 'positive')\r\n })\r\n .attr('x', function (d: Bar) {\r\n return x(d.name)!\r\n })\r\n .attr('y', function (d: Bar) {\r\n return y(Math.max(0, d.value))\r\n })\r\n .attr('height', function (d: Bar) {\r\n let height = Math.abs(y(d.value) - y(0))\r\n if (d.value > 0 || d.value < 0) {\r\n height = Math.max(height, 0.5)\r\n }\r\n return height\r\n })\r\n .attr('width', barWidth)\r\n bars.exit().remove()\r\n\r\n this.svgRef.current!.style.width = width + 'px'\r\n this.svgRef.current!.style.height = height + 'px'\r\n }\r\n\r\n render() {\r\n return \r\n }\r\n}\r\n\r\nfunction EliteHoverAd() {\r\n return (\r\n
\r\n
\r\n \r\n

Upgrade your FINVIZ experience

\r\n

\r\n Join thousands of traders who make more informed decisions with our premium features. Real-time\r\n quotes, advanced visualizations, historical statements, and much more.\r\n

\r\n \r\n Learn more\r\n \r\n
\r\n
\r\n )\r\n}\r\n\r\ninterface BarChartWrapperProps {\r\n data: Bar[]\r\n}\r\n\r\nclass BarChartWrapper extends Component {\r\n state = {\r\n hover: false,\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n \r\n x.value !== null)}>\r\n \r\n \r\n \r\n {FinvizSettings.hasUserPremium ? (\r\n \r\n ) : (\r\n \r\n )}\r\n \r\n \r\n
\r\n )\r\n }\r\n}\r\n\r\nconst DEFAULT_SOURCE = 'F'\r\n\r\nconst _getDefaultSource = (): 'F' | 'R' => {\r\n if (!FinvizSettings.hasUserPremium) {\r\n return DEFAULT_SOURCE\r\n }\r\n\r\n return getValue('statements-source', DEFAULT_SOURCE) === 'R' ? 'R' : 'F'\r\n}\r\n\r\nconst getTimeframeFromStatementsSettingsTimeframe = (statementsTimeframe: StatementsTimeframeEnum) => {\r\n if (statementsTimeframe === StatementsTimeframeEnum.quarterly) {\r\n return 'Q'\r\n }\r\n\r\n // statementsTimeframe === StatementsTimeframeEnum.annual or fallback\r\n return 'A'\r\n}\r\n\r\ninterface StatementsState {\r\n source: 'F' | 'R'\r\n sheet: string\r\n currency: string | null\r\n data: Record | null\r\n}\r\n\r\nfunction StatementsComponent() {\r\n const { settings } = useFinancialsTableContext()\r\n const pageRef = React.useRef(getInvestingChannelPage())\r\n\r\n const [state, setState] = React.useState({\r\n source: _getDefaultSource(),\r\n sheet: 'I',\r\n currency: null,\r\n data: null,\r\n })\r\n\r\n const timeframe = getTimeframeFromStatementsSettingsTimeframe(settings.statementsTimeframe)\r\n\r\n const { data } = state\r\n const hasData = data && !data.error && Object.keys(data).length > 0\r\n const hasRedesignEnabled = FinvizSettings?.hasRedesignEnabled\r\n\r\n const _fetch = async () => {\r\n const { source, sheet } = state\r\n const { t } = decodeQueryString()\r\n\r\n try {\r\n const response = await fetch(`/api/statement.ashx?t=${t}&so=${source}&s=${sheet}${timeframe}`)\r\n const json = await response.json()\r\n\r\n setState({\r\n ...state,\r\n currency: json.currency,\r\n data: json.error ? json : json.data,\r\n })\r\n } catch {}\r\n }\r\n\r\n React.useEffect(() => {\r\n pageRef.current = getInvestingChannelPage()\r\n pageRef.current?.create()\r\n\r\n return () => {\r\n pageRef.current?.destroy()\r\n }\r\n }, [])\r\n\r\n React.useEffect(() => {\r\n _fetch()\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [state.sheet, state.source, timeframe])\r\n\r\n const _renderSheetLink = (id: string, text: string) => (\r\n // eslint-disable-next-line jsx-a11y/anchor-is-valid\r\n {\r\n e.preventDefault()\r\n setState({\r\n ...state,\r\n sheet: id,\r\n })\r\n }}\r\n >\r\n {text}\r\n \r\n )\r\n\r\n if (data === null) {\r\n return null\r\n }\r\n\r\n return (\r\n <>\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
\r\n {FinvizSettings.hasUserPremium && (\r\n // TODO fix classname when css mixins removal is merged\r\n {\r\n e.preventDefault()\r\n const source = e.target.value === 'R' ? 'R' : 'F'\r\n setState({\r\n ...state,\r\n source: source,\r\n })\r\n setValue('statements-source', source, DEFAULT_SOURCE, false)\r\n }}\r\n >\r\n \r\n \r\n \r\n )}\r\n {FinvizSettings.hasUserPremium && <>   }\r\n\r\n \r\n {_renderSheetLink('I', 'Income Statement')} {' '}\r\n {_renderSheetLink('B', 'Balance Sheet')} {' '}\r\n {_renderSheetLink('C', 'Cash Flow')}\r\n \r\n \r\n \r\n
\r\n {hasData && }\r\n {!hasData && (\r\n \r\n \r\n \r\n \r\n The statement is not available. Try switching between FactSet-Reuters source.\r\n \r\n \r\n \r\n \r\n )}\r\n \r\n )\r\n}\r\n\r\nfunction Statements() {\r\n return (\r\n \r\n \r\n \r\n )\r\n}\r\n\r\nfunction StatementsSettingsSection() {\r\n const { settings, setSettings } = useFinancialsTableContext()\r\n\r\n const toggleSetting = (key: keyof StatementsType, value: StatementsType[keyof StatementsType]) => {\r\n setSettings({\r\n ...settings,\r\n [key]: value,\r\n })\r\n }\r\n\r\n const yoyGrowthLabel = React.useMemo(() => {\r\n const isQuarterlyTimeframe = settings.statementsTimeframe === StatementsTimeframeEnum.quarterly\r\n\r\n if (isQuarterlyTimeframe) {\r\n return 'QoQ Growth'\r\n }\r\n\r\n return 'YoY Growth'\r\n }, [settings.statementsTimeframe])\r\n\r\n return (\r\n
\r\n \r\n {\r\n toggleSetting(StatementsDataEnum.yoyChange, !settings[StatementsDataEnum.yoyChange])\r\n }}\r\n >\r\n {yoyGrowthLabel}\r\n \r\n {\r\n toggleSetting(StatementsDataEnum.yoyChangePct, !settings[StatementsDataEnum.yoyChangePct])\r\n }}\r\n >\r\n {`${yoyGrowthLabel} %`}\r\n \r\n \r\n\r\n \r\n {\r\n toggleSetting('statementsTimeframe', StatementsTimeframeEnum.annual)\r\n }}\r\n >\r\n Annual\r\n \r\n {\r\n toggleSetting('statementsTimeframe', StatementsTimeframeEnum.quarterly)\r\n }}\r\n >\r\n Quarterly\r\n \r\n \r\n
\r\n )\r\n}\r\n\r\nfunction isChartable(label: string) {\r\n switch (label) {\r\n case 'Period End Date':\r\n case 'Period Length':\r\n return false\r\n }\r\n\r\n return true\r\n}\r\n\r\nfunction parseData(data: Record, skipFirst: boolean) {\r\n const parsed: any = {}\r\n Object.keys(data).forEach((key) => {\r\n parsed[key] = data[key]\r\n .map((value, index) => {\r\n if (isChartable(key)) {\r\n let parsedValue\r\n if (value === '') {\r\n parsedValue = null\r\n } else {\r\n parsedValue = parseFloat(value.replace(/,/g, ''))\r\n }\r\n return {\r\n name: data['Period End Date'][index],\r\n value: parsedValue,\r\n }\r\n }\r\n return null\r\n })\r\n .slice(skipFirst ? 1 : 0)\r\n })\r\n\r\n return parsed as Record>\r\n}\r\n\r\nfunction isHighlightRow(label: string) {\r\n switch (label) {\r\n case 'Period End Date':\r\n case 'Total Revenue':\r\n case 'Total Premiums Earned':\r\n case 'Interest Income':\r\n case 'Gross Profit':\r\n case 'Total Operating Expense':\r\n case 'Operating Income':\r\n case 'Net Income Before Taxes':\r\n case 'Net Income':\r\n case 'Total Current Assets':\r\n case 'Total Assets':\r\n case 'Total Current Liabilities':\r\n case 'Total Liabilities':\r\n case 'Total Equity':\r\n case 'Total Liabilities and Equity':\r\n case 'Cash from Operating Activities':\r\n case 'Cash from Investing Activities':\r\n case 'Cash from Financing Activities':\r\n case 'Net Change in Cash':\r\n case 'Price To Earnings Ratio':\r\n case 'Price to Book Ratio':\r\n case 'Price to Free Cash Flow':\r\n return true\r\n }\r\n\r\n return false\r\n}\r\n\r\ntype StatementsTableProps = Pick\r\n\r\nfunction StatementsTable({ data, currency }: StatementsTableProps) {\r\n const { settings } = useFinancialsTableContext()\r\n const skipFirst = data?.['Period End Date'][0] === 'TTM'\r\n const parsedData = data ? parseData(data, skipFirst) : null\r\n\r\n const yoyData = React.useMemo(\r\n () =>\r\n parsedData\r\n ? Object.entries(parsedData).reduce<\r\n Record<\r\n string,\r\n {\r\n change: Array\r\n changePct: Array\r\n }\r\n >\r\n >((acc, [key, values]) => {\r\n if (!isChartable(key)) {\r\n return acc\r\n }\r\n const yoyData: Array<{ change: number | null; changePct: number | null }> = []\r\n let lastValue: number | null = null\r\n\r\n // values are in DESC order\r\n const reversedValues = [...values].reverse()\r\n\r\n reversedValues.forEach(({ value }) => {\r\n const isValidValue = typeof value === 'number'\r\n if (!isValidValue || lastValue === null || lastValue === 0) {\r\n yoyData.push({ change: null, changePct: null })\r\n } else {\r\n const change = value - lastValue\r\n yoyData.push({ change, changePct: (change / Math.abs(lastValue)) * 100 })\r\n }\r\n\r\n if (isValidValue) lastValue = value\r\n })\r\n\r\n const reversedYoyData = [...yoyData].reverse()\r\n return {\r\n ...acc,\r\n [key]: {\r\n change: reversedYoyData.map(({ change }) => change),\r\n changePct: reversedYoyData.map(({ changePct }) => changePct),\r\n },\r\n }\r\n }, {})\r\n : {},\r\n [parsedData]\r\n )\r\n\r\n const yoyGrowthLabel = React.useMemo(() => {\r\n const isQuarterlyTimeframe = settings.statementsTimeframe === StatementsTimeframeEnum.quarterly\r\n\r\n if (isQuarterlyTimeframe) {\r\n return 'QoQ Growth'\r\n }\r\n\r\n return 'YoY Growth'\r\n }, [settings.statementsTimeframe])\r\n\r\n if (!data || !parsedData) return null\r\n\r\n const hasRedesignEnabled = FinvizSettings?.hasRedesignEnabled\r\n const cellClass = classnames('align-top', {\r\n 'snapshot-td2 h-6 !leading-4 !pt-[4px]': !hasRedesignEnabled,\r\n })\r\n const adRowIndexStart = !hasRedesignEnabled && data['Period Length'] ? 2 : 1\r\n\r\n return (\r\n <>\r\n \r\n \r\n {Object.keys(data).map((key, rowIndex) => {\r\n const hasYoYData = !!yoyData[key] && data[key].some((value) => value)\r\n return (\r\n \r\n \r\n {key}\r\n {hasYoYData && settings[StatementsDataEnum.yoyChange] && (\r\n <>\r\n
\r\n {yoyGrowthLabel}\r\n \r\n )}\r\n {hasYoYData && settings[StatementsDataEnum.yoyChangePct] && (\r\n <>\r\n
\r\n {`${yoyGrowthLabel} %`}\r\n \r\n )}\r\n \r\n \r\n {isChartable(key) && }\r\n \r\n {data[key].map((value, index) => {\r\n const changeIndex = skipFirst ? index - 1 : index\r\n const yoyChangeValue = yoyData[key]?.change[changeIndex] ?? null\r\n const yoyChangePctValue = yoyData[key]?.changePct[changeIndex] ?? null\r\n if (!FinvizSettings.hasUserPremium) {\r\n if (rowIndex === adRowIndexStart && index === 3) {\r\n return (\r\n \r\n \r\n \r\n

Upgrade your FINVIZ experience

\r\n

\r\n Join thousands of traders who make more informed decisions with our premium\r\n features. Real-time quotes, advanced visualizations, historical statements, and much\r\n more.\r\n

\r\n \r\n Learn more\r\n \r\n \r\n )\r\n }\r\n if (\r\n index > 2 &&\r\n ((hasRedesignEnabled && key !== 'Period End Date') ||\r\n (key !== 'Period End Date' && key !== 'Period Length'))\r\n ) {\r\n return null\r\n }\r\n }\r\n\r\n return (\r\n \r\n {value}\r\n {hasYoYData && settings[StatementsDataEnum.yoyChange] && (\r\n <>\r\n
\r\n \r\n {shortFormatNumber(yoyChangeValue, { defaultValue: '—' })}\r\n \r\n \r\n )}\r\n {hasYoYData && settings[StatementsDataEnum.yoyChangePct] && (\r\n <>\r\n
\r\n \r\n {yoyChangePctValue?.toFixed(2) ?? '—'}\r\n \r\n \r\n )}\r\n \r\n )\r\n })}\r\n \r\n )\r\n })}\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
values in Millions, {currency}
\r\n \r\n )\r\n}\r\n\r\nexport default Statements\r\n","import classNames from 'classnames'\r\nimport { isRedesignEnabled } from 'finviz-charts/app/utils'\r\nimport React from 'react'\r\n\r\nimport { ChartTypesSelect, StockDetailTimeframeBar } from '../../../../app/charts-lib'\r\nimport { Button } from '../../../components'\r\nimport { SpecificChartFunctionality } from '../../../constants'\r\nimport { QuoteContext } from '../QuoteContext'\r\n\r\ninterface Props {\r\n isStockDetailUpdating: boolean\r\n}\r\n\r\nconst hasRedesign = isRedesignEnabled()\r\nconst isPremium = window.FinvizSettings.hasUserPremium\r\n\r\nexport function StaticChartHeader({ isStockDetailUpdating }: Props) {\r\n const { index, ticker, period } = React.useContext(QuoteContext)\r\n\r\n return (\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n Share\r\n \r\n
\r\n
\r\n )\r\n}\r\n","import * as React from 'react'\r\n\r\nimport { round } from '../../../../app/backtest/utils'\r\nimport { parseRouteInitData } from '../../../util-routing'\r\nimport { QuoteContext } from '../QuoteContext'\r\nimport BarChart, { Bar } from './barChart'\r\n\r\nfunction convertData(endYear: number, values: any[]) {\r\n return values.map((value, index) => ({ name: endYear - index, value })).reverse() as unknown as Bar[]\r\n}\r\n\r\ninterface FAChartProps {\r\n year: number\r\n data: number[]\r\n title: string\r\n smallRoundPlaces?: number\r\n largeRoundPlaces?: number\r\n smallScale?: number\r\n largeScale?: number\r\n smallTitleSufix?: string\r\n largeTitleSufix?: string\r\n}\r\n\r\nfunction FAChart({\r\n year,\r\n data,\r\n title,\r\n smallRoundPlaces = 2,\r\n largeRoundPlaces = 0,\r\n smallScale = 1,\r\n largeScale = 1,\r\n smallTitleSufix = '',\r\n largeTitleSufix = '',\r\n}: FAChartProps) {\r\n const range = Math.max(...data.map((value) => Math.abs(value)).filter(Number))\r\n const isLarge = Math.abs(range) >= 1000\r\n const scale = isLarge ? largeScale : smallScale\r\n const values = data.map((value) => {\r\n const rounded = round(scale * value, isLarge ? largeRoundPlaces : smallRoundPlaces)\r\n return value == null || Number.isNaN(rounded) ? null : rounded\r\n })\r\n\r\n return (\r\n round(value, isLarge ? largeRoundPlaces : smallRoundPlaces)}\r\n width={280}\r\n height={150}\r\n marginRight={37}\r\n className=\"is-fa\"\r\n />\r\n )\r\n}\r\n\r\nexport default function FundamentalCharts() {\r\n const { index } = React.useContext(QuoteContext)\r\n\r\n const routeData = React.useMemo(\r\n () =>\r\n parseRouteInitData<{ year: number; values: Array }>({\r\n elementId: `fa-init-data-${index}`,\r\n removeElement: false,\r\n }),\r\n [index]\r\n )\r\n\r\n if (!routeData) return null\r\n\r\n return (\r\n <>\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n )\r\n}\r\n","export const etfHoldingsAsyncModule = {\r\n importFn: () => import(/* webpackChunkName: \"etf-holdings-widget\" */ './module-entry'),\r\n cacheKey: 'etf-holdings-widget',\r\n}\r\n","import { withNotificationContext } from '../../../components/notification'\r\nimport { Spinner } from '../../../components/spinner'\r\nimport { useAsyncModule } from '../../../services/async-modules-utils'\r\nimport { etfHoldingsAsyncModule } from './async-modules'\r\n\r\nfunction LoadingFallback() {\r\n const widgetClass =\r\n 'ml-3 mt-3 flex max-h-85 min-h-85 min-w-152 max-w-175 shrink grow basis-0 rounded-md border border-primary justify-center items-center'\r\n return (\r\n
\r\n {Array.from(Array(2)).map((_, index) => (\r\n
\r\n \r\n
\r\n ))}\r\n
\r\n )\r\n}\r\n\r\nfunction ETFHoldings() {\r\n const [etfHoldingsModule] = useAsyncModule({\r\n ...etfHoldingsAsyncModule,\r\n shouldLoadModule: true,\r\n errorSeverity: 'high',\r\n })\r\n const ETFHoldingsComponent = etfHoldingsModule?.ETFHoldings\r\n return ETFHoldingsComponent ? : \r\n}\r\n\r\nexport default withNotificationContext(ETFHoldings)\r\n","import * as React from 'react'\r\n\r\nimport { QuoteNavigation } from './Navigation'\r\nimport { QuoteContext } from './QuoteContext'\r\nimport { Perf } from './components/ComparePerformance'\r\nimport { FundFlowsChart } from './components/FundFlowsChart'\r\nimport { InsiderTradingVolumeChart } from './components/InsiderTradingChart'\r\nimport { InstitutionalOwnership } from './components/InstitutionalOwnership'\r\nimport { QuotePortal } from './components/Portal'\r\nimport { ChartContextQuoteHeader, ManualInitQuoteHeader } from './components/Price'\r\nimport { QuoteChart } from './components/QuoteChart'\r\nimport Statements from './components/Statements/statements'\r\nimport { StaticChartHeader } from './components/StaticChartHeader'\r\nimport FundamentalCharts from './components/fundamentalCharts'\r\nimport EtfHoldings from './etf-holdings'\r\nimport { QuoteSubview, QuoteView } from './types'\r\n\r\nconst PRICE_STATIC = document.querySelectorAll('.js-quote-price-static')\r\nconst PRICE_ROOTS = document.querySelectorAll('.js-quote-price-root')\r\n\r\nconst NAVIGATION_STATIC = document.querySelectorAll('.js-quote-navigation-static')\r\nconst NAVIGATION_ROOTS = document.querySelectorAll('.js-quote-navigation-root')\r\n\r\nconst STATIC_CHART_HEADER_ROOTS = document.querySelectorAll('.quote-menu')\r\n\r\nconst FUNDAMENTAL_CHARTS_ROOTS = document.querySelectorAll('.js-quote-fa')\r\n\r\nconst STATEMENTS_ROOTS = document.querySelectorAll('#statements')\r\n\r\nconst INSIDER_CHART_ROOTS = document.querySelectorAll('.insider-trading-chart')\r\n\r\nconst MANAGERS_AND_FUNDS_ROOTS = document.querySelectorAll('.managers-and-funds')\r\n\r\nexport function QuotePortalComponents({ isStockDetailUpdating }: { isStockDetailUpdating: boolean }) {\r\n const context = React.useContext(QuoteContext)\r\n\r\n const ETF_HOLDINGS_STATIC = document.querySelector(`.js-etf-holdings-static-${context.ticker}`)\r\n const ETF_HOLDINGS_ROOTS = document.querySelector(`.js-etf-holdings-root-${context.ticker}`)\r\n const isETF = !!ETF_HOLDINGS_ROOTS && !!ETF_HOLDINGS_STATIC\r\n\r\n return (\r\n <>\r\n {context.index === 0 && !window.isIdeaNotFoundPage && (\r\n \r\n \r\n {context.view === QuoteView.ChartDetail || context.subview === QuoteSubview.ShortInterest ? (\r\n \r\n ) : (\r\n \r\n )}\r\n \r\n \r\n )}\r\n\r\n \r\n \r\n \r\n\r\n {context.view === QuoteView.ChartDetail && (\r\n \r\n {context.index === 0 && }\r\n\r\n {context.index > 0 && (\r\n \r\n \r\n \r\n )}\r\n \r\n )}\r\n\r\n {context.subview === QuoteSubview.ComparePerf && window.FinvizQuoteTickers && context.index === 0 && }\r\n\r\n {isETF && (\r\n \r\n <>\r\n \r\n \r\n \r\n \r\n )}\r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n )\r\n}\r\n","import * as React from 'react'\r\nimport { useLocation } from 'react-router-dom'\r\n\r\nimport { decodeQueryString } from '../../../../app/queryString'\r\n\r\nconst CORRELATION_LINKS_CONTAINER_SELECTOR = 'js-quote-correlation-links-container'\r\nconst MULTITICKER_CHART_ELEMENT_SELECTOR = 'js-multi-ticker-chart'\r\nconst SET_SEARCH_EXT_SELECTOR = 'js-set-search-ext-argument'\r\n\r\nexport function useStockDetailUpdater() {\r\n const location = useLocation()\r\n const { p, ty } = decodeQueryString(location.search)\r\n const isInitializedRef = React.useRef(false)\r\n const [isStockDetailUpdating, setIsStockDetailUpdating] = React.useState(false)\r\n\r\n React.useEffect(() => {\r\n const multiTickerElements = document.getElementsByClassName(MULTITICKER_CHART_ELEMENT_SELECTOR)\r\n const correlationElements = document.getElementsByClassName(CORRELATION_LINKS_CONTAINER_SELECTOR)\r\n const abortController = new AbortController()\r\n\r\n if (isInitializedRef.current) {\r\n if (multiTickerElements.length > 0) setIsStockDetailUpdating(true)\r\n\r\n fetch(location.pathname + location.search, { signal: abortController.signal })\r\n .then((response) => response.text())\r\n .then((text) => {\r\n const virtualDOM = new DOMParser().parseFromString(text, 'text/html')\r\n\r\n // Multiticker update\r\n if (multiTickerElements.length > 0) {\r\n const multiTickerHtmlElements = Array.from(multiTickerElements) as HTMLImageElement[]\r\n const newMultiTickerHtmlElements = Array.from(\r\n virtualDOM.getElementsByClassName(MULTITICKER_CHART_ELEMENT_SELECTOR)\r\n ) as HTMLImageElement[]\r\n\r\n if (newMultiTickerHtmlElements?.length === multiTickerHtmlElements.length) {\r\n multiTickerHtmlElements.forEach((element, index) => {\r\n element.onload = () => setIsStockDetailUpdating(false)\r\n element.src = newMultiTickerHtmlElements[index].src\r\n })\r\n } else {\r\n setIsStockDetailUpdating(false)\r\n }\r\n }\r\n\r\n // Correlation update\r\n const correlationLinksTableCellHtmlElements = Array.from(correlationElements) as HTMLTableCellElement[]\r\n const newCorrelationLinksTableCellHtmlElements = Array.from(\r\n virtualDOM.getElementsByClassName(CORRELATION_LINKS_CONTAINER_SELECTOR)\r\n ) as HTMLTableCellElement[]\r\n\r\n if (newCorrelationLinksTableCellHtmlElements?.length === correlationLinksTableCellHtmlElements.length) {\r\n correlationLinksTableCellHtmlElements.forEach((element, index) => {\r\n element.innerHTML = newCorrelationLinksTableCellHtmlElements[index].innerHTML\r\n })\r\n }\r\n\r\n // Search function update\r\n const newsearchFunctionWrapperElement = virtualDOM.getElementById(SET_SEARCH_EXT_SELECTOR) as HTMLDivElement\r\n if (newsearchFunctionWrapperElement?.dataset.setSearchExtArgument) {\r\n FinvizSettings.quoteSearchExt = newsearchFunctionWrapperElement.dataset.setSearchExtArgument\r\n }\r\n })\r\n .catch((err) => {\r\n setIsStockDetailUpdating(false)\r\n if (err.name !== 'AbortError') {\r\n Sentry.captureException(err)\r\n }\r\n })\r\n }\r\n isInitializedRef.current = true\r\n return () => {\r\n abortController.abort()\r\n }\r\n // We don't want to trigger effect on any location change just if period or type change\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [p, ty])\r\n\r\n return { isStockDetailUpdating }\r\n}\r\n","import { useSearchParams } from 'react-router-dom'\r\n\r\nimport { useCheckNonIdeaChartMissingConfig } from '../../../hooks/use-check-non-idea-chart-missing-config'\r\nimport { QuotePortalComponents } from '../PortalComponents'\r\nimport { QuoteContextProvider } from '../QuoteContext'\r\nimport { useStockDetailUpdater } from '../hooks/use-stock-detail-updater'\r\nimport { useToggleRatings } from '../hooks/useToggleRatings'\r\nimport { QuoteQuery } from '../types'\r\n\r\nexport default function QuoteSharedWrapper() {\r\n useCheckNonIdeaChartMissingConfig()\r\n useToggleRatings()\r\n\r\n const [query] = useSearchParams()\r\n const tickers = query.get(QuoteQuery.Ticker)!.split(',')\r\n const { isStockDetailUpdating } = useStockDetailUpdater()\r\n\r\n return tickers.map((ticker, index) => (\r\n \r\n \r\n \r\n ))\r\n}\r\n","import * as React from 'react'\r\n\r\nexport function useToggleRatings() {\r\n React.useEffect(() => {\r\n const revealButtons = document.querySelectorAll('.js-reveal-ratings-button')\r\n\r\n function onToggleRatingsClick(ev: MouseEvent) {\r\n ev.preventDefault()\r\n\r\n const button = ev.currentTarget as HTMLElement\r\n const ratingsRowWithTable = button.previousElementSibling\r\n\r\n ratingsRowWithTable?.querySelectorAll('table tr').forEach((rating, index, rows) => {\r\n if (rating.classList.contains('is-last')) {\r\n rating.classList.remove('is-last')\r\n }\r\n\r\n rating.classList.remove('hidden')\r\n\r\n if (index === rows.length - 1) {\r\n rating.classList.add('is-last')\r\n }\r\n })\r\n\r\n button.classList.add('hidden')\r\n window.gtag && window.gtag('event', 'click', { event_category: 'reveal-ratings' })\r\n }\r\n\r\n revealButtons.forEach((button) => button.addEventListener('click', onToggleRatingsClick))\r\n\r\n return () => {\r\n revealButtons.forEach((button) => button.removeEventListener('click', onToggleRatingsClick))\r\n }\r\n }, [])\r\n}\r\n","import { isForexFuturesCryptoPage } from 'finviz-charts/app/utils/chart'\r\nimport * as React from 'react'\r\n\r\nimport {\r\n RootChartConfigObject,\r\n getIntradayChartConfig,\r\n useChartLayoutGlobalModelAsync,\r\n useModelState,\r\n} from '../../../../app/charts-lib'\r\nimport { TIMEFRAME } from '../../../constants'\r\nimport { useWindowSize } from '../../../hooks/use-window-size'\r\n\r\nexport function getChartLayoutSizeConfig(\r\n layoutConfig: Pick<\r\n RootChartConfigObject,\r\n 'idea' | 'barWidth' | 'barMargin' | 'charts' | 'specificChartFunctionality'\r\n >,\r\n p = TIMEFRAME.d\r\n) {\r\n const { clientWidth } = document.body\r\n const { premarket, aftermarket, dateRange } = layoutConfig.charts[0]\r\n const maxChartWidth = clientWidth - 40 // 40px left right chart padding = (19px * 2 for margin left/right) + (1px * 2 for border)\r\n let width = 990\r\n let barWidth = 3\r\n let barMargin = 1\r\n let timeframeMinutes = 0\r\n const isForexFuturesCrypto =\r\n layoutConfig.specificChartFunctionality && isForexFuturesCryptoPage(layoutConfig.specificChartFunctionality)\r\n\r\n switch (p) {\r\n case TIMEFRAME.i1:\r\n timeframeMinutes = 1\r\n barWidth = 1\r\n if (premarket || aftermarket || clientWidth < 1650) {\r\n barMargin = 0\r\n }\r\n break\r\n case TIMEFRAME.i2:\r\n timeframeMinutes = 2\r\n break\r\n case TIMEFRAME.i3:\r\n timeframeMinutes = 3\r\n if (premarket && aftermarket && clientWidth <= 1505) {\r\n barWidth = 2\r\n }\r\n break\r\n case TIMEFRAME.i5:\r\n timeframeMinutes = 5\r\n barWidth = 5\r\n barMargin = clientWidth >= 1100 ? 2 : 1\r\n break\r\n case TIMEFRAME.i10:\r\n width = 1058 // 39bars per day * 5days * 5px per bar + 35px left offset + 48px right offset\r\n barMargin = 0\r\n break\r\n case TIMEFRAME.i15:\r\n case TIMEFRAME.i30:\r\n width = 1019\r\n break\r\n case TIMEFRAME.h:\r\n width = 1008\r\n break\r\n case TIMEFRAME.h2:\r\n case TIMEFRAME.h4:\r\n width = 1020\r\n break\r\n case TIMEFRAME.d:\r\n width = 1282\r\n break\r\n case TIMEFRAME.w:\r\n case TIMEFRAME.m:\r\n width = 994\r\n break\r\n }\r\n\r\n switch (p) {\r\n case TIMEFRAME.i1:\r\n case TIMEFRAME.i2:\r\n case TIMEFRAME.i3:\r\n case TIMEFRAME.i5:\r\n const commonProps = {\r\n timeframeMinutes,\r\n barWidthWithMargin: barWidth + 2 + barMargin,\r\n hasAftermarket: aftermarket,\r\n hasPremarket: premarket,\r\n }\r\n width = getIntradayChartConfig({\r\n ...commonProps,\r\n maxWidth: maxChartWidth,\r\n canCropChart: !dateRange,\r\n }).chartWidthWithOffset\r\n break\r\n }\r\n\r\n // If FFC chart use DAILY type width\r\n if (isForexFuturesCrypto) width = 1282\r\n\r\n // If chart is wider than available space in vieport override width\r\n if (maxChartWidth <= width) {\r\n width = Math.max(994, maxChartWidth)\r\n if (p === TIMEFRAME.d) {\r\n barWidth = 2\r\n barMargin = 0\r\n width = 991\r\n }\r\n }\r\n\r\n // If idea chart or FFC chart use bar configs from layout\r\n if (layoutConfig.idea || isForexFuturesCrypto) {\r\n barWidth = layoutConfig.barWidth!\r\n barMargin = layoutConfig.barMargin!\r\n }\r\n\r\n return {\r\n width,\r\n barWidth,\r\n barMargin,\r\n }\r\n}\r\n\r\nexport function useChartLayoutWidthWatch() {\r\n const { innerWidth } = useWindowSize()\r\n const { chartLayoutModel } = useChartLayoutGlobalModelAsync()\r\n const unwatchedFirstChart = React.useMemo(() => chartLayoutModel?.charts().all()[0] ?? null, [chartLayoutModel])\r\n const chartModel = useModelState(unwatchedFirstChart, { watchProperties: ['quote'] })\r\n const quote = useModelState(chartModel?.quote() ?? null, { watchProperties: ['ticker', 'timeframe', 'isFetching'] })\r\n const ideaId = chartLayoutModel?.idea?.id\r\n\r\n React.useEffect(() => {\r\n const settings = !ideaId ? chartLayoutModel?.settings : null\r\n const timeframe = quote?.timeframe\r\n if (chartLayoutModel && timeframe && settings) {\r\n const { width, barWidth, barMargin } = getChartLayoutSizeConfig(chartLayoutModel.toConfig(), timeframe)\r\n const newSettings = JSON.parse(JSON.stringify(settings))\r\n newSettings.ChartSettings.center.barWidth = barWidth\r\n newSettings.IndicatorSettings.center.barWidth = barWidth\r\n newSettings.ChartSettings.center.barMargin = barMargin\r\n newSettings.IndicatorSettings.center.barMargin = barMargin\r\n chartLayoutModel.updateAttributes({ width, settings: newSettings })\r\n }\r\n // We don't want to trigger this effect on any chartLayoutModel change\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [quote?.premarket, quote?.aftermarket, quote?.timeframe, ideaId, innerWidth])\r\n}\r\n"],"names":["round","n","places","arguments","length","undefined","Math","Number","toFixed","format","totalReturn","maxDrawdown","sharpeRatio","calmarRatio","CAGR","cagr","volatility","numberOfTrades","positiveDays","negativeDays","bestMonth","worstMonth","figureSpace","BACKTEST_MIN_MAX_DATES","Object","freeze","min","Date","max","getStaticChartConfig","_ref","width","height","ticker","timeframe","paneElements","specificChartFunctionality","SpecificChartFunctionality","default","colorsOverride","theme","colors","getCustomColorsFromCookies","refreshData","layout","LayoutType","barWidth","barMargin","scrollable","editable","charts","premarket","aftermarket","dateRange","scale","ScaleType","Linear","leftOffset","instrument","Instrument","Stock","stretch","panes","elements","JSON","parse","getParsedCookies","IC_PUBLISHER_ID","AdTagName","tagDefinition","IC_TickerInContent","placements","style","minHeight","IC_MapsLeftRail","IC_Statements","IC_Groups","hasInvestingChannelAds","tracking","InvestingChannel","getInvestingChannelPage","page","create","window","InvestingChannelQueue","push","config","UAT","Run","e","console","error","destroy","useInvestingChannelAds","deps","React","AdTag","name","position","props","tagName","tagProps","placementName","_jsx","id","getInitChartConfig","initialConfig","initialTA","FinvizSettings","TA","stringify","hasUserPremium","Utils","isMobile","COTs","convertTa","CartesianGrid","vertical","RechartsCartesianGrid","stroke","strokeDasharray","className","classNames","displayName","LabelInner","color","viewBox","dx","dy","angle","children","x","y","_jsxs","fontSize","fontWeight","textAnchor","dominantBaseline","transform","CHART_ITEM_COLORS","Label","_ref2","RechartsLabel","content","DateFormat","TICK_STYLE","fill","dateAxisFormatter","value","outFormat","parseAsNY","breakOnYear","isFinite","getTime","date","getDate","getMonth","MonthSingleChar","getFullYear","toString","substring","XAxis","RechartsXAxis","static","defaultProps","tickLine","axisLine","tick","dataKey","type","interval","useCheckNonIdeaChartMissingConfig","location","useLocation","i","decodeQueryString","search","isIdeaNotFoundPage","reload","useWindowSize","throttleWaitInMs","isWatching","size","setSize","clientWidth","document","documentElement","innerWidth","innerHeight","handleResize","throttle","addEventListener","cancel","removeEventListener","PADDING","getChartsDimensions","chartElementId","containerElement","getElementById","box","getBoundingClientRect","getChartConfig","idea","chartsDimensions","chartConfig","assign","FinvizChartsSettings","ideaChart","editors","newCharts","alignChartsToRight","tickers","map","index","periods","ranges","taConfig","getInstrumentForTicker","hasChartEvents","initIdeaQuotes","quotes","hasPatterns","includes","quote","hasOwnProperty","drawMinutesPerDay","marketStartMinutes","premarketLengthMinutes","aftermarketLengthMinutes","ideaID","Quote","QuoteContext","period","TIMEFRAME","d","view","subview","QuoteContextProvider","query","useSearchParams","get","QuoteQuery","Type","Period","contextValue","getQuoteView","getQuoteSubview","Provider","QuoteChart","configOverride","TAOverride","chartEl","CHART_ELEMENT_ID","useChartLayoutWidthWatch","globalChartConfig","ideaQuotes","quoteData","p","defaultPeriod","sizeConfig","getChartLayoutSizeConfig","hasDarkTheme","Theme","dark","light","quotePage","chart","FREE_DATE_RANGES","current","ReactDOM","ChartLayoutWithGlobalState","parentElement","QuotePortalContext","rootElement","staticElement","toggleStaticElement","QuotePortal","staticElements","roots","context","elementIndex","NodeList","Array","isArray","isEnabled","setIsEnabled","elementToHide","elementToShow","enabled","hideElement","element","classList","add","showElement","remove","toggleElements","toggleFn","forEach","useToggleStaticElements","portalContextValue","prevValue","ErrorBoundary","fallback","onError","QuoteLinksContext","chartLayoutModel","URL","href","QuoteLinksWrapper","info","isPremium","useChartLayoutGlobalModelAsync","chartModel","useModelState","activeChart","watchProperties","generateChartLayoutRouterPath","useChartModelCustomDateRangeValues","pathname","origin","useChartTimeframePathWatch","NavigationLink","isEliteOnly","utmCampaign","getLink","reloadDocument","preserveQueryKeys","Ticker","DateRange","removeQueryKeys","additionalQueryValues","quoteContext","linkContext","linkUrl","getElitePageLink","getNavigationLinkUrl","Link","to","CreateAlertLink","dialog","useDialogState","isVisible","useState","createAlertModule","useAsyncModule","createAlertAsyncModule","shouldLoadModule","CreateAlert","_Fragment","onClick","gtag","event_category","ctrlKey","metaKey","preventDefault","show","Dialog","state","Spinner","SaveToPortfolioLink","saveToPortfolioModule","saveToPortfolioAsyncModule","SaveToPortfolio","email","QuoteNavigation","hasShortInterest","dataset","shortinterest","QuoteView","ChartDetail","QuoteSubview","ComparePerf","ShortInterest","Financials","hasTrafficPageEnabled","Traffic","Options","LatestFilings","redesignEnabled","hasRedesignEnabled","colorScaleClass","monthNames","Chart","Component","containerRef","shouldComponentUpdate","nextProps","arr1","arr2","arraysEqual","this","render","tickerQuote","select","q","close","ChartElementType","PerfChart","fromDate","fromDay","toDate","toDay","overlays","quotePerf","ref","opacity","ChartLayout","Table","months","rows","groupsCount","ceil","tdClasses","classnames","trs","g","splice","month","row","col","monthIndex","parseFloat","total","cellPadding","cellSpacing","border","Perf","constructor","super","now","year","padStart","label","tickersInput","FinvizQuoteTickers","join","fromMonth","toMonth","minDate","formatDateToStringUS","dateFns","years","maxDate","loading","from","monthsToShow","filter","quotesPerf","obj","perf","dateFromUnixTimestamp","cols","isNaN","onSubmit","_onSubmit","padding","onChange","setState","target","top","right","display","DatePicker","newValue","_onDatePickerChange","readOnly","_onMonthChange","bind","option","refetchQuotes","_fetch","componentDidMount","updateQuoteData","componentWillUnmount","unbind","dailyQuotes","o","h","l","c","v","open","high","low","volume","clearCachedData","updateAttributes","forceUpdate","_this","async","isRefetch","t","all","fetchData","fetchType","QuoteFetchType","Refetch","NewerData","m","getAll","concat","getSanitizedTicker","split","formattedDate","ChartBox","FlowsChartDataKeys","AXIS_LABEL_OFFSET","tooltipValueFormatter","formatted","shortFormatDollar","Aum","RedGreenText","rightContent","FundFlowsChart","initData","routeData","parseRouteInitData","elementId","removeElement","dateStrToTimestamp","monthlyTicks","startingTimestamp","endingTimestamp","dayOfMonth","ticks","endingDate","initTimestamp","startDate","getMonthlyTicks","ChartWrapper","isHoverHighlight","ComposedChart","data","margin","left","domain","tickFormatter","MonthShort","YAxis","yAxisId","tickCount","orientation","dataMin","dataMax","absMax","abs","Tooltip","formatLabel","MonthShortDayNumYearFull","formatValue","TooltipRow","Flows","Line","dot","Bar","radius","CHART_HEIGHT","BAR_WIDTH","BarType","InsiderVolumeBar","newX","payload","isCenteredBar","saleAggregated","buyAggregated","Sale","Rectangle","background","BarInner","Buy","tooltipTitleFormatter","startOfMonth","endDate","endOfMonth","toLocaleString","startDay","tooltipDataFormatter","_","fullTooltipPayload","insider","tradeCount","buyTransactionCount","saleTransactionCount","isZeroValue","valueToUse","defaultValue","InsiderTradingVolumeChart","chartData","setChartData","hasInsiderTradingHistory","some","monthlyData","fromTimestamp","toTimestamp","currentTimestamp","currentClose","barToDataIndex","filterDataForChart","getInstrument","options","cachePredicate","fetchQuoteData","barGap","barCategoryGap","xAxisId","hide","cursor","CursorBar","numberOfDatapoints","valueClass","shape","InstitutionalOwnershipType","getInvestorLink","investorId","Funds","isRedesignEnabled","commonTdClassName","InstitutionalOwnership","managersItems","hasManagersItems","fundsItems","hasFundsItems","managersOwnership","fundsOwnership","institutionalOwnership","setInstitutionalOwnership","Managers","items","Heading","level","ChipSwitch","rounding","ChipSwitchButton","disabled","active","TableBody","percOwnership","TableRow","TableCell","hasPadding","align","TableAlign","Right","formatNumber","suffix","QuotePrice","title","dateLabel","price","changeUsd","changePct","fractions","hasValue","formatDate","RedGreenMultiline","showPlusSign","CHANGE_UPATE_EVENTS","QUOTE_MODEL_CHANGE_EVENTS","useChartContextPrices","first","listenOnEvents","quoteModel","prevClose","lastClose","lastTime","lastDate","afterClose","afterTime","ChartContextQuoteHeader","hasData","QuoteHeaderContent","ManualInitQuoteHeader","withCompleteLayoutModelInit","withQuotePolling","modelProperties","chart_layout","maxBars","fetchAndMapInitialQuote","isChange","isAfterChange","afterDate","afterhoursTitle","BarChart","svgRef","createRef","renderChart","componentDidUpdate","_prevData","innerHTML","xAxisRotate","marginRight","totalWidth","totalHeight","d3","rangeRound","range","nice","yFormat","valueFormatter","tickFormat","svg","property","append","attr","xAxis","yAxis","call","tickSize","tickSizeOuter","selectAll","text","getHeight","isOutside","enter","bandwidth","outside","StatementsDataEnum","StatementsTimeframeEnum","DEFAULT_SETTINGS","yoyChange","yoyChangePct","statementsTimeframe","annual","unknown","bars","transition","exit","EliteHoverAd","Icon","BarChartWrapper","hover","Ariakit","placement","showTimeout","portal","BarChartBig","DEFAULT_SOURCE","_getDefaultSource","getValue","getTimeframeFromStatementsSettingsTimeframe","quarterly","StatementsComponent","settings","useFinancialsTableContext","pageRef","source","sheet","currency","keys","response","fetch","json","_renderSheetLink","paddingLeft","setValue","StatementsSettingsSection","StatementsTable","setSettings","toggleSetting","key","yoyGrowthLabel","isChartable","isHighlightRow","skipFirst","parsedData","parsed","parsedValue","replace","slice","parseData","yoyData","entries","reduce","acc","values","lastValue","reverse","_ref3","isValidValue","change","reversedYoyData","_ref4","_ref5","cellClass","adRowIndexStart","rowIndex","hasYoYData","changeIndex","yoyChangeValue","yoyChangePctValue","rowSpan","colSpan","shortFormatNumber","FinancialsTableContextProvider","defaultSettings","cookieKey","hasRedesign","StaticChartHeader","isStockDetailUpdating","ChartTypesSelect","specificFunctionality","StockDetailTimeframeBar","chartIndex","isDateRangeAvailable","isLoadingOverride","isScrollIntoViewEnabled","Button","leftContent","convertData","endYear","FAChart","smallRoundPlaces","largeRoundPlaces","smallScale","largeScale","smallTitleSufix","largeTitleSufix","isLarge","rounded","FundamentalCharts","etfHoldingsAsyncModule","importFn","cacheKey","LoadingFallback","withNotificationContext","etfHoldingsModule","errorSeverity","ETFHoldingsComponent","ETFHoldings","PRICE_STATIC","querySelectorAll","PRICE_ROOTS","NAVIGATION_STATIC","NAVIGATION_ROOTS","STATIC_CHART_HEADER_ROOTS","FUNDAMENTAL_CHARTS_ROOTS","STATEMENTS_ROOTS","INSIDER_CHART_ROOTS","MANAGERS_AND_FUNDS_ROOTS","QuotePortalComponents","ETF_HOLDINGS_STATIC","querySelector","ETF_HOLDINGS_ROOTS","isETF","EtfHoldings","Statements","CORRELATION_LINKS_CONTAINER_SELECTOR","MULTITICKER_CHART_ELEMENT_SELECTOR","SET_SEARCH_EXT_SELECTOR","QuoteSharedWrapper","revealButtons","onToggleRatingsClick","ev","button","currentTarget","ratingsRowWithTable","previousElementSibling","rating","contains","ty","isInitializedRef","setIsStockDetailUpdating","multiTickerElements","getElementsByClassName","correlationElements","abortController","AbortController","signal","then","virtualDOM","DOMParser","parseFromString","multiTickerHtmlElements","newMultiTickerHtmlElements","onload","src","correlationLinksTableCellHtmlElements","newCorrelationLinksTableCellHtmlElements","newsearchFunctionWrapperElement","setSearchExtArgument","quoteSearchExt","catch","err","Sentry","captureException","abort","useStockDetailUpdater","layoutConfig","body","maxChartWidth","timeframeMinutes","isForexFuturesCrypto","isForexFuturesCryptoPage","i1","i2","i3","i5","i10","i15","i30","h2","h4","w","commonProps","barWidthWithMargin","hasAftermarket","hasPremarket","getIntradayChartConfig","maxWidth","canCropChart","chartWidthWithOffset","unwatchedFirstChart","ideaId","toConfig","newSettings","ChartSettings","center","IndicatorSettings"],"sourceRoot":""}