@envive-ai/react-hooks 0.3.6 → 0.3.7

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 (142) hide show
  1. package/dist/application/commerce-api.cjs +1 -1
  2. package/dist/application/commerce-api.js +1 -1
  3. package/dist/application/models/api/userEvent.d.cts +4 -2
  4. package/dist/application/models/api/userEvent.d.ts +4 -2
  5. package/dist/application/models/graphql/queries/getColorsAndFrontendQuery.cjs +18 -0
  6. package/dist/application/models/graphql/queries/getColorsAndFrontendQuery.js +18 -0
  7. package/dist/application/models/guards/api/isApiFormResponse.cjs +1 -1
  8. package/dist/application/models/guards/api/isApiFormResponse.js +1 -1
  9. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.cjs +1 -1
  10. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.js +1 -1
  11. package/dist/application/models/guards/api/isApiOrderResponseAttributes.cjs +1 -1
  12. package/dist/application/models/guards/api/isApiOrderResponseAttributes.js +1 -1
  13. package/dist/application/models/guards/api/isApiProductResponseAttributes.cjs +1 -1
  14. package/dist/application/models/guards/api/isApiProductResponseAttributes.js +1 -1
  15. package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.cjs +2 -2
  16. package/dist/application/models/guards/api/isApiQueryTypedEventAttributes.js +2 -2
  17. package/dist/application/models/guards/api/isApiResponse.cjs +1 -1
  18. package/dist/application/models/guards/api/isApiResponse.js +1 -1
  19. package/dist/application/utils/analyticsUtils.cjs +1 -1
  20. package/dist/application/utils/analyticsUtils.js +1 -1
  21. package/dist/application/utils/elementObserver.d.cts +2 -2
  22. package/dist/application/utils/elementObserver.d.ts +2 -2
  23. package/dist/atoms/app/variant.d.cts +6 -6
  24. package/dist/atoms/app/variant.d.ts +6 -6
  25. package/dist/atoms/chat/chatState.d.ts +17 -17
  26. package/dist/atoms/chat/form.d.cts +2 -2
  27. package/dist/atoms/chat/form.d.ts +2 -2
  28. package/dist/atoms/chat/index.cjs +1 -3
  29. package/dist/atoms/chat/index.d.cts +4 -5
  30. package/dist/atoms/chat/index.d.ts +4 -5
  31. package/dist/atoms/chat/index.js +2 -3
  32. package/dist/atoms/chat/lastMessage.d.cts +2 -2
  33. package/dist/atoms/chat/lastMessage.d.ts +2 -2
  34. package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
  35. package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
  36. package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
  37. package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
  38. package/dist/atoms/chat/suggestions.d.cts +2 -2
  39. package/dist/atoms/chat/suggestions.d.ts +2 -2
  40. package/dist/atoms/globalSearch/globalSearch.d.cts +5 -5
  41. package/dist/atoms/globalSearch/globalSearch.d.ts +5 -5
  42. package/dist/atoms/org/customerService.d.cts +6 -6
  43. package/dist/atoms/org/customerService.d.ts +6 -6
  44. package/dist/atoms/org/graphqlConfig.d.cts +4 -4
  45. package/dist/atoms/org/graphqlConfig.d.ts +4 -4
  46. package/dist/atoms/org/newOrgConfigAtom.d.cts +2 -2
  47. package/dist/atoms/org/newOrgConfigAtom.d.ts +2 -2
  48. package/dist/atoms/org/orgAnalyticsConfig.d.cts +5 -5
  49. package/dist/atoms/org/orgAnalyticsConfig.d.ts +5 -5
  50. package/dist/atoms/search/chatSearch.d.cts +17 -17
  51. package/dist/atoms/search/chatSearch.d.ts +17 -17
  52. package/dist/atoms/search/searchAPI.d.cts +13 -13
  53. package/dist/atoms/search/searchAPI.d.ts +13 -13
  54. package/dist/atoms/search/types.d.cts +1 -1
  55. package/dist/atoms/widget/chatPreviewLoading.d.cts +2 -2
  56. package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
  57. package/dist/contexts/featureFlagContext/featureFlagContext.cjs +1 -1
  58. package/dist/contexts/featureFlagContext/featureFlagContext.js +1 -1
  59. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.cjs +1 -1
  60. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.js +1 -1
  61. package/dist/contexts/graphqlContext/graphqlContext.cjs +41 -27
  62. package/dist/contexts/graphqlContext/graphqlContext.js +42 -27
  63. package/dist/contexts/graphqlContext/mockV3Config.cjs +47 -45
  64. package/dist/contexts/graphqlContext/mockV3Config.js +5 -3
  65. package/dist/contexts/newOrgConfigContext/newOrgConfigContext.cjs +1 -2
  66. package/dist/contexts/newOrgConfigContext/newOrgConfigContext.js +1 -2
  67. package/dist/contexts/salesAgentContext/chatAPI.cjs +26 -5
  68. package/dist/contexts/salesAgentContext/chatAPI.d.cts +7 -3
  69. package/dist/contexts/salesAgentContext/chatAPI.d.ts +7 -3
  70. package/dist/contexts/salesAgentContext/chatAPI.js +26 -5
  71. package/dist/contexts/salesAgentContext/salesAgentContext.cjs +4 -7
  72. package/dist/contexts/salesAgentContext/salesAgentContext.js +4 -7
  73. package/dist/contexts/salesAgentContext/salesAgentService.cjs +43 -18
  74. package/dist/contexts/salesAgentContext/salesAgentService.js +43 -18
  75. package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +2 -2
  76. package/dist/contexts/systemSettingsContext/systemSettingsContext.d.ts +2 -2
  77. package/dist/contexts/types.d.cts +1 -1
  78. package/dist/contexts/types.d.ts +1 -1
  79. package/dist/contexts/typesV3.cjs +1 -1
  80. package/dist/contexts/typesV3.d.cts +4 -4
  81. package/dist/contexts/typesV3.d.ts +4 -4
  82. package/dist/contexts/typesV3.js +1 -1
  83. package/dist/contexts/userIdentityContext/userIdentityContext.cjs +1 -2
  84. package/dist/contexts/userIdentityContext/userIdentityContext.js +1 -2
  85. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +2 -2
  86. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.ts +2 -2
  87. package/dist/hooks/GraphQLConfig/useGraphQLConfig.cjs +1 -2
  88. package/dist/hooks/GraphQLConfig/useGraphQLConfig.js +1 -2
  89. package/dist/hooks/Search/useSearchInput.cjs +1 -1
  90. package/dist/hooks/Search/useSearchInput.js +1 -1
  91. package/dist/hooks/utils.d.cts +1 -1
  92. package/dist/hooks/utils.d.ts +1 -1
  93. package/dist/packages/components-v3/dist/ChatHeader/hooks/useGetCloseButtonProperties.cjs +1 -1
  94. package/dist/packages/components-v3/dist/ChatHeader/hooks/useGetCloseButtonProperties.js +1 -1
  95. package/dist/packages/components-v3/dist/Container/Container.cjs +1 -1
  96. package/dist/packages/components-v3/dist/Container/Container.js +1 -1
  97. package/dist/packages/components-v3/dist/FloatingButton/FloatingButton.cjs +2 -0
  98. package/dist/packages/components-v3/dist/FloatingButton/FloatingButton.js +4 -0
  99. package/dist/packages/components-v3/dist/FloatingButton/components/Button.cjs +9 -0
  100. package/dist/packages/components-v3/dist/FloatingButton/components/Button.js +10 -0
  101. package/dist/packages/components-v3/dist/FloatingButton/components/Container.cjs +9 -0
  102. package/dist/packages/components-v3/dist/FloatingButton/components/Container.js +10 -0
  103. package/dist/packages/components-v3/dist/FloatingButton/components/Icon.cjs +3 -0
  104. package/dist/packages/components-v3/dist/FloatingButton/components/Icon.js +5 -0
  105. package/dist/packages/components-v3/dist/FloatingButton/components/Wrapper.cjs +9 -0
  106. package/dist/packages/components-v3/dist/FloatingButton/components/Wrapper.js +10 -0
  107. package/dist/packages/components-v3/dist/FloatingButton/components/index.cjs +4 -0
  108. package/dist/packages/components-v3/dist/FloatingButton/components/index.js +6 -0
  109. package/dist/packages/components-v3/dist/FloatingButton/index.cjs +2 -0
  110. package/dist/packages/components-v3/dist/FloatingButton/index.js +4 -0
  111. package/dist/packages/components-v3/dist/FloatingButton/types/types.cjs +17 -0
  112. package/dist/packages/components-v3/dist/FloatingButton/types/types.js +16 -0
  113. package/dist/packages/components-v3/dist/ImageGallery/components/Layout.cjs +1 -1
  114. package/dist/packages/components-v3/dist/ImageGallery/components/Layout.js +1 -1
  115. package/dist/packages/components-v3/dist/WelcomeMessage/components/SparkleIcon.cjs +1 -1
  116. package/dist/packages/components-v3/dist/WelcomeMessage/components/SparkleIcon.js +1 -1
  117. package/dist/packages/components-v3/dist/utils/CustomIcon.cjs +2 -0
  118. package/dist/packages/components-v3/dist/utils/CustomIcon.js +4 -0
  119. package/dist/services/amplitudeService/amplitudeService.cjs +5 -2
  120. package/dist/services/amplitudeService/amplitudeService.js +5 -2
  121. package/package.json +1 -5
  122. package/src/application/models/api/userEvent.ts +3 -1
  123. package/src/application/models/graphql/queries/getColorsAndFrontendQuery.ts +13 -0
  124. package/src/application/models/guards/api/isApiQueryTypedEventAttributes.ts +6 -1
  125. package/src/atoms/chat/index.ts +0 -1
  126. package/src/contexts/graphqlContext/graphqlContext.tsx +32 -41
  127. package/src/contexts/graphqlContext/mockV3Config.ts +3 -2
  128. package/src/contexts/newOrgConfigContext/newOrgConfigContext.tsx +0 -1
  129. package/src/contexts/salesAgentContext/chatAPI.ts +21 -4
  130. package/src/contexts/salesAgentContext/salesAgentContext.tsx +3 -7
  131. package/src/contexts/salesAgentContext/salesAgentService.ts +36 -11
  132. package/src/contexts/typesV3.ts +3 -4
  133. package/src/contexts/uiConfigContext/__tests__/uiConfigContext.test.tsx +3 -2
  134. package/src/contexts/userIdentityContext/userIdentityContext.tsx +0 -1
  135. package/src/hooks/GraphQLConfig/useGraphQLConfig.ts +0 -1
  136. package/src/services/amplitudeService/__tests__/amplitudeService.test.ts +0 -15
  137. package/src/services/amplitudeService/amplitudeService.ts +2 -1
  138. package/dist/atoms/chat/replies.cjs +0 -46
  139. package/dist/atoms/chat/replies.d.cts +0 -14
  140. package/dist/atoms/chat/replies.d.ts +0 -14
  141. package/dist/atoms/chat/replies.js +0 -45
  142. package/src/atoms/chat/replies.ts +0 -56
@@ -1,31 +1,22 @@
1
1
  import { PageVariantTestType } from "../types.js";
2
2
  import { ConfigVersionEnum } from "../typesV3.js";
3
- import logger_default from "../../application/logging/logger.js";
4
- import { configVersion } from "../../types/config-versions.js";
5
3
  import { getMerchantOrgIdQuery } from "../../application/models/graphql/queries/getMerchantOrgIdQuery.js";
4
+ import logger_default from "../../application/logging/logger.js";
6
5
  import { transformSnakeToCamel } from "../../application/models/utils/snakeToCamelTransformer.js";
