@quillsql/react 2.11.16 → 2.11.18
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.
- package/dist/cjs/Chart.d.ts +109 -42
- package/dist/cjs/Chart.d.ts.map +1 -1
- package/dist/cjs/Chart.js +44 -18
- package/dist/cjs/ChartBuilder.d.ts +204 -30
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +124 -63
- package/dist/cjs/ChartEditor.d.ts +123 -19
- package/dist/cjs/ChartEditor.d.ts.map +1 -1
- package/dist/cjs/ChartEditor.js +47 -15
- package/dist/cjs/Dashboard.d.ts +148 -91
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/Dashboard.js +51 -159
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts +21 -1
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +5 -2
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +1 -1
- package/dist/cjs/QuillProvider.d.ts +105 -2
- package/dist/cjs/QuillProvider.d.ts.map +1 -1
- package/dist/cjs/QuillProvider.js +59 -0
- package/dist/cjs/ReportBuilder.d.ts +194 -42
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +563 -416
- package/dist/cjs/SQLEditor.d.ts +160 -23
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +36 -30
- package/dist/cjs/Table.d.ts +119 -15
- package/dist/cjs/Table.d.ts.map +1 -1
- package/dist/cjs/Table.js +37 -6
- package/dist/cjs/TableChart.d.ts.map +1 -1
- package/dist/cjs/TableChart.js +0 -194
- package/dist/cjs/{BarList.d.ts → components/Chart/BarList.d.ts} +1 -1
- package/dist/cjs/components/Chart/BarList.d.ts.map +1 -0
- package/dist/cjs/{BarList.js → components/Chart/BarList.js} +1 -1
- package/dist/cjs/components/Chart/LineChart.d.ts +2 -3
- package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/LineChart.js +3 -3
- package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -0
- package/dist/cjs/{PieChart.js → components/Chart/PieChart.js} +1 -1
- package/dist/cjs/components/Dashboard/ChartComponent.d.ts +2 -1
- package/dist/cjs/components/Dashboard/ChartComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/ChartComponent.js +6 -7
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts +22 -0
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -0
- package/dist/cjs/components/Dashboard/DashboardFilter.js +75 -0
- package/dist/cjs/components/Dashboard/DataLoader.d.ts +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.js +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.d.ts +2 -12
- package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.js +39 -17
- package/dist/cjs/components/Dashboard/TableComponent.d.ts +2 -1
- package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/TableComponent.js +6 -9
- package/dist/cjs/components/QuillCard.d.ts +2 -7
- package/dist/cjs/components/QuillCard.d.ts.map +1 -1
- package/dist/cjs/components/QuillCard.js +15 -9
- package/dist/cjs/components/QuillSelect.d.ts +4 -1
- package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
- package/dist/cjs/components/QuillSelect.js +13 -8
- package/dist/cjs/components/QuillTable.d.ts +16 -2
- package/dist/cjs/components/QuillTable.d.ts.map +1 -1
- package/dist/cjs/components/QuillTable.js +4 -4
- package/dist/cjs/components/ReportBuilder/AddColumnPopover.d.ts +9 -3
- package/dist/cjs/components/ReportBuilder/AddColumnPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddColumnPopover.js +10 -6
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts +13 -1
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.js +5 -15
- package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts +21 -1
- package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddSortPopover.js +15 -17
- package/dist/cjs/components/ReportBuilder/bigDateMap.js +1 -1
- package/dist/cjs/components/ReportBuilder/convert.d.ts +3 -1
- package/dist/cjs/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/convert.js +60 -21
- package/dist/cjs/components/ReportBuilder/operators.d.ts +15 -10
- package/dist/cjs/components/ReportBuilder/operators.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/operators.js +23 -10
- package/dist/cjs/components/ReportBuilder/pivot.d.ts +2 -1
- package/dist/cjs/components/ReportBuilder/pivot.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ui.d.ts +82 -18
- package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ui.js +55 -103
- package/dist/cjs/components/ReportBuilder/util.d.ts +10 -4
- package/dist/cjs/components/ReportBuilder/util.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/util.js +124 -71
- package/dist/cjs/components/UiComponents.d.ts +81 -87
- package/dist/cjs/components/UiComponents.d.ts.map +1 -1
- package/dist/cjs/components/UiComponents.js +76 -103
- package/dist/cjs/hooks/index.d.ts +1 -0
- package/dist/cjs/hooks/index.d.ts.map +1 -1
- package/dist/cjs/hooks/index.js +3 -1
- package/dist/cjs/hooks/useTheme.d.ts +7 -0
- package/dist/cjs/hooks/useTheme.d.ts.map +1 -0
- package/dist/cjs/hooks/useTheme.js +12 -0
- package/dist/cjs/index.d.ts +10 -2
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts +5 -2
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.js +21 -21
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +30 -14
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +77 -52
- package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
- package/dist/cjs/utils/dataFetcher.js +2 -0
- package/dist/cjs/utils/parserBigQuery.d.ts +6 -0
- package/dist/cjs/utils/parserBigQuery.d.ts.map +1 -0
- package/dist/cjs/utils/parserBigQuery.js +60 -0
- package/dist/cjs/utils/parserPostgres.d.ts +3 -0
- package/dist/cjs/utils/parserPostgres.d.ts.map +1 -0
- package/dist/cjs/utils/parserPostgres.js +42 -0
- package/dist/esm/Chart.d.ts +109 -42
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +45 -19
- package/dist/esm/ChartBuilder.d.ts +204 -30
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +124 -63
- package/dist/esm/ChartEditor.d.ts +123 -19
- package/dist/esm/ChartEditor.d.ts.map +1 -1
- package/dist/esm/ChartEditor.js +51 -19
- package/dist/esm/Dashboard.d.ts +148 -91
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/Dashboard.js +54 -160
- package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts +21 -1
- package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/QuillDateRangePicker.js +6 -3
- package/dist/esm/DateRangePicker/dateRangePickerUtils.js +1 -1
- package/dist/esm/QuillProvider.d.ts +105 -2
- package/dist/esm/QuillProvider.d.ts.map +1 -1
- package/dist/esm/QuillProvider.js +59 -0
- package/dist/esm/ReportBuilder.d.ts +194 -42
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +566 -419
- package/dist/esm/SQLEditor.d.ts +160 -23
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +36 -30
- package/dist/esm/Table.d.ts +119 -15
- package/dist/esm/Table.d.ts.map +1 -1
- package/dist/esm/Table.js +38 -7
- package/dist/esm/TableChart.d.ts.map +1 -1
- package/dist/esm/TableChart.js +0 -194
- package/dist/esm/{BarList.d.ts → components/Chart/BarList.d.ts} +1 -1
- package/dist/esm/components/Chart/BarList.d.ts.map +1 -0
- package/dist/esm/{BarList.js → components/Chart/BarList.js} +1 -1
- package/dist/esm/components/Chart/LineChart.d.ts +2 -3
- package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/LineChart.js +3 -3
- package/dist/esm/components/Chart/PieChart.d.ts.map +1 -0
- package/dist/esm/{PieChart.js → components/Chart/PieChart.js} +1 -1
- package/dist/esm/components/Dashboard/ChartComponent.d.ts +2 -1
- package/dist/esm/components/Dashboard/ChartComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/ChartComponent.js +5 -6
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts +22 -0
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -0
- package/dist/esm/components/Dashboard/DashboardFilter.js +71 -0
- package/dist/esm/components/Dashboard/DataLoader.d.ts +1 -1
- package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DataLoader.js +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.d.ts +2 -12
- package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.js +39 -17
- package/dist/esm/components/Dashboard/TableComponent.d.ts +2 -1
- package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/TableComponent.js +6 -9
- package/dist/esm/components/QuillCard.d.ts +2 -7
- package/dist/esm/components/QuillCard.d.ts.map +1 -1
- package/dist/esm/components/QuillCard.js +15 -9
- package/dist/esm/components/QuillSelect.d.ts +4 -1
- package/dist/esm/components/QuillSelect.d.ts.map +1 -1
- package/dist/esm/components/QuillSelect.js +14 -9
- package/dist/esm/components/QuillTable.d.ts +16 -2
- package/dist/esm/components/QuillTable.d.ts.map +1 -1
- package/dist/esm/components/QuillTable.js +4 -4
- package/dist/esm/components/ReportBuilder/AddColumnPopover.d.ts +9 -3
- package/dist/esm/components/ReportBuilder/AddColumnPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddColumnPopover.js +10 -6
- package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts +13 -1
- package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddLimitPopover.js +5 -15
- package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts +21 -1
- package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddSortPopover.js +17 -19
- package/dist/esm/components/ReportBuilder/bigDateMap.js +1 -1
- package/dist/esm/components/ReportBuilder/convert.d.ts +3 -1
- package/dist/esm/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/convert.js +51 -13
- package/dist/esm/components/ReportBuilder/operators.d.ts +15 -10
- package/dist/esm/components/ReportBuilder/operators.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/operators.js +23 -10
- package/dist/esm/components/ReportBuilder/pivot.d.ts +2 -1
- package/dist/esm/components/ReportBuilder/pivot.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ui.d.ts +82 -18
- package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ui.js +53 -101
- package/dist/esm/components/ReportBuilder/util.d.ts +10 -4
- package/dist/esm/components/ReportBuilder/util.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/util.js +114 -67
- package/dist/esm/components/UiComponents.d.ts +81 -87
- package/dist/esm/components/UiComponents.d.ts.map +1 -1
- package/dist/esm/components/UiComponents.js +71 -102
- package/dist/esm/hooks/index.d.ts +1 -0
- package/dist/esm/hooks/index.d.ts.map +1 -1
- package/dist/esm/hooks/index.js +1 -0
- package/dist/esm/hooks/useTheme.d.ts +7 -0
- package/dist/esm/hooks/useTheme.d.ts.map +1 -0
- package/dist/esm/hooks/useTheme.js +10 -0
- package/dist/esm/index.d.ts +10 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts +5 -2
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotList.js +21 -21
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +30 -14
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +77 -52
- package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
- package/dist/esm/utils/dataFetcher.js +2 -0
- package/dist/esm/utils/parserBigQuery.d.ts +6 -0
- package/dist/esm/utils/parserBigQuery.d.ts.map +1 -0
- package/dist/esm/utils/parserBigQuery.js +52 -0
- package/dist/esm/utils/parserPostgres.d.ts +3 -0
- package/dist/esm/utils/parserPostgres.d.ts.map +1 -0
- package/dist/esm/utils/parserPostgres.js +37 -0
- package/package.json +1 -1
- package/dist/cjs/BarList.d.ts.map +0 -1
- package/dist/cjs/PieChart.d.ts.map +0 -1
- package/dist/esm/BarList.d.ts.map +0 -1
- package/dist/esm/PieChart.d.ts.map +0 -1
- /package/dist/cjs/{PieChart.d.ts → components/Chart/PieChart.d.ts} +0 -0
- /package/dist/esm/{PieChart.d.ts → components/Chart/PieChart.d.ts} +0 -0
package/dist/esm/ChartEditor.js
CHANGED
|
@@ -1,23 +1,62 @@
|
|
|
1
|
-
import { jsx as _jsx
|
|
2
|
-
|
|
3
|
-
import { useContext, useEffect, useState } from 'react';
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/* eslint-disable no-unused-vars */
|
|
3
|
+
import { useContext, useEffect, useRef, useState, } from 'react';
|
|
4
4
|
import ChartBuilder from './ChartBuilder';
|
|
5
|
-
import { DashboardContext, DashboardFiltersContext, ClientContext,
|
|
6
|
-
import { MemoizedModal
|
|
5
|
+
import { DashboardContext, DashboardFiltersContext, ClientContext, } from './Context';
|
|
6
|
+
import { MemoizedModal } from './components/UiComponents';
|
|
7
7
|
import { getData } from './utils/dataFetcher';
|
|
8
8
|
import { mergeComparisonRange } from './utils/merge';
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
import { QuillCard } from './components/QuillCard';
|
|
10
|
+
/**
|
|
11
|
+
* ### Quill Chart Editor
|
|
12
|
+
*
|
|
13
|
+
* Presents the Quill Chart Builder form as a modal.
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```js
|
|
17
|
+
* // Usage without custom components
|
|
18
|
+
* <ChartEditor isOpen={true} chartId="1234" />
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* @example
|
|
22
|
+
* ```js
|
|
23
|
+
* // You can also pass your own components
|
|
24
|
+
* <ChartEditor
|
|
25
|
+
* isOpen={isOpen}
|
|
26
|
+
* setIsOpen={setIsOpen}
|
|
27
|
+
* chartId="1234"
|
|
28
|
+
* Button={MyButton}
|
|
29
|
+
* Modal={MyModal}
|
|
30
|
+
* />
|
|
31
|
+
* ```
|
|
32
|
+
*
|
|
33
|
+
* ### Chart Editor API
|
|
34
|
+
* @see https://docs.quillsql.com/components/chart-editor
|
|
35
|
+
*/
|
|
36
|
+
export default function ChartEditor({ isOpen, chartId, isAdmin = false, destinationDashboard, chartBuilderTitle = 'Edit chart', chartBuilderButtonLabel, onAddToDashboardComplete, organizationName, isHorizontalView = true, onDelete, setIsOpen, SelectComponent, TextInputComponent, ButtonComponent, SecondaryButtonComponent, HeaderComponent, LabelComponent, TextComponent, DeleteButtonComponent, ModalComponent = MemoizedModal, CardComponent = QuillCard, PopoverComponent, hideDeleteButton = false, hideSubmitButton = false, }) {
|
|
37
|
+
const parentRef = useRef(null);
|
|
38
|
+
const [modalWidth, setModalWidth] = useState(200);
|
|
39
|
+
const [modalHeight, setModalHeight] = useState(200);
|
|
11
40
|
const { dispatch, dashboard } = useContext(DashboardContext);
|
|
12
41
|
const { dashboardFilters } = useContext(DashboardFiltersContext);
|
|
13
42
|
const [client, _] = useContext(ClientContext);
|
|
14
43
|
const [dashboardItem, setDashboardItem] = useState(dashboard?.[chartId]);
|
|
15
44
|
const [isLoading, setIsLoading] = useState(false);
|
|
16
|
-
const [error, setError] = useState(undefined);
|
|
17
45
|
const dateFilter = Object.values(dashboardFilters).find((filter) => filter.filterType == 'date_range');
|
|
18
46
|
const dateRange = dateFilter?.startDate
|
|
19
47
|
? [dateFilter?.startDate, dateFilter?.endDate, null]
|
|
20
48
|
: [null, null, null];
|
|
49
|
+
useEffect(() => {
|
|
50
|
+
function handleResize() {
|
|
51
|
+
setModalWidth(window.innerWidth - 80);
|
|
52
|
+
setModalHeight(window.innerHeight - 80);
|
|
53
|
+
}
|
|
54
|
+
handleResize();
|
|
55
|
+
window.addEventListener('resize', handleResize);
|
|
56
|
+
return () => {
|
|
57
|
+
window.removeEventListener('resize', handleResize);
|
|
58
|
+
};
|
|
59
|
+
}, []);
|
|
21
60
|
useEffect(() => {
|
|
22
61
|
let isSubscribed = true;
|
|
23
62
|
async function getChartOptions() {
|
|
@@ -74,15 +113,8 @@ export default function ChartEditor({ isOpen, chartId, isEditMode, admin = false
|
|
|
74
113
|
if (!dashboardItem) {
|
|
75
114
|
return _jsx("div", {});
|
|
76
115
|
}
|
|
77
|
-
return (_jsx(
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
}
|
|
82
|
-
: {}, theme: theme, children: _jsx(ChartBuilder, { dashboardItem: dashboardItem, rows: dashboardItem.rows, columns: dashboardItem.columns, fields: dashboardItem.fields, query: dashboardItem.queryString, pivot: dashboardItem.pivot, isOpen: isOpen, isEditMode: isEditMode, setIsOpen: setIsOpen, showTableFormatOptions: admin, showDateFieldOptions: admin, showAccessControlOptions: admin, showDashboardDropdown: admin, destinationDashboard: destinationDashboard, onAddToDashboardComplete: onAddToDashboardComplete, dateRange: dateRange, Select: Select, TextInput: TextInput, Button: Button, SecondaryButton: SecondaryButton, Header: Header, Label: Label, Text: Text, DeleteButton: DeleteButton, Modal: Modal, horizontalView: horizontalView, Popover: Popover, onDelete: onDelete, title: chartBuilderTitle, buttonLabel: chartBuilderButtonLabel, organizationName: organizationName }) })) : (_jsx(MemoizedModal, { setIsOpen: setIsOpen, isOpen: isOpen, onClose: () => setIsOpen(false), title: chartBuilderTitle || 'Add to dashboard', style: horizontalView
|
|
83
|
-
? {
|
|
84
|
-
width: 'calc(100vw - 80px)',
|
|
85
|
-
height: 'calc(100vh - 80px)',
|
|
86
|
-
}
|
|
87
|
-
: {}, theme: theme, children: _jsx(ChartBuilder, { dashboardItem: dashboardItem, rows: dashboardItem.rows, columns: dashboardItem.columns, fields: dashboardItem.fields, query: dashboardItem.queryString, pivot: dashboardItem.pivot, isOpen: isOpen, isEditMode: isEditMode, setIsOpen: setIsOpen, isOpenEditBar: isOpenEditBar, showTableFormatOptions: admin, showDateFieldOptions: admin, showAccessControlOptions: admin, showDashboardDropdown: admin, destinationDashboard: destinationDashboard, onAddToDashboardComplete: onAddToDashboardComplete, dateRange: dateRange, Select: Select, TextInput: TextInput, Button: Button, SecondaryButton: SecondaryButton, Header: Header, Label: Label, Text: Text, DeleteButton: DeleteButton, Modal: Modal, horizontalView: horizontalView, Popover: Popover, onDelete: onDelete, title: chartBuilderTitle, buttonLabel: chartBuilderButtonLabel, organizationName: organizationName }) })) }));
|
|
116
|
+
return (_jsx("div", { ref: parentRef, children: _jsx(ModalComponent, { isOpen: isOpen, setIsOpen: setIsOpen, title: chartBuilderTitle || 'Add to dashboard',
|
|
117
|
+
// For isHorizontalView, use full viewport size minus 80px for padding,
|
|
118
|
+
// otherwise use the default layout method of the modal (contents).
|
|
119
|
+
width: isHorizontalView ? modalWidth : undefined, height: isHorizontalView ? modalHeight : undefined, children: _jsx(ChartBuilder, { dashboardItem: dashboardItem, rows: dashboardItem.rows, columns: dashboardItem.columns, fields: dashboardItem.fields, query: dashboardItem.queryString, pivot: dashboardItem.pivot, isOpen: isOpen, setIsOpen: setIsOpen, showTableFormatOptions: isAdmin, showDateFieldOptions: isAdmin, showAccessControlOptions: isAdmin, showDashboardDropdown: isAdmin, destinationDashboard: destinationDashboard, onAddToDashboardComplete: onAddToDashboardComplete, dateRange: dateRange, SelectComponent: SelectComponent, TextInputComponent: TextInputComponent, ButtonComponent: ButtonComponent, SecondaryButtonComponent: SecondaryButtonComponent, HeaderComponent: HeaderComponent, LabelComponent: LabelComponent, TextComponent: TextComponent, DeleteButtonComponent: DeleteButtonComponent, CardComponent: CardComponent, ModalComponent: ModalComponent, isHorizontalView: isHorizontalView, PopoverComponent: PopoverComponent, onDelete: onDelete, title: chartBuilderTitle, buttonLabel: chartBuilderButtonLabel, organizationName: organizationName, hideSubmitButton: hideSubmitButton, hideDeleteButton: hideDeleteButton }) }) }));
|
|
88
120
|
}
|
package/dist/esm/Dashboard.d.ts
CHANGED
|
@@ -1,49 +1,28 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
theme?: any;
|
|
13
|
-
}
|
|
14
|
-
export interface DateRangePickerComponentProps {
|
|
15
|
-
dateRange: {
|
|
16
|
-
startDate: Date;
|
|
17
|
-
endDate: Date;
|
|
18
|
-
};
|
|
19
|
-
label?: string;
|
|
20
|
-
onChangeDateRange: (_: {
|
|
21
|
-
startDate: Date;
|
|
22
|
-
endDate: Date;
|
|
23
|
-
}) => void;
|
|
24
|
-
presetOptions: {
|
|
25
|
-
label: string;
|
|
26
|
-
value: string;
|
|
27
|
-
}[];
|
|
28
|
-
onChangePreset: (_: string) => void;
|
|
29
|
-
preset: string;
|
|
30
|
-
}
|
|
31
|
-
interface FilterButtonComponentProps {
|
|
32
|
-
onClick: () => void;
|
|
33
|
-
label: string;
|
|
34
|
-
}
|
|
35
|
-
interface ModalComponentProps {
|
|
36
|
-
children: any;
|
|
37
|
-
isOpen: boolean;
|
|
38
|
-
onClose: () => void;
|
|
39
|
-
title: string;
|
|
1
|
+
import React, { ReactNode, ChangeEvent } from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* The props passed into the ChartComponent, TableComponent, and MetricComponent
|
|
4
|
+
* functions in the dashboard.
|
|
5
|
+
*/
|
|
6
|
+
export interface DashboardItemProps {
|
|
7
|
+
dashboardItem: DashboardItem;
|
|
8
|
+
onClick?: (item: DashboardItem) => void;
|
|
9
|
+
isLoading?: boolean;
|
|
10
|
+
error?: string;
|
|
11
|
+
children?: ReactNode;
|
|
40
12
|
}
|
|
13
|
+
/**
|
|
14
|
+
* A set of valid format values for the x and y axes of dashboard items.
|
|
15
|
+
*/
|
|
41
16
|
export type AxisFormat = 'percent' | 'dollar_amount' | 'dollar_cents' | 'whole_number' | 'one_decimal_place' | 'two_decimal_places' | 'string' | 'yyyy' | 'MMM_yyyy' | 'MMM_dd_yyyy' | 'hh_ap_pm' | 'MMM_dd-MMM_dd' | 'MMM_dd_hh:mm_ap_pm' | 'wo, yyyy';
|
|
42
17
|
/**
|
|
18
|
+
* ## DashboardItem
|
|
43
19
|
* A dashboard item represents an individual item on a dashboard.
|
|
44
20
|
*
|
|
45
21
|
* Dashboard items can be charts, metric tiles, tables, etc. and can be styled
|
|
46
22
|
* however you'd like.
|
|
23
|
+
*
|
|
24
|
+
* ### API Reference
|
|
25
|
+
* @see https://docs.quillsql.com/components/quill-provider#dashboarditem
|
|
47
26
|
*/
|
|
48
27
|
export interface DashboardItem {
|
|
49
28
|
/** The dashboard item's unique id. */
|
|
@@ -60,12 +39,12 @@ export interface DashboardItem {
|
|
|
60
39
|
columns: any[];
|
|
61
40
|
/** The type of this chart. */
|
|
62
41
|
chartType: string;
|
|
63
|
-
/** The table and field this chart uses for date filtering */
|
|
42
|
+
/** The table and field this chart uses for date filtering. */
|
|
64
43
|
dateField: {
|
|
65
44
|
table: string;
|
|
66
45
|
field: string;
|
|
67
46
|
} | null;
|
|
68
|
-
/** The pivot used in this query */
|
|
47
|
+
/** The pivot used in this query, if any. */
|
|
69
48
|
pivot: {
|
|
70
49
|
title: string;
|
|
71
50
|
aggregationType: 'sum' | 'average' | 'count';
|
|
@@ -74,6 +53,7 @@ export interface DashboardItem {
|
|
|
74
53
|
columnField: string | undefined;
|
|
75
54
|
columnFieldType: string | undefined;
|
|
76
55
|
valueField: string;
|
|
56
|
+
valueFieldType: string;
|
|
77
57
|
} | null;
|
|
78
58
|
/** The formatted primary range aggregation value, if any. */
|
|
79
59
|
primaryAggregation?: string;
|
|
@@ -100,7 +80,7 @@ export interface DashboardItem {
|
|
|
100
80
|
}[];
|
|
101
81
|
/**
|
|
102
82
|
* The relative ordering of this dashboard item in relation to its sibling
|
|
103
|
-
* dashboard items. Ordering starts at 1 and counts up.
|
|
83
|
+
* dashboard items. Ordering starts at 1 and counts up (eg. 1, 2, 3, etc.).
|
|
104
84
|
*
|
|
105
85
|
* Also note that dashboard items in the same section are first grouped by
|
|
106
86
|
* `chartType` and then each group is sorted by `order`. Currently, the first
|
|
@@ -120,64 +100,141 @@ export interface DashboardItem {
|
|
|
120
100
|
[key: string]: any;
|
|
121
101
|
};
|
|
122
102
|
}
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
isLoading?: boolean;
|
|
127
|
-
error?: string | null;
|
|
128
|
-
children?: any;
|
|
129
|
-
theme?: any;
|
|
130
|
-
style?: any;
|
|
131
|
-
}
|
|
103
|
+
/**
|
|
104
|
+
* Props for the Quill Dashboard component.
|
|
105
|
+
*/
|
|
132
106
|
export interface DashboardProps {
|
|
133
|
-
/**
|
|
107
|
+
/**
|
|
108
|
+
* The name of the dashboard you created in the Quill Portal.
|
|
109
|
+
*/
|
|
134
110
|
name?: string;
|
|
111
|
+
/** A component that wraps a dashboard item for 'metric' chart types. */
|
|
112
|
+
MetricComponent?: ({ dashboardItem, onClick, isLoading, error, }: {
|
|
113
|
+
dashboardItem: DashboardItem;
|
|
114
|
+
onClick?: (item: DashboardItem) => void;
|
|
115
|
+
isLoading?: boolean;
|
|
116
|
+
error?: string;
|
|
117
|
+
}) => JSX.Element;
|
|
118
|
+
/** A component that wraps a dashboard item for non-table, non-metric chart types. */
|
|
119
|
+
ChartComponent?: ({ dashboardItem, onClick, isLoading, error, children, }: {
|
|
120
|
+
dashboardItem: DashboardItem;
|
|
121
|
+
onClick?: (item: DashboardItem) => void;
|
|
122
|
+
isLoading?: boolean;
|
|
123
|
+
error?: string;
|
|
124
|
+
children?: ReactNode;
|
|
125
|
+
}) => JSX.Element;
|
|
126
|
+
/** A component that wraps a dashboard item for 'table' chart types. */
|
|
127
|
+
TableComponent?: ({ dashboardItem, onClick, isLoading, error, }: {
|
|
128
|
+
dashboardItem: DashboardItem;
|
|
129
|
+
onClick?: (item: DashboardItem) => void;
|
|
130
|
+
isLoading?: boolean;
|
|
131
|
+
error?: string;
|
|
132
|
+
}) => JSX.Element;
|
|
133
|
+
/** A select component. */
|
|
134
|
+
SelectComponent?: ({ label, value, options, onChange, }: {
|
|
135
|
+
value: string;
|
|
136
|
+
label?: string;
|
|
137
|
+
options: {
|
|
138
|
+
value: string;
|
|
139
|
+
label: string;
|
|
140
|
+
}[];
|
|
141
|
+
onChange: (event: React.ChangeEvent<HTMLSelectElement>) => void;
|
|
142
|
+
}) => JSX.Element;
|
|
143
|
+
/** A date range picker component. */
|
|
144
|
+
DateRangePickerComponent?: ({ dateRange, label, presetOptions, preset, onChangeDateRange, onChangePreset, }: {
|
|
145
|
+
preset: string;
|
|
146
|
+
label?: string;
|
|
147
|
+
dateRange: {
|
|
148
|
+
startDate: Date;
|
|
149
|
+
endDate: Date;
|
|
150
|
+
};
|
|
151
|
+
presetOptions: {
|
|
152
|
+
label: string;
|
|
153
|
+
value: string;
|
|
154
|
+
}[];
|
|
155
|
+
onChangeDateRange: ({ startDate, endDate, }: {
|
|
156
|
+
startDate: Date;
|
|
157
|
+
endDate: Date;
|
|
158
|
+
}) => void;
|
|
159
|
+
onChangePreset: (event: ChangeEvent<HTMLSelectElement>) => void;
|
|
160
|
+
}) => JSX.Element;
|
|
135
161
|
/**
|
|
136
|
-
*
|
|
137
|
-
*
|
|
138
|
-
* This container is the parent of all the filtering buttons as well as any
|
|
139
|
-
* dashboard sections. The passed style can either be an object of React-style
|
|
140
|
-
* CSSProperties or a TailwindCSS-style classname string.
|
|
162
|
+
* A component that wraps each dashboard section.
|
|
141
163
|
*/
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
164
|
+
DashboardSectionComponent?: ({ section, children, }: {
|
|
165
|
+
section: 'metrics' | 'charts' | 'tables';
|
|
166
|
+
children: ReactNode;
|
|
167
|
+
}) => JSX.Element;
|
|
168
|
+
/** A component that wraps all dashboard sections. */
|
|
169
|
+
DashboardSectionContainerComponent?: ({ children, }: {
|
|
170
|
+
children: ReactNode;
|
|
171
|
+
}) => JSX.Element;
|
|
172
|
+
/** A fallback component displayed when an active dashboard has no items. */
|
|
150
173
|
EmptyDashboardComponent?: () => JSX.Element;
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
onChangeLoading?: (_: boolean) => void;
|
|
174
|
+
/** A callback fired when a dashboard item is clicked. */
|
|
175
|
+
onClickDashboardItem?: (item: DashboardItem) => void;
|
|
176
|
+
/** A callback that is fired when the loading status of the dashboard changes. */
|
|
177
|
+
onChangeLoading?: (isLoading: boolean) => void;
|
|
178
|
+
/** Whether to hide the dashboard filters (default: `false`). */
|
|
179
|
+
hideFilters?: boolean;
|
|
180
|
+
/** Whether the date range filters on the dashboard are hidden (default: `false`). */
|
|
181
|
+
hideDateRangeFilter?: boolean;
|
|
182
|
+
/** Whether to hide the xAxis (default: `false`). */
|
|
161
183
|
hideXAxis?: boolean;
|
|
184
|
+
/** Whether to hide the yAxis (default: `false`). */
|
|
162
185
|
hideYAxis?: boolean;
|
|
186
|
+
/** Whether to hide the cartesian grid (default: `false`). */
|
|
163
187
|
hideCartesianGrid?: boolean;
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
188
|
+
/** The line style for comparison ranges on line chart (default: `solid`). */
|
|
189
|
+
comparisonLineStyle?: 'solid' | 'dashed';
|
|
190
|
+
/**
|
|
191
|
+
* Applies the following classes to the ReportBuilder.
|
|
192
|
+
*
|
|
193
|
+
* This container is the parent of all the filtering buttons as well as any
|
|
194
|
+
* dashboard sections. This can be useful for TailwindCSS-style classname
|
|
195
|
+
* strings.
|
|
196
|
+
*/
|
|
197
|
+
className?: string;
|
|
198
|
+
/**
|
|
199
|
+
* The styles for the dashboard container.
|
|
200
|
+
*
|
|
201
|
+
* This container is the parent of all the filtering buttons as well as any
|
|
202
|
+
* dashboard sections.
|
|
203
|
+
*/
|
|
204
|
+
containerStyle?: React.CSSProperties;
|
|
205
|
+
/** The styles for the chart container. */
|
|
206
|
+
chartContainerStyle?: React.CSSProperties;
|
|
176
207
|
}
|
|
177
|
-
export declare function DashboardFilter({ filter, onChangeFilter, SelectComponent, DateRangePickerComponent, theme, }: DashboardFilterProps): import("react/jsx-runtime").JSX.Element | null;
|
|
178
208
|
/**
|
|
179
|
-
* Quill Dashboard
|
|
209
|
+
* ### Quill Dashboard
|
|
210
|
+
*
|
|
211
|
+
* Dynamically displays a filterable grid of charts, metrics, and tables with
|
|
212
|
+
* live data from your database. Once implemented, Quill lets you perform
|
|
213
|
+
* zero-downtime, zero-code updates to your dashboard views on an org-level as
|
|
214
|
+
* well as company-wide.
|
|
215
|
+
*
|
|
216
|
+
* @example
|
|
217
|
+
* ```js
|
|
218
|
+
* // Usage without custom components
|
|
219
|
+
* <Dashboard />
|
|
220
|
+
* ```
|
|
221
|
+
*
|
|
222
|
+
* @example
|
|
223
|
+
* ```js
|
|
224
|
+
* // You can also pass your own components
|
|
225
|
+
* <Dashboard
|
|
226
|
+
* name="saved_reports"
|
|
227
|
+
* SelectComponent={MySelect}
|
|
228
|
+
* onClickDashboardItem={(item) => navigate(`/detail/${item.id}`)}
|
|
229
|
+
* MetricComponent={MyMetric}
|
|
230
|
+
* ChartComponent={MyChart}
|
|
231
|
+
* TableComponent={MyTable}
|
|
232
|
+
* containerStyle={{ backgroundColor: 'white', padding: '10px' }}
|
|
233
|
+
* />
|
|
234
|
+
* ```
|
|
235
|
+
*
|
|
236
|
+
* ### API Reference
|
|
237
|
+
* @see https://docs.quillsql.com/components/dashboard
|
|
180
238
|
*/
|
|
181
|
-
export default function Dashboard({ name,
|
|
182
|
-
export {};
|
|
239
|
+
export default function Dashboard({ name, SelectComponent, EmptyDashboardComponent, DateRangePickerComponent, MetricComponent, ChartComponent, TableComponent, DashboardSectionComponent, DashboardSectionContainerComponent, onClickDashboardItem, onChangeLoading, hideFilters, hideDateRangeFilter, hideXAxis, hideYAxis, hideCartesianGrid, comparisonLineStyle, containerStyle, className, chartContainerStyle, }: DashboardProps): import("react/jsx-runtime").JSX.Element;
|
|
183
240
|
//# sourceMappingURL=Dashboard.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Dashboard.d.ts","sourceRoot":"","sources":["../../src/Dashboard.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Dashboard.d.ts","sourceRoot":"","sources":["../../src/Dashboard.tsx"],"names":[],"mappings":"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"}
|