@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.
- package/dist/esm/core/gemxql/builder/clauses/time-query.d.ts +2 -1
- package/dist/esm/core/gemxql/builder/helpers/date-query-helpers.d.ts +1 -1
- package/dist/esm/core/gemxql/hooks/useAnalyticData.d.ts +1 -2
- package/dist/esm/core/gemxql/types/date-filter.d.ts +1 -1
- package/dist/esm/core/gemxql/types/index.d.ts +0 -1
- package/dist/esm/gemxql.js +183 -2
- package/dist/esm/gemxql.mjs +183 -2
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.js +117 -3
- package/dist/esm/index.mjs +117 -3
- package/dist/esm/providers/ConvertMoneyProvider.d.ts +13 -0
- package/dist/esm/providers/currencyRatesStore.d.ts +7 -0
- package/dist/esm/providers/index.d.ts +5 -0
- package/dist/esm/providers/useFetchCurrencyRates.d.ts +1 -0
- package/dist/esm/utils/currency.d.ts +5 -0
- package/dist/umd/esm/core/gemxql/builder/clauses/time-query.d.ts +2 -1
- package/dist/umd/esm/core/gemxql/builder/helpers/date-query-helpers.d.ts +1 -1
- package/dist/umd/esm/core/gemxql/hooks/useAnalyticData.d.ts +1 -2
- package/dist/umd/esm/core/gemxql/types/date-filter.d.ts +1 -1
- package/dist/umd/esm/core/gemxql/types/index.d.ts +0 -1
- package/dist/umd/esm/index.d.ts +1 -0
- package/dist/umd/esm/providers/ConvertMoneyProvider.d.ts +13 -0
- package/dist/umd/esm/providers/currencyRatesStore.d.ts +7 -0
- package/dist/umd/esm/providers/index.d.ts +5 -0
- package/dist/umd/esm/providers/useFetchCurrencyRates.d.ts +1 -0
- package/dist/umd/esm/utils/currency.d.ts +5 -0
- package/dist/umd/gemxql.js +1 -1
- package/dist/umd/index.js +1 -1
- package/package.json +2 -2
package/dist/esm/index.mjs
CHANGED
|
@@ -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 = (
|
|
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;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type {
|
|
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,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: (
|
|
22
|
+
export declare const useAnalyticData: () => IUseAnalyticDataReturn;
|
|
24
23
|
export {};
|
package/dist/umd/esm/index.d.ts
CHANGED
|
@@ -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;
|
package/dist/umd/gemxql.js
CHANGED
|
@@ -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});
|