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

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 (27) hide show
  1. package/dist/esm/components/GTimePicker/hooks/useDateTimeFilter.d.ts +2 -2
  2. package/dist/esm/core/gemxql/helpers/extractQueryData.d.ts +1 -1
  3. package/dist/esm/gemxql.js +2 -1
  4. package/dist/esm/gemxql.mjs +2 -1
  5. package/dist/esm/hooks/index.d.ts +2 -1
  6. package/dist/esm/hooks/useFetchCurrencyRates.d.ts +1 -0
  7. package/dist/esm/index.d.ts +2 -0
  8. package/dist/esm/index.js +98 -65
  9. package/dist/esm/index.mjs +98 -65
  10. package/dist/esm/providers/index.d.ts +0 -3
  11. package/dist/esm/shared/charts/components/GPolarisViz/components/TooltipWrapper/utilities/getDonutChartTooltipPosition.d.ts +1 -1
  12. package/dist/esm/shared/charts/components/GPolarisViz/components/TooltipWrapper/utilities/getLineChartTooltipPosition.d.ts +1 -1
  13. package/dist/esm/stores/currencyRatesStore.d.ts +7 -0
  14. package/dist/esm/stores/index.d.ts +2 -0
  15. package/dist/umd/esm/components/GTimePicker/hooks/useDateTimeFilter.d.ts +2 -2
  16. package/dist/umd/esm/core/gemxql/helpers/extractQueryData.d.ts +1 -1
  17. package/dist/umd/esm/hooks/index.d.ts +2 -1
  18. package/dist/umd/esm/hooks/useFetchCurrencyRates.d.ts +1 -0
  19. package/dist/umd/esm/index.d.ts +2 -0
  20. package/dist/umd/esm/providers/index.d.ts +0 -3
  21. package/dist/umd/esm/shared/charts/components/GPolarisViz/components/TooltipWrapper/utilities/getDonutChartTooltipPosition.d.ts +1 -1
  22. package/dist/umd/esm/shared/charts/components/GPolarisViz/components/TooltipWrapper/utilities/getLineChartTooltipPosition.d.ts +1 -1
  23. package/dist/umd/esm/stores/currencyRatesStore.d.ts +7 -0
  24. package/dist/umd/esm/stores/index.d.ts +2 -0
  25. package/dist/umd/gemxql.js +1 -1
  26. package/dist/umd/index.js +1 -1
  27. package/package.json +1 -1