7
6
  import { validateAndTransformMountingConfig, validateAndTransformPageVariants } from "../../application/models/validators/validateGraphQLFrontendConfig.js";
8
7
  import { validateGraphQLOrgId } from "../../application/models/validators/validateGraphQLOrgId.js";
9
8
  import "../../application/models/index.js";
10
9
  import { baseUrlAtom, orgLevelApiKeyAtom } from "../../atoms/envive/enviveConfig.js";
10
+ import { getColorsAndFrontendQuery } from "../../application/models/graphql/queries/getColorsAndFrontendQuery.js";
11
+ import { FloatingButtonLocation } from "../../packages/components-v3/dist/FloatingButton/types/types.js";
12
+ import "../../packages/components-v3/dist/FloatingButton/index.js";
11
13
  import { mockV3ColorsConfig, mockV3FrontendConfig } from "./mockV3Config.js";
12
- import React, { createContext, useCallback, useContext, useMemo } from "react";
14
+ import { createContext, useCallback, useContext, useMemo } from "react";
13
15
  import { useAtomValue } from "jotai";
14
16
  import { jsx } from "react/jsx-runtime";
15
17
 
16
18
  //#region src/contexts/graphqlContext/graphqlContext.tsx
17
19
  const GraphQLContext = createContext(null);
