@quillsql/admin 1.4.0 → 1.6.0

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 (149) hide show
  1. package/dist/cjs/Admin.d.ts +23 -73
  2. package/dist/cjs/Admin.d.ts.map +1 -1
  3. package/dist/cjs/Admin.js +221 -970
  4. package/dist/cjs/AdminProvider.d.ts +1 -12
  5. package/dist/cjs/AdminProvider.d.ts.map +1 -1
  6. package/dist/cjs/AdminProvider.js +24 -18
  7. package/dist/cjs/api/ConnectionClient.d.ts +11 -0
  8. package/dist/cjs/api/ConnectionClient.d.ts.map +1 -1
  9. package/dist/cjs/api/ConnectionClient.js +84 -10
  10. package/dist/cjs/components/DropDownMenu.js +1 -1
  11. package/dist/cjs/components/DropDownMenuWithLabel.d.ts.map +1 -1
  12. package/dist/cjs/components/DropDownMenuWithLabel.js +16 -54
  13. package/dist/cjs/components/OrgSelect.d.ts.map +1 -1
  14. package/dist/cjs/components/OrgSelect.js +10 -20
  15. package/dist/cjs/components/QuillSelect.d.ts +3 -0
  16. package/dist/cjs/components/QuillSelect.d.ts.map +1 -0
  17. package/dist/cjs/components/QuillSelect.js +137 -0
  18. package/dist/cjs/components/SegmentedControl.d.ts +7 -0
  19. package/dist/cjs/components/SegmentedControl.d.ts.map +1 -0
  20. package/dist/cjs/components/SegmentedControl.js +54 -0
  21. package/dist/cjs/components/UiComponents.d.ts +18 -29
  22. package/dist/cjs/components/UiComponents.d.ts.map +1 -1
  23. package/dist/cjs/components/UiComponents.js +40 -83
  24. package/dist/cjs/forms/client_onboard/ConnectSchema.d.ts +2 -1
  25. package/dist/cjs/forms/client_onboard/ConnectSchema.d.ts.map +1 -1
  26. package/dist/cjs/forms/client_onboard/ConnectSchema.js +143 -68
  27. package/dist/cjs/forms/client_onboard/CreateSqlViews.d.ts.map +1 -1
  28. package/dist/cjs/forms/client_onboard/CreateSqlViews.js +40 -11
  29. package/dist/cjs/forms/sql_views/CreateEditSqlView.d.ts +7 -4
  30. package/dist/cjs/forms/sql_views/CreateEditSqlView.d.ts.map +1 -1
  31. package/dist/cjs/forms/sql_views/CreateEditSqlView.js +36 -20
  32. package/dist/cjs/hooks/useOnClickOutside.d.ts +3 -0
  33. package/dist/cjs/hooks/useOnClickOutside.d.ts.map +1 -0
  34. package/dist/cjs/hooks/useOnClickOutside.js +20 -0
  35. package/dist/cjs/modals/EditFiltersModal.d.ts +17 -0
  36. package/dist/cjs/modals/EditFiltersModal.d.ts.map +1 -0
  37. package/dist/cjs/modals/EditFiltersModal.js +345 -0
  38. package/dist/cjs/modals/NewDashboardModal.d.ts +1 -3
  39. package/dist/cjs/modals/NewDashboardModal.d.ts.map +1 -1
  40. package/dist/cjs/modals/NewDashboardModal.js +63 -46
  41. package/dist/cjs/modals/PromoteDashModal.d.ts.map +1 -1
  42. package/dist/cjs/modals/PromoteDashModal.js +10 -3
  43. package/dist/cjs/modals/ReorderDashboardModal.d.ts.map +1 -1
  44. package/dist/cjs/modals/ReorderDashboardModal.js +202 -90
  45. package/dist/cjs/modals/index.d.ts +0 -1
  46. package/dist/cjs/modals/index.d.ts.map +1 -1
  47. package/dist/cjs/modals/index.js +1 -3
  48. package/dist/cjs/primitives/ButtonPrimitive.d.ts +3 -1
  49. package/dist/cjs/primitives/ButtonPrimitive.d.ts.map +1 -1
  50. package/dist/cjs/primitives/ButtonPrimitive.js +5 -3
  51. package/dist/cjs/primitives/ModalPrimitive.d.ts.map +1 -1
  52. package/dist/cjs/primitives/ModalPrimitive.js +1 -2
  53. package/dist/cjs/primitives/TogglePrimitive.js +5 -5
  54. package/dist/cjs/public_components/CreateEnvironment.d.ts.map +1 -1
  55. package/dist/cjs/public_components/CreateEnvironment.js +1 -1
  56. package/dist/cjs/public_components/DashboardBuilder.d.ts.map +1 -1
  57. package/dist/cjs/public_components/DashboardBuilder.js +127 -30
  58. package/dist/cjs/public_components/DashboardManager.d.ts.map +1 -1
  59. package/dist/cjs/public_components/DashboardManager.js +161 -193
  60. package/dist/cjs/public_components/SQLViewManager.d.ts.map +1 -1
  61. package/dist/cjs/public_components/SQLViewManager.js +92 -24
  62. package/dist/cjs/utils/constants.d.ts +4 -4
  63. package/dist/cjs/utils/constants.js +2 -2
  64. package/dist/cjs/utils/schema.d.ts +6 -0
  65. package/dist/cjs/utils/schema.d.ts.map +1 -1
  66. package/dist/cjs/utils/table.d.ts +1 -0
  67. package/dist/cjs/utils/table.d.ts.map +1 -1
  68. package/dist/cjs/utils/table.js +13 -0
  69. package/dist/cjs/utils/textProcessing.d.ts +2 -0
  70. package/dist/cjs/utils/textProcessing.d.ts.map +1 -0
  71. package/dist/cjs/utils/textProcessing.js +9 -0
  72. package/dist/esm/Admin.d.ts +23 -73
  73. package/dist/esm/Admin.d.ts.map +1 -1
  74. package/dist/esm/Admin.js +225 -964
  75. package/dist/esm/AdminProvider.d.ts +1 -12
  76. package/dist/esm/AdminProvider.d.ts.map +1 -1
  77. package/dist/esm/AdminProvider.js +25 -19
  78. package/dist/esm/api/ConnectionClient.d.ts +11 -0
  79. package/dist/esm/api/ConnectionClient.d.ts.map +1 -1
  80. package/dist/esm/api/ConnectionClient.js +82 -9
  81. package/dist/esm/components/DropDownMenu.js +1 -1
  82. package/dist/esm/components/DropDownMenuWithLabel.d.ts.map +1 -1
  83. package/dist/esm/components/DropDownMenuWithLabel.js +16 -54
  84. package/dist/esm/components/OrgSelect.d.ts.map +1 -1
  85. package/dist/esm/components/OrgSelect.js +6 -19
  86. package/dist/esm/components/QuillSelect.d.ts +3 -0
  87. package/dist/esm/components/QuillSelect.d.ts.map +1 -0
  88. package/dist/esm/components/QuillSelect.js +130 -0
  89. package/dist/esm/components/SegmentedControl.d.ts +7 -0
  90. package/dist/esm/components/SegmentedControl.d.ts.map +1 -0
  91. package/dist/esm/components/SegmentedControl.js +50 -0
  92. package/dist/esm/components/UiComponents.d.ts +18 -29
  93. package/dist/esm/components/UiComponents.d.ts.map +1 -1
  94. package/dist/esm/components/UiComponents.js +37 -82
  95. package/dist/esm/forms/client_onboard/ConnectSchema.d.ts +2 -1
  96. package/dist/esm/forms/client_onboard/ConnectSchema.d.ts.map +1 -1
  97. package/dist/esm/forms/client_onboard/ConnectSchema.js +145 -70
  98. package/dist/esm/forms/client_onboard/CreateSqlViews.d.ts.map +1 -1
  99. package/dist/esm/forms/client_onboard/CreateSqlViews.js +41 -12
  100. package/dist/esm/forms/sql_views/CreateEditSqlView.d.ts +7 -4
  101. package/dist/esm/forms/sql_views/CreateEditSqlView.d.ts.map +1 -1
  102. package/dist/esm/forms/sql_views/CreateEditSqlView.js +38 -22
  103. package/dist/esm/hooks/useOnClickOutside.d.ts +3 -0
  104. package/dist/esm/hooks/useOnClickOutside.d.ts.map +1 -0
  105. package/dist/esm/hooks/useOnClickOutside.js +18 -0
  106. package/dist/esm/modals/EditFiltersModal.d.ts +17 -0
  107. package/dist/esm/modals/EditFiltersModal.d.ts.map +1 -0
  108. package/dist/esm/modals/EditFiltersModal.js +338 -0
  109. package/dist/esm/modals/NewDashboardModal.d.ts +1 -3
  110. package/dist/esm/modals/NewDashboardModal.d.ts.map +1 -1
  111. package/dist/esm/modals/NewDashboardModal.js +63 -46
  112. package/dist/esm/modals/PromoteDashModal.d.ts.map +1 -1
  113. package/dist/esm/modals/PromoteDashModal.js +10 -3
  114. package/dist/esm/modals/ReorderDashboardModal.d.ts.map +1 -1
  115. package/dist/esm/modals/ReorderDashboardModal.js +201 -89
  116. package/dist/esm/modals/index.d.ts +0 -1
  117. package/dist/esm/modals/index.d.ts.map +1 -1
  118. package/dist/esm/modals/index.js +0 -1
  119. package/dist/esm/primitives/ButtonPrimitive.d.ts +3 -1
  120. package/dist/esm/primitives/ButtonPrimitive.d.ts.map +1 -1
  121. package/dist/esm/primitives/ButtonPrimitive.js +5 -3
  122. package/dist/esm/primitives/ModalPrimitive.d.ts.map +1 -1
  123. package/dist/esm/primitives/ModalPrimitive.js +1 -2
  124. package/dist/esm/primitives/TogglePrimitive.js +5 -5
  125. package/dist/esm/public_components/CreateEnvironment.d.ts.map +1 -1
  126. package/dist/esm/public_components/CreateEnvironment.js +1 -1
  127. package/dist/esm/public_components/DashboardBuilder.d.ts.map +1 -1
  128. package/dist/esm/public_components/DashboardBuilder.js +128 -31
  129. package/dist/esm/public_components/DashboardManager.d.ts.map +1 -1
  130. package/dist/esm/public_components/DashboardManager.js +163 -195
  131. package/dist/esm/public_components/SQLViewManager.d.ts.map +1 -1
  132. package/dist/esm/public_components/SQLViewManager.js +92 -24
  133. package/dist/esm/utils/constants.d.ts +4 -4
  134. package/dist/esm/utils/constants.js +2 -2
  135. package/dist/esm/utils/schema.d.ts +6 -0
  136. package/dist/esm/utils/schema.d.ts.map +1 -1
  137. package/dist/esm/utils/table.d.ts +1 -0
  138. package/dist/esm/utils/table.d.ts.map +1 -1
  139. package/dist/esm/utils/table.js +11 -1
  140. package/dist/esm/utils/textProcessing.d.ts +2 -0
  141. package/dist/esm/utils/textProcessing.d.ts.map +1 -0
  142. package/dist/esm/utils/textProcessing.js +5 -0
  143. package/package.json +1 -1
  144. package/dist/cjs/modals/EditDashboardsModal.d.ts +0 -20
  145. package/dist/cjs/modals/EditDashboardsModal.d.ts.map +0 -1
  146. package/dist/cjs/modals/EditDashboardsModal.js +0 -94
  147. package/dist/esm/modals/EditDashboardsModal.d.ts +0 -20
  148. package/dist/esm/modals/EditDashboardsModal.d.ts.map +0 -1
  149. package/dist/esm/modals/EditDashboardsModal.js +0 -91
