@envive-ai/react-hooks 0.2.9 → 0.2.10-arthur-1

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 (123) hide show
  1. package/dist/{NewOrgConfig-BPnlb15T.cjs → NewOrgConfig-5ExpEMAj.cjs} +2 -2
  2. package/dist/{NewOrgConfig-D80VRZ38.js → NewOrgConfig-Dq_nxjNv.js} +2 -2
  3. package/dist/{SystemSettingsContext-ChQgRVnq.js → SystemSettingsContext-BY1BFgAQ.js} +2 -2
  4. package/dist/{SystemSettingsContext-DLrUiwz2.cjs → SystemSettingsContext-EDpRMMt2.cjs} +2 -2
  5. package/dist/application/utils/index.d.ts +2 -2
  6. package/dist/atoms/app/index.d.cts +6 -6
  7. package/dist/atoms/app/index.d.ts +7 -7
  8. package/dist/atoms/chat/index.cjs +3 -3
  9. package/dist/atoms/chat/index.d.cts +27 -27
  10. package/dist/atoms/chat/index.d.ts +27 -27
  11. package/dist/atoms/chat/index.js +3 -3
  12. package/dist/atoms/globalSearch/index.cjs +1 -1
  13. package/dist/atoms/globalSearch/index.d.cts +5 -5
  14. package/dist/atoms/globalSearch/index.d.ts +6 -6
  15. package/dist/atoms/globalSearch/index.js +1 -1
  16. package/dist/atoms/org/index.cjs +3 -3
  17. package/dist/atoms/org/index.d.cts +17 -17
  18. package/dist/atoms/org/index.js +3 -3
  19. package/dist/atoms/search/index.cjs +10 -10
  20. package/dist/atoms/search/index.d.cts +1 -1
  21. package/dist/atoms/search/index.d.ts +1 -1
  22. package/dist/atoms/search/index.js +10 -10
  23. package/dist/atoms/search/types.cjs +1 -1
  24. package/dist/atoms/search/types.js +1 -1
  25. package/dist/atoms/search/utils.cjs +1 -1
  26. package/dist/atoms/search/utils.js +1 -1
  27. package/dist/{cdnContext-CtrIlAqX.js → cdnContext-B8zWuGGT.js} +1 -1
  28. package/dist/{cdnContext-CaDyQ_5p.cjs → cdnContext-DzifgoNo.cjs} +1 -1
  29. package/dist/{chat-BTfQhuk5.js → chat-DfL00obw.js} +3 -3
  30. package/dist/{chat-B1B05BM-.cjs → chat-zX9xdvd8.cjs} +3 -3
  31. package/dist/{chatSearch-BGWkK5FD.js → chatSearch-BWrMo8_Q.js} +7 -6
  32. package/dist/{chatSearch-BWXonqb0.cjs → chatSearch-CtOVPeYw.cjs} +7 -6
  33. package/dist/{chatState-C1ksoACz.cjs → chatState-BFHlHqzs.cjs} +1 -1
  34. package/dist/{chatState-5iiJOrvd.js → chatState-DtwyMZOg.js} +1 -1
  35. package/dist/{commerce-api-DA5_5J9U.js → commerce-api-4ZnHoGQA.js} +3 -3
  36. package/dist/{commerce-api-DUmK4auK.cjs → commerce-api-V1XAx9KE.cjs} +3 -3
  37. package/dist/contexts/amplitudeContext/index.cjs +1 -1
  38. package/dist/contexts/amplitudeContext/index.js +1 -1
  39. package/dist/contexts/cdnContext/index.cjs +1 -1
  40. package/dist/contexts/cdnContext/index.js +1 -1
  41. package/dist/contexts/chatContext/index.cjs +13 -13
  42. package/dist/contexts/chatContext/index.d.ts +2 -2
  43. package/dist/contexts/chatContext/index.js +13 -13
  44. package/dist/contexts/enviveCssContext/index.cjs +3 -3
  45. package/dist/contexts/enviveCssContext/index.js +3 -3
  46. package/dist/contexts/graphqlContext/index.d.cts +1 -1
  47. package/dist/contexts/newOrgConfigContext/index.cjs +2 -2
  48. package/dist/contexts/newOrgConfigContext/index.d.cts +2 -2
  49. package/dist/contexts/newOrgConfigContext/index.js +2 -2
  50. package/dist/contexts/searchContext/index.cjs +3 -3
  51. package/dist/contexts/searchContext/index.js +3 -3
  52. package/dist/contexts/systemSettingsContext/index.cjs +1 -1
  53. package/dist/contexts/systemSettingsContext/index.d.cts +2 -2
  54. package/dist/contexts/systemSettingsContext/index.d.ts +2 -2
  55. package/dist/contexts/systemSettingsContext/index.js +1 -1
  56. package/dist/contexts/userIdentityContext/index.cjs +4 -4
  57. package/dist/contexts/userIdentityContext/index.js +4 -4
  58. package/dist/frontendConfig-DPpzM5cz.d.cts +1 -1
  59. package/dist/frontendConfig-msK69LYN.d.ts +1 -1
  60. package/dist/{globalSearch-CuyNpefG.js → globalSearch-Ccxq8hNF.js} +1 -1
  61. package/dist/{globalSearch-D7K4TS83.cjs → globalSearch-FBk2epe8.cjs} +1 -1
  62. package/dist/{graphqlConfig-BnfE0ql5.cjs → graphqlConfig-9S6WH9iP.cjs} +1 -1
  63. package/dist/{graphqlConfig-CZGjJ8hP.js → graphqlConfig-BJYgS8H5.js} +1 -1
  64. package/dist/{graphqlContext-Y9q6GK71.d.cts → graphqlContext-1BkFjchL.d.cts} +3 -3
  65. package/dist/hooks/AmplitudeOperations/index.cjs +1 -1
  66. package/dist/hooks/AmplitudeOperations/index.js +1 -1
  67. package/dist/hooks/CdnOperations/index.cjs +1 -1
  68. package/dist/hooks/CdnOperations/index.js +1 -1
  69. package/dist/hooks/ChatToggle/index.cjs +3 -3
  70. package/dist/hooks/ChatToggle/index.js +3 -3
  71. package/dist/hooks/ChatToggleAnalytics/index.cjs +2 -2
  72. package/dist/hooks/ChatToggleAnalytics/index.js +2 -2
  73. package/dist/hooks/GraphQLConfig/index.d.cts +1 -1
  74. package/dist/hooks/IdentifyUser/index.cjs +4 -4
  75. package/dist/hooks/IdentifyUser/index.js +4 -4
  76. package/dist/hooks/NewOrgConfig/index.cjs +3 -3
  77. package/dist/hooks/NewOrgConfig/index.d.cts +2 -2
  78. package/dist/hooks/NewOrgConfig/index.js +3 -3
  79. package/dist/hooks/Search/index.cjs +16 -15
  80. package/dist/hooks/Search/index.d.cts +1 -1
  81. package/dist/hooks/Search/index.d.ts +1 -1
  82. package/dist/hooks/Search/index.js +16 -15
  83. package/dist/hooks/SearchOperations/index.cjs +3 -3
  84. package/dist/hooks/SearchOperations/index.js +3 -3
  85. package/dist/hooks/SystemSettingsContext/index.cjs +2 -2
  86. package/dist/hooks/SystemSettingsContext/index.d.ts +2 -2
  87. package/dist/hooks/SystemSettingsContext/index.js +2 -2
  88. package/dist/{index-B0elglKV.d.cts → index-C1uCtGnL.d.cts} +30 -30
  89. package/dist/{index-DvUvoVHb.d.ts → index-CeeyLImD.d.ts} +30 -30
  90. package/dist/{newOrgConfigAtom-DkZVcH1n.cjs → newOrgConfigAtom-B_Lg4Rla.cjs} +1 -1
  91. package/dist/{newOrgConfigAtom-TCV1_sTk.js → newOrgConfigAtom-HLwFoYIi.js} +1 -1
  92. package/dist/{newOrgConfigContext-f3ZD_laY.cjs → newOrgConfigContext-CX1KHzju.cjs} +2 -2
  93. package/dist/{newOrgConfigContext-XmEpnUcU.js → newOrgConfigContext-CgjVZuQi.js} +2 -2
  94. package/dist/{newOrgConfigContext-DhsBBjlG.d.cts → newOrgConfigContext-Deofb8_o.d.cts} +2 -2
  95. package/dist/{org-D7JD-Jhj.js → org-CRNH9BHE.js} +1 -1
  96. package/dist/{org-B_56cFG-.cjs → org-Di4wNmJY.cjs} +1 -1
  97. package/dist/search-Bamw5aOc.js +127 -0
  98. package/dist/search-DFIGjP1v.cjs +206 -0
  99. package/dist/{searchContext-B5ea-PzV.cjs → searchContext-Cq6I8Jbr.cjs} +3 -3
  100. package/dist/{searchContext-i5I9qGDl.js → searchContext-LbD2SkWw.js} +3 -3
  101. package/dist/{searchServiceAdapter-BGlvoZFE.cjs → searchServiceAdapter-B3KCzkDl.cjs} +1 -1
  102. package/dist/{searchServiceAdapter-Db6jEcJs.js → searchServiceAdapter-DQorsH-V.js} +1 -1
  103. package/dist/{systemSettingsContext-B4kZOE-R.js → systemSettingsContext-DF0jSq9m.js} +1 -1
  104. package/dist/{systemSettingsContext-jFIz9KS4.cjs → systemSettingsContext-dmE1v6w8.cjs} +1 -1
  105. package/dist/{types-BuvXXGxE.cjs → types-C4uWPJYq.cjs} +1 -1
  106. package/dist/{types-DXnG1tV0.js → types-CaytKP8k.js} +1 -1
  107. package/dist/{unsupportedProductExceptions-B4f9aLjr.cjs → unsupportedProductExceptions-DGENUnEA.cjs} +1 -1
  108. package/dist/{unsupportedProductExceptions-DlmraJm8.js → unsupportedProductExceptions-uQuuelOs.js} +1 -1
  109. package/dist/{useAmplitudeOperations-DufyKAt6.js → useAmplitudeOperations-C12VMX2E.js} +1 -1
  110. package/dist/{useAmplitudeOperations-CnN2-inX.cjs → useAmplitudeOperations-DTQ2I2GN.cjs} +1 -1
  111. package/dist/{userIdentityContext-Djf2FPEf.js → userIdentityContext-8FB3OlQU.js} +2 -2
  112. package/dist/{userIdentityContext-Dxm2Lnyi.cjs → userIdentityContext-Ds1Vtcdr.cjs} +2 -2
  113. package/dist/utils-C2HshI4X.d.cts +1 -1
  114. package/dist/{utils-CvLmSsUj.cjs → utils-Cnpp2Lur.cjs} +1 -1
  115. package/dist/{utils-D82gfbgU.js → utils-CpzV-LYG.js} +1 -1
  116. package/package.json +1 -1
  117. package/src/atoms/search/chatSearch.ts +1 -0
  118. package/src/atoms/search/searchAPI.ts +1 -0
  119. package/src/hooks/Search/useSearch.tsx +1 -0
  120. package/dist/search-3Q6-C6L4.cjs +0 -205
  121. package/dist/search-B24LICty.js +0 -126
  122. /package/dist/{amplitudeContext-BJHyYQ5s.cjs → amplitudeContext-BX76wdSS.cjs} +0 -0
  123. /package/dist/{amplitudeContext-DffV4DW_.js → amplitudeContext-Yff2qNrs.js} +0 -0