18
- const colorsAndFrontendConfigQuery = () => `
19
- query ($version: String = "${configVersion()}") {
20
- me {
21
- getProductsConfigByVersion(version: $version) {
22
- frontend { values }
23
- colors { values }
24
- v_three_config { values }
25
- }
26
- }
27
- }
28
- `;
29
20
  const DEFAULT_PAGE_VARIANTS = [{
30
21
  variantId: "plp",
31
22
  variantType: "plp",
@@ -40,10 +31,10 @@ const DEFAULT_PAGE_VARIANTS = [{
40
31
  variantTests: [{ testType: PageVariantTestType.UrlResolver }]
41
32
  }];
42
33
  const mapPositionToCamelCase = (position) => {
43
- if (position === "bottom-left") return "bottomLeft";
44
- if (position === "middle-left") return "middleLeft";
45
- if (position === "middle-right") return "middleRight";
46
- if (position === "bottom-right") return "bottomRight";
34
+ if (position === "bottom-left") return FloatingButtonLocation.BOTTOM_LEFT;
35
+ if (position === "middle-left") return FloatingButtonLocation.MIDDLE_LEFT;
36
+ if (position === "middle-right") return FloatingButtonLocation.MIDDLE_RIGHT;
37
+ if (position === "bottom-right") return FloatingButtonLocation.BOTTOM_RIGHT;
47
38
  throw new Error(`Invalid position: ${position}`);
48
39
  };
49
40
  /**
@@ -133,7 +124,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
133
124
  }, [executeQuery]);
134
125
  const getV3Config = useCallback(async () => {
135
126
  try {
136
- const query = await colorsAndFrontendConfigQuery();
127
+ const query = await getColorsAndFrontendQuery();
137
128
  if (!query) throw new Error("Colors and frontend config query is not defined");
138
129
  const v3RootConfig = (await executeQuery(query)).me.getProductsConfigByVersion?.v_three_config?.values;
139
130
  const v3FrontendConfig = v3FrontendConfigCleanup(transformSnakeToCamel(v3RootConfig));
@@ -148,10 +139,31 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
148
139
  }]));
149
140
  const v3pageVariants = Array.isArray(v3RootConfig?.page_variants) ? v3RootConfig?.page_variants.map(validateAndTransformPageVariants) : DEFAULT_PAGE_VARIANTS;
150
141
  const v3ColorsConfig = transformSnakeToCamel(v3RootConfig?.colors?.values);
151
- if (!v3RootConfig && mockV3ConfigToDeprecatedConfig) return {
152
- colorsConfig: !window.location.href.includes("globals=merchant") ? mockV3ColorsConfig : v3ColorsConfig,
153
- frontendConfig: mockV3FrontendConfig
154
- };
142
+ if (!v3RootConfig && mockV3ConfigToDeprecatedConfig) {
143
+ const isSemanticColors = !window.location.href.includes("globals=merchant");
144
+ logger_default.logInfo("GraphQLContext | Returning mock v3 config", {
145
+ colorsConfig: mockV3ColorsConfig,
146
+ frontendConfig: mockV3FrontendConfig
147
+ });
148
+ return {
149
+ colorsConfig: isSemanticColors ? mockV3ColorsConfig : v3ColorsConfig,
150
+ frontendConfig: mockV3FrontendConfig,
151
+ orgPageConfig: {
152
+ pageVariants: [],
153
+ widgetConfigs: {},
154
+ mountingConfigs: {}
155
+ }
156
+ };
157
+ }
158
+ logger_default.logInfo("GraphQLContext | Returning v3 config", {
159
+ colorsConfig: v3ColorsConfig,
160
+ frontendConfig: v3FrontendConfig,
161
+ orgPageConfig: {
162
+ pageVariants: v3pageVariants,
163
+ widgetConfigs: v3WidgetConfigs,
164
+ mountingConfigs: v3MountingConfigs
165
+ }
166
+ });
155
167
  return {
156
168
  colorsConfig: v3ColorsConfig,
157
169
  frontendConfig: {
@@ -174,7 +186,7 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
174
186
  }, [executeQuery, mockV3ConfigToDeprecatedConfig]);
175
187
  const getColorsAndFrontendConfig = useCallback(async () => {
176
188
  try {
177
- const query = await colorsAndFrontendConfigQuery();
189
+ const query = await getColorsAndFrontendQuery();
178
190
  if (!query) throw new Error("Colors and frontend config query is not defined");
179
191
  const response = await executeQuery(query);
180
192
  if (response.me.getProductsConfigByVersion?.version !== ConfigVersionEnum.V3 && !mockV3ConfigToDeprecatedConfig) {
@@ -200,8 +212,11 @@ const GraphQLProvider = ({ children, requestV3Config = false, mockV3ConfigToDepr
200
212
  }
201
213
  }, [executeQuery]);
202
214
  const getConfig = useCallback(async () => {
203
- console.log("GraphQLProvider: getConfig: requestV3Config", requestV3Config);
204
- if (requestV3Config) return getV3Config();
215
+ if (requestV3Config) {
216
+ logger_default.logInfo("GraphQLContext | Getting v3 config", requestV3Config);
217
+ return getV3Config();
218
+ }
219
+ logger_default.logInfo("GraphQLContext | Getting colors and frontend config", requestV3Config);
205
220
  return getColorsAndFrontendConfig();
206
221
  }, [
207
222
  getColorsAndFrontendConfig,
@@ -236,4 +251,4 @@ const useGraphQLClient = () => {
236
251
 
237
252
  //#endregion
238
253
  export { GraphQLProvider, useGraphQLClient };
239
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"graphqlContext.js","names":["DEFAULT_PAGE_VARIANTS: PageVariantConfig[]","v3pageVariants: PageVariantConfig[]"],"sources":["../../../src/contexts/graphqlContext/graphqlContext.tsx"],"sourcesContent":["import React, { ReactNode, createContext, useCallback, useContext, useMemo } from 'react';\nimport { useAtomValue } from 'jotai';\nimport { baseUrlAtom, orgLevelApiKeyAtom } from 'src/atoms/envive/enviveConfig';\nimport { getMerchantOrgIdQuery } from 'src/application/models/graphql/queries/getMerchantOrgIdQuery';\nimport { validateGraphQLOrgId } from 'src/application/models/validators/validateGraphQLOrgId';\nimport {\n  GetMerchantColorsQueryData,\n  GetMerchantFrontendConfigQueryData,\n} from 'src/application/models/graphql';\nimport { ColorMapping } from 'src/application/models/colorsConfig';\nimport { FrontendConfig } from 'src/application/models/frontendConfig';\nimport Logger from 'src/application/logging/logger';\nimport { configVersion } from 'src/types/config-versions';\nimport {\n  CamelCasedPropertiesDeep,\n  transformSnakeToCamel,\n  validateAndTransformMountingConfig,\n  validateAndTransformPageVariants,\n} from 'src/application/models';\nimport { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3 } from 'src/application/models/colorsConfigV3';\nimport { mockV3ColorsConfig, mockV3FrontendConfig } from './mockV3Config';\nimport { ConfigVersionEnum, Position, WidgetConfigV3 } from '../typesV3';\nimport {\n  OrgPageConfig,\n  PageVariantConfig,\n  PageVariantTestType,\n  WidgetMountingConfig,\n} from '../types';\n\ninterface BaseMeConfigQueryResponse {\n  me: {\n    org?: {\n      id: string;\n    };\n    getProductsConfigByVersion?: {\n      frontend?: {\n        values: CamelCasedPropertiesDeep<GetMerchantFrontendConfigQueryData>;\n      };\n      colors?: { values: CamelCasedPropertiesDeep<GetMerchantColorsQueryData> };\n    };\n  };\n}\nexport type ColorsConfigResponse = CamelCasedPropertiesDeep<ColorMapping>;\nexport type FrontendConfigResponse = CamelCasedPropertiesDeep<FrontendConfig>;\nexport type ColorsConfigV3Response = CamelCasedPropertiesDeep<ColorMappingV3>;\nexport type FrontendConfigV3Response = CamelCasedPropertiesDeep<FrontendConfigV3>;\n\nexport type GraphQlConfigValues = {\n  colorsConfig?: ColorsConfigResponse | ColorsConfigV3Response;\n  frontendConfig?: CamelCasedPropertiesDeep<FrontendConfig | FrontendConfigV3>;\n  orgPageConfig?: OrgPageConfig;\n};\n\ninterface GraphQLContextValue {\n  executeQuery: <T>(query: string, variables?: Record<string, unknown>) => Promise<T>;\n  getOrgId: () => Promise<string | undefined>;\n  getColorsAndFrontendConfig: () => Promise<GraphQlConfigValues>;\n  getV3Config: () => Promise<GraphQlConfigValues>;\n  getConfig: () => Promise<GraphQlConfigValues>;\n  isReady: boolean;\n}\n\nconst GraphQLContext = createContext<GraphQLContextValue | null>(null);\n\nconst colorsAndFrontendConfigQuery = () => `\n  query ($version: String = \"${configVersion()}\") {\n    me {\n      getProductsConfigByVersion(version: $version) {\n        frontend { values }\n        colors { values }\n        v_three_config { values }\n      }\n    }\n  }\n`;\n\ntype GraphQLProviderProps = {\n  children: ReactNode;\n  requestV3Config?: boolean;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n};\n\nconst DEFAULT_PAGE_VARIANTS: PageVariantConfig[] = [\n  {\n    variantId: 'plp',\n    variantType: 'plp',\n    plpIdExtractor: 'url-resolver-plp-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n  {\n    variantId: 'pdp',\n    variantType: 'pdp',\n    productIdExtractor: 'url-resolver-product-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n];\n\nconst mapPositionToCamelCase = (position: string): Position => {\n  if (position === 'bottom-left') {\n    return 'bottomLeft';\n  }\n  if (position === 'middle-left') {\n    return 'middleLeft';\n  }\n  if (position === 'middle-right') {\n    return 'middleRight';\n  }\n  if (position === 'bottom-right') {\n    return 'bottomRight';\n  }\n  throw new Error(`Invalid position: ${position}`);\n};\n\n/**\n * This function is used to do some additional cleanup of the v3 frontend config to ensure that the config is in the correct format.\n */\nconst v3FrontendConfigCleanup = (\n  v3RootConfig: FrontendConfigV3Response,\n): FrontendConfigV3Response => {\n  const { uiConfigs } = v3RootConfig;\n  if (!uiConfigs) {\n    return v3RootConfig;\n  }\n  const { floatingButton, lookAndFeel } = uiConfigs as any;\n  if (!floatingButton || !lookAndFeel) {\n    return v3RootConfig;\n  }\n  const { fontSize, lineHeight } = lookAndFeel.typography as any;\n  return {\n    ...v3RootConfig,\n    uiConfigs: {\n      ...uiConfigs,\n      floatingButton: {\n        ...floatingButton,\n        position: mapPositionToCamelCase(\n          v3RootConfig.uiConfigs?.floatingButton?.position as string,\n        ),\n      },\n      lookAndFeel: {\n        ...lookAndFeel,\n        chatHeaderLogoDarkSrc: lookAndFeel.chatHeaderLogoDarkSrc || lookAndFeel.chatHeaderLogoSrc,\n        chatHeaderLogoLightSrc: lookAndFeel.chatHeaderLogoLightSrc || lookAndFeel.chatHeaderLogoSrc,\n        typography: {\n          ...lookAndFeel.typography,\n          fontSize: {\n            // The fonts sizes are defined differently in the backend config\n            // so we need to map the values to the correct camel case keys\n            b1: fontSize?.b1 || fontSize?.b_1,\n            b2: fontSize?.b2 || fontSize?.b_2,\n            b3: fontSize?.b3 || fontSize?.b_3,\n            b4: fontSize?.b4 || fontSize?.b_4,\n            b5: fontSize?.b5 || fontSize?.b_5,\n            h1: fontSize?.h1 || fontSize?.h_1,\n            h2: fontSize?.h2 || fontSize?.h_2,\n            h3: fontSize?.h3 || fontSize?.h_3,\n            l1: fontSize?.l1 || fontSize?.l_1,\n            l2: fontSize?.l2 || fontSize?.l_2,\n            t1: fontSize?.t1 || fontSize?.t_1,\n            t2: fontSize?.t2 || fontSize?.t_2,\n            t3: fontSize?.t3 || fontSize?.t_3,\n          },\n          lineHeight: {\n            ...lookAndFeel.typography.lineHeight,\n            '114': lineHeight?.lh_114 || lineHeight?.[114],\n            '116': lineHeight?.lh_116 || lineHeight?.[116],\n            '118': lineHeight?.lh_118 || lineHeight?.[118],\n            '120': lineHeight?.lh_120 || lineHeight?.[120],\n            '124': lineHeight?.lh_124 || lineHeight?.[124],\n            '128': lineHeight?.lh_128 || lineHeight?.[128],\n            '130': lineHeight?.lh_130 || lineHeight?.[130],\n            '133': lineHeight?.lh_133 || lineHeight?.[133],\n            '140': lineHeight?.lh_140 || lineHeight?.[140],\n            '148': lineHeight?.lh_148 || lineHeight?.[148],\n          },\n        },\n      },\n    },\n  };\n};\n\nexport const GraphQLProvider = ({\n  children,\n  requestV3Config = false,\n  mockV3ConfigToDeprecatedConfig = false,\n}: GraphQLProviderProps) => {\n  const apiKey = useAtomValue(orgLevelApiKeyAtom);\n  const baseUrl = useAtomValue(baseUrlAtom);\n  const isReady = useMemo(() => Boolean(apiKey && baseUrl), [apiKey, baseUrl]);\n\n  const executeQuery = useCallback(\n    async (query: string, variables?: Record<string, unknown>) => {\n      if (!isReady) {\n        throw new Error('GraphQL client not ready - missing apiKey or baseUrl');\n      }\n\n      const response = await fetch(`${baseUrl}/v1/graphql`, {\n        method: 'POST',\n        headers: {\n          'Content-Type': 'application/json',\n          Authorization: `Bearer ${apiKey}`,\n        },\n        body: JSON.stringify({ query, variables }),\n      });\n\n      if (!response.ok) {\n        throw new Error(`GraphQL request failed: ${response.statusText}`);\n      }\n\n      const result = await response.json();\n      if (result.errors) {\n        throw new Error(`GraphQL errors: ${JSON.stringify(result.errors)}`);\n      }\n\n      return result.data;\n    },\n    [apiKey, baseUrl, isReady],\n  );\n\n  const getOrgId = useCallback(async () => {\n    const response = await executeQuery(getMerchantOrgIdQuery);\n    return validateGraphQLOrgId(response.me.org?.id);\n  }, [executeQuery]);\n\n  const getV3Config = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await colorsAndFrontendConfigQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n\n      // We may update this root config location in the future\n      const v3RootConfig = response.me.getProductsConfigByVersion?.v_three_config?.values;\n\n      const v3FrontendConfig = v3FrontendConfigCleanup(\n        transformSnakeToCamel(v3RootConfig) as FrontendConfigV3Response,\n      );\n\n      const v3MountingConfigsArray = (transformSnakeToCamel(v3RootConfig?.mounting_configs) ??\n        []) as unknown as { key: string; config: WidgetMountingConfig }[];\n\n      const v3MountingConfigs = v3MountingConfigsArray.reduce(\n        (acc, { key, config }) => {\n          acc[key] = validateAndTransformMountingConfig(config, key);\n          return acc;\n        },\n        {} as Record<string, WidgetMountingConfig>,\n      );\n\n      const v3widgetConfigsArray = (transformSnakeToCamel(v3RootConfig?.widget_configs) ??\n        []) as unknown as WidgetConfigV3[];\n      const v3WidgetConfigs = Object.fromEntries(\n        v3widgetConfigsArray?.map(({ widgetConfigId, ...rest }: WidgetConfigV3) => [\n          widgetConfigId,\n          { widgetConfigId, ...rest } as WidgetConfigV3,\n        ]),\n      ) as Record<string, WidgetConfigV3>;\n      const v3pageVariants: PageVariantConfig[] = Array.isArray(v3RootConfig?.page_variants)\n        ? v3RootConfig?.page_variants.map(validateAndTransformPageVariants)\n        : DEFAULT_PAGE_VARIANTS;\n\n      const v3ColorsConfig = transformSnakeToCamel(v3RootConfig?.colors?.values);\n\n      // If the v3 root config is not found and we are configured to return the deprecated config, we will return the mocked config\n      if (!v3RootConfig && mockV3ConfigToDeprecatedConfig) {\n        const isSemanticColors = !window.location.href.includes('globals=merchant');\n        const colorsConfig = mockV3ColorsConfig;\n        const frontendConfig = mockV3FrontendConfig;\n        return {\n          colorsConfig: isSemanticColors\n            ? (colorsConfig as ColorsConfigV3Response)\n            : (v3ColorsConfig as ColorsConfigV3Response),\n          frontendConfig: frontendConfig as FrontendConfigV3Response,\n        };\n      }\n\n      return {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: {\n          ...(v3FrontendConfig as FrontendConfigV3Response),\n          // Need to replace the automatic widget configs with the object based ones\n          widgetConfigs: v3WidgetConfigs,\n        },\n        orgPageConfig: {\n          pageVariants: v3pageVariants,\n          widgetConfigs: v3WidgetConfigs,\n          mountingConfigs: v3MountingConfigs,\n        },\n        // TODO: Add widgets and other config here\n      };\n    } catch (err) {\n      Logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery, mockV3ConfigToDeprecatedConfig]);\n\n  const getColorsAndFrontendConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await colorsAndFrontendConfigQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n      if (\n        response.me.getProductsConfigByVersion?.version !== ConfigVersionEnum.V3 &&\n        !mockV3ConfigToDeprecatedConfig\n      ) {\n        const colorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n        const frontendConfig = response.me.getProductsConfigByVersion?.frontend?.values;\n        const transformedColorConfig = transformSnakeToCamel(colorsConfig);\n        const transformedFrontendConfig = transformSnakeToCamel(frontendConfig);\n        return {\n          colorsConfig: transformedColorConfig as ColorsConfigResponse,\n          frontendConfig: transformedFrontendConfig as FrontendConfigResponse,\n        };\n      }\n      // TODO: REMOVE MOCKED CONFIG ONCE WE HAVE THE NEW CONFIG IMPLEMENTED ON BACKEND\n      const merchantColorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n      const transformedMerchantColorConfig = transformSnakeToCamel(merchantColorsConfig);\n\n      const isSemanticColors = !window.location.href.includes('globals=merchant');\n\n      const colorsConfig = mockV3ColorsConfig;\n      const frontendConfig = mockV3FrontendConfig;\n\n      return {\n        colorsConfig: isSemanticColors\n          ? (colorsConfig as ColorsConfigV3Response)\n          : (transformedMerchantColorConfig as ColorsConfigV3Response),\n        frontendConfig: frontendConfig as FrontendConfigV3Response,\n      };\n    } catch (err) {\n      Logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery]);\n\n  const getConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    console.log('GraphQLProvider: getConfig: requestV3Config', requestV3Config);\n    if (requestV3Config) {\n      return getV3Config();\n    }\n    return getColorsAndFrontendConfig();\n  }, [getColorsAndFrontendConfig, getV3Config, requestV3Config]);\n\n  const value = useMemo(\n    () => ({\n      executeQuery,\n      getOrgId,\n      getColorsAndFrontendConfig,\n      getV3Config,\n      getConfig,\n      isReady,\n    }),\n    [executeQuery, getOrgId, getColorsAndFrontendConfig, getV3Config, getConfig, isReady],\n  );\n\n  return <GraphQLContext.Provider value={value}>{children}</GraphQLContext.Provider>;\n};\n\nexport const useGraphQLClient = () => {\n  const context = useContext(GraphQLContext);\n  if (!context) {\n    throw new Error('useGraphQLClient must be used within a GraphQLProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
254
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"graphqlContext.js","names":["DEFAULT_PAGE_VARIANTS: PageVariantConfig[]","v3pageVariants: PageVariantConfig[]"],"sources":["../../../src/contexts/graphqlContext/graphqlContext.tsx"],"sourcesContent":["import { ReactNode, createContext, useCallback, useContext, useMemo } from 'react';\nimport { useAtomValue } from 'jotai';\nimport { baseUrlAtom, orgLevelApiKeyAtom } from 'src/atoms/envive/enviveConfig';\nimport { getMerchantOrgIdQuery } from 'src/application/models/graphql/queries/getMerchantOrgIdQuery';\nimport { validateGraphQLOrgId } from 'src/application/models/validators/validateGraphQLOrgId';\nimport { ColorMapping } from 'src/application/models/colorsConfig';\nimport { FrontendConfig } from 'src/application/models/frontendConfig';\nimport Logger from 'src/application/logging/logger';\nimport {\n  CamelCasedPropertiesDeep,\n  transformSnakeToCamel,\n  validateAndTransformMountingConfig,\n  validateAndTransformPageVariants,\n} from 'src/application/models';\nimport { getColorsAndFrontendQuery } from 'src/application/models/graphql/queries/getColorsAndFrontendQuery';\nimport { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3 } from 'src/application/models/colorsConfigV3';\nimport { FloatingButtonLocation } from '@envive-ai/react-toolkit-v3/FloatingButton';\nimport { mockV3ColorsConfig, mockV3FrontendConfig } from './mockV3Config';\nimport { ConfigVersionEnum, WidgetConfigV3 } from '../typesV3';\nimport {\n  OrgPageConfig,\n  PageVariantConfig,\n  PageVariantTestType,\n  WidgetMountingConfig,\n} from '../types';\n\nexport type ColorsConfigResponse = CamelCasedPropertiesDeep<ColorMapping>;\nexport type FrontendConfigResponse = CamelCasedPropertiesDeep<FrontendConfig>;\nexport type ColorsConfigV3Response = CamelCasedPropertiesDeep<ColorMappingV3>;\nexport type FrontendConfigV3Response = CamelCasedPropertiesDeep<FrontendConfigV3>;\n\nexport type GraphQlConfigValues = {\n  colorsConfig?: ColorsConfigResponse | ColorsConfigV3Response;\n  frontendConfig?: CamelCasedPropertiesDeep<FrontendConfig | FrontendConfigV3>;\n  orgPageConfig?: OrgPageConfig;\n};\n\ninterface GraphQLContextValue {\n  executeQuery: <T>(query: string, variables?: Record<string, unknown>) => Promise<T>;\n  getOrgId: () => Promise<string | undefined>;\n  getColorsAndFrontendConfig: () => Promise<GraphQlConfigValues>;\n  getV3Config: () => Promise<GraphQlConfigValues>;\n  getConfig: () => Promise<GraphQlConfigValues>;\n  isReady: boolean;\n}\n\nconst GraphQLContext = createContext<GraphQLContextValue | null>(null);\n\ntype GraphQLProviderProps = {\n  children: ReactNode;\n  requestV3Config?: boolean;\n  mockV3ConfigToDeprecatedConfig?: boolean;\n};\n\nconst DEFAULT_PAGE_VARIANTS: PageVariantConfig[] = [\n  {\n    variantId: 'plp',\n    variantType: 'plp',\n    plpIdExtractor: 'url-resolver-plp-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n  {\n    variantId: 'pdp',\n    variantType: 'pdp',\n    productIdExtractor: 'url-resolver-product-id',\n    widgetMounting: [],\n    variantTests: [\n      {\n        testType: PageVariantTestType.UrlResolver,\n      },\n    ],\n  },\n];\n\nconst mapPositionToCamelCase = (position: string): FloatingButtonLocation => {\n  if (position === 'bottom-left') {\n    return FloatingButtonLocation.BOTTOM_LEFT;\n  }\n  if (position === 'middle-left') {\n    return FloatingButtonLocation.MIDDLE_LEFT;\n  }\n  if (position === 'middle-right') {\n    return FloatingButtonLocation.MIDDLE_RIGHT;\n  }\n  if (position === 'bottom-right') {\n    return FloatingButtonLocation.BOTTOM_RIGHT;\n  }\n  throw new Error(`Invalid position: ${position}`);\n};\n\n/**\n * This function is used to do some additional cleanup of the v3 frontend config to ensure that the config is in the correct format.\n */\nconst v3FrontendConfigCleanup = (\n  v3RootConfig: FrontendConfigV3Response,\n): FrontendConfigV3Response => {\n  const { uiConfigs } = v3RootConfig;\n  if (!uiConfigs) {\n    return v3RootConfig;\n  }\n  const { floatingButton, lookAndFeel } = uiConfigs as any;\n  if (!floatingButton || !lookAndFeel) {\n    return v3RootConfig;\n  }\n  const { fontSize, lineHeight } = lookAndFeel.typography as any;\n  return {\n    ...v3RootConfig,\n    uiConfigs: {\n      ...uiConfigs,\n      floatingButton: {\n        ...floatingButton,\n        position: mapPositionToCamelCase(\n          v3RootConfig.uiConfigs?.floatingButton?.position as string,\n        ),\n      },\n      lookAndFeel: {\n        ...lookAndFeel,\n        chatHeaderLogoDarkSrc: lookAndFeel.chatHeaderLogoDarkSrc || lookAndFeel.chatHeaderLogoSrc,\n        chatHeaderLogoLightSrc: lookAndFeel.chatHeaderLogoLightSrc || lookAndFeel.chatHeaderLogoSrc,\n        typography: {\n          ...lookAndFeel.typography,\n          fontSize: {\n            // The fonts sizes are defined differently in the backend config\n            // so we need to map the values to the correct camel case keys\n            b1: fontSize?.b1 || fontSize?.b_1,\n            b2: fontSize?.b2 || fontSize?.b_2,\n            b3: fontSize?.b3 || fontSize?.b_3,\n            b4: fontSize?.b4 || fontSize?.b_4,\n            b5: fontSize?.b5 || fontSize?.b_5,\n            h1: fontSize?.h1 || fontSize?.h_1,\n            h2: fontSize?.h2 || fontSize?.h_2,\n            h3: fontSize?.h3 || fontSize?.h_3,\n            l1: fontSize?.l1 || fontSize?.l_1,\n            l2: fontSize?.l2 || fontSize?.l_2,\n            t1: fontSize?.t1 || fontSize?.t_1,\n            t2: fontSize?.t2 || fontSize?.t_2,\n            t3: fontSize?.t3 || fontSize?.t_3,\n          },\n          lineHeight: {\n            ...lookAndFeel.typography.lineHeight,\n            '114': lineHeight?.lh_114 || lineHeight?.[114],\n            '116': lineHeight?.lh_116 || lineHeight?.[116],\n            '118': lineHeight?.lh_118 || lineHeight?.[118],\n            '120': lineHeight?.lh_120 || lineHeight?.[120],\n            '124': lineHeight?.lh_124 || lineHeight?.[124],\n            '128': lineHeight?.lh_128 || lineHeight?.[128],\n            '130': lineHeight?.lh_130 || lineHeight?.[130],\n            '133': lineHeight?.lh_133 || lineHeight?.[133],\n            '140': lineHeight?.lh_140 || lineHeight?.[140],\n            '148': lineHeight?.lh_148 || lineHeight?.[148],\n          },\n        },\n      },\n    },\n  };\n};\n\nexport const GraphQLProvider = ({\n  children,\n  requestV3Config = false,\n  mockV3ConfigToDeprecatedConfig = false,\n}: GraphQLProviderProps) => {\n  const apiKey = useAtomValue(orgLevelApiKeyAtom);\n  const baseUrl = useAtomValue(baseUrlAtom);\n  const isReady = useMemo(() => Boolean(apiKey && baseUrl), [apiKey, baseUrl]);\n\n  const executeQuery = useCallback(\n    async (query: string, variables?: Record<string, unknown>) => {\n      if (!isReady) {\n        throw new Error('GraphQL client not ready - missing apiKey or baseUrl');\n      }\n\n      const response = await fetch(`${baseUrl}/v1/graphql`, {\n        method: 'POST',\n        headers: {\n          'Content-Type': 'application/json',\n          Authorization: `Bearer ${apiKey}`,\n        },\n        body: JSON.stringify({ query, variables }),\n      });\n\n      if (!response.ok) {\n        throw new Error(`GraphQL request failed: ${response.statusText}`);\n      }\n\n      const result = await response.json();\n      if (result.errors) {\n        throw new Error(`GraphQL errors: ${JSON.stringify(result.errors)}`);\n      }\n\n      return result.data;\n    },\n    [apiKey, baseUrl, isReady],\n  );\n\n  const getOrgId = useCallback(async () => {\n    const response = await executeQuery(getMerchantOrgIdQuery);\n    return validateGraphQLOrgId(response.me.org?.id);\n  }, [executeQuery]);\n\n  const getV3Config = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await getColorsAndFrontendQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n\n      // We may update this root config location in the future\n      const v3RootConfig = response.me.getProductsConfigByVersion?.v_three_config?.values;\n\n      const v3FrontendConfig = v3FrontendConfigCleanup(\n        transformSnakeToCamel(v3RootConfig) as FrontendConfigV3Response,\n      );\n\n      const v3MountingConfigsArray = (transformSnakeToCamel(v3RootConfig?.mounting_configs) ??\n        []) as unknown as { key: string; config: WidgetMountingConfig }[];\n\n      const v3MountingConfigs = v3MountingConfigsArray.reduce(\n        (acc, { key, config }) => {\n          acc[key] = validateAndTransformMountingConfig(config, key);\n          return acc;\n        },\n        {} as Record<string, WidgetMountingConfig>,\n      );\n\n      const v3widgetConfigsArray = (transformSnakeToCamel(v3RootConfig?.widget_configs) ??\n        []) as unknown as WidgetConfigV3[];\n      const v3WidgetConfigs = Object.fromEntries(\n        v3widgetConfigsArray?.map(({ widgetConfigId, ...rest }: WidgetConfigV3) => [\n          widgetConfigId,\n          { widgetConfigId, ...rest } as WidgetConfigV3,\n        ]),\n      ) as Record<string, WidgetConfigV3>;\n      const v3pageVariants: PageVariantConfig[] = Array.isArray(v3RootConfig?.page_variants)\n        ? v3RootConfig?.page_variants.map(validateAndTransformPageVariants)\n        : DEFAULT_PAGE_VARIANTS;\n\n      const v3ColorsConfig = transformSnakeToCamel(v3RootConfig?.colors?.values);\n      // If the v3 root config is not found and we are configured to return the deprecated config, we will return the mocked config\n      if (!v3RootConfig && mockV3ConfigToDeprecatedConfig) {\n        const isSemanticColors = !window.location.href.includes('globals=merchant');\n        Logger.logInfo('GraphQLContext | Returning mock v3 config', {\n          colorsConfig: mockV3ColorsConfig as ColorsConfigV3Response,\n          frontendConfig: mockV3FrontendConfig as FrontendConfigV3Response,\n        });\n        const colorsConfig = mockV3ColorsConfig;\n        const frontendConfig = mockV3FrontendConfig;\n        return {\n          colorsConfig: isSemanticColors\n            ? (colorsConfig as ColorsConfigV3Response)\n            : (v3ColorsConfig as ColorsConfigV3Response),\n          frontendConfig: frontendConfig as FrontendConfigV3Response,\n          orgPageConfig: {\n            pageVariants: [],\n            widgetConfigs: {},\n            mountingConfigs: {},\n          },\n        };\n      }\n\n      Logger.logInfo('GraphQLContext | Returning v3 config', {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: v3FrontendConfig as FrontendConfigV3Response,\n        orgPageConfig: {\n          pageVariants: v3pageVariants,\n          widgetConfigs: v3WidgetConfigs,\n          mountingConfigs: v3MountingConfigs,\n        },\n      });\n\n      return {\n        colorsConfig: v3ColorsConfig as ColorsConfigV3Response,\n        frontendConfig: {\n          ...(v3FrontendConfig as FrontendConfigV3Response),\n          // Need to replace the automatic widget configs with the object based ones\n          widgetConfigs: v3WidgetConfigs,\n        },\n        orgPageConfig: {\n          pageVariants: v3pageVariants,\n          widgetConfigs: v3WidgetConfigs,\n          mountingConfigs: v3MountingConfigs,\n        },\n        // TODO: Add widgets and other config here\n      };\n    } catch (err) {\n      Logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery, mockV3ConfigToDeprecatedConfig]);\n\n  const getColorsAndFrontendConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    try {\n      const query = await getColorsAndFrontendQuery();\n      if (!query) {\n        throw new Error('Colors and frontend config query is not defined');\n      }\n      const response = await executeQuery(query);\n      if (\n        response.me.getProductsConfigByVersion?.version !== ConfigVersionEnum.V3 &&\n        !mockV3ConfigToDeprecatedConfig\n      ) {\n        const colorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n        const frontendConfig = response.me.getProductsConfigByVersion?.frontend?.values;\n        const transformedColorConfig = transformSnakeToCamel(colorsConfig);\n        const transformedFrontendConfig = transformSnakeToCamel(frontendConfig);\n        return {\n          colorsConfig: transformedColorConfig as ColorsConfigResponse,\n          frontendConfig: transformedFrontendConfig as FrontendConfigResponse,\n        };\n      }\n      // TODO: REMOVE MOCKED CONFIG ONCE WE HAVE THE NEW CONFIG IMPLEMENTED ON BACKEND\n      const merchantColorsConfig = response.me.getProductsConfigByVersion?.colors?.values;\n      const transformedMerchantColorConfig = transformSnakeToCamel(merchantColorsConfig);\n\n      const isSemanticColors = !window.location.href.includes('globals=merchant');\n\n      const colorsConfig = mockV3ColorsConfig;\n      const frontendConfig = mockV3FrontendConfig;\n\n      return {\n        colorsConfig: isSemanticColors\n          ? (colorsConfig as ColorsConfigV3Response)\n          : (transformedMerchantColorConfig as ColorsConfigV3Response),\n        frontendConfig: frontendConfig as FrontendConfigV3Response,\n      };\n    } catch (err) {\n      Logger.logError('Error fetching graphql colors and frontend config', err);\n      return { colorsConfig: undefined, frontendConfig: undefined };\n    }\n  }, [executeQuery]);\n\n  const getConfig = useCallback(async (): Promise<GraphQlConfigValues> => {\n    if (requestV3Config) {\n      Logger.logInfo('GraphQLContext | Getting v3 config', requestV3Config);\n      return getV3Config();\n    }\n    Logger.logInfo('GraphQLContext | Getting colors and frontend config', requestV3Config);\n    return getColorsAndFrontendConfig();\n  }, [getColorsAndFrontendConfig, getV3Config, requestV3Config]);\n\n  const value = useMemo(\n    () => ({\n      executeQuery,\n      getOrgId,\n      getColorsAndFrontendConfig,\n      getV3Config,\n      getConfig,\n      isReady,\n    }),\n    [executeQuery, getOrgId, getColorsAndFrontendConfig, getV3Config, getConfig, isReady],\n  );\n\n  return <GraphQLContext.Provider value={value}>{children}</GraphQLContext.Provider>;\n};\n\nexport const useGraphQLClient = () => {\n  const context = useContext(GraphQLContext);\n  if (!context) {\n    throw new Error('useGraphQLClient must be used within a GraphQLProvider');\n  }\n  return context;\n};\n"],"mappings":"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"}
@@ -1,18 +1,20 @@
1
1
  const require_colorsConfigV3 = require('../../application/models/colorsConfigV3.cjs');
2
2
  const require_contexts_typesV3 = require('../typesV3.cjs');
3
- const require_types = require('../../packages/components-v3/dist/ImageGallery/types/types.cjs');
3
+ const require_types = require('../../packages/components-v3/dist/FloatingButton/types/types.cjs');
4
+ require('../../packages/components-v3/dist/FloatingButton/index.cjs');
5
+ const require_types$1 = require('../../packages/components-v3/dist/ImageGallery/types/types.cjs');
4
6
  const require_theme = require('../../packages/components-v3/dist/tokens/theme/theme.cjs');
5
7
  require('../../packages/components-v3/dist/ImageGallery/index.cjs');
6
- const require_index$1 = require('../../packages/components-v3/dist/PromptButton/types/index.cjs');
8
+ const require_index$2 = require('../../packages/components-v3/dist/PromptButton/types/index.cjs');
7
9
  require('../../packages/components-v3/dist/PromptButton/index.cjs');
8
- const require_types$1 = require('../../packages/components-v3/dist/PromptCarousel/types/types.cjs');
10
+ const require_types$2 = require('../../packages/components-v3/dist/PromptCarousel/types/types.cjs');
9
11
  require('../../packages/components-v3/dist/PromptCarousel/index.cjs');
10
- const require_types$2 = require('../../packages/components-v3/dist/WidgetWrapper/types/types.cjs');
12
+ const require_types$3 = require('../../packages/components-v3/dist/WidgetWrapper/types/types.cjs');
11
13
  require('../../packages/components-v3/dist/WidgetWrapper/index.cjs');
12
14
  require('../../packages/components-v3/dist/Tokens/index.cjs');
13
- const require_index$6 = require('../../packages/components-v3/dist/ChatHeader/types/index.cjs');
15
+ const require_index$7 = require('../../packages/components-v3/dist/ChatHeader/types/index.cjs');
14
16
  require('../../packages/components-v3/dist/ChatHeader/index.cjs');
15
- const require_types$3 = require('../../packages/components-v3/dist/WelcomeMessage/types/types.cjs');
17
+ const require_types$4 = require('../../packages/components-v3/dist/WelcomeMessage/types/types.cjs');
16
18
  require('../../packages/components-v3/dist/WelcomeMessage/index.cjs');
17
19
  const require_customerService = require('../../types/customerService.cjs');
18
20
 
@@ -114,7 +116,7 @@ const mockV3FrontendConfig = {
114
116
  }
115
117
  },
116
118
  floatingButton: {
117
- position: "bottomRight",
119
+ position: require_types.FloatingButtonLocation.BOTTOM_RIGHT,
118
120
  backgroundColor: require_colorsConfigV3.ColorNames.BackgroundPrimary,
119
121
  mode: "dark",
120
122
  showOption: "always",
@@ -122,9 +124,9 @@ const mockV3FrontendConfig = {
122
124
  iconSVGSrc: ""
123
125
  },
124
126
  floatingChat: {
125
- headerBackgroundColor: void 0,
126
- headerMode: require_index$6.ChatHeaderVariant.DARK,
127
- welcomeMessageIconColor: require_types$3.SparkleIconColor.ACCENT_PRIMARY,
127
+ headerBackgroundColor: require_colorsConfigV3.ColorNames.BackgroundPrimary,
128
+ headerMode: require_index$7.ChatHeaderVariant.DARK,
129
+ welcomeMessageIconColor: require_types$4.SparkleIconColor.ACCENT_PRIMARY,
128
130
  showVerifiedBuyer: true,
129
131
  userQueryInputEnabled: true,
130
132
  showEnviveLogo: true,
@@ -147,97 +149,97 @@ const mockV3FrontendConfig = {
147
149
  widgetConfigId: "prompt-carousel-test-light-widget",
148
150
  contentId: "prompt-carousel-test-light-widget",
149
151
  type: require_contexts_typesV3.WidgetTypeV3.PromptCarouselV3,
150
- promptButtonType: require_index$1.PromptButtonVariant.LIGHT,
152
+ promptButtonType: require_index$2.PromptButtonVariant.LIGHT,
151
153
  boldFirstButton: false,
152
- promptCarouselRows: require_types$1.PromptCarouselRows.ALWAYS_ONE,
153
- animationSpeed: require_types$1.AnimationSpeed.FAST
154
+ promptCarouselRows: require_types$2.PromptCarouselRows.ALWAYS_ONE,
155
+ animationSpeed: require_types$2.AnimationSpeed.FAST
154
156
  },
155
157
  "prompt-carousel-test-dark-widget": {
156
158
  widgetConfigId: "prompt-carousel-test-dark-widget",
157
159
  contentId: "prompt-carousel-test-dark-widget",
158
160
  type: require_contexts_typesV3.WidgetTypeV3.PromptCarouselV3,
159
- promptButtonType: require_index$1.PromptButtonVariant.DARK,
161
+ promptButtonType: require_index$2.PromptButtonVariant.DARK,
160
162
  boldFirstButton: false,
161
- promptCarouselRows: require_types$1.PromptCarouselRows.ALWAYS_ONE,
162
- animationSpeed: require_types$1.AnimationSpeed.FAST
163
+ promptCarouselRows: require_types$2.PromptCarouselRows.ALWAYS_ONE,
164
+ animationSpeed: require_types$2.AnimationSpeed.FAST
163
165
  },
164
166
  "titled-prompt-carousel-test-light-widget": {
165
167
  widgetConfigId: "titled-prompt-carousel-test-light-widget",
166
168
  contentId: "titled-prompt-carousel-test-light-widget",
167
169
  type: require_contexts_typesV3.WidgetTypeV3.TitledPromptCarouselV3,
168
- promptButtonType: require_index$1.PromptButtonVariant.LIGHT,
170
+ promptButtonType: require_index$2.PromptButtonVariant.LIGHT,
169
171
  boldFirstButton: false,
170
- promptCarouselRows: require_types$1.PromptCarouselRows.ALWAYS_ONE,
171
- animationSpeed: require_types$1.AnimationSpeed.FAST
172
+ promptCarouselRows: require_types$2.PromptCarouselRows.ALWAYS_ONE,
173
+ animationSpeed: require_types$2.AnimationSpeed.FAST
172
174
  },
173
175
  "titled-prompt-carousel-test-dark-widget": {
174
176
  widgetConfigId: "titled-prompt-carousel-test-dark-widget",
175
177
  contentId: "titled-prompt-carousel-test-dark-widget",
176
178
  type: require_contexts_typesV3.WidgetTypeV3.TitledPromptCarouselV3,
177
- promptButtonType: require_index$1.PromptButtonVariant.DARK,
179
+ promptButtonType: require_index$2.PromptButtonVariant.DARK,
178
180
  boldFirstButton: false,
179
- promptCarouselRows: require_types$1.PromptCarouselRows.ALWAYS_ONE,
180
- animationSpeed: require_types$1.AnimationSpeed.FAST
181
+ promptCarouselRows: require_types$2.PromptCarouselRows.ALWAYS_ONE,
182
+ animationSpeed: require_types$2.AnimationSpeed.FAST
181
183
  },
182
184
  "social-proof-test-widget-four-grid": {
183
185
  widgetConfigId: "social-proof-test-widget-four-grid",
184
186
  contentId: "social-proof-test-widget-four-grid",
185
187
  type: require_contexts_typesV3.WidgetTypeV3.SocialProofV3,
186
- imageGalleryLayout: require_types.ImageGalleryLayout.FOUR_GRID,
188
+ imageGalleryLayout: require_types$1.ImageGalleryLayout.FOUR_GRID,
187
189
  kind: require_contexts_typesV3.SocialProofWidgetKind.STATIC,
188
- variant: require_types$2.WidgetWrapperVariant.INLINE_WITH_BORDER,
189
- promptCarouselRows: require_types$1.PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,
190
- primaryButtonVariant: require_index$1.PromptButtonVariant.DARK,
191
- secondaryButtonVariant: require_index$1.PromptButtonVariant.LIGHT,
190
+ variant: require_types$3.WidgetWrapperVariant.INLINE_WITH_BORDER,
191
+ promptCarouselRows: require_types$2.PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,
192
+ primaryButtonVariant: require_index$2.PromptButtonVariant.DARK,
193
+ secondaryButtonVariant: require_index$2.PromptButtonVariant.LIGHT,
192
194
  images: mockImages
193
195
  },
194
196
  "social-proof-test-widget-single": {
195
197
  widgetConfigId: "social-proof-test-widget-single",
196
198
  contentId: "social-proof-test-widget-single",
197
199
  type: require_contexts_typesV3.WidgetTypeV3.SocialProofV3,
198
- imageGalleryLayout: require_types.ImageGalleryLayout.SINGLE,
200
+ imageGalleryLayout: require_types$1.ImageGalleryLayout.SINGLE,
199
201
  kind: require_contexts_typesV3.SocialProofWidgetKind.STATIC,
200
- variant: require_types$2.WidgetWrapperVariant.CARD_NO_BORDER,
201
- promptCarouselRows: require_types$1.PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,
202
- primaryButtonVariant: require_index$1.PromptButtonVariant.DARK,
203
- secondaryButtonVariant: require_index$1.PromptButtonVariant.LIGHT,
202
+ variant: require_types$3.WidgetWrapperVariant.CARD_NO_BORDER,
203
+ promptCarouselRows: require_types$2.PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,
204
+ primaryButtonVariant: require_index$2.PromptButtonVariant.DARK,
205
+ secondaryButtonVariant: require_index$2.PromptButtonVariant.LIGHT,
204
206
  images: mockImages
205
207
  },
206
208
  "social-proof-test-widget-four-horizontal": {
207
209
  widgetConfigId: "social-proof-test-widget-four-horizontal",
208
210
  contentId: "social-proof-test-widget-four-horizontal",
209
211
  type: require_contexts_typesV3.WidgetTypeV3.SocialProofV3,
210
- imageGalleryLayout: require_types.ImageGalleryLayout.FOUR_HORIZONTAL,
212
+ imageGalleryLayout: require_types$1.ImageGalleryLayout.FOUR_HORIZONTAL,
211
213
  kind: require_contexts_typesV3.SocialProofWidgetKind.STATIC,
212
- variant: require_types$2.WidgetWrapperVariant.CARD_WITH_BORDER,
213
- promptCarouselRows: require_types$1.PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,
214
- primaryButtonVariant: require_index$1.PromptButtonVariant.DARK,
215
- secondaryButtonVariant: require_index$1.PromptButtonVariant.LIGHT,
214
+ variant: require_types$3.WidgetWrapperVariant.CARD_WITH_BORDER,
215
+ promptCarouselRows: require_types$2.PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,
216
+ primaryButtonVariant: require_index$2.PromptButtonVariant.DARK,
217
+ secondaryButtonVariant: require_index$2.PromptButtonVariant.LIGHT,
216
218
  images: mockImages
217
219
  },
218
220
  "typing-animation-test-light-widget": {
219
221
  widgetConfigId: "typing-animation-test-light-widget",
220
222
  contentId: "typing-animation-test-light-widget",
221
223
  type: require_contexts_typesV3.WidgetTypeV3.TypingAnimationV3,
222
- widgetVariant: require_types$2.WidgetWrapperVariant.CARD_WITH_BORDER,
223
- promptButtonType: require_index$1.PromptButtonVariant.LIGHT,
224
- promptCarouselRows: require_types$1.PromptCarouselRows.ALWAYS_ONE,
224
+ widgetVariant: require_types$3.WidgetWrapperVariant.CARD_WITH_BORDER,
225
+ promptButtonType: require_index$2.PromptButtonVariant.LIGHT,
226
+ promptCarouselRows: require_types$2.PromptCarouselRows.ALWAYS_ONE,
225
227
  showTextField: true
226
228
  },
227
229
  "typing-animation-test-dark-widget": {
228
230
  widgetConfigId: "typing-animation-test-dark-widget",
229
231
  contentId: "typing-animation-test-dark-widget",
230
232
  type: require_contexts_typesV3.WidgetTypeV3.TypingAnimationV3,
231
- widgetVariant: require_types$2.WidgetWrapperVariant.CARD_WITH_BORDER,
232
- promptButtonType: require_index$1.PromptButtonVariant.DARK,
233
- promptCarouselRows: require_types$1.PromptCarouselRows.ALWAYS_ONE,
233
+ widgetVariant: require_types$3.WidgetWrapperVariant.CARD_WITH_BORDER,
234
+ promptButtonType: require_index$2.PromptButtonVariant.DARK,
235
+ promptCarouselRows: require_types$2.PromptCarouselRows.ALWAYS_ONE,
234
236
  showTextField: true
235
237
  },
236
238
  "prompt-button-carousel-with-image-test-widget": {
237
239
  widgetConfigId: "prompt-button-carousel-with-image-test-widget",
238
240
  contentId: "prompt-button-carousel-with-image-test-widget",
239
241
  type: require_contexts_typesV3.WidgetTypeV3.PromptButtonCarouselWithImageV3,
240
- promptButtonType: require_index$1.PromptButtonVariant.LIGHT,
242
+ promptButtonType: require_index$2.PromptButtonVariant.LIGHT,
241
243
  image: mockImages[0],
242
244
  hideTextField: false
243
245
  }
@@ -247,4 +249,4 @@ const mockV3FrontendConfig = {
247
249
  //#endregion
248
250
  exports.mockV3ColorsConfig = mockV3ColorsConfig;
249
251
  exports.mockV3FrontendConfig = mockV3FrontendConfig;
250
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mockV3Config.cjs","names":["mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3>","mockV3FrontendConfig: FrontendConfigV3","ConfigVersionEnum","Theme","colorVar","ColorNames","ChatHeaderVariant","SparkleIconColor","CustomerServiceType","WidgetTypeV3","PromptButtonVariant","PromptCarouselRows","AnimationSpeed","ImageGalleryLayout","SocialProofWidgetKind","WidgetWrapperVariant"],"sources":["../../../src/contexts/graphqlContext/mockV3Config.ts"],"sourcesContent":["import { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3, ColorNames, colorVar } from 'src/application/models/colorsConfigV3';\nimport { CamelCasedPropertiesDeep } from 'src/application/models';\nimport { ImageGalleryLayout } from '@envive-ai/react-toolkit-v3/ImageGallery';\nimport { PromptButtonVariant } from '@envive-ai/react-toolkit-v3/PromptButton';\nimport { AnimationSpeed, PromptCarouselRows } from '@envive-ai/react-toolkit-v3/PromptCarousel';\nimport { WidgetWrapperVariant } from '@envive-ai/react-toolkit-v3/WidgetWrapper';\nimport { Theme } from '@envive-ai/react-toolkit-v3/Tokens';\nimport { ChatHeaderVariant } from '@envive-ai/react-toolkit-v3/ChatHeader';\nimport { SparkleIconColor } from '@envive-ai/react-toolkit-v3/WelcomeMessage';\n\nimport { CustomerServiceType } from 'src/types/customerService';\nimport { ConfigVersionEnum, SocialProofWidgetKind, WidgetTypeV3 } from '../typesV3';\n\nconst mockImages = [\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 1',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 2',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 3',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 4',\n  },\n];\n\nexport const mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3> = {\n  textPrimary: '#021414',\n  textSecondary: '#666666',\n  textAccent: '#478D87',\n  textLink: '#042E2C',\n  textLight: '#FFFFFF',\n  backgroundPrimary: '#1F5F51',\n  backgroundSecondary: '#F9F6EA',\n  backgroundTertiary: '#EEECDD',\n  backgroundDark: '#021414',\n  backgroundLight: '#FFFFFF',\n  borderLight: '#E6E7E7',\n  borderMedium: '#B3B8B8',\n  borderDark: '#021414',\n  accentPrimary: '#1F5F51',\n  accentSecondary: '#AE8659',\n};\n\nexport const mockV3FrontendConfig: FrontendConfigV3 = {\n  uiConfigs: {\n    version: ConfigVersionEnum.V3,\n    shortName: 'Envive AI',\n    lookAndFeel: {\n      theme: Theme.STANDARD,\n      agentName: 'Envive AI',\n      chatHeaderLogoDarkSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      chatHeaderLogoLightSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_Lt.svg',\n      widgetLogoSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      hideWidgetLogo: false,\n      elementRadius: 8,\n      imageAspectRatio: '1/1',\n      buttonColors: {\n        lightButtonBackgroundColor: colorVar(ColorNames.BackgroundSecondary),\n        lightButtonIconColor: colorVar(ColorNames.AccentPrimary),\n        darkButtonBackgroundColor: colorVar(ColorNames.BackgroundDark),\n        darkButtonIconColor: colorVar(ColorNames.AccentPrimary),\n      },\n      typography: {\n        titleFontFamily: 'Poppins',\n        headerFontFamily: 'Poppins',\n        bodyFontFamily: 'Inter Variable',\n        fontSize: {\n          t1: '32px',\n          t2: '28px',\n          t3: '24px',\n          h1: '20px',\n          h2: '16px',\n          h3: '14px',\n          b1: '20px',\n          b2: '16px',\n          b3: '14px',\n          b4: '12px',\n          b5: '10px',\n          l1: '14px',\n          l2: '12px',\n        },\n        fontWeight: {\n          rg: '400',\n          md: '500',\n          sb: '600',\n        },\n        letterSpacing: {\n          '0': '0em',\n          'wide-1': '1px',\n        },\n        lineHeight: {\n          '124': 1.24,\n          '120': 1.2,\n          '118': 1.18,\n          '116': 1.16,\n          '114': 1.14,\n          '148': 1.48,\n          '140': 1.4,\n          '128': 1.28,\n          '130': 1.3,\n          '133': 1.33,\n        },\n      },\n    },\n    floatingButton: {\n      position: 'bottomRight',\n      backgroundColor: ColorNames.BackgroundPrimary,\n      mode: 'dark',\n      showOption: 'always',\n      style: 'attached',\n      iconSVGSrc: '',\n    },\n    floatingChat: {\n      headerBackgroundColor: undefined,\n      headerMode: ChatHeaderVariant.DARK,\n      welcomeMessageIconColor: SparkleIconColor.ACCENT_PRIMARY,\n      showVerifiedBuyer: true,\n      userQueryInputEnabled: true,\n      showEnviveLogo: true,\n      ignoreFirstModelResponse: false,\n      neverShowSingleProductCards: false,\n      welcomeMessageTitle: 'Welcome to Envive AI',\n      welcomeMessageText:\n        'Your personal shopper trained on the collective knowledge of thousands of real experts!',\n      chatFooterTextFieldPlaceholderText: 'Ask me anything...',\n    },\n    customerServiceIntegration: {\n      provider: CustomerServiceType.unsupported,\n      enabled: false,\n      suppressMerchantButton: false,\n    },\n  },\n  pageVariants: [],\n  mountingConfigs: {},\n  widgetConfigs: {\n    'prompt-carousel-test-light-widget': {\n      widgetConfigId: 'prompt-carousel-test-light-widget',\n      contentId: 'prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'prompt-carousel-test-dark-widget',\n      contentId: 'prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-light-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-light-widget',\n      contentId: 'titled-prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-dark-widget',\n      contentId: 'titled-prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'social-proof-test-widget-four-grid': {\n      widgetConfigId: 'social-proof-test-widget-four-grid',\n      contentId: 'social-proof-test-widget-four-grid',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_GRID,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.INLINE_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-single': {\n      widgetConfigId: 'social-proof-test-widget-single',\n      contentId: 'social-proof-test-widget-single',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.SINGLE,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_NO_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-four-horizontal': {\n      widgetConfigId: 'social-proof-test-widget-four-horizontal',\n      contentId: 'social-proof-test-widget-four-horizontal',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_HORIZONTAL,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'typing-animation-test-light-widget': {\n      widgetConfigId: 'typing-animation-test-light-widget',\n      contentId: 'typing-animation-test-light-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'typing-animation-test-dark-widget': {\n      widgetConfigId: 'typing-animation-test-dark-widget',\n      contentId: 'typing-animation-test-dark-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.DARK,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'prompt-button-carousel-with-image-test-widget': {\n      widgetConfigId: 'prompt-button-carousel-with-image-test-widget',\n      contentId: 'prompt-button-carousel-with-image-test-widget',\n      type: WidgetTypeV3.PromptButtonCarouselWithImageV3,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      image: mockImages[0],\n      hideTextField: false,\n    },\n  },\n};\n"],"mappings":"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"}
252
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mockV3Config.cjs","names":["mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3>","mockV3FrontendConfig: FrontendConfigV3","ConfigVersionEnum","Theme","colorVar","ColorNames","FloatingButtonLocation","ChatHeaderVariant","SparkleIconColor","CustomerServiceType","WidgetTypeV3","PromptButtonVariant","PromptCarouselRows","AnimationSpeed","ImageGalleryLayout","SocialProofWidgetKind","WidgetWrapperVariant"],"sources":["../../../src/contexts/graphqlContext/mockV3Config.ts"],"sourcesContent":["import { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3, ColorNames, colorVar } from 'src/application/models/colorsConfigV3';\nimport { CamelCasedPropertiesDeep } from 'src/application/models';\nimport { ImageGalleryLayout } from '@envive-ai/react-toolkit-v3/ImageGallery';\nimport { PromptButtonVariant } from '@envive-ai/react-toolkit-v3/PromptButton';\nimport { AnimationSpeed, PromptCarouselRows } from '@envive-ai/react-toolkit-v3/PromptCarousel';\nimport { WidgetWrapperVariant } from '@envive-ai/react-toolkit-v3/WidgetWrapper';\nimport { Theme } from '@envive-ai/react-toolkit-v3/Tokens';\nimport { ChatHeaderVariant } from '@envive-ai/react-toolkit-v3/ChatHeader';\nimport { SparkleIconColor } from '@envive-ai/react-toolkit-v3/WelcomeMessage';\n\nimport { CustomerServiceType } from 'src/types/customerService';\nimport { FloatingButtonLocation } from '@envive-ai/react-toolkit-v3/FloatingButton';\nimport { ConfigVersionEnum, SocialProofWidgetKind, WidgetTypeV3 } from '../typesV3';\n\nconst mockImages = [\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 1',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 2',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 3',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 4',\n  },\n];\n\nexport const mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3> = {\n  textPrimary: '#021414',\n  textSecondary: '#666666',\n  textAccent: '#478D87',\n  textLink: '#042E2C',\n  textLight: '#FFFFFF',\n  backgroundPrimary: '#1F5F51',\n  backgroundSecondary: '#F9F6EA',\n  backgroundTertiary: '#EEECDD',\n  backgroundDark: '#021414',\n  backgroundLight: '#FFFFFF',\n  borderLight: '#E6E7E7',\n  borderMedium: '#B3B8B8',\n  borderDark: '#021414',\n  accentPrimary: '#1F5F51',\n  accentSecondary: '#AE8659',\n};\n\nexport const mockV3FrontendConfig: FrontendConfigV3 = {\n  uiConfigs: {\n    version: ConfigVersionEnum.V3,\n    shortName: 'Envive AI',\n    lookAndFeel: {\n      theme: Theme.STANDARD,\n      agentName: 'Envive AI',\n      chatHeaderLogoDarkSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      chatHeaderLogoLightSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_Lt.svg',\n      widgetLogoSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      hideWidgetLogo: false,\n      elementRadius: 8,\n      imageAspectRatio: '1/1',\n      buttonColors: {\n        lightButtonBackgroundColor: colorVar(ColorNames.BackgroundSecondary),\n        lightButtonIconColor: colorVar(ColorNames.AccentPrimary),\n        darkButtonBackgroundColor: colorVar(ColorNames.BackgroundDark),\n        darkButtonIconColor: colorVar(ColorNames.AccentPrimary),\n      },\n      typography: {\n        titleFontFamily: 'Poppins',\n        headerFontFamily: 'Poppins',\n        bodyFontFamily: 'Inter Variable',\n        fontSize: {\n          t1: '32px',\n          t2: '28px',\n          t3: '24px',\n          h1: '20px',\n          h2: '16px',\n          h3: '14px',\n          b1: '20px',\n          b2: '16px',\n          b3: '14px',\n          b4: '12px',\n          b5: '10px',\n          l1: '14px',\n          l2: '12px',\n        },\n        fontWeight: {\n          rg: '400',\n          md: '500',\n          sb: '600',\n        },\n        letterSpacing: {\n          '0': '0em',\n          'wide-1': '1px',\n        },\n        lineHeight: {\n          '124': 1.24,\n          '120': 1.2,\n          '118': 1.18,\n          '116': 1.16,\n          '114': 1.14,\n          '148': 1.48,\n          '140': 1.4,\n          '128': 1.28,\n          '130': 1.3,\n          '133': 1.33,\n        },\n      },\n    },\n    floatingButton: {\n      position: FloatingButtonLocation.BOTTOM_RIGHT,\n      backgroundColor: ColorNames.BackgroundPrimary,\n      mode: 'dark',\n      showOption: 'always',\n      style: 'attached',\n      iconSVGSrc: '',\n    },\n    floatingChat: {\n      headerBackgroundColor: ColorNames.BackgroundPrimary,\n      headerMode: ChatHeaderVariant.DARK,\n      welcomeMessageIconColor: SparkleIconColor.ACCENT_PRIMARY,\n      showVerifiedBuyer: true,\n      userQueryInputEnabled: true,\n      showEnviveLogo: true,\n      ignoreFirstModelResponse: false,\n      neverShowSingleProductCards: false,\n      welcomeMessageTitle: 'Welcome to Envive AI',\n      welcomeMessageText:\n        'Your personal shopper trained on the collective knowledge of thousands of real experts!',\n      chatFooterTextFieldPlaceholderText: 'Ask me anything...',\n    },\n    customerServiceIntegration: {\n      provider: CustomerServiceType.unsupported,\n      enabled: false,\n      suppressMerchantButton: false,\n    },\n  },\n  pageVariants: [],\n  mountingConfigs: {},\n  widgetConfigs: {\n    'prompt-carousel-test-light-widget': {\n      widgetConfigId: 'prompt-carousel-test-light-widget',\n      contentId: 'prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'prompt-carousel-test-dark-widget',\n      contentId: 'prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-light-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-light-widget',\n      contentId: 'titled-prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-dark-widget',\n      contentId: 'titled-prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'social-proof-test-widget-four-grid': {\n      widgetConfigId: 'social-proof-test-widget-four-grid',\n      contentId: 'social-proof-test-widget-four-grid',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_GRID,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.INLINE_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-single': {\n      widgetConfigId: 'social-proof-test-widget-single',\n      contentId: 'social-proof-test-widget-single',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.SINGLE,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_NO_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-four-horizontal': {\n      widgetConfigId: 'social-proof-test-widget-four-horizontal',\n      contentId: 'social-proof-test-widget-four-horizontal',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_HORIZONTAL,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'typing-animation-test-light-widget': {\n      widgetConfigId: 'typing-animation-test-light-widget',\n      contentId: 'typing-animation-test-light-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'typing-animation-test-dark-widget': {\n      widgetConfigId: 'typing-animation-test-dark-widget',\n      contentId: 'typing-animation-test-dark-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.DARK,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'prompt-button-carousel-with-image-test-widget': {\n      widgetConfigId: 'prompt-button-carousel-with-image-test-widget',\n      contentId: 'prompt-button-carousel-with-image-test-widget',\n      type: WidgetTypeV3.PromptButtonCarouselWithImageV3,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      image: mockImages[0],\n      hideTextField: false,\n    },\n  },\n};\n"],"mappings":"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"}
@@ -1,5 +1,7 @@
1
1
  import { ColorNames, colorVar } from "../../application/models/colorsConfigV3.js";
2
2
  import { ConfigVersionEnum, SocialProofWidgetKind, WidgetTypeV3 } from "../typesV3.js";
3
+ import { FloatingButtonLocation } from "../../packages/components-v3/dist/FloatingButton/types/types.js";
4
+ import "../../packages/components-v3/dist/FloatingButton/index.js";
3
5
  import { ImageGalleryLayout } from "../../packages/components-v3/dist/ImageGallery/types/types.js";
4
6
  import { Theme } from "../../packages/components-v3/dist/tokens/theme/theme.js";
5
7
  import "../../packages/components-v3/dist/ImageGallery/index.js";
@@ -114,7 +116,7 @@ const mockV3FrontendConfig = {
114
116
  }
115
117
  },
116
118
  floatingButton: {
117
- position: "bottomRight",
119
+ position: FloatingButtonLocation.BOTTOM_RIGHT,
118
120
  backgroundColor: ColorNames.BackgroundPrimary,
119
121
  mode: "dark",
120
122
  showOption: "always",
@@ -122,7 +124,7 @@ const mockV3FrontendConfig = {
122
124
  iconSVGSrc: ""
123
125
  },
124
126
  floatingChat: {
125
- headerBackgroundColor: void 0,
127
+ headerBackgroundColor: ColorNames.BackgroundPrimary,
126
128
  headerMode: ChatHeaderVariant.DARK,
127
129
  welcomeMessageIconColor: SparkleIconColor.ACCENT_PRIMARY,
128
130
  showVerifiedBuyer: true,
@@ -246,4 +248,4 @@ const mockV3FrontendConfig = {
246
248
 
247
249
  //#endregion
248
250
  export { mockV3ColorsConfig, mockV3FrontendConfig };
249
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mockV3Config.js","names":["mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3>","mockV3FrontendConfig: FrontendConfigV3"],"sources":["../../../src/contexts/graphqlContext/mockV3Config.ts"],"sourcesContent":["import { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3, ColorNames, colorVar } from 'src/application/models/colorsConfigV3';\nimport { CamelCasedPropertiesDeep } from 'src/application/models';\nimport { ImageGalleryLayout } from '@envive-ai/react-toolkit-v3/ImageGallery';\nimport { PromptButtonVariant } from '@envive-ai/react-toolkit-v3/PromptButton';\nimport { AnimationSpeed, PromptCarouselRows } from '@envive-ai/react-toolkit-v3/PromptCarousel';\nimport { WidgetWrapperVariant } from '@envive-ai/react-toolkit-v3/WidgetWrapper';\nimport { Theme } from '@envive-ai/react-toolkit-v3/Tokens';\nimport { ChatHeaderVariant } from '@envive-ai/react-toolkit-v3/ChatHeader';\nimport { SparkleIconColor } from '@envive-ai/react-toolkit-v3/WelcomeMessage';\n\nimport { CustomerServiceType } from 'src/types/customerService';\nimport { ConfigVersionEnum, SocialProofWidgetKind, WidgetTypeV3 } from '../typesV3';\n\nconst mockImages = [\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 1',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 2',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 3',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 4',\n  },\n];\n\nexport const mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3> = {\n  textPrimary: '#021414',\n  textSecondary: '#666666',\n  textAccent: '#478D87',\n  textLink: '#042E2C',\n  textLight: '#FFFFFF',\n  backgroundPrimary: '#1F5F51',\n  backgroundSecondary: '#F9F6EA',\n  backgroundTertiary: '#EEECDD',\n  backgroundDark: '#021414',\n  backgroundLight: '#FFFFFF',\n  borderLight: '#E6E7E7',\n  borderMedium: '#B3B8B8',\n  borderDark: '#021414',\n  accentPrimary: '#1F5F51',\n  accentSecondary: '#AE8659',\n};\n\nexport const mockV3FrontendConfig: FrontendConfigV3 = {\n  uiConfigs: {\n    version: ConfigVersionEnum.V3,\n    shortName: 'Envive AI',\n    lookAndFeel: {\n      theme: Theme.STANDARD,\n      agentName: 'Envive AI',\n      chatHeaderLogoDarkSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      chatHeaderLogoLightSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_Lt.svg',\n      widgetLogoSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      hideWidgetLogo: false,\n      elementRadius: 8,\n      imageAspectRatio: '1/1',\n      buttonColors: {\n        lightButtonBackgroundColor: colorVar(ColorNames.BackgroundSecondary),\n        lightButtonIconColor: colorVar(ColorNames.AccentPrimary),\n        darkButtonBackgroundColor: colorVar(ColorNames.BackgroundDark),\n        darkButtonIconColor: colorVar(ColorNames.AccentPrimary),\n      },\n      typography: {\n        titleFontFamily: 'Poppins',\n        headerFontFamily: 'Poppins',\n        bodyFontFamily: 'Inter Variable',\n        fontSize: {\n          t1: '32px',\n          t2: '28px',\n          t3: '24px',\n          h1: '20px',\n          h2: '16px',\n          h3: '14px',\n          b1: '20px',\n          b2: '16px',\n          b3: '14px',\n          b4: '12px',\n          b5: '10px',\n          l1: '14px',\n          l2: '12px',\n        },\n        fontWeight: {\n          rg: '400',\n          md: '500',\n          sb: '600',\n        },\n        letterSpacing: {\n          '0': '0em',\n          'wide-1': '1px',\n        },\n        lineHeight: {\n          '124': 1.24,\n          '120': 1.2,\n          '118': 1.18,\n          '116': 1.16,\n          '114': 1.14,\n          '148': 1.48,\n          '140': 1.4,\n          '128': 1.28,\n          '130': 1.3,\n          '133': 1.33,\n        },\n      },\n    },\n    floatingButton: {\n      position: 'bottomRight',\n      backgroundColor: ColorNames.BackgroundPrimary,\n      mode: 'dark',\n      showOption: 'always',\n      style: 'attached',\n      iconSVGSrc: '',\n    },\n    floatingChat: {\n      headerBackgroundColor: undefined,\n      headerMode: ChatHeaderVariant.DARK,\n      welcomeMessageIconColor: SparkleIconColor.ACCENT_PRIMARY,\n      showVerifiedBuyer: true,\n      userQueryInputEnabled: true,\n      showEnviveLogo: true,\n      ignoreFirstModelResponse: false,\n      neverShowSingleProductCards: false,\n      welcomeMessageTitle: 'Welcome to Envive AI',\n      welcomeMessageText:\n        'Your personal shopper trained on the collective knowledge of thousands of real experts!',\n      chatFooterTextFieldPlaceholderText: 'Ask me anything...',\n    },\n    customerServiceIntegration: {\n      provider: CustomerServiceType.unsupported,\n      enabled: false,\n      suppressMerchantButton: false,\n    },\n  },\n  pageVariants: [],\n  mountingConfigs: {},\n  widgetConfigs: {\n    'prompt-carousel-test-light-widget': {\n      widgetConfigId: 'prompt-carousel-test-light-widget',\n      contentId: 'prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'prompt-carousel-test-dark-widget',\n      contentId: 'prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-light-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-light-widget',\n      contentId: 'titled-prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-dark-widget',\n      contentId: 'titled-prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'social-proof-test-widget-four-grid': {\n      widgetConfigId: 'social-proof-test-widget-four-grid',\n      contentId: 'social-proof-test-widget-four-grid',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_GRID,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.INLINE_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-single': {\n      widgetConfigId: 'social-proof-test-widget-single',\n      contentId: 'social-proof-test-widget-single',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.SINGLE,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_NO_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-four-horizontal': {\n      widgetConfigId: 'social-proof-test-widget-four-horizontal',\n      contentId: 'social-proof-test-widget-four-horizontal',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_HORIZONTAL,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'typing-animation-test-light-widget': {\n      widgetConfigId: 'typing-animation-test-light-widget',\n      contentId: 'typing-animation-test-light-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'typing-animation-test-dark-widget': {\n      widgetConfigId: 'typing-animation-test-dark-widget',\n      contentId: 'typing-animation-test-dark-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.DARK,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'prompt-button-carousel-with-image-test-widget': {\n      widgetConfigId: 'prompt-button-carousel-with-image-test-widget',\n      contentId: 'prompt-button-carousel-with-image-test-widget',\n      type: WidgetTypeV3.PromptButtonCarouselWithImageV3,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      image: mockImages[0],\n      hideTextField: false,\n    },\n  },\n};\n"],"mappings":"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"}
251
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mockV3Config.js","names":["mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3>","mockV3FrontendConfig: FrontendConfigV3"],"sources":["../../../src/contexts/graphqlContext/mockV3Config.ts"],"sourcesContent":["import { FrontendConfigV3 } from 'src/application/models/frontendConfigV3';\nimport { ColorMappingV3, ColorNames, colorVar } from 'src/application/models/colorsConfigV3';\nimport { CamelCasedPropertiesDeep } from 'src/application/models';\nimport { ImageGalleryLayout } from '@envive-ai/react-toolkit-v3/ImageGallery';\nimport { PromptButtonVariant } from '@envive-ai/react-toolkit-v3/PromptButton';\nimport { AnimationSpeed, PromptCarouselRows } from '@envive-ai/react-toolkit-v3/PromptCarousel';\nimport { WidgetWrapperVariant } from '@envive-ai/react-toolkit-v3/WidgetWrapper';\nimport { Theme } from '@envive-ai/react-toolkit-v3/Tokens';\nimport { ChatHeaderVariant } from '@envive-ai/react-toolkit-v3/ChatHeader';\nimport { SparkleIconColor } from '@envive-ai/react-toolkit-v3/WelcomeMessage';\n\nimport { CustomerServiceType } from 'src/types/customerService';\nimport { FloatingButtonLocation } from '@envive-ai/react-toolkit-v3/FloatingButton';\nimport { ConfigVersionEnum, SocialProofWidgetKind, WidgetTypeV3 } from '../typesV3';\n\nconst mockImages = [\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 1',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 2',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 3',\n  },\n  {\n    src: 'https://picsum.photos/400/600',\n    alt: 'Image 4',\n  },\n];\n\nexport const mockV3ColorsConfig: CamelCasedPropertiesDeep<ColorMappingV3> = {\n  textPrimary: '#021414',\n  textSecondary: '#666666',\n  textAccent: '#478D87',\n  textLink: '#042E2C',\n  textLight: '#FFFFFF',\n  backgroundPrimary: '#1F5F51',\n  backgroundSecondary: '#F9F6EA',\n  backgroundTertiary: '#EEECDD',\n  backgroundDark: '#021414',\n  backgroundLight: '#FFFFFF',\n  borderLight: '#E6E7E7',\n  borderMedium: '#B3B8B8',\n  borderDark: '#021414',\n  accentPrimary: '#1F5F51',\n  accentSecondary: '#AE8659',\n};\n\nexport const mockV3FrontendConfig: FrontendConfigV3 = {\n  uiConfigs: {\n    version: ConfigVersionEnum.V3,\n    shortName: 'Envive AI',\n    lookAndFeel: {\n      theme: Theme.STANDARD,\n      agentName: 'Envive AI',\n      chatHeaderLogoDarkSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      chatHeaderLogoLightSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_Lt.svg',\n      widgetLogoSrc: 'https://cdn.spiffy.ai/other/assets/envive-ai/Envive_Logo_DK.svg',\n      hideWidgetLogo: false,\n      elementRadius: 8,\n      imageAspectRatio: '1/1',\n      buttonColors: {\n        lightButtonBackgroundColor: colorVar(ColorNames.BackgroundSecondary),\n        lightButtonIconColor: colorVar(ColorNames.AccentPrimary),\n        darkButtonBackgroundColor: colorVar(ColorNames.BackgroundDark),\n        darkButtonIconColor: colorVar(ColorNames.AccentPrimary),\n      },\n      typography: {\n        titleFontFamily: 'Poppins',\n        headerFontFamily: 'Poppins',\n        bodyFontFamily: 'Inter Variable',\n        fontSize: {\n          t1: '32px',\n          t2: '28px',\n          t3: '24px',\n          h1: '20px',\n          h2: '16px',\n          h3: '14px',\n          b1: '20px',\n          b2: '16px',\n          b3: '14px',\n          b4: '12px',\n          b5: '10px',\n          l1: '14px',\n          l2: '12px',\n        },\n        fontWeight: {\n          rg: '400',\n          md: '500',\n          sb: '600',\n        },\n        letterSpacing: {\n          '0': '0em',\n          'wide-1': '1px',\n        },\n        lineHeight: {\n          '124': 1.24,\n          '120': 1.2,\n          '118': 1.18,\n          '116': 1.16,\n          '114': 1.14,\n          '148': 1.48,\n          '140': 1.4,\n          '128': 1.28,\n          '130': 1.3,\n          '133': 1.33,\n        },\n      },\n    },\n    floatingButton: {\n      position: FloatingButtonLocation.BOTTOM_RIGHT,\n      backgroundColor: ColorNames.BackgroundPrimary,\n      mode: 'dark',\n      showOption: 'always',\n      style: 'attached',\n      iconSVGSrc: '',\n    },\n    floatingChat: {\n      headerBackgroundColor: ColorNames.BackgroundPrimary,\n      headerMode: ChatHeaderVariant.DARK,\n      welcomeMessageIconColor: SparkleIconColor.ACCENT_PRIMARY,\n      showVerifiedBuyer: true,\n      userQueryInputEnabled: true,\n      showEnviveLogo: true,\n      ignoreFirstModelResponse: false,\n      neverShowSingleProductCards: false,\n      welcomeMessageTitle: 'Welcome to Envive AI',\n      welcomeMessageText:\n        'Your personal shopper trained on the collective knowledge of thousands of real experts!',\n      chatFooterTextFieldPlaceholderText: 'Ask me anything...',\n    },\n    customerServiceIntegration: {\n      provider: CustomerServiceType.unsupported,\n      enabled: false,\n      suppressMerchantButton: false,\n    },\n  },\n  pageVariants: [],\n  mountingConfigs: {},\n  widgetConfigs: {\n    'prompt-carousel-test-light-widget': {\n      widgetConfigId: 'prompt-carousel-test-light-widget',\n      contentId: 'prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'prompt-carousel-test-dark-widget',\n      contentId: 'prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.PromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-light-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-light-widget',\n      contentId: 'titled-prompt-carousel-test-light-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.LIGHT,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'titled-prompt-carousel-test-dark-widget': {\n      widgetConfigId: 'titled-prompt-carousel-test-dark-widget',\n      contentId: 'titled-prompt-carousel-test-dark-widget',\n      type: WidgetTypeV3.TitledPromptCarouselV3,\n\n      promptButtonType: PromptButtonVariant.DARK,\n      boldFirstButton: false,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      animationSpeed: AnimationSpeed.FAST,\n    },\n    'social-proof-test-widget-four-grid': {\n      widgetConfigId: 'social-proof-test-widget-four-grid',\n      contentId: 'social-proof-test-widget-four-grid',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_GRID,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.INLINE_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-single': {\n      widgetConfigId: 'social-proof-test-widget-single',\n      contentId: 'social-proof-test-widget-single',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.SINGLE,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_NO_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'social-proof-test-widget-four-horizontal': {\n      widgetConfigId: 'social-proof-test-widget-four-horizontal',\n      contentId: 'social-proof-test-widget-four-horizontal',\n      type: WidgetTypeV3.SocialProofV3,\n\n      imageGalleryLayout: ImageGalleryLayout.FOUR_HORIZONTAL,\n      kind: SocialProofWidgetKind.STATIC,\n      variant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptCarouselRows: PromptCarouselRows.TWO_ON_MOBILE_ONE_ON_DESKTOP,\n      primaryButtonVariant: PromptButtonVariant.DARK,\n      secondaryButtonVariant: PromptButtonVariant.LIGHT,\n      images: mockImages,\n    },\n    'typing-animation-test-light-widget': {\n      widgetConfigId: 'typing-animation-test-light-widget',\n      contentId: 'typing-animation-test-light-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'typing-animation-test-dark-widget': {\n      widgetConfigId: 'typing-animation-test-dark-widget',\n      contentId: 'typing-animation-test-dark-widget',\n      type: WidgetTypeV3.TypingAnimationV3,\n      widgetVariant: WidgetWrapperVariant.CARD_WITH_BORDER,\n      promptButtonType: PromptButtonVariant.DARK,\n      promptCarouselRows: PromptCarouselRows.ALWAYS_ONE,\n      showTextField: true,\n    },\n    'prompt-button-carousel-with-image-test-widget': {\n      widgetConfigId: 'prompt-button-carousel-with-image-test-widget',\n      contentId: 'prompt-button-carousel-with-image-test-widget',\n      type: WidgetTypeV3.PromptButtonCarouselWithImageV3,\n      promptButtonType: PromptButtonVariant.LIGHT,\n      image: mockImages[0],\n      hideTextField: false,\n    },\n  },\n};\n"],"mappings":"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"}