@envive-ai/react-hooks 0.3.18 → 0.3.19

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 (196) hide show
  1. package/dist/application/commerce-api.cjs +14 -13
  2. package/dist/application/commerce-api.js +14 -13
  3. package/dist/application/logging/logger.cjs +16 -10
  4. package/dist/application/logging/logger.js +16 -10
  5. package/dist/application/models/guards/api/isApiFormResponse.cjs +9 -8
  6. package/dist/application/models/guards/api/isApiFormResponse.js +9 -8
  7. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.cjs +6 -5
  8. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.js +6 -5
  9. package/dist/application/models/guards/api/isApiOrderResponseAttributes.cjs +19 -18
  10. package/dist/application/models/guards/api/isApiOrderResponseAttributes.js +19 -18
  11. package/dist/application/models/guards/api/isApiOrgConfigResults.cjs +27 -26
  12. package/dist/application/models/guards/api/isApiOrgConfigResults.js +27 -26
  13. package/dist/application/models/guards/api/isApiOrganizationConfig.cjs +23 -22
  14. package/dist/application/models/guards/api/isApiOrganizationConfig.js +23 -22
  15. package/dist/application/models/guards/api/isApiProductResponseAttributes.cjs +12 -11
  16. package/dist/application/models/guards/api/isApiProductResponseAttributes.js +12 -11
  17. package/dist/application/models/guards/api/isApiResponse.cjs +7 -6
  18. package/dist/application/models/guards/api/isApiResponse.js +7 -6
  19. package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.cjs +5 -4
  20. package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.js +5 -4
  21. package/dist/application/models/validators/validateGraphQLFrontendConfig.cjs +15 -14
  22. package/dist/application/models/validators/validateGraphQLFrontendConfig.js +15 -14
  23. package/dist/application/utils/analyticsUtils.cjs +4 -3
  24. package/dist/application/utils/analyticsUtils.js +4 -3
  25. package/dist/application/utils/nextMessageRequestToApiRequest.cjs +3 -1
  26. package/dist/application/utils/nextMessageRequestToApiRequest.js +3 -1
  27. package/dist/atoms/app/index.d.cts +7 -7
  28. package/dist/atoms/app/index.d.ts +7 -7
  29. package/dist/atoms/app/variant.cjs +3 -2
  30. package/dist/atoms/app/variant.js +3 -2
  31. package/dist/atoms/chat/chatState.d.cts +17 -17
  32. package/dist/atoms/chat/chatState.d.ts +17 -17
  33. package/dist/atoms/chat/form.d.cts +2 -2
  34. package/dist/atoms/chat/form.d.ts +2 -2
  35. package/dist/atoms/chat/index.d.cts +2 -2
  36. package/dist/atoms/chat/index.d.ts +2 -2
  37. package/dist/atoms/chat/lastMessage.d.cts +2 -2
  38. package/dist/atoms/chat/lastMessage.d.ts +2 -2
  39. package/dist/atoms/chat/messageQueue.d.cts +6 -6
  40. package/dist/atoms/chat/messageQueue.d.ts +6 -6
  41. package/dist/atoms/chat/performanceMetrics.cjs +3 -2
  42. package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
  43. package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
  44. package/dist/atoms/chat/performanceMetrics.js +3 -2
  45. package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
  46. package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
  47. package/dist/atoms/chat/replies.d.cts +2 -2
  48. package/dist/atoms/chat/replies.d.ts +3 -3
  49. package/dist/atoms/chat/suggestions.d.cts +2 -2
  50. package/dist/atoms/chat/suggestions.d.ts +2 -2
  51. package/dist/atoms/envive/enviveConfig.cjs +5 -4
  52. package/dist/atoms/envive/enviveConfig.d.cts +13 -13
  53. package/dist/atoms/envive/enviveConfig.d.ts +13 -13
  54. package/dist/atoms/envive/enviveConfig.js +5 -4
  55. package/dist/atoms/globalSearch/globalSearch.d.cts +5 -5
  56. package/dist/atoms/globalSearch/globalSearch.d.ts +5 -5
  57. package/dist/atoms/org/customerService.d.cts +6 -6
  58. package/dist/atoms/org/customerService.d.ts +6 -6
  59. package/dist/atoms/org/graphqlConfig.d.cts +4 -4
  60. package/dist/atoms/org/graphqlConfig.d.ts +4 -4
  61. package/dist/atoms/org/newOrgConfigAtom.d.cts +2 -2
  62. package/dist/atoms/org/newOrgConfigAtom.d.ts +2 -2
  63. package/dist/atoms/org/orgAnalyticsConfig.d.cts +5 -5
  64. package/dist/atoms/org/orgAnalyticsConfig.d.ts +5 -5
  65. package/dist/atoms/search/chatSearch.d.cts +17 -17
  66. package/dist/atoms/search/chatSearch.d.ts +17 -17
  67. package/dist/atoms/search/searchAPI.d.cts +13 -13
  68. package/dist/atoms/search/searchAPI.d.ts +13 -13
  69. package/dist/atoms/search/types.d.cts +1 -1
  70. package/dist/atoms/search/types.d.ts +1 -1
  71. package/dist/atoms/search/utils.d.ts +1 -1
  72. package/dist/atoms/widget/chatPreviewLoading.d.cts +2 -2
  73. package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
  74. package/dist/contexts/amplitudeContext/amplitudeContext.cjs +4 -3
  75. package/dist/contexts/amplitudeContext/amplitudeContext.js +3 -2
  76. package/dist/contexts/enviveConfigContext/enviveConfigContext.cjs +26 -15
  77. package/dist/contexts/enviveConfigContext/enviveConfigContext.d.cts +2 -4
  78. package/dist/contexts/enviveConfigContext/enviveConfigContext.d.ts +2 -4
  79. package/dist/contexts/enviveConfigContext/enviveConfigContext.js +29 -16
  80. package/dist/contexts/enviveConfigContext/index.cjs +2 -1
  81. package/dist/contexts/enviveConfigContext/index.d.cts +2 -1
  82. package/dist/contexts/enviveConfigContext/index.d.ts +2 -1
  83. package/dist/contexts/enviveConfigContext/index.js +2 -1
  84. package/dist/contexts/enviveConfigContext/useEnviveConfig.cjs +12 -0
  85. package/dist/contexts/enviveConfigContext/useEnviveConfig.d.cts +7 -0
  86. package/dist/contexts/enviveConfigContext/useEnviveConfig.d.ts +7 -0
  87. package/dist/contexts/enviveConfigContext/useEnviveConfig.js +11 -0
  88. package/dist/contexts/enviveContext/WindowChatToggleBinder.cjs +7 -5
  89. package/dist/contexts/enviveContext/WindowChatToggleBinder.js +6 -4
  90. package/dist/contexts/enviveContext/enviveContext.cjs +34 -39
  91. package/dist/contexts/enviveContext/enviveContext.js +35 -40
  92. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.cjs +7 -6
  93. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.js +7 -6
  94. package/dist/contexts/graphqlContext/graphqlContext.cjs +8 -7
  95. package/dist/contexts/graphqlContext/graphqlContext.js +8 -7
  96. package/dist/contexts/hardcopyContext/hardcopyContext.cjs +9 -8
  97. package/dist/contexts/hardcopyContext/hardcopyContext.js +9 -8
  98. package/dist/contexts/localStorageContext/localStorageContext.cjs +4 -3
  99. package/dist/contexts/localStorageContext/localStorageContext.js +4 -3
  100. package/dist/contexts/pageContext/pageContext.cjs +3 -2
  101. package/dist/contexts/pageContext/pageContext.js +3 -2
  102. package/dist/contexts/salesAgentContext/chatAPI.cjs +3 -2
  103. package/dist/contexts/salesAgentContext/chatAPI.js +3 -2
  104. package/dist/contexts/salesAgentContext/salesAgentContext.cjs +4 -3
  105. package/dist/contexts/salesAgentContext/salesAgentContext.js +4 -3
  106. package/dist/contexts/salesAgentContext/salesAgentService.cjs +3 -2
  107. package/dist/contexts/salesAgentContext/salesAgentService.js +3 -2
  108. package/dist/contexts/searchContext/searchContext.cjs +8 -6
  109. package/dist/contexts/searchContext/searchContext.js +7 -5
  110. package/dist/contexts/sessionStorageContext/sessionStorageContext.cjs +3 -2
  111. package/dist/contexts/sessionStorageContext/sessionStorageContext.js +3 -2
  112. package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +2 -2
  113. package/dist/contexts/types.d.cts +1 -1
  114. package/dist/contexts/types.d.ts +1 -1
  115. package/dist/contexts/typesV3.d.cts +1 -1
  116. package/dist/contexts/typesV3.d.ts +1 -1
  117. package/dist/contexts/uiConfigContext/index.cjs +0 -1
  118. package/dist/contexts/uiConfigContext/index.d.cts +2 -2
  119. package/dist/contexts/uiConfigContext/index.d.ts +2 -2
  120. package/dist/contexts/uiConfigContext/index.js +2 -2
  121. package/dist/contexts/uiConfigContext/uiConfigContext.cjs +13 -30
  122. package/dist/contexts/uiConfigContext/uiConfigContext.d.cts +5 -9
  123. package/dist/contexts/uiConfigContext/uiConfigContext.d.ts +5 -9
  124. package/dist/contexts/uiConfigContext/uiConfigContext.js +14 -29
  125. package/dist/contexts/userIdentityContext/userIdentityContext.cjs +7 -7
  126. package/dist/contexts/userIdentityContext/userIdentityContext.js +7 -7
  127. package/dist/contexts/widgetConfigContext/widgetConfigContext.cjs +4 -3
  128. package/dist/contexts/widgetConfigContext/widgetConfigContext.js +4 -3
  129. package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.cjs +4 -3
  130. package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.js +4 -3
  131. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +2 -2
  132. package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.d.cts +2 -2
  133. package/dist/hooks/WidgetInteraction/useWidgetInteraction.cjs +2 -2
  134. package/dist/hooks/WidgetInteraction/useWidgetInteraction.js +2 -2
  135. package/dist/hooks/WidgetInteraction/utils.cjs +2 -1
  136. package/dist/hooks/WidgetInteraction/utils.js +2 -1
  137. package/dist/hooks/utils.d.cts +1 -1
  138. package/dist/hooks/utils.d.ts +1 -1
  139. package/dist/services/amplitudeService/amplitudeService.cjs +8 -7
  140. package/dist/services/amplitudeService/amplitudeService.js +8 -7
  141. package/dist/services/ga4ProjectionService/ga4ProjectionService.cjs +3 -2
  142. package/dist/services/ga4ProjectionService/ga4ProjectionService.js +3 -2
  143. package/dist/services/userIdentityService/userIdentityService.cjs +8 -7
  144. package/dist/services/userIdentityService/userIdentityService.js +8 -7
  145. package/package.json +1 -1
  146. package/src/application/commerce-api.ts +14 -12
  147. package/src/application/logging/logger.ts +33 -8
  148. package/src/application/models/guards/api/isApiFormResponse.ts +9 -7
  149. package/src/application/models/guards/api/isApiFormSubmittedResponseAttributes.ts +6 -4
  150. package/src/application/models/guards/api/isApiOrderResponseAttributes.ts +19 -17
  151. package/src/application/models/guards/api/isApiOrgConfigResults.ts +40 -48
  152. package/src/application/models/guards/api/isApiOrganizationConfig.ts +25 -38
  153. package/src/application/models/guards/api/isApiProductResponseAttributes.ts +12 -10
  154. package/src/application/models/guards/api/isApiResponse.ts +7 -5
  155. package/src/application/models/guards/graphQL/isGraphQLColorsConfig.ts +5 -3
  156. package/src/application/models/validators/validateGraphQLFrontendConfig.ts +15 -13
  157. package/src/application/utils/analyticsUtils.ts +4 -4
  158. package/src/application/utils/nextMessageRequestToApiRequest.ts +2 -0
  159. package/src/atoms/app/variant.ts +3 -1
  160. package/src/atoms/chat/performanceMetrics.ts +3 -1
  161. package/src/atoms/envive/enviveConfig.ts +5 -3
  162. package/src/contexts/amplitudeContext/amplitudeContext.tsx +1 -1
  163. package/src/contexts/enviveConfigContext/__tests__/enviveConfigContext.test.tsx +4 -3
  164. package/src/contexts/enviveConfigContext/enviveConfigContext.tsx +50 -35
  165. package/src/contexts/enviveConfigContext/index.ts +1 -0
  166. package/src/contexts/enviveConfigContext/useEnviveConfig.ts +9 -0
  167. package/src/contexts/enviveContext/WindowChatToggleBinder.tsx +6 -4
  168. package/src/contexts/enviveContext/enviveContext.tsx +40 -45
  169. package/src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx +11 -12
  170. package/src/contexts/graphqlContext/__tests__/graphqlContext.test.tsx +4 -4
  171. package/src/contexts/graphqlContext/graphqlContext.tsx +8 -6
  172. package/src/contexts/hardcopyContext/hardcopyContext.tsx +9 -7
  173. package/src/contexts/localStorageContext/__tests__/localStorageContext.test.tsx +6 -6
  174. package/src/contexts/localStorageContext/localStorageContext.tsx +4 -2
  175. package/src/contexts/pageContext/__tests__/pageContext.test.tsx +5 -5
  176. package/src/contexts/pageContext/pageContext.tsx +3 -1
  177. package/src/contexts/salesAgentContext/chatAPI.ts +5 -5
  178. package/src/contexts/salesAgentContext/salesAgentContext.tsx +4 -2
  179. package/src/contexts/salesAgentContext/salesAgentService.ts +4 -2
  180. package/src/contexts/searchContext/__tests__/searchContext.test.tsx +15 -12
  181. package/src/contexts/searchContext/searchContext.tsx +6 -4
  182. package/src/contexts/sessionStorageContext/sessionStorageContext.tsx +3 -1
  183. package/src/contexts/uiConfigContext/__tests__/uiConfigContext.test.tsx +7 -32
  184. package/src/contexts/uiConfigContext/uiConfigContext.tsx +17 -29
  185. package/src/contexts/userIdentityContext/__tests__/userIdentityContext.test.tsx +5 -5
  186. package/src/contexts/userIdentityContext/userIdentityContext.tsx +7 -6
  187. package/src/contexts/widgetConfigContext/__tests__/widgetConfigContext.test.tsx +7 -7
  188. package/src/contexts/widgetConfigContext/widgetConfigContext.tsx +4 -2
  189. package/src/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.ts +4 -2
  190. package/src/hooks/Search/__tests__/useSearch.test.tsx +14 -8
  191. package/src/hooks/WidgetInteraction/useWidgetInteraction.ts +3 -2
  192. package/src/hooks/WidgetInteraction/utils.ts +3 -1
  193. package/src/services/amplitudeService/__tests__/amplitudeService.test.ts +3 -3
  194. package/src/services/amplitudeService/amplitudeService.ts +8 -6
  195. package/src/services/ga4ProjectionService/ga4ProjectionService.ts +3 -1
  196. package/src/services/userIdentityService/userIdentityService.ts +8 -8
