@quillsql/admin 1.6.3 → 1.6.4

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 (193) hide show
  1. package/dist/cjs/Admin.d.ts +3 -0
  2. package/dist/cjs/Admin.d.ts.map +1 -1
  3. package/dist/cjs/Admin.js +20 -18
  4. package/dist/cjs/AdminProvider.d.ts +3 -1
  5. package/dist/cjs/AdminProvider.d.ts.map +1 -1
  6. package/dist/cjs/AdminProvider.js +3 -2
  7. package/dist/cjs/api/ConnectionClient.d.ts +21 -10
  8. package/dist/cjs/api/ConnectionClient.d.ts.map +1 -1
  9. package/dist/cjs/api/ConnectionClient.js +138 -31
  10. package/dist/cjs/components/CardSection.d.ts.map +1 -1
  11. package/dist/cjs/components/CardSection.js +4 -2
  12. package/dist/cjs/components/DashboardSelectPopover.d.ts.map +1 -1
  13. package/dist/cjs/components/DashboardSelectPopover.js +17 -6
  14. package/dist/cjs/components/DatabaseSelector.d.ts +3 -1
  15. package/dist/cjs/components/DatabaseSelector.d.ts.map +1 -1
  16. package/dist/cjs/components/DatabaseSelector.js +3 -2
  17. package/dist/cjs/components/DateRangePicker/SingleDatePicker.d.ts.map +1 -1
  18. package/dist/cjs/components/DateRangePicker/SingleDatePicker.js +31 -7
  19. package/dist/cjs/components/DateRangePicker/YearlessDateRangePicker.d.ts.map +1 -1
  20. package/dist/cjs/components/DateRangePicker/YearlessDateRangePicker.js +31 -7
  21. package/dist/cjs/components/DropDownMenuWithLabel.d.ts.map +1 -1
  22. package/dist/cjs/components/DropDownMenuWithLabel.js +8 -1
  23. package/dist/cjs/components/DynamicBanner.d.ts +3 -2
  24. package/dist/cjs/components/DynamicBanner.d.ts.map +1 -1
  25. package/dist/cjs/components/DynamicBanner.js +7 -2
  26. package/dist/cjs/components/EmptyDashboardComponent/index.d.ts.map +1 -1
  27. package/dist/cjs/components/EmptyDashboardComponent/index.js +3 -2
  28. package/dist/cjs/components/EmptyVirtualTablesComponent.d.ts.map +1 -1
  29. package/dist/cjs/components/EmptyVirtualTablesComponent.js +4 -1
  30. package/dist/cjs/components/FormTooltip.d.ts.map +1 -1
  31. package/dist/cjs/components/FormTooltip.js +4 -1
  32. package/dist/cjs/components/InputLabel.d.ts.map +1 -1
  33. package/dist/cjs/components/InputLabel.js +4 -2
  34. package/dist/cjs/components/InternalDashboard/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  35. package/dist/cjs/components/InternalDashboard/DateRangePicker/QuillDateRangePicker.js +33 -14
  36. package/dist/cjs/components/InternalDashboard/InternalDashboard.d.ts.map +1 -1
  37. package/dist/cjs/components/InternalDashboard/InternalDashboard.js +14 -1
  38. package/dist/cjs/components/OrgSelect.d.ts +0 -6
  39. package/dist/cjs/components/OrgSelect.d.ts.map +1 -1
  40. package/dist/cjs/components/OrgSelect.js +32 -44
  41. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts +3 -1
  42. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  43. package/dist/cjs/components/QuillMultiSelectWithCombo.js +27 -22
  44. package/dist/cjs/components/QuillPopover.d.ts.map +1 -1
  45. package/dist/cjs/components/QuillPopover.js +4 -5
  46. package/dist/cjs/components/QuillSelect.js +9 -9
  47. package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
  48. package/dist/cjs/components/QuillSelectWithCombo.js +13 -15
  49. package/dist/cjs/components/Tenants/EditTenant.d.ts.map +1 -1
  50. package/dist/cjs/components/Tenants/EditTenant.js +2 -2
  51. package/dist/cjs/components/UiComponents.d.ts +16 -43
  52. package/dist/cjs/components/UiComponents.d.ts.map +1 -1
  53. package/dist/cjs/components/UiComponents.js +161 -33
  54. package/dist/cjs/forms/client_onboard/ConnectDatabase.d.ts.map +1 -1
  55. package/dist/cjs/forms/client_onboard/ConnectDatabase.js +113 -49
  56. package/dist/cjs/forms/client_onboard/ConnectSchema.d.ts.map +1 -1
  57. package/dist/cjs/forms/client_onboard/ConnectSchema.js +3 -1
  58. package/dist/cjs/forms/client_onboard/CreateVirtualTables.d.ts.map +1 -1
  59. package/dist/cjs/forms/client_onboard/CreateVirtualTables.js +6 -2
  60. package/dist/cjs/forms/client_onboard/__tests__/ConnectSchema.test.js +1 -0
  61. package/dist/cjs/forms/client_onboard/__tests__/CreateVirtualTables.test.js +1 -0
  62. package/dist/cjs/forms/virtual_tables/CreateEditVirtualTable.d.ts.map +1 -1
  63. package/dist/cjs/forms/virtual_tables/CreateEditVirtualTable.js +10 -6
  64. package/dist/cjs/hooks/useDatabaseSchema.d.ts.map +1 -1
  65. package/dist/cjs/hooks/useDatabaseSchema.js +6 -1
  66. package/dist/cjs/modals/EditEnvironmentModal.d.ts.map +1 -1
  67. package/dist/cjs/modals/EditEnvironmentModal.js +7 -2
  68. package/dist/cjs/modals/EditFiltersModal.js +7 -7
  69. package/dist/cjs/primitives/ButtonPrimitive.d.ts.map +1 -1
  70. package/dist/cjs/primitives/ButtonPrimitive.js +10 -6
  71. package/dist/cjs/primitives/HeaderPrimitive.d.ts.map +1 -1
  72. package/dist/cjs/primitives/HeaderPrimitive.js +11 -7
  73. package/dist/cjs/primitives/PopoverPrimitive.d.ts.map +1 -1
  74. package/dist/cjs/primitives/PopoverPrimitive.js +3 -1
  75. package/dist/cjs/primitives/SecondaryButtonPrimitive.d.ts.map +1 -1
  76. package/dist/cjs/primitives/SecondaryButtonPrimitive.js +5 -3
  77. package/dist/cjs/public_components/ChartQueryBuilder.d.ts.map +1 -1
  78. package/dist/cjs/public_components/ChartQueryBuilder.js +13 -3
  79. package/dist/cjs/public_components/CreateEnvironment.d.ts.map +1 -1
  80. package/dist/cjs/public_components/CreateEnvironment.js +20 -15
  81. package/dist/cjs/public_components/DashboardManager.d.ts.map +1 -1
  82. package/dist/cjs/public_components/DashboardManager.js +10 -1
  83. package/dist/cjs/public_components/EnvSelectPopover.d.ts +2 -1
  84. package/dist/cjs/public_components/EnvSelectPopover.d.ts.map +1 -1
  85. package/dist/cjs/public_components/EnvSelectPopover.js +19 -7
  86. package/dist/cjs/public_components/VirtualTableManager.d.ts.map +1 -1
  87. package/dist/cjs/public_components/VirtualTableManager.js +32 -8
  88. package/dist/cjs/utils/columnProcessing.d.ts +1 -0
  89. package/dist/cjs/utils/columnProcessing.d.ts.map +1 -1
  90. package/dist/cjs/utils/columnProcessing.js +1 -0
  91. package/dist/cjs/utils/constants.d.ts +1 -0
  92. package/dist/cjs/utils/constants.d.ts.map +1 -1
  93. package/dist/cjs/utils/constants.js +5 -1
  94. package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
  95. package/dist/cjs/utils/dataFetcher.js +0 -1
  96. package/dist/cjs/utils/databases.js +5 -5
  97. package/dist/esm/Admin.d.ts +3 -0
  98. package/dist/esm/Admin.d.ts.map +1 -1
  99. package/dist/esm/Admin.js +20 -18
  100. package/dist/esm/AdminProvider.d.ts +3 -1
  101. package/dist/esm/AdminProvider.d.ts.map +1 -1
  102. package/dist/esm/AdminProvider.js +5 -4
  103. package/dist/esm/api/ConnectionClient.d.ts +21 -10
  104. package/dist/esm/api/ConnectionClient.d.ts.map +1 -1
  105. package/dist/esm/api/ConnectionClient.js +136 -31
  106. package/dist/esm/components/CardSection.d.ts.map +1 -1
  107. package/dist/esm/components/CardSection.js +4 -2
  108. package/dist/esm/components/DashboardSelectPopover.d.ts.map +1 -1
  109. package/dist/esm/components/DashboardSelectPopover.js +18 -7
  110. package/dist/esm/components/DatabaseSelector.d.ts +3 -1
  111. package/dist/esm/components/DatabaseSelector.d.ts.map +1 -1
  112. package/dist/esm/components/DatabaseSelector.js +3 -2
  113. package/dist/esm/components/DateRangePicker/SingleDatePicker.d.ts.map +1 -1
  114. package/dist/esm/components/DateRangePicker/SingleDatePicker.js +31 -7
  115. package/dist/esm/components/DateRangePicker/YearlessDateRangePicker.d.ts.map +1 -1
  116. package/dist/esm/components/DateRangePicker/YearlessDateRangePicker.js +31 -7
  117. package/dist/esm/components/DropDownMenuWithLabel.d.ts.map +1 -1
  118. package/dist/esm/components/DropDownMenuWithLabel.js +9 -2
  119. package/dist/esm/components/DynamicBanner.d.ts +3 -2
  120. package/dist/esm/components/DynamicBanner.d.ts.map +1 -1
  121. package/dist/esm/components/DynamicBanner.js +7 -2
  122. package/dist/esm/components/EmptyDashboardComponent/index.d.ts.map +1 -1
  123. package/dist/esm/components/EmptyDashboardComponent/index.js +3 -2
  124. package/dist/esm/components/EmptyVirtualTablesComponent.d.ts.map +1 -1
  125. package/dist/esm/components/EmptyVirtualTablesComponent.js +4 -1
  126. package/dist/esm/components/FormTooltip.d.ts.map +1 -1
  127. package/dist/esm/components/FormTooltip.js +4 -1
  128. package/dist/esm/components/InputLabel.d.ts.map +1 -1
  129. package/dist/esm/components/InputLabel.js +4 -2
  130. package/dist/esm/components/InternalDashboard/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  131. package/dist/esm/components/InternalDashboard/DateRangePicker/QuillDateRangePicker.js +33 -11
  132. package/dist/esm/components/InternalDashboard/InternalDashboard.d.ts.map +1 -1
  133. package/dist/esm/components/InternalDashboard/InternalDashboard.js +14 -1
  134. package/dist/esm/components/OrgSelect.d.ts +0 -6
  135. package/dist/esm/components/OrgSelect.d.ts.map +1 -1
  136. package/dist/esm/components/OrgSelect.js +32 -42
  137. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts +3 -1
  138. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  139. package/dist/esm/components/QuillMultiSelectWithCombo.js +27 -22
  140. package/dist/esm/components/QuillPopover.d.ts.map +1 -1
  141. package/dist/esm/components/QuillPopover.js +4 -5
  142. package/dist/esm/components/QuillSelect.js +9 -9
  143. package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
  144. package/dist/esm/components/QuillSelectWithCombo.js +13 -15
  145. package/dist/esm/components/Tenants/EditTenant.d.ts.map +1 -1
  146. package/dist/esm/components/Tenants/EditTenant.js +2 -2
  147. package/dist/esm/components/UiComponents.d.ts +16 -43
  148. package/dist/esm/components/UiComponents.d.ts.map +1 -1
  149. package/dist/esm/components/UiComponents.js +126 -29
  150. package/dist/esm/forms/client_onboard/ConnectDatabase.d.ts.map +1 -1
  151. package/dist/esm/forms/client_onboard/ConnectDatabase.js +113 -49
  152. package/dist/esm/forms/client_onboard/ConnectSchema.d.ts.map +1 -1
  153. package/dist/esm/forms/client_onboard/ConnectSchema.js +3 -1
  154. package/dist/esm/forms/client_onboard/CreateVirtualTables.d.ts.map +1 -1
  155. package/dist/esm/forms/client_onboard/CreateVirtualTables.js +6 -2
  156. package/dist/esm/forms/client_onboard/__tests__/ConnectSchema.test.js +1 -0
  157. package/dist/esm/forms/client_onboard/__tests__/CreateVirtualTables.test.js +1 -0
  158. package/dist/esm/forms/virtual_tables/CreateEditVirtualTable.d.ts.map +1 -1
  159. package/dist/esm/forms/virtual_tables/CreateEditVirtualTable.js +11 -7
  160. package/dist/esm/hooks/useDatabaseSchema.d.ts.map +1 -1
  161. package/dist/esm/hooks/useDatabaseSchema.js +7 -2
  162. package/dist/esm/modals/EditEnvironmentModal.d.ts.map +1 -1
  163. package/dist/esm/modals/EditEnvironmentModal.js +7 -2
  164. package/dist/esm/modals/EditFiltersModal.js +8 -8
  165. package/dist/esm/primitives/ButtonPrimitive.d.ts.map +1 -1
  166. package/dist/esm/primitives/ButtonPrimitive.js +10 -6
  167. package/dist/esm/primitives/HeaderPrimitive.d.ts.map +1 -1
  168. package/dist/esm/primitives/HeaderPrimitive.js +11 -7
  169. package/dist/esm/primitives/PopoverPrimitive.d.ts.map +1 -1
  170. package/dist/esm/primitives/PopoverPrimitive.js +3 -1
  171. package/dist/esm/primitives/SecondaryButtonPrimitive.d.ts.map +1 -1
  172. package/dist/esm/primitives/SecondaryButtonPrimitive.js +5 -3
  173. package/dist/esm/public_components/ChartQueryBuilder.d.ts.map +1 -1
  174. package/dist/esm/public_components/ChartQueryBuilder.js +14 -4
  175. package/dist/esm/public_components/CreateEnvironment.d.ts.map +1 -1
  176. package/dist/esm/public_components/CreateEnvironment.js +20 -15
  177. package/dist/esm/public_components/DashboardManager.d.ts.map +1 -1
  178. package/dist/esm/public_components/DashboardManager.js +10 -1
  179. package/dist/esm/public_components/EnvSelectPopover.d.ts +2 -1
  180. package/dist/esm/public_components/EnvSelectPopover.d.ts.map +1 -1
  181. package/dist/esm/public_components/EnvSelectPopover.js +20 -8
  182. package/dist/esm/public_components/VirtualTableManager.d.ts.map +1 -1
  183. package/dist/esm/public_components/VirtualTableManager.js +33 -9
  184. package/dist/esm/utils/columnProcessing.d.ts +1 -0
  185. package/dist/esm/utils/columnProcessing.d.ts.map +1 -1
  186. package/dist/esm/utils/columnProcessing.js +1 -1
  187. package/dist/esm/utils/constants.d.ts +1 -0
  188. package/dist/esm/utils/constants.d.ts.map +1 -1
  189. package/dist/esm/utils/constants.js +4 -0
  190. package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
  191. package/dist/esm/utils/dataFetcher.js +0 -1
  192. package/dist/esm/utils/databases.js +5 -5
  193. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"HeaderPrimitive.d.ts","sourceRoot":"","sources":["../../../src/primitives/HeaderPrimitive.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAgB,MAAM,UAAU,CAAC;AAEpD,KAAK,oBAAoB,GAAG;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,UAAU,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAcnD,CAAC;AAEF,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"HeaderPrimitive.d.ts","sourceRoot":"","sources":["../../../src/primitives/HeaderPrimitive.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGtC,KAAK,oBAAoB,GAAG;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,UAAU,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAiBnD,CAAC;AAEF,eAAe,eAAe,CAAC"}
@@ -1,9 +1,13 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import { defaultTheme } from '../Admin';
3
- const HeaderPrimitive = ({ label, theme = defaultTheme, }) => (_jsx("h1", { style: {
4
- color: theme?.primaryTextColor,
5
- fontFamily: theme?.fontFamily,
6
- fontWeight: theme?.buttonFontWeight || 600,
7
- fontSize: 24,
8
- }, children: label }));
2
+ import { useAdmin } from '../AdminProvider';
3
+ const HeaderPrimitive = ({ label, theme }) => {
4
+ const { state: { theme: stateTheme }, } = useAdmin();
5
+ theme = theme ?? stateTheme;
6
+ return (_jsx("h1", { style: {
7
+ color: theme?.primaryTextColor,
8
+ fontFamily: theme?.fontFamily,
9
+ fontWeight: theme?.buttonFontWeight || 600,
10
+ fontSize: 24,
11
+ }, children: label }));
12
+ };
9
13
  export default HeaderPrimitive;
@@ -1 +1 @@
1
- {"version":3,"file":"PopoverPrimitive.d.ts","sourceRoot":"","sources":["../../../src/primitives/PopoverPrimitive.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAE3D,UAAU,YAAY;IACpB,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B;AACD,eAAO,MAAM,OAAO,yBAA0B,YAAY,4CAiEzD,CAAC"}
1
+ {"version":3,"file":"PopoverPrimitive.d.ts","sourceRoot":"","sources":["../../../src/primitives/PopoverPrimitive.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAG3D,UAAU,YAAY;IACpB,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B;AACD,eAAO,MAAM,OAAO,yBAA0B,YAAY,4CAoEzD,CAAC"}
@@ -1,7 +1,9 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { useEffect, useState, useRef } from 'react';
3
3
  import { createPortal } from 'react-dom';
4
+ import { useAdmin } from '../AdminProvider';
4
5
  export const Popover = ({ trigger, content }) => {
6
+ const { state: { theme }, } = useAdmin();
5
7
  const [isVisible, setIsVisible] = useState(false);
6
8
  const [position, setPosition] = useState({
7
9
  top: 0,
@@ -34,7 +36,7 @@ export const Popover = ({ trigger, content }) => {
34
36
  zIndex: 1000,
35
37
  top: position.top,
36
38
  left: position.left - 53,
37
- background: 'white',
39
+ background: theme.backgroundColor,
38
40
  boxShadow: '0px 1px 12px 0px rgba(56, 65, 81, 0.1)',
39
41
  padding: 12,
40
42
  borderRadius: 6,
@@ -1 +1 @@
1
- {"version":3,"file":"SecondaryButtonPrimitive.d.ts","sourceRoot":"","sources":["../../../src/primitives/SecondaryButtonPrimitive.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAgB,MAAM,UAAU,CAAC;AAEpD,MAAM,MAAM,6BAA6B,GAAG;IAC1C,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC9D,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CAC7B,CAAC;AAEF,QAAA,MAAM,wBAAwB,EAAE,KAAK,CAAC,EAAE,CAAC,6BAA6B,CAkCrE,CAAC;AAEF,eAAe,wBAAwB,CAAC"}
1
+ {"version":3,"file":"SecondaryButtonPrimitive.d.ts","sourceRoot":"","sources":["../../../src/primitives/SecondaryButtonPrimitive.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGtC,MAAM,MAAM,6BAA6B,GAAG;IAC1C,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC9D,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CAC7B,CAAC;AAEF,QAAA,MAAM,wBAAwB,EAAE,KAAK,CAAC,EAAE,CAAC,6BAA6B,CAsCrE,CAAC;AAEF,eAAe,wBAAwB,CAAC"}
@@ -1,10 +1,12 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import { defaultTheme } from '../Admin';
3
- const SecondaryButtonPrimitive = ({ onClick, label, theme = defaultTheme, disabled, style, }) => {
2
+ import { useAdmin } from '../AdminProvider';
3
+ const SecondaryButtonPrimitive = ({ onClick, label, theme, disabled, style, }) => {
4
+ const { state: { theme: stateTheme }, } = useAdmin();
5
+ theme = theme ?? stateTheme;
4
6
  return (_jsx("button", { style: {
5
7
  height: 40,
6
8
  background: disabled ? '#f8f8f8' : '#ffffff',
7
- borderColor: '#E7E7E7',
9
+ borderColor: theme?.borderColor,
8
10
  borderStyle: 'solid',
9
11
  borderWidth: 1,
10
12
  color: theme?.primaryTextColor,
@@ -1 +1 @@
1
- {"version":3,"file":"ChartQueryBuilder.d.ts","sourceRoot":"","sources":["../../../src/public_components/ChartQueryBuilder.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAA+B,MAAM,OAAO,CAAC;AAGnE,OAAO,EACL,WAAW,EAIZ,MAAM,iBAAiB,CAAC;AAUzB,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,EACxC,eAAe,EACf,MAAM,EACN,cAAc,EACd,oBAAoB,GACrB,EAAE;IACD,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,WAAW,KAAK,IAAI,CAAC;IACxC,cAAc,CAAC,EAAE,aAAa,CAAC;IAC/B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,2CAkOA"}
1
+ {"version":3,"file":"ChartQueryBuilder.d.ts","sourceRoot":"","sources":["../../../src/public_components/ChartQueryBuilder.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAA+B,MAAM,OAAO,CAAC;AAGnE,OAAO,EACL,WAAW,EAIZ,MAAM,iBAAiB,CAAC;AAWzB,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,EACxC,eAAe,EACf,MAAM,EACN,cAAc,EACd,oBAAoB,GACrB,EAAE;IACD,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,WAAW,KAAK,IAAI,CAAC;IACxC,cAAc,CAAC,EAAE,aAAa,CAAC;IAC/B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,2CAwPA"}
@@ -9,13 +9,16 @@ import XMarkIcon from '../icons/XMarkIcon';
9
9
  import PlaceholderPrimitive from '../primitives/PlaceholderPrimitive';
10
10
  import { useDashboardManager } from '../hooks/useDashboardManager';
11
11
  import { onlySingleDatabaseTenant } from '../utils/tenants';
12
- import { ButtonPrimitive } from '../primitives';
12
+ import { ButtonPrimitive, ModalPrimitive } from '../primitives';
13
13
  import { SAVED_QUERIES_DASHBOARD } from '../utils/constants';
14
+ import CreateEnvironment from './CreateEnvironment';
14
15
  export default function ChartQueryBuilder({ activeComponent, onExit, containerStyle, destinationDashboard, }) {
15
16
  const parentRef = useRef(null);
17
+ const envPopoverRef = useRef(null);
16
18
  const { state, dispatch, clientLoading, setClient } = useAdmin();
17
19
  const [query, setQuery] = useState(state.activeQuery);
18
20
  const [toggleMode, setToggleMode] = useState(activeComponent);
21
+ const [showCreateEnvironmentModal, setShowCreateEnvironmentModal] = useState(false);
19
22
  const { setSelectedDashboard } = useDashboardManager();
20
23
  const { reload } = useDashboard(SAVED_QUERIES_DASHBOARD);
21
24
  const modeToggleOptions = [
@@ -48,6 +51,9 @@ export default function ChartQueryBuilder({ activeComponent, onExit, containerSt
48
51
  useEffect(() => {
49
52
  setToggleMode(activeComponent);
50
53
  }, [activeComponent]);
54
+ if (showCreateEnvironmentModal) {
55
+ return (_jsx(ModalPrimitive, { isOpen: showCreateEnvironmentModal, onClose: () => setShowCreateEnvironmentModal(false), children: _jsx(CreateEnvironment, { onOnboardComplete: () => setShowCreateEnvironmentModal(false) }) }));
56
+ }
51
57
  return (_jsx("div", { style: {
52
58
  height: '100%',
53
59
  ...containerStyle,
@@ -82,9 +88,12 @@ export default function ChartQueryBuilder({ activeComponent, onExit, containerSt
82
88
  flexDirection: 'row',
83
89
  gap: 12,
84
90
  alignItems: 'flex-end',
85
- }, children: [_jsx("div", { style: { display: 'flex', flexDirection: 'column' }, children: _jsx(EnvSelectPopover, { clients: state.clients, client: state.client, setClient: (client) => {
91
+ }, ref: envPopoverRef, children: [_jsx("div", { style: { display: 'flex', flexDirection: 'column' }, children: _jsx(EnvSelectPopover, { clients: state.clients, client: state.client, setClient: (client) => {
92
+ setSelectedDashboard(null);
86
93
  setClient(client, true);
87
- }, theme: state.theme, parentRef: parentRef, isLoading: clientLoading }) }), state.client?.name !== undefined &&
94
+ }, theme: state.theme, parentRef: envPopoverRef, isLoading: clientLoading, onCreateNewEnvironment: () => {
95
+ setShowCreateEnvironmentModal(true);
96
+ } }) }), state.client?.name !== undefined &&
88
97
  !state.databaseTypeMismatch.show &&
89
98
  !onlySingleDatabaseTenant(state.client) && (_jsx(OrgSelect, { isLoading: clientLoading })), _jsx(QuillTab, { modeToggleOptions: modeToggleOptions, toggleMode: toggleMode, setToggleMode: setToggleMode, width: "250px" })] }), onExit && (_jsx("button", { type: "button", onClick: () => {
90
99
  onExit();
@@ -104,8 +113,8 @@ export default function ChartQueryBuilder({ activeComponent, onExit, containerSt
104
113
  gap: 32,
105
114
  padding: 32,
106
115
  }, children: [_jsx(PlaceholderPrimitive, { containerStyle: { width: '12%' } }), _jsx(PlaceholderPrimitive, { containerStyle: { maxHeight: 300 } })] })) : toggleMode === 'Report Builder' ? (_jsx(ReportBuilder, { reportId: state.activeSavedQueryReportId ?? '', isAdminEnabled: true, onSubmitCreateReport: submitReport, onSubmitEditReport: submitReport, onSubmitSaveQuery: submitSavedQuery, containerStyle: {
107
- height: 'calc(100vh - 146px)',
108
116
  width: '100%',
117
+ backgroundColor: 'white',
109
118
  }, ButtonComponent: ({ onClick, label, isLoading, disabled }) => {
110
119
  if (label === 'Save changes' && state.activeSavedQueryReportId) {
111
120
  return (_jsx(ButtonPrimitive, { onClick: onClick, label: 'Add to dashboard', isLoading: isLoading, disabled: disabled }));
@@ -119,6 +128,7 @@ export default function ChartQueryBuilder({ activeComponent, onExit, containerSt
119
128
  height: '100%',
120
129
  width: '100%',
121
130
  overflow: 'hidden',
131
+ backgroundColor: 'white',
122
132
  // paddingRight: 25,
123
133
  // paddingTop: 25,
124
134
  }, destinationDashboard: destinationDashboard }))] }) }));
@@ -1 +1 @@
1
- {"version":3,"file":"CreateEnvironment.d.ts","sourceRoot":"","sources":["../../../src/public_components/CreateEnvironment.tsx"],"names":[],"mappings":"AACA,OAAc,EACZ,aAAa,EAOd,MAAM,OAAO,CAAC;AAsCf,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,EACxC,iBAAiB,EACjB,cAAc,GACf,EAAE;IACD,0BAA0B,CAAC,EAAE,MAAM,IAAI,CAAC;IACxC,iBAAiB,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,IAAI,CAAC;IAC1C,cAAc,CAAC,EAAE,aAAa,CAAC;CAChC,2CAoUA"}
1
+ {"version":3,"file":"CreateEnvironment.d.ts","sourceRoot":"","sources":["../../../src/public_components/CreateEnvironment.tsx"],"names":[],"mappings":"AACA,OAAc,EACZ,aAAa,EAOd,MAAM,OAAO,CAAC;AAwBf,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,EACxC,iBAAiB,EACjB,cAAc,GACf,EAAE;IACD,0BAA0B,CAAC,EAAE,MAAM,IAAI,CAAC;IACxC,iBAAiB,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,IAAI,CAAC;IAC1C,cAAc,CAAC,EAAE,aAAa,CAAC;CAChC,2CA4VA"}
@@ -9,22 +9,11 @@ import { getDatabaseConnectionFormat, } from '../utils/databases';
9
9
  import CreateVirtualTables from '../forms/client_onboard/CreateVirtualTables';
10
10
  import { getTableColumnsBySchema } from '../api/ConnectionClient';
11
11
  import { quillFetch } from '../utils/dataFetcher';
12
- const header1Style = {
13
- fontWeight: '600',
14
- fontSize: '18px',
15
- marginBottom: '6px',
16
- color: '#000000',
17
- };
18
- const header2Style = {
19
- fontWeight: '500',
20
- fontSize: '13px',
21
- color: '#595959',
22
- marginBottom: '4px',
23
- };
24
12
  export default function CreateEnvironment({ onOnboardComplete, containerStyle, }) {
25
13
  const parentRef = React.useRef(null);
26
14
  const { state, dispatch, setClient, getToken, quillFetchWithToken } = useAdmin();
27
- const domainName = state.domainName;
15
+ const domainName = state.client?.domainName || state.domainName;
16
+ const defaultDatabaseType = state.client?.databaseType || 'PostgreSQL';
28
17
  const [createEnvSteps, setCreateEnvSteps] = useState({
29
18
  connectDB: {
30
19
  label: 'Connect Database',
@@ -39,7 +28,7 @@ export default function CreateEnvironment({ onOnboardComplete, containerStyle, }
39
28
  open: false,
40
29
  },
41
30
  });
42
- const [connection, setConnection] = useState(getDatabaseConnectionFormat('PostgreSQL'));
31
+ const [connection, setConnection] = useState(getDatabaseConnectionFormat(state.isSelfHosted ? defaultDatabaseType : 'PostgreSQL'));
43
32
  const [newClient, setNewClient] = useState({});
44
33
  const [databaseSchema, setDatabaseSchema] = useState(undefined);
45
34
  const [sqlTables, setSqlTables] = useState([]);
@@ -57,6 +46,7 @@ export default function CreateEnvironment({ onOnboardComplete, containerStyle, }
57
46
  if (newClient.clientId) {
58
47
  await quillFetch({
59
48
  client: {
49
+ queryHeaders: state.queryHeaders,
60
50
  queryEndpoint: state.queryEndpoint,
61
51
  clientId: newClient.clientId,
62
52
  withCredentials: false,
@@ -89,7 +79,7 @@ export default function CreateEnvironment({ onOnboardComplete, containerStyle, }
89
79
  type: 'SET_DATABASE_SCHEMA',
90
80
  payload: { schema: [], id: clientId, loading: true },
91
81
  });
92
- await getTableColumnsBySchema(state.queryEndpoint, clientId, getToken, selectedSchemaNames)
82
+ await getTableColumnsBySchema(state.isSelfHosted, state.queryEndpoint, clientId, connection.type, getToken, selectedSchemaNames, state.queryHeaders)
93
83
  .then((schema) => {
94
84
  dispatch({
95
85
  type: 'SET_DATABASE_SCHEMA',
@@ -124,6 +114,7 @@ export default function CreateEnvironment({ onOnboardComplete, containerStyle, }
124
114
  };
125
115
  const finishOnboarding = async () => {
126
116
  setOnboardingCompleteIsLoading(true);
117
+ // TODO: Anyone could create a client with some domain through this endpoint
127
118
  const response = await quillFetchWithToken({
128
119
  client: {
129
120
  queryEndpoint: state.queryEndpoint,
@@ -160,6 +151,20 @@ export default function CreateEnvironment({ onOnboardComplete, containerStyle, }
160
151
  // setOnboardingCompleteIsLoading(false);
161
152
  };
162
153
  const isTestMode = process.env.TEST_MODE === 'true';
154
+ const header1Style = {
155
+ fontWeight: '600',
156
+ fontSize: '18px',
157
+ marginBottom: '6px',
158
+ color: state.theme?.primaryTextColor,
159
+ fontFamily: state.theme?.fontFamily,
160
+ };
161
+ const header2Style = {
162
+ fontWeight: '500',
163
+ fontSize: '13px',
164
+ marginBottom: '4px',
165
+ fontFamily: state.theme?.fontFamily,
166
+ color: state.theme?.secondaryTextColor,
167
+ };
163
168
  return (_jsxs("div", { ref: parentRef, style: {
164
169
  ...containerStyle,
165
170
  display: 'flex',
@@ -1 +1 @@
1
- {"version":3,"file":"DashboardManager.d.ts","sourceRoot":"","sources":["../../../src/public_components/DashboardManager.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAA4C,MAAM,OAAO,CAAC;AAuChF,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,6BAA6B,EAAE,6BAA6B,EAC5D,cAAc,GACf,EAAE;IACD,6BAA6B,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3C,cAAc,CAAC,EAAE,aAAa,CAAC;CAChC,2CA6yBA"}
1
+ {"version":3,"file":"DashboardManager.d.ts","sourceRoot":"","sources":["../../../src/public_components/DashboardManager.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAA4C,MAAM,OAAO,CAAC;AAwChF,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,6BAA6B,EAAE,6BAA6B,EAC5D,cAAc,GACf,EAAE;IACD,6BAA6B,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3C,cAAc,CAAC,EAAE,aAAa,CAAC;CAChC,2CAi0BA"}
@@ -21,6 +21,7 @@ import { Popover } from '../primitives/PopoverPrimitive';
21
21
  import CodePreview from '../modals/CodePreview';
22
22
  import SavedQueriesModal from '../modals/SavedQueriesModal';
23
23
  import { InternalDashboard } from '../components/InternalDashboard/InternalDashboard';
24
+ import CreateEnvironment from './CreateEnvironment';
24
25
  export default function DashboardManager({ navigateToVirtualTableManager: navigateToVirtualTableManager, containerStyle, }) {
25
26
  const { state, dispatch, clientLoading, setClient, getToken, quillFetchWithToken, } = useAdmin();
26
27
  const parentRef = useRef(null);
@@ -33,6 +34,7 @@ export default function DashboardManager({ navigateToVirtualTableManager: naviga
33
34
  const [editEnvironmentModalIsOpen, setEditEnvironmentModalIsOpen] = useState(false);
34
35
  //FIXME: we don't want to lift up this state
35
36
  const [userFilters, setUserFilters] = useState([]);
37
+ const [showCreateEnvironmentModal, setShowCreateEnvironmentModal] = useState(false);
36
38
  const { data: dashboardConfig, reload: reloadDashboard } = useDashboard(state.selectedDashboard, userFilters);
37
39
  const { dashboards, isLoading: dashboardsLoading } = useDashboards();
38
40
  const { setSelectedDashboard } = useDashboardManager();
@@ -155,6 +157,9 @@ export default function DashboardManager({ navigateToVirtualTableManager: naviga
155
157
  alert('Could not promote this dashboard.');
156
158
  }
157
159
  };
160
+ if (showCreateEnvironmentModal) {
161
+ return (_jsx(ModalPrimitive, { isOpen: showCreateEnvironmentModal, onClose: () => setShowCreateEnvironmentModal(false), children: _jsx(CreateEnvironment, { onOnboardComplete: () => setShowCreateEnvironmentModal(false) }) }));
162
+ }
158
163
  return (_jsxs("div", { style: containerStyle, children: [(state.activeComponent === 'Report Builder' ||
159
164
  state.activeComponent === 'SQL Editor') && (_jsx(ChartQueryBuilder, { activeComponent: state.activeComponent, destinationDashboard: state.selectedDashboard ??
160
165
  dashboards?.filter((d) => d.name !== SAVED_QUERIES_DASHBOARD)?.[0]
@@ -228,6 +233,8 @@ export default function DashboardManager({ navigateToVirtualTableManager: naviga
228
233
  setClient(client, true);
229
234
  }, onSelectedEditEnvironment: () => {
230
235
  setEditEnvironmentModalIsOpen(true);
236
+ }, onCreateNewEnvironment: () => {
237
+ setShowCreateEnvironmentModal(true);
231
238
  }, theme: state.theme, parentRef: envSelectPopoverRef, isLoading: clientLoading }) }), _jsx("div", { style: { display: 'flex', flexDirection: 'column' }, ref: dashboardSelectPopoverRef, children: _jsx(DashboardSelectPopover, { dashboards: dashboards?.filter((d) => d.name !== SAVED_QUERIES_DASHBOARD)?.length
232
239
  ? dashboards
233
240
  .map((elem) => {
@@ -336,8 +343,10 @@ export default function DashboardManager({ navigateToVirtualTableManager: naviga
336
343
  justifyContent: 'center',
337
344
  width: 260,
338
345
  }, children: [_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", fill: "#565656", height: 26, width: 26, children: [_jsx("path", { fillRule: "evenodd", d: "M2.25 13.5a8.25 8.25 0 0 1 8.25-8.25.75.75 0 0 1 .75.75v6.75H18a.75.75 0 0 1 .75.75 8.25 8.25 0 0 1-16.5 0Z", clipRule: "evenodd" }), _jsx("path", { fillRule: "evenodd", d: "M12.75 3a.75.75 0 0 1 .75-.75 8.25 8.25 0 0 1 8.25 8.25.75.75 0 0 1-.75.75h-7.5a.75.75 0 0 1-.75-.75V3Z", clipRule: "evenodd" })] }), _jsx("div", { style: {
339
- fontSize: 16,
346
+ fontSize: state.theme?.fontSize,
340
347
  fontWeight: 500,
348
+ fontFamily: state.theme?.fontFamily,
349
+ fontSizeAdjust: 0.5,
341
350
  color: '#565656',
342
351
  paddingTop: 8,
343
352
  paddingBottom: 8,
@@ -6,7 +6,8 @@ interface EnvSelectPopoverProps {
6
6
  onSelectedEditEnvironment?: (environment: string) => void;
7
7
  parentRef: React.RefObject<HTMLDivElement>;
8
8
  isLoading?: boolean;
9
+ onCreateNewEnvironment?: () => void;
9
10
  }
10
- export default function EnvSelectPopover({ clients, setClient, client, theme, onSelectedEditEnvironment, parentRef, isLoading, }: EnvSelectPopoverProps): import("react/jsx-runtime").JSX.Element;
11
+ export default function EnvSelectPopover({ clients, setClient, client, theme, onSelectedEditEnvironment, parentRef, isLoading, onCreateNewEnvironment, }: EnvSelectPopoverProps): import("react/jsx-runtime").JSX.Element;
11
12
  export {};
12
13
  //# sourceMappingURL=EnvSelectPopover.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"EnvSelectPopover.d.ts","sourceRoot":"","sources":["../../../src/public_components/EnvSelectPopover.tsx"],"names":[],"mappings":"AAMA,UAAU,qBAAqB;IAC7B,OAAO,EAAE,GAAG,EAAE,CAAC;IACf,SAAS,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,IAAI,CAAC;IACjC,MAAM,EAAE,GAAG,CAAC;IACZ,KAAK,EAAE,GAAG,CAAC;IACX,yBAAyB,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1D,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;IAC3C,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,OAAO,EACP,SAAS,EACT,MAAM,EACN,KAAK,EACL,yBAAyB,EACzB,SAAS,EACT,SAAS,GACV,EAAE,qBAAqB,2CA4NvB"}
1
+ {"version":3,"file":"EnvSelectPopover.d.ts","sourceRoot":"","sources":["../../../src/public_components/EnvSelectPopover.tsx"],"names":[],"mappings":"AAMA,UAAU,qBAAqB;IAC7B,OAAO,EAAE,GAAG,EAAE,CAAC;IACf,SAAS,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,IAAI,CAAC;IACjC,MAAM,EAAE,GAAG,CAAC;IACZ,KAAK,EAAE,GAAG,CAAC;IACX,yBAAyB,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1D,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;IAC3C,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,sBAAsB,CAAC,EAAE,MAAM,IAAI,CAAC;CACrC;AAED,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,OAAO,EACP,SAAS,EACT,MAAM,EACN,KAAK,EACL,yBAAyB,EACzB,SAAS,EACT,SAAS,EACT,sBAAsB,GACvB,EAAE,qBAAqB,2CAwOvB"}
@@ -1,10 +1,11 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  import { useMemo, useState } from 'react';
3
3
  import { useAdmin } from '../AdminProvider';
4
- import { ListboxRow, ListboxTextInput, Popover } from '../components/OrgSelect';
4
+ import { ListboxRow, Popover } from '../components/OrgSelect';
5
5
  import MiniButtonPrimitive from '../primitives/MiniButtonPrimitive';
6
6
  import { LoadingSpinner } from '../components/UiComponents';
7
- export default function EnvSelectPopover({ clients, setClient, client, theme, onSelectedEditEnvironment, parentRef, isLoading, }) {
7
+ import { ListboxTextInput } from '../components/QuillMultiSelectWithCombo';
8
+ export default function EnvSelectPopover({ clients, setClient, client, theme, onSelectedEditEnvironment, parentRef, isLoading, onCreateNewEnvironment, }) {
8
9
  const { state, dispatch } = useAdmin();
9
10
  const [isOpen, setIsOpen] = useState(false);
10
11
  const [searchQuery, setSearchQuery] = useState('');
@@ -78,11 +79,16 @@ export default function EnvSelectPopover({ clients, setClient, client, theme, on
78
79
  marginBottom: '4px',
79
80
  fontWeight: '600',
80
81
  color: theme.secondaryTextColor,
82
+ fontFamily: theme.fontFamily,
81
83
  }, children: "Environment" }), _jsx(Popover, { parentRef: parentRef, label: client?.name ?? 'Select environment', isOpen: isOpen, onClose: () => setIsOpen(false), style: {
82
84
  boxSizing: 'border-box',
83
85
  fontSize: 14,
84
86
  maxHeight: '50vh',
85
- }, setIsOpen: setIsOpen, onClick: () => { }, children: !isLoading ? (_jsxs(_Fragment, { children: [_jsx(ListboxTextInput, { id: "quill-search-bar", placeholder: "Search", value: searchQuery, onChange: setSearchQuery }), _jsx("div", { style: { height: 9, width: 230, borderTop: '1px solid #e7e7e7' } }), _jsxs("div", { style: { paddingTop: 8, paddingBottom: 8 }, children: [filteredClients.map((item) => (_jsx(ListboxRow, { setSelected: client._id !== item._id
87
+ }, setIsOpen: setIsOpen, onClick: () => { }, children: !isLoading ? (_jsxs(_Fragment, { children: [_jsx(ListboxTextInput, { id: "quill-search-bar", placeholder: "Search", value: searchQuery, onChange: setSearchQuery, width: 180 }), _jsx("div", { style: {
88
+ height: 9,
89
+ width: 230,
90
+ borderTop: `1px solid ${state.theme?.borderColor ?? '#e7e7e7'}`,
91
+ } }), _jsxs("div", { style: { paddingTop: 8, paddingBottom: 8 }, children: [filteredClients.map((item) => (_jsx(ListboxRow, { setSelected: client._id !== item._id
86
92
  ? () => handleItemClick(item)
87
93
  : undefined, item: item.name, isSelected: client._id === item._id, hoverActions: onSelectedEditEnvironment
88
94
  ? (item) => (_jsx(MiniButtonPrimitive, { label: "Manage", onClick: () => {
@@ -92,10 +98,12 @@ export default function EnvSelectPopover({ clients, setClient, client, theme, on
92
98
  marginRight: -8,
93
99
  marginTop: 'auto',
94
100
  marginBottom: 'auto',
101
+ fontFamily: theme.fontFamily,
102
+ color: theme.secondaryTextColor,
103
+ backgroundColor: theme.backgroundColor,
95
104
  } }))
96
- : undefined }, item._id))), _jsx("div", { className: 'quill-list-select', style: { paddingBottom: 6, cursor: 'pointer' }, children: _jsxs("a", { href: '/onboard', style: {
105
+ : undefined }, item._id))), _jsx("div", { className: 'quill-list-select', style: { paddingBottom: 6, cursor: 'pointer' }, children: _jsxs("a", { onClick: onCreateNewEnvironment, style: {
97
106
  height: 42,
98
- color: '#384151',
99
107
  width: 216,
100
108
  borderRadius: 6,
101
109
  textAlign: 'left',
@@ -109,15 +117,19 @@ export default function EnvSelectPopover({ clients, setClient, client, theme, on
109
117
  textOverflow: 'ellipsis',
110
118
  whiteSpace: 'nowrap',
111
119
  overflow: 'hidden',
120
+ fontFamily: theme.fontFamily,
112
121
  }, children: [_jsx("style", { children: `
113
122
  .quill-list-select > a {
114
- background-color: white;
123
+ background-color: ${state.theme?.backgroundColor};
124
+ color: ${theme?.primaryTextColor};
115
125
  }
116
126
  .quill-list-selected > a {
117
- background-color: rgba(56, 65, 81, 0.04);
127
+ background-color: ${state.theme?.hoverBackgroundColor};
128
+ color: ${theme?.hoverTextColor};
118
129
  }
119
130
  .quill-list-select:hover > a {
120
- background-color: rgba(56, 65, 81, 0.04);
131
+ background-color: ${state.theme?.hoverBackgroundColor};
132
+ color: ${theme?.hoverTextColor};
121
133
  }` }), _jsxs("div", { style: {
122
134
  textOverflow: 'ellipsis',
123
135
  whiteSpace: 'nowrap',
@@ -1 +1 @@
1
- {"version":3,"file":"VirtualTableManager.d.ts","sourceRoot":"","sources":["../../../src/public_components/VirtualTableManager.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAwC,MAAM,OAAO,CAAC;AA0C5E,eAAO,MAAM,mBAAmB,aAAc,GAAG,EAAE,aAalD,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,mBAAmB,CAAC,EAC1C,cAAc,EACd,YAAY,GACb,EAAE;IACD,cAAc,CAAC,EAAE,aAAa,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,2CA08BA"}
1
+ {"version":3,"file":"VirtualTableManager.d.ts","sourceRoot":"","sources":["../../../src/public_components/VirtualTableManager.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAwC,MAAM,OAAO,CAAC;AA2C5E,eAAO,MAAM,mBAAmB,aAAc,GAAG,EAAE,aAalD,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,mBAAmB,CAAC,EAC1C,cAAc,EACd,YAAY,GACb,EAAE;IACD,cAAc,CAAC,EAAE,aAAa,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,2CAw+BA"}
@@ -4,7 +4,7 @@ import { useEffect, useMemo, useRef, useState } from 'react';
4
4
  import { ButtonPrimitive, HeaderPrimitive, ModalPrimitive, SecondaryButtonPrimitive, TextInputPrimitive, } from '../primitives';
5
5
  import { useAdmin } from '../AdminProvider';
6
6
  import { EnvSelectPopover } from '../components';
7
- import { defaultTheme, TableCell } from '../Admin';
7
+ import { TableCell } from '../Admin';
8
8
  import CreateEditVirtualTable from '../forms/virtual_tables/CreateEditVirtualTable';
9
9
  import { addVirtualTable, editVirtualTable, deleteVirtualTable as requestDeleteVirtualTable, } from '../utils/dataEditor';
10
10
  import { getVirtualTableData } from '../api/ConnectionClient';
@@ -23,6 +23,7 @@ import { onlySingleDatabaseTenant } from '../utils/tenants';
23
23
  import { useDatabaseSchema } from '../hooks/useDatabaseSchema';
24
24
  import InputLabel from '../components/InputLabel';
25
25
  import { useDashboardManager } from '../hooks/useDashboardManager';
26
+ import CreateEnvironment from './CreateEnvironment';
26
27
  export const getDuplicateColumns = (columns) => {
27
28
  if (!columns) {
28
29
  return [];
@@ -60,7 +61,9 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
60
61
  const [initialVirtualTable, setInitialVirtualTable] = useState(undefined);
61
62
  const [submittingVirtualTable, setSubmittingVirtualTable] = useState(false);
62
63
  const [noCustomerField, setNoCustomerField] = useState(false);
64
+ const [showCreateEnvironmentModal, setShowCreateEnvironmentModal] = useState(false);
63
65
  const parentRef = useRef(null);
66
+ const envHeaderRef = useRef(null);
64
67
  const { state, dispatch, clientLoading, setClient, getToken, quillFetchWithToken, } = useAdmin();
65
68
  const closeEditModal = () => {
66
69
  setEditModalIsOpen(false);
@@ -294,13 +297,16 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
294
297
  break;
295
298
  }
296
299
  };
300
+ if (showCreateEnvironmentModal) {
301
+ return (_jsx(ModalPrimitive, { isOpen: showCreateEnvironmentModal, onClose: () => setShowCreateEnvironmentModal(false), children: _jsx(CreateEnvironment, { onOnboardComplete: () => setShowCreateEnvironmentModal(false) }) }));
302
+ }
297
303
  return (_jsx("div", { style: { ...containerStyle }, children: _jsxs("div", { style: {
298
304
  minHeight: '100%',
299
305
  display: 'flex',
300
306
  flexDirection: 'column',
301
307
  paddingTop: '0px',
302
308
  position: 'relative',
303
- }, ref: parentRef, children: [(state.databaseTypeMismatch.show || !editQueryView) && (_jsx("div", { style: {
309
+ }, ref: parentRef, children: [(state.databaseTypeMismatch.show || !editQueryView) && (_jsx("div", { ref: envHeaderRef, style: {
304
310
  // width: 'calc(100vw - 30px)',
305
311
  display: 'flex',
306
312
  position: 'sticky',
@@ -334,6 +340,8 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
334
340
  setClient(client, true);
335
341
  }, onSelectedEditEnvironment: () => {
336
342
  setEditEnvironmentModalIsOpen(true);
343
+ }, onCreateNewEnvironment: () => {
344
+ setShowCreateEnvironmentModal(true);
337
345
  }, theme: state.theme, parentRef: parentRef, isLoading: clientLoading }) }), !editQueryView && !state.databaseTypeMismatch.show && (_jsxs("div", { style: {
338
346
  display: 'flex',
339
347
  flexDirection: 'row',
@@ -352,6 +360,7 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
352
360
  gridTemplateColumns: 'repeat(auto-fill,minmax(460px, 1fr))',
353
361
  padding: 25,
354
362
  width: '100%',
363
+ ...containerStyle,
355
364
  }, children: Array.from({ length: 12 }).map((_, i) => (_jsx("div", { style: {
356
365
  height: '180px',
357
366
  width: '540px',
@@ -368,6 +377,11 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
368
377
  gridGap: 24,
369
378
  gridTemplateColumns: 'repeat(auto-fill,minmax(460px, 1fr))',
370
379
  padding: 25,
380
+ height: '100%',
381
+ maxHeight: envHeaderRef.current
382
+ ? `calc(100vh - ${envHeaderRef.current?.getBoundingClientRect().bottom ?? 0}px)`
383
+ : '100%',
384
+ overflow: 'scroll',
371
385
  }, children: tables && tables?.length ? (_jsxs(_Fragment, { children: [tables.map((table) => (_jsx(TableCell, { table: table, clickTableCellHeader: clickTableCell, clickTableCellBody: () => {
372
386
  clickTableCell(table, true);
373
387
  setEditQueryView(true);
@@ -386,6 +400,7 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
386
400
  display: 'flex',
387
401
  flexDirection: 'row',
388
402
  alignItems: 'center',
403
+ border: `0 solid ${state.theme?.borderColor ?? '#e7e7e7'}`,
389
404
  }, onClick: (event) => {
390
405
  event.stopPropagation();
391
406
  clickTableCell(table, true);
@@ -404,6 +419,7 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
404
419
  display: 'flex',
405
420
  flexDirection: 'row',
406
421
  alignItems: 'center',
422
+ border: `0 solid ${state.theme?.borderColor ?? '#e7e7e7'}`,
407
423
  }, onClick: (event) => {
408
424
  event.stopPropagation();
409
425
  clickTableCell(table);
@@ -427,6 +443,7 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
427
443
  display: 'flex',
428
444
  flexDirection: 'row',
429
445
  alignItems: 'center',
446
+ border: `0 solid ${state.theme?.borderColor ?? '#e7e7e7'}`,
430
447
  }, className: "secondary-button-quill", onClick: (event) => {
431
448
  event.stopPropagation();
432
449
  reloadTables([table]);
@@ -437,6 +454,7 @@ export default function VirtualTableManager({ containerStyle, virtualTable, }) {
437
454
  height: 32,
438
455
  width: 32,
439
456
  color: state.theme?.secondaryTextColor,
457
+ border: `0 solid ${state.theme?.borderColor ?? '#e7e7e7'}`,
440
458
  borderRadius: 6,
441
459
  outline: 'none',
442
460
  cursor: 'pointer',
@@ -518,7 +536,8 @@ function EditAddViewModal({ viewName, viewQuery, viewOwnerTenantFields, viewId,
518
536
  marginTop: '0px',
519
537
  marginBottom: '0px',
520
538
  fontWeight: 'bold',
521
- color: '#384151',
539
+ color: state.theme?.primaryTextColor,
540
+ fontFamily: state.theme?.fontFamily,
522
541
  }, children: viewName ? 'Edit Virtual Table' : 'Add Virtual Table' }), _jsx(MemoizedDeleteButton, { onClick: closeEditModal, style: undefined })] }), _jsx(InputLabel, { children: "Name" }), _jsx(TextInputPrimitive, { ref: (input) => editModalIsOpen && !viewName && input?.focus(), placeholder: "Enter view display name...", onChange: (e) => setName(e.target.value), value: name ? name : '' }), _jsx("br", {}), viewOwnerTenantFields.length > 0 && (_jsxs(_Fragment, { children: [_jsx(InputLabel, { tooltip: "Dashboards may only query from virtual tables that share an owner with them. Virtual tables are required to return each of their owners' foreign keys as part of the query.", children: "Owners" }), _jsx("div", { style: {
523
542
  flexDirection: 'row',
524
543
  display: 'flex',
@@ -530,7 +549,8 @@ function EditAddViewModal({ viewName, viewQuery, viewOwnerTenantFields, viewId,
530
549
  .map((tenantField) => (_jsx("div", { style: {
531
550
  fontWeight: 300,
532
551
  fontSize: 12,
533
- color: defaultTheme?.primaryTextColor,
552
+ fontFamily: state.theme?.fontFamily,
553
+ color: state.theme?.primaryTextColor,
534
554
  padding: 2,
535
555
  paddingLeft: 4,
536
556
  paddingRight: 4,
@@ -559,7 +579,8 @@ function EditAddViewModal({ viewName, viewQuery, viewOwnerTenantFields, viewId,
559
579
  fontWeight: '600',
560
580
  fontSize: '14px',
561
581
  marginBottom: '6px',
562
- color: '#212121',
582
+ color: state.theme?.secondaryTextColor,
583
+ fontFamily: state.theme?.fontFamily,
563
584
  }, children: "Custom fields" }), _jsx(TogglePrimitive, { value: useCustomField, onClick: () => {
564
585
  setUseCustomField((useCustomField) => !useCustomField);
565
586
  }, style: {
@@ -569,19 +590,22 @@ function EditAddViewModal({ viewName, viewQuery, viewOwnerTenantFields, viewId,
569
590
  fontSize: '14px',
570
591
  marginBottom: '6px',
571
592
  marginTop: '20px',
572
- color: '#212121',
593
+ color: state.theme?.secondaryTextColor,
594
+ fontFamily: state.theme?.fontFamily,
573
595
  }, children: "Custom field type" }), _jsx(SegmentedControl, { theme: state.theme, value: customFieldType?.toLowerCase(), onChange: (e) => {
574
596
  setCustomFieldType(e);
575
597
  }, left: { label: 'EAV', value: 'eav' }, right: { label: 'JSON', value: 'json' } }), _jsx("br", {}), _jsx("h3", { style: {
576
598
  fontWeight: '600',
577
599
  fontSize: '14px',
578
600
  marginBottom: '6px',
579
- color: '#212121',
601
+ color: state.theme?.secondaryTextColor,
602
+ fontFamily: state.theme?.fontFamily,
580
603
  }, children: "Custom field query" }), _jsx("h3", { style: {
581
604
  fontWeight: '400',
582
605
  fontSize: '14px',
583
606
  marginBottom: '20px',
584
- color: '#212121',
607
+ color: state.theme?.secondaryTextColor,
608
+ fontFamily: state.theme?.fontFamily,
585
609
  }, children: customFieldType === 'eav'
586
610
  ? `A table of custom fields. It must have these columns: ref_table, ref_id, ref_table_id_field, field, value, type${clientIsSingleTenant ? '' : `, ${state.client.customerFieldName.replaceAll('"', '')}`}.`
587
611
  : `A table of custom fields. It must have these columns: ref_table, ref_column, field${clientIsSingleTenant ? '' : `, ${state.client.customerFieldName.replaceAll('"', '')}`}.` }), _jsx(SqlTextEditor, { value: customFieldQuery, setValue: (e) => {
@@ -598,7 +622,7 @@ function EditAddViewModal({ viewName, viewQuery, viewOwnerTenantFields, viewId,
598
622
  }
599
623
  setErrorInfo({ show: false, message: '' });
600
624
  setRunQueryButtonLoading(true);
601
- const getSqlResults = await getVirtualTableData(state.client._id, customFieldQuery, state.client.databaseType, state.queryEndpoint, getToken);
625
+ const getSqlResults = await getVirtualTableData(state.client._id, customFieldQuery, state.client.databaseType, state.queryEndpoint, getToken, state.queryHeaders);
602
626
  if (!getSqlResults.success) {
603
627
  setErrorInfo({
604
628
  show: true,
@@ -7,6 +7,7 @@ export type ColumnInfo = {
7
7
  isVisible: true;
8
8
  };
9
9
  export declare function convertFieldTypeToJSType(fieldType: string): string;
10
+ export declare function fieldTypeToDataTypeID(fieldType: string): number;
10
11
  export declare function processColumnReference(column: string, databaseType: string): string;
11
12
  export declare function convertColumnInfoToColumnInternal(columnInfo: ColumnInfo): ColumnInternal;
12
13
  export declare function isStringType(fieldType: string): boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"columnProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/columnProcessing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,cAAc,EAAE,MAAM,SAAS,CAAC;AAErD,MAAM,MAAM,UAAU,GAAG;IACvB,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,IAAI,CAAC;CACjB,CAAC;AAEF,wBAAgB,wBAAwB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAwDlE;AAsED,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,UAuB1E;AAED,wBAAgB,iCAAiC,CAC/C,UAAU,EAAE,UAAU,GACrB,cAAc,CAShB;AAED,wBAAgB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAYvD;AAED,wBAAgB,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CASrD;AAED,wBAAgB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAwBvD"}
1
+ {"version":3,"file":"columnProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/columnProcessing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,cAAc,EAAE,MAAM,SAAS,CAAC;AAErD,MAAM,MAAM,UAAU,GAAG;IACvB,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,IAAI,CAAC;CACjB,CAAC;AAEF,wBAAgB,wBAAwB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAwDlE;AAED,wBAAgB,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CA0C/D;AA0BD,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,UAuB1E;AAED,wBAAgB,iCAAiC,CAC/C,UAAU,EAAE,UAAU,GACrB,cAAc,CAShB;AAED,wBAAgB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAYvD;AAED,wBAAgB,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CASrD;AAED,wBAAgB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAwBvD"}
@@ -53,7 +53,7 @@ export function convertFieldTypeToJSType(fieldType) {
53
53
  }
54
54
  return jsType;
55
55
  }
56
- function fieldTypeToDataTypeID(fieldType) {
56
+ export function fieldTypeToDataTypeID(fieldType) {
57
57
  switch (fieldType) {
58
58
  case 'bool':
59
59
  return 16;
@@ -6,4 +6,5 @@ export declare const SINGLE_TENANT = "QUILL_SINGLE_TENANT";
6
6
  export declare const SAVED_QUERIES_DASHBOARD = "quill-saved-queries";
7
7
  export declare const QUILL_SERVER: string;
8
8
  export declare const QUILL_QUERY_ENDPOINT: string;
9
+ export declare const QUILL_ENDPOINTS: string[];
9
10
  //# sourceMappingURL=constants.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/utils/constants.ts"],"names":[],"mappings":"AAAA;;GAEG;AAWH,eAAO,MAAM,WAAW,sBAAsB,CAAC;AAC/C,eAAO,MAAM,aAAa,wBAAwB,CAAC;AACnD,eAAO,MAAM,uBAAuB,wBAAwB,CAAC;AAE7D,eAAO,MAAM,YAAY,QAGoB,CAAC;AAC9C,eAAO,MAAM,oBAAoB,QAGnB,CAAC"}
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/utils/constants.ts"],"names":[],"mappings":"AAAA;;GAEG;AAWH,eAAO,MAAM,WAAW,sBAAsB,CAAC;AAC/C,eAAO,MAAM,aAAa,wBAAwB,CAAC;AACnD,eAAO,MAAM,uBAAuB,wBAAwB,CAAC;AAE7D,eAAO,MAAM,YAAY,QAGoB,CAAC;AAC9C,eAAO,MAAM,oBAAoB,QAGnB,CAAC;AAEf,eAAO,MAAM,eAAe,UAG3B,CAAC"}
@@ -19,3 +19,7 @@ export const QUILL_SERVER = typeof process !== 'undefined' && process.env
19
19
  export const QUILL_QUERY_ENDPOINT = typeof process !== 'undefined' && process.env
20
20
  ? (process.env.QUILL_QUERY_ENDPOINT ?? '/cloud')
21
21
  : '/cloud';
22
+ export const QUILL_ENDPOINTS = [
23
+ 'https://quill-344421.uc.r.appspot.com/cloud',
24
+ 'https://quill-ruby-server.onrender.com/cloud',
25
+ ];
@@ -1 +1 @@
1
- {"version":3,"file":"dataFetcher.d.ts","sourceRoot":"","sources":["../../../src/utils/dataFetcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAG/C,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,IAAI,CACV,mBAAmB,EACnB,UAAU,GAAG,eAAe,GAAG,cAAc,GAAG,iBAAiB,CAClE,CAAC;IACF,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,GAAG,CAAC;IACd,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAChC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,CAAC,EAAE,GAAG,CAAC;IACX,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,eAAO,MAAM,UAAU,2FASpB,iBAAiB,KAAG,OAAO,CAAC,YAAY,CAwD1C,CAAC"}
1
+ {"version":3,"file":"dataFetcher.d.ts","sourceRoot":"","sources":["../../../src/utils/dataFetcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAG/C,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,IAAI,CACV,mBAAmB,EACnB,UAAU,GAAG,eAAe,GAAG,cAAc,GAAG,iBAAiB,CAClE,CAAC;IACF,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,GAAG,CAAC;IACd,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAChC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,CAAC,EAAE,GAAG,CAAC;IACX,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,eAAO,MAAM,UAAU,2FASpB,iBAAiB,KAAG,OAAO,CAAC,YAAY,CAuD1C,CAAC"}
@@ -12,7 +12,6 @@ export const quillFetch = async ({ client, task, method = 'POST', metadata, abor
12
12
  ...(token ? { Authorization: `Bearer ${token}` } : {}),
13
13
  ...client.queryHeaders,
14
14
  'Content-Type': 'application/json',
15
- 'Vercel-Env': process.env.NEXT_PUBLIC_VERCEL_ENV ?? 'production',
16
15
  },
17
16
  body: JSON.stringify({
18
17
  metadata: {