@@ -0,0 +1,127 @@
1
+ import { newOrgConfigAtom } from "./newOrgConfigAtom-HLwFoYIi.js";
2
+ import { ProductFilters, ProductSorter } from "./chatSearch-BWrMo8_Q.js";
3
+ import { ProductSorting } from "./types-CaytKP8k.js";
4
+ import { getSearchServiceFunction } from "./searchServiceAdapter-DQorsH-V.js";
5
+ import { atom } from "jotai";
6
+
7
+ //#region src/atoms/search/searchAPI.ts
8
+ const searchAtom = atom({
9
+ data: null,
10
+ loading: false,
11
+ error: null,
12
+ lastQuery: null
13
+ });
14
+ const searchProductSortingAtom = atom(ProductSorting.FEATURED);
15
+ const searchSelectedFiltersAtom = atom([]);
16
+ const createFilterOption = (filterId, filterItemId, displayName) => ({
17
+ id: `${filterId}:${filterItemId}`,
18
+ displayName,
19
+ filterId,
20
+ filterItemId
21
+ });
22
+ const internalSearchParamsAtom = atom({
23
+ id: null,
24
+ query: null
25
+ });
26
+ const searchParamsAtom = atom((get) => get(internalSearchParamsAtom), (_, set, value) => {
27
+ set(internalSearchParamsAtom, value);
28
+ });
29
+ const internalSearchSystemStateAtom = atom(false);
30
+ const searchSystemAtom = atom((get) => get(internalSearchSystemStateAtom), (get, set, value) => {
31
+ if (value === get(internalSearchSystemStateAtom)) return;
32
+ const stateChangeHandler = () => {
33
+ const params = new URLSearchParams(window.location.search);
34
+ console.log("SEARCH_DEBUG - stateChangeHandler", value, params.get("es"), params.get("esq"), window.location.search);
35
+ if (params.get("es") === "true") {
36
+ const id = params.get("esi");
37
+ const query = params.get("esq");
38
+ set(searchParamsAtom, {
39
+ id,
40
+ query
41
+ });
42
+ } else set(searchParamsAtom, {
43
+ id: null,
44
+ query: null
45
+ });
46
+ };
47
+ if (value) {
48
+ set(internalSearchSystemStateAtom, true);
49
+ window.addEventListener("popstate", stateChangeHandler);
50
+ stateChangeHandler();
51
+ } else {
52
+ set(internalSearchSystemStateAtom, false);
53
+ window.removeEventListener("popstate", stateChangeHandler);
54
+ }
55
+ });
56
+ const filteredSearchProductsAtom = atom((get) => {
57
+ const searchData = get(searchAtom).data;
58
+ const sorting = get(searchProductSortingAtom);
59
+ const selectedFilters = get(searchSelectedFiltersAtom);
60
+ const newOrgConfig = get(newOrgConfigAtom);
61
+ if (!searchData?.products || !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig) return [];
62
+ const filteredProducts = ProductFilters.filterProducts(searchData.products, newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig, selectedFilters, newOrgConfig.frontendConfig.uiConfigs.searchConfig.additiveDynamicFilters);
63
+ return ProductSorter.sort(filteredProducts, sorting);
64
+ });
65
+ const searchFiltersAtom = atom((get) => {
66
+ const searchData = get(searchAtom).data;
67
+ const selectedFilters = get(searchSelectedFiltersAtom);
68
+ const newOrgConfig = get(newOrgConfigAtom);
69
+ if (!searchData?.products || !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig) return [];
70
+ return ProductFilters.getFiltersForProducts(searchData.products, newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig, selectedFilters);
71
+ });
72
+ const addSearchFilterAtom = atom(null, (get, set, filter) => {
73
+ const current = get(searchSelectedFiltersAtom);
74
+ if (!current.some((f) => f.id === filter.id)) set(searchSelectedFiltersAtom, [...current, filter]);
75
+ });
76
+ const removeSearchFilterAtom = atom(null, (get, set, filterId) => {
77
+ const current = get(searchSelectedFiltersAtom);
78
+ set(searchSelectedFiltersAtom, current.filter((f) => f.id !== filterId));
79
+ });
80
+ const clearSearchFiltersAtom = atom(null, (_, set) => {
81
+ set(searchSelectedFiltersAtom, []);
82
+ });
83
+ const performSearchAtom = atom(null, async (get, set, params, allowRedirect = false) => {
84
+ const currentState = get(searchAtom);
85
+ const redirectSearchResultsUrl = get(newOrgConfigAtom)?.frontendConfig?.uiConfigs?.searchConfig?.redirectSearchResultsUrl;
86
+ if (allowRedirect && redirectSearchResultsUrl) {
87
+ const redirectUrl = new URL(redirectSearchResultsUrl);
88
+ redirectUrl.searchParams.set("es", "true");
89
+ redirectUrl.searchParams.set("esq", params.query);
90
+ window.location.href = redirectUrl.toString();
91
+ } else {
92
+ const url = new URL(window.location.href);
93
+ url.searchParams.set("es", "true");
94
+ url.searchParams.set("esq", params.query);
95
+ window.history.pushState({}, "", url);
96
+ window.dispatchEvent(new PopStateEvent("popstate", { state: {} }));
97
+ }
98
+ window.dispatchEvent(new PopStateEvent("popstate", { state: {} }));
99
+ if (currentState.loading) return;
100
+ set(searchAtom, {
101
+ data: null,
102
+ loading: true,
103
+ error: null,
104
+ lastQuery: params.query
105
+ });
106
+ try {
107
+ const result = await getSearchServiceFunction()(params);
108
+ set(searchAtom, {
109
+ data: result,
110
+ loading: false,
111
+ error: null,
112
+ lastQuery: params.query
113
+ });
114
+ } catch (error) {
115
+ const errorMessage = error instanceof Error ? error.message : "An unknown error occurred";
116
+ set(searchAtom, {
117
+ data: null,
118
+ loading: false,
119
+ error: errorMessage,
120
+ lastQuery: params.query
121
+ });
122
+ }
123
+ });
124
+
125
+ //#endregion
126
+ export { addSearchFilterAtom, clearSearchFiltersAtom, createFilterOption, filteredSearchProductsAtom, internalSearchSystemStateAtom, performSearchAtom, removeSearchFilterAtom, searchAtom, searchFiltersAtom, searchParamsAtom, searchProductSortingAtom, searchSelectedFiltersAtom, searchSystemAtom };
127
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"search-Bamw5aOc.js","names":["error: unknown"],"sources":["../src/atoms/search/searchAPI.ts"],"sourcesContent":["import { atom } from \"jotai\";\nimport { SearchResult, SearchParams } from \"src/application/models/api/search\";\nimport { ProductSorting } from \"./types\";\nimport { ProductFilters } from \"./productFilters\";\nimport { ProductSorter } from \"./productSorter\";\nimport { newOrgConfigAtom } from \"../org\";\nimport { getSearchServiceFunction } from \"./searchServiceAdapter\";\n\nexport type SelectedFilterOption = {\n  id: string; // \"filterId:filterItemId\" - maintains backward compatibility for comparisons\n  displayName: string;\n  filterId: string; // Filter category\n  filterItemId: string; // Filter value\n};\n\ninterface SearchState {\n  data: SearchResult | null;\n  loading: boolean;\n  error: string | null;\n  lastQuery: string | null;\n}\n\nexport const searchAtom = atom<SearchState>({\n  data: null,\n  loading: false,\n  error: null,\n  lastQuery: null,\n});\n\nexport const searchProductSortingAtom = atom<ProductSorting>(\n  ProductSorting.FEATURED\n);\nexport const searchSelectedFiltersAtom = atom<SelectedFilterOption[]>([]);\n\nexport const createFilterOption = (\n  filterId: string,\n  filterItemId: string,\n  displayName: string\n): SelectedFilterOption => ({\n  id: `${filterId}:${filterItemId}`,\n  displayName,\n  filterId,\n  filterItemId,\n});\n\nconst internalSearchParamsAtom = atom<{\n  id: string | null;\n  query: string | null;\n}>({\n  id: null,\n  query: null,\n});\n\nexport const searchParamsAtom = atom(\n  (get) => get(internalSearchParamsAtom),\n  (_, set, value: { id: string | null; query: string | null }) => {\n    set(internalSearchParamsAtom, value);\n  }\n);\nexport const internalSearchSystemStateAtom = atom<boolean>(false);\n\nexport const searchSystemAtom = atom(\n  (get) => get(internalSearchSystemStateAtom),\n  (get, set, value: boolean) => {\n    if (value === get(internalSearchSystemStateAtom)) {\n      return;\n    }\n    const stateChangeHandler = () => {\n      const params = new URLSearchParams(window.location.search);\n      console.log(\"SEARCH_DEBUG - stateChangeHandler\", value, params.get(\"es\"), params.get(\"esq\"), window.location.search);\n      if (params.get(\"es\") === \"true\") {\n        const id = params.get(\"esi\");\n        const query = params.get(\"esq\");\n        set(searchParamsAtom, { id, query });\n      } else {\n        set(searchParamsAtom, { id: null, query: null });\n      }\n    };\n    if (value) {\n      set(internalSearchSystemStateAtom, true);\n      window.addEventListener(\"popstate\", stateChangeHandler);\n      // Also trigger the hash change handler to set the initial state\n      stateChangeHandler();\n    } else {\n      set(internalSearchSystemStateAtom, false);\n      window.removeEventListener(\"popstate\", stateChangeHandler);\n    }\n  }\n);\n\nexport const filteredSearchProductsAtom = atom((get) => {\n  const searchData = get(searchAtom).data;\n  const sorting = get(searchProductSortingAtom);\n  const selectedFilters = get(searchSelectedFiltersAtom);\n  const newOrgConfig = get(newOrgConfigAtom);\n\n  if (\n    !searchData?.products ||\n    !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig\n  )\n    return [];\n\n  const filteredProducts = ProductFilters.filterProducts(\n    searchData.products,\n    newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig,\n    selectedFilters,\n    newOrgConfig.frontendConfig.uiConfigs.searchConfig.additiveDynamicFilters\n  );\n\n  return ProductSorter.sort(filteredProducts, sorting);\n});\n\nexport const searchFiltersAtom = atom((get) => {\n  const searchData = get(searchAtom).data;\n  const selectedFilters = get(searchSelectedFiltersAtom);\n  const newOrgConfig = get(newOrgConfigAtom);\n\n  if (\n    !searchData?.products ||\n    !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig\n  )\n    return [];\n\n  return ProductFilters.getFiltersForProducts(\n    searchData.products,\n    newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig,\n    selectedFilters\n  );\n});\n\nexport const addSearchFilterAtom = atom(\n  null,\n  (get, set, filter: SelectedFilterOption) => {\n    const current = get(searchSelectedFiltersAtom);\n    if (!current.some((f) => f.id === filter.id)) {\n      set(searchSelectedFiltersAtom, [...current, filter]);\n    }\n  }\n);\n\nexport const removeSearchFilterAtom = atom(\n  null,\n  (get, set, filterId: string) => {\n    const current = get(searchSelectedFiltersAtom);\n    set(\n      searchSelectedFiltersAtom,\n      current.filter((f) => f.id !== filterId)\n    );\n  }\n);\n\nexport const clearSearchFiltersAtom = atom(null, (_, set) => {\n  set(searchSelectedFiltersAtom, []);\n});\n\nexport const performSearchAtom = atom(\n  null,\n  async (get, set, params: SearchParams, allowRedirect = false) => {\n    const currentState = get(searchAtom);\n    const newOrgConfig = get(newOrgConfigAtom);\n    const redirectSearchResultsUrl =\n      newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig\n        ?.redirectSearchResultsUrl;\n\n    if (allowRedirect && redirectSearchResultsUrl) {\n      const redirectUrl = new URL(redirectSearchResultsUrl);\n      redirectUrl.searchParams.set(\"es\", \"true\");\n      redirectUrl.searchParams.set(\"esq\", params.query);\n      window.location.href = redirectUrl.toString();\n    } else {\n      // Update URL and manually trigger state change (since pushState doesn't trigger popstate)\n      const url = new URL(window.location.href);\n      url.searchParams.set(\"es\", \"true\");\n      url.searchParams.set(\"esq\", params.query);\n      window.history.pushState({}, \"\", url);\n\n      // Manually trigger page variant re-evaluation by dispatching a popstate event\n      // This ensures the page variant system detects the URL change and mounts search results\n      window.dispatchEvent(new PopStateEvent(\"popstate\", { state: {} }));\n    }\n\n    // Manually trigger page variant re-evaluation by dispatching a popstate event\n    // This ensures the page variant system detects the URL change and mounts search results\n    window.dispatchEvent(new PopStateEvent(\"popstate\", { state: {} }));\n    if (currentState.loading) {\n      return; // Prevent concurrent searches\n    }\n\n    set(searchAtom, {\n      data: null,\n      loading: true,\n      error: null,\n      lastQuery: params.query,\n    });\n    try {\n      const searchServiceFunction = getSearchServiceFunction();\n      const result = await searchServiceFunction(params);\n      set(searchAtom, {\n        data: result,\n        loading: false,\n        error: null,\n        lastQuery: params.query,\n      });\n    } catch (error: unknown) {\n      const errorMessage =\n        error instanceof Error ? error.message : \"An unknown error occurred\";\n      set(searchAtom, {\n        data: null,\n        loading: false,\n        error: errorMessage,\n        lastQuery: params.query,\n      });\n    }\n  }\n);\n"],"mappings":"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"}
@@ -0,0 +1,206 @@
1
+ const require_chunk = require('./chunk-CUT6urMc.cjs');
2
+ const require_newOrgConfigAtom = require('./newOrgConfigAtom-B_Lg4Rla.cjs');
3
+ const require_chatSearch = require('./chatSearch-CtOVPeYw.cjs');
4
+ const require_types = require('./types-C4uWPJYq.cjs');
5
+ const require_searchServiceAdapter = require('./searchServiceAdapter-B3KCzkDl.cjs');
6
+ let jotai = require("jotai");
7
+ jotai = require_chunk.__toESM(jotai);
8
+
9
+ //#region src/atoms/search/searchAPI.ts
10
+ const searchAtom = (0, jotai.atom)({
11
+ data: null,
12
+ loading: false,
13
+ error: null,
14
+ lastQuery: null
15
+ });
16
+ const searchProductSortingAtom = (0, jotai.atom)(require_types.ProductSorting.FEATURED);
17
+ const searchSelectedFiltersAtom = (0, jotai.atom)([]);
18
+ const createFilterOption = (filterId, filterItemId, displayName) => ({
19
+ id: `${filterId}:${filterItemId}`,
20
+ displayName,
21
+ filterId,
22
+ filterItemId
23
+ });
24
+ const internalSearchParamsAtom = (0, jotai.atom)({
25
+ id: null,
26
+ query: null
27
+ });
28
+ const searchParamsAtom = (0, jotai.atom)((get) => get(internalSearchParamsAtom), (_, set, value) => {
29
+ set(internalSearchParamsAtom, value);
30
+ });
31
+ const internalSearchSystemStateAtom = (0, jotai.atom)(false);
32
+ const searchSystemAtom = (0, jotai.atom)((get) => get(internalSearchSystemStateAtom), (get, set, value) => {
33
+ if (value === get(internalSearchSystemStateAtom)) return;
34
+ const stateChangeHandler = () => {
35
+ const params = new URLSearchParams(window.location.search);
36
+ console.log("SEARCH_DEBUG - stateChangeHandler", value, params.get("es"), params.get("esq"), window.location.search);
37
+ if (params.get("es") === "true") {
38
+ const id = params.get("esi");
39
+ const query = params.get("esq");
40
+ set(searchParamsAtom, {
41
+ id,
42
+ query
43
+ });
44
+ } else set(searchParamsAtom, {
45
+ id: null,
46
+ query: null
47
+ });
48
+ };
49
+ if (value) {
50
+ set(internalSearchSystemStateAtom, true);
51
+ window.addEventListener("popstate", stateChangeHandler);
52
+ stateChangeHandler();
53
+ } else {
54
+ set(internalSearchSystemStateAtom, false);
55
+ window.removeEventListener("popstate", stateChangeHandler);
56
+ }
57
+ });
58
+ const filteredSearchProductsAtom = (0, jotai.atom)((get) => {
59
+ const searchData = get(searchAtom).data;
60
+ const sorting = get(searchProductSortingAtom);
61
+ const selectedFilters = get(searchSelectedFiltersAtom);
62
+ const newOrgConfig = get(require_newOrgConfigAtom.newOrgConfigAtom);
63
+ if (!searchData?.products || !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig) return [];
64
+ const filteredProducts = require_chatSearch.ProductFilters.filterProducts(searchData.products, newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig, selectedFilters, newOrgConfig.frontendConfig.uiConfigs.searchConfig.additiveDynamicFilters);
65
+ return require_chatSearch.ProductSorter.sort(filteredProducts, sorting);
66
+ });
67
+ const searchFiltersAtom = (0, jotai.atom)((get) => {
68
+ const searchData = get(searchAtom).data;
69
+ const selectedFilters = get(searchSelectedFiltersAtom);
70
+ const newOrgConfig = get(require_newOrgConfigAtom.newOrgConfigAtom);
71
+ if (!searchData?.products || !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig) return [];
72
+ return require_chatSearch.ProductFilters.getFiltersForProducts(searchData.products, newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig, selectedFilters);
73
+ });
74
+ const addSearchFilterAtom = (0, jotai.atom)(null, (get, set, filter) => {
75
+ const current = get(searchSelectedFiltersAtom);
76
+ if (!current.some((f) => f.id === filter.id)) set(searchSelectedFiltersAtom, [...current, filter]);
77
+ });
78
+ const removeSearchFilterAtom = (0, jotai.atom)(null, (get, set, filterId) => {
79
+ const current = get(searchSelectedFiltersAtom);
80
+ set(searchSelectedFiltersAtom, current.filter((f) => f.id !== filterId));
81
+ });
82
+ const clearSearchFiltersAtom = (0, jotai.atom)(null, (_, set) => {
83
+ set(searchSelectedFiltersAtom, []);
84
+ });
85
+ const performSearchAtom = (0, jotai.atom)(null, async (get, set, params, allowRedirect = false) => {
86
+ const currentState = get(searchAtom);
87
+ const redirectSearchResultsUrl = get(require_newOrgConfigAtom.newOrgConfigAtom)?.frontendConfig?.uiConfigs?.searchConfig?.redirectSearchResultsUrl;
88
+ if (allowRedirect && redirectSearchResultsUrl) {
89
+ const redirectUrl = new URL(redirectSearchResultsUrl);
90
+ redirectUrl.searchParams.set("es", "true");
91
+ redirectUrl.searchParams.set("esq", params.query);
92
+ window.location.href = redirectUrl.toString();
93
+ } else {
94
+ const url = new URL(window.location.href);
95
+ url.searchParams.set("es", "true");
96
+ url.searchParams.set("esq", params.query);
97
+ window.history.pushState({}, "", url);
98
+ window.dispatchEvent(new PopStateEvent("popstate", { state: {} }));
99
+ }
100
+ window.dispatchEvent(new PopStateEvent("popstate", { state: {} }));
101
+ if (currentState.loading) return;
102
+ set(searchAtom, {
103
+ data: null,
104
+ loading: true,
105
+ error: null,
106
+ lastQuery: params.query
107
+ });
108
+ try {
109
+ const result = await require_searchServiceAdapter.getSearchServiceFunction()(params);
110
+ set(searchAtom, {
111
+ data: result,
112
+ loading: false,
113
+ error: null,
114
+ lastQuery: params.query
115
+ });
116
+ } catch (error) {
117
+ const errorMessage = error instanceof Error ? error.message : "An unknown error occurred";
118
+ set(searchAtom, {
119
+ data: null,
120
+ loading: false,
121
+ error: errorMessage,
122
+ lastQuery: params.query
123
+ });
124
+ }
125
+ });
126
+
127
+ //#endregion
128
+ Object.defineProperty(exports, 'addSearchFilterAtom', {
129
+ enumerable: true,
130
+ get: function () {
131
+ return addSearchFilterAtom;
132
+ }
133
+ });
134
+ Object.defineProperty(exports, 'clearSearchFiltersAtom', {
135
+ enumerable: true,
136
+ get: function () {
137
+ return clearSearchFiltersAtom;
138
+ }
139
+ });
140
+ Object.defineProperty(exports, 'createFilterOption', {
141
+ enumerable: true,
142
+ get: function () {
143
+ return createFilterOption;
144
+ }
145
+ });
146
+ Object.defineProperty(exports, 'filteredSearchProductsAtom', {
147
+ enumerable: true,
148
+ get: function () {
149
+ return filteredSearchProductsAtom;
150
+ }
151
+ });
152
+ Object.defineProperty(exports, 'internalSearchSystemStateAtom', {
153
+ enumerable: true,
154
+ get: function () {
155
+ return internalSearchSystemStateAtom;
156
+ }
157
+ });
158
+ Object.defineProperty(exports, 'performSearchAtom', {
159
+ enumerable: true,
160
+ get: function () {
161
+ return performSearchAtom;
162
+ }
163
+ });
164
+ Object.defineProperty(exports, 'removeSearchFilterAtom', {
165
+ enumerable: true,
166
+ get: function () {
167
+ return removeSearchFilterAtom;
168
+ }
169
+ });
170
+ Object.defineProperty(exports, 'searchAtom', {
171
+ enumerable: true,
172
+ get: function () {
173
+ return searchAtom;
174
+ }
175
+ });
176
+ Object.defineProperty(exports, 'searchFiltersAtom', {
177
+ enumerable: true,
178
+ get: function () {
179
+ return searchFiltersAtom;
180
+ }
181
+ });
182
+ Object.defineProperty(exports, 'searchParamsAtom', {
183
+ enumerable: true,
184
+ get: function () {
185
+ return searchParamsAtom;
186
+ }
187
+ });
188
+ Object.defineProperty(exports, 'searchProductSortingAtom', {
189
+ enumerable: true,
190
+ get: function () {
191
+ return searchProductSortingAtom;
192
+ }
193
+ });
194
+ Object.defineProperty(exports, 'searchSelectedFiltersAtom', {
195
+ enumerable: true,
196
+ get: function () {
197
+ return searchSelectedFiltersAtom;
198
+ }
199
+ });
200
+ Object.defineProperty(exports, 'searchSystemAtom', {
201
+ enumerable: true,
202
+ get: function () {
203
+ return searchSystemAtom;
204
+ }
205
+ });
206
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"search-DFIGjP1v.cjs","names":["ProductSorting","newOrgConfigAtom","ProductFilters","ProductSorter","getSearchServiceFunction","error: unknown"],"sources":["../src/atoms/search/searchAPI.ts"],"sourcesContent":["import { atom } from \"jotai\";\nimport { SearchResult, SearchParams } from \"src/application/models/api/search\";\nimport { ProductSorting } from \"./types\";\nimport { ProductFilters } from \"./productFilters\";\nimport { ProductSorter } from \"./productSorter\";\nimport { newOrgConfigAtom } from \"../org\";\nimport { getSearchServiceFunction } from \"./searchServiceAdapter\";\n\nexport type SelectedFilterOption = {\n  id: string; // \"filterId:filterItemId\" - maintains backward compatibility for comparisons\n  displayName: string;\n  filterId: string; // Filter category\n  filterItemId: string; // Filter value\n};\n\ninterface SearchState {\n  data: SearchResult | null;\n  loading: boolean;\n  error: string | null;\n  lastQuery: string | null;\n}\n\nexport const searchAtom = atom<SearchState>({\n  data: null,\n  loading: false,\n  error: null,\n  lastQuery: null,\n});\n\nexport const searchProductSortingAtom = atom<ProductSorting>(\n  ProductSorting.FEATURED\n);\nexport const searchSelectedFiltersAtom = atom<SelectedFilterOption[]>([]);\n\nexport const createFilterOption = (\n  filterId: string,\n  filterItemId: string,\n  displayName: string\n): SelectedFilterOption => ({\n  id: `${filterId}:${filterItemId}`,\n  displayName,\n  filterId,\n  filterItemId,\n});\n\nconst internalSearchParamsAtom = atom<{\n  id: string | null;\n  query: string | null;\n}>({\n  id: null,\n  query: null,\n});\n\nexport const searchParamsAtom = atom(\n  (get) => get(internalSearchParamsAtom),\n  (_, set, value: { id: string | null; query: string | null }) => {\n    set(internalSearchParamsAtom, value);\n  }\n);\nexport const internalSearchSystemStateAtom = atom<boolean>(false);\n\nexport const searchSystemAtom = atom(\n  (get) => get(internalSearchSystemStateAtom),\n  (get, set, value: boolean) => {\n    if (value === get(internalSearchSystemStateAtom)) {\n      return;\n    }\n    const stateChangeHandler = () => {\n      const params = new URLSearchParams(window.location.search);\n      console.log(\"SEARCH_DEBUG - stateChangeHandler\", value, params.get(\"es\"), params.get(\"esq\"), window.location.search);\n      if (params.get(\"es\") === \"true\") {\n        const id = params.get(\"esi\");\n        const query = params.get(\"esq\");\n        set(searchParamsAtom, { id, query });\n      } else {\n        set(searchParamsAtom, { id: null, query: null });\n      }\n    };\n    if (value) {\n      set(internalSearchSystemStateAtom, true);\n      window.addEventListener(\"popstate\", stateChangeHandler);\n      // Also trigger the hash change handler to set the initial state\n      stateChangeHandler();\n    } else {\n      set(internalSearchSystemStateAtom, false);\n      window.removeEventListener(\"popstate\", stateChangeHandler);\n    }\n  }\n);\n\nexport const filteredSearchProductsAtom = atom((get) => {\n  const searchData = get(searchAtom).data;\n  const sorting = get(searchProductSortingAtom);\n  const selectedFilters = get(searchSelectedFiltersAtom);\n  const newOrgConfig = get(newOrgConfigAtom);\n\n  if (\n    !searchData?.products ||\n    !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig\n  )\n    return [];\n\n  const filteredProducts = ProductFilters.filterProducts(\n    searchData.products,\n    newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig,\n    selectedFilters,\n    newOrgConfig.frontendConfig.uiConfigs.searchConfig.additiveDynamicFilters\n  );\n\n  return ProductSorter.sort(filteredProducts, sorting);\n});\n\nexport const searchFiltersAtom = atom((get) => {\n  const searchData = get(searchAtom).data;\n  const selectedFilters = get(searchSelectedFiltersAtom);\n  const newOrgConfig = get(newOrgConfigAtom);\n\n  if (\n    !searchData?.products ||\n    !newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig\n  )\n    return [];\n\n  return ProductFilters.getFiltersForProducts(\n    searchData.products,\n    newOrgConfig.frontendConfig.uiConfigs.searchConfig.searchFilterConfig,\n    selectedFilters\n  );\n});\n\nexport const addSearchFilterAtom = atom(\n  null,\n  (get, set, filter: SelectedFilterOption) => {\n    const current = get(searchSelectedFiltersAtom);\n    if (!current.some((f) => f.id === filter.id)) {\n      set(searchSelectedFiltersAtom, [...current, filter]);\n    }\n  }\n);\n\nexport const removeSearchFilterAtom = atom(\n  null,\n  (get, set, filterId: string) => {\n    const current = get(searchSelectedFiltersAtom);\n    set(\n      searchSelectedFiltersAtom,\n      current.filter((f) => f.id !== filterId)\n    );\n  }\n);\n\nexport const clearSearchFiltersAtom = atom(null, (_, set) => {\n  set(searchSelectedFiltersAtom, []);\n});\n\nexport const performSearchAtom = atom(\n  null,\n  async (get, set, params: SearchParams, allowRedirect = false) => {\n    const currentState = get(searchAtom);\n    const newOrgConfig = get(newOrgConfigAtom);\n    const redirectSearchResultsUrl =\n      newOrgConfig?.frontendConfig?.uiConfigs?.searchConfig\n        ?.redirectSearchResultsUrl;\n\n    if (allowRedirect && redirectSearchResultsUrl) {\n      const redirectUrl = new URL(redirectSearchResultsUrl);\n      redirectUrl.searchParams.set(\"es\", \"true\");\n      redirectUrl.searchParams.set(\"esq\", params.query);\n      window.location.href = redirectUrl.toString();\n    } else {\n      // Update URL and manually trigger state change (since pushState doesn't trigger popstate)\n      const url = new URL(window.location.href);\n      url.searchParams.set(\"es\", \"true\");\n      url.searchParams.set(\"esq\", params.query);\n      window.history.pushState({}, \"\", url);\n\n      // Manually trigger page variant re-evaluation by dispatching a popstate event\n      // This ensures the page variant system detects the URL change and mounts search results\n      window.dispatchEvent(new PopStateEvent(\"popstate\", { state: {} }));\n    }\n\n    // Manually trigger page variant re-evaluation by dispatching a popstate event\n    // This ensures the page variant system detects the URL change and mounts search results\n    window.dispatchEvent(new PopStateEvent(\"popstate\", { state: {} }));\n    if (currentState.loading) {\n      return; // Prevent concurrent searches\n    }\n\n    set(searchAtom, {\n      data: null,\n      loading: true,\n      error: null,\n      lastQuery: params.query,\n    });\n    try {\n      const searchServiceFunction = getSearchServiceFunction();\n      const result = await searchServiceFunction(params);\n      set(searchAtom, {\n        data: result,\n        loading: false,\n        error: null,\n        lastQuery: params.query,\n      });\n    } catch (error: unknown) {\n      const errorMessage =\n        error instanceof Error ? error.message : \"An unknown error occurred\";\n      set(searchAtom, {\n        data: null,\n        loading: false,\n        error: errorMessage,\n        lastQuery: params.query,\n      });\n    }\n  }\n);\n"],"mappings":"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"}
@@ -2,8 +2,8 @@ const require_chunk = require('./chunk-CUT6urMc.cjs');
2
2
  const require_logger = require('./logger-TBIl4uIH.cjs');