@@ -3,25 +3,26 @@ import { hasPropertyOfType } from "../utils.js";
3
3
  import { ResponseCategory } from "@spiffy-ai/commerce-api-client";
4
4
 
5
5
  //#region src/application/models/guards/api/isApiResponse.ts
6
+ const logger = new logger_default("isApiResponse");
6
7
  const isApiResponse = (data) => {
7
8
  if (data == null || typeof data !== "object") {
8
- logger_default.logError("isApiResponse: data is null or not an object", void 0, { data });
9
+ logger.logError("isApiResponse: data is null or not an object", void 0, { data });
9
10
  return false;
10
11
  }
11
12
  if (!hasPropertyOfType(data, "id", "string")) {
12
- logger_default.logError("isApiResponse: id is not a string", void 0, { data });
13
+ logger.logError("isApiResponse: id is not a string", void 0, { data });
13
14
  return false;
14
15
  }
15
16
  if (!hasPropertyOfType(data, "category", "string") || !Object.values(ResponseCategory).includes(data.category)) {
16
- logger_default.logError("isApiResponse: category is not a string or not a valid response category", void 0, { data });
17
+ logger.logError("isApiResponse: category is not a string or not a valid response category", void 0, { data });
17
18
  return false;
18
19
  }
19
20
  if (!hasPropertyOfType(data, "created_at", "string")) {
20
- logger_default.logError("isApiResponse: created_at is not a string", void 0, { data });
21
+ logger.logError("isApiResponse: created_at is not a string", void 0, { data });
21
22
  return false;
22
23
  }
23
24
  if (!hasPropertyOfType(data, "attributes", "object", true)) {
24
- logger_default.logError("isApiResponse: attributes is not an object", void 0, { data });
25
+ logger.logError("isApiResponse: attributes is not an object", void 0, { data });
25
26
  return false;
26
27
  }
27
28
  return true;
@@ -29,4 +30,4 @@ const isApiResponse = (data) => {
29
30
 
30
31
  //#endregion
31
32
  export { isApiResponse };
32
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNBcGlSZXNwb25zZS5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwbGljYXRpb24vbW9kZWxzL2d1YXJkcy9hcGkvaXNBcGlSZXNwb25zZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTG9nZ2VyIGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9sb2dnaW5nL2xvZ2dlcic7XG5pbXBvcnQgeyBSZXNwb25zZSwgUmVzcG9uc2VDYXRlZ29yeSB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBoYXNQcm9wZXJ0eU9mVHlwZSB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvZ3VhcmRzL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IGlzQXBpUmVzcG9uc2UgPSAoZGF0YTogdW5rbm93bik6IGRhdGEgaXMgUmVzcG9uc2UgPT4ge1xuICBpZiAoZGF0YSA9PSBudWxsIHx8IHR5cGVvZiBkYXRhICE9PSAnb2JqZWN0Jykge1xuICAgIExvZ2dlci5sb2dFcnJvcignaXNBcGlSZXNwb25zZTogZGF0YSBpcyBudWxsIG9yIG5vdCBhbiBvYmplY3QnLCB1bmRlZmluZWQsIHsgZGF0YSB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIWhhc1Byb3BlcnR5T2ZUeXBlKGRhdGEsICdpZCcsICdzdHJpbmcnKSkge1xuICAgIExvZ2dlci5sb2dFcnJvcignaXNBcGlSZXNwb25zZTogaWQgaXMgbm90IGEgc3RyaW5nJywgdW5kZWZpbmVkLCB7IGRhdGEgfSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKFxuICAgICFoYXNQcm9wZXJ0eU9mVHlwZShkYXRhLCAnY2F0ZWdvcnknLCAnc3RyaW5nJykgfHxcbiAgICAhT2JqZWN0LnZhbHVlcyhSZXNwb25zZUNhdGVnb3J5KS5pbmNsdWRlcyhkYXRhLmNhdGVnb3J5IGFzIFJlc3BvbnNlQ2F0ZWdvcnkpXG4gICkge1xuICAgIExvZ2dlci5sb2dFcnJvcihcbiAgICAgICdpc0FwaVJlc3BvbnNlOiBjYXRlZ29yeSBpcyBub3QgYSBzdHJpbmcgb3Igbm90IGEgdmFsaWQgcmVzcG9uc2UgY2F0ZWdvcnknLFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgeyBkYXRhIH0sXG4gICAgKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIWhhc1Byb3BlcnR5T2ZUeXBlKGRhdGEsICdjcmVhdGVkX2F0JywgJ3N0cmluZycpKSB7XG4gICAgTG9nZ2VyLmxvZ0Vycm9yKCdpc0FwaVJlc3BvbnNlOiBjcmVhdGVkX2F0IGlzIG5vdCBhIHN0cmluZycsIHVuZGVmaW5lZCwgeyBkYXRhIH0pO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICghaGFzUHJvcGVydHlPZlR5cGUoZGF0YSwgJ2F0dHJpYnV0ZXMnLCAnb2JqZWN0JywgdHJ1ZSkpIHtcbiAgICBMb2dnZXIubG9nRXJyb3IoJ2lzQXBpUmVzcG9uc2U6IGF0dHJpYnV0ZXMgaXMgbm90IGFuIG9iamVjdCcsIHVuZGVmaW5lZCwgeyBkYXRhIH0pO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFJQSxNQUFhLGlCQUFpQixTQUFvQztBQUNoRSxLQUFJLFFBQVEsUUFBUSxPQUFPLFNBQVMsVUFBVTtBQUM1QyxpQkFBTyxTQUFTLGdEQUFnRCxRQUFXLEVBQUUsTUFBTSxDQUFDO0FBQ3BGLFNBQU87O0FBR1QsS0FBSSxDQUFDLGtCQUFrQixNQUFNLE1BQU0sU0FBUyxFQUFFO0FBQzVDLGlCQUFPLFNBQVMscUNBQXFDLFFBQVcsRUFBRSxNQUFNLENBQUM7QUFDekUsU0FBTzs7QUFHVCxLQUNFLENBQUMsa0JBQWtCLE1BQU0sWUFBWSxTQUFTLElBQzlDLENBQUMsT0FBTyxPQUFPLGlCQUFpQixDQUFDLFNBQVMsS0FBSyxTQUE2QixFQUM1RTtBQUNBLGlCQUFPLFNBQ0wsNEVBQ0EsUUFDQSxFQUFFLE1BQU0sQ0FDVDtBQUNELFNBQU87O0FBR1QsS0FBSSxDQUFDLGtCQUFrQixNQUFNLGNBQWMsU0FBUyxFQUFFO0FBQ3BELGlCQUFPLFNBQVMsNkNBQTZDLFFBQVcsRUFBRSxNQUFNLENBQUM7QUFDakYsU0FBTzs7QUFHVCxLQUFJLENBQUMsa0JBQWtCLE1BQU0sY0FBYyxVQUFVLEtBQUssRUFBRTtBQUMxRCxpQkFBTyxTQUFTLDhDQUE4QyxRQUFXLEVBQUUsTUFBTSxDQUFDO0FBQ2xGLFNBQU87O0FBR1QsUUFBTyJ9
33
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNBcGlSZXNwb25zZS5qcyIsIm5hbWVzIjpbIkxvZ2dlciJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvZ3VhcmRzL2FwaS9pc0FwaVJlc3BvbnNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBMb2dnZXIgZnJvbSAnc3JjL2FwcGxpY2F0aW9uL2xvZ2dpbmcvbG9nZ2VyJztcbmltcG9ydCB7IFJlc3BvbnNlLCBSZXNwb25zZUNhdGVnb3J5IH0gZnJvbSAnQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50JztcbmltcG9ydCB7IGhhc1Byb3BlcnR5T2ZUeXBlIH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscy9ndWFyZHMvdXRpbHMnO1xuXG5jb25zdCBsb2dnZXIgPSBuZXcgTG9nZ2VyKCdpc0FwaVJlc3BvbnNlJyk7XG5cbmV4cG9ydCBjb25zdCBpc0FwaVJlc3BvbnNlID0gKGRhdGE6IHVua25vd24pOiBkYXRhIGlzIFJlc3BvbnNlID0+IHtcbiAgaWYgKGRhdGEgPT0gbnVsbCB8fCB0eXBlb2YgZGF0YSAhPT0gJ29iamVjdCcpIHtcbiAgICBsb2dnZXIubG9nRXJyb3IoJ2lzQXBpUmVzcG9uc2U6IGRhdGEgaXMgbnVsbCBvciBub3QgYW4gb2JqZWN0JywgdW5kZWZpbmVkLCB7IGRhdGEgfSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFoYXNQcm9wZXJ0eU9mVHlwZShkYXRhLCAnaWQnLCAnc3RyaW5nJykpIHtcbiAgICBsb2dnZXIubG9nRXJyb3IoJ2lzQXBpUmVzcG9uc2U6IGlkIGlzIG5vdCBhIHN0cmluZycsIHVuZGVmaW5lZCwgeyBkYXRhIH0pO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmIChcbiAgICAhaGFzUHJvcGVydHlPZlR5cGUoZGF0YSwgJ2NhdGVnb3J5JywgJ3N0cmluZycpIHx8XG4gICAgIU9iamVjdC52YWx1ZXMoUmVzcG9uc2VDYXRlZ29yeSkuaW5jbHVkZXMoZGF0YS5jYXRlZ29yeSBhcyBSZXNwb25zZUNhdGVnb3J5KVxuICApIHtcbiAgICBsb2dnZXIubG9nRXJyb3IoXG4gICAgICAnaXNBcGlSZXNwb25zZTogY2F0ZWdvcnkgaXMgbm90IGEgc3RyaW5nIG9yIG5vdCBhIHZhbGlkIHJlc3BvbnNlIGNhdGVnb3J5JyxcbiAgICAgIHVuZGVmaW5lZCxcbiAgICAgIHsgZGF0YSB9LFxuICAgICk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFoYXNQcm9wZXJ0eU9mVHlwZShkYXRhLCAnY3JlYXRlZF9hdCcsICdzdHJpbmcnKSkge1xuICAgIGxvZ2dlci5sb2dFcnJvcignaXNBcGlSZXNwb25zZTogY3JlYXRlZF9hdCBpcyBub3QgYSBzdHJpbmcnLCB1bmRlZmluZWQsIHsgZGF0YSB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIWhhc1Byb3BlcnR5T2ZUeXBlKGRhdGEsICdhdHRyaWJ1dGVzJywgJ29iamVjdCcsIHRydWUpKSB7XG4gICAgbG9nZ2VyLmxvZ0Vycm9yKCdpc0FwaVJlc3BvbnNlOiBhdHRyaWJ1dGVzIGlzIG5vdCBhbiBvYmplY3QnLCB1bmRlZmluZWQsIHsgZGF0YSB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7O0FBSUEsTUFBTSxTQUFTLElBQUlBLGVBQU8sZ0JBQWdCO0FBRTFDLE1BQWEsaUJBQWlCLFNBQW9DO0FBQ2hFLEtBQUksUUFBUSxRQUFRLE9BQU8sU0FBUyxVQUFVO0FBQzVDLFNBQU8sU0FBUyxnREFBZ0QsUUFBVyxFQUFFLE1BQU0sQ0FBQztBQUNwRixTQUFPOztBQUdULEtBQUksQ0FBQyxrQkFBa0IsTUFBTSxNQUFNLFNBQVMsRUFBRTtBQUM1QyxTQUFPLFNBQVMscUNBQXFDLFFBQVcsRUFBRSxNQUFNLENBQUM7QUFDekUsU0FBTzs7QUFHVCxLQUNFLENBQUMsa0JBQWtCLE1BQU0sWUFBWSxTQUFTLElBQzlDLENBQUMsT0FBTyxPQUFPLGlCQUFpQixDQUFDLFNBQVMsS0FBSyxTQUE2QixFQUM1RTtBQUNBLFNBQU8sU0FDTCw0RUFDQSxRQUNBLEVBQUUsTUFBTSxDQUNUO0FBQ0QsU0FBTzs7QUFHVCxLQUFJLENBQUMsa0JBQWtCLE1BQU0sY0FBYyxTQUFTLEVBQUU7QUFDcEQsU0FBTyxTQUFTLDZDQUE2QyxRQUFXLEVBQUUsTUFBTSxDQUFDO0FBQ2pGLFNBQU87O0FBR1QsS0FBSSxDQUFDLGtCQUFrQixNQUFNLGNBQWMsVUFBVSxLQUFLLEVBQUU7QUFDMUQsU0FBTyxTQUFTLDhDQUE4QyxRQUFXLEVBQUUsTUFBTSxDQUFDO0FBQ2xGLFNBQU87O0FBR1QsUUFBTyJ9
@@ -21,18 +21,19 @@ const REQUIRED_COLOR_FIELDS = [
21
21
  "text_primary",
22
22
  "text_secondary"
23
23
  ];
24
+ const logger = new require_logger.default("isGraphQLColorsConfig");
24
25
  const isGraphQLColorsConfig = (data) => {
25
26
  if (typeof data !== "object" || data === null) {
26
- require_logger.default.logError("Invalid graphql response for colors config", void 0, { data });
27
+ logger.logError("Invalid graphql response for colors config", void 0, { data });
27
28
  return false;
28
29
  }
29
30
  const missingFields = REQUIRED_COLOR_FIELDS.filter((field) => !(field in data) || typeof data[field] !== "string");
30
31
  if (missingFields.length === REQUIRED_COLOR_FIELDS.length) {
31
- require_logger.default.logError("All color fields are missing or null", void 0);
32
+ logger.logError("All color fields are missing or null", void 0);
32
33
  return false;
33
34
  }
34
35
  if (missingFields.length > 0) {
35
- require_logger.default.logError("Missing or invalid color fields", void 0, {
36
+ logger.logError("Missing or invalid color fields", void 0, {
36
37
  data,
37
38
  missingFields
38
39
  });
@@ -43,4 +44,4 @@ const isGraphQLColorsConfig = (data) => {
43
44
 
44
45
  //#endregion
45
46
  exports.isGraphQLColorsConfig = isGraphQLColorsConfig;
46
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNHcmFwaFFMQ29sb3JzQ29uZmlnLmNqcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwbGljYXRpb24vbW9kZWxzL2d1YXJkcy9ncmFwaFFML2lzR3JhcGhRTENvbG9yc0NvbmZpZy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTG9nZ2VyIGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9sb2dnaW5nL2xvZ2dlcic7XG5pbXBvcnQgeyBHZXRNZXJjaGFudENvbG9yc1F1ZXJ5RGF0YSB9IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvZ3JhcGhxbCc7XG5cbmNvbnN0IFJFUVVJUkVEX0NPTE9SX0ZJRUxEUyA9IFtcbiAgJ2FjY2VudF9wcmltYXJ5JyxcbiAgJ2FjY2VudF9zZWNvbmRhcnknLFxuICAnYmFja2dyb3VuZF9kYXJrJyxcbiAgJ2JhY2tncm91bmRfbGlnaHQnLFxuICAnYmFja2dyb3VuZF9wcmltYXJ5JyxcbiAgJ2JhY2tncm91bmRfc2F0dXJhdGVkJyxcbiAgJ2JhY2tncm91bmRfc2Vjb25kYXJ5JyxcbiAgJ2JhY2tncm91bmRfc2Vjb25kYXJ5X2RhcmsnLFxuICAnYmFja2dyb3VuZF90ZXJ0aWFyeScsXG4gICdib3JkZXJfZGFyaycsXG4gICdib3JkZXJfbGlnaHQnLFxuICAnYm9yZGVyX21lZGl1bScsXG4gICdib3JkZXJfb3V0bGluZScsXG4gICd0ZXh0X2FjY2VudCcsXG4gICd0ZXh0X2xpZ2h0JyxcbiAgJ3RleHRfbGluaycsXG4gICd0ZXh0X3ByaW1hcnknLFxuICAndGV4dF9zZWNvbmRhcnknLFxuXSBhcyBjb25zdDtcblxuZXhwb3J0IGNvbnN0IGlzR3JhcGhRTENvbG9yc0NvbmZpZyA9IChkYXRhOiB1bmtub3duKTogZGF0YSBpcyBHZXRNZXJjaGFudENvbG9yc1F1ZXJ5RGF0YSA9PiB7XG4gIGlmICh0eXBlb2YgZGF0YSAhPT0gJ29iamVjdCcgfHwgZGF0YSA9PT0gbnVsbCkge1xuICAgIExvZ2dlci5sb2dFcnJvcignSW52YWxpZCBncmFwaHFsIHJlc3BvbnNlIGZvciBjb2xvcnMgY29uZmlnJywgdW5kZWZpbmVkLCB7IGRhdGEgfSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gQ2hlY2sgZWFjaCByZXF1aXJlZCBmaWVsZFxuICBjb25zdCBtaXNzaW5nRmllbGRzID0gUkVRVUlSRURfQ09MT1JfRklFTERTLmZpbHRlcihcbiAgICBmaWVsZCA9PiAhKGZpZWxkIGluIGRhdGEpIHx8IHR5cGVvZiAoZGF0YSBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPilbZmllbGRdICE9PSAnc3RyaW5nJyxcbiAgKTtcblxuICBpZiAobWlzc2luZ0ZpZWxkcy5sZW5ndGggPT09IFJFUVVJUkVEX0NPTE9SX0ZJRUxEUy5sZW5ndGgpIHtcbiAgICBMb2dnZXIubG9nRXJyb3IoJ0FsbCBjb2xvciBmaWVsZHMgYXJlIG1pc3Npbmcgb3IgbnVsbCcsIHVuZGVmaW5lZCk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKG1pc3NpbmdGaWVsZHMubGVuZ3RoID4gMCkge1xuICAgIExvZ2dlci5sb2dFcnJvcignTWlzc2luZyBvciBpbnZhbGlkIGNvbG9yIGZpZWxkcycsIHVuZGVmaW5lZCwge1xuICAgICAgZGF0YSxcbiAgICAgIG1pc3NpbmdGaWVsZHMsXG4gICAgfSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7QUFHQSxNQUFNLHdCQUF3QjtDQUM1QjtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDRDtBQUVELE1BQWEseUJBQXlCLFNBQXNEO0FBQzFGLEtBQUksT0FBTyxTQUFTLFlBQVksU0FBUyxNQUFNO0FBQzdDLHlCQUFPLFNBQVMsOENBQThDLFFBQVcsRUFBRSxNQUFNLENBQUM7QUFDbEYsU0FBTzs7Q0FJVCxNQUFNLGdCQUFnQixzQkFBc0IsUUFDMUMsVUFBUyxFQUFFLFNBQVMsU0FBUyxPQUFRLEtBQWlDLFdBQVcsU0FDbEY7QUFFRCxLQUFJLGNBQWMsV0FBVyxzQkFBc0IsUUFBUTtBQUN6RCx5QkFBTyxTQUFTLHdDQUF3QyxPQUFVO0FBQ2xFLFNBQU87O0FBR1QsS0FBSSxjQUFjLFNBQVMsR0FBRztBQUM1Qix5QkFBTyxTQUFTLG1DQUFtQyxRQUFXO0dBQzVEO0dBQ0E7R0FDRCxDQUFDO0FBQ0YsU0FBTzs7QUFHVCxRQUFPIn0=
47
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNHcmFwaFFMQ29sb3JzQ29uZmlnLmNqcyIsIm5hbWVzIjpbIkxvZ2dlciJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvZ3VhcmRzL2dyYXBoUUwvaXNHcmFwaFFMQ29sb3JzQ29uZmlnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBMb2dnZXIgZnJvbSAnc3JjL2FwcGxpY2F0aW9uL2xvZ2dpbmcvbG9nZ2VyJztcbmltcG9ydCB7IEdldE1lcmNoYW50Q29sb3JzUXVlcnlEYXRhIH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscy9ncmFwaHFsJztcblxuY29uc3QgUkVRVUlSRURfQ09MT1JfRklFTERTID0gW1xuICAnYWNjZW50X3ByaW1hcnknLFxuICAnYWNjZW50X3NlY29uZGFyeScsXG4gICdiYWNrZ3JvdW5kX2RhcmsnLFxuICAnYmFja2dyb3VuZF9saWdodCcsXG4gICdiYWNrZ3JvdW5kX3ByaW1hcnknLFxuICAnYmFja2dyb3VuZF9zYXR1cmF0ZWQnLFxuICAnYmFja2dyb3VuZF9zZWNvbmRhcnknLFxuICAnYmFja2dyb3VuZF9zZWNvbmRhcnlfZGFyaycsXG4gICdiYWNrZ3JvdW5kX3RlcnRpYXJ5JyxcbiAgJ2JvcmRlcl9kYXJrJyxcbiAgJ2JvcmRlcl9saWdodCcsXG4gICdib3JkZXJfbWVkaXVtJyxcbiAgJ2JvcmRlcl9vdXRsaW5lJyxcbiAgJ3RleHRfYWNjZW50JyxcbiAgJ3RleHRfbGlnaHQnLFxuICAndGV4dF9saW5rJyxcbiAgJ3RleHRfcHJpbWFyeScsXG4gICd0ZXh0X3NlY29uZGFyeScsXG5dIGFzIGNvbnN0O1xuXG5jb25zdCBsb2dnZXIgPSBuZXcgTG9nZ2VyKCdpc0dyYXBoUUxDb2xvcnNDb25maWcnKTtcblxuZXhwb3J0IGNvbnN0IGlzR3JhcGhRTENvbG9yc0NvbmZpZyA9IChkYXRhOiB1bmtub3duKTogZGF0YSBpcyBHZXRNZXJjaGFudENvbG9yc1F1ZXJ5RGF0YSA9PiB7XG4gIGlmICh0eXBlb2YgZGF0YSAhPT0gJ29iamVjdCcgfHwgZGF0YSA9PT0gbnVsbCkge1xuICAgIGxvZ2dlci5sb2dFcnJvcignSW52YWxpZCBncmFwaHFsIHJlc3BvbnNlIGZvciBjb2xvcnMgY29uZmlnJywgdW5kZWZpbmVkLCB7IGRhdGEgfSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gQ2hlY2sgZWFjaCByZXF1aXJlZCBmaWVsZFxuICBjb25zdCBtaXNzaW5nRmllbGRzID0gUkVRVUlSRURfQ09MT1JfRklFTERTLmZpbHRlcihcbiAgICBmaWVsZCA9PiAhKGZpZWxkIGluIGRhdGEpIHx8IHR5cGVvZiAoZGF0YSBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPilbZmllbGRdICE9PSAnc3RyaW5nJyxcbiAgKTtcblxuICBpZiAobWlzc2luZ0ZpZWxkcy5sZW5ndGggPT09IFJFUVVJUkVEX0NPTE9SX0ZJRUxEUy5sZW5ndGgpIHtcbiAgICBsb2dnZXIubG9nRXJyb3IoJ0FsbCBjb2xvciBmaWVsZHMgYXJlIG1pc3Npbmcgb3IgbnVsbCcsIHVuZGVmaW5lZCk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKG1pc3NpbmdGaWVsZHMubGVuZ3RoID4gMCkge1xuICAgIGxvZ2dlci5sb2dFcnJvcignTWlzc2luZyBvciBpbnZhbGlkIGNvbG9yIGZpZWxkcycsIHVuZGVmaW5lZCwge1xuICAgICAgZGF0YSxcbiAgICAgIG1pc3NpbmdGaWVsZHMsXG4gICAgfSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7QUFHQSxNQUFNLHdCQUF3QjtDQUM1QjtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDRDtBQUVELE1BQU0sU0FBUyxJQUFJQSx1QkFBTyx3QkFBd0I7QUFFbEQsTUFBYSx5QkFBeUIsU0FBc0Q7QUFDMUYsS0FBSSxPQUFPLFNBQVMsWUFBWSxTQUFTLE1BQU07QUFDN0MsU0FBTyxTQUFTLDhDQUE4QyxRQUFXLEVBQUUsTUFBTSxDQUFDO0FBQ2xGLFNBQU87O0NBSVQsTUFBTSxnQkFBZ0Isc0JBQXNCLFFBQzFDLFVBQVMsRUFBRSxTQUFTLFNBQVMsT0FBUSxLQUFpQyxXQUFXLFNBQ2xGO0FBRUQsS0FBSSxjQUFjLFdBQVcsc0JBQXNCLFFBQVE7QUFDekQsU0FBTyxTQUFTLHdDQUF3QyxPQUFVO0FBQ2xFLFNBQU87O0FBR1QsS0FBSSxjQUFjLFNBQVMsR0FBRztBQUM1QixTQUFPLFNBQVMsbUNBQW1DLFFBQVc7R0FDNUQ7R0FDQTtHQUNELENBQUM7QUFDRixTQUFPOztBQUdULFFBQU8ifQ==
@@ -21,18 +21,19 @@ const REQUIRED_COLOR_FIELDS = [
21
21
  "text_primary",
22
22
  "text_secondary"
23
23
  ];
24
+ const logger = new logger_default("isGraphQLColorsConfig");
24
25
  const isGraphQLColorsConfig = (data) => {
25
26
  if (typeof data !== "object" || data === null) {
26
- logger_default.logError("Invalid graphql response for colors config", void 0, { data });
27
+ logger.logError("Invalid graphql response for colors config", void 0, { data });
27
28
  return false;
28
29
  }
29
30
  const missingFields = REQUIRED_COLOR_FIELDS.filter((field) => !(field in data) || typeof data[field] !== "string");
30
31
  if (missingFields.length === REQUIRED_COLOR_FIELDS.length) {
31
- logger_default.logError("All color fields are missing or null", void 0);
32
+ logger.logError("All color fields are missing or null", void 0);
32
33
  return false;
33
34
  }
34
35
  if (missingFields.length > 0) {
35
- logger_default.logError("Missing or invalid color fields", void 0, {
36
+ logger.logError("Missing or invalid color fields", void 0, {
36
37
  data,
37
38
  missingFields
38
39
  });
@@ -43,4 +44,4 @@ const isGraphQLColorsConfig = (data) => {
43
44
 
44
45
  //#endregion
45
46
  export { isGraphQLColorsConfig };
46
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNHcmFwaFFMQ29sb3JzQ29uZmlnLmpzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMvZ3VhcmRzL2dyYXBoUUwvaXNHcmFwaFFMQ29sb3JzQ29uZmlnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBMb2dnZXIgZnJvbSAnc3JjL2FwcGxpY2F0aW9uL2xvZ2dpbmcvbG9nZ2VyJztcbmltcG9ydCB7IEdldE1lcmNoYW50Q29sb3JzUXVlcnlEYXRhIH0gZnJvbSAnc3JjL2FwcGxpY2F0aW9uL21vZGVscy9ncmFwaHFsJztcblxuY29uc3QgUkVRVUlSRURfQ09MT1JfRklFTERTID0gW1xuICAnYWNjZW50X3ByaW1hcnknLFxuICAnYWNjZW50X3NlY29uZGFyeScsXG4gICdiYWNrZ3JvdW5kX2RhcmsnLFxuICAnYmFja2dyb3VuZF9saWdodCcsXG4gICdiYWNrZ3JvdW5kX3ByaW1hcnknLFxuICAnYmFja2dyb3VuZF9zYXR1cmF0ZWQnLFxuICAnYmFja2dyb3VuZF9zZWNvbmRhcnknLFxuICAnYmFja2dyb3VuZF9zZWNvbmRhcnlfZGFyaycsXG4gICdiYWNrZ3JvdW5kX3RlcnRpYXJ5JyxcbiAgJ2JvcmRlcl9kYXJrJyxcbiAgJ2JvcmRlcl9saWdodCcsXG4gICdib3JkZXJfbWVkaXVtJyxcbiAgJ2JvcmRlcl9vdXRsaW5lJyxcbiAgJ3RleHRfYWNjZW50JyxcbiAgJ3RleHRfbGlnaHQnLFxuICAndGV4dF9saW5rJyxcbiAgJ3RleHRfcHJpbWFyeScsXG4gICd0ZXh0X3NlY29uZGFyeScsXG5dIGFzIGNvbnN0O1xuXG5leHBvcnQgY29uc3QgaXNHcmFwaFFMQ29sb3JzQ29uZmlnID0gKGRhdGE6IHVua25vd24pOiBkYXRhIGlzIEdldE1lcmNoYW50Q29sb3JzUXVlcnlEYXRhID0+IHtcbiAgaWYgKHR5cGVvZiBkYXRhICE9PSAnb2JqZWN0JyB8fCBkYXRhID09PSBudWxsKSB7XG4gICAgTG9nZ2VyLmxvZ0Vycm9yKCdJbnZhbGlkIGdyYXBocWwgcmVzcG9uc2UgZm9yIGNvbG9ycyBjb25maWcnLCB1bmRlZmluZWQsIHsgZGF0YSB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvLyBDaGVjayBlYWNoIHJlcXVpcmVkIGZpZWxkXG4gIGNvbnN0IG1pc3NpbmdGaWVsZHMgPSBSRVFVSVJFRF9DT0xPUl9GSUVMRFMuZmlsdGVyKFxuICAgIGZpZWxkID0+ICEoZmllbGQgaW4gZGF0YSkgfHwgdHlwZW9mIChkYXRhIGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+KVtmaWVsZF0gIT09ICdzdHJpbmcnLFxuICApO1xuXG4gIGlmIChtaXNzaW5nRmllbGRzLmxlbmd0aCA9PT0gUkVRVUlSRURfQ09MT1JfRklFTERTLmxlbmd0aCkge1xuICAgIExvZ2dlci5sb2dFcnJvcignQWxsIGNvbG9yIGZpZWxkcyBhcmUgbWlzc2luZyBvciBudWxsJywgdW5kZWZpbmVkKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAobWlzc2luZ0ZpZWxkcy5sZW5ndGggPiAwKSB7XG4gICAgTG9nZ2VyLmxvZ0Vycm9yKCdNaXNzaW5nIG9yIGludmFsaWQgY29sb3IgZmllbGRzJywgdW5kZWZpbmVkLCB7XG4gICAgICBkYXRhLFxuICAgICAgbWlzc2luZ0ZpZWxkcyxcbiAgICB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn07XG4iXSwibWFwcGluZ3MiOiI7OztBQUdBLE1BQU0sd0JBQXdCO0NBQzVCO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNEO0FBRUQsTUFBYSx5QkFBeUIsU0FBc0Q7QUFDMUYsS0FBSSxPQUFPLFNBQVMsWUFBWSxTQUFTLE1BQU07QUFDN0MsaUJBQU8sU0FBUyw4Q0FBOEMsUUFBVyxFQUFFLE1BQU0sQ0FBQztBQUNsRixTQUFPOztDQUlULE1BQU0sZ0JBQWdCLHNCQUFzQixRQUMxQyxVQUFTLEVBQUUsU0FBUyxTQUFTLE9BQVEsS0FBaUMsV0FBVyxTQUNsRjtBQUVELEtBQUksY0FBYyxXQUFXLHNCQUFzQixRQUFRO0FBQ3pELGlCQUFPLFNBQVMsd0NBQXdDLE9BQVU7QUFDbEUsU0FBTzs7QUFHVCxLQUFJLGNBQWMsU0FBUyxHQUFHO0FBQzVCLGlCQUFPLFNBQVMsbUNBQW1DLFFBQVc7R0FDNUQ7R0FDQTtHQUNELENBQUM7QUFDRixTQUFPOztBQUdULFFBQU8ifQ==
47
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNHcmFwaFFMQ29sb3JzQ29uZmlnLmpzIiwibmFtZXMiOlsiTG9nZ2VyIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcGxpY2F0aW9uL21vZGVscy9ndWFyZHMvZ3JhcGhRTC9pc0dyYXBoUUxDb2xvcnNDb25maWcudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IExvZ2dlciBmcm9tICdzcmMvYXBwbGljYXRpb24vbG9nZ2luZy9sb2dnZXInO1xuaW1wb3J0IHsgR2V0TWVyY2hhbnRDb2xvcnNRdWVyeURhdGEgfSBmcm9tICdzcmMvYXBwbGljYXRpb24vbW9kZWxzL2dyYXBocWwnO1xuXG5jb25zdCBSRVFVSVJFRF9DT0xPUl9GSUVMRFMgPSBbXG4gICdhY2NlbnRfcHJpbWFyeScsXG4gICdhY2NlbnRfc2Vjb25kYXJ5JyxcbiAgJ2JhY2tncm91bmRfZGFyaycsXG4gICdiYWNrZ3JvdW5kX2xpZ2h0JyxcbiAgJ2JhY2tncm91bmRfcHJpbWFyeScsXG4gICdiYWNrZ3JvdW5kX3NhdHVyYXRlZCcsXG4gICdiYWNrZ3JvdW5kX3NlY29uZGFyeScsXG4gICdiYWNrZ3JvdW5kX3NlY29uZGFyeV9kYXJrJyxcbiAgJ2JhY2tncm91bmRfdGVydGlhcnknLFxuICAnYm9yZGVyX2RhcmsnLFxuICAnYm9yZGVyX2xpZ2h0JyxcbiAgJ2JvcmRlcl9tZWRpdW0nLFxuICAnYm9yZGVyX291dGxpbmUnLFxuICAndGV4dF9hY2NlbnQnLFxuICAndGV4dF9saWdodCcsXG4gICd0ZXh0X2xpbmsnLFxuICAndGV4dF9wcmltYXJ5JyxcbiAgJ3RleHRfc2Vjb25kYXJ5Jyxcbl0gYXMgY29uc3Q7XG5cbmNvbnN0IGxvZ2dlciA9IG5ldyBMb2dnZXIoJ2lzR3JhcGhRTENvbG9yc0NvbmZpZycpO1xuXG5leHBvcnQgY29uc3QgaXNHcmFwaFFMQ29sb3JzQ29uZmlnID0gKGRhdGE6IHVua25vd24pOiBkYXRhIGlzIEdldE1lcmNoYW50Q29sb3JzUXVlcnlEYXRhID0+IHtcbiAgaWYgKHR5cGVvZiBkYXRhICE9PSAnb2JqZWN0JyB8fCBkYXRhID09PSBudWxsKSB7XG4gICAgbG9nZ2VyLmxvZ0Vycm9yKCdJbnZhbGlkIGdyYXBocWwgcmVzcG9uc2UgZm9yIGNvbG9ycyBjb25maWcnLCB1bmRlZmluZWQsIHsgZGF0YSB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvLyBDaGVjayBlYWNoIHJlcXVpcmVkIGZpZWxkXG4gIGNvbnN0IG1pc3NpbmdGaWVsZHMgPSBSRVFVSVJFRF9DT0xPUl9GSUVMRFMuZmlsdGVyKFxuICAgIGZpZWxkID0+ICEoZmllbGQgaW4gZGF0YSkgfHwgdHlwZW9mIChkYXRhIGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+KVtmaWVsZF0gIT09ICdzdHJpbmcnLFxuICApO1xuXG4gIGlmIChtaXNzaW5nRmllbGRzLmxlbmd0aCA9PT0gUkVRVUlSRURfQ09MT1JfRklFTERTLmxlbmd0aCkge1xuICAgIGxvZ2dlci5sb2dFcnJvcignQWxsIGNvbG9yIGZpZWxkcyBhcmUgbWlzc2luZyBvciBudWxsJywgdW5kZWZpbmVkKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAobWlzc2luZ0ZpZWxkcy5sZW5ndGggPiAwKSB7XG4gICAgbG9nZ2VyLmxvZ0Vycm9yKCdNaXNzaW5nIG9yIGludmFsaWQgY29sb3IgZmllbGRzJywgdW5kZWZpbmVkLCB7XG4gICAgICBkYXRhLFxuICAgICAgbWlzc2luZ0ZpZWxkcyxcbiAgICB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn07XG4iXSwibWFwcGluZ3MiOiI7OztBQUdBLE1BQU0sd0JBQXdCO0NBQzVCO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNBO0NBQ0E7Q0FDQTtDQUNEO0FBRUQsTUFBTSxTQUFTLElBQUlBLGVBQU8sd0JBQXdCO0FBRWxELE1BQWEseUJBQXlCLFNBQXNEO0FBQzFGLEtBQUksT0FBTyxTQUFTLFlBQVksU0FBUyxNQUFNO0FBQzdDLFNBQU8sU0FBUyw4Q0FBOEMsUUFBVyxFQUFFLE1BQU0sQ0FBQztBQUNsRixTQUFPOztDQUlULE1BQU0sZ0JBQWdCLHNCQUFzQixRQUMxQyxVQUFTLEVBQUUsU0FBUyxTQUFTLE9BQVEsS0FBaUMsV0FBVyxTQUNsRjtBQUVELEtBQUksY0FBYyxXQUFXLHNCQUFzQixRQUFRO0FBQ3pELFNBQU8sU0FBUyx3Q0FBd0MsT0FBVTtBQUNsRSxTQUFPOztBQUdULEtBQUksY0FBYyxTQUFTLEdBQUc7QUFDNUIsU0FBTyxTQUFTLG1DQUFtQyxRQUFXO0dBQzVEO0dBQ0E7R0FDRCxDQUFDO0FBQ0YsU0FBTzs7QUFHVCxRQUFPIn0=
@@ -5,6 +5,7 @@ const require_domInsertion = require('../../../merchants/domInsertion.cjs');
5
5
  const require_gridInsertion = require('../../../merchants/gridInsertion.cjs');
6
6
 
7
7
  //#region src/application/models/validators/validateGraphQLFrontendConfig.ts
8
+ const logger = new require_logger.default("validateGraphQLFrontendConfig");
8
9
  const validateAndTransformPageVariants = (config) => {
9
10
  const { variantChecks, widgetMounting, ...rest } = require_snakeToCamelTransformer.transformSnakeToCamel(config);
10
11
  const variantTests = Array.isArray(variantChecks) ? variantChecks.map(({ checkType, ...restCheck }) => ({
@@ -137,34 +138,34 @@ const validateAndTransformWidgetConfig = (config, configKey) => {
137
138
  const validateGraphQLFrontendConfig = (data) => {
138
139
  if (data === null || data === void 0) return;
139
140
  if (typeof data !== "object" || Array.isArray(data)) {
140
- require_logger.default.logWarn("Invalid GraphQL frontend config data: not an object", void 0, { data });
141
+ logger.logWarn("Invalid GraphQL frontend config data: not an object", void 0, { data });
141
142
  return;
142
143
  }
143
144
  const obj = data;
144
145
  if ("merchant_override_css" in obj && typeof obj.merchant_override_css !== "string" && obj.merchant_override_css !== null) {
145
- require_logger.default.logWarn("Invalid GraphQL frontend config data: merchant_override_css must be a string or null", void 0, { data });
146
+ logger.logWarn("Invalid GraphQL frontend config data: merchant_override_css must be a string or null", void 0, { data });
146
147
  return;
147
148
  }
148
149
  if ("page_variants" in obj) {
149
150
  if (obj.page_variants !== void 0 && obj.page_variants !== null && !Array.isArray(obj.page_variants)) {
150
- require_logger.default.logWarn("Invalid GraphQL frontend config data: page_variants must be an array or null/undefined", void 0, { data });
151
+ logger.logWarn("Invalid GraphQL frontend config data: page_variants must be an array or null/undefined", void 0, { data });
151
152
  return;
152
153
  }
153
154
  }
154
155
  if ("mounting_configs" in obj) {
155
156
  if (obj.mounting_configs !== void 0 && obj.mounting_configs !== null && !Array.isArray(obj.mounting_configs)) {
156
- require_logger.default.logWarn("Invalid GraphQL frontend config data: mounting_configs must be an array or null/undefined", void 0, { data });
157
+ logger.logWarn("Invalid GraphQL frontend config data: mounting_configs must be an array or null/undefined", void 0, { data });
157
158
  return;
158
159
  }
159
160
  }
160
161
  if ("widget_configs" in obj) {
161
162
  if (obj.widget_configs !== void 0 && obj.widget_configs !== null && !Array.isArray(obj.widget_configs)) {
162
- require_logger.default.logWarn("Invalid GraphQL frontend config data: widget_configs must be an array or null/undefined", void 0, { data });
163
+ logger.logWarn("Invalid GraphQL frontend config data: widget_configs must be an array or null/undefined", void 0, { data });
163
164
  return;
164
165
  }
165
166
  }
166
167
  if ("ui_configs" in obj && typeof obj.ui_configs !== "object" && obj.ui_configs !== null) {
167
- require_logger.default.logWarn("Invalid GraphQL frontend config data: ui_configs must be an object or null/undefined", void 0, { data });
168
+ logger.logWarn("Invalid GraphQL frontend config data: ui_configs must be an object or null/undefined", void 0, { data });
168
169
  return;
169
170
  }
170
171
  try {
@@ -176,12 +177,12 @@ const validateGraphQLFrontendConfig = (data) => {
176
177
  const validatedVariant = validateAndTransformPageVariants(variant);
177
178
  validatedPageVariants.push(validatedVariant);
178
179
  } catch (error) {
179
- require_logger.default.logWarn("Invalid page variant, skipping", error, {
180
+ logger.logWarn("Invalid page variant, skipping", error, {
180
181
  variantId: variant.variantId,
181
182
  variant
182
183
  });
183
184
  }
184
- else require_logger.default.logWarn("Invalid page variant structure, skipping", void 0, { variant });
185
+ else logger.logWarn("Invalid page variant structure, skipping", void 0, { variant });
185
186
  transformedData.pageVariants = validatedPageVariants;
186
187
  }
187
188
  if (transformedData.mountingConfigs && Array.isArray(transformedData.mountingConfigs)) {
@@ -192,12 +193,12 @@ const validateGraphQLFrontendConfig = (data) => {
192
193
  const validatedConfig = validateAndTransformMountingConfig(config, item.key);
193
194
  mountingConfigsRecord[item.key] = validatedConfig;
194
195
  } catch (error) {
195
- require_logger.default.logWarn("Invalid mounting config, skipping", error, {
196
+ logger.logWarn("Invalid mounting config, skipping", error, {
196
197
  configKey: item.key,
197
198
  config: item.config
198
199
  });
199
200
  }
200
- else require_logger.default.logWarn("Invalid mounting config item structure, skipping", void 0, { item });
201
+ else logger.logWarn("Invalid mounting config item structure, skipping", void 0, { item });
201
202
  transformedData.mountingConfigs = mountingConfigsRecord;
202
203
  }
203
204
  if (transformedData.widgetConfigs && Array.isArray(transformedData.widgetConfigs)) {
@@ -208,17 +209,17 @@ const validateGraphQLFrontendConfig = (data) => {
208
209
  const validatedConfig = validateAndTransformWidgetConfig(config, item.key);
209
210
  widgetConfigsRecord[item.key] = validatedConfig;
210
211
  } catch (error) {
211
- require_logger.default.logWarn("Invalid widget config, skipping", error, {
212
+ logger.logWarn("Invalid widget config, skipping", error, {
212
213
  configKey: item.key,
213
214
  config: item.config
214
215
  });
215
216
  }
216
- else require_logger.default.logWarn("Invalid widget config item structure, skipping", void 0, { item });
217
+ else logger.logWarn("Invalid widget config item structure, skipping", void 0, { item });
217
218
  transformedData.widgetConfigs = widgetConfigsRecord;
218
219
  }
219
220
  return transformedData;
220
221
  } catch (error) {
221
- require_logger.default.logWarn("Failed to validate and transform GraphQL frontend config data", error, { data });
222
+ logger.logWarn("Failed to validate and transform GraphQL frontend config data", error, { data });
222
223
  return;
223
224
  }
224
225
  };
@@ -228,4 +229,4 @@ exports.validateAndTransformMountingConfig = validateAndTransformMountingConfig;
228
229
  exports.validateAndTransformPageVariants = validateAndTransformPageVariants;
229
230
  exports.validateAndTransformWidgetConfig = validateAndTransformWidgetConfig;
230
231
  exports.validateGraphQLFrontendConfig = validateGraphQLFrontendConfig;
231
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"validateGraphQLFrontendConfig.cjs","names":["transformSnakeToCamel","normalizedConfig: Record<string, unknown>","PageVariantTestType","DOMInsertionType","GridInsertionType","result: WidgetMountingConfig","validatedPageVariants: PageVariantConfig[]","mountingConfigsRecord: Record<string, WidgetMountingConfig>","widgetConfigsRecord: Record<string, unknown>"],"sources":["../../../../src/application/models/validators/validateGraphQLFrontendConfig.ts"],"sourcesContent":["import { FrontendConfig } from 'src/application/models/frontendConfig';\nimport { transformSnakeToCamel } from 'src/application/models/utils/snakeToCamelTransformer';\nimport {\n  PageVariantConfig,\n  PageVariantTestType,\n  WidgetConfig,\n  WidgetMountingConfig,\n} from 'src/contexts/types';\nimport { DOMInsertionType } from 'src/merchants/domInsertion';\nimport { GridInsertionType } from 'src/merchants/gridInsertion';\nimport Logger from 'src/application/logging/logger';\n\n// Helper function to validate and transform PageVariantQueryData to PageVariantConfig\nexport const validateAndTransformPageVariants = (\n  config: Record<string, unknown>,\n): PageVariantConfig => {\n  const transformed = transformSnakeToCamel(config) as Record<string, unknown>;\n\n  const { variantChecks, widgetMounting, ...rest } = transformed;\n\n  // Convert variantChecks to variantTests with testType normalization\n  const variantTests = Array.isArray(variantChecks)\n    ? variantChecks.map(({ checkType, ...restCheck }) => ({\n        ...restCheck,\n        testType: checkType,\n      }))\n    : [];\n\n  // Normalize widgetMounting: checks -> tests, checkType -> testType\n  const normalizedWidgetMounting = Array.isArray(widgetMounting)\n    ? widgetMounting.map(({ mountingPointWidgets, ...restMounting }) => ({\n        ...restMounting,\n        ...(Array.isArray(mountingPointWidgets)\n          ? {\n              mountingPointWidgets: mountingPointWidgets.map(({ checks, ...restWidget }) => ({\n                ...restWidget,\n                tests: Array.isArray(checks)\n                  ? checks.map(({ checkType, ...restCheck }) => ({\n                      ...restCheck,\n                      testType: checkType,\n                    }))\n                  : [],\n              })),\n            }\n          : {}),\n      }))\n    : [];\n\n  const normalizedConfig: Record<string, unknown> = {\n    ...rest,\n    ...(variantTests ? { variantTests } : {}),\n    ...(normalizedWidgetMounting ? { widgetMounting: normalizedWidgetMounting } : {}),\n  };\n\n  const variantId = normalizedConfig.variantId as string;\n  const variantType = normalizedConfig.variantType as string;\n\n  if (typeof variantId !== 'string' || !variantId) {\n    throw new Error(`Missing or invalid variantId for pageVariant`);\n  }\n\n  if (typeof variantType !== 'string' || !variantType) {\n    throw new Error(`Missing or invalid variantType for pageVariant '${variantId}'`);\n  }\n\n  if (!Array.isArray(variantTests)) {\n    throw new Error(\n      `Missing or invalid variantTests for pageVariant '${variantId}'. Must be an array`,\n    );\n  }\n\n  for (const test of variantTests) {\n    if (!test.testType || typeof test.testType !== 'string') {\n      throw new Error(`Invalid variantTest.testType for pageVariant '${variantId}'`);\n    }\n    if (!Object.values(PageVariantTestType).includes(test.testType as PageVariantTestType)) {\n      throw new Error(\n        `Invalid testType '${test.testType}' for pageVariant '${variantId}'. Valid types: ${Object.values(\n          PageVariantTestType,\n        ).join(', ')}`,\n      );\n    }\n  }\n\n  if (!Array.isArray(normalizedWidgetMounting)) {\n    throw new Error(\n      `Missing or invalid widgetMounting for pageVariant '${variantId}'. Must be an array`,\n    );\n  }\n\n  for (const mounting of normalizedWidgetMounting) {\n    if (typeof mounting.mountingConfigId !== 'string' || !mounting.mountingConfigId) {\n      throw new Error(`Invalid mountingConfigId in widgetMounting for pageVariant '${variantId}'`);\n    }\n\n    if (mounting.widgetConfigId && typeof mounting.widgetConfigId !== 'string') {\n      throw new Error(`Invalid widgetConfigId in widgetMounting for pageVariant '${variantId}'`);\n    }\n\n    if (mounting.mountingPointWidgets) {\n      for (const widget of mounting.mountingPointWidgets) {\n        if (typeof widget.widgetConfigId !== 'string' || !widget.widgetConfigId) {\n          throw new Error(\n            `Invalid widgetConfigId in mountingPointWidgets for pageVariant '${variantId}'`,\n          );\n        }\n\n        if (!Array.isArray(widget.tests)) {\n          throw new Error(\n            `Invalid or missing tests in mountingPointWidgets for pageVariant '${variantId}'`,\n          );\n        }\n      }\n    }\n  }\n\n  if (variantType === 'plp') {\n    if (typeof normalizedConfig.plpIdExtractor !== 'string' || !normalizedConfig.plpIdExtractor) {\n      throw new Error(`Missing or invalid plpIdExtractor for PLP pageVariant '${variantId}'`);\n    }\n  }\n\n  if (variantType === 'pdp') {\n    if (\n      typeof normalizedConfig.productIdExtractor !== 'string' ||\n      !normalizedConfig.productIdExtractor\n    ) {\n      throw new Error(`Missing or invalid productIdExtractor for PDP pageVariant '${variantId}'`);\n    }\n    if (\n      normalizedConfig.parentProductIdExtractor &&\n      typeof normalizedConfig.parentProductIdExtractor !== 'string'\n    ) {\n      throw new Error(\n        `Invalid parentProductIdExtractor for PDP pageVariant '${variantId}'. Must be string if provided`,\n      );\n    }\n  }\n\n  return normalizedConfig as PageVariantConfig;\n};\n\n// Helper function to validate and transform MountingConfigQueryData to WidgetMountingConfig\nexport const validateAndTransformMountingConfig = (\n  config: Record<string, unknown>,\n  configKey: string,\n): WidgetMountingConfig => {\n  // RENAMING LOGIC: Convert backend \"Check\" terminology to frontend \"Test\" terminology\n  const normalizedConfig = { ...config };\n\n  // Convert checkId to testId for frontend compatibility (data is already camelCase)\n  if (normalizedConfig.checkId && !normalizedConfig.testId) {\n    normalizedConfig.testId = normalizedConfig.checkId;\n    delete normalizedConfig.checkId;\n  }\n\n  // Required fields - these must be present and valid\n  if (typeof normalizedConfig.mountingConfigId !== 'string' || !normalizedConfig.mountingConfigId) {\n    throw new Error(`Missing or invalid mountingConfigId for config '${configKey}'`);\n  }\n  if (typeof normalizedConfig.containerId !== 'string' || !normalizedConfig.containerId) {\n    throw new Error(`Missing or invalid containerId for config '${configKey}'`);\n  }\n  if (typeof normalizedConfig.testId !== 'string' || !normalizedConfig.testId) {\n    throw new Error(`Missing or invalid testId for config '${configKey}'`);\n  }\n\n  // Required insertionPoint\n  if (\n    !normalizedConfig.insertionPoint ||\n    typeof normalizedConfig.insertionPoint !== 'object' ||\n    Array.isArray(normalizedConfig.insertionPoint)\n  ) {\n    throw new Error(`Missing or invalid insertionPoint for config '${configKey}'`);\n  }\n\n  const insertionPoint = normalizedConfig.insertionPoint as Record<string, unknown>;\n\n  // Validate insertionPoint required fields\n  if (typeof insertionPoint.selector !== 'string' || !insertionPoint.selector) {\n    throw new Error(`Missing or invalid insertionPoint.selector for config '${configKey}'`);\n  }\n  if (typeof insertionPoint.insertionType !== 'string' || !insertionPoint.insertionType) {\n    throw new Error(`Missing or invalid insertionPoint.insertionType for config '${configKey}'`);\n  }\n\n  // Validate insertionType is a valid DOMInsertionType\n  if (!Object.values(DOMInsertionType).includes(insertionPoint.insertionType as DOMInsertionType)) {\n    throw new Error(\n      `Invalid insertionPoint.insertionType '${insertionPoint.insertionType}' for config '${configKey}'. Valid types: ${Object.values(DOMInsertionType).join(', ')}`,\n    );\n  }\n\n  // Validate optional insertionPoint fields\n  if (insertionPoint.selectionIndex != null && typeof insertionPoint.selectionIndex !== 'number') {\n    throw new Error(\n      `Invalid insertionPoint.selectionIndex for config '${configKey}'. Must be a number or null/undefined`,\n    );\n  }\n\n  // Validate optional parentInsertionPoint if present\n  let parentInsertionPoint;\n  if (normalizedConfig.parentInsertionPoint) {\n    if (\n      typeof normalizedConfig.parentInsertionPoint !== 'object' ||\n      Array.isArray(normalizedConfig.parentInsertionPoint)\n    ) {\n      throw new Error(`Invalid parentInsertionPoint for config '${configKey}'. Must be an object`);\n    }\n\n    const parentPoint = normalizedConfig.parentInsertionPoint as Record<string, unknown>;\n    if (typeof parentPoint.selector !== 'string' || !parentPoint.selector) {\n      throw new Error(`Missing or invalid parentInsertionPoint.selector for config '${configKey}'`);\n    }\n    if (typeof parentPoint.insertionType !== 'string' || !parentPoint.insertionType) {\n      throw new Error(\n        `Missing or invalid parentInsertionPoint.insertionType for config '${configKey}'`,\n      );\n    }\n\n    if (!Object.values(DOMInsertionType).includes(parentPoint.insertionType as DOMInsertionType)) {\n      throw new Error(\n        `Invalid parentInsertionPoint.insertionType '${parentPoint.insertionType}' for config '${configKey}'. Valid types: ${Object.values(DOMInsertionType).join(', ')}`,\n      );\n    }\n\n    if (parentPoint.selectionIndex != null && typeof parentPoint.selectionIndex !== 'number') {\n      throw new Error(\n        `Invalid parentInsertionPoint.selectionIndex for config '${configKey}'. Must be a number or null/undefined`,\n      );\n    }\n\n    parentInsertionPoint = {\n      selector: parentPoint.selector,\n      insertionType: parentPoint.insertionType as DOMInsertionType,\n      selectionIndex: parentPoint.selectionIndex as number | undefined,\n    };\n  }\n\n  // Validate optional wrappingElement if present\n  let wrappingElement;\n  if (normalizedConfig.wrappingElement) {\n    if (\n      typeof normalizedConfig.wrappingElement !== 'object' ||\n      Array.isArray(normalizedConfig.wrappingElement)\n    ) {\n      throw new Error(`Invalid wrappingElement for config '${configKey}'. Must be an object`);\n    }\n\n    const wrapping = normalizedConfig.wrappingElement as Record<string, unknown>;\n    if (typeof wrapping.className !== 'string' || !wrapping.className) {\n      throw new Error(`Missing or invalid wrappingElement.className for config '${configKey}'`);\n    }\n    if (typeof wrapping.element !== 'string' || !wrapping.element) {\n      throw new Error(`Missing or invalid wrappingElement.element for config '${configKey}'`);\n    }\n    if (typeof wrapping.insertionType !== 'string' || !wrapping.insertionType) {\n      throw new Error(`Missing or invalid wrappingElement.insertionType for config '${configKey}'`);\n    }\n\n    if (!Object.values(DOMInsertionType).includes(wrapping.insertionType as DOMInsertionType)) {\n      throw new Error(\n        `Invalid wrappingElement.insertionType '${wrapping.insertionType}' for config '${configKey}'. Valid types: ${Object.values(DOMInsertionType).join(', ')}`,\n      );\n    }\n\n    wrappingElement = {\n      className: wrapping.className,\n      element: wrapping.element,\n      insertionType: wrapping.insertionType as DOMInsertionType,\n    };\n  }\n\n  // Validate optional fields\n  if (\n    normalizedConfig.divCheckSelector != null &&\n    typeof normalizedConfig.divCheckSelector !== 'string'\n  ) {\n    throw new Error(\n      `Invalid divCheckSelector for config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n  if (normalizedConfig.className != null && typeof normalizedConfig.className !== 'string') {\n    throw new Error(\n      `Invalid className for config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n  if (\n    normalizedConfig.suppressionSelector != null &&\n    typeof normalizedConfig.suppressionSelector !== 'string'\n  ) {\n    throw new Error(\n      `Invalid suppressionSelector for config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n  if (\n    normalizedConfig.dataAttributes != null &&\n    (typeof normalizedConfig.dataAttributes !== 'object' ||\n      Array.isArray(normalizedConfig.dataAttributes))\n  ) {\n    throw new Error(\n      `Invalid dataAttributes for config '${configKey}'. Must be an object or null/undefined`,\n    );\n  }\n  if (\n    normalizedConfig.style != null &&\n    (typeof normalizedConfig.style !== 'object' || Array.isArray(normalizedConfig.style))\n  ) {\n    throw new Error(`Invalid style for config '${configKey}'. Must be an object or null/undefined`);\n  }\n\n  // Validate gridInsertionType if present\n  let gridInsertionType;\n  if (normalizedConfig.gridInsertionType) {\n    if (\n      typeof normalizedConfig.gridInsertionType !== 'string' ||\n      !normalizedConfig.gridInsertionType\n    ) {\n      throw new Error(`Invalid gridInsertionType for config '${configKey}'. Must be a string`);\n    }\n\n    if (\n      !Object.values(GridInsertionType).includes(\n        normalizedConfig.gridInsertionType as GridInsertionType,\n      )\n    ) {\n      throw new Error(\n        `Invalid gridInsertionType '${normalizedConfig.gridInsertionType}' for config '${configKey}'. Valid types: ${Object.values(GridInsertionType).join(', ')}`,\n      );\n    }\n    gridInsertionType = normalizedConfig.gridInsertionType as GridInsertionType;\n  }\n\n  // Build the return object, only including optional fields if they have values\n  const result: WidgetMountingConfig = {\n    mountingConfigId: normalizedConfig.mountingConfigId,\n    containerId: normalizedConfig.containerId,\n    testId: normalizedConfig.testId,\n    insertionPoint: {\n      selector: insertionPoint.selector,\n      insertionType: insertionPoint.insertionType as DOMInsertionType,\n      ...(insertionPoint.selectionIndex != null && {\n        selectionIndex: insertionPoint.selectionIndex,\n      }),\n    },\n  };\n\n  // Only add optional fields if they have values\n  if (parentInsertionPoint) {\n    result.parentInsertionPoint = parentInsertionPoint;\n  }\n  if (gridInsertionType) {\n    result.gridInsertionType = gridInsertionType;\n  }\n  if (wrappingElement) {\n    result.wrappingElement = wrappingElement;\n  }\n  if (normalizedConfig.divCheckSelector) {\n    result.divCheckSelector = normalizedConfig.divCheckSelector as string;\n  }\n  if (normalizedConfig.className) {\n    result.className = normalizedConfig.className as string;\n  }\n  if (normalizedConfig.suppressionSelector) {\n    result.suppressionSelector = normalizedConfig.suppressionSelector;\n  }\n  if (normalizedConfig.dataAttributes) {\n    result.dataAttributes = normalizedConfig.dataAttributes as Record<string, string>;\n  }\n  if (normalizedConfig.style) {\n    result.style = normalizedConfig.style as Partial<CSSStyleDeclaration>;\n  }\n\n  return result;\n};\n\n// Helper function to validate and transform WidgetConfigQueryData to WidgetConfig\nexport const validateAndTransformWidgetConfig = (\n  config: Record<string, unknown>,\n  configKey: string,\n): WidgetConfig => {\n  const normalizedConfig = transformSnakeToCamel(config) as Record<string, unknown>;\n\n  if (typeof normalizedConfig.widgetConfigId !== 'string' || !normalizedConfig.widgetConfigId) {\n    throw new Error(`Missing or invalid widgetConfigId for widget config '${configKey}'`);\n  }\n  if (typeof normalizedConfig.type !== 'string' || !normalizedConfig.type) {\n    throw new Error(`Missing or invalid type for widget config '${configKey}'`);\n  }\n\n  if (normalizedConfig.contentId != null && typeof normalizedConfig.contentId !== 'string') {\n    throw new Error(\n      `Invalid contentId for widget config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n\n  // Note: Widget configs are complex unions with type-specific properties.\n\n  // Return the normalized config as WidgetConfig\n  // Use intermediate 'unknown' cast for complex union types\n  return normalizedConfig as unknown as WidgetConfig;\n};\n\nexport const validateGraphQLFrontendConfig = (data: unknown): FrontendConfig | undefined => {\n  if (data === null || data === undefined) {\n    return undefined;\n  }\n\n  if (typeof data !== 'object' || Array.isArray(data)) {\n    Logger.logWarn('Invalid GraphQL frontend config data: not an object', undefined, { data });\n    return undefined;\n  }\n\n  const obj = data as Record<string, unknown>;\n\n  // Validate merchant_override_css if present\n  if (\n    'merchant_override_css' in obj &&\n    typeof obj.merchant_override_css !== 'string' &&\n    obj.merchant_override_css !== null\n  ) {\n    Logger.logWarn(\n      'Invalid GraphQL frontend config data: merchant_override_css must be a string or null',\n      undefined,\n      { data },\n    );\n    return undefined;\n  }\n\n  // Validate page_variants if present\n  if ('page_variants' in obj) {\n    if (\n      obj.page_variants !== undefined &&\n      obj.page_variants !== null &&\n      !Array.isArray(obj.page_variants)\n    ) {\n      Logger.logWarn(\n        'Invalid GraphQL frontend config data: page_variants must be an array or null/undefined',\n        undefined,\n        { data },\n      );\n      return undefined;\n    }\n  }\n\n  // Validate mounting_configs if present\n  if ('mounting_configs' in obj) {\n    if (\n      obj.mounting_configs !== undefined &&\n      obj.mounting_configs !== null &&\n      !Array.isArray(obj.mounting_configs)\n    ) {\n      Logger.logWarn(\n        'Invalid GraphQL frontend config data: mounting_configs must be an array or null/undefined',\n        undefined,\n        { data },\n      );\n      return undefined;\n    }\n  }\n\n  // Validate widget_configs if present\n  if ('widget_configs' in obj) {\n    if (\n      obj.widget_configs !== undefined &&\n      obj.widget_configs !== null &&\n      !Array.isArray(obj.widget_configs)\n    ) {\n      Logger.logWarn(\n        'Invalid GraphQL frontend config data: widget_configs must be an array or null/undefined',\n        undefined,\n        { data },\n      );\n      return undefined;\n    }\n  }\n\n  // Validate ui_configs if present\n  if ('ui_configs' in obj && typeof obj.ui_configs !== 'object' && obj.ui_configs !== null) {\n    Logger.logWarn(\n      'Invalid GraphQL frontend config data: ui_configs must be an object or null/undefined',\n      undefined,\n      { data },\n    );\n    return undefined;\n  }\n\n  try {\n    // Transform the data to camelCase\n    const transformedData = transformSnakeToCamel(obj) as Record<string, unknown>;\n\n    // Convert page_variants from array to validated array if present\n    if (transformedData.pageVariants && Array.isArray(transformedData.pageVariants)) {\n      const pageVariantsArray = transformedData.pageVariants;\n      const validatedPageVariants: PageVariantConfig[] = [];\n\n      for (const variant of pageVariantsArray) {\n        if (variant && typeof variant === 'object' && typeof variant.variantId === 'string') {\n          try {\n            const validatedVariant = validateAndTransformPageVariants(variant);\n            validatedPageVariants.push(validatedVariant);\n          } catch (error) {\n            Logger.logWarn('Invalid page variant, skipping', error, {\n              variantId: variant.variantId,\n              variant,\n            });\n            // Continue processing other variants\n          }\n        } else {\n          Logger.logWarn('Invalid page variant structure, skipping', undefined, { variant });\n        }\n      }\n\n      transformedData.pageVariants = validatedPageVariants;\n    }\n\n    // Convert mounting_configs from array to Record if present\n    if (transformedData.mountingConfigs && Array.isArray(transformedData.mountingConfigs)) {\n      const mountingConfigsArray = transformedData.mountingConfigs as Array<{\n        key: string;\n        config: unknown;\n      }>;\n      const mountingConfigsRecord: Record<string, WidgetMountingConfig> = {};\n\n      for (const item of mountingConfigsArray) {\n        if (\n          item &&\n          typeof item.key === 'string' &&\n          item.config &&\n          typeof item.config === 'object'\n        ) {\n          try {\n            // Validate and transform the config structure\n            const config = item.config as Record<string, unknown>;\n            const validatedConfig = validateAndTransformMountingConfig(config, item.key);\n            mountingConfigsRecord[item.key] = validatedConfig;\n          } catch (error) {\n            Logger.logWarn('Invalid mounting config, skipping', error, {\n              configKey: item.key,\n              config: item.config,\n            });\n            // Continue processing other configs\n          }\n        } else {\n          Logger.logWarn('Invalid mounting config item structure, skipping', undefined, { item });\n        }\n      }\n\n      transformedData.mountingConfigs = mountingConfigsRecord;\n    }\n\n    // Convert widget_configs from array to Record if present\n    if (transformedData.widgetConfigs && Array.isArray(transformedData.widgetConfigs)) {\n      const widgetConfigsArray = transformedData.widgetConfigs as Array<{\n        key: string;\n        config: unknown;\n      }>;\n      const widgetConfigsRecord: Record<string, unknown> = {};\n\n      for (const item of widgetConfigsArray) {\n        if (\n          item &&\n          typeof item.key === 'string' &&\n          item.config &&\n          typeof item.config === 'object'\n        ) {\n          try {\n            // Validate and transform widget config using the dedicated validation function\n            const config = item.config as Record<string, unknown>;\n            const validatedConfig = validateAndTransformWidgetConfig(config, item.key);\n            widgetConfigsRecord[item.key] = validatedConfig;\n          } catch (error) {\n            Logger.logWarn('Invalid widget config, skipping', error, {\n              configKey: item.key,\n              config: item.config,\n            });\n            // Continue processing other configs\n          }\n        } else {\n          Logger.logWarn('Invalid widget config item structure, skipping', undefined, { item });\n        }\n      }\n\n      transformedData.widgetConfigs = widgetConfigsRecord;\n    }\n\n    return transformedData as FrontendConfig;\n  } catch (error) {\n    Logger.logWarn('Failed to validate and transform GraphQL frontend config data', error, {\n      data,\n    });\n    return undefined;\n  }\n};\n"],"mappings":"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"}
232
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"validateGraphQLFrontendConfig.cjs","names":["Logger","transformSnakeToCamel","normalizedConfig: Record<string, unknown>","PageVariantTestType","DOMInsertionType","GridInsertionType","result: WidgetMountingConfig","validatedPageVariants: PageVariantConfig[]","mountingConfigsRecord: Record<string, WidgetMountingConfig>","widgetConfigsRecord: Record<string, unknown>"],"sources":["../../../../src/application/models/validators/validateGraphQLFrontendConfig.ts"],"sourcesContent":["import { FrontendConfig } from 'src/application/models/frontendConfig';\nimport { transformSnakeToCamel } from 'src/application/models/utils/snakeToCamelTransformer';\nimport {\n  PageVariantConfig,\n  PageVariantTestType,\n  WidgetConfig,\n  WidgetMountingConfig,\n} from 'src/contexts/types';\nimport { DOMInsertionType } from 'src/merchants/domInsertion';\nimport { GridInsertionType } from 'src/merchants/gridInsertion';\nimport Logger from 'src/application/logging/logger';\n\nconst logger = new Logger('validateGraphQLFrontendConfig');\n\n// Helper function to validate and transform PageVariantQueryData to PageVariantConfig\nexport const validateAndTransformPageVariants = (\n  config: Record<string, unknown>,\n): PageVariantConfig => {\n  const transformed = transformSnakeToCamel(config) as Record<string, unknown>;\n\n  const { variantChecks, widgetMounting, ...rest } = transformed;\n\n  // Convert variantChecks to variantTests with testType normalization\n  const variantTests = Array.isArray(variantChecks)\n    ? variantChecks.map(({ checkType, ...restCheck }) => ({\n        ...restCheck,\n        testType: checkType,\n      }))\n    : [];\n\n  // Normalize widgetMounting: checks -> tests, checkType -> testType\n  const normalizedWidgetMounting = Array.isArray(widgetMounting)\n    ? widgetMounting.map(({ mountingPointWidgets, ...restMounting }) => ({\n        ...restMounting,\n        ...(Array.isArray(mountingPointWidgets)\n          ? {\n              mountingPointWidgets: mountingPointWidgets.map(({ checks, ...restWidget }) => ({\n                ...restWidget,\n                tests: Array.isArray(checks)\n                  ? checks.map(({ checkType, ...restCheck }) => ({\n                      ...restCheck,\n                      testType: checkType,\n                    }))\n                  : [],\n              })),\n            }\n          : {}),\n      }))\n    : [];\n\n  const normalizedConfig: Record<string, unknown> = {\n    ...rest,\n    ...(variantTests ? { variantTests } : {}),\n    ...(normalizedWidgetMounting ? { widgetMounting: normalizedWidgetMounting } : {}),\n  };\n\n  const variantId = normalizedConfig.variantId as string;\n  const variantType = normalizedConfig.variantType as string;\n\n  if (typeof variantId !== 'string' || !variantId) {\n    throw new Error(`Missing or invalid variantId for pageVariant`);\n  }\n\n  if (typeof variantType !== 'string' || !variantType) {\n    throw new Error(`Missing or invalid variantType for pageVariant '${variantId}'`);\n  }\n\n  if (!Array.isArray(variantTests)) {\n    throw new Error(\n      `Missing or invalid variantTests for pageVariant '${variantId}'. Must be an array`,\n    );\n  }\n\n  for (const test of variantTests) {\n    if (!test.testType || typeof test.testType !== 'string') {\n      throw new Error(`Invalid variantTest.testType for pageVariant '${variantId}'`);\n    }\n    if (!Object.values(PageVariantTestType).includes(test.testType as PageVariantTestType)) {\n      throw new Error(\n        `Invalid testType '${test.testType}' for pageVariant '${variantId}'. Valid types: ${Object.values(\n          PageVariantTestType,\n        ).join(', ')}`,\n      );\n    }\n  }\n\n  if (!Array.isArray(normalizedWidgetMounting)) {\n    throw new Error(\n      `Missing or invalid widgetMounting for pageVariant '${variantId}'. Must be an array`,\n    );\n  }\n\n  for (const mounting of normalizedWidgetMounting) {\n    if (typeof mounting.mountingConfigId !== 'string' || !mounting.mountingConfigId) {\n      throw new Error(`Invalid mountingConfigId in widgetMounting for pageVariant '${variantId}'`);\n    }\n\n    if (mounting.widgetConfigId && typeof mounting.widgetConfigId !== 'string') {\n      throw new Error(`Invalid widgetConfigId in widgetMounting for pageVariant '${variantId}'`);\n    }\n\n    if (mounting.mountingPointWidgets) {\n      for (const widget of mounting.mountingPointWidgets) {\n        if (typeof widget.widgetConfigId !== 'string' || !widget.widgetConfigId) {\n          throw new Error(\n            `Invalid widgetConfigId in mountingPointWidgets for pageVariant '${variantId}'`,\n          );\n        }\n\n        if (!Array.isArray(widget.tests)) {\n          throw new Error(\n            `Invalid or missing tests in mountingPointWidgets for pageVariant '${variantId}'`,\n          );\n        }\n      }\n    }\n  }\n\n  if (variantType === 'plp') {\n    if (typeof normalizedConfig.plpIdExtractor !== 'string' || !normalizedConfig.plpIdExtractor) {\n      throw new Error(`Missing or invalid plpIdExtractor for PLP pageVariant '${variantId}'`);\n    }\n  }\n\n  if (variantType === 'pdp') {\n    if (\n      typeof normalizedConfig.productIdExtractor !== 'string' ||\n      !normalizedConfig.productIdExtractor\n    ) {\n      throw new Error(`Missing or invalid productIdExtractor for PDP pageVariant '${variantId}'`);\n    }\n    if (\n      normalizedConfig.parentProductIdExtractor &&\n      typeof normalizedConfig.parentProductIdExtractor !== 'string'\n    ) {\n      throw new Error(\n        `Invalid parentProductIdExtractor for PDP pageVariant '${variantId}'. Must be string if provided`,\n      );\n    }\n  }\n\n  return normalizedConfig as PageVariantConfig;\n};\n\n// Helper function to validate and transform MountingConfigQueryData to WidgetMountingConfig\nexport const validateAndTransformMountingConfig = (\n  config: Record<string, unknown>,\n  configKey: string,\n): WidgetMountingConfig => {\n  // RENAMING LOGIC: Convert backend \"Check\" terminology to frontend \"Test\" terminology\n  const normalizedConfig = { ...config };\n\n  // Convert checkId to testId for frontend compatibility (data is already camelCase)\n  if (normalizedConfig.checkId && !normalizedConfig.testId) {\n    normalizedConfig.testId = normalizedConfig.checkId;\n    delete normalizedConfig.checkId;\n  }\n\n  // Required fields - these must be present and valid\n  if (typeof normalizedConfig.mountingConfigId !== 'string' || !normalizedConfig.mountingConfigId) {\n    throw new Error(`Missing or invalid mountingConfigId for config '${configKey}'`);\n  }\n  if (typeof normalizedConfig.containerId !== 'string' || !normalizedConfig.containerId) {\n    throw new Error(`Missing or invalid containerId for config '${configKey}'`);\n  }\n  if (typeof normalizedConfig.testId !== 'string' || !normalizedConfig.testId) {\n    throw new Error(`Missing or invalid testId for config '${configKey}'`);\n  }\n\n  // Required insertionPoint\n  if (\n    !normalizedConfig.insertionPoint ||\n    typeof normalizedConfig.insertionPoint !== 'object' ||\n    Array.isArray(normalizedConfig.insertionPoint)\n  ) {\n    throw new Error(`Missing or invalid insertionPoint for config '${configKey}'`);\n  }\n\n  const insertionPoint = normalizedConfig.insertionPoint as Record<string, unknown>;\n\n  // Validate insertionPoint required fields\n  if (typeof insertionPoint.selector !== 'string' || !insertionPoint.selector) {\n    throw new Error(`Missing or invalid insertionPoint.selector for config '${configKey}'`);\n  }\n  if (typeof insertionPoint.insertionType !== 'string' || !insertionPoint.insertionType) {\n    throw new Error(`Missing or invalid insertionPoint.insertionType for config '${configKey}'`);\n  }\n\n  // Validate insertionType is a valid DOMInsertionType\n  if (!Object.values(DOMInsertionType).includes(insertionPoint.insertionType as DOMInsertionType)) {\n    throw new Error(\n      `Invalid insertionPoint.insertionType '${insertionPoint.insertionType}' for config '${configKey}'. Valid types: ${Object.values(DOMInsertionType).join(', ')}`,\n    );\n  }\n\n  // Validate optional insertionPoint fields\n  if (insertionPoint.selectionIndex != null && typeof insertionPoint.selectionIndex !== 'number') {\n    throw new Error(\n      `Invalid insertionPoint.selectionIndex for config '${configKey}'. Must be a number or null/undefined`,\n    );\n  }\n\n  // Validate optional parentInsertionPoint if present\n  let parentInsertionPoint;\n  if (normalizedConfig.parentInsertionPoint) {\n    if (\n      typeof normalizedConfig.parentInsertionPoint !== 'object' ||\n      Array.isArray(normalizedConfig.parentInsertionPoint)\n    ) {\n      throw new Error(`Invalid parentInsertionPoint for config '${configKey}'. Must be an object`);\n    }\n\n    const parentPoint = normalizedConfig.parentInsertionPoint as Record<string, unknown>;\n    if (typeof parentPoint.selector !== 'string' || !parentPoint.selector) {\n      throw new Error(`Missing or invalid parentInsertionPoint.selector for config '${configKey}'`);\n    }\n    if (typeof parentPoint.insertionType !== 'string' || !parentPoint.insertionType) {\n      throw new Error(\n        `Missing or invalid parentInsertionPoint.insertionType for config '${configKey}'`,\n      );\n    }\n\n    if (!Object.values(DOMInsertionType).includes(parentPoint.insertionType as DOMInsertionType)) {\n      throw new Error(\n        `Invalid parentInsertionPoint.insertionType '${parentPoint.insertionType}' for config '${configKey}'. Valid types: ${Object.values(DOMInsertionType).join(', ')}`,\n      );\n    }\n\n    if (parentPoint.selectionIndex != null && typeof parentPoint.selectionIndex !== 'number') {\n      throw new Error(\n        `Invalid parentInsertionPoint.selectionIndex for config '${configKey}'. Must be a number or null/undefined`,\n      );\n    }\n\n    parentInsertionPoint = {\n      selector: parentPoint.selector,\n      insertionType: parentPoint.insertionType as DOMInsertionType,\n      selectionIndex: parentPoint.selectionIndex as number | undefined,\n    };\n  }\n\n  // Validate optional wrappingElement if present\n  let wrappingElement;\n  if (normalizedConfig.wrappingElement) {\n    if (\n      typeof normalizedConfig.wrappingElement !== 'object' ||\n      Array.isArray(normalizedConfig.wrappingElement)\n    ) {\n      throw new Error(`Invalid wrappingElement for config '${configKey}'. Must be an object`);\n    }\n\n    const wrapping = normalizedConfig.wrappingElement as Record<string, unknown>;\n    if (typeof wrapping.className !== 'string' || !wrapping.className) {\n      throw new Error(`Missing or invalid wrappingElement.className for config '${configKey}'`);\n    }\n    if (typeof wrapping.element !== 'string' || !wrapping.element) {\n      throw new Error(`Missing or invalid wrappingElement.element for config '${configKey}'`);\n    }\n    if (typeof wrapping.insertionType !== 'string' || !wrapping.insertionType) {\n      throw new Error(`Missing or invalid wrappingElement.insertionType for config '${configKey}'`);\n    }\n\n    if (!Object.values(DOMInsertionType).includes(wrapping.insertionType as DOMInsertionType)) {\n      throw new Error(\n        `Invalid wrappingElement.insertionType '${wrapping.insertionType}' for config '${configKey}'. Valid types: ${Object.values(DOMInsertionType).join(', ')}`,\n      );\n    }\n\n    wrappingElement = {\n      className: wrapping.className,\n      element: wrapping.element,\n      insertionType: wrapping.insertionType as DOMInsertionType,\n    };\n  }\n\n  // Validate optional fields\n  if (\n    normalizedConfig.divCheckSelector != null &&\n    typeof normalizedConfig.divCheckSelector !== 'string'\n  ) {\n    throw new Error(\n      `Invalid divCheckSelector for config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n  if (normalizedConfig.className != null && typeof normalizedConfig.className !== 'string') {\n    throw new Error(\n      `Invalid className for config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n  if (\n    normalizedConfig.suppressionSelector != null &&\n    typeof normalizedConfig.suppressionSelector !== 'string'\n  ) {\n    throw new Error(\n      `Invalid suppressionSelector for config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n  if (\n    normalizedConfig.dataAttributes != null &&\n    (typeof normalizedConfig.dataAttributes !== 'object' ||\n      Array.isArray(normalizedConfig.dataAttributes))\n  ) {\n    throw new Error(\n      `Invalid dataAttributes for config '${configKey}'. Must be an object or null/undefined`,\n    );\n  }\n  if (\n    normalizedConfig.style != null &&\n    (typeof normalizedConfig.style !== 'object' || Array.isArray(normalizedConfig.style))\n  ) {\n    throw new Error(`Invalid style for config '${configKey}'. Must be an object or null/undefined`);\n  }\n\n  // Validate gridInsertionType if present\n  let gridInsertionType;\n  if (normalizedConfig.gridInsertionType) {\n    if (\n      typeof normalizedConfig.gridInsertionType !== 'string' ||\n      !normalizedConfig.gridInsertionType\n    ) {\n      throw new Error(`Invalid gridInsertionType for config '${configKey}'. Must be a string`);\n    }\n\n    if (\n      !Object.values(GridInsertionType).includes(\n        normalizedConfig.gridInsertionType as GridInsertionType,\n      )\n    ) {\n      throw new Error(\n        `Invalid gridInsertionType '${normalizedConfig.gridInsertionType}' for config '${configKey}'. Valid types: ${Object.values(GridInsertionType).join(', ')}`,\n      );\n    }\n    gridInsertionType = normalizedConfig.gridInsertionType as GridInsertionType;\n  }\n\n  // Build the return object, only including optional fields if they have values\n  const result: WidgetMountingConfig = {\n    mountingConfigId: normalizedConfig.mountingConfigId,\n    containerId: normalizedConfig.containerId,\n    testId: normalizedConfig.testId,\n    insertionPoint: {\n      selector: insertionPoint.selector,\n      insertionType: insertionPoint.insertionType as DOMInsertionType,\n      ...(insertionPoint.selectionIndex != null && {\n        selectionIndex: insertionPoint.selectionIndex,\n      }),\n    },\n  };\n\n  // Only add optional fields if they have values\n  if (parentInsertionPoint) {\n    result.parentInsertionPoint = parentInsertionPoint;\n  }\n  if (gridInsertionType) {\n    result.gridInsertionType = gridInsertionType;\n  }\n  if (wrappingElement) {\n    result.wrappingElement = wrappingElement;\n  }\n  if (normalizedConfig.divCheckSelector) {\n    result.divCheckSelector = normalizedConfig.divCheckSelector as string;\n  }\n  if (normalizedConfig.className) {\n    result.className = normalizedConfig.className as string;\n  }\n  if (normalizedConfig.suppressionSelector) {\n    result.suppressionSelector = normalizedConfig.suppressionSelector;\n  }\n  if (normalizedConfig.dataAttributes) {\n    result.dataAttributes = normalizedConfig.dataAttributes as Record<string, string>;\n  }\n  if (normalizedConfig.style) {\n    result.style = normalizedConfig.style as Partial<CSSStyleDeclaration>;\n  }\n\n  return result;\n};\n\n// Helper function to validate and transform WidgetConfigQueryData to WidgetConfig\nexport const validateAndTransformWidgetConfig = (\n  config: Record<string, unknown>,\n  configKey: string,\n): WidgetConfig => {\n  const normalizedConfig = transformSnakeToCamel(config) as Record<string, unknown>;\n\n  if (typeof normalizedConfig.widgetConfigId !== 'string' || !normalizedConfig.widgetConfigId) {\n    throw new Error(`Missing or invalid widgetConfigId for widget config '${configKey}'`);\n  }\n  if (typeof normalizedConfig.type !== 'string' || !normalizedConfig.type) {\n    throw new Error(`Missing or invalid type for widget config '${configKey}'`);\n  }\n\n  if (normalizedConfig.contentId != null && typeof normalizedConfig.contentId !== 'string') {\n    throw new Error(\n      `Invalid contentId for widget config '${configKey}'. Must be a string or null/undefined`,\n    );\n  }\n\n  // Note: Widget configs are complex unions with type-specific properties.\n\n  // Return the normalized config as WidgetConfig\n  // Use intermediate 'unknown' cast for complex union types\n  return normalizedConfig as unknown as WidgetConfig;\n};\n\nexport const validateGraphQLFrontendConfig = (data: unknown): FrontendConfig | undefined => {\n  if (data === null || data === undefined) {\n    return undefined;\n  }\n\n  if (typeof data !== 'object' || Array.isArray(data)) {\n    logger.logWarn('Invalid GraphQL frontend config data: not an object', undefined, { data });\n    return undefined;\n  }\n\n  const obj = data as Record<string, unknown>;\n\n  // Validate merchant_override_css if present\n  if (\n    'merchant_override_css' in obj &&\n    typeof obj.merchant_override_css !== 'string' &&\n    obj.merchant_override_css !== null\n  ) {\n    logger.logWarn(\n      'Invalid GraphQL frontend config data: merchant_override_css must be a string or null',\n      undefined,\n      { data },\n    );\n    return undefined;\n  }\n\n  // Validate page_variants if present\n  if ('page_variants' in obj) {\n    if (\n      obj.page_variants !== undefined &&\n      obj.page_variants !== null &&\n      !Array.isArray(obj.page_variants)\n    ) {\n      logger.logWarn(\n        'Invalid GraphQL frontend config data: page_variants must be an array or null/undefined',\n        undefined,\n        { data },\n      );\n      return undefined;\n    }\n  }\n\n  // Validate mounting_configs if present\n  if ('mounting_configs' in obj) {\n    if (\n      obj.mounting_configs !== undefined &&\n      obj.mounting_configs !== null &&\n      !Array.isArray(obj.mounting_configs)\n    ) {\n      logger.logWarn(\n        'Invalid GraphQL frontend config data: mounting_configs must be an array or null/undefined',\n        undefined,\n        { data },\n      );\n      return undefined;\n    }\n  }\n\n  // Validate widget_configs if present\n  if ('widget_configs' in obj) {\n    if (\n      obj.widget_configs !== undefined &&\n      obj.widget_configs !== null &&\n      !Array.isArray(obj.widget_configs)\n    ) {\n      logger.logWarn(\n        'Invalid GraphQL frontend config data: widget_configs must be an array or null/undefined',\n        undefined,\n        { data },\n      );\n      return undefined;\n    }\n  }\n\n  // Validate ui_configs if present\n  if ('ui_configs' in obj && typeof obj.ui_configs !== 'object' && obj.ui_configs !== null) {\n    logger.logWarn(\n      'Invalid GraphQL frontend config data: ui_configs must be an object or null/undefined',\n      undefined,\n      { data },\n    );\n    return undefined;\n  }\n\n  try {\n    // Transform the data to camelCase\n    const transformedData = transformSnakeToCamel(obj) as Record<string, unknown>;\n\n    // Convert page_variants from array to validated array if present\n    if (transformedData.pageVariants && Array.isArray(transformedData.pageVariants)) {\n      const pageVariantsArray = transformedData.pageVariants;\n      const validatedPageVariants: PageVariantConfig[] = [];\n\n      for (const variant of pageVariantsArray) {\n        if (variant && typeof variant === 'object' && typeof variant.variantId === 'string') {\n          try {\n            const validatedVariant = validateAndTransformPageVariants(variant);\n            validatedPageVariants.push(validatedVariant);\n          } catch (error) {\n            logger.logWarn('Invalid page variant, skipping', error, {\n              variantId: variant.variantId,\n              variant,\n            });\n            // Continue processing other variants\n          }\n        } else {\n          logger.logWarn('Invalid page variant structure, skipping', undefined, { variant });\n        }\n      }\n\n      transformedData.pageVariants = validatedPageVariants;\n    }\n\n    // Convert mounting_configs from array to Record if present\n    if (transformedData.mountingConfigs && Array.isArray(transformedData.mountingConfigs)) {\n      const mountingConfigsArray = transformedData.mountingConfigs as Array<{\n        key: string;\n        config: unknown;\n      }>;\n      const mountingConfigsRecord: Record<string, WidgetMountingConfig> = {};\n\n      for (const item of mountingConfigsArray) {\n        if (\n          item &&\n          typeof item.key === 'string' &&\n          item.config &&\n          typeof item.config === 'object'\n        ) {\n          try {\n            // Validate and transform the config structure\n            const config = item.config as Record<string, unknown>;\n            const validatedConfig = validateAndTransformMountingConfig(config, item.key);\n            mountingConfigsRecord[item.key] = validatedConfig;\n          } catch (error) {\n            logger.logWarn('Invalid mounting config, skipping', error, {\n              configKey: item.key,\n              config: item.config,\n            });\n            // Continue processing other configs\n          }\n        } else {\n          logger.logWarn('Invalid mounting config item structure, skipping', undefined, { item });\n        }\n      }\n\n      transformedData.mountingConfigs = mountingConfigsRecord;\n    }\n\n    // Convert widget_configs from array to Record if present\n    if (transformedData.widgetConfigs && Array.isArray(transformedData.widgetConfigs)) {\n      const widgetConfigsArray = transformedData.widgetConfigs as Array<{\n        key: string;\n        config: unknown;\n      }>;\n      const widgetConfigsRecord: Record<string, unknown> = {};\n\n      for (const item of widgetConfigsArray) {\n        if (\n          item &&\n          typeof item.key === 'string' &&\n          item.config &&\n          typeof item.config === 'object'\n        ) {\n          try {\n            // Validate and transform widget config using the dedicated validation function\n            const config = item.config as Record<string, unknown>;\n            const validatedConfig = validateAndTransformWidgetConfig(config, item.key);\n            widgetConfigsRecord[item.key] = validatedConfig;\n          } catch (error) {\n            logger.logWarn('Invalid widget config, skipping', error, {\n              configKey: item.key,\n              config: item.config,\n            });\n            // Continue processing other configs\n          }\n        } else {\n          logger.logWarn('Invalid widget config item structure, skipping', undefined, { item });\n        }\n      }\n\n      transformedData.widgetConfigs = widgetConfigsRecord;\n    }\n\n    return transformedData as FrontendConfig;\n  } catch (error) {\n    logger.logWarn('Failed to validate and transform GraphQL frontend config data', error, {\n      data,\n    });\n    return undefined;\n  }\n};\n"],"mappings":"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"}