@levi-gemcommerce/analytics 1.0.0-dev.14 → 1.0.0-dev.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/dist/esm/core/gemxql/builder/clauses/time-query.d.ts +2 -1
  2. package/dist/esm/core/gemxql/builder/helpers/date-query-helpers.d.ts +1 -1
  3. package/dist/esm/core/gemxql/hooks/useAnalyticData.d.ts +1 -2
  4. package/dist/esm/core/gemxql/types/date-filter.d.ts +1 -1
  5. package/dist/esm/core/gemxql/types/index.d.ts +0 -1
  6. package/dist/esm/gemxql.js +183 -2
  7. package/dist/esm/gemxql.mjs +183 -2
  8. package/dist/esm/index.d.ts +1 -0
  9. package/dist/esm/index.js +117 -3
  10. package/dist/esm/index.mjs +117 -3
  11. package/dist/esm/providers/ConvertMoneyProvider.d.ts +13 -0
  12. package/dist/esm/providers/currencyRatesStore.d.ts +7 -0
  13. package/dist/esm/providers/index.d.ts +5 -0
  14. package/dist/esm/providers/useFetchCurrencyRates.d.ts +1 -0
  15. package/dist/esm/utils/currency.d.ts +5 -0
  16. package/dist/umd/esm/core/gemxql/builder/clauses/time-query.d.ts +2 -1
  17. package/dist/umd/esm/core/gemxql/builder/helpers/date-query-helpers.d.ts +1 -1
  18. package/dist/umd/esm/core/gemxql/hooks/useAnalyticData.d.ts +1 -2
  19. package/dist/umd/esm/core/gemxql/types/date-filter.d.ts +1 -1
  20. package/dist/umd/esm/core/gemxql/types/index.d.ts +0 -1
  21. package/dist/umd/esm/index.d.ts +1 -0
  22. package/dist/umd/esm/providers/ConvertMoneyProvider.d.ts +13 -0
  23. package/dist/umd/esm/providers/currencyRatesStore.d.ts +7 -0
  24. package/dist/umd/esm/providers/index.d.ts +5 -0
  25. package/dist/umd/esm/providers/useFetchCurrencyRates.d.ts +1 -0
  26. package/dist/umd/esm/utils/currency.d.ts +5 -0
  27. package/dist/umd/gemxql.js +1 -1
  28. package/dist/umd/index.js +1 -1
  29. package/package.json +2 -2
@@ -8,8 +8,9 @@ import quarterOfYear from 'dayjs/plugin/quarterOfYear.js';
8
8
  import timezone from 'dayjs/plugin/timezone.js';
9
9
  import utc from 'dayjs/plugin/utc.js';
10
10
  import { useTranslation } from 'react-i18next';
11
+ import { create } from 'zustand';
12
+ import { useQuery } from '@tanstack/react-query';
11
13
  import { PolarisVizProvider, LineChart, DonutChart } from '@shopify/polaris-viz';
12
- import '@tanstack/react-query';
13
14
 
14
15
  var EMetricKey;