3
3
  const require_enviveConfig = require('./enviveConfig-Dv9-esGV.cjs');
4
4
  const require_enviveConfigContext = require('./enviveConfigContext-D2OELZDR.cjs');
5
- const require_searchServiceAdapter = require('./searchServiceAdapter-BGlvoZFE.cjs');
6
- const require_unsupportedProductExceptions = require('./unsupportedProductExceptions-B4f9aLjr.cjs');
5
+ const require_searchServiceAdapter = require('./searchServiceAdapter-B3KCzkDl.cjs');
6
+ const require_unsupportedProductExceptions = require('./unsupportedProductExceptions-DGENUnEA.cjs');
7
7
  const require_useAppDetails = require('./useAppDetails-CPqMbju3.cjs');
8
8
  let __spiffy_ai_commerce_api_client = require("@spiffy-ai/commerce-api-client");
9
9
  __spiffy_ai_commerce_api_client = require_chunk.__toESM(__spiffy_ai_commerce_api_client);
@@ -142,4 +142,4 @@ Object.defineProperty(exports, 'useSearchService', {
142
142
  return useSearchService;
143
143
  }
144
144
  });
145
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"searchContext-B5ea-PzV.cjs","names":["ResponseCategory","ResponseError","UnsupportedProductException","SessionRestartRequired","SearchProvider: React.FC<{ children: React.ReactNode }>","useEnviveConfig","useAppDetails","baseUrlAtom","config: Configuration","Configuration","SearchApi"],"sources":["../src/contexts/searchContext/searchContext.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useContext,\n  useCallback,\n  useMemo,\n  useEffect,\n} from \"react\";\nimport { useAtomValue } from \"jotai\";\nimport {\n  Configuration,\n  ResponseCategory,\n  ResponseError,\n  SearchApi,\n} from \"@spiffy-ai/commerce-api-client\";\nimport { baseUrlAtom } from \"src/atoms/envive/enviveConfig\";\nimport Logger from \"src/application/logging/logger\";\nimport { useAppDetails } from \"src/hooks/AppDetails/useAppDetails\";\nimport { useEnviveConfig } from \"src/contexts/enviveConfigContext/enviveConfigContext\";\nimport { SessionRestartRequired } from \"src/types/exceptions/sessionExceptions\";\nimport { UnsupportedProductException } from \"src/types/exceptions/unsupportedProductExceptions\";\nimport { SearchParams, SearchResult } from \"src/application/models/api/search\";\nimport {\n  clearSearchServiceFunction,\n  setSearchServiceFunction,\n} from \"src/atoms/search/searchServiceAdapter\";\n\nconst transformProductResponses = (products: SearchResult[\"products\"]) =>\n  products.map((data) => ({\n    id: data.id,\n    responseId: data.response_id,\n    category: ResponseCategory.Product,\n    description: data.description,\n    imageUrl: data.image_url,\n    imageUrls: data.image_urls,\n    title: data.title,\n    url: data.url,\n    originalPrice: data.original_price,\n    salePrice: data.sale_price,\n    averageRating: data.average_rating,\n    numberReviews: data.number_reviews,\n    metadata: data.metadata,\n    isForGrid: data.is_for_grid,\n    colors: data.colors,\n    sizes: data.sizes,\n    filters: data.filters,\n  }));\n\nasync function errorResponseBody(error: ResponseError) {\n  try {\n    return await error.response.json();\n  } catch {\n    return {};\n  }\n}\n\nasync function throwSessionRestartRequiredIf(errorMsg: string, error: unknown) {\n  if (!(error instanceof ResponseError)) {\n    Logger.logInfo(errorMsg, error);\n    throw error;\n  }\n\n  const errorResponse = await errorResponseBody(error);\n  if (\n    errorResponse?.message?.toLowerCase() === \"unsupported product\" ||\n    errorResponse?.app_code?.toUpperCase() === \"PRODUCT_NOT_FOUND\"\n  ) {\n    throw new UnsupportedProductException();\n  } else if (\n    errorResponse?.app_code?.toUpperCase() === \"RESTART_SESSION\" ||\n    errorResponse?.sub_code?.toUpperCase() === \"NOT_FOUND\"\n  ) {\n    Logger.logInfo(\n      \"Session does not exist. Re-start session\",\n      error,\n      error.response,\n      errorResponse\n    );\n    throw new SessionRestartRequired();\n  }\n\n  Logger.logInfo(errorMsg, error);\n  throw error;\n}\n\ninterface SearchContextValue {\n  searchProducts: (params: SearchParams) => Promise<SearchResult>;\n  isReady: boolean;\n}\n\nconst SearchContext = createContext<SearchContextValue | undefined>(undefined);\n\nexport const SearchProvider: React.FC<{ children: React.ReactNode }> = ({\n  children,\n}) => {\n  const { orgLevelApiKey, publicKey } = useEnviveConfig();\n  const apiKey = orgLevelApiKey || publicKey; // Replicate apiKeyAtom logic\n  const appDetails = useAppDetails();\n  const baseUrl = useAtomValue(baseUrlAtom);\n\n  const isReady = Boolean(apiKey && appDetails && baseUrl);\n\n  const searchApi = useMemo(() => {\n    if (!isReady) return null;\n\n    const config: Configuration = new Configuration({\n      accessToken: apiKey,\n      basePath: baseUrl,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Accept: \"application/json\",\n      },\n    });\n    return new SearchApi(config);\n  }, [apiKey, baseUrl, isReady]);\n\n  const searchProducts = useCallback(\n    async (params: SearchParams): Promise<SearchResult> => {\n      if (!isReady || !searchApi) {\n        throw new Error(\"SearchService not ready - missing dependencies\");\n      }\n\n      try {\n        const response = await searchApi.v1SearchQueryGet({\n          query: params.query,\n          limit: params.limit,\n          org_id: appDetails.orgId,\n          user_id: appDetails.userId,\n        });\n        const {\n          products,\n          filters,\n          search_response_id: searchResponseId,\n        } = response;\n\n        return {\n          products: transformProductResponses(products) || [],\n          filters: filters || [],\n          totalProductCount: products?.length || 0,\n          searchResponseId: searchResponseId || \"\",\n        };\n      } catch (error) {\n        await throwSessionRestartRequiredIf(\"Failed to search products\", error);\n        // This part will not be reached if an exception is thrown, but it's required for type safety\n        return {\n          products: [],\n          filters: [],\n          totalProductCount: 0,\n          searchResponseId: \"\",\n        };\n      }\n    },\n    [searchApi, isReady, appDetails]\n  );\n\n  // Register the search function with the adapter for use in atoms\n  useEffect(() => {\n    if (isReady) {\n      setSearchServiceFunction(searchProducts);\n    } else {\n      clearSearchServiceFunction();\n    }\n\n    return () => {\n      clearSearchServiceFunction();\n    };\n  }, [searchProducts, isReady]);\n\n  const value = useMemo(\n    () => ({\n      searchProducts,\n      isReady,\n    }),\n    [searchProducts, isReady]\n  );\n\n  return (\n    <SearchContext.Provider value={value}>{children}</SearchContext.Provider>\n  );\n};\n\nexport const useSearchService = () => {\n  const context = useContext(SearchContext);\n  if (!context) {\n    throw new Error(\"useSearchService must be used within a SearchProvider\");\n  }\n  return context;\n};\n"],"mappings":";;;;;;;;;;;;;;;;;AA0BA,MAAM,6BAA6B,aACjC,SAAS,KAAK,UAAU;CACtB,IAAI,KAAK;CACT,YAAY,KAAK;CACjB,UAAUA,iDAAiB;CAC3B,aAAa,KAAK;CAClB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,OAAO,KAAK;CACZ,KAAK,KAAK;CACV,eAAe,KAAK;CACpB,WAAW,KAAK;CAChB,eAAe,KAAK;CACpB,eAAe,KAAK;CACpB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,QAAQ,KAAK;CACb,OAAO,KAAK;CACZ,SAAS,KAAK;CACf,EAAE;AAEL,eAAe,kBAAkB,OAAsB;AACrD,KAAI;AACF,SAAO,MAAM,MAAM,SAAS,MAAM;SAC5B;AACN,SAAO,EAAE;;;AAIb,eAAe,8BAA8B,UAAkB,OAAgB;AAC7E,KAAI,EAAE,iBAAiBC,gDAAgB;AACrC,gCAAO,QAAQ,UAAU,MAAM;AAC/B,QAAM;;CAGR,MAAM,gBAAgB,MAAM,kBAAkB,MAAM;AACpD,KACE,eAAe,SAAS,aAAa,KAAK,yBAC1C,eAAe,UAAU,aAAa,KAAK,oBAE3C,OAAM,IAAIC,kEAA6B;UAEvC,eAAe,UAAU,aAAa,KAAK,qBAC3C,eAAe,UAAU,aAAa,KAAK,aAC3C;AACA,gCAAO,QACL,4CACA,OACA,MAAM,UACN,cACD;AACD,QAAM,IAAIC,6DAAwB;;AAGpC,+BAAO,QAAQ,UAAU,MAAM;AAC/B,OAAM;;AAQR,MAAM,yCAA8D,OAAU;AAE9E,MAAaC,kBAA2D,EACtE,eACI;CACJ,MAAM,EAAE,gBAAgB,cAAcC,6CAAiB;CACvD,MAAM,SAAS,kBAAkB;CACjC,MAAM,aAAaC,qCAAe;CAClC,MAAM,kCAAuBC,iCAAY;CAEzC,MAAM,UAAU,QAAQ,UAAU,cAAc,QAAQ;CAExD,MAAM,qCAA0B;AAC9B,MAAI,CAAC,QAAS,QAAO;EAErB,MAAMC,SAAwB,IAAIC,8CAAc;GAC9C,aAAa;GACb,UAAU;GACV,SAAS;IACP,gBAAgB;IAChB,QAAQ;IACT;GACF,CAAC;AACF,SAAO,IAAIC,0CAAU,OAAO;IAC3B;EAAC;EAAQ;EAAS;EAAQ,CAAC;CAE9B,MAAM,wCACJ,OAAO,WAAgD;AACrD,MAAI,CAAC,WAAW,CAAC,UACf,OAAM,IAAI,MAAM,iDAAiD;AAGnE,MAAI;GAOF,MAAM,EACJ,UACA,SACA,oBAAoB,qBATL,MAAM,UAAU,iBAAiB;IAChD,OAAO,OAAO;IACd,OAAO,OAAO;IACd,QAAQ,WAAW;IACnB,SAAS,WAAW;IACrB,CAAC;AAOF,UAAO;IACL,UAAU,0BAA0B,SAAS,IAAI,EAAE;IACnD,SAAS,WAAW,EAAE;IACtB,mBAAmB,UAAU,UAAU;IACvC,kBAAkB,oBAAoB;IACvC;WACM,OAAO;AACd,SAAM,8BAA8B,6BAA6B,MAAM;AAEvE,UAAO;IACL,UAAU,EAAE;IACZ,SAAS,EAAE;IACX,mBAAmB;IACnB,kBAAkB;IACnB;;IAGL;EAAC;EAAW;EAAS;EAAW,CACjC;AAGD,4BAAgB;AACd,MAAI,QACF,uDAAyB,eAAe;MAExC,0DAA4B;AAG9B,eAAa;AACX,4DAA4B;;IAE7B,CAAC,gBAAgB,QAAQ,CAAC;CAE7B,MAAM,kCACG;EACL;EACA;EACD,GACD,CAAC,gBAAgB,QAAQ,CAC1B;AAED,QACE,2CAAC,cAAc;EAAgB;EAAQ;GAAkC;;AAI7E,MAAa,yBAAyB;CACpC,MAAM,gCAAqB,cAAc;AACzC,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,wDAAwD;AAE1E,QAAO"}
145
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"searchContext-Cq6I8Jbr.cjs","names":["ResponseCategory","ResponseError","UnsupportedProductException","SessionRestartRequired","SearchProvider: React.FC<{ children: React.ReactNode }>","useEnviveConfig","useAppDetails","baseUrlAtom","config: Configuration","Configuration","SearchApi"],"sources":["../src/contexts/searchContext/searchContext.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useContext,\n  useCallback,\n  useMemo,\n  useEffect,\n} from \"react\";\nimport { useAtomValue } from \"jotai\";\nimport {\n  Configuration,\n  ResponseCategory,\n  ResponseError,\n  SearchApi,\n} from \"@spiffy-ai/commerce-api-client\";\nimport { baseUrlAtom } from \"src/atoms/envive/enviveConfig\";\nimport Logger from \"src/application/logging/logger\";\nimport { useAppDetails } from \"src/hooks/AppDetails/useAppDetails\";\nimport { useEnviveConfig } from \"src/contexts/enviveConfigContext/enviveConfigContext\";\nimport { SessionRestartRequired } from \"src/types/exceptions/sessionExceptions\";\nimport { UnsupportedProductException } from \"src/types/exceptions/unsupportedProductExceptions\";\nimport { SearchParams, SearchResult } from \"src/application/models/api/search\";\nimport {\n  clearSearchServiceFunction,\n  setSearchServiceFunction,\n} from \"src/atoms/search/searchServiceAdapter\";\n\nconst transformProductResponses = (products: SearchResult[\"products\"]) =>\n  products.map((data) => ({\n    id: data.id,\n    responseId: data.response_id,\n    category: ResponseCategory.Product,\n    description: data.description,\n    imageUrl: data.image_url,\n    imageUrls: data.image_urls,\n    title: data.title,\n    url: data.url,\n    originalPrice: data.original_price,\n    salePrice: data.sale_price,\n    averageRating: data.average_rating,\n    numberReviews: data.number_reviews,\n    metadata: data.metadata,\n    isForGrid: data.is_for_grid,\n    colors: data.colors,\n    sizes: data.sizes,\n    filters: data.filters,\n  }));\n\nasync function errorResponseBody(error: ResponseError) {\n  try {\n    return await error.response.json();\n  } catch {\n    return {};\n  }\n}\n\nasync function throwSessionRestartRequiredIf(errorMsg: string, error: unknown) {\n  if (!(error instanceof ResponseError)) {\n    Logger.logInfo(errorMsg, error);\n    throw error;\n  }\n\n  const errorResponse = await errorResponseBody(error);\n  if (\n    errorResponse?.message?.toLowerCase() === \"unsupported product\" ||\n    errorResponse?.app_code?.toUpperCase() === \"PRODUCT_NOT_FOUND\"\n  ) {\n    throw new UnsupportedProductException();\n  } else if (\n    errorResponse?.app_code?.toUpperCase() === \"RESTART_SESSION\" ||\n    errorResponse?.sub_code?.toUpperCase() === \"NOT_FOUND\"\n  ) {\n    Logger.logInfo(\n      \"Session does not exist. Re-start session\",\n      error,\n      error.response,\n      errorResponse\n    );\n    throw new SessionRestartRequired();\n  }\n\n  Logger.logInfo(errorMsg, error);\n  throw error;\n}\n\ninterface SearchContextValue {\n  searchProducts: (params: SearchParams) => Promise<SearchResult>;\n  isReady: boolean;\n}\n\nconst SearchContext = createContext<SearchContextValue | undefined>(undefined);\n\nexport const SearchProvider: React.FC<{ children: React.ReactNode }> = ({\n  children,\n}) => {\n  const { orgLevelApiKey, publicKey } = useEnviveConfig();\n  const apiKey = orgLevelApiKey || publicKey; // Replicate apiKeyAtom logic\n  const appDetails = useAppDetails();\n  const baseUrl = useAtomValue(baseUrlAtom);\n\n  const isReady = Boolean(apiKey && appDetails && baseUrl);\n\n  const searchApi = useMemo(() => {\n    if (!isReady) return null;\n\n    const config: Configuration = new Configuration({\n      accessToken: apiKey,\n      basePath: baseUrl,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Accept: \"application/json\",\n      },\n    });\n    return new SearchApi(config);\n  }, [apiKey, baseUrl, isReady]);\n\n  const searchProducts = useCallback(\n    async (params: SearchParams): Promise<SearchResult> => {\n      if (!isReady || !searchApi) {\n        throw new Error(\"SearchService not ready - missing dependencies\");\n      }\n\n      try {\n        const response = await searchApi.v1SearchQueryGet({\n          query: params.query,\n          limit: params.limit,\n          org_id: appDetails.orgId,\n          user_id: appDetails.userId,\n        });\n        const {\n          products,\n          filters,\n          search_response_id: searchResponseId,\n        } = response;\n\n        return {\n          products: transformProductResponses(products) || [],\n          filters: filters || [],\n          totalProductCount: products?.length || 0,\n          searchResponseId: searchResponseId || \"\",\n        };\n      } catch (error) {\n        await throwSessionRestartRequiredIf(\"Failed to search products\", error);\n        // This part will not be reached if an exception is thrown, but it's required for type safety\n        return {\n          products: [],\n          filters: [],\n          totalProductCount: 0,\n          searchResponseId: \"\",\n        };\n      }\n    },\n    [searchApi, isReady, appDetails]\n  );\n\n  // Register the search function with the adapter for use in atoms\n  useEffect(() => {\n    if (isReady) {\n      setSearchServiceFunction(searchProducts);\n    } else {\n      clearSearchServiceFunction();\n    }\n\n    return () => {\n      clearSearchServiceFunction();\n    };\n  }, [searchProducts, isReady]);\n\n  const value = useMemo(\n    () => ({\n      searchProducts,\n      isReady,\n    }),\n    [searchProducts, isReady]\n  );\n\n  return (\n    <SearchContext.Provider value={value}>{children}</SearchContext.Provider>\n  );\n};\n\nexport const useSearchService = () => {\n  const context = useContext(SearchContext);\n  if (!context) {\n    throw new Error(\"useSearchService must be used within a SearchProvider\");\n  }\n  return context;\n};\n"],"mappings":";;;;;;;;;;;;;;;;;AA0BA,MAAM,6BAA6B,aACjC,SAAS,KAAK,UAAU;CACtB,IAAI,KAAK;CACT,YAAY,KAAK;CACjB,UAAUA,iDAAiB;CAC3B,aAAa,KAAK;CAClB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,OAAO,KAAK;CACZ,KAAK,KAAK;CACV,eAAe,KAAK;CACpB,WAAW,KAAK;CAChB,eAAe,KAAK;CACpB,eAAe,KAAK;CACpB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,QAAQ,KAAK;CACb,OAAO,KAAK;CACZ,SAAS,KAAK;CACf,EAAE;AAEL,eAAe,kBAAkB,OAAsB;AACrD,KAAI;AACF,SAAO,MAAM,MAAM,SAAS,MAAM;SAC5B;AACN,SAAO,EAAE;;;AAIb,eAAe,8BAA8B,UAAkB,OAAgB;AAC7E,KAAI,EAAE,iBAAiBC,gDAAgB;AACrC,gCAAO,QAAQ,UAAU,MAAM;AAC/B,QAAM;;CAGR,MAAM,gBAAgB,MAAM,kBAAkB,MAAM;AACpD,KACE,eAAe,SAAS,aAAa,KAAK,yBAC1C,eAAe,UAAU,aAAa,KAAK,oBAE3C,OAAM,IAAIC,kEAA6B;UAEvC,eAAe,UAAU,aAAa,KAAK,qBAC3C,eAAe,UAAU,aAAa,KAAK,aAC3C;AACA,gCAAO,QACL,4CACA,OACA,MAAM,UACN,cACD;AACD,QAAM,IAAIC,6DAAwB;;AAGpC,+BAAO,QAAQ,UAAU,MAAM;AAC/B,OAAM;;AAQR,MAAM,yCAA8D,OAAU;AAE9E,MAAaC,kBAA2D,EACtE,eACI;CACJ,MAAM,EAAE,gBAAgB,cAAcC,6CAAiB;CACvD,MAAM,SAAS,kBAAkB;CACjC,MAAM,aAAaC,qCAAe;CAClC,MAAM,kCAAuBC,iCAAY;CAEzC,MAAM,UAAU,QAAQ,UAAU,cAAc,QAAQ;CAExD,MAAM,qCAA0B;AAC9B,MAAI,CAAC,QAAS,QAAO;EAErB,MAAMC,SAAwB,IAAIC,8CAAc;GAC9C,aAAa;GACb,UAAU;GACV,SAAS;IACP,gBAAgB;IAChB,QAAQ;IACT;GACF,CAAC;AACF,SAAO,IAAIC,0CAAU,OAAO;IAC3B;EAAC;EAAQ;EAAS;EAAQ,CAAC;CAE9B,MAAM,wCACJ,OAAO,WAAgD;AACrD,MAAI,CAAC,WAAW,CAAC,UACf,OAAM,IAAI,MAAM,iDAAiD;AAGnE,MAAI;GAOF,MAAM,EACJ,UACA,SACA,oBAAoB,qBATL,MAAM,UAAU,iBAAiB;IAChD,OAAO,OAAO;IACd,OAAO,OAAO;IACd,QAAQ,WAAW;IACnB,SAAS,WAAW;IACrB,CAAC;AAOF,UAAO;IACL,UAAU,0BAA0B,SAAS,IAAI,EAAE;IACnD,SAAS,WAAW,EAAE;IACtB,mBAAmB,UAAU,UAAU;IACvC,kBAAkB,oBAAoB;IACvC;WACM,OAAO;AACd,SAAM,8BAA8B,6BAA6B,MAAM;AAEvE,UAAO;IACL,UAAU,EAAE;IACZ,SAAS,EAAE;IACX,mBAAmB;IACnB,kBAAkB;IACnB;;IAGL;EAAC;EAAW;EAAS;EAAW,CACjC;AAGD,4BAAgB;AACd,MAAI,QACF,uDAAyB,eAAe;MAExC,0DAA4B;AAG9B,eAAa;AACX,4DAA4B;;IAE7B,CAAC,gBAAgB,QAAQ,CAAC;CAE7B,MAAM,kCACG;EACL;EACA;EACD,GACD,CAAC,gBAAgB,QAAQ,CAC1B;AAED,QACE,2CAAC,cAAc;EAAgB;EAAQ;GAAkC;;AAI7E,MAAa,yBAAyB;CACpC,MAAM,gCAAqB,cAAc;AACzC,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,wDAAwD;AAE1E,QAAO"}
@@ -1,8 +1,8 @@
1
1
  import { logger_default } from "./logger-W3lqg-4b.js";