@@ -15,34 +15,29 @@ const NewDashboardModal_1 = require("../modals/NewDashboardModal");
15
15
  const constants_1 = require("../utils/constants");
16
16
  const EmptyDashboardComponent_1 = __importDefault(require("../components/EmptyDashboardComponent"));
17
17
  const DatabaseMismatchCard_1 = __importDefault(require("../components/DatabaseMismatchCard"));
18
+ const UiComponents_1 = require("../components/UiComponents");
19
+ const QuillSelect_1 = require("../components/QuillSelect");
20
+ const EditFiltersModal_1 = require("../modals/EditFiltersModal");
18
21
  function DashboardManager({ navigateToDashboardBuilder, containerStyle, }) {
19
22
  const { state, dispatch } = (0, AdminProvider_1.useAdmin)();
20
23
  const parentRef = (0, react_1.useRef)(null);
21
24
  const [initialLoad, setInitialLoad] = (0, react_1.useState)(true);
22
25
  const [dashboards, setDashboards] = (0, react_1.useState)([]);
23
26
  const [reloadFlag, setReloadFlag] = (0, react_1.useState)(false);
24
- const [selectedEditDashboard, setSelectedEditDashboard] = (0, react_1.useState)('');
25
27
  const [selectedReorderDashboard, setSelectedReorderDashboard] = (0, react_1.useState)('');
26
- const [addFilterModalIsOpen, setAddFilterModalIsOpen] = (0, react_1.useState)(false);
27
- const [isAddDashboardModalOpen, setIsAddDashboardModalOpen] = (0, react_1.useState)(false);
28
28
  const [newDashboardModalIsOpen, setNewDashboardModalIsOpen] = (0, react_1.useState)(false);
29
29
  const [editFilterModalIsOpen, setEditFilterModalIsOpen] = (0, react_1.useState)(false);
30
- const { reload: reloadDashboard } = (0, react_2.useDashboard)(state.selectedDashboard);
30
+ const { reload: reloadDashboard } = (0, react_2.useDashboard)(state.selectedDashboard?.name);
31
31
  const [isReorderDashboardModalOpen, setIsReorderDashboardModalOpen] = (0, react_1.useState)(false);
32
32
  const [dashboardData, setDashboardData] = (0, react_1.useState)(null);
33
- // const [activeComponent, setActiveComponent] = useContext(
34
- // ActiveComponentContext
35
- // );
36
- const [isEditDashboardModalOpen, setIsEditDashboardModalOpen] = (0, react_1.useState)(false);
37
33
  const [isPromoteDashModalOpen, setIsPromoteDashModalOpen] = (0, react_1.useState)(false);
38
- const [isOpen, setIsOpen] = (0, react_1.useState)(false);
39
34
  // A useless flag that just turns itself off.
40
35
  (0, react_1.useEffect)(() => {
41
36
  if (reloadFlag) {
42
37
  setReloadFlag(false);
43
38
  }
44
39
  }, [reloadFlag]);
45
- async function getDashNames() {
40
+ async function getDashNames(dashboardName) {
46
41
  const response = await fetch(`${state.queryEndpoint}`, {
47
42
  method: 'POST',
48
43
  headers: {
@@ -62,20 +57,19 @@ function DashboardManager({ navigateToDashboardBuilder, containerStyle, }) {
62
57
  const data = await response.json();
63
58
  setInitialLoad(false);
64
59
  if (!data.data.dashboardNames || !data.data.dashboardNames.length) {
60
+ dispatch({ type: 'SET_DASHBOARDS', payload: [] });
65
61
  return;
66
62
  }
67
- const dashNames = data.data.dashboardNames.map((elem) => {
68
- if (!elem) {
69
- return { name: 'null' };
70
- }
71
- return { name: elem };
63
+ let selectedDashboard = data.data.dashboards.find((dash) => {
64
+ return dash.name === dashboardName;
72
65
  });
73
- dispatch({ type: 'SET_DASHBOARDS', payload: dashNames });
66
+ if (!selectedDashboard) {
67
+ selectedDashboard = data.data.dashboards[0];
68
+ }
69
+ dispatch({ type: 'SET_DASHBOARDS', payload: data.data.dashboards });
74
70
  dispatch({
75
71
  type: 'SET_SELECTED_DASHBOARD',
76
- payload: dashNames.some((dash) => dash.name === state.selectedDashboard)
77
- ? state.selectedDashboard
78
- : dashNames[0].name,
72
+ payload: selectedDashboard,
79
73
  });
80
74
  }
81
75
  (0, react_1.useEffect)(() => {
@@ -92,7 +86,7 @@ function DashboardManager({ navigateToDashboardBuilder, containerStyle, }) {
92
86
  (0, react_1.useEffect)(() => {
93
87
  let isSubscribed = true;
94
88
  if (isSubscribed) {
95
- getDashNames();
89
+ getDashNames(state.selectedDashboard?.name || '');
96
90
  }
97
91
  return () => {
98
92
  isSubscribed = false;
@@ -114,13 +108,15 @@ function DashboardManager({ navigateToDashboardBuilder, containerStyle, }) {
114
108
  ...state.queryHeaders,
115
109
  'Content-Type': 'application/json',
116
110
  },
117
- body: JSON.stringify({ metadata: {
111
+ body: JSON.stringify({
112
+ metadata: {
118
113
  orgId: state.organizationId || '*',
119
114
  task: 'config',
120
115
  name: dashboard,
121
116
  clientId: state.client._id,
122
117
  databaseType: state.client.databaseType,
123
- } }),
118
+ },
119
+ }),
124
120
  credentials: state.withCredentials ? 'include' : 'omit', // If withCredentials is true, set to 'include'. Otherwise, set to 'omit'.
125
121
  });
126
122
  responseData = (await response.json()).data;
@@ -145,184 +141,156 @@ function DashboardManager({ navigateToDashboardBuilder, containerStyle, }) {
145
141
  }
146
142
  setData(responseData);
147
143
  }
148
- if (state.selectedEditDashboard) {
149
- getDashboardData(state.selectedEditDashboard, (data) => {
150
- dispatch({ type: 'SET_EDIT_DASHBOARD_DATA', payload: data });
151
- });
152
- return;
153
- }
154
144
  if (state.selectedDashboard && state.client) {
155
- getDashboardData(state.selectedDashboard, setDashboardData);
145
+ getDashboardData(state.selectedDashboard.name, setDashboardData);
156
146
  }
157
- }, [
158
- state.selectedDashboard,
159
- state.selectedEditDashboard,
160
- state.organizationId,
161
- state.client,
162
- ]);
163
- if (state.activeComponent == 'Report') {
164
- return ((0, jsx_runtime_1.jsx)(Admin_1.ReportWrapper, { ButtonComponent: primitives_1.ButtonPrimitive, SecondaryButtonComponent: primitives_1.SecondaryButtonPrimitive, ModalComponent: primitives_1.ModalPrimitive, SelectComponent: primitives_1.SelectPrimitive, OrganizationSelectComponent: components_1.OrgSelect, organizationId: state.organizationId, queryEndpoint: state.queryEndpoint, queryHeaders: state.queryHeaders, withCredentials: state.withCredentials }));
165
- }
166
- return ((0, jsx_runtime_1.jsx)("div", { style: containerStyle, children: (0, jsx_runtime_1.jsxs)("div", { style: {
167
- display: 'flex',
168
- flexDirection: 'column',
169
- paddingTop: '0px',
170
- position: 'relative',
171
- }, ref: parentRef, children: [(0, jsx_runtime_1.jsx)("div", { style: {
172
- // width: 'calc(100vw - 30px)',
173
- display: 'flex',
174
- position: 'sticky',
175
- backgroundColor: 'white',
176
- zIndex: 3,
177
- left: 0,
178
- right: 0,
179
- top: 0,
180
- flexDirection: 'row',
181
- paddingTop: 12,
182
- alignItems: 'center',
183
- justifyContent: 'space-between',
184
- paddingLeft: '30px',
185
- paddingRight: '30px',
186
- borderBottomWidth: 1,
187
- borderTopWidth: 0,
188
- borderLeftWidth: 0,
189
- borderRightWidth: 0,
190
- borderStyle: 'solid',
191
- borderColor: state.theme.borderColor,
192
- paddingBottom: 20,
193
- // boxShadow: "0px 1px 4px 0px rgba(0, 0, 0, 0.07)",
194
- // paddingRight: '50px',
195
- // position: 'absolute'
196
- // // zIndex: 10
197
- }, children: (0, jsx_runtime_1.jsxs)("div", { style: {
198
- width: '100%',
147
+ }, [state.selectedDashboard, state.organizationId, state.client]);
148
+ return ((0, jsx_runtime_1.jsxs)("div", { style: containerStyle, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
149
+ display: 'flex',
150
+ flexDirection: 'column',
151
+ paddingTop: '0px',
152
+ position: 'relative',
153
+ }, ref: parentRef, children: [(0, jsx_runtime_1.jsx)("div", { style: {
154
+ // width: 'calc(100vw - 30px)',
199
155
  display: 'flex',
156
+ position: 'sticky',
157
+ backgroundColor: 'white',
158
+ zIndex: 3,
159
+ left: 0,
160
+ right: 0,
161
+ top: 0,
200
162
  flexDirection: 'row',
201
- alignItems: 'flex-end',
163
+ paddingTop: 12,
164
+ alignItems: 'center',
202
165
  justifyContent: 'space-between',
203
- }, children: [(0, jsx_runtime_1.jsxs)("div", { style: { gap: 16, display: 'flex', flexDirection: 'row' }, children: [!!state.dashboards.length && ((0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', flexDirection: 'column' }, children: [(0, jsx_runtime_1.jsx)("h1", { style: {
204
- fontSize: '14px',
205
- paddingTop: '0px',
206
- marginTop: '0px',
207
- marginBottom: '4px',
208
- fontWeight: '600',
209
- color: state.theme.secondaryTextColor,
210
- userSelect: 'none',
211
- }, children: "Dashboard" }), (0, jsx_runtime_1.jsx)(components_1.DashboardSelectPopover, { dashboards: state.dashboards.length
212
- ? state.dashboards.map((elem) => {
213
- return { value: elem.name, label: elem.name };
214
- })
215
- : [], setDashboard: (dashboard) => {
216
- dispatch({
217
- type: 'SET_SELECTED_DASHBOARD',
218
- payload: dashboard,
219
- });
220
- }, dashboard: state.selectedDashboard ? state.selectedDashboard : '', theme: state.theme, onClickNewDashboard: () => {
221
- setNewDashboardModalIsOpen(true);
222
- }, setSelectedEditDashboard: (d) => {
223
- dispatch({
224
- type: 'SET_SELECTED_EDIT_DASHBOARD',
225
- payload: d,
226
- });
227
- setEditFilterModalIsOpen(true);
228
- } })] })), (0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', flexDirection: 'column' }, children: [(0, jsx_runtime_1.jsx)("h1", { style: {
229
- fontSize: '14px',
230
- paddingTop: '0px',
231
- marginTop: '0px',
232
- marginBottom: '4px',
233
- fontWeight: '600',
234
- color: state.theme.secondaryTextColor,
235
- fontFamily: state.theme.fontFamily,
236
- userSelect: 'none',
237
- }, children: "Environment" }), (0, jsx_runtime_1.jsx)(components_1.EnvSelectPopover, { setEnvironment: (env) => dispatch({ type: 'SET_ENVIRONMENT', payload: env }), environment: state.environment, clients: state.clients, client: state.client, setClient: (client) => dispatch({ type: 'SET_CLIENT', payload: client }), theme: state.theme, showPromote: true, handlePromote: () => setIsPromoteDashModalOpen(true) })] })] }), !!state.dashboards.length && !state.databaseTypeMismatch.show && ((0, jsx_runtime_1.jsx)(components_1.OrgSelect, { parentRef: parentRef, environment: state.environment, setEnvironment: (env) => dispatch({ type: 'SET_ENVIRONMENT', payload: env }), organizations: state.organizations, theme: state.theme, organizationId: state.organizationId, setOrganizationId: (id) => dispatch({ type: 'SET_ORGANIZATION_ID', payload: id }) }))] }) }), state.databaseTypeMismatch.show ? ((0, jsx_runtime_1.jsx)(DatabaseMismatchCard_1.default, { environemntName: state.client.name, environemntDatabaseType: state.client.databaseType, backendDatabaseType: state.databaseTypeMismatch.backendDatabaseType })) : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)("div", { style: { display: 'inline-block' }, children: [!state.dashboards.length && !initialLoad && ((0, jsx_runtime_1.jsx)("div", { style: {
238
- width: '100%',
239
- display: 'flex',
240
- flexDirection: 'column',
241
- alignItems: 'center',
242
- }, children: (0, jsx_runtime_1.jsxs)("div", { style: {
243
- height: 80,
244
- width: 260,
245
- borderRadius: 6,
246
- marginTop: 100,
166
+ paddingLeft: '30px',
167
+ paddingRight: '30px',
168
+ borderBottomWidth: 1,
169
+ borderTopWidth: 0,
170
+ borderLeftWidth: 0,
171
+ borderRightWidth: 0,
172
+ borderStyle: 'solid',
173
+ borderColor: state.theme?.borderColor,
174
+ paddingBottom: 20,
175
+ // boxShadow: "0px 1px 4px 0px rgba(0, 0, 0, 0.07)",
176
+ // paddingRight: '50px',
177
+ // position: 'absolute'
178
+ // // zIndex: 10
179
+ }, children: (0, jsx_runtime_1.jsxs)("div", { style: {
180
+ width: '100%',
181
+ display: 'flex',
182
+ flexDirection: 'row',
183
+ alignItems: 'flex-end',
184
+ justifyContent: 'space-between',
185
+ }, children: [(0, jsx_runtime_1.jsxs)("div", { style: { gap: 16, display: 'flex', flexDirection: 'row' }, children: [!!state.dashboards.length && ((0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', flexDirection: 'column' }, children: [(0, jsx_runtime_1.jsx)("h1", { style: {
186
+ fontSize: '14px',
187
+ paddingTop: '0px',
188
+ marginTop: '0px',
189
+ marginBottom: '4px',
190
+ fontWeight: '600',
191
+ color: state.theme.secondaryTextColor,
192
+ userSelect: 'none',
193
+ }, children: "Dashboard" }), (0, jsx_runtime_1.jsx)(components_1.DashboardSelectPopover, { dashboards: state.dashboards.length
194
+ ? state.dashboards.map((elem) => {
195
+ return { value: elem.name, label: elem.name };
196
+ })
197
+ : [], setDashboard: (dashboard) => {
198
+ const selectedDashboard = state.dashboards.find((dash) => {
199
+ return dash.name === dashboard;
200
+ });
201
+ dispatch({
202
+ type: 'SET_SELECTED_DASHBOARD',
203
+ payload: selectedDashboard,
204
+ });
205
+ }, dashboard: state.selectedDashboard
206
+ ? state.selectedDashboard.name
207
+ : '', theme: state.theme, onClickNewDashboard: () => {
208
+ setNewDashboardModalIsOpen(true);
209
+ }, setSelectedEditDashboard: (d) => {
210
+ setEditFilterModalIsOpen(true);
211
+ } })] })), (0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', flexDirection: 'column' }, children: [(0, jsx_runtime_1.jsx)("h1", { style: {
212
+ fontSize: '14px',
213
+ paddingTop: '0px',
214
+ marginTop: '0px',
215
+ marginBottom: '4px',
216
+ fontWeight: '600',
217
+ color: state.theme.secondaryTextColor,
218
+ fontFamily: state.theme.fontFamily,
219
+ userSelect: 'none',
220
+ }, children: "Environment" }), (0, jsx_runtime_1.jsx)(components_1.EnvSelectPopover, { setEnvironment: (env) => dispatch({ type: 'SET_ENVIRONMENT', payload: env }), environment: state.environment, clients: state.clients, client: state.client, setClient: (client) => dispatch({ type: 'SET_CLIENT', payload: client }), theme: state.theme, showPromote: true, handlePromote: () => setIsPromoteDashModalOpen(true) })] })] }), !!state.dashboards.length && !state.databaseTypeMismatch.show && ((0, jsx_runtime_1.jsx)(components_1.OrgSelect, { parentRef: parentRef, environment: state.environment, setEnvironment: (env) => dispatch({ type: 'SET_ENVIRONMENT', payload: env }), organizations: state.organizations, theme: state.theme, organizationId: state.organizationId, setOrganizationId: (id) => dispatch({ type: 'SET_ORGANIZATION_ID', payload: id }) }))] }) }), state.databaseTypeMismatch.show ? ((0, jsx_runtime_1.jsx)(DatabaseMismatchCard_1.default, { environemntName: state.client.name, environemntDatabaseType: state.client.databaseType, backendDatabaseType: state.databaseTypeMismatch.backendDatabaseType })) : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)("div", { style: { display: 'inline-block' }, children: [!state.dashboards.length && !initialLoad && ((0, jsx_runtime_1.jsx)("div", { style: {
221
+ width: '100%',
247
222
  display: 'flex',
248
223
  flexDirection: 'column',
249
224
  alignItems: 'center',
250
- justifyContent: 'center',
251
- gap: 20,
252
- }, className: "hover-dash-rect", onClick: () => {
253
- setNewDashboardModalIsOpen(true);
254
- }, children: [(0, jsx_runtime_1.jsx)("style", { children: ` .hover-dash-rect { background: white; border: 1px dashed #e7e7e7; } .hover-dash-rect:hover { background: white; box-shadow: 0px 1px 24px 0px rgba(0, 0, 0, 0.07); border: 1px solid #e7e7e7; } ` }), (0, jsx_runtime_1.jsxs)("div", { style: {
255
- display: 'flex',
256
- flexDirection: 'row',
257
- alignItems: 'center',
258
- justifyContent: 'center',
259
- width: 260,
260
- }, children: [(0, jsx_runtime_1.jsxs)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", fill: "#565656", height: 26, width: 26, children: [(0, jsx_runtime_1.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" }), (0, jsx_runtime_1.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" })] }), (0, jsx_runtime_1.jsx)("div", { style: {
261
- fontSize: 14,
262
- fontWeight: 500,
263
- color: '#565656',
264
- // border: '1px solid #e7e7e7',
265
- paddingTop: 8,
266
- paddingBottom: 8,
267
- paddingRight: 12,
268
- paddingLeft: 12,
269
- borderRadius: 4,
270
- cursor: 'pointer',
271
- }, className: "quill-hover-button", children: "Create new dashboard" })] })] }) })), reloadFlag ? null : ((0, jsx_runtime_1.jsx)(react_2.Dashboard, { name: state.selectedDashboard, containerStyle: {
272
- paddingRight: 25,
273
- paddingLeft: 25,
274
- paddingTop: 30,
275
- }, onClickDashboardItem: (elem) => {
276
- dispatch({ type: 'SET_REPORT_ID', payload: elem._id });
277
- dispatch({
278
- type: 'SET_ACTIVE_COMPONENT',
279
- payload: 'Report',
280
- });
281
- }, EmptyDashboardComponent: EmptyDashboardComponent_1.default }))] }), (0, jsx_runtime_1.jsx)(modals_1.EditDashboardsModal, { clientId: state.client._id, isOpen: isEditDashboardModalOpen, setIsOpen: setIsEditDashboardModalOpen, ModalComponent: primitives_1.ModalPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, SecondaryButtonComponent: primitives_1.SecondaryButtonPrimitive, TextInputComponent: primitives_1.TextInputPrimitive, openEditFilterModal: (dashboardName) => {
282
- dispatch({
283
- type: 'SET_SELECTED_EDIT_DASHBOARD',
284
- payload: dashboardName,
285
- });
286
- setEditFilterModalIsOpen(true);
287
- // setIsEditDashboardModalOpen(false);
288
- }, openAddDashboardModal: () => {
289
- setIsAddDashboardModalOpen(true);
290
- // setIsEditDashboardModalOpen(false);
291
- }, openEditOrderModal: (dashboardName) => {
292
- setSelectedReorderDashboard(dashboardName);
293
- setIsReorderDashboardModalOpen(true);
294
- }, HeaderComponent: primitives_1.HeaderPrimitive, setDashboardData: setDashboardData, dashboards: state.dashboards, getDashNames: getDashNames }), (0, jsx_runtime_1.jsx)(modals_1.PromoteDashModal, { clientId: state.client._id, client: state.client, clients: state.clients, isOpen: isPromoteDashModalOpen, setIsOpen: setIsPromoteDashModalOpen, ModalComponent: primitives_1.ModalPrimitive, dashboards: state.dashboards, selectedDashboard: state.selectedDashboard, theme: state.theme, ButtonComponent: primitives_1.ButtonPrimitive }), (0, jsx_runtime_1.jsx)(Admin_1.EditFiltersModal, { selectedDashboard: state.selectedDashboard, dashboardData: state.editDashboardData, isOpen: editFilterModalIsOpen, setIsOpen: setEditFilterModalIsOpen, openAddFilterModal: () => {
295
- setAddFilterModalIsOpen(true);
296
- // setEditFilterModalIsOpen(false);
297
- }, openEditOrderModal: (dashboardName) => {
298
- setSelectedReorderDashboard(dashboardName);
299
- setIsReorderDashboardModalOpen(true);
300
- }, onSave: async () => {
301
- await getDashNames();
302
- setReloadFlag(true);
303
- reloadDashboard();
304
- }, client: state.client, ModalComponent: primitives_1.ModalPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, SecondaryButtonComponent: primitives_1.SecondaryButtonPrimitive, TextInputComponent: primitives_1.TextInputPrimitive, HeaderComponent: primitives_1.HeaderPrimitive, SelectComponent: primitives_1.SelectPrimitive, dashNames: state.dashboards, setSelectedEditDashboard: (d) => dispatch({ type: 'SET_SELECTED_EDIT_DASHBOARD', payload: d }) }), (0, jsx_runtime_1.jsx)(NewDashboardModal_1.NewDashboardModal, { isOpen: newDashboardModalIsOpen, setIsOpen: setNewDashboardModalIsOpen, openEditOrderModal: (dashboardName) => {
305
- setSelectedReorderDashboard(dashboardName);
306
- setIsReorderDashboardModalOpen(true);
307
- }, onSave: (name) => {
308
- dispatch({ type: 'SET_SELECTED_DASHBOARD', payload: name });
309
- dispatch({
310
- type: 'SET_DASHBOARDS',
311
- payload: [...state.dashboards, { name }],
312
- });
313
- setReloadFlag(true);
314
- reloadDashboard();
315
- }, client: state.client, ModalComponent: primitives_1.ModalPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, SecondaryButtonComponent: primitives_1.SecondaryButtonPrimitive, TextInputComponent: primitives_1.TextInputPrimitive, HeaderComponent: primitives_1.HeaderPrimitive, SelectComponent: primitives_1.SelectPrimitive, dashNames: state.dashboards, setSelectedEditDashboard: (d) => dispatch({ type: 'SET_SELECTED_EDIT_DASHBOARD', payload: d }) }), (0, jsx_runtime_1.jsx)(modals_1.ReorderDashboardModal, { organizationId: state.organizationId, isOpen: isReorderDashboardModalOpen, client: state.client, onSave: () => {
316
- setReloadFlag(true);
317
- reloadDashboard();
318
- }, setIsOpen: setIsReorderDashboardModalOpen, ModalComponent: primitives_1.ModalPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, selectedDashboard: selectedReorderDashboard }), (0, jsx_runtime_1.jsx)(Admin_1.AddFilterModal, { selectedDashboard: state.selectedEditDashboard, isOpen: addFilterModalIsOpen, setIsOpen: setAddFilterModalIsOpen, client: state.client, ModalComponent: primitives_1.ModalPrimitive, TextInputComponent: primitives_1.TextInputPrimitive, SelectComponent: primitives_1.SelectPrimitive, HeaderComponent: primitives_1.HeaderPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, openAddDashboardModal: () => {
319
- setIsAddDashboardModalOpen(true);
320
- // setAddFilterModalIsOpen(false);
321
- } }), (0, jsx_runtime_1.jsx)(Admin_1.AddDashboardModal, { selectedDashboard: state.selectedDashboard, isOpen: isAddDashboardModalOpen, setIsOpen: setIsAddDashboardModalOpen, client: state.client, ModalComponent: primitives_1.ModalPrimitive, TextInputComponent: primitives_1.TextInputPrimitive, SelectComponent: primitives_1.SelectPrimitive, HeaderComponent: primitives_1.HeaderPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, dashNames: state.dashboards,
322
- // @ts-ignore
323
- openAddFilterModal: () => {
324
- setAddFilterModalIsOpen(true);
325
- // setIsAddDashboardModalOpen(false);
326
- }, organizationId: state.organizationId, getDashNames: getDashNames })] }))] }) }));
225
+ }, children: (0, jsx_runtime_1.jsxs)("div", { style: {
226
+ height: 80,
227
+ width: 260,
228
+ borderRadius: 6,
229
+ marginTop: 100,
230
+ display: 'flex',
231
+ flexDirection: 'column',
232
+ alignItems: 'center',
233
+ justifyContent: 'center',
234
+ gap: 20,
235
+ }, className: "hover-dash-rect", onClick: () => {
236
+ setNewDashboardModalIsOpen(true);
237
+ }, children: [(0, jsx_runtime_1.jsx)("style", { children: ` .hover-dash-rect { background: white; border: 1px dashed #e7e7e7; } .hover-dash-rect:hover { background: white; box-shadow: 0px 1px 24px 0px rgba(0, 0, 0, 0.07); border: 1px solid #e7e7e7; } ` }), (0, jsx_runtime_1.jsxs)("div", { style: {
238
+ display: 'flex',
239
+ flexDirection: 'row',
240
+ alignItems: 'center',
241
+ justifyContent: 'center',
242
+ width: 260,
243
+ }, children: [(0, jsx_runtime_1.jsxs)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", fill: "#565656", height: 26, width: 26, children: [(0, jsx_runtime_1.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" }), (0, jsx_runtime_1.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" })] }), (0, jsx_runtime_1.jsx)("div", { style: {
244
+ fontSize: 14,
245
+ fontWeight: 500,
246
+ color: '#565656',
247
+ // border: '1px solid #e7e7e7',
248
+ paddingTop: 8,
249
+ paddingBottom: 8,
250
+ paddingRight: 12,
251
+ paddingLeft: 12,
252
+ borderRadius: 4,
253
+ cursor: 'pointer',
254
+ }, className: "quill-hover-button", children: "Create new dashboard" })] })] }) })), reloadFlag
255
+ ? null
256
+ : (state.dashboards.length || initialLoad) && ((0, jsx_runtime_1.jsx)(react_2.Dashboard, { name: state.selectedDashboard?.name, containerStyle: { padding: 25 }, onClickReport: (elem) => {
257
+ dispatch({ type: 'SET_REPORT_ID', payload: elem._id });
258
+ dispatch({
259
+ type: 'SET_ACTIVE_COMPONENT',
260
+ payload: 'Report',
261
+ });
262
+ }, EmptyDashboardComponent: EmptyDashboardComponent_1.default }))] }), state.selectedDashboard && ((0, jsx_runtime_1.jsx)(modals_1.PromoteDashModal, { clientId: state.client._id, client: state.client, clients: state.clients, isOpen: isPromoteDashModalOpen, setIsOpen: setIsPromoteDashModalOpen, ModalComponent: primitives_1.ModalPrimitive, dashboards: state.dashboards, selectedDashboard: state.selectedDashboard?.name, theme: state.theme, ButtonComponent: primitives_1.ButtonPrimitive })), state.selectedDashboard && ((0, jsx_runtime_1.jsx)(EditFiltersModal_1.EditFiltersModal, { selectedDashboard: state.selectedDashboard, dashboardData: state.selectedDashboard, isOpen: editFilterModalIsOpen, setIsOpen: setEditFilterModalIsOpen, openEditOrderModal: (dashboardName) => {
263
+ setSelectedReorderDashboard(dashboardName);
264
+ setIsReorderDashboardModalOpen(true);
265
+ }, onSave: async (dashName) => {
266
+ await getDashNames(dashName);
267
+ setReloadFlag(true);
268
+ reloadDashboard(dashName);
269
+ }, client: state.client, ModalComponent: primitives_1.ModalPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, SecondaryButtonComponent: primitives_1.SecondaryButtonPrimitive, TextInputComponent: primitives_1.TextInputPrimitive, HeaderComponent: primitives_1.HeaderPrimitive, SelectComponent: QuillSelect_1.QuillSelectComponent, dashNames: state.dashboards })), (0, jsx_runtime_1.jsx)(NewDashboardModal_1.NewDashboardModal, { isOpen: newDashboardModalIsOpen, setIsOpen: setNewDashboardModalIsOpen, openEditOrderModal: (dashboardName) => {
270
+ setSelectedReorderDashboard(dashboardName);
271
+ setIsReorderDashboardModalOpen(true);
272
+ }, onSave: (dashboard) => {
273
+ dispatch({
274
+ type: 'SET_SELECTED_DASHBOARD',
275
+ payload: dashboard,
276
+ });
277
+ dispatch({
278
+ type: 'SET_DASHBOARDS',
279
+ payload: [...state.dashboards, { ...dashboard }],
280
+ });
281
+ setReloadFlag(true);
282
+ reloadDashboard(state.selectedDashboard?.name);
283
+ }, client: state.client, ModalComponent: primitives_1.ModalPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, SecondaryButtonComponent: primitives_1.SecondaryButtonPrimitive, TextInputComponent: primitives_1.TextInputPrimitive, HeaderComponent: primitives_1.HeaderPrimitive, SelectComponent: QuillSelect_1.QuillSelectComponent, dashNames: state.dashboards }), (0, jsx_runtime_1.jsx)(modals_1.ReorderDashboardModal, { organizationId: state.organizationId, isOpen: isReorderDashboardModalOpen, client: state.client, onSave: () => {
284
+ setReloadFlag(true);
285
+ reloadDashboard(state.selectedDashboard?.name);
286
+ }, setIsOpen: setIsReorderDashboardModalOpen, ModalComponent: primitives_1.ModalPrimitive, ButtonComponent: primitives_1.ButtonPrimitive, selectedDashboard: selectedReorderDashboard })] }))] }), (0, jsx_runtime_1.jsx)(Admin_1.ReportWrapper, { isOpen: state.activeComponent === 'Report', setIsOpen: (isOpen) => {
287
+ dispatch({
288
+ type: 'SET_ACTIVE_COMPONENT',
289
+ payload: isOpen ? 'Report' : 'Dashboards',
290
+ });
291
+ }, ButtonComponent: primitives_1.ButtonPrimitive, SecondaryButtonComponent: primitives_1.SecondaryButtonPrimitive, ModalComponent: UiComponents_1.MemoizedModal, SelectComponent: primitives_1.SelectPrimitive, OrganizationSelectComponent: components_1.OrgSelect, organizationId: state.organizationId, queryEndpoint: state.queryEndpoint, queryHeaders: state.queryHeaders, withCredentials: state.withCredentials, reloadDashboard: () => {
292
+ setReloadFlag(true);
293
+ reloadDashboard(state.selectedDashboard?.name);
294
+ } })] }));
327
295
  }
328
296
  exports.default = DashboardManager;
@@ -1 +1 @@
1
- {"version":3,"file":"SQLViewManager.d.ts","sourceRoot":"","sources":["../../../src/public_components/SQLViewManager.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAA+B,MAAM,OAAO,CAAC;AA0BnE,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EACrC,cAAc,GACf,EAAE;IACD,cAAc,CAAC,EAAE,aAAa,CAAC;CAChC,2CAqUA"}
1
+ {"version":3,"file":"SQLViewManager.d.ts","sourceRoot":"","sources":["../../../src/public_components/SQLViewManager.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAA+B,MAAM,OAAO,CAAC;AAyBnE,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EACrC,cAAc,GACf,EAAE;IACD,cAAc,CAAC,EAAE,aAAa,CAAC;CAChC,2CAgaA"}