15
16
  (function (EMetricKey) {
@@ -879,6 +880,118 @@ const GChartSkeleton = () => {
879
880
  return jsx(GSkeletonDisplayText, { height: "188px" });
880
881
  };
881
882
 
883
+ const getPriceByCurrency = (price, currency = DEFAULT_CURRENCY_ANALYTIC, options) => {
884
+ if (typeof price === 'string')
885
+ return price;
886
+ if (typeof price !== 'number')
887
+ return;
888
+ // Support legacy 3rd arg as locale string
889
+ const opts = typeof options === 'string' ? { locale: options } : options;
890
+ const locale = opts?.locale ?? 'en-US';
891
+ if (price >= 1_000_000_000) {
892
+ return `${new Intl.NumberFormat(locale, {
893
+ style: 'currency',
894
+ currency,
895
+ minimumFractionDigits: 2,
896
+ maximumFractionDigits: 2,
897
+ }).format(price / 1_000_000_000)}B`;
898
+ }
899
+ if (price >= 1_000_000) {
900
+ return `${new Intl.NumberFormat(locale, {
901
+ style: 'currency',
902
+ currency,
903
+ minimumFractionDigits: 2,
904
+ maximumFractionDigits: 2,
905
+ }).format(price / 1_000_000)}M`;
906
+ }
907
+ if (opts?.compact && Math.abs(price) >= 1_000) {
908
+ return `${new Intl.NumberFormat(locale, {
909
+ style: 'currency',
910
+ currency,
911
+ minimumFractionDigits: 1,
912
+ maximumFractionDigits: 1,
913
+ }).format(price / 1_000)}K`;
914
+ }
915
+ return new Intl.NumberFormat(locale, {
916
+ style: 'currency',
917
+ currency,
918
+ }).format(price);
919
+ };
920
+
921
+ const useCurrencyRatesStore = create((set) => ({
922
+ currencyRates: null,
923
+ setCurrencyRates: (rates) => set({ currencyRates: rates }),
924
+ }));
925
+
926
+ const SHOPIFY_CURRENCIES_URL = 'https://cdn.shopify.com/s/javascripts/currencies.js';
927
+ const parseCurrencyRates = (scriptText) => {
928
+ const rates = {};
929
+ const match = /var Currency=\{rates:\{(.*?)\}\};/s.exec(scriptText);
930
+ const ratesStr = match?.[1];
931
+ if (!ratesStr)
932
+ return rates;
933
+ const ratePattern = /([A-Z]+):\s*([\d.e+-]+),/g;
934
+ let m;
935
+ while ((m = ratePattern.exec(ratesStr)) !== null) {
936
+ const [, code, value] = m;
937
+ if (code && value)
938
+ rates[code] = parseFloat(value);
939
+ }
940
+ return rates;
941
+ };
942
+ const fetchCurrencyRates = async () => {
943
+ const res = await fetch(SHOPIFY_CURRENCIES_URL);
944
+ if (!res.ok)
945
+ throw new Error('Failed to fetch currency rates');
946
+ const text = await res.text();
947
+ return parseCurrencyRates(text);
948
+ };
949
+ const useFetchCurrencyRates = () => {
950
+ const setCurrencyRates = useCurrencyRatesStore((state) => state.setCurrencyRates);
951
+ const { data } = useQuery({
952
+ queryKey: ['sdk-currency-rates'],
953
+ queryFn: fetchCurrencyRates,
954
+ staleTime: 1000 * 60 * 60, // 1 hour — rates don't change often
955
+ });
956
+ useEffect(() => {
957
+ if (data)
958
+ setCurrencyRates(data);
959
+ }, [data, setCurrencyRates]);
960
+ };
961
+
962
+ const ConvertMoneyContext = createContext({
963
+ getTextPrice: (price) => {
964
+ if (typeof price === 'string')
965
+ return price;
966
+ return `${price ?? 0}`;
967
+ },
968
+ });
969
+ const convertAmount = (amount, from, to, rates) => {
970
+ if (from === to || !rates[from] || !rates[to])
971
+ return amount;
972
+ const converted = (amount * rates[from]) / rates[to];
973
+ return converted ? Number(converted.toFixed(2)) : amount;
974
+ };
975
+ const ConvertMoneyProvider = ({ children, currency, locale = 'en-US' }) => {
976
+ useFetchCurrencyRates();
977
+ const currencyRates = useCurrencyRatesStore((state) => state.currencyRates);
978
+ const getTextPrice = useCallback((price, _hasCurrency, options) => {
979
+ if (typeof price === 'string')
980
+ return price;
981
+ if (typeof price !== 'number')
982
+ return '0';
983
+ if (!currency)
984
+ return price.toString();
985
+ const converted = currencyRates
986
+ ? convertAmount(price, DEFAULT_CURRENCY_ANALYTIC, currency, currencyRates)
987
+ : price;
988
+ return trimDecimalZeros(getPriceByCurrency(converted, currency, { locale, compact: options?.compact }) ?? '0');
989
+ }, [currency, locale, currencyRates]);
990
+ const value = useMemo(() => ({ getTextPrice }), [getTextPrice]);
991
+ return jsx(ConvertMoneyContext.Provider, { value: value, children: children });
992
+ };
993
+ const useConvertMoneyContext = () => useContext(ConvertMoneyContext);
994
+
882
995
  const LINE_SERIES_COLORS = {
883
996
  comparison: SERIES_COLORS.comparison,
884
997
  single: SERIES_COLORS.current,
@@ -1169,7 +1282,8 @@ const readNumeric = (metric, key) => {
1169
1282
  return typeof raw === 'number' ? raw : 0;
1170
1283
  };
1171
1284
 
1172
- const useAnalyticData = (getTextPrice) => {
1285
+ const useAnalyticData = () => {
1286
+ const { getTextPrice } = useConvertMoneyContext();
1173
1287
  const formatData = ({ value, formatter, name }) => {
1174
1288
  return formatAnalyticData({ value, formatter, getTextPrice, name });
1175
1289
  };
@@ -2525,4 +2639,4 @@ const GTimePicker = (props) => {
2525
2639
  return (jsxs(InlineStack, { gap: "200", children: [jsx(MainTimePicker, { ...timePickerProps }), isCompare && (jsx(CompareTimePicker, { rangeAddition: timePickerProps.rangeAddition, popoverProps: timePickerProps.popoverProps }))] }));
2526
2640
  };
2527
2641
 
2528
- export { ANALYTICS_METRIC_TOOLTIP, AnalyticModeSelector, CAMPAIGN_BACKGROUND_MAIN, CHART_MIN_HEIGHT, COMPARE_DATE_TIME_FILTERS_MAP, CompareDateTimePickerAlias, CurrencySelector, DATE_TIME_COMPARISON_FILTERS, DEFAULT_CURRENCY_ANALYTIC, DEFAULT_CURRENT_PERIOD_LABEL, DEFAULT_PREVIOUS_PERIOD_LABEL, DateTimeFilterInputs, DateTimeFilters, DateTimePickerContext, DateTimePickerProvider, GSelectableMetricChartCard, GTimePicker, MainDateTimePickerAlias, MetricDonutChartCard, PLACEHOLDER_VALUE$1 as PLACEHOLDER_VALUE, PREVIOUS_PERIOD_FILTER, SERIES_COLORS, SingleMetricChartCard, TARGET_CHANNEL, TARGET_DEVICES, TARGET_VISITOR, THUMB_PRODUCT_DEFAULT, TREND_TONE, convertDateToTz, convertToDateTimeFilters, createLastDaysRange, dayjsTz, dayjsTzToDate, dayjsTzToLocalTZ, formatDate, formatDateTimeRange, formatDayjs, formatMs, formatTime, formatTimeRange, getDateRangeTitle, getDateTimeFilterBase, getDateTimeFilterByAlias, getDateTimeFilterMapping, getEndOfDayBy, getInitialTimezone, getLast12Months, getLast30Days, getLast365Days, getLast7Days, getLast90Days, getLastMonth, getLastYear, getMonthAndYearByDateFilter, getNoComparison, getPreviousMonth, getPreviousPeriod, getPreviousQuarter, getPreviousWeek, getPreviousYear, getToday, getVersionDateDescription, getVersionDateRangeTitle, getYesterday, isDate, isMidnight, isSameDayTimestamp, isValidDate, isValidYearMonthDayDateString, parseYearMonthDayDateString, setTz, useDateTimeFilter, useDateTimePicker, useDateTimePickerContext, useVersionDateTimeFilters };
2642
+ export { ANALYTICS_METRIC_TOOLTIP, AnalyticModeSelector, CAMPAIGN_BACKGROUND_MAIN, CHART_MIN_HEIGHT, COMPARE_DATE_TIME_FILTERS_MAP, CompareDateTimePickerAlias, ConvertMoneyProvider, CurrencySelector, DATE_TIME_COMPARISON_FILTERS, DEFAULT_CURRENCY_ANALYTIC, DEFAULT_CURRENT_PERIOD_LABEL, DEFAULT_PREVIOUS_PERIOD_LABEL, DateTimeFilterInputs, DateTimeFilters, DateTimePickerContext, DateTimePickerProvider, GSelectableMetricChartCard, GTimePicker, MainDateTimePickerAlias, MetricChartProvider, MetricDonutChartCard, PLACEHOLDER_VALUE$1 as PLACEHOLDER_VALUE, PREVIOUS_PERIOD_FILTER, SERIES_COLORS, SingleMetricChartCard, TARGET_CHANNEL, TARGET_DEVICES, TARGET_VISITOR, THUMB_PRODUCT_DEFAULT, TREND_TONE, convertDateToTz, convertToDateTimeFilters, createLastDaysRange, dayjsTz, dayjsTzToDate, dayjsTzToLocalTZ, formatDate, formatDateTimeRange, formatDayjs, formatMs, formatTime, formatTimeRange, getDateRangeTitle, getDateTimeFilterBase, getDateTimeFilterByAlias, getDateTimeFilterMapping, getEndOfDayBy, getInitialTimezone, getLast12Months, getLast30Days, getLast365Days, getLast7Days, getLast90Days, getLastMonth, getLastYear, getMonthAndYearByDateFilter, getNoComparison, getPreviousMonth, getPreviousPeriod, getPreviousQuarter, getPreviousWeek, getPreviousYear, getToday, getVersionDateDescription, getVersionDateRangeTitle, getYesterday, isDate, isMidnight, isSameDayTimestamp, isValidDate, isValidYearMonthDayDateString, parseYearMonthDayDateString, setTz, useConvertMoneyContext, useCurrencyRatesStore, useDateTimeFilter, useDateTimePicker, useDateTimePickerContext, useFetchCurrencyRates, useVersionDateTimeFilters };
@@ -0,0 +1,13 @@
1
+ import type { ReactNode } from 'react';
2
+ import type { IGetTextPrice } from '@/core/gemxql/helpers/formatAnalyticData';
3
+ interface IConvertMoneyContext {
4
+ getTextPrice: IGetTextPrice;
5
+ }
6
+ export interface IProps {
7
+ children: ReactNode;
8
+ currency?: string;
9
+ locale?: string;
10
+ }
11
+ export declare const ConvertMoneyProvider: ({ children, currency, locale }: IProps) => import("react/jsx-runtime").JSX.Element;
12
+ export declare const useConvertMoneyContext: () => IConvertMoneyContext;
13
+ export {};
@@ -0,0 +1,7 @@
1
+ export type ICurrencyRates = Record<string, number>;
2
+ interface ICurrencyRatesStore {
3
+ currencyRates: ICurrencyRates | null;
4
+ setCurrencyRates: (rates: ICurrencyRates) => void;
5
+ }
6
+ export declare const useCurrencyRatesStore: import("zustand").UseBoundStore<import("zustand").StoreApi<ICurrencyRatesStore>>;
7
+ export {};
@@ -1 +1,6 @@
1
+ export { ConvertMoneyProvider, useConvertMoneyContext } from './ConvertMoneyProvider';
2
+ export type { IProps as IConvertMoneyProviderProps } from './ConvertMoneyProvider';
3
+ export { useCurrencyRatesStore } from './currencyRatesStore';
4
+ export type { ICurrencyRates } from './currencyRatesStore';
1
5
  export { MetricChartProvider } from './MetricChartProvider';
6
+ export { useFetchCurrencyRates } from './useFetchCurrencyRates';
@@ -0,0 +1 @@
1
+ export declare const useFetchCurrencyRates: () => void;
@@ -0,0 +1,5 @@
1
+ export interface IGetPriceByCurrencyOptions {
2
+ locale?: string;
3
+ compact?: boolean;
4
+ }
5
+ export declare const getPriceByCurrency: (price?: string | number | null, currency?: string, options?: string | IGetPriceByCurrencyOptions) => string | undefined;
@@ -1,4 +1,5 @@
1
- import type { AnalyticDateFilter, GemXQlFilters, GemXQlOverrideFilters } from '../../types';
1
+ import type { GemXQlFilters, GemXQlOverrideFilters } from '../../types';
2
+ import type { AnalyticDateFilter } from '@/components';
2
3
  export interface IBuildTimeQueryParams {
3
4
  dateRange?: AnalyticDateFilter;
4
5
  compareDateRange?: AnalyticDateFilter;
@@ -1,4 +1,4 @@
1
- import type { AnalyticDateFilter } from '../../types';
1
+ import type { AnalyticDateFilter } from '@/components';
2
2
  export declare const getDateRangeForQuery: (dateRange: AnalyticDateFilter) => {
3
3
  dateGTE: string;
4
4
  dateLTE: string;
@@ -1,4 +1,3 @@
1
- import type { IGetTextPrice } from '../helpers/formatAnalyticData';
2
1
  import type { AnalyticValueType } from '../types';
3
2
  interface IFormatDataParams {
4
3
  value: AnalyticValueType;
@@ -20,5 +19,5 @@ interface IUseAnalyticDataReturn {
20
19
  formatData: (params: IFormatDataParams) => AnalyticValueType;
21
20
  computeMetric: (params: IComputeMetricParams) => IComputeMetricResult;
22
21
  }
23
- export declare const useAnalyticData: (getTextPrice?: IGetTextPrice) => IUseAnalyticDataReturn;
22
+ export declare const useAnalyticData: () => IUseAnalyticDataReturn;
24
23
  export {};
@@ -1,4 +1,4 @@
1
- import type { Dayjs } from '@/utils';
1
+ import type { Dayjs } from '../../../utils';
2
2
  export interface AnalyticDateFilter {
3
3
  versionId?: string;
4
4
  startDate: Dayjs | string;
@@ -1,6 +1,5 @@
1
1
  export * from './analytic-data';
2
2
  export * from './analytic-source';
3
- export * from './date-filter';
4
3
  export * from './extra-condition';
5
4
  export * from './field-filters';
6
5
  export * from './field-operators';
@@ -1,3 +1,4 @@
1
1
  export * from './components';
2
2
  export * from './constants';
3
+ export * from './providers';
3
4
  export * from './utils/dayjs';
@@ -0,0 +1,13 @@
1
+ import type { ReactNode } from 'react';
2
+ import type { IGetTextPrice } from '@/core/gemxql/helpers/formatAnalyticData';
3
+ interface IConvertMoneyContext {
4
+ getTextPrice: IGetTextPrice;
5
+ }
6
+ export interface IProps {
7
+ children: ReactNode;
8
+ currency?: string;
9
+ locale?: string;
10
+ }
11
+ export declare const ConvertMoneyProvider: ({ children, currency, locale }: IProps) => import("react/jsx-runtime").JSX.Element;
12
+ export declare const useConvertMoneyContext: () => IConvertMoneyContext;
13
+ export {};
@@ -0,0 +1,7 @@
1
+ export type ICurrencyRates = Record<string, number>;
2
+ interface ICurrencyRatesStore {
3
+ currencyRates: ICurrencyRates | null;
4
+ setCurrencyRates: (rates: ICurrencyRates) => void;
5
+ }
6
+ export declare const useCurrencyRatesStore: import("zustand").UseBoundStore<import("zustand").StoreApi<ICurrencyRatesStore>>;
7
+ export {};
@@ -1 +1,6 @@
1
+ export { ConvertMoneyProvider, useConvertMoneyContext } from './ConvertMoneyProvider';
2
+ export type { IProps as IConvertMoneyProviderProps } from './ConvertMoneyProvider';
3
+ export { useCurrencyRatesStore } from './currencyRatesStore';
4
+ export type { ICurrencyRates } from './currencyRatesStore';
1
5
  export { MetricChartProvider } from './MetricChartProvider';
6
+ export { useFetchCurrencyRates } from './useFetchCurrencyRates';
@@ -0,0 +1 @@
1
+ export declare const useFetchCurrencyRates: () => void;
@@ -0,0 +1,5 @@
1
+ export interface IGetPriceByCurrencyOptions {
2
+ locale?: string;
3
+ compact?: boolean;
4
+ }
5
+ export declare const getPriceByCurrency: (price?: string | number | null, currency?: string, options?: string | IGetPriceByCurrencyOptions) => string | undefined;
@@ -1 +1 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("dayjs"),require("dayjs/plugin/quarterOfYear.js"),require("dayjs/plugin/timezone.js"),require("dayjs/plugin/utc.js"),require("@tanstack/react-query"),require("react")):"function"==typeof define&&define.amd?define(["exports","dayjs","dayjs/plugin/quarterOfYear.js","dayjs/plugin/timezone.js","dayjs/plugin/utc.js","@tanstack/react-query","react"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).GemAnalytics={},e.dayjs,e.quarterOfYear,e.timezone,e.utc,e.reactQuery,e.React)}(this,function(e,t,r,i,a,n,o){"use strict";const s="None",l="___totals",E="comparison___",u="___previous_period",m=`${u}${l}`,c="is",d="is_one_of";var p,R,O,T,A,f,y,I,S,D,F,M,g;e.EAnalyticDataType=void 0,(p=e.EAnalyticDataType||(e.EAnalyticDataType={})).DATE="DATE",p.ARRAY="ARRAY",p.OBJECT="OBJECT",p.STRING="STRING",p.INTEGER="INTEGER",p.CURRENCY="CURRENCY",p.PERCENT="PERCENT",p.DURATION="DURATION",p.MONTH="MONTH_TIMESTAMP",p.QUARTER="QUARTER_TIMESTAMP",p.DAY="DAY_TIMESTAMP",p.WEEK="WEEK_TIMESTAMP",p.YEAR="YEAR_TIMESTAMP",p.HOUR="HOUR_TIMESTAMP",e.EAnalyticColumnKey=void 0,(R=e.EAnalyticColumnKey||(e.EAnalyticColumnKey={})).CAMPAIGNS="experiments",R.VISITOR_ITEMS="visitor_items",R.DEVICE_ITEMS="device_items",R.TRAFFIC_SOURCE_ITEMS="traffic_source_items",e.EAnalyticSource=void 0,(O=e.EAnalyticSource||(e.EAnalyticSource={})).SESSIONS="sessions",O.SALES="sales",e.EComparisonOperator=void 0,(T=e.EComparisonOperator||(e.EComparisonOperator={})).EQ="=",T.IN="IN",T.LIKE="LIKE",e.EGroupOperator=void 0,(A=e.EGroupOperator||(e.EGroupOperator={})).OR="OR",A.AND="AND",e.EFilterField=void 0,(f=e.EFilterField||(e.EFilterField={})).DEVICE="device",f.DEVICES="devices",f.VISITOR="visitor_type",f.VISITORS="visitor_types",f.TRAFFIC_SOURCE="traffic_source",f.TRAFFIC_SOURCES="traffic_sources",f.VERSION="version",f.VERSIONS="versions",f.SINGLE_PAGE="page_path",f.LIST_PAGE="page_paths",f.GROUP_CAMPAIGN_ITEM="group_campaign_item",f.GROUP_CAMPAIGN_ITEMS="group_campaign_items",f.SINGLE_CAMPAIGN="experiment_id",f.GROUP_CAMPAIGN="experiment_group_id",f.CAMPAIGN_VERSION_ID="version_id",f.GROUP_CAMPAIGN_VERSION_ID="group_version_id",e.EOperatorField=void 0,(y=e.EOperatorField||(e.EOperatorField={})).DEVICE_OPERATOR="deviceOperator",y.VISITOR_OPERATOR="visitorOperator",y.TRAFFIC_SOURCE_OPERATOR="trafficSourceOperator",y.VERSION_OPERATOR="versionOperator",y.PAGE_OPERATOR="pageOperator",y.CAMPAIGN_ITEM_OPERATOR="campaignItemOperator",e.EGroupWithClause=void 0,(I=e.EGroupWithClause||(e.EGroupWithClause={})).NONE="",I.TOTALS="TOTALS",I.ALL="WITH GROUP_TOTALS, TOTALS",e.EOrderDirectionType=void 0,(S=e.EOrderDirectionType||(e.EOrderDirectionType={})).ASC="ASC",S.DESC="DESC",e.EPageMetric=void 0,(D=e.EPageMetric||(e.EPageMetric={})).PAGE_ITEMS="page_items",D.PAGE_PATHS="page_paths",e.EPageDimension=void 0,(e.EPageDimension||(e.EPageDimension={})).PAGE_PATH="page_path",e.EPageField=void 0,(F=e.EPageField||(e.EPageField={})).SHOPIFY_PAGE_ID="shopify_page_id",F.LOCATION_PATH="location_path",F.PAGE_TYPE="page_type",F.PAGE_TITLE="page_title",F.PAGE_PATH="page_path",F.TEMPLATE_SUFFIX="template_suffix",e.ERowReaderMode=void 0,(M=e.ERowReaderMode||(e.ERowReaderMode={})).DEFAULT="DEFAULT",M.COMPARISON="COMPARISON",M.TOTALS="TOTALS",M.COMPARISON_TOTALS="COMPARISON_TOTALS",e.ETimeDimension=void 0,(g=e.ETimeDimension||(e.ETimeDimension={})).HOUR="hour",g.DAY="day",g.WEEK="week",g.MONTH="month",g.QUARTER="quarter",g.YEAR="year";const _={[e.ERowReaderMode.DEFAULT]:{prefix:"",suffix:""},[e.ERowReaderMode.COMPARISON]:{prefix:E,suffix:u},[e.ERowReaderMode.TOTALS]:{prefix:"",suffix:l},[e.ERowReaderMode.COMPARISON_TOTALS]:{prefix:E,suffix:m}},N="YYYY-MM-DDTHH:mm:ss",C=["MODE","FROM","SHOW","GROUP BY","TIMESERIES","SINCE","DURING","TIMEZONE","WHERE","ORDER BY","LIMIT","OFFSET"],P=C.join("|"),h=1e3,G=e.EGroupOperator.OR,Y=(e,t=G)=>e.length?1===e.length?e[0]??"":`(${e.join(` ${t} `)})`:"",$=t=>{switch(t.operator){case e.EComparisonOperator.EQ:return(({fields:e,value:t,groupOperator:r})=>e.length?Y(e.map(e=>`${e} = ${t}`),r):"")(t);case e.EComparisonOperator.IN:return(({fields:e,values:t,groupOperator:r})=>e.length&&t.length?Y(e.map(e=>`${e} IN (${t.join(", ")})`),r):"")(t);case e.EComparisonOperator.LIKE:return(({fields:e,value:t,groupOperator:r})=>{const i=t.trim();return i&&e.length?Y(e.map(e=>`${e} LIKE '%${i}%'`),r):""})(t)}},b=e=>e?.length?e.map($).filter(Boolean):[],v=[{operator:e.EOperatorField.DEVICE_OPERATOR,singleField:e.EFilterField.DEVICE,multiField:e.EFilterField.DEVICES,fieldName:e.EFilterField.DEVICE},{operator:e.EOperatorField.VISITOR_OPERATOR,singleField:e.EFilterField.VISITOR,multiField:e.EFilterField.VISITORS,fieldName:e.EFilterField.VISITOR},{operator:e.EOperatorField.TRAFFIC_SOURCE_OPERATOR,singleField:e.EFilterField.TRAFFIC_SOURCE,multiField:e.EFilterField.TRAFFIC_SOURCES,fieldName:e.EFilterField.TRAFFIC_SOURCE},{operator:e.EOperatorField.VERSION_OPERATOR,singleField:e.EFilterField.VERSION,multiField:e.EFilterField.VERSIONS,fieldName:e.EFilterField.VERSION},{operator:e.EOperatorField.PAGE_OPERATOR,singleField:e.EFilterField.SINGLE_PAGE,multiField:e.EFilterField.LIST_PAGE,fieldName:e.EFilterField.SINGLE_PAGE},{operator:e.EOperatorField.CAMPAIGN_ITEM_OPERATOR,singleField:e.EFilterField.GROUP_CAMPAIGN_ITEM,multiField:e.EFilterField.GROUP_CAMPAIGN_ITEMS,condition:e.EFilterField.GROUP_CAMPAIGN,fieldName:e.EFilterField.SINGLE_CAMPAIGN},{operatorVal:c,singleField:e.EFilterField.SINGLE_CAMPAIGN,multiField:e.EFilterField.GROUP_CAMPAIGN}],U=(e,t)=>{const r=[],i=Object.keys(e).length>0,a=!!t&&Object.keys(t).length>0;if(!i&&!a)return r;const n=(e=>e?Object.fromEntries(Object.entries(e).filter(([,e])=>void 0!==e).map(([e,t])=>[e,Array.isArray(t)?`${e} IN (${t.join(", ")})`:`${e} = ${t}`])):{})(t);return v.forEach(({operator:t,operatorVal:i,singleField:a,multiField:o,condition:s,fieldName:l})=>{if(n[a])return void r.push(n[a]);const E=t?e[t]:i;let u=e[a];const m=e[o],p=s&&e[s];if(s&&!p)return;const R=l??(u?a:o);i&&!u&&(u=e[o]);const O=(e=>{const{operatorValue:t,singleValue:r,multiValue:i,fieldName:a}=e;return t===c&&r?`${a} = ${r}`:t===d&&Array.isArray(i)&&i.length>0?`${a} IN (${i.join(", ")})`:""})({operatorValue:E,singleValue:Array.isArray(u)?void 0:u,multiValue:Array.isArray(m)?m:void 0,fieldName:R});O&&r.push(O)}),r},L=e=>{const t=[];return e?(Object.entries(e).forEach(([e,r])=>{r&&t.push(`${e} = ${r}`)}),t):t},Q=(e,t)=>{if(!e||0===t.length)return[];const r=t.find(t=>e[t]);return r?[r]:[]},x=({filters:e,overrideFilters:t,versionIds:r,extraConditions:i})=>{const a=[...U(e,t),...L(r),...b(i)];return a.length>0?`WHERE ${a.join(" AND ")}`:""},H=e=>{const t=e.match(new RegExp(`\\bWHERE\\s+([\\s\\S]+?)(?=\\s+(?:${P})\\b|$)`,"i"));if(!t)return{filters:{}};const r=(t[1]??"").trim().split(/\s+AND\s+/i),i={},a={};return r.forEach(e=>{const t=e.trim(),r=t.match(/^(\S+)\s+IN\s+\((.+)\)$/i);if(r){const e=r[1]??"",t=(r[2]??"").split(",").map(e=>e.trim()),a=v.find(t=>t.fieldName===e||t.multiField===e);return void(a?.operator&&(i[a.multiField]=t,i[a.operator]=d))}const n=t.match(/^(\S+)\s+=\s+(.+)$/);if(n){const e=n[1]??"",t=n[2]??"",r=v.find(t=>t.fieldName===e||t.singleField===e);r?(i[r.singleField]=t,r.operator&&(i[r.operator]=c)):e&&(a[e]=t)}}),{filters:i,versionIds:Object.keys(a).length>0?a:void 0}},V=e=>`FROM ${e.join(", ")}`,j=e=>{const t=e.match(new RegExp(`\\bFROM\\s+([\\s\\S]+?)(?=\\s+(?:${P})\\b)`,"i"));return t?(t[1]??"").split(",").map(e=>e.trim()).filter(Boolean):[]},W=(t,r=e.EGroupWithClause.ALL)=>0===t.length?"":`GROUP BY ${t.join(", ")} ${r}`,K=t=>{const r=t.match(new RegExp(`\\bGROUP BY\\s+([\\s\\S]+?)(?=\\s+(?:${P})\\b)`,"i"));if(!r)return{dimensions:[]};const i=(r[1]??"").trim(),a=i.toUpperCase().indexOf(" WITH ");return-1===a?{dimensions:i.split(",").map(e=>e.trim()).filter(Boolean),groupWithClause:e.EGroupWithClause.NONE}:{dimensions:i.slice(0,a).split(",").map(e=>e.trim()).filter(Boolean),groupWithClause:i.slice(a+1).trim()}},B=e=>e?`LIMIT ${e}`:"",w=e=>{const t=e.match(/\bLIMIT\s+(\d+)/i);return t?parseInt(t[1]??"0",10):void 0},q=e=>`MODE ${e}`,X=e=>{const t=e.match(/\bMODE\s+(\S+)/i);return t?.[1]},k=e=>!e||e<0?"":`OFFSET ${e}`,z=e=>{const t=e.match(/\bOFFSET\s+(\d+)/i);return t?parseInt(t[1]??"0",10):void 0},J=(e,t)=>{if(!e)return"";const r=Object.values(e).filter(e=>t?.includes(e.field)).map(e=>`${e.field} ${e.direction}`).join(", ");return r?`ORDER BY ${r}`:""},Z=e=>{const t=e.match(new RegExp(`\\bORDER BY\\s+([\\s\\S]+?)(?=\\s+(?:${P})\\b|$)`,"i"));if(!t)return;const r={};return(t[1]??"").split(",").forEach(e=>{const t=e.trim().split(/\s+/);if(2===t.length){const e=t[0]??"",i=t[1]??"";e&&(r[e]={field:e,direction:i})}}),Object.keys(r).length>0?r:void 0},ee=e=>`SHOW ${e.join(", ")}`,te=e=>{const t=e.match(new RegExp(`\\bSHOW\\s+([\\s\\S]+?)(?=\\s+(?:${P})\\b)`,"i"));return t?(t[1]??"").split(",").map(e=>e.trim()).filter(Boolean):[]},re=/\.0+$/,ie=(e,t=2)=>(e=>`${e}`.replace(re,""))(e.toFixed(t)),ae=(e,t,r=2)=>{const i=((e,t,r=2)=>{if("number"!=typeof e||!t)return;return 0===e?0:parseFloat(ie(e/t*100,r))})(e,t,r);if("number"==typeof i)return(e=>e>0&&e<.005)(i)?"~0%":`${i}%`};t.extend(a),t.extend(i),t.extend(r);let ne="UTC";function oe(){return ne}const se=e=>e?t(e).tz(ne):t().tz(ne);var le;!function(e){e.DAY="DAY",e.HOUR="HOUR",e.MONTH="MONTH",e.QUARTER="QUARTER",e.WEEK="WEEK",e.YEAR="YEAR"}(le||(le={}));const Ee=60,ue=3600,me=(e,t,r)=>{if(!e)return"";const i=r?.isExpandDetail?{formatHouse:"MMM D, h:mm A",formatDay:"MMM D, YYYY",formatMonth:"MMM YYYY",formatYear:"MMM YYYY"}:{formatHouse:"h A",formatDay:"MMM D",formatMonth:"MMM YYYY",formatYear:"YYYY"};switch(t){case le.HOUR:return se(e).format(i.formatHouse);case le.DAY:case le.WEEK:return se(e).format(i.formatDay);case le.MONTH:return se(e).format(i.formatMonth);case le.QUARTER:{const t=se(e);return`Q${t.quarter()} ${t.format("YYYY")}`}case le.YEAR:return se(e).format(i.formatYear)}return se(e).format(i.formatMonth)},ce=e=>"string"==typeof e?se(e):e,de=(e,t=!1)=>t&&(e=>0===e.hour()&&0===e.minute())(e)?e.endOf("day").format(N):e.format(N),pe=e=>{const t=ce(e.startDate),r=ce(e.endDate);return t.isSame(r)?{dateGTE:de(t),dateLTE:(i=r,de(i?se(i).endOf("day"):se().endOf("day")))}:{dateGTE:de(t),dateLTE:de(r,!0)};var i},Re=e=>{const{dateRange:t,compareDateRange:r,overrideFilters:i,timeDimension:a}=e,n=a?i?.[a]:void 0;if(a&&n)return`DURING (${n}, ${a})`;if(!t)return"";const{dateGTE:o,dateLTE:s}=pe(t),{dateGTE:l,dateLTE:E}=r?pe(r):{};return`SINCE ${o} UNTIL ${s} ${r?`COMPARE TO ${l} UNTIL ${E}`:""}`},Oe=e=>{const t=e.match(/\bDURING\s+\(([^,]+),\s*([^)]+)\)/i);if(t){const e=t[1]??"",r=t[2]??"";return{timeDimension:r.trim(),overrideFilters:{[r.trim()]:e.trim()}}}const r=e.match(/\bSINCE\s+(\S+)\s+UNTIL\s+(\S+)/i);if(!r)return{};const i={startDate:se(r[1]??""),endDate:se(r[2]??"")},a=e.match(/\bCOMPARE TO\s+(\S+)\s+UNTIL\s+(\S+)/i);return{dateRange:i,compareDateRange:a?{startDate:se(a[1]??""),endDate:se(a[2]??"")}:void 0}},Te=e=>e?`TIMESERIES ${e}`:"",Ae=e=>{const t=e.match(/\bTIMESERIES\s+(\S+)/i);return t?.[1]},fe=e=>{const t=e??oe();return t?`TIMEZONE ${t}`:""},ye=e=>{const t=e.match(/\bTIMEZONE\s+(\S+)/i);return t?.[1]};function Ie(e){if("string"!=typeof e)return!1;const t=e.trim();return/^MODE\b[\s\S]*\bFROM\b[\s\S]*\bSHOW\b[\s\S]*$/.test(t)}const Se=e=>e?.gemxQLQuery?.tableData?.columns??[],De=e=>{if(!e)return"None";const t=se(e),r=se(),i=se().subtract(1,"day"),a=t.format("YYYY-MM-DD")===r.format("YYYY-MM-DD"),n=t.format("YYYY-MM-DD")===i.format("YYYY-MM-DD");if(a)return`Today at ${t.format("HH:mm")}`;if(n)return`Yesterday at ${t.format("HH:mm")}`;const o=r.diff(t,"day");return o>=0&&o<7?`${t.format("dddd")} at ${t.format("HH:mm")}`:`${t.format("MMM D")} at ${t.format("hh:mm a")}`},Fe=({value:t,formatter:r,getTextPrice:i,name:a})=>{if(null!==t&&("object"==typeof t||Array.isArray(t)))return t;switch(r){case e.EAnalyticDataType.INTEGER:return(t??0).toString().toString().replace(/\B(?=(\d{3})+(?!\d))/g,",");case e.EAnalyticDataType.CURRENCY:return i?i(t,!1):`${t??0}`;case e.EAnalyticDataType.DATE:return De(t);case e.EAnalyticDataType.PERCENT:return"number"!=typeof t?ae(0,1,2)??"":ae(t/100,1,2)??"";case e.EAnalyticDataType.DURATION:return(e=>{let t=e;Number.isFinite(e)&&null!=e||(t=0);const r=ie(t);if(t>=ue)return`${Math.floor(t/ue)}h ${Math.floor(t%ue/Ee)}m ${Math.floor(t%Ee)}s`;if(t>=Ee)return`${Math.floor(t/Ee)}m ${Math.floor(t%Ee)}s`;return`${r}s`})(Number(t));case e.EAnalyticDataType.STRING:{const r=a===e.EAnalyticColumnKey.CAMPAIGNS?"":s;return t??r}case e.EAnalyticDataType.DAY:return me(t,le.DAY,{isExpandDetail:!0});case e.EAnalyticDataType.HOUR:return me(t,le.HOUR,{isExpandDetail:!0});case e.EAnalyticDataType.MONTH:return me(t,le.MONTH,{isExpandDetail:!0});case e.EAnalyticDataType.YEAR:return me(t,le.YEAR);case e.EAnalyticDataType.WEEK:return me(t,le.WEEK,{isExpandDetail:!0});case e.EAnalyticDataType.QUARTER:return me(t,le.QUARTER,{isExpandDetail:!0});case e.EAnalyticDataType.OBJECT:case e.EAnalyticDataType.ARRAY:return t;default:return`${t}`}},Me=e=>{const t=e?.sessions;return"number"==typeof t&&t>0},ge=e=>{if(e)return"string"==typeof e?JSON.parse(e):e},_e=e=>{try{const t=ge(e);return t&&"object"==typeof t?t:null}catch{return null}},Ne=e=>{try{const t=ge(e);if(!Array.isArray(t))return;return t}catch{return}},Ce=(e,t)=>{const r=e?.[t];return"number"==typeof r?r:0},Pe="\n fragment ColumnSelect on Column {\n dataType\n displayName\n name\n}\n ",he="\n fragment TableDataSelect on TableData {\n columns {\n ...ColumnSelect\n }\n rows\n}\n ",Ge="\n fragment GemXQLResultSelect on GemxQLResult {\n tableData {\n ...TableDataSelect\n }\n}\n ",Ye=`\n query GemxQL($input: String!) {\n gemxQLQuery(query: $input) {\n ...GemXQLResultSelect\n }\n}\n ${Ge}\n${he}\n${Pe}`,$e=(e,t,r)=>n.useQuery({queryKey:["GemXQlCustom",e],queryFn:t(Ye,e),...r});$e.getKey=e=>["GemXQlCustom",e];const be=({name:e,variables:t,fetcher:r},i)=>{const a=Ye.replace(/query\s+GemxQL\b/,`query ${e}`);return n.useQuery({queryKey:[e,t],queryFn:r(a,t),retry:0,...i})};be.getKey=(e,t)=>[e,t];var ve;e.GPaginationDirection=void 0,(ve=e.GPaginationDirection||(e.GPaginationDirection={})).NEXT="NEXT",ve.PREV="PREV";e.CLAUSE_KEYWORDS=C,e.CLAUSE_KEYWORD_BOUNDARY=P,e.COMPARE_PREFIX=E,e.COMPARE_SUFFIX=u,e.COMPARE_TOTALS_SUFFIX=m,e.ColumnSelectFragmentDoc=Pe,e.DATE_QUERY_FORMAT=N,e.DEFAULT_QUERY_LIMIT=h,e.GemXqlResultSelectFragmentDoc=Ge,e.GemxQlDocument=Ye,e.NONE_VALUE=s,e.OPERATOR_IS=c,e.OPERATOR_IS_ONE_OF=d,e.PLACEHOLDER_VALUE="-",e.ROW_READER_MODE_CONFIG=_,e.TOTALS_SUFFIX=l,e.TableDataSelectFragmentDoc=he,e.buildConditionQuery=x,e.buildExtraCondition=$,e.buildExtraConditions=b,e.buildFromQuery=V,e.buildGemXQlQuery=e=>{const{mode:t,metrics:r,dimensions:i,dateRange:a,compareDateRange:n,filters:o,overrideFilters:s,versionIds:l,extraConditions:E,orderBy:u,sources:m,timeDimension:c,groupWithClause:d,timezone:p,limit:R=h,offset:O,extraOrderByFields:T}=e,A=[...i,...Q(u,r),...T??[]],f=[q(t),V(m),ee(r),W(i,d),Te(c),Re({dateRange:a,compareDateRange:n,timeDimension:c,overrideFilters:s}),fe(p),x({filters:o,overrideFilters:s,versionIds:l,extraConditions:E}),J(u,A),B(R),k(O)].filter(Boolean).join(" ");return Ie(f)?f:""},e.buildGroupQuery=W,e.buildLimitQuery=B,e.buildModeQuery=q,e.buildOffsetQuery=k,e.buildOrderByQuery=J,e.buildShowQuery=ee,e.buildTimeQuery=Re,e.buildTimeSeriesQuery=Te,e.buildTimezoneQuery=fe,e.buildVersionIdCondition=L,e.createNumericRowReader=(t,r=e.ERowReaderMode.DEFAULT)=>e=>{const{prefix:i,suffix:a}=_[r],n=t[`${i}${e}${a}`];if("number"==typeof n)return n;if("string"==typeof n){const e=parseFloat(n);return isNaN(e)?0:e}return 0},e.extractColumnTypes=e=>{const t=Se(e),r={};for(const e of t)e?.name&&(r[e.name]=e.dataType);return r},e.extractQueryColumns=Se,e.extractQueryRows=e=>e?.gemxQLQuery?.tableData?.rows??[],e.filterConfigs=v,e.formatAnalyticData=Fe,e.formatAnalyticDate=De,e.generateFilterConditions=U,e.getComparisonKey=e=>`${E}${e}${u}`,e.getComparisonTotalsKey=e=>`${E}${e}${u}${l}`,e.getFirstMetricInOrderBy=Q,e.getTimeDimensionByDate=(t,r)=>{const i=r.diff(t,"day");return i<=3?e.ETimeDimension.HOUR:i<=93?e.ETimeDimension.DAY:e.ETimeDimension.MONTH},e.getTotalsKey=e=>`${e}${l}`,e.hasMetricData=Me,e.isValidQueryInput=Ie,e.parseBreakdownItems=e=>Ne(e)?.map(e=>({...e,total:Number(e.total)})),e.parseConditionQuery=H,e.parseFromQuery=j,e.parseGemXQlQuery=e=>{const{dateRange:t,compareDateRange:r,timeDimension:i,overrideFilters:a}=Oe(e),n=i??Ae(e),{dimensions:o,groupWithClause:s}=K(e),{filters:l,versionIds:E}=H(e);return{mode:X(e),sources:j(e),metrics:te(e),dimensions:o,groupWithClause:s,timeDimension:n,dateRange:t,compareDateRange:r,overrideFilters:a,filters:l,versionIds:E,timezone:ye(e),orderBy:Z(e),limit:w(e),offset:z(e)}},e.parseGroupQuery=K,e.parseJsonArray=Ne,e.parseJsonObject=_e,e.parseLimitQuery=w,e.parseModeQuery=X,e.parseOffsetQuery=z,e.parseOrderByQuery=Z,e.parsePageItems=e=>_e(e),e.parseShowQuery=te,e.parseTimeQuery=Oe,e.parseTimeSeriesQuery=Ae,e.parseTimezoneQuery=ye,e.readNumeric=Ce,e.useAnalyticData=e=>{const t=({value:t,formatter:r,name:i})=>Fe({value:t,formatter:r,getTextPrice:e,name:i});return{formatData:t,computeMetric:({metric:e,previousMetric:r,metricKey:i,formatter:a})=>{if(!Me(e))return{value:0,change:"-"};const n=Ce(e,i),o=Ce(r,i),s=t({value:n,formatter:a,name:i});if(0===n&&0!==o)return{value:s,change:-100};if(0===o)return{value:s,change:"-"};return{value:s,change:(n-o)/o*100}}}},e.useCustomGemXQlQuery=$e,e.useGemXQlPagination=({resetKey:t,itemsPerPage:r})=>{const[i,a]=o.useState(1),n=o.useRef(),s=i>1&&void 0!==n.current&&n.current!==t?1:i,l=(s-1)*r,E=o.useCallback(t=>r=>{a(i=>{const a=r===e.GPaginationDirection.NEXT?i+1:i-1;return Math.min(Math.max(a,1),t)})},[]);o.useEffect(()=>{n.current!==t&&(n.current=t,a(1))},[t]);const u=o.useCallback(({totalRecords:e,isLoading:t})=>{const i=Math.max(1,Math.ceil(e/r));return{currentPage:s,totalPages:i,loading:t,handlePageChange:E(i)}},[s,r,E]);return{currentPage:s,offset:l,buildPagination:u}},e.useGemxQlNamedQuery=be});
1
+ !function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("dayjs"),require("dayjs/plugin/quarterOfYear.js"),require("dayjs/plugin/timezone.js"),require("dayjs/plugin/utc.js"),require("@tanstack/react-query"),require("react/jsx-runtime"),require("react"),require("zustand")):"function"==typeof define&&define.amd?define(["exports","dayjs","dayjs/plugin/quarterOfYear.js","dayjs/plugin/timezone.js","dayjs/plugin/utc.js","@tanstack/react-query","react/jsx-runtime","react","zustand"],r):r((e="undefined"!=typeof globalThis?globalThis:e||self).GemAnalytics={},e.dayjs,e.quarterOfYear,e.timezone,e.utc,e.reactQuery,e.jsxRuntime,e.React,e.zustand)}(this,function(e,r,t,a,i,n,s,o,l){"use strict";const E="None",u="___totals",c="comparison___",m="___previous_period",d=`${m}${u}`,p="is",R="is_one_of";var A,O,T,f,I,S,_,N,y,D,C,F,g;e.EAnalyticDataType=void 0,(A=e.EAnalyticDataType||(e.EAnalyticDataType={})).DATE="DATE",A.ARRAY="ARRAY",A.OBJECT="OBJECT",A.STRING="STRING",A.INTEGER="INTEGER",A.CURRENCY="CURRENCY",A.PERCENT="PERCENT",A.DURATION="DURATION",A.MONTH="MONTH_TIMESTAMP",A.QUARTER="QUARTER_TIMESTAMP",A.DAY="DAY_TIMESTAMP",A.WEEK="WEEK_TIMESTAMP",A.YEAR="YEAR_TIMESTAMP",A.HOUR="HOUR_TIMESTAMP",e.EAnalyticColumnKey=void 0,(O=e.EAnalyticColumnKey||(e.EAnalyticColumnKey={})).CAMPAIGNS="experiments",O.VISITOR_ITEMS="visitor_items",O.DEVICE_ITEMS="device_items",O.TRAFFIC_SOURCE_ITEMS="traffic_source_items",e.EAnalyticSource=void 0,(T=e.EAnalyticSource||(e.EAnalyticSource={})).SESSIONS="sessions",T.SALES="sales",e.EComparisonOperator=void 0,(f=e.EComparisonOperator||(e.EComparisonOperator={})).EQ="=",f.IN="IN",f.LIKE="LIKE",e.EGroupOperator=void 0,(I=e.EGroupOperator||(e.EGroupOperator={})).OR="OR",I.AND="AND",e.EFilterField=void 0,(S=e.EFilterField||(e.EFilterField={})).DEVICE="device",S.DEVICES="devices",S.VISITOR="visitor_type",S.VISITORS="visitor_types",S.TRAFFIC_SOURCE="traffic_source",S.TRAFFIC_SOURCES="traffic_sources",S.VERSION="version",S.VERSIONS="versions",S.SINGLE_PAGE="page_path",S.LIST_PAGE="page_paths",S.GROUP_CAMPAIGN_ITEM="group_campaign_item",S.GROUP_CAMPAIGN_ITEMS="group_campaign_items",S.SINGLE_CAMPAIGN="experiment_id",S.GROUP_CAMPAIGN="experiment_group_id",S.CAMPAIGN_VERSION_ID="version_id",S.GROUP_CAMPAIGN_VERSION_ID="group_version_id",e.EOperatorField=void 0,(_=e.EOperatorField||(e.EOperatorField={})).DEVICE_OPERATOR="deviceOperator",_.VISITOR_OPERATOR="visitorOperator",_.TRAFFIC_SOURCE_OPERATOR="trafficSourceOperator",_.VERSION_OPERATOR="versionOperator",_.PAGE_OPERATOR="pageOperator",_.CAMPAIGN_ITEM_OPERATOR="campaignItemOperator",e.EGroupWithClause=void 0,(N=e.EGroupWithClause||(e.EGroupWithClause={})).NONE="",N.TOTALS="TOTALS",N.ALL="WITH GROUP_TOTALS, TOTALS",e.EOrderDirectionType=void 0,(y=e.EOrderDirectionType||(e.EOrderDirectionType={})).ASC="ASC",y.DESC="DESC",e.EPageMetric=void 0,(D=e.EPageMetric||(e.EPageMetric={})).PAGE_ITEMS="page_items",D.PAGE_PATHS="page_paths",e.EPageDimension=void 0,(e.EPageDimension||(e.EPageDimension={})).PAGE_PATH="page_path",e.EPageField=void 0,(C=e.EPageField||(e.EPageField={})).SHOPIFY_PAGE_ID="shopify_page_id",C.LOCATION_PATH="location_path",C.PAGE_TYPE="page_type",C.PAGE_TITLE="page_title",C.PAGE_PATH="page_path",C.TEMPLATE_SUFFIX="template_suffix",e.ERowReaderMode=void 0,(F=e.ERowReaderMode||(e.ERowReaderMode={})).DEFAULT="DEFAULT",F.COMPARISON="COMPARISON",F.TOTALS="TOTALS",F.COMPARISON_TOTALS="COMPARISON_TOTALS",e.ETimeDimension=void 0,(g=e.ETimeDimension||(e.ETimeDimension={})).HOUR="hour",g.DAY="day",g.WEEK="week",g.MONTH="month",g.QUARTER="quarter",g.YEAR="year";const h={[e.ERowReaderMode.DEFAULT]:{prefix:"",suffix:""},[e.ERowReaderMode.COMPARISON]:{prefix:c,suffix:m},[e.ERowReaderMode.TOTALS]:{prefix:"",suffix:u},[e.ERowReaderMode.COMPARISON_TOTALS]:{prefix:c,suffix:d}},M="YYYY-MM-DDTHH:mm:ss",P=["MODE","FROM","SHOW","GROUP BY","TIMESERIES","SINCE","DURING","TIMEZONE","WHERE","ORDER BY","LIMIT","OFFSET"],x=P.join("|"),G=1e3,v=e.EGroupOperator.OR,j=(e,r=v)=>e.length?1===e.length?e[0]??"":`(${e.join(` ${r} `)})`:"",Y=r=>{switch(r.operator){case e.EComparisonOperator.EQ:return(({fields:e,value:r,groupOperator:t})=>e.length?j(e.map(e=>`${e} = ${r}`),t):"")(r);case e.EComparisonOperator.IN:return(({fields:e,values:r,groupOperator:t})=>e.length&&r.length?j(e.map(e=>`${e} IN (${r.join(", ")})`),t):"")(r);case e.EComparisonOperator.LIKE:return(({fields:e,value:r,groupOperator:t})=>{const a=r.trim();return a&&e.length?j(e.map(e=>`${e} LIKE '%${a}%'`),t):""})(r)}},$=e=>e?.length?e.map(Y).filter(Boolean):[],L=[{operator:e.EOperatorField.DEVICE_OPERATOR,singleField:e.EFilterField.DEVICE,multiField:e.EFilterField.DEVICES,fieldName:e.EFilterField.DEVICE},{operator:e.EOperatorField.VISITOR_OPERATOR,singleField:e.EFilterField.VISITOR,multiField:e.EFilterField.VISITORS,fieldName:e.EFilterField.VISITOR},{operator:e.EOperatorField.TRAFFIC_SOURCE_OPERATOR,singleField:e.EFilterField.TRAFFIC_SOURCE,multiField:e.EFilterField.TRAFFIC_SOURCES,fieldName:e.EFilterField.TRAFFIC_SOURCE},{operator:e.EOperatorField.VERSION_OPERATOR,singleField:e.EFilterField.VERSION,multiField:e.EFilterField.VERSIONS,fieldName:e.EFilterField.VERSION},{operator:e.EOperatorField.PAGE_OPERATOR,singleField:e.EFilterField.SINGLE_PAGE,multiField:e.EFilterField.LIST_PAGE,fieldName:e.EFilterField.SINGLE_PAGE},{operator:e.EOperatorField.CAMPAIGN_ITEM_OPERATOR,singleField:e.EFilterField.GROUP_CAMPAIGN_ITEM,multiField:e.EFilterField.GROUP_CAMPAIGN_ITEMS,condition:e.EFilterField.GROUP_CAMPAIGN,fieldName:e.EFilterField.SINGLE_CAMPAIGN},{operatorVal:p,singleField:e.EFilterField.SINGLE_CAMPAIGN,multiField:e.EFilterField.GROUP_CAMPAIGN}],b=(e,r)=>{const t=[],a=Object.keys(e).length>0,i=!!r&&Object.keys(r).length>0;if(!a&&!i)return t;const n=(e=>e?Object.fromEntries(Object.entries(e).filter(([,e])=>void 0!==e).map(([e,r])=>[e,Array.isArray(r)?`${e} IN (${r.join(", ")})`:`${e} = ${r}`])):{})(r);return L.forEach(({operator:r,operatorVal:a,singleField:i,multiField:s,condition:o,fieldName:l})=>{if(n[i])return void t.push(n[i]);const E=r?e[r]:a;let u=e[i];const c=e[s],m=o&&e[o];if(o&&!m)return;const d=l??(u?i:s);a&&!u&&(u=e[s]);const A=(e=>{const{operatorValue:r,singleValue:t,multiValue:a,fieldName:i}=e;return r===p&&t?`${i} = ${t}`:r===R&&Array.isArray(a)&&a.length>0?`${i} IN (${a.join(", ")})`:""})({operatorValue:E,singleValue:Array.isArray(u)?void 0:u,multiValue:Array.isArray(c)?c:void 0,fieldName:d});A&&t.push(A)}),t},U=e=>{const r=[];return e?(Object.entries(e).forEach(([e,t])=>{t&&r.push(`${e} = ${t}`)}),r):r},Q=(e,r)=>{if(!e||0===r.length)return[];const t=r.find(r=>e[r]);return t?[t]:[]},V=({filters:e,overrideFilters:r,versionIds:t,extraConditions:a})=>{const i=[...b(e,r),...U(t),...$(a)];return i.length>0?`WHERE ${i.join(" AND ")}`:""},H=e=>{const r=e.match(new RegExp(`\\bWHERE\\s+([\\s\\S]+?)(?=\\s+(?:${x})\\b|$)`,"i"));if(!r)return{filters:{}};const t=(r[1]??"").trim().split(/\s+AND\s+/i),a={},i={};return t.forEach(e=>{const r=e.trim(),t=r.match(/^(\S+)\s+IN\s+\((.+)\)$/i);if(t){const e=t[1]??"",r=(t[2]??"").split(",").map(e=>e.trim()),i=L.find(r=>r.fieldName===e||r.multiField===e);return void(i?.operator&&(a[i.multiField]=r,a[i.operator]=R))}const n=r.match(/^(\S+)\s+=\s+(.+)$/);if(n){const e=n[1]??"",r=n[2]??"",t=L.find(r=>r.fieldName===e||r.singleField===e);t?(a[t.singleField]=r,t.operator&&(a[t.operator]=p)):e&&(i[e]=r)}}),{filters:a,versionIds:Object.keys(i).length>0?i:void 0}},W=e=>`FROM ${e.join(", ")}`,K=e=>{const r=e.match(new RegExp(`\\bFROM\\s+([\\s\\S]+?)(?=\\s+(?:${x})\\b)`,"i"));return r?(r[1]??"").split(",").map(e=>e.trim()).filter(Boolean):[]},w=(r,t=e.EGroupWithClause.ALL)=>0===r.length?"":`GROUP BY ${r.join(", ")} ${t}`,B=r=>{const t=r.match(new RegExp(`\\bGROUP BY\\s+([\\s\\S]+?)(?=\\s+(?:${x})\\b)`,"i"));if(!t)return{dimensions:[]};const a=(t[1]??"").trim(),i=a.toUpperCase().indexOf(" WITH ");return-1===i?{dimensions:a.split(",").map(e=>e.trim()).filter(Boolean),groupWithClause:e.EGroupWithClause.NONE}:{dimensions:a.slice(0,i).split(",").map(e=>e.trim()).filter(Boolean),groupWithClause:a.slice(i+1).trim()}},q=e=>e?`LIMIT ${e}`:"",X=e=>{const r=e.match(/\bLIMIT\s+(\d+)/i);return r?parseInt(r[1]??"0",10):void 0},k=e=>`MODE ${e}`,z=e=>{const r=e.match(/\bMODE\s+(\S+)/i);return r?.[1]},J=e=>!e||e<0?"":`OFFSET ${e}`,Z=e=>{const r=e.match(/\bOFFSET\s+(\d+)/i);return r?parseInt(r[1]??"0",10):void 0},ee=(e,r)=>{if(!e)return"";const t=Object.values(e).filter(e=>r?.includes(e.field)).map(e=>`${e.field} ${e.direction}`).join(", ");return t?`ORDER BY ${t}`:""},re=e=>{const r=e.match(new RegExp(`\\bORDER BY\\s+([\\s\\S]+?)(?=\\s+(?:${x})\\b|$)`,"i"));if(!r)return;const t={};return(r[1]??"").split(",").forEach(e=>{const r=e.trim().split(/\s+/);if(2===r.length){const e=r[0]??"",a=r[1]??"";e&&(t[e]={field:e,direction:a})}}),Object.keys(t).length>0?t:void 0},te=e=>`SHOW ${e.join(", ")}`,ae=e=>{const r=e.match(new RegExp(`\\bSHOW\\s+([\\s\\S]+?)(?=\\s+(?:${x})\\b)`,"i"));return r?(r[1]??"").split(",").map(e=>e.trim()).filter(Boolean):[]},ie=/\.0+$/,ne=(e,r=2)=>(e=>`${e}`.replace(ie,""))(e.toFixed(r)),se=(e,r,t=2)=>{const a=((e,r,t=2)=>{if("number"!=typeof e||!r)return;return 0===e?0:parseFloat(ne(e/r*100,t))})(e,r,t);if("number"==typeof a)return(e=>e>0&&e<.005)(a)?"~0%":`${a}%`};r.extend(i),r.extend(a),r.extend(t);let oe="UTC";function le(){return oe}const Ee=e=>e?r(e).tz(oe):r().tz(oe);var ue;!function(e){e.DAY="DAY",e.HOUR="HOUR",e.MONTH="MONTH",e.QUARTER="QUARTER",e.WEEK="WEEK",e.YEAR="YEAR"}(ue||(ue={}));const ce=60,me=3600,de=(e,r,t)=>{if(!e)return"";const a=t?.isExpandDetail?{formatHouse:"MMM D, h:mm A",formatDay:"MMM D, YYYY",formatMonth:"MMM YYYY",formatYear:"MMM YYYY"}:{formatHouse:"h A",formatDay:"MMM D",formatMonth:"MMM YYYY",formatYear:"YYYY"};switch(r){case ue.HOUR:return Ee(e).format(a.formatHouse);case ue.DAY:case ue.WEEK:return Ee(e).format(a.formatDay);case ue.MONTH:return Ee(e).format(a.formatMonth);case ue.QUARTER:{const r=Ee(e);return`Q${r.quarter()} ${r.format("YYYY")}`}case ue.YEAR:return Ee(e).format(a.formatYear)}return Ee(e).format(a.formatMonth)},pe=e=>"string"==typeof e?Ee(e):e,Re=(e,r=!1)=>r&&(e=>0===e.hour()&&0===e.minute())(e)?e.endOf("day").format(M):e.format(M),Ae=e=>{const r=pe(e.startDate),t=pe(e.endDate);return r.isSame(t)?{dateGTE:Re(r),dateLTE:(a=t,Re(a?Ee(a).endOf("day"):Ee().endOf("day")))}:{dateGTE:Re(r),dateLTE:Re(t,!0)};var a},Oe=e=>{const{dateRange:r,compareDateRange:t,overrideFilters:a,timeDimension:i}=e,n=i?a?.[i]:void 0;if(i&&n)return`DURING (${n}, ${i})`;if(!r)return"";const{dateGTE:s,dateLTE:o}=Ae(r),{dateGTE:l,dateLTE:E}=t?Ae(t):{};return`SINCE ${s} UNTIL ${o} ${t?`COMPARE TO ${l} UNTIL ${E}`:""}`},Te=e=>{const r=e.match(/\bDURING\s+\(([^,]+),\s*([^)]+)\)/i);if(r){const e=r[1]??"",t=r[2]??"";return{timeDimension:t.trim(),overrideFilters:{[t.trim()]:e.trim()}}}const t=e.match(/\bSINCE\s+(\S+)\s+UNTIL\s+(\S+)/i);if(!t)return{};const a={startDate:Ee(t[1]??""),endDate:Ee(t[2]??"")},i=e.match(/\bCOMPARE TO\s+(\S+)\s+UNTIL\s+(\S+)/i);return{dateRange:a,compareDateRange:i?{startDate:Ee(i[1]??""),endDate:Ee(i[2]??"")}:void 0}},fe=e=>e?`TIMESERIES ${e}`:"",Ie=e=>{const r=e.match(/\bTIMESERIES\s+(\S+)/i);return r?.[1]},Se=e=>{const r=e??le();return r?`TIMEZONE ${r}`:""},_e=e=>{const r=e.match(/\bTIMEZONE\s+(\S+)/i);return r?.[1]};function Ne(e){if("string"!=typeof e)return!1;const r=e.trim();return/^MODE\b[\s\S]*\bFROM\b[\s\S]*\bSHOW\b[\s\S]*$/.test(r)}const ye=e=>e?.gemxQLQuery?.tableData?.columns??[],De=e=>{if(!e)return"None";const r=Ee(e),t=Ee(),a=Ee().subtract(1,"day"),i=r.format("YYYY-MM-DD")===t.format("YYYY-MM-DD"),n=r.format("YYYY-MM-DD")===a.format("YYYY-MM-DD");if(i)return`Today at ${r.format("HH:mm")}`;if(n)return`Yesterday at ${r.format("HH:mm")}`;const s=t.diff(r,"day");return s>=0&&s<7?`${r.format("dddd")} at ${r.format("HH:mm")}`:`${r.format("MMM D")} at ${r.format("hh:mm a")}`},Ce=({value:r,formatter:t,getTextPrice:a,name:i})=>{if(null!==r&&("object"==typeof r||Array.isArray(r)))return r;switch(t){case e.EAnalyticDataType.INTEGER:return(r??0).toString().toString().replace(/\B(?=(\d{3})+(?!\d))/g,",");case e.EAnalyticDataType.CURRENCY:return a?a(r,!1):`${r??0}`;case e.EAnalyticDataType.DATE:return De(r);case e.EAnalyticDataType.PERCENT:return"number"!=typeof r?se(0,1,2)??"":se(r/100,1,2)??"";case e.EAnalyticDataType.DURATION:return(e=>{let r=e;Number.isFinite(e)&&null!=e||(r=0);const t=ne(r);if(r>=me)return`${Math.floor(r/me)}h ${Math.floor(r%me/ce)}m ${Math.floor(r%ce)}s`;if(r>=ce)return`${Math.floor(r/ce)}m ${Math.floor(r%ce)}s`;return`${t}s`})(Number(r));case e.EAnalyticDataType.STRING:{const t=i===e.EAnalyticColumnKey.CAMPAIGNS?"":E;return r??t}case e.EAnalyticDataType.DAY:return de(r,ue.DAY,{isExpandDetail:!0});case e.EAnalyticDataType.HOUR:return de(r,ue.HOUR,{isExpandDetail:!0});case e.EAnalyticDataType.MONTH:return de(r,ue.MONTH,{isExpandDetail:!0});case e.EAnalyticDataType.YEAR:return de(r,ue.YEAR);case e.EAnalyticDataType.WEEK:return de(r,ue.WEEK,{isExpandDetail:!0});case e.EAnalyticDataType.QUARTER:return de(r,ue.QUARTER,{isExpandDetail:!0});case e.EAnalyticDataType.OBJECT:case e.EAnalyticDataType.ARRAY:return r;default:return`${r}`}},Fe=e=>{const r=e?.sessions;return"number"==typeof r&&r>0},ge=e=>{if(e)return"string"==typeof e?JSON.parse(e):e},he=e=>{try{const r=ge(e);return r&&"object"==typeof r?r:null}catch{return null}},Me=e=>{try{const r=ge(e);if(!Array.isArray(r))return;return r}catch{return}},Pe=(e,r)=>{const t=e?.[r];return"number"==typeof t?t:0},xe="\n fragment ColumnSelect on Column {\n dataType\n displayName\n name\n}\n ",Ge="\n fragment TableDataSelect on TableData {\n columns {\n ...ColumnSelect\n }\n rows\n}\n ",ve="\n fragment GemXQLResultSelect on GemxQLResult {\n tableData {\n ...TableDataSelect\n }\n}\n ",je=`\n query GemxQL($input: String!) {\n gemxQLQuery(query: $input) {\n ...GemXQLResultSelect\n }\n}\n ${ve}\n${Ge}\n${xe}`,Ye=(e,r,t)=>n.useQuery({queryKey:["GemXQlCustom",e],queryFn:r(je,e),...t});Ye.getKey=e=>["GemXQlCustom",e];const $e=({name:e,variables:r,fetcher:t},a)=>{const i=je.replace(/query\s+GemxQL\b/,`query ${e}`);return n.useQuery({queryKey:[e,r],queryFn:t(i,r),retry:0,...a})};var Le,be,Ue,Qe,Ve;$e.getKey=(e,r)=>[e,r],function(e){e.SESSION="sessions",e.ORDERS="orders",e.PAGE_VIEWS="pageviews",e.VISITORS="visitors",e.BOUNCE_RATE="bounce_rate",e.CTR="ctr",e.CONVERSION_RATE="conversion_rate",e.AVG_TIME_ON_PAGE="average_time_on_page",e.ADDED_TO_CART="added_to_cart",e.ADD_TO_CART_RATE="added_to_cart_rate",e.REACHED_CHECKOUT="sessions_that_reached_checkout",e.COMPLETE_CHECKOUT="sessions_that_completed_checkout",e.CART_ADDITION="sessions_with_cart_additions",e.AOV="aov",e.REVENUE="revenue",e.RPV="revenue_per_visitor",e.VISITOR_ITEMS="visitor_items",e.DEVICE_ITEMS="device_items",e.TRAFFIC_SOURCE_ITEMS="traffic_source_items"}(Le||(Le={})),Le.SESSION,Le.VISITORS,Le.BOUNCE_RATE,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Bounce rate"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"sessions with a pageview"}),s.jsx("span",{className:"formula-operator",children:" / "}),s.jsx("span",{className:"formula-input",children:"total sessions"})]}),Le.CTR,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Click-through rate"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"total clicks"}),s.jsx("span",{className:"formula-operator",children:" / "}),s.jsx("span",{className:"formula-input",children:"total pageviews"})]}),Le.AVG_TIME_ON_PAGE,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Average time on page"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"total time on page"}),s.jsx("span",{className:"formula-operator",children:" / "}),s.jsx("span",{className:"formula-input",children:"(total pageviews - total exits)"})]}),Le.PAGE_VIEWS,Le.RPV,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Revenue per visitor"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"total revenue"}),s.jsx("span",{className:"formula-operator",children:" / "}),s.jsx("span",{className:"formula-input",children:"total visitors"})]}),Le.ADDED_TO_CART,Le.REACHED_CHECKOUT,Le.COMPLETE_CHECKOUT,Le.ORDERS,Le.CONVERSION_RATE,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Conversion rate"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"sessions that completed checkout"}),s.jsx("span",{className:"formula-operator",children:" / "}),s.jsx("span",{className:"formula-input",children:"total sessions"})]}),Le.AOV,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Average order value"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"total revenue"}),s.jsx("span",{className:"formula-operator",children:" / "}),s.jsx("span",{className:"formula-input",children:"total orders"})]}),Le.REVENUE,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Revenue"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"gross sales"}),s.jsx("span",{className:"formula-operator",children:" - "}),s.jsx("span",{className:"formula-input",children:"discounts"})]}),Le.ADD_TO_CART_RATE,s.jsxs(s.Fragment,{children:[s.jsx("span",{className:"formula-variable",children:"Added to cart rate"}),s.jsx("span",{children:" = "}),s.jsx("span",{className:"formula-input",children:"sessions with cart additions"}),s.jsx("span",{className:"formula-operator",children:" / "}),s.jsx("span",{className:"formula-input",children:"total sessions"})]}),Le.CART_ADDITION,Le.VISITOR_ITEMS,Le.DEVICE_ITEMS,Le.TRAFFIC_SOURCE_ITEMS,function(e){e.ALL_SESSION="ALL_SESSION",e.FIRST_SESSION="FIRST_SESSION",e.PAGE_ONLY="PAGE_ONLY"}(be||(be={})),function(e){e.NEW="new",e.RETURNING="returning"}(Ue||(Ue={})),function(e){e.DESKTOP="desktop",e.MOBILE="mobile",e.TABLET="tablet"}(Qe||(Qe={})),function(e){e.DIRECT="direct",e.EMAIL="email",e.REFERRAL="referral",e.ORGANIC_SOCIAL="organic-social",e.ORGANIC_SEARCH="organic-search",e.PAID_SOCIAL="paid-social",e.PAID_SEARCH="paid-search",e.SMS="sms"}(Ve||(Ve={})),Ue.NEW,Ue.RETURNING,Qe.DESKTOP,Qe.TABLET,Qe.MOBILE,Ve.DIRECT,Ve.EMAIL,Ve.REFERRAL,Ve.ORGANIC_SOCIAL,Ve.ORGANIC_SEARCH,Ve.PAID_SOCIAL,Ve.PAID_SEARCH,Ve.SMS,l.create(e=>({currencyRates:null,setCurrencyRates:r=>e({currencyRates:r})}));const He=o.createContext({getTextPrice:e=>"string"==typeof e?e:`${e??0}`});var We;e.GPaginationDirection=void 0,(We=e.GPaginationDirection||(e.GPaginationDirection={})).NEXT="NEXT",We.PREV="PREV";e.CLAUSE_KEYWORDS=P,e.CLAUSE_KEYWORD_BOUNDARY=x,e.COMPARE_PREFIX=c,e.COMPARE_SUFFIX=m,e.COMPARE_TOTALS_SUFFIX=d,e.ColumnSelectFragmentDoc=xe,e.DATE_QUERY_FORMAT=M,e.DEFAULT_QUERY_LIMIT=G,e.GemXqlResultSelectFragmentDoc=ve,e.GemxQlDocument=je,e.NONE_VALUE=E,e.OPERATOR_IS=p,e.OPERATOR_IS_ONE_OF=R,e.PLACEHOLDER_VALUE="-",e.ROW_READER_MODE_CONFIG=h,e.TOTALS_SUFFIX=u,e.TableDataSelectFragmentDoc=Ge,e.buildConditionQuery=V,e.buildExtraCondition=Y,e.buildExtraConditions=$,e.buildFromQuery=W,e.buildGemXQlQuery=e=>{const{mode:r,metrics:t,dimensions:a,dateRange:i,compareDateRange:n,filters:s,overrideFilters:o,versionIds:l,extraConditions:E,orderBy:u,sources:c,timeDimension:m,groupWithClause:d,timezone:p,limit:R=G,offset:A,extraOrderByFields:O}=e,T=[...a,...Q(u,t),...O??[]],f=[k(r),W(c),te(t),w(a,d),fe(m),Oe({dateRange:i,compareDateRange:n,timeDimension:m,overrideFilters:o}),Se(p),V({filters:s,overrideFilters:o,versionIds:l,extraConditions:E}),ee(u,T),q(R),J(A)].filter(Boolean).join(" ");return Ne(f)?f:""},e.buildGroupQuery=w,e.buildLimitQuery=q,e.buildModeQuery=k,e.buildOffsetQuery=J,e.buildOrderByQuery=ee,e.buildShowQuery=te,e.buildTimeQuery=Oe,e.buildTimeSeriesQuery=fe,e.buildTimezoneQuery=Se,e.buildVersionIdCondition=U,e.createNumericRowReader=(r,t=e.ERowReaderMode.DEFAULT)=>e=>{const{prefix:a,suffix:i}=h[t],n=r[`${a}${e}${i}`];if("number"==typeof n)return n;if("string"==typeof n){const e=parseFloat(n);return isNaN(e)?0:e}return 0},e.extractColumnTypes=e=>{const r=ye(e),t={};for(const e of r)e?.name&&(t[e.name]=e.dataType);return t},e.extractQueryColumns=ye,e.extractQueryRows=e=>e?.gemxQLQuery?.tableData?.rows??[],e.filterConfigs=L,e.formatAnalyticData=Ce,e.formatAnalyticDate=De,e.generateFilterConditions=b,e.getComparisonKey=e=>`${c}${e}${m}`,e.getComparisonTotalsKey=e=>`${c}${e}${m}${u}`,e.getFirstMetricInOrderBy=Q,e.getTimeDimensionByDate=(r,t)=>{const a=t.diff(r,"day");return a<=3?e.ETimeDimension.HOUR:a<=93?e.ETimeDimension.DAY:e.ETimeDimension.MONTH},e.getTotalsKey=e=>`${e}${u}`,e.hasMetricData=Fe,e.isValidQueryInput=Ne,e.parseBreakdownItems=e=>Me(e)?.map(e=>({...e,total:Number(e.total)})),e.parseConditionQuery=H,e.parseFromQuery=K,e.parseGemXQlQuery=e=>{const{dateRange:r,compareDateRange:t,timeDimension:a,overrideFilters:i}=Te(e),n=a??Ie(e),{dimensions:s,groupWithClause:o}=B(e),{filters:l,versionIds:E}=H(e);return{mode:z(e),sources:K(e),metrics:ae(e),dimensions:s,groupWithClause:o,timeDimension:n,dateRange:r,compareDateRange:t,overrideFilters:i,filters:l,versionIds:E,timezone:_e(e),orderBy:re(e),limit:X(e),offset:Z(e)}},e.parseGroupQuery=B,e.parseJsonArray=Me,e.parseJsonObject=he,e.parseLimitQuery=X,e.parseModeQuery=z,e.parseOffsetQuery=Z,e.parseOrderByQuery=re,e.parsePageItems=e=>he(e),e.parseShowQuery=ae,e.parseTimeQuery=Te,e.parseTimeSeriesQuery=Ie,e.parseTimezoneQuery=_e,e.readNumeric=Pe,e.useAnalyticData=()=>{const{getTextPrice:e}=o.useContext(He),r=({value:r,formatter:t,name:a})=>Ce({value:r,formatter:t,getTextPrice:e,name:a});return{formatData:r,computeMetric:({metric:e,previousMetric:t,metricKey:a,formatter:i})=>{if(!Fe(e))return{value:0,change:"-"};const n=Pe(e,a),s=Pe(t,a),o=r({value:n,formatter:i,name:a});if(0===n&&0!==s)return{value:o,change:-100};if(0===s)return{value:o,change:"-"};return{value:o,change:(n-s)/s*100}}}},e.useCustomGemXQlQuery=Ye,e.useGemXQlPagination=({resetKey:r,itemsPerPage:t})=>{const[a,i]=o.useState(1),n=o.useRef(),s=a>1&&void 0!==n.current&&n.current!==r?1:a,l=(s-1)*t,E=o.useCallback(r=>t=>{i(a=>{const i=t===e.GPaginationDirection.NEXT?a+1:a-1;return Math.min(Math.max(i,1),r)})},[]);o.useEffect(()=>{n.current!==r&&(n.current=r,i(1))},[r]);const u=o.useCallback(({totalRecords:e,isLoading:r})=>{const a=Math.max(1,Math.ceil(e/t));return{currentPage:s,totalPages:a,loading:r,handlePageChange:E(a)}},[s,t,E]);return{currentPage:s,offset:l,buildPagination:u}},e.useGemxQlNamedQuery=$e});