2
2
  import { baseUrlAtom } from "./enviveConfig-DZBohDpc.js";
3
3
  import { useEnviveConfig } from "./enviveConfigContext-DrDjCems.js";
4
- import { clearSearchServiceFunction, setSearchServiceFunction } from "./searchServiceAdapter-Db6jEcJs.js";
5
- import { SessionRestartRequired, UnsupportedProductException } from "./unsupportedProductExceptions-DlmraJm8.js";
4
+ import { clearSearchServiceFunction, setSearchServiceFunction } from "./searchServiceAdapter-DQorsH-V.js";
5
+ import { SessionRestartRequired, UnsupportedProductException } from "./unsupportedProductExceptions-uQuuelOs.js";
6
6
  import { useAppDetails } from "./useAppDetails-WagqDI97.js";
7
7
  import { Configuration, ResponseCategory, ResponseError, SearchApi } from "@spiffy-ai/commerce-api-client";
8
8
  import React, { createContext, useCallback, useContext, useEffect, useMemo } from "react";
@@ -126,4 +126,4 @@ const useSearchService = () => {
126
126
 
127
127
  //#endregion
128
128
  export { SearchProvider, useSearchService };
129
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"searchContext-i5I9qGDl.js","names":["SearchProvider: React.FC<{ children: React.ReactNode }>","config: Configuration"],"sources":["../src/contexts/searchContext/searchContext.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useContext,\n  useCallback,\n  useMemo,\n  useEffect,\n} from \"react\";\nimport { useAtomValue } from \"jotai\";\nimport {\n  Configuration,\n  ResponseCategory,\n  ResponseError,\n  SearchApi,\n} from \"@spiffy-ai/commerce-api-client\";\nimport { baseUrlAtom } from \"src/atoms/envive/enviveConfig\";\nimport Logger from \"src/application/logging/logger\";\nimport { useAppDetails } from \"src/hooks/AppDetails/useAppDetails\";\nimport { useEnviveConfig } from \"src/contexts/enviveConfigContext/enviveConfigContext\";\nimport { SessionRestartRequired } from \"src/types/exceptions/sessionExceptions\";\nimport { UnsupportedProductException } from \"src/types/exceptions/unsupportedProductExceptions\";\nimport { SearchParams, SearchResult } from \"src/application/models/api/search\";\nimport {\n  clearSearchServiceFunction,\n  setSearchServiceFunction,\n} from \"src/atoms/search/searchServiceAdapter\";\n\nconst transformProductResponses = (products: SearchResult[\"products\"]) =>\n  products.map((data) => ({\n    id: data.id,\n    responseId: data.response_id,\n    category: ResponseCategory.Product,\n    description: data.description,\n    imageUrl: data.image_url,\n    imageUrls: data.image_urls,\n    title: data.title,\n    url: data.url,\n    originalPrice: data.original_price,\n    salePrice: data.sale_price,\n    averageRating: data.average_rating,\n    numberReviews: data.number_reviews,\n    metadata: data.metadata,\n    isForGrid: data.is_for_grid,\n    colors: data.colors,\n    sizes: data.sizes,\n    filters: data.filters,\n  }));\n\nasync function errorResponseBody(error: ResponseError) {\n  try {\n    return await error.response.json();\n  } catch {\n    return {};\n  }\n}\n\nasync function throwSessionRestartRequiredIf(errorMsg: string, error: unknown) {\n  if (!(error instanceof ResponseError)) {\n    Logger.logInfo(errorMsg, error);\n    throw error;\n  }\n\n  const errorResponse = await errorResponseBody(error);\n  if (\n    errorResponse?.message?.toLowerCase() === \"unsupported product\" ||\n    errorResponse?.app_code?.toUpperCase() === \"PRODUCT_NOT_FOUND\"\n  ) {\n    throw new UnsupportedProductException();\n  } else if (\n    errorResponse?.app_code?.toUpperCase() === \"RESTART_SESSION\" ||\n    errorResponse?.sub_code?.toUpperCase() === \"NOT_FOUND\"\n  ) {\n    Logger.logInfo(\n      \"Session does not exist. Re-start session\",\n      error,\n      error.response,\n      errorResponse\n    );\n    throw new SessionRestartRequired();\n  }\n\n  Logger.logInfo(errorMsg, error);\n  throw error;\n}\n\ninterface SearchContextValue {\n  searchProducts: (params: SearchParams) => Promise<SearchResult>;\n  isReady: boolean;\n}\n\nconst SearchContext = createContext<SearchContextValue | undefined>(undefined);\n\nexport const SearchProvider: React.FC<{ children: React.ReactNode }> = ({\n  children,\n}) => {\n  const { orgLevelApiKey, publicKey } = useEnviveConfig();\n  const apiKey = orgLevelApiKey || publicKey; // Replicate apiKeyAtom logic\n  const appDetails = useAppDetails();\n  const baseUrl = useAtomValue(baseUrlAtom);\n\n  const isReady = Boolean(apiKey && appDetails && baseUrl);\n\n  const searchApi = useMemo(() => {\n    if (!isReady) return null;\n\n    const config: Configuration = new Configuration({\n      accessToken: apiKey,\n      basePath: baseUrl,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Accept: \"application/json\",\n      },\n    });\n    return new SearchApi(config);\n  }, [apiKey, baseUrl, isReady]);\n\n  const searchProducts = useCallback(\n    async (params: SearchParams): Promise<SearchResult> => {\n      if (!isReady || !searchApi) {\n        throw new Error(\"SearchService not ready - missing dependencies\");\n      }\n\n      try {\n        const response = await searchApi.v1SearchQueryGet({\n          query: params.query,\n          limit: params.limit,\n          org_id: appDetails.orgId,\n          user_id: appDetails.userId,\n        });\n        const {\n          products,\n          filters,\n          search_response_id: searchResponseId,\n        } = response;\n\n        return {\n          products: transformProductResponses(products) || [],\n          filters: filters || [],\n          totalProductCount: products?.length || 0,\n          searchResponseId: searchResponseId || \"\",\n        };\n      } catch (error) {\n        await throwSessionRestartRequiredIf(\"Failed to search products\", error);\n        // This part will not be reached if an exception is thrown, but it's required for type safety\n        return {\n          products: [],\n          filters: [],\n          totalProductCount: 0,\n          searchResponseId: \"\",\n        };\n      }\n    },\n    [searchApi, isReady, appDetails]\n  );\n\n  // Register the search function with the adapter for use in atoms\n  useEffect(() => {\n    if (isReady) {\n      setSearchServiceFunction(searchProducts);\n    } else {\n      clearSearchServiceFunction();\n    }\n\n    return () => {\n      clearSearchServiceFunction();\n    };\n  }, [searchProducts, isReady]);\n\n  const value = useMemo(\n    () => ({\n      searchProducts,\n      isReady,\n    }),\n    [searchProducts, isReady]\n  );\n\n  return (\n    <SearchContext.Provider value={value}>{children}</SearchContext.Provider>\n  );\n};\n\nexport const useSearchService = () => {\n  const context = useContext(SearchContext);\n  if (!context) {\n    throw new Error(\"useSearchService must be used within a SearchProvider\");\n  }\n  return context;\n};\n"],"mappings":";;;;;;;;;;;;AA0BA,MAAM,6BAA6B,aACjC,SAAS,KAAK,UAAU;CACtB,IAAI,KAAK;CACT,YAAY,KAAK;CACjB,UAAU,iBAAiB;CAC3B,aAAa,KAAK;CAClB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,OAAO,KAAK;CACZ,KAAK,KAAK;CACV,eAAe,KAAK;CACpB,WAAW,KAAK;CAChB,eAAe,KAAK;CACpB,eAAe,KAAK;CACpB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,QAAQ,KAAK;CACb,OAAO,KAAK;CACZ,SAAS,KAAK;CACf,EAAE;AAEL,eAAe,kBAAkB,OAAsB;AACrD,KAAI;AACF,SAAO,MAAM,MAAM,SAAS,MAAM;SAC5B;AACN,SAAO,EAAE;;;AAIb,eAAe,8BAA8B,UAAkB,OAAgB;AAC7E,KAAI,EAAE,iBAAiB,gBAAgB;AACrC,iBAAO,QAAQ,UAAU,MAAM;AAC/B,QAAM;;CAGR,MAAM,gBAAgB,MAAM,kBAAkB,MAAM;AACpD,KACE,eAAe,SAAS,aAAa,KAAK,yBAC1C,eAAe,UAAU,aAAa,KAAK,oBAE3C,OAAM,IAAI,6BAA6B;UAEvC,eAAe,UAAU,aAAa,KAAK,qBAC3C,eAAe,UAAU,aAAa,KAAK,aAC3C;AACA,iBAAO,QACL,4CACA,OACA,MAAM,UACN,cACD;AACD,QAAM,IAAI,wBAAwB;;AAGpC,gBAAO,QAAQ,UAAU,MAAM;AAC/B,OAAM;;AAQR,MAAM,gBAAgB,cAA8C,OAAU;AAE9E,MAAaA,kBAA2D,EACtE,eACI;CACJ,MAAM,EAAE,gBAAgB,cAAc,iBAAiB;CACvD,MAAM,SAAS,kBAAkB;CACjC,MAAM,aAAa,eAAe;CAClC,MAAM,UAAU,aAAa,YAAY;CAEzC,MAAM,UAAU,QAAQ,UAAU,cAAc,QAAQ;CAExD,MAAM,YAAY,cAAc;AAC9B,MAAI,CAAC,QAAS,QAAO;EAErB,MAAMC,SAAwB,IAAI,cAAc;GAC9C,aAAa;GACb,UAAU;GACV,SAAS;IACP,gBAAgB;IAChB,QAAQ;IACT;GACF,CAAC;AACF,SAAO,IAAI,UAAU,OAAO;IAC3B;EAAC;EAAQ;EAAS;EAAQ,CAAC;CAE9B,MAAM,iBAAiB,YACrB,OAAO,WAAgD;AACrD,MAAI,CAAC,WAAW,CAAC,UACf,OAAM,IAAI,MAAM,iDAAiD;AAGnE,MAAI;GAOF,MAAM,EACJ,UACA,SACA,oBAAoB,qBATL,MAAM,UAAU,iBAAiB;IAChD,OAAO,OAAO;IACd,OAAO,OAAO;IACd,QAAQ,WAAW;IACnB,SAAS,WAAW;IACrB,CAAC;AAOF,UAAO;IACL,UAAU,0BAA0B,SAAS,IAAI,EAAE;IACnD,SAAS,WAAW,EAAE;IACtB,mBAAmB,UAAU,UAAU;IACvC,kBAAkB,oBAAoB;IACvC;WACM,OAAO;AACd,SAAM,8BAA8B,6BAA6B,MAAM;AAEvE,UAAO;IACL,UAAU,EAAE;IACZ,SAAS,EAAE;IACX,mBAAmB;IACnB,kBAAkB;IACnB;;IAGL;EAAC;EAAW;EAAS;EAAW,CACjC;AAGD,iBAAgB;AACd,MAAI,QACF,0BAAyB,eAAe;MAExC,6BAA4B;AAG9B,eAAa;AACX,+BAA4B;;IAE7B,CAAC,gBAAgB,QAAQ,CAAC;CAE7B,MAAM,QAAQ,eACL;EACL;EACA;EACD,GACD,CAAC,gBAAgB,QAAQ,CAC1B;AAED,QACE,oBAAC,cAAc;EAAgB;EAAQ;GAAkC;;AAI7E,MAAa,yBAAyB;CACpC,MAAM,UAAU,WAAW,cAAc;AACzC,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,wDAAwD;AAE1E,QAAO"}
129
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"searchContext-LbD2SkWw.js","names":["SearchProvider: React.FC<{ children: React.ReactNode }>","config: Configuration"],"sources":["../src/contexts/searchContext/searchContext.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useContext,\n  useCallback,\n  useMemo,\n  useEffect,\n} from \"react\";\nimport { useAtomValue } from \"jotai\";\nimport {\n  Configuration,\n  ResponseCategory,\n  ResponseError,\n  SearchApi,\n} from \"@spiffy-ai/commerce-api-client\";\nimport { baseUrlAtom } from \"src/atoms/envive/enviveConfig\";\nimport Logger from \"src/application/logging/logger\";\nimport { useAppDetails } from \"src/hooks/AppDetails/useAppDetails\";\nimport { useEnviveConfig } from \"src/contexts/enviveConfigContext/enviveConfigContext\";\nimport { SessionRestartRequired } from \"src/types/exceptions/sessionExceptions\";\nimport { UnsupportedProductException } from \"src/types/exceptions/unsupportedProductExceptions\";\nimport { SearchParams, SearchResult } from \"src/application/models/api/search\";\nimport {\n  clearSearchServiceFunction,\n  setSearchServiceFunction,\n} from \"src/atoms/search/searchServiceAdapter\";\n\nconst transformProductResponses = (products: SearchResult[\"products\"]) =>\n  products.map((data) => ({\n    id: data.id,\n    responseId: data.response_id,\n    category: ResponseCategory.Product,\n    description: data.description,\n    imageUrl: data.image_url,\n    imageUrls: data.image_urls,\n    title: data.title,\n    url: data.url,\n    originalPrice: data.original_price,\n    salePrice: data.sale_price,\n    averageRating: data.average_rating,\n    numberReviews: data.number_reviews,\n    metadata: data.metadata,\n    isForGrid: data.is_for_grid,\n    colors: data.colors,\n    sizes: data.sizes,\n    filters: data.filters,\n  }));\n\nasync function errorResponseBody(error: ResponseError) {\n  try {\n    return await error.response.json();\n  } catch {\n    return {};\n  }\n}\n\nasync function throwSessionRestartRequiredIf(errorMsg: string, error: unknown) {\n  if (!(error instanceof ResponseError)) {\n    Logger.logInfo(errorMsg, error);\n    throw error;\n  }\n\n  const errorResponse = await errorResponseBody(error);\n  if (\n    errorResponse?.message?.toLowerCase() === \"unsupported product\" ||\n    errorResponse?.app_code?.toUpperCase() === \"PRODUCT_NOT_FOUND\"\n  ) {\n    throw new UnsupportedProductException();\n  } else if (\n    errorResponse?.app_code?.toUpperCase() === \"RESTART_SESSION\" ||\n    errorResponse?.sub_code?.toUpperCase() === \"NOT_FOUND\"\n  ) {\n    Logger.logInfo(\n      \"Session does not exist. Re-start session\",\n      error,\n      error.response,\n      errorResponse\n    );\n    throw new SessionRestartRequired();\n  }\n\n  Logger.logInfo(errorMsg, error);\n  throw error;\n}\n\ninterface SearchContextValue {\n  searchProducts: (params: SearchParams) => Promise<SearchResult>;\n  isReady: boolean;\n}\n\nconst SearchContext = createContext<SearchContextValue | undefined>(undefined);\n\nexport const SearchProvider: React.FC<{ children: React.ReactNode }> = ({\n  children,\n}) => {\n  const { orgLevelApiKey, publicKey } = useEnviveConfig();\n  const apiKey = orgLevelApiKey || publicKey; // Replicate apiKeyAtom logic\n  const appDetails = useAppDetails();\n  const baseUrl = useAtomValue(baseUrlAtom);\n\n  const isReady = Boolean(apiKey && appDetails && baseUrl);\n\n  const searchApi = useMemo(() => {\n    if (!isReady) return null;\n\n    const config: Configuration = new Configuration({\n      accessToken: apiKey,\n      basePath: baseUrl,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Accept: \"application/json\",\n      },\n    });\n    return new SearchApi(config);\n  }, [apiKey, baseUrl, isReady]);\n\n  const searchProducts = useCallback(\n    async (params: SearchParams): Promise<SearchResult> => {\n      if (!isReady || !searchApi) {\n        throw new Error(\"SearchService not ready - missing dependencies\");\n      }\n\n      try {\n        const response = await searchApi.v1SearchQueryGet({\n          query: params.query,\n          limit: params.limit,\n          org_id: appDetails.orgId,\n          user_id: appDetails.userId,\n        });\n        const {\n          products,\n          filters,\n          search_response_id: searchResponseId,\n        } = response;\n\n        return {\n          products: transformProductResponses(products) || [],\n          filters: filters || [],\n          totalProductCount: products?.length || 0,\n          searchResponseId: searchResponseId || \"\",\n        };\n      } catch (error) {\n        await throwSessionRestartRequiredIf(\"Failed to search products\", error);\n        // This part will not be reached if an exception is thrown, but it's required for type safety\n        return {\n          products: [],\n          filters: [],\n          totalProductCount: 0,\n          searchResponseId: \"\",\n        };\n      }\n    },\n    [searchApi, isReady, appDetails]\n  );\n\n  // Register the search function with the adapter for use in atoms\n  useEffect(() => {\n    if (isReady) {\n      setSearchServiceFunction(searchProducts);\n    } else {\n      clearSearchServiceFunction();\n    }\n\n    return () => {\n      clearSearchServiceFunction();\n    };\n  }, [searchProducts, isReady]);\n\n  const value = useMemo(\n    () => ({\n      searchProducts,\n      isReady,\n    }),\n    [searchProducts, isReady]\n  );\n\n  return (\n    <SearchContext.Provider value={value}>{children}</SearchContext.Provider>\n  );\n};\n\nexport const useSearchService = () => {\n  const context = useContext(SearchContext);\n  if (!context) {\n    throw new Error(\"useSearchService must be used within a SearchProvider\");\n  }\n  return context;\n};\n"],"mappings":";;;;;;;;;;;;AA0BA,MAAM,6BAA6B,aACjC,SAAS,KAAK,UAAU;CACtB,IAAI,KAAK;CACT,YAAY,KAAK;CACjB,UAAU,iBAAiB;CAC3B,aAAa,KAAK;CAClB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,OAAO,KAAK;CACZ,KAAK,KAAK;CACV,eAAe,KAAK;CACpB,WAAW,KAAK;CAChB,eAAe,KAAK;CACpB,eAAe,KAAK;CACpB,UAAU,KAAK;CACf,WAAW,KAAK;CAChB,QAAQ,KAAK;CACb,OAAO,KAAK;CACZ,SAAS,KAAK;CACf,EAAE;AAEL,eAAe,kBAAkB,OAAsB;AACrD,KAAI;AACF,SAAO,MAAM,MAAM,SAAS,MAAM;SAC5B;AACN,SAAO,EAAE;;;AAIb,eAAe,8BAA8B,UAAkB,OAAgB;AAC7E,KAAI,EAAE,iBAAiB,gBAAgB;AACrC,iBAAO,QAAQ,UAAU,MAAM;AAC/B,QAAM;;CAGR,MAAM,gBAAgB,MAAM,kBAAkB,MAAM;AACpD,KACE,eAAe,SAAS,aAAa,KAAK,yBAC1C,eAAe,UAAU,aAAa,KAAK,oBAE3C,OAAM,IAAI,6BAA6B;UAEvC,eAAe,UAAU,aAAa,KAAK,qBAC3C,eAAe,UAAU,aAAa,KAAK,aAC3C;AACA,iBAAO,QACL,4CACA,OACA,MAAM,UACN,cACD;AACD,QAAM,IAAI,wBAAwB;;AAGpC,gBAAO,QAAQ,UAAU,MAAM;AAC/B,OAAM;;AAQR,MAAM,gBAAgB,cAA8C,OAAU;AAE9E,MAAaA,kBAA2D,EACtE,eACI;CACJ,MAAM,EAAE,gBAAgB,cAAc,iBAAiB;CACvD,MAAM,SAAS,kBAAkB;CACjC,MAAM,aAAa,eAAe;CAClC,MAAM,UAAU,aAAa,YAAY;CAEzC,MAAM,UAAU,QAAQ,UAAU,cAAc,QAAQ;CAExD,MAAM,YAAY,cAAc;AAC9B,MAAI,CAAC,QAAS,QAAO;EAErB,MAAMC,SAAwB,IAAI,cAAc;GAC9C,aAAa;GACb,UAAU;GACV,SAAS;IACP,gBAAgB;IAChB,QAAQ;IACT;GACF,CAAC;AACF,SAAO,IAAI,UAAU,OAAO;IAC3B;EAAC;EAAQ;EAAS;EAAQ,CAAC;CAE9B,MAAM,iBAAiB,YACrB,OAAO,WAAgD;AACrD,MAAI,CAAC,WAAW,CAAC,UACf,OAAM,IAAI,MAAM,iDAAiD;AAGnE,MAAI;GAOF,MAAM,EACJ,UACA,SACA,oBAAoB,qBATL,MAAM,UAAU,iBAAiB;IAChD,OAAO,OAAO;IACd,OAAO,OAAO;IACd,QAAQ,WAAW;IACnB,SAAS,WAAW;IACrB,CAAC;AAOF,UAAO;IACL,UAAU,0BAA0B,SAAS,IAAI,EAAE;IACnD,SAAS,WAAW,EAAE;IACtB,mBAAmB,UAAU,UAAU;IACvC,kBAAkB,oBAAoB;IACvC;WACM,OAAO;AACd,SAAM,8BAA8B,6BAA6B,MAAM;AAEvE,UAAO;IACL,UAAU,EAAE;IACZ,SAAS,EAAE;IACX,mBAAmB;IACnB,kBAAkB;IACnB;;IAGL;EAAC;EAAW;EAAS;EAAW,CACjC;AAGD,iBAAgB;AACd,MAAI,QACF,0BAAyB,eAAe;MAExC,6BAA4B;AAG9B,eAAa;AACX,+BAA4B;;IAE7B,CAAC,gBAAgB,QAAQ,CAAC;CAE7B,MAAM,QAAQ,eACL;EACL;EACA;EACD,GACD,CAAC,gBAAgB,QAAQ,CAC1B;AAED,QACE,oBAAC,cAAc;EAAgB;EAAQ;GAAkC;;AAI7E,MAAa,yBAAyB;CACpC,MAAM,UAAU,WAAW,cAAc;AACzC,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,wDAAwD;AAE1E,QAAO"}
@@ -31,4 +31,4 @@ Object.defineProperty(exports, 'setSearchServiceFunction', {
31
31
  return setSearchServiceFunction;
32
32
  }
33
33
  });