@@ -0,0 +1,2 @@
1
+ export { useCurrencyRatesStore } from './currencyRatesStore';
2
+ export type { ICurrencyRates } from './currencyRatesStore';
@@ -4,14 +4,14 @@ export declare const useDateTimeFilter: () => {
4
4
  LAST_7_DAYS_DATE_RANGE: {
5
5
  since: string | number;
6
6
  until: string | number;
7
- getDateRange: (date: import("dayjs").Dayjs) => import("../types").IDateTimeFilterValue;
7
+ getDateRange: (date: import("dayjs").Dayjs) => import("..").IDateTimeFilterValue;
8
8
  title: string;
9
9
  alias: string;
10
10
  };
11
11
  LAST_30_DAYS_DATE_RANGE: {
12
12
  since: string | number;
13
13
  until: string | number;
14
- getDateRange: (date: import("dayjs").Dayjs) => import("../types").IDateTimeFilterValue;
14
+ getDateRange: (date: import("dayjs").Dayjs) => import("..").IDateTimeFilterValue;
15
15
  title: string;
16
16
  alias: string;
17
17
  };
@@ -1,5 +1,5 @@
1
1
  import type { GemxQlQueryResponse, TableDataType } from '../graphql';
2
2
  export type ColumnTypesMap = Record<string, TableDataType>;
3
3
  export declare const extractQueryRows: (response?: GemxQlQueryResponse) => Record<string, unknown>[];
4
- export declare const extractQueryColumns: (response?: GemxQlQueryResponse) => import("../graphql").Maybe<Pick<import("../graphql").IColumn, "dataType" | "displayName" | "name">>[];
4
+ export declare const extractQueryColumns: (response?: GemxQlQueryResponse) => import("..").Maybe<Pick<import("..").IColumn, "dataType" | "displayName" | "name">>[];
5
5
  export declare const extractColumnTypes: (response?: GemxQlQueryResponse) => ColumnTypesMap;
@@ -1,5 +1,6 @@
1
1
  export { useEnhancedEffect } from './useEnhancedEffect';
2
- export { useToggle } from './useToggle';
2
+ export { useFetchCurrencyRates } from './useFetchCurrencyRates';
3
3
  export { useFormatLineChartData } from './useFormatLineChartData';
4
4
  export { usePopoverResizeObserver } from './usePopoverResizeObserver';
5
+ export { useToggle } from './useToggle';
5
6
  export { useWindowSize } from './useWindowSize';
@@ -0,0 +1 @@
1
+ export declare const useFetchCurrencyRates: () => void;
@@ -1,4 +1,6 @@
1
1
  export * from './components';
2
2
  export * from './constants';
3
+ export * from './hooks';
3
4
  export * from './providers';
5
+ export * from './stores';
4
6
  export * from './utils/dayjs';
@@ -1,6 +1,3 @@
1
1
  export { ConvertMoneyProvider, useConvertMoneyContext } from './ConvertMoneyProvider';
2
2
  export type { IProps as IConvertMoneyProviderProps } from './ConvertMoneyProvider';
3
- export { useCurrencyRatesStore } from './currencyRatesStore';
4
- export type { ICurrencyRates } from './currencyRatesStore';
5
3
  export { MetricChartProvider } from './MetricChartProvider';
6
- export { useFetchCurrencyRates } from './useFetchCurrencyRates';
@@ -4,5 +4,5 @@ interface Props extends Pick<TooltipPositionParams, 'event' | 'eventType' | 'ind
4
4
  containerBounds: BoundingRect;
5
5
  parentElement: SVGSVGElement | null;
6
6
  }
7
- export declare function getDonutChartTooltipPosition({ containerBounds, event, eventType, index, parentElement }: Props): import("../types").TooltipPosition;
7
+ export declare function getDonutChartTooltipPosition({ containerBounds, event, eventType, index, parentElement }: Props): import("..").TooltipPosition;
8
8
  export {};
@@ -7,5 +7,5 @@ interface Props extends Omit<TooltipPositionParams, 'xScale'> {
7
7
  scrollY: number;
8
8
  xScale: ScaleLinear<number, number>;
9
9
  }
10
- export declare function getLineChartTooltipPosition({ containerBounds, chartBounds, data, event, eventType, index, isTouchDevice, longestSeriesIndex, scrollY, xScale, }: Props): import("../types").TooltipPosition;
10
+ export declare function getLineChartTooltipPosition({ containerBounds, chartBounds, data, event, eventType, index, isTouchDevice, longestSeriesIndex, scrollY, xScale, }: Props): import("..").TooltipPosition;
11
11
  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 {};
