\n\t\t\t{activeLicenseV3?.state === LicenseState.TERMINATED && (\n\t\t\t\t<>\n\t\t\t\t\tYour SigNoz license is terminated, enterprise features have been disabled.\n\t\t\t\t\tPlease contact support at{' '}\n\t\t\t\t\t
support@signoz.io for new license\n\t\t\t\t>\n\t\t\t)}\n\t\t\t{activeLicenseV3?.state === LicenseState.EXPIRED && (\n\t\t\t\t<>\n\t\t\t\t\tYour SigNoz license has expired. Please contact support at{' '}\n\t\t\t\t\t
support@signoz.io for renewal to\n\t\t\t\t\tavoid termination of license as per our{' '}\n\t\t\t\t\t
\n\t\t\t\t\t\tterms of service\n\t\t\t\t\t\n\t\t\t\t>\n\t\t\t)}\n\t\t\t{activeLicenseV3?.state === LicenseState.CANCELLED && (\n\t\t\t\t<>\n\t\t\t\t\tYour SigNoz license is cancelled. Please contact support at{' '}\n\t\t\t\t\t
support@signoz.io for reactivation\n\t\t\t\t\tto avoid termination of license as per our{' '}\n\t\t\t\t\t
\n\t\t\t\t\t\tterms of service\n\t\t\t\t\t\n\t\t\t\t>\n\t\t\t)}\n\n\t\t\t{activeLicenseV3?.state === LicenseState.DEFAULTED && (\n\t\t\t\t<>\n\t\t\t\t\tYour SigNoz license is defaulted. Please clear the bill to continue using\n\t\t\t\t\tthe enterprise features. Contact support at{' '}\n\t\t\t\t\t
support@signoz.io to avoid\n\t\t\t\t\ttermination of license as per our{' '}\n\t\t\t\t\t
\n\t\t\t\t\t\tterms of service\n\t\t\t\t\t\n\t\t\t\t>\n\t\t\t)}\n\n\t\t\t{activeLicenseV3?.state === LicenseState.EVALUATION_EXPIRED && (\n\t\t\t\t<>\n\t\t\t\t\tYour SigNoz trial has ended. Please contact support at{' '}\n\t\t\t\t\t
support@signoz.io for next steps to\n\t\t\t\t\tavoid termination of license as per our{' '}\n\t\t\t\t\t
\n\t\t\t\t\t\tterms of service\n\t\t\t\t\t\n\t\t\t\t>\n\t\t\t)}\n\t\t
\n\t);\n\n\treturn (\n\t\t\n\t\t\t\n\t\t\t\t{pageTitle}\n\t\t\t\n\n\t\t\t{showTrialExpiryBanner && !showPaymentFailedWarning && (\n\t\t\t\t\n\t\t\t\t\tYou are in free trial period. Your free trial will end on{' '}\n\t\t\t\t\t
{getFormattedDate(trialInfo?.trialEnd || Date.now())}.\n\t\t\t\t\t{user.role === USER_ROLES.ADMIN ? (\n\t\t\t\t\t\t
\n\t\t\t\t\t\t\t{' '}\n\t\t\t\t\t\t\tPlease{' '}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tupgrade\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tto continue using SigNoz features.\n\t\t\t\t\t\t\n\t\t\t\t\t) : (\n\t\t\t\t\t\t'Please contact your administrator for upgrading to a paid plan.'\n\t\t\t\t\t)}\n\t\t\t\t
\n\t\t\t)}\n\n\t\t\t{showWorkspaceRestricted && renderWorkspaceRestrictedBanner()}\n\n\t\t\t{!showTrialExpiryBanner && showPaymentFailedWarning && (\n\t\t\t\t\n\t\t\t\t\tYour bill payment has failed. Your workspace will get suspended on{' '}\n\t\t\t\t\t
\n\t\t\t\t\t\t{getFormattedDateWithMinutes(\n\t\t\t\t\t\t\tdayjs(activeLicenseV3?.event_queue?.scheduled_at).unix() || Date.now(),\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t.\n\t\t\t\t\t\n\t\t\t\t\t{user.role === USER_ROLES.ADMIN ? (\n\t\t\t\t\t\t
\n\t\t\t\t\t\t\t{' '}\n\t\t\t\t\t\t\tPlease{' '}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tpay the bill\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tto continue using SigNoz features.\n\t\t\t\t\t\t\n\t\t\t\t\t) : (\n\t\t\t\t\t\t' Please contact your administrator to pay the bill.'\n\t\t\t\t\t)}\n\t\t\t\t
\n\t\t\t)}\n\n\t\t\t\n\t\t\t\t{isToDisplayLayout && !renderFullScreen && }\n\t\t\t\t\n\t\t\t\t\t}>\n\t\t\t\t\t\t\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t{isToDisplayLayout && !renderFullScreen && }\n\t\t\t\t\t\t\t\t\t{children}\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t\n\n\t\t\t{showAddCreditCardModal && }\n\t\t\n\t);\n}\n\ninterface AppLayoutProps {\n\tchildren: ReactNode;\n}\n\nexport default AppLayout;\n","import { Layout as LayoutComponent } from 'antd';\nimport styled from 'styled-components';\n\nexport const Layout = styled(LayoutComponent)`\n\t&&& {\n\t\tdisplay: flex;\n\t\tposition: relative;\n\t\tmin-height: calc(100vh - 8rem);\n\t\toverflow: hidden;\n\t\theight: 100%;\n\t\tflex-direction: column !important;\n\t}\n`;\n\nexport const LayoutContent = styled(LayoutComponent.Content)`\n\theight: 100%;\n\t&::-webkit-scrollbar {\n\t\twidth: 0.1rem;\n\t}\n`;\n\nexport const ChildrenContainer = styled.div`\n\tdisplay: flex;\n\tflex-direction: column;\n\theight: 100%;\n`;\n","import ROUTES from 'constants/routes';\n\nexport function getRouteKey(pathname: string): string {\n\tconst [routeKey] = Object.entries(ROUTES).find(\n\t\t([, value]) => value === pathname,\n\t) || ['DEFAULT'];\n\n\treturn routeKey;\n}\n","import { CSSProperties } from 'react';\n\nexport const ITEMS_PER_PAGE_OPTIONS = [25, 50, 100, 200];\n\nexport const DEFAULT_PER_PAGE_VALUE = 100;\n\nexport const defaultSelectStyle: CSSProperties = {\n\tminWidth: '6rem',\n};\n","import { LeftOutlined, RightOutlined } from '@ant-design/icons';\nimport { Button, Select } from 'antd';\nimport { DEFAULT_PER_PAGE_OPTIONS, Pagination } from 'hooks/queryPagination';\nimport { memo, useMemo } from 'react';\nimport { popupContainer } from 'utils/selectPopupContainer';\n\nimport { defaultSelectStyle } from './config';\nimport { Container } from './styles';\n\nfunction Controls({\n\toffset = 0,\n\tperPageOptions = DEFAULT_PER_PAGE_OPTIONS,\n\tisLoading,\n\ttotalCount,\n\tcountPerPage,\n\thandleNavigatePrevious,\n\thandleNavigateNext,\n\thandleCountItemsPerPageChange,\n\tisLogPanel = false,\n\tshowSizeChanger = true,\n}: ControlsProps): JSX.Element | null {\n\tconst isNextAndPreviousDisabled = useMemo(\n\t\t() => isLoading || countPerPage < 0 || totalCount === 0,\n\t\t[isLoading, countPerPage, totalCount],\n\t);\n\tconst isPreviousDisabled = useMemo(\n\t\t() => (isLogPanel ? false : offset <= 0 || isNextAndPreviousDisabled),\n\t\t[isLogPanel, isNextAndPreviousDisabled, offset],\n\t);\n\tconst isNextDisabled = useMemo(\n\t\t() =>\n\t\t\tisLogPanel ? false : totalCount < countPerPage || isNextAndPreviousDisabled,\n\t\t[countPerPage, isLogPanel, isNextAndPreviousDisabled, totalCount],\n\t);\n\n\treturn (\n\t\t