34
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoU2VydmljZUFkYXB0ZXItQkdsdm9aRkUuY2pzIiwibmFtZXMiOlsic2VhcmNoU2VydmljZUZ1bmN0aW9uOlxuICB8ICgocGFyYW1zOiBTZWFyY2hQYXJhbXMpID0+IFByb21pc2U8U2VhcmNoUmVzdWx0PilcbiAgfCBudWxsIl0sInNvdXJjZXMiOlsiLi4vc3JjL2F0b21zL3NlYXJjaC9zZWFyY2hTZXJ2aWNlQWRhcHRlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZWFyY2hSZXN1bHQsIFNlYXJjaFBhcmFtcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9zZWFyY2hcIjtcblxuLy8gVGhpcyB3aWxsIGJlIHNldCBieSB0aGUgU2VhcmNoUHJvdmlkZXIgd2hlbiBpdCBpbml0aWFsaXplc1xubGV0IHNlYXJjaFNlcnZpY2VGdW5jdGlvbjpcbiAgfCAoKHBhcmFtczogU2VhcmNoUGFyYW1zKSA9PiBQcm9taXNlPFNlYXJjaFJlc3VsdD4pXG4gIHwgbnVsbCA9IG51bGw7XG5cbmV4cG9ydCBjb25zdCBzZXRTZWFyY2hTZXJ2aWNlRnVuY3Rpb24gPSAoXG4gIGZuOiAocGFyYW1zOiBTZWFyY2hQYXJhbXMpID0+IFByb21pc2U8U2VhcmNoUmVzdWx0PlxuKSA9PiB7XG4gIHNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9IGZuO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9ICgpID0+IHtcbiAgaWYgKCFzZWFyY2hTZXJ2aWNlRnVuY3Rpb24pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIlNlYXJjaCBzZXJ2aWNlIGZ1bmN0aW9uIG5vdCBpbml0aWFsaXplZC4gTWFrZSBzdXJlIFNlYXJjaFByb3ZpZGVyIGlzIG1vdW50ZWQuXCJcbiAgICApO1xuICB9XG4gIHJldHVybiBzZWFyY2hTZXJ2aWNlRnVuY3Rpb247XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJTZWFyY2hTZXJ2aWNlRnVuY3Rpb24gPSAoKSA9PiB7XG4gIHNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9IG51bGw7XG59O1xuIl0sIm1hcHBpbmdzIjoiOztBQUdBLElBQUlBLHdCQUVPO0FBRVgsTUFBYSw0QkFDWCxPQUNHO0FBQ0gseUJBQXdCOztBQUcxQixNQUFhLGlDQUFpQztBQUM1QyxLQUFJLENBQUMsc0JBQ0gsT0FBTSxJQUFJLE1BQ1IsZ0ZBQ0Q7QUFFSCxRQUFPOztBQUdULE1BQWEsbUNBQW1DO0FBQzlDLHlCQUF3QiJ9
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoU2VydmljZUFkYXB0ZXItQjNLQ3prRGwuY2pzIiwibmFtZXMiOlsic2VhcmNoU2VydmljZUZ1bmN0aW9uOlxuICB8ICgocGFyYW1zOiBTZWFyY2hQYXJhbXMpID0+IFByb21pc2U8U2VhcmNoUmVzdWx0PilcbiAgfCBudWxsIl0sInNvdXJjZXMiOlsiLi4vc3JjL2F0b21zL3NlYXJjaC9zZWFyY2hTZXJ2aWNlQWRhcHRlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZWFyY2hSZXN1bHQsIFNlYXJjaFBhcmFtcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9zZWFyY2hcIjtcblxuLy8gVGhpcyB3aWxsIGJlIHNldCBieSB0aGUgU2VhcmNoUHJvdmlkZXIgd2hlbiBpdCBpbml0aWFsaXplc1xubGV0IHNlYXJjaFNlcnZpY2VGdW5jdGlvbjpcbiAgfCAoKHBhcmFtczogU2VhcmNoUGFyYW1zKSA9PiBQcm9taXNlPFNlYXJjaFJlc3VsdD4pXG4gIHwgbnVsbCA9IG51bGw7XG5cbmV4cG9ydCBjb25zdCBzZXRTZWFyY2hTZXJ2aWNlRnVuY3Rpb24gPSAoXG4gIGZuOiAocGFyYW1zOiBTZWFyY2hQYXJhbXMpID0+IFByb21pc2U8U2VhcmNoUmVzdWx0PlxuKSA9PiB7XG4gIHNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9IGZuO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9ICgpID0+IHtcbiAgaWYgKCFzZWFyY2hTZXJ2aWNlRnVuY3Rpb24pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIlNlYXJjaCBzZXJ2aWNlIGZ1bmN0aW9uIG5vdCBpbml0aWFsaXplZC4gTWFrZSBzdXJlIFNlYXJjaFByb3ZpZGVyIGlzIG1vdW50ZWQuXCJcbiAgICApO1xuICB9XG4gIHJldHVybiBzZWFyY2hTZXJ2aWNlRnVuY3Rpb247XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJTZWFyY2hTZXJ2aWNlRnVuY3Rpb24gPSAoKSA9PiB7XG4gIHNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9IG51bGw7XG59O1xuIl0sIm1hcHBpbmdzIjoiOztBQUdBLElBQUlBLHdCQUVPO0FBRVgsTUFBYSw0QkFDWCxPQUNHO0FBQ0gseUJBQXdCOztBQUcxQixNQUFhLGlDQUFpQztBQUM1QyxLQUFJLENBQUMsc0JBQ0gsT0FBTSxJQUFJLE1BQ1IsZ0ZBQ0Q7QUFFSCxRQUFPOztBQUdULE1BQWEsbUNBQW1DO0FBQzlDLHlCQUF3QiJ9
@@ -13,4 +13,4 @@ const clearSearchServiceFunction = () => {
13
13
 
14
14
  //#endregion
15
15
  export { clearSearchServiceFunction, getSearchServiceFunction, setSearchServiceFunction };
16
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoU2VydmljZUFkYXB0ZXItRGI2akVjSnMuanMiLCJuYW1lcyI6WyJzZWFyY2hTZXJ2aWNlRnVuY3Rpb246XG4gIHwgKChwYXJhbXM6IFNlYXJjaFBhcmFtcykgPT4gUHJvbWlzZTxTZWFyY2hSZXN1bHQ+KVxuICB8IG51bGwiXSwic291cmNlcyI6WyIuLi9zcmMvYXRvbXMvc2VhcmNoL3NlYXJjaFNlcnZpY2VBZGFwdGVyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlYXJjaFJlc3VsdCwgU2VhcmNoUGFyYW1zIH0gZnJvbSBcInNyYy9hcHBsaWNhdGlvbi9tb2RlbHMvYXBpL3NlYXJjaFwiO1xuXG4vLyBUaGlzIHdpbGwgYmUgc2V0IGJ5IHRoZSBTZWFyY2hQcm92aWRlciB3aGVuIGl0IGluaXRpYWxpemVzXG5sZXQgc2VhcmNoU2VydmljZUZ1bmN0aW9uOlxuICB8ICgocGFyYW1zOiBTZWFyY2hQYXJhbXMpID0+IFByb21pc2U8U2VhcmNoUmVzdWx0PilcbiAgfCBudWxsID0gbnVsbDtcblxuZXhwb3J0IGNvbnN0IHNldFNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9IChcbiAgZm46IChwYXJhbXM6IFNlYXJjaFBhcmFtcykgPT4gUHJvbWlzZTxTZWFyY2hSZXN1bHQ+XG4pID0+IHtcbiAgc2VhcmNoU2VydmljZUZ1bmN0aW9uID0gZm47XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VhcmNoU2VydmljZUZ1bmN0aW9uID0gKCkgPT4ge1xuICBpZiAoIXNlYXJjaFNlcnZpY2VGdW5jdGlvbikge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiU2VhcmNoIHNlcnZpY2UgZnVuY3Rpb24gbm90IGluaXRpYWxpemVkLiBNYWtlIHN1cmUgU2VhcmNoUHJvdmlkZXIgaXMgbW91bnRlZC5cIlxuICAgICk7XG4gIH1cbiAgcmV0dXJuIHNlYXJjaFNlcnZpY2VGdW5jdGlvbjtcbn07XG5cbmV4cG9ydCBjb25zdCBjbGVhclNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9ICgpID0+IHtcbiAgc2VhcmNoU2VydmljZUZ1bmN0aW9uID0gbnVsbDtcbn07XG4iXSwibWFwcGluZ3MiOiI7QUFHQSxJQUFJQSx3QkFFTztBQUVYLE1BQWEsNEJBQ1gsT0FDRztBQUNILHlCQUF3Qjs7QUFHMUIsTUFBYSxpQ0FBaUM7QUFDNUMsS0FBSSxDQUFDLHNCQUNILE9BQU0sSUFBSSxNQUNSLGdGQUNEO0FBRUgsUUFBTzs7QUFHVCxNQUFhLG1DQUFtQztBQUM5Qyx5QkFBd0IifQ==
16
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoU2VydmljZUFkYXB0ZXItRFFvcnNILVYuanMiLCJuYW1lcyI6WyJzZWFyY2hTZXJ2aWNlRnVuY3Rpb246XG4gIHwgKChwYXJhbXM6IFNlYXJjaFBhcmFtcykgPT4gUHJvbWlzZTxTZWFyY2hSZXN1bHQ+KVxuICB8IG51bGwiXSwic291cmNlcyI6WyIuLi9zcmMvYXRvbXMvc2VhcmNoL3NlYXJjaFNlcnZpY2VBZGFwdGVyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlYXJjaFJlc3VsdCwgU2VhcmNoUGFyYW1zIH0gZnJvbSBcInNyYy9hcHBsaWNhdGlvbi9tb2RlbHMvYXBpL3NlYXJjaFwiO1xuXG4vLyBUaGlzIHdpbGwgYmUgc2V0IGJ5IHRoZSBTZWFyY2hQcm92aWRlciB3aGVuIGl0IGluaXRpYWxpemVzXG5sZXQgc2VhcmNoU2VydmljZUZ1bmN0aW9uOlxuICB8ICgocGFyYW1zOiBTZWFyY2hQYXJhbXMpID0+IFByb21pc2U8U2VhcmNoUmVzdWx0PilcbiAgfCBudWxsID0gbnVsbDtcblxuZXhwb3J0IGNvbnN0IHNldFNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9IChcbiAgZm46IChwYXJhbXM6IFNlYXJjaFBhcmFtcykgPT4gUHJvbWlzZTxTZWFyY2hSZXN1bHQ+XG4pID0+IHtcbiAgc2VhcmNoU2VydmljZUZ1bmN0aW9uID0gZm47XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0U2VhcmNoU2VydmljZUZ1bmN0aW9uID0gKCkgPT4ge1xuICBpZiAoIXNlYXJjaFNlcnZpY2VGdW5jdGlvbikge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiU2VhcmNoIHNlcnZpY2UgZnVuY3Rpb24gbm90IGluaXRpYWxpemVkLiBNYWtlIHN1cmUgU2VhcmNoUHJvdmlkZXIgaXMgbW91bnRlZC5cIlxuICAgICk7XG4gIH1cbiAgcmV0dXJuIHNlYXJjaFNlcnZpY2VGdW5jdGlvbjtcbn07XG5cbmV4cG9ydCBjb25zdCBjbGVhclNlYXJjaFNlcnZpY2VGdW5jdGlvbiA9ICgpID0+IHtcbiAgc2VhcmNoU2VydmljZUZ1bmN0aW9uID0gbnVsbDtcbn07XG4iXSwibWFwcGluZ3MiOiI7QUFHQSxJQUFJQSx3QkFFTztBQUVYLE1BQWEsNEJBQ1gsT0FDRztBQUNILHlCQUF3Qjs7QUFHMUIsTUFBYSxpQ0FBaUM7QUFDNUMsS0FBSSxDQUFDLHNCQUNILE9BQU0sSUFBSSxNQUNSLGdGQUNEO0FBRUgsUUFBTzs7QUFHVCxNQUFhLG1DQUFtQztBQUM5Qyx5QkFBd0IifQ==
@@ -36,4 +36,4 @@ const SystemSettingsContextProvider = ({ children, generationParams, showDebugBa
36
36
 
37
37
  //#endregion
38
38
  export { SystemSettingsContext, SystemSettingsContextProvider, defaultGenerationParams };
39
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVtU2V0dGluZ3NDb250ZXh0LUI0a1pPRS1SLmpzIiwibmFtZXMiOlsiZGVmYXVsdEdlbmVyYXRpb25QYXJhbXM6IEdlbmVyYXRpb25QYXJhbXMiXSwic291cmNlcyI6WyIuLi9zcmMvY29udGV4dHMvc3lzdGVtU2V0dGluZ3NDb250ZXh0L3N5c3RlbVNldHRpbmdzQ29udGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlQXRvbVZhbHVlIH0gZnJvbSBcImpvdGFpXCI7XG5pbXBvcnQge1xuICBEaXNwYXRjaCxcbiAgUmVhY3ROb2RlLFxuICBTZXRTdGF0ZUFjdGlvbixcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlTWVtbyxcbiAgdXNlU3RhdGUsXG59IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgR2VuZXJhdGlvblBhcmFtcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzXCI7XG5pbXBvcnQgeyBiYXNlVXJsQXRvbSB9IGZyb20gXCJzcmMvYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZ1wiO1xuXG4vLyBUT0RPOiBSZWZhY3RvciB0aGlzIHRvIGEgY29tbW9uIHNlcnZpY2UgdGhhdCBoYW5kbGVzIHF1ZXJ5IHBhcmFtcyAoYW5kIHNwaWZmeSB2YXJpYWJsZXMgYWxsIHRvZ2V0aGVyKVxuY29uc3QgZ2V0Q2hhdE1vZGVsTmFtZSA9ICgpID0+IHtcbiAgY29uc3QgdXJsT2JqID0gbmV3IFVSTCh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gIGNvbnN0IHBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXModXJsT2JqLnNlYXJjaCk7XG4gIGNvbnN0IHBhcmFtc09iaiA9IE9iamVjdC5mcm9tRW50cmllcyhwYXJhbXMuZW50cmllcygpKTtcbiAgcmV0dXJuIHBhcmFtc09iai5sbG1fbW9kZWxfbmFtZTtcbn07XG5cbmNvbnN0IGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zOiBHZW5lcmF0aW9uUGFyYW1zID0ge1xuICBzdHJlYW06IHRydWUsXG4gIG51bVN1Z2dlc3Rpb25zOiAzLFxuICBtb2RlbDogZ2V0Q2hhdE1vZGVsTmFtZSgpLFxufTtcblxuaW50ZXJmYWNlIFN5c3RlbVNldHRpbmdzQ29udGV4dFBhcmFtcyB7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xuICBlbmRwb2ludFVSTD86IHN0cmluZztcbiAgc2V0R2VuZXJhdGlvblBhcmFtczogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4+O1xufVxuXG5pbnRlcmZhY2UgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcyB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xufVxuXG5jb25zdCBTeXN0ZW1TZXR0aW5nc0NvbnRleHQgPSBjcmVhdGVDb250ZXh0PFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHRQYXJhbXMgfCB1bmRlZmluZWRcbj4odW5kZWZpbmVkKTtcblxuY29uc3QgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXIgPSAoe1xuICBjaGlsZHJlbixcbiAgZ2VuZXJhdGlvblBhcmFtcyxcbiAgc2hvd0RlYnVnQmFyLFxufTogU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcykgPT4ge1xuICBjb25zdCBbcGFyYW1zLCBzZXRQYXJhbXNdID0gdXNlU3RhdGU8R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4oXG4gICAgKCkgPT4gZ2VuZXJhdGlvblBhcmFtcyA/PyBkZWZhdWx0R2VuZXJhdGlvblBhcmFtc1xuICApO1xuICBjb25zdCBlbmRwb2ludFVSTCA9IHVzZUF0b21WYWx1ZShiYXNlVXJsQXRvbSk7XG4gIGNvbnN0IHNldHRpbmdzQ29udGV4dFZhbHVlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdlbmVyYXRpb25QYXJhbXM6IHBhcmFtcyxcbiAgICAgIHNob3dEZWJ1Z0JhcixcbiAgICAgIHNldEdlbmVyYXRpb25QYXJhbXM6IHNldFBhcmFtcyxcbiAgICAgIGVuZHBvaW50VVJMLFxuICAgIH0pLFxuICAgIFtnZW5lcmF0aW9uUGFyYW1zLCBlbmRwb2ludFVSTCwgc2hvd0RlYnVnQmFyXVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17c2V0dGluZ3NDb250ZXh0VmFsdWVzfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCB7XG4gIFN5c3RlbVNldHRpbmdzQ29udGV4dFByb3ZpZGVyLFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHQsXG4gIGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBYUEsTUFBTSx5QkFBeUI7Q0FDN0IsTUFBTSxTQUFTLElBQUksSUFBSSxPQUFPLFNBQVMsS0FBSztDQUM1QyxNQUFNLFNBQVMsSUFBSSxnQkFBZ0IsT0FBTyxPQUFPO0FBRWpELFFBRGtCLE9BQU8sWUFBWSxPQUFPLFNBQVMsQ0FBQyxDQUNyQzs7QUFHbkIsTUFBTUEsMEJBQTRDO0NBQ2hELFFBQVE7Q0FDUixnQkFBZ0I7Q0FDaEIsT0FBTyxrQkFBa0I7Q0FDMUI7QUFlRCxNQUFNLHdCQUF3QixjQUU1QixPQUFVO0FBRVosTUFBTSxpQ0FBaUMsRUFDckMsVUFDQSxrQkFDQSxtQkFDd0M7Q0FDeEMsTUFBTSxDQUFDLFFBQVEsYUFBYSxlQUNwQixvQkFBb0Isd0JBQzNCO0NBQ0QsTUFBTSxjQUFjLGFBQWEsWUFBWTtDQUM3QyxNQUFNLHdCQUF3QixlQUNyQjtFQUNMLGtCQUFrQjtFQUNsQjtFQUNBLHFCQUFxQjtFQUNyQjtFQUNELEdBQ0Q7RUFBQztFQUFrQjtFQUFhO0VBQWEsQ0FDOUM7QUFFRCxRQUNFLG9CQUFDLHNCQUFzQjtFQUFTLE9BQU87RUFDcEM7R0FDOEIifQ==
39
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVtU2V0dGluZ3NDb250ZXh0LURGMGpTcTltLmpzIiwibmFtZXMiOlsiZGVmYXVsdEdlbmVyYXRpb25QYXJhbXM6IEdlbmVyYXRpb25QYXJhbXMiXSwic291cmNlcyI6WyIuLi9zcmMvY29udGV4dHMvc3lzdGVtU2V0dGluZ3NDb250ZXh0L3N5c3RlbVNldHRpbmdzQ29udGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlQXRvbVZhbHVlIH0gZnJvbSBcImpvdGFpXCI7XG5pbXBvcnQge1xuICBEaXNwYXRjaCxcbiAgUmVhY3ROb2RlLFxuICBTZXRTdGF0ZUFjdGlvbixcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlTWVtbyxcbiAgdXNlU3RhdGUsXG59IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgR2VuZXJhdGlvblBhcmFtcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzXCI7XG5pbXBvcnQgeyBiYXNlVXJsQXRvbSB9IGZyb20gXCJzcmMvYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZ1wiO1xuXG4vLyBUT0RPOiBSZWZhY3RvciB0aGlzIHRvIGEgY29tbW9uIHNlcnZpY2UgdGhhdCBoYW5kbGVzIHF1ZXJ5IHBhcmFtcyAoYW5kIHNwaWZmeSB2YXJpYWJsZXMgYWxsIHRvZ2V0aGVyKVxuY29uc3QgZ2V0Q2hhdE1vZGVsTmFtZSA9ICgpID0+IHtcbiAgY29uc3QgdXJsT2JqID0gbmV3IFVSTCh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gIGNvbnN0IHBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXModXJsT2JqLnNlYXJjaCk7XG4gIGNvbnN0IHBhcmFtc09iaiA9IE9iamVjdC5mcm9tRW50cmllcyhwYXJhbXMuZW50cmllcygpKTtcbiAgcmV0dXJuIHBhcmFtc09iai5sbG1fbW9kZWxfbmFtZTtcbn07XG5cbmNvbnN0IGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zOiBHZW5lcmF0aW9uUGFyYW1zID0ge1xuICBzdHJlYW06IHRydWUsXG4gIG51bVN1Z2dlc3Rpb25zOiAzLFxuICBtb2RlbDogZ2V0Q2hhdE1vZGVsTmFtZSgpLFxufTtcblxuaW50ZXJmYWNlIFN5c3RlbVNldHRpbmdzQ29udGV4dFBhcmFtcyB7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xuICBlbmRwb2ludFVSTD86IHN0cmluZztcbiAgc2V0R2VuZXJhdGlvblBhcmFtczogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4+O1xufVxuXG5pbnRlcmZhY2UgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcyB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xufVxuXG5jb25zdCBTeXN0ZW1TZXR0aW5nc0NvbnRleHQgPSBjcmVhdGVDb250ZXh0PFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHRQYXJhbXMgfCB1bmRlZmluZWRcbj4odW5kZWZpbmVkKTtcblxuY29uc3QgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXIgPSAoe1xuICBjaGlsZHJlbixcbiAgZ2VuZXJhdGlvblBhcmFtcyxcbiAgc2hvd0RlYnVnQmFyLFxufTogU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcykgPT4ge1xuICBjb25zdCBbcGFyYW1zLCBzZXRQYXJhbXNdID0gdXNlU3RhdGU8R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4oXG4gICAgKCkgPT4gZ2VuZXJhdGlvblBhcmFtcyA/PyBkZWZhdWx0R2VuZXJhdGlvblBhcmFtc1xuICApO1xuICBjb25zdCBlbmRwb2ludFVSTCA9IHVzZUF0b21WYWx1ZShiYXNlVXJsQXRvbSk7XG4gIGNvbnN0IHNldHRpbmdzQ29udGV4dFZhbHVlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdlbmVyYXRpb25QYXJhbXM6IHBhcmFtcyxcbiAgICAgIHNob3dEZWJ1Z0JhcixcbiAgICAgIHNldEdlbmVyYXRpb25QYXJhbXM6IHNldFBhcmFtcyxcbiAgICAgIGVuZHBvaW50VVJMLFxuICAgIH0pLFxuICAgIFtnZW5lcmF0aW9uUGFyYW1zLCBlbmRwb2ludFVSTCwgc2hvd0RlYnVnQmFyXVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17c2V0dGluZ3NDb250ZXh0VmFsdWVzfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCB7XG4gIFN5c3RlbVNldHRpbmdzQ29udGV4dFByb3ZpZGVyLFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHQsXG4gIGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBYUEsTUFBTSx5QkFBeUI7Q0FDN0IsTUFBTSxTQUFTLElBQUksSUFBSSxPQUFPLFNBQVMsS0FBSztDQUM1QyxNQUFNLFNBQVMsSUFBSSxnQkFBZ0IsT0FBTyxPQUFPO0FBRWpELFFBRGtCLE9BQU8sWUFBWSxPQUFPLFNBQVMsQ0FBQyxDQUNyQzs7QUFHbkIsTUFBTUEsMEJBQTRDO0NBQ2hELFFBQVE7Q0FDUixnQkFBZ0I7Q0FDaEIsT0FBTyxrQkFBa0I7Q0FDMUI7QUFlRCxNQUFNLHdCQUF3QixjQUU1QixPQUFVO0FBRVosTUFBTSxpQ0FBaUMsRUFDckMsVUFDQSxrQkFDQSxtQkFDd0M7Q0FDeEMsTUFBTSxDQUFDLFFBQVEsYUFBYSxlQUNwQixvQkFBb0Isd0JBQzNCO0NBQ0QsTUFBTSxjQUFjLGFBQWEsWUFBWTtDQUM3QyxNQUFNLHdCQUF3QixlQUNyQjtFQUNMLGtCQUFrQjtFQUNsQjtFQUNBLHFCQUFxQjtFQUNyQjtFQUNELEdBQ0Q7RUFBQztFQUFrQjtFQUFhO0VBQWEsQ0FDOUM7QUFFRCxRQUNFLG9CQUFDLHNCQUFzQjtFQUFTLE9BQU87RUFDcEM7R0FDOEIifQ==
@@ -57,4 +57,4 @@ Object.defineProperty(exports, 'defaultGenerationParams', {
57
57
  return defaultGenerationParams;
58
58
  }
59
59
  });
60
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVtU2V0dGluZ3NDb250ZXh0LWpGSXo5S1M0LmNqcyIsIm5hbWVzIjpbImRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zOiBHZW5lcmF0aW9uUGFyYW1zIiwiYmFzZVVybEF0b20iXSwic291cmNlcyI6WyIuLi9zcmMvY29udGV4dHMvc3lzdGVtU2V0dGluZ3NDb250ZXh0L3N5c3RlbVNldHRpbmdzQ29udGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlQXRvbVZhbHVlIH0gZnJvbSBcImpvdGFpXCI7XG5pbXBvcnQge1xuICBEaXNwYXRjaCxcbiAgUmVhY3ROb2RlLFxuICBTZXRTdGF0ZUFjdGlvbixcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlTWVtbyxcbiAgdXNlU3RhdGUsXG59IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgR2VuZXJhdGlvblBhcmFtcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzXCI7XG5pbXBvcnQgeyBiYXNlVXJsQXRvbSB9IGZyb20gXCJzcmMvYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZ1wiO1xuXG4vLyBUT0RPOiBSZWZhY3RvciB0aGlzIHRvIGEgY29tbW9uIHNlcnZpY2UgdGhhdCBoYW5kbGVzIHF1ZXJ5IHBhcmFtcyAoYW5kIHNwaWZmeSB2YXJpYWJsZXMgYWxsIHRvZ2V0aGVyKVxuY29uc3QgZ2V0Q2hhdE1vZGVsTmFtZSA9ICgpID0+IHtcbiAgY29uc3QgdXJsT2JqID0gbmV3IFVSTCh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gIGNvbnN0IHBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXModXJsT2JqLnNlYXJjaCk7XG4gIGNvbnN0IHBhcmFtc09iaiA9IE9iamVjdC5mcm9tRW50cmllcyhwYXJhbXMuZW50cmllcygpKTtcbiAgcmV0dXJuIHBhcmFtc09iai5sbG1fbW9kZWxfbmFtZTtcbn07XG5cbmNvbnN0IGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zOiBHZW5lcmF0aW9uUGFyYW1zID0ge1xuICBzdHJlYW06IHRydWUsXG4gIG51bVN1Z2dlc3Rpb25zOiAzLFxuICBtb2RlbDogZ2V0Q2hhdE1vZGVsTmFtZSgpLFxufTtcblxuaW50ZXJmYWNlIFN5c3RlbVNldHRpbmdzQ29udGV4dFBhcmFtcyB7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xuICBlbmRwb2ludFVSTD86IHN0cmluZztcbiAgc2V0R2VuZXJhdGlvblBhcmFtczogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4+O1xufVxuXG5pbnRlcmZhY2UgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcyB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xufVxuXG5jb25zdCBTeXN0ZW1TZXR0aW5nc0NvbnRleHQgPSBjcmVhdGVDb250ZXh0PFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHRQYXJhbXMgfCB1bmRlZmluZWRcbj4odW5kZWZpbmVkKTtcblxuY29uc3QgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXIgPSAoe1xuICBjaGlsZHJlbixcbiAgZ2VuZXJhdGlvblBhcmFtcyxcbiAgc2hvd0RlYnVnQmFyLFxufTogU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcykgPT4ge1xuICBjb25zdCBbcGFyYW1zLCBzZXRQYXJhbXNdID0gdXNlU3RhdGU8R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4oXG4gICAgKCkgPT4gZ2VuZXJhdGlvblBhcmFtcyA/PyBkZWZhdWx0R2VuZXJhdGlvblBhcmFtc1xuICApO1xuICBjb25zdCBlbmRwb2ludFVSTCA9IHVzZUF0b21WYWx1ZShiYXNlVXJsQXRvbSk7XG4gIGNvbnN0IHNldHRpbmdzQ29udGV4dFZhbHVlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdlbmVyYXRpb25QYXJhbXM6IHBhcmFtcyxcbiAgICAgIHNob3dEZWJ1Z0JhcixcbiAgICAgIHNldEdlbmVyYXRpb25QYXJhbXM6IHNldFBhcmFtcyxcbiAgICAgIGVuZHBvaW50VVJMLFxuICAgIH0pLFxuICAgIFtnZW5lcmF0aW9uUGFyYW1zLCBlbmRwb2ludFVSTCwgc2hvd0RlYnVnQmFyXVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17c2V0dGluZ3NDb250ZXh0VmFsdWVzfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCB7XG4gIFN5c3RlbVNldHRpbmdzQ29udGV4dFByb3ZpZGVyLFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHQsXG4gIGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQWFBLE1BQU0seUJBQXlCO0NBQzdCLE1BQU0sU0FBUyxJQUFJLElBQUksT0FBTyxTQUFTLEtBQUs7Q0FDNUMsTUFBTSxTQUFTLElBQUksZ0JBQWdCLE9BQU8sT0FBTztBQUVqRCxRQURrQixPQUFPLFlBQVksT0FBTyxTQUFTLENBQUMsQ0FDckM7O0FBR25CLE1BQU1BLDBCQUE0QztDQUNoRCxRQUFRO0NBQ1IsZ0JBQWdCO0NBQ2hCLE9BQU8sa0JBQWtCO0NBQzFCO0FBZUQsTUFBTSxpREFFSixPQUFVO0FBRVosTUFBTSxpQ0FBaUMsRUFDckMsVUFDQSxrQkFDQSxtQkFDd0M7Q0FDeEMsTUFBTSxDQUFDLFFBQVEsdUNBQ1Asb0JBQW9CLHdCQUMzQjtDQUNELE1BQU0sc0NBQTJCQyxpQ0FBWTtDQUM3QyxNQUFNLGtEQUNHO0VBQ0wsa0JBQWtCO0VBQ2xCO0VBQ0EscUJBQXFCO0VBQ3JCO0VBQ0QsR0FDRDtFQUFDO0VBQWtCO0VBQWE7RUFBYSxDQUM5QztBQUVELFFBQ0UsMkNBQUMsc0JBQXNCO0VBQVMsT0FBTztFQUNwQztHQUM4QiJ9
60
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVtU2V0dGluZ3NDb250ZXh0LWRtRTF2Nnc4LmNqcyIsIm5hbWVzIjpbImRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zOiBHZW5lcmF0aW9uUGFyYW1zIiwiYmFzZVVybEF0b20iXSwic291cmNlcyI6WyIuLi9zcmMvY29udGV4dHMvc3lzdGVtU2V0dGluZ3NDb250ZXh0L3N5c3RlbVNldHRpbmdzQ29udGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlQXRvbVZhbHVlIH0gZnJvbSBcImpvdGFpXCI7XG5pbXBvcnQge1xuICBEaXNwYXRjaCxcbiAgUmVhY3ROb2RlLFxuICBTZXRTdGF0ZUFjdGlvbixcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlTWVtbyxcbiAgdXNlU3RhdGUsXG59IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgR2VuZXJhdGlvblBhcmFtcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzXCI7XG5pbXBvcnQgeyBiYXNlVXJsQXRvbSB9IGZyb20gXCJzcmMvYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZ1wiO1xuXG4vLyBUT0RPOiBSZWZhY3RvciB0aGlzIHRvIGEgY29tbW9uIHNlcnZpY2UgdGhhdCBoYW5kbGVzIHF1ZXJ5IHBhcmFtcyAoYW5kIHNwaWZmeSB2YXJpYWJsZXMgYWxsIHRvZ2V0aGVyKVxuY29uc3QgZ2V0Q2hhdE1vZGVsTmFtZSA9ICgpID0+IHtcbiAgY29uc3QgdXJsT2JqID0gbmV3IFVSTCh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gIGNvbnN0IHBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXModXJsT2JqLnNlYXJjaCk7XG4gIGNvbnN0IHBhcmFtc09iaiA9IE9iamVjdC5mcm9tRW50cmllcyhwYXJhbXMuZW50cmllcygpKTtcbiAgcmV0dXJuIHBhcmFtc09iai5sbG1fbW9kZWxfbmFtZTtcbn07XG5cbmNvbnN0IGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zOiBHZW5lcmF0aW9uUGFyYW1zID0ge1xuICBzdHJlYW06IHRydWUsXG4gIG51bVN1Z2dlc3Rpb25zOiAzLFxuICBtb2RlbDogZ2V0Q2hhdE1vZGVsTmFtZSgpLFxufTtcblxuaW50ZXJmYWNlIFN5c3RlbVNldHRpbmdzQ29udGV4dFBhcmFtcyB7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xuICBlbmRwb2ludFVSTD86IHN0cmluZztcbiAgc2V0R2VuZXJhdGlvblBhcmFtczogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4+O1xufVxuXG5pbnRlcmZhY2UgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcyB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGdlbmVyYXRpb25QYXJhbXM/OiBHZW5lcmF0aW9uUGFyYW1zO1xuICBzaG93RGVidWdCYXI/OiBib29sZWFuO1xufVxuXG5jb25zdCBTeXN0ZW1TZXR0aW5nc0NvbnRleHQgPSBjcmVhdGVDb250ZXh0PFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHRQYXJhbXMgfCB1bmRlZmluZWRcbj4odW5kZWZpbmVkKTtcblxuY29uc3QgU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXIgPSAoe1xuICBjaGlsZHJlbixcbiAgZ2VuZXJhdGlvblBhcmFtcyxcbiAgc2hvd0RlYnVnQmFyLFxufTogU3lzdGVtU2V0dGluZ3NDb250ZXh0UHJvdmlkZXJQcm9wcykgPT4ge1xuICBjb25zdCBbcGFyYW1zLCBzZXRQYXJhbXNdID0gdXNlU3RhdGU8R2VuZXJhdGlvblBhcmFtcyB8IHVuZGVmaW5lZD4oXG4gICAgKCkgPT4gZ2VuZXJhdGlvblBhcmFtcyA/PyBkZWZhdWx0R2VuZXJhdGlvblBhcmFtc1xuICApO1xuICBjb25zdCBlbmRwb2ludFVSTCA9IHVzZUF0b21WYWx1ZShiYXNlVXJsQXRvbSk7XG4gIGNvbnN0IHNldHRpbmdzQ29udGV4dFZhbHVlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdlbmVyYXRpb25QYXJhbXM6IHBhcmFtcyxcbiAgICAgIHNob3dEZWJ1Z0JhcixcbiAgICAgIHNldEdlbmVyYXRpb25QYXJhbXM6IHNldFBhcmFtcyxcbiAgICAgIGVuZHBvaW50VVJMLFxuICAgIH0pLFxuICAgIFtnZW5lcmF0aW9uUGFyYW1zLCBlbmRwb2ludFVSTCwgc2hvd0RlYnVnQmFyXVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17c2V0dGluZ3NDb250ZXh0VmFsdWVzfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N5c3RlbVNldHRpbmdzQ29udGV4dC5Qcm92aWRlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCB7XG4gIFN5c3RlbVNldHRpbmdzQ29udGV4dFByb3ZpZGVyLFxuICBTeXN0ZW1TZXR0aW5nc0NvbnRleHQsXG4gIGRlZmF1bHRHZW5lcmF0aW9uUGFyYW1zLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQWFBLE1BQU0seUJBQXlCO0NBQzdCLE1BQU0sU0FBUyxJQUFJLElBQUksT0FBTyxTQUFTLEtBQUs7Q0FDNUMsTUFBTSxTQUFTLElBQUksZ0JBQWdCLE9BQU8sT0FBTztBQUVqRCxRQURrQixPQUFPLFlBQVksT0FBTyxTQUFTLENBQUMsQ0FDckM7O0FBR25CLE1BQU1BLDBCQUE0QztDQUNoRCxRQUFRO0NBQ1IsZ0JBQWdCO0NBQ2hCLE9BQU8sa0JBQWtCO0NBQzFCO0FBZUQsTUFBTSxpREFFSixPQUFVO0FBRVosTUFBTSxpQ0FBaUMsRUFDckMsVUFDQSxrQkFDQSxtQkFDd0M7Q0FDeEMsTUFBTSxDQUFDLFFBQVEsdUNBQ1Asb0JBQW9CLHdCQUMzQjtDQUNELE1BQU0sc0NBQTJCQyxpQ0FBWTtDQUM3QyxNQUFNLGtEQUNHO0VBQ0wsa0JBQWtCO0VBQ2xCO0VBQ0EscUJBQXFCO0VBQ3JCO0VBQ0QsR0FDRDtFQUFDO0VBQWtCO0VBQWE7RUFBYSxDQUM5QztBQUVELFFBQ0UsMkNBQUMsc0JBQXNCO0VBQVMsT0FBTztFQUNwQztHQUM4QiJ9
@@ -45,4 +45,4 @@ Object.defineProperty(exports, 'ProductSortingNames', {
45
45
  return ProductSortingNames;
46
46
  }
47
47
  });
48
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMtQnV2WFhHeEUuY2pzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uL3NyYy9hdG9tcy9zZWFyY2gvdHlwZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2VhcmNoUmVzcG9uc2VQcm9kdWN0QXR0cmlidXRlcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9yZXNwb25zZVwiO1xuXG5leHBvcnQgZW51bSBQcm9kdWN0U29ydGluZyB7XG4gIEZFQVRVUkVEID0gJ2ZlYXR1cmVkJyxcbiAgUFJJQ0VfQVNDID0gJ3ByaWNlX2FzYycsXG4gIFBSSUNFX0RFU0MgPSAncHJpY2VfZGVzYycsXG59XG5cbmV4cG9ydCBjb25zdCBQcm9kdWN0U29ydGluZ05hbWVzID0ge1xuICBbUHJvZHVjdFNvcnRpbmcuRkVBVFVSRURdOiAnRmVhdHVyZWQnLFxuICBbUHJvZHVjdFNvcnRpbmcuUFJJQ0VfQVNDXTogJ1ByaWNlIExvdyB0byBIaWdoJyxcbiAgW1Byb2R1Y3RTb3J0aW5nLlBSSUNFX0RFU0NdOiAnUHJpY2UgSGlnaCB0byBMb3cnLFxufTtcblxuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaFN0YXRlVHlwZSA9ICdlbnRyeXBvaW50JyB8ICdpbml0aWFsaXppbmctc2VhcmNoJyB8ICdwcm9kdWN0LXBhZ2UnO1xuXG5leHBvcnQgdHlwZSBDaGF0U2VhcmNoRmlsdGVyID0ge1xuICBmaWx0ZXJJZDogc3RyaW5nO1xuICBkaXNwbGF5TmFtZTogc3RyaW5nO1xuICBpdGVtczogQ2hhdFNlYXJjaEZpbHRlckl0ZW1bXTtcbn07XG5cbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hGaWx0ZXJJdGVtID0ge1xuICBmaWx0ZXJJdGVtSWQ6IHN0cmluZztcbiAgZGlzcGxheU5hbWU6IHN0cmluZztcbiAgcHJvZHVjdENvdW50OiBudW1iZXI7XG4gIGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICBvcHRpb25zOiBQcm9kdWN0U29ydGluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0TW9kYWxQcm9wcyBleHRlbmRzIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICBvcGVuOiBib29sZWFuO1xuICBoYW5kbGVQb3B1cFN0YXRlOiAoc3RhdGU6IGJvb2xlYW4pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU29ydE9wdGlvbiB7XG4gIHZhbHVlOiBQcm9kdWN0U29ydGluZztcbiAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbiAgb25TZWxlY3Q6IChvcHRpb246IFByb2R1Y3RTb3J0aW5nKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgZW51bSBDaGF0U2VhcmNoU29ydE92ZXJyaWRlcyB7XG4gIERFU0tUT1BfRklMVEVSX0NPTlRBSU5FUiA9ICdzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLWNvbnRhaW5lcicsXG4gIERFU0tUT1BfRklMVEVSX1NFTEVDVF9DT01QT05FTlQgPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1zZWxlY3QtY29tcG9uZW50JyxcbiAgREVTS1RPUF9GSUxURVJfU0VMRUNUX0lDT04gPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1zZWxlY3QtaWNvbicsXG4gIE1PQklMRV9GSUxURVJfQlVUVE9OID0gJ3NwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItYnV0dG9uJyxcbiAgTU9CSUxFX0ZJTFRFUl9NT0RBTF9DT05UQUlORVIgPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1jb250YWluZXInLFxuICBNT0JJTEVfRklMVEVSX01PREFMX0hFQURFUiA9ICdzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLWhlYWRlcicsXG4gIE1PQklMRV9GSUxURVJfTU9EQUxfU0VMRUNUSU9OID0gJ3NwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItbW9kYWwtc2VsZWN0aW9uJyxcbiAgTU9CSUxFX0ZJTFRFUl9NT0RBTF9PUFRJT04gPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1vcHRpb24nLFxuICBNT0JJTEVfRklMVEVSX01PREFMX09QVElPTl9QSUxMID0gJ3NwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItbW9kYWwtb3B0aW9uLXBpbGwnLFxuICBNT0JJTEVfRklMVEVSX01PREFMX09QVElPTl9ERVNDUklQVElPTiA9ICdzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLW9wdGlvbi1kZXNjJyxcbiAgTU9CSUxFX0ZJTFRFUl9NT0RBTF9BUFBMWV9CVVRUT04gPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1hcHBseS1idXR0b24nLFxufVxuXG4vLyBDdXN0b20gcHJvZHVjdCByZXRyaWV2YWwgcmVzdWx0IGludGVyZmFjZVxuZXhwb3J0IGludGVyZmFjZSBQcm9kdWN0UmV0cmlldmFsUmVzdWx0IHtcbiAgcHJvZHVjdHM6IFNlYXJjaFJlc3BvbnNlUHJvZHVjdEF0dHJpYnV0ZXNbJ2F0dHJpYnV0ZXMnXVtdO1xuICB0b3RhbFByb2R1Y3RDb3VudDogbnVtYmVyO1xufVxuXG4vLyBQcm9kdWN0IHJldHJpZXZhbCBwYXJhbWV0ZXJzIGludGVyZmFjZVxuZXhwb3J0IGludGVyZmFjZSBQcm9kdWN0UmV0cmlldmFsUGFyYW1zIHtcbiAgcHJvZHVjdElkczogc3RyaW5nW107XG59Il0sIm1hcHBpbmdzIjoiOztBQUVBLElBQVksNERBQUw7QUFDTDtBQUNBO0FBQ0E7OztBQUdGLE1BQWEsc0JBQXNCO0VBQ2hDLGVBQWUsV0FBVztFQUMxQixlQUFlLFlBQVk7RUFDM0IsZUFBZSxhQUFhO0NBQzlCO0FBZ0NELElBQVksOEVBQUw7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIn0=
48
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMtQzR1V1BKWXEuY2pzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uL3NyYy9hdG9tcy9zZWFyY2gvdHlwZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2VhcmNoUmVzcG9uc2VQcm9kdWN0QXR0cmlidXRlcyB9IGZyb20gXCJzcmMvYXBwbGljYXRpb24vbW9kZWxzL2FwaS9yZXNwb25zZVwiO1xuXG5leHBvcnQgZW51bSBQcm9kdWN0U29ydGluZyB7XG4gIEZFQVRVUkVEID0gJ2ZlYXR1cmVkJyxcbiAgUFJJQ0VfQVNDID0gJ3ByaWNlX2FzYycsXG4gIFBSSUNFX0RFU0MgPSAncHJpY2VfZGVzYycsXG59XG5cbmV4cG9ydCBjb25zdCBQcm9kdWN0U29ydGluZ05hbWVzID0ge1xuICBbUHJvZHVjdFNvcnRpbmcuRkVBVFVSRURdOiAnRmVhdHVyZWQnLFxuICBbUHJvZHVjdFNvcnRpbmcuUFJJQ0VfQVNDXTogJ1ByaWNlIExvdyB0byBIaWdoJyxcbiAgW1Byb2R1Y3RTb3J0aW5nLlBSSUNFX0RFU0NdOiAnUHJpY2UgSGlnaCB0byBMb3cnLFxufTtcblxuZXhwb3J0IHR5cGUgQ2hhdFNlYXJjaFN0YXRlVHlwZSA9ICdlbnRyeXBvaW50JyB8ICdpbml0aWFsaXppbmctc2VhcmNoJyB8ICdwcm9kdWN0LXBhZ2UnO1xuXG5leHBvcnQgdHlwZSBDaGF0U2VhcmNoRmlsdGVyID0ge1xuICBmaWx0ZXJJZDogc3RyaW5nO1xuICBkaXNwbGF5TmFtZTogc3RyaW5nO1xuICBpdGVtczogQ2hhdFNlYXJjaEZpbHRlckl0ZW1bXTtcbn07XG5cbmV4cG9ydCB0eXBlIENoYXRTZWFyY2hGaWx0ZXJJdGVtID0ge1xuICBmaWx0ZXJJdGVtSWQ6IHN0cmluZztcbiAgZGlzcGxheU5hbWU6IHN0cmluZztcbiAgcHJvZHVjdENvdW50OiBudW1iZXI7XG4gIGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICBvcHRpb25zOiBQcm9kdWN0U29ydGluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZWFyY2hTb3J0TW9kYWxQcm9wcyBleHRlbmRzIENoYXRTZWFyY2hTb3J0UHJvcHMge1xuICBvcGVuOiBib29sZWFuO1xuICBoYW5kbGVQb3B1cFN0YXRlOiAoc3RhdGU6IGJvb2xlYW4pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU29ydE9wdGlvbiB7XG4gIHZhbHVlOiBQcm9kdWN0U29ydGluZztcbiAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbiAgb25TZWxlY3Q6IChvcHRpb246IFByb2R1Y3RTb3J0aW5nKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgZW51bSBDaGF0U2VhcmNoU29ydE92ZXJyaWRlcyB7XG4gIERFU0tUT1BfRklMVEVSX0NPTlRBSU5FUiA9ICdzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLWNvbnRhaW5lcicsXG4gIERFU0tUT1BfRklMVEVSX1NFTEVDVF9DT01QT05FTlQgPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1zZWxlY3QtY29tcG9uZW50JyxcbiAgREVTS1RPUF9GSUxURVJfU0VMRUNUX0lDT04gPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1zZWxlY3QtaWNvbicsXG4gIE1PQklMRV9GSUxURVJfQlVUVE9OID0gJ3NwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItYnV0dG9uJyxcbiAgTU9CSUxFX0ZJTFRFUl9NT0RBTF9DT05UQUlORVIgPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1jb250YWluZXInLFxuICBNT0JJTEVfRklMVEVSX01PREFMX0hFQURFUiA9ICdzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLWhlYWRlcicsXG4gIE1PQklMRV9GSUxURVJfTU9EQUxfU0VMRUNUSU9OID0gJ3NwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItbW9kYWwtc2VsZWN0aW9uJyxcbiAgTU9CSUxFX0ZJTFRFUl9NT0RBTF9PUFRJT04gPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1vcHRpb24nLFxuICBNT0JJTEVfRklMVEVSX01PREFMX09QVElPTl9QSUxMID0gJ3NwaWZmeS1jaGF0LXNlYXJjaC1maWx0ZXItbW9kYWwtb3B0aW9uLXBpbGwnLFxuICBNT0JJTEVfRklMVEVSX01PREFMX09QVElPTl9ERVNDUklQVElPTiA9ICdzcGlmZnktY2hhdC1zZWFyY2gtZmlsdGVyLW1vZGFsLW9wdGlvbi1kZXNjJyxcbiAgTU9CSUxFX0ZJTFRFUl9NT0RBTF9BUFBMWV9CVVRUT04gPSAnc3BpZmZ5LWNoYXQtc2VhcmNoLWZpbHRlci1tb2RhbC1hcHBseS1idXR0b24nLFxufVxuXG4vLyBDdXN0b20gcHJvZHVjdCByZXRyaWV2YWwgcmVzdWx0IGludGVyZmFjZVxuZXhwb3J0IGludGVyZmFjZSBQcm9kdWN0UmV0cmlldmFsUmVzdWx0IHtcbiAgcHJvZHVjdHM6IFNlYXJjaFJlc3BvbnNlUHJvZHVjdEF0dHJpYnV0ZXNbJ2F0dHJpYnV0ZXMnXVtdO1xuICB0b3RhbFByb2R1Y3RDb3VudDogbnVtYmVyO1xufVxuXG4vLyBQcm9kdWN0IHJldHJpZXZhbCBwYXJhbWV0ZXJzIGludGVyZmFjZVxuZXhwb3J0IGludGVyZmFjZSBQcm9kdWN0UmV0cmlldmFsUGFyYW1zIHtcbiAgcHJvZHVjdElkczogc3RyaW5nW107XG59Il0sIm1hcHBpbmdzIjoiOztBQUVBLElBQVksNERBQUw7QUFDTDtBQUNBO0FBQ0E7OztBQUdGLE1BQWEsc0JBQXNCO0VBQ2hDLGVBQWUsV0FBVztFQUMxQixlQUFlLFlBQVk7RUFDM0IsZUFBZSxhQUFhO0NBQzlCO0FBZ0NELElBQVksOEVBQUw7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIn0=