@@ -0,0 +1,2 @@
1
+ export { useCurrencyRatesStore } from './currencyRatesStore';
2
+ export type { ICurrencyRates } from './currencyRatesStore';
@@ -1 +1 @@
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});
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("zustand"),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/jsx-runtime","zustand","react"],r):r((e="undefined"!=typeof globalThis?globalThis:e||self).GemAnalytics={},e.dayjs,e.quarterOfYear,e.timezone,e.utc,e.reactQuery,e.jsxRuntime,e.zustand,e.React)}(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 T,A,O,f,I,S,_,N,y,D,C,g,F;e.EAnalyticDataType=void 0,(T=e.EAnalyticDataType||(e.EAnalyticDataType={})).DATE="DATE",T.ARRAY="ARRAY",T.OBJECT="OBJECT",T.STRING="STRING",T.INTEGER="INTEGER",T.CURRENCY="CURRENCY",T.PERCENT="PERCENT",T.DURATION="DURATION",T.MONTH="MONTH_TIMESTAMP",T.QUARTER="QUARTER_TIMESTAMP",T.DAY="DAY_TIMESTAMP",T.WEEK="WEEK_TIMESTAMP",T.YEAR="YEAR_TIMESTAMP",T.HOUR="HOUR_TIMESTAMP",e.EAnalyticColumnKey=void 0,(A=e.EAnalyticColumnKey||(e.EAnalyticColumnKey={})).CAMPAIGNS="experiments",A.VISITOR_ITEMS="visitor_items",A.DEVICE_ITEMS="device_items",A.TRAFFIC_SOURCE_ITEMS="traffic_source_items",e.EAnalyticSource=void 0,(O=e.EAnalyticSource||(e.EAnalyticSource={})).SESSIONS="sessions",O.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,(g=e.ERowReaderMode||(e.ERowReaderMode={})).DEFAULT="DEFAULT",g.COMPARISON="COMPARISON",g.TOTALS="TOTALS",g.COMPARISON_TOTALS="COMPARISON_TOTALS",e.ETimeDimension=void 0,(F=e.ETimeDimension||(e.ETimeDimension={})).HOUR="hour",F.DAY="day",F.WEEK="week",F.MONTH="month",F.QUARTER="quarter",F.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("|"),v=1e3,G=e.EGroupOperator.OR,j=(e,r=G)=>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 T=(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});T&&t.push(T)}),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),Te=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},Ae=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}=Te(r),{dateGTE:l,dateLTE:E}=t?Te(t):{};return`SINCE ${s} UNTIL ${o} ${t?`COMPARE TO ${l} UNTIL ${E}`:""}`},Oe=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}`}},ge=e=>{const r=e?.sessions;return"number"==typeof r&&r>0},Fe=e=>{if(e)return"string"==typeof e?JSON.parse(e):e},he=e=>{try{const r=Fe(e);return r&&"object"==typeof r?r:null}catch{return null}},Me=e=>{try{const r=Fe(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 ",ve="\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 ",je=`\n query GemxQL($input: String!) {\n gemxQLQuery(query: $input) {\n ...GemXQLResultSelect\n }\n}\n ${Ge}\n${ve}\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,o.create(e=>({currencyRates:null,setCurrencyRates:r=>e({currencyRates:r})}));const He=l.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=v,e.GemXqlResultSelectFragmentDoc=Ge,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=ve,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=v,offset:T,extraOrderByFields:A}=e,O=[...a,...Q(u,t),...A??[]],f=[k(r),W(c),te(t),w(a,d),fe(m),Ae({dateRange:i,compareDateRange:n,timeDimension:m,overrideFilters:o}),Se(p),V({filters:s,overrideFilters:o,versionIds:l,extraConditions:E}),ee(u,O),q(R),J(T)].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=Ae,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=ge,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}=Oe(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=Oe,e.parseTimeSeriesQuery=Ie,e.parseTimezoneQuery=_e,e.readNumeric=Pe,e.useAnalyticData=()=>{const{getTextPrice:e}=l.useContext(He),r=({value:r,formatter:t,name:a})=>(console.log({value:r,formatter:t,getTextPrice:e,name:a}),Ce({value:r,formatter:t,getTextPrice:e,name:a}));return{formatData:r,computeMetric:({metric:e,previousMetric:t,metricKey:a,formatter:i})=>{if(!ge(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]=l.useState(1),n=l.useRef(),s=a>1&&void 0!==n.current&&n.current!==r?1:a,o=(s-1)*t,E=l.useCallback(r=>t=>{i(a=>{const i=t===e.GPaginationDirection.NEXT?a+1:a-1;return Math.min(Math.max(i,1),r)})},[]);l.useEffect(()=>{n.current!==r&&(n.current=r,i(1))},[r]);const u=l.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:o,buildPagination:u}},e.useGemxQlNamedQuery=$e});