@quillsql/react 2.12.28 → 2.12.30
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 +24 -10
- package/dist/cjs/Chart.d.ts.map +1 -1
- package/dist/cjs/Chart.js +151 -189
- package/dist/cjs/ChartBuilder.d.ts +51 -11
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +162 -101
- package/dist/cjs/ChartEditor.d.ts +13 -1
- package/dist/cjs/ChartEditor.d.ts.map +1 -1
- package/dist/cjs/ChartEditor.js +62 -121
- package/dist/cjs/Context.d.ts +1 -19
- package/dist/cjs/Context.d.ts.map +1 -1
- package/dist/cjs/Context.js +74 -85
- package/dist/cjs/Dashboard.d.ts +16 -7
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/Dashboard.js +90 -68
- package/dist/cjs/DateRangePicker/Calendar.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/Calendar.js +3 -6
- package/dist/cjs/DateRangePicker/DateRangePicker.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/DateRangePicker.js +2 -3
- package/dist/cjs/DateRangePicker/DateRangePickerButton.d.ts +1 -2
- package/dist/cjs/DateRangePicker/DateRangePickerButton.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/DateRangePickerButton.js +2 -4
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts +2 -1
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +4 -4
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +1 -1
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +1 -15
- package/dist/cjs/ReportBuilder.d.ts +22 -1
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +758 -505
- package/dist/cjs/SQLEditor.d.ts +2 -9
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +142 -90
- package/dist/cjs/Table.d.ts +19 -3
- package/dist/cjs/Table.d.ts.map +1 -1
- package/dist/cjs/Table.js +110 -92
- package/dist/cjs/TableChart.d.ts.map +1 -1
- package/dist/cjs/TableChart.js +0 -1
- package/dist/cjs/assets/ArrowDownHeadIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowDownIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowDownRightIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowLeftHeadIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowRightHeadIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowRightIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowUpHeadIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowUpIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ArrowUpRightIcon.d.ts.map +1 -1
- package/dist/cjs/assets/CalendarIcon.d.ts.map +1 -1
- package/dist/cjs/assets/DoubleArrowLeftHeadIcon.d.ts.map +1 -1
- package/dist/cjs/assets/DoubleArrowRightHeadIcon.d.ts.map +1 -1
- package/dist/cjs/assets/ExclamationFilledIcon.d.ts.map +1 -1
- package/dist/cjs/assets/LoadingSpinner.d.ts.map +1 -1
- package/dist/cjs/assets/SearchIcon.d.ts.map +1 -1
- package/dist/cjs/assets/XCircleIcon.d.ts.map +1 -1
- package/dist/cjs/components/Banner/index.d.ts +1 -1
- package/dist/cjs/components/Banner/index.d.ts.map +1 -1
- package/dist/cjs/components/Banner/index.js +1 -1
- package/dist/cjs/components/BigModal/BigModal.d.ts.map +1 -1
- package/dist/cjs/components/BigModal/BigModal.js +6 -12
- package/dist/cjs/components/Chart/BarList.d.ts.map +1 -1
- package/dist/cjs/components/Chart/BarList.js +21 -14
- package/dist/cjs/components/Chart/ChartError.d.ts +8 -1
- package/dist/cjs/components/Chart/ChartError.d.ts.map +1 -1
- package/dist/cjs/components/Chart/ChartError.js +40 -5
- package/dist/cjs/components/Chart/ChartTooltip.d.ts.map +1 -1
- package/dist/cjs/components/Chart/ChartTooltip.js +8 -2
- package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/LineChart.js +2 -2
- package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/PieChart.js +1 -3
- package/dist/cjs/components/Dashboard/ChartComponent.d.ts +1 -1
- package/dist/cjs/components/Dashboard/ChartComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/ChartComponent.js +1 -1
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts +5 -1
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DashboardFilter.js +10 -5
- package/dist/cjs/components/Dashboard/DataLoader.d.ts +2 -6
- package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.js +98 -187
- package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.js +1 -1
- package/dist/cjs/components/Dashboard/TableComponent.d.ts +1 -4
- package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/TableComponent.js +3 -3
- package/dist/cjs/components/Dropdown/Dropdown.d.ts.map +1 -1
- package/dist/cjs/components/Dropdown/Dropdown.js +1 -3
- package/dist/cjs/components/Dropdown/DropdownItem.d.ts.map +1 -1
- package/dist/cjs/components/Dropdown/DropdownItem.js +3 -8
- package/dist/cjs/components/Dropdown/index.d.ts +2 -2
- package/dist/cjs/components/Modal/Modal.d.ts.map +1 -1
- package/dist/cjs/components/Modal/Modal.js +2 -3
- package/dist/cjs/components/Modal/index.d.ts +1 -1
- package/dist/cjs/components/QuillMultiSelect.d.ts.map +1 -1
- package/dist/cjs/components/QuillMultiSelect.js +18 -3
- package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
- package/dist/cjs/components/QuillMultiSelectWithCombo.js +2 -2
- package/dist/cjs/components/QuillSelect.js +1 -1
- package/dist/cjs/components/QuillSelectWithCombo.js +2 -2
- package/dist/cjs/components/QuillTable.d.ts +1 -4
- package/dist/cjs/components/QuillTable.d.ts.map +1 -1
- package/dist/cjs/components/QuillTable.js +5 -11
- package/dist/cjs/components/ReportBuilder/AddColumnModal.d.ts +3 -1
- package/dist/cjs/components/ReportBuilder/AddColumnModal.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddColumnModal.js +5 -8
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.js +1 -3
- package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddSortPopover.js +12 -1
- package/dist/cjs/components/ReportBuilder/FilterModal.d.ts +22 -0
- package/dist/cjs/components/ReportBuilder/FilterModal.d.ts.map +1 -0
- package/dist/cjs/components/ReportBuilder/FilterModal.js +555 -0
- package/dist/cjs/components/ReportBuilder/ast.d.ts +2 -1
- package/dist/cjs/components/ReportBuilder/ast.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ast.js +33 -6
- package/dist/cjs/components/ReportBuilder/constants.d.ts +18 -3
- package/dist/cjs/components/ReportBuilder/constants.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/constants.js +24 -3
- package/dist/cjs/components/ReportBuilder/convert.d.ts +12 -15
- package/dist/cjs/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/convert.js +326 -494
- package/dist/cjs/components/ReportBuilder/operators.d.ts +24 -4
- package/dist/cjs/components/ReportBuilder/operators.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/operators.js +32 -4
- package/dist/cjs/components/ReportBuilder/ui.d.ts +20 -0
- package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ui.js +30 -4
- package/dist/cjs/components/ReportBuilder/util.d.ts +3 -11
- package/dist/cjs/components/ReportBuilder/util.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/util.js +15 -18
- package/dist/cjs/components/UiComponents.d.ts +10 -7
- package/dist/cjs/components/UiComponents.d.ts.map +1 -1
- package/dist/cjs/components/UiComponents.js +9 -8
- package/dist/cjs/components/selectUtils.d.ts +0 -1
- package/dist/cjs/components/selectUtils.d.ts.map +1 -1
- package/dist/cjs/components/selectUtils.js +1 -22
- package/dist/cjs/hooks/index.d.ts +4 -4
- package/dist/cjs/hooks/useAstToFilterTree.d.ts +11 -0
- package/dist/cjs/hooks/useAstToFilterTree.d.ts.map +1 -0
- package/dist/cjs/hooks/useAstToFilterTree.js +26 -0
- package/dist/cjs/hooks/useDashboard.d.ts +1 -1
- package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
- package/dist/cjs/hooks/useDashboard.js +22 -4
- package/dist/cjs/hooks/useExport.d.ts.map +1 -1
- package/dist/cjs/hooks/useExport.js +3 -1
- package/dist/cjs/hooks/useOnClickOutside.js +4 -4
- package/dist/cjs/hooks/useOnWindowResize.d.ts.map +1 -1
- package/dist/cjs/hooks/useOnWindowResize.js +2 -2
- package/dist/cjs/hooks/useQuill.d.ts +10 -27
- package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
- package/dist/cjs/hooks/useQuill.js +114 -82
- package/dist/cjs/hooks/useSelectOnKeyDown.d.ts.map +1 -1
- package/dist/cjs/hooks/useSelectOnKeyDown.js +4 -4
- package/dist/cjs/hooks/useTheme.js +1 -1
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +3 -1
- package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotForm.js +8 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts +2 -2
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.js +2 -2
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +64 -78
- package/dist/cjs/lib/utils.js +2 -2
- package/dist/cjs/models/Filter.d.ts +104 -4
- package/dist/cjs/models/Filter.d.ts.map +1 -1
- package/dist/cjs/models/Filter.js +91 -0
- package/dist/cjs/models/Pagination.d.ts +10 -0
- package/dist/cjs/models/Pagination.d.ts.map +1 -0
- package/dist/cjs/models/Pagination.js +2 -0
- package/dist/cjs/models/Report.d.ts +116 -0
- package/dist/cjs/models/Report.d.ts.map +1 -0
- package/dist/cjs/models/Report.js +2 -0
- package/dist/cjs/utils/aggregate.js +1 -1
- package/dist/cjs/utils/astFilterProcessing.d.ts +36 -0
- package/dist/cjs/utils/astFilterProcessing.d.ts.map +1 -0
- package/dist/cjs/utils/astFilterProcessing.js +8056 -0
- package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/astProcessing.js +4 -3
- package/dist/cjs/utils/axisFormatter.js +0 -71
- package/dist/cjs/utils/color.js +9 -87
- package/dist/cjs/utils/columnProcessing.d.ts +1 -0
- package/dist/cjs/utils/columnProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/columnProcessing.js +8 -1
- package/dist/cjs/utils/csv.d.ts.map +1 -1
- package/dist/cjs/utils/dashboard.d.ts.map +1 -1
- package/dist/cjs/utils/dashboard.js +4 -4
- package/dist/cjs/utils/dataFetcher.d.ts +1 -1
- package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
- package/dist/cjs/utils/dataFetcher.js +72 -5
- package/dist/cjs/utils/dataProcessing.d.ts +8 -0
- package/dist/cjs/utils/dataProcessing.d.ts.map +1 -0
- package/dist/cjs/utils/dataProcessing.js +127 -0
- package/dist/cjs/utils/dates.d.ts +2 -1
- package/dist/cjs/utils/dates.d.ts.map +1 -1
- package/dist/cjs/utils/dates.js +12 -3
- package/dist/cjs/utils/error.d.ts +5 -0
- package/dist/cjs/utils/error.d.ts.map +1 -0
- package/dist/cjs/utils/error.js +12 -0
- package/dist/cjs/utils/filterConstants.d.ts +34 -0
- package/dist/cjs/utils/filterConstants.d.ts.map +1 -0
- package/dist/cjs/utils/filterConstants.js +36 -0
- package/dist/cjs/utils/filterProcessing.js +4 -4
- package/dist/cjs/utils/logging.d.ts.map +1 -1
- package/dist/cjs/utils/logging.js +1 -0
- package/dist/cjs/utils/merge.js +0 -21
- package/dist/cjs/utils/monacoConfig.d.ts +21 -0
- package/dist/cjs/utils/monacoConfig.d.ts.map +1 -0
- package/dist/cjs/utils/monacoConfig.js +324 -0
- package/dist/cjs/utils/paginationProcessing.d.ts +5 -0
- package/dist/cjs/utils/paginationProcessing.d.ts.map +1 -0
- package/dist/cjs/utils/paginationProcessing.js +30 -0
- package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/pivotConstructor.js +67 -5
- package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/pivotProcessing.js +12 -6
- package/dist/cjs/utils/queryConstructor.d.ts +4 -2
- package/dist/cjs/utils/queryConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/queryConstructor.js +121 -59
- package/dist/cjs/utils/report.d.ts +7 -0
- package/dist/cjs/utils/report.d.ts.map +1 -0
- package/dist/cjs/utils/report.js +93 -0
- package/dist/cjs/utils/schema.d.ts.map +1 -1
- package/dist/cjs/utils/schema.js +35 -6
- package/dist/cjs/utils/styles.d.ts +1 -1
- package/dist/cjs/utils/styles.d.ts.map +1 -1
- package/dist/cjs/utils/tableProcessing.d.ts +23 -8
- package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/tableProcessing.js +156 -38
- package/dist/cjs/utils/textProcessing.js +3 -3
- package/dist/cjs/utils/validation.d.ts +9 -0
- package/dist/cjs/utils/validation.d.ts.map +1 -0
- package/dist/cjs/utils/validation.js +24 -0
- package/dist/cjs/utils/valueFormatter.d.ts.map +1 -1
- package/dist/cjs/utils/valueFormatter.js +8 -4
- package/dist/esm/Chart.d.ts +24 -10
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +154 -192
- package/dist/esm/ChartBuilder.d.ts +51 -11
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +161 -101
- package/dist/esm/ChartEditor.d.ts +13 -1
- package/dist/esm/ChartEditor.d.ts.map +1 -1
- package/dist/esm/ChartEditor.js +63 -122
- package/dist/esm/Context.d.ts +1 -19
- package/dist/esm/Context.d.ts.map +1 -1
- package/dist/esm/Context.js +74 -84
- package/dist/esm/Dashboard.d.ts +16 -7
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/Dashboard.js +91 -69
- package/dist/esm/DateRangePicker/Calendar.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/Calendar.js +5 -8
- package/dist/esm/DateRangePicker/DateRangePicker.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/DateRangePicker.js +2 -3
- package/dist/esm/DateRangePicker/DateRangePickerButton.d.ts +1 -2
- package/dist/esm/DateRangePicker/DateRangePickerButton.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/DateRangePickerButton.js +2 -4
- package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts +2 -1
- package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/QuillDateRangePicker.js +4 -4
- package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +1 -1
- package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/dateRangePickerUtils.js +1 -15
- package/dist/esm/ReportBuilder.d.ts +22 -1
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +766 -513
- package/dist/esm/SQLEditor.d.ts +2 -9
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +144 -92
- package/dist/esm/Table.d.ts +19 -3
- package/dist/esm/Table.d.ts.map +1 -1
- package/dist/esm/Table.js +112 -94
- package/dist/esm/TableChart.d.ts.map +1 -1
- package/dist/esm/TableChart.js +0 -1
- package/dist/esm/assets/ArrowDownHeadIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowDownIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowDownRightIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowLeftHeadIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowRightHeadIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowRightIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowUpHeadIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowUpIcon.d.ts.map +1 -1
- package/dist/esm/assets/ArrowUpRightIcon.d.ts.map +1 -1
- package/dist/esm/assets/CalendarIcon.d.ts.map +1 -1
- package/dist/esm/assets/DoubleArrowLeftHeadIcon.d.ts.map +1 -1
- package/dist/esm/assets/DoubleArrowRightHeadIcon.d.ts.map +1 -1
- package/dist/esm/assets/ExclamationFilledIcon.d.ts.map +1 -1
- package/dist/esm/assets/LoadingSpinner.d.ts.map +1 -1
- package/dist/esm/assets/SearchIcon.d.ts.map +1 -1
- package/dist/esm/assets/XCircleIcon.d.ts.map +1 -1
- package/dist/esm/components/Banner/index.d.ts +1 -1
- package/dist/esm/components/Banner/index.d.ts.map +1 -1
- package/dist/esm/components/Banner/index.js +1 -1
- package/dist/esm/components/BigModal/BigModal.d.ts.map +1 -1
- package/dist/esm/components/BigModal/BigModal.js +7 -13
- package/dist/esm/components/Chart/BarList.d.ts.map +1 -1
- package/dist/esm/components/Chart/BarList.js +21 -14
- package/dist/esm/components/Chart/ChartError.d.ts +8 -1
- package/dist/esm/components/Chart/ChartError.d.ts.map +1 -1
- package/dist/esm/components/Chart/ChartError.js +39 -6
- package/dist/esm/components/Chart/ChartTooltip.d.ts.map +1 -1
- package/dist/esm/components/Chart/ChartTooltip.js +8 -2
- package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/LineChart.js +2 -2
- package/dist/esm/components/Chart/PieChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/PieChart.js +1 -3
- package/dist/esm/components/Dashboard/ChartComponent.d.ts +1 -1
- package/dist/esm/components/Dashboard/ChartComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/ChartComponent.js +1 -1
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts +5 -1
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DashboardFilter.js +10 -5
- package/dist/esm/components/Dashboard/DataLoader.d.ts +2 -6
- package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DataLoader.js +98 -187
- package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.js +1 -1
- package/dist/esm/components/Dashboard/TableComponent.d.ts +1 -4
- package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/TableComponent.js +3 -3
- package/dist/esm/components/Dropdown/Dropdown.d.ts.map +1 -1
- package/dist/esm/components/Dropdown/Dropdown.js +2 -4
- package/dist/esm/components/Dropdown/DropdownItem.d.ts.map +1 -1
- package/dist/esm/components/Dropdown/DropdownItem.js +4 -9
- package/dist/esm/components/Dropdown/index.d.ts +2 -2
- package/dist/esm/components/Dropdown/index.js +2 -2
- package/dist/esm/components/Modal/Modal.d.ts.map +1 -1
- package/dist/esm/components/Modal/Modal.js +2 -3
- package/dist/esm/components/Modal/index.d.ts +1 -1
- package/dist/esm/components/Modal/index.js +1 -1
- package/dist/esm/components/QuillMultiSelect.d.ts.map +1 -1
- package/dist/esm/components/QuillMultiSelect.js +18 -3
- package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
- package/dist/esm/components/QuillMultiSelectWithCombo.js +2 -2
- package/dist/esm/components/QuillSelect.js +1 -1
- package/dist/esm/components/QuillSelectWithCombo.js +2 -2
- package/dist/esm/components/QuillTable.d.ts +1 -4
- package/dist/esm/components/QuillTable.d.ts.map +1 -1
- package/dist/esm/components/QuillTable.js +5 -11
- package/dist/esm/components/ReportBuilder/AddColumnModal.d.ts +3 -1
- package/dist/esm/components/ReportBuilder/AddColumnModal.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddColumnModal.js +8 -11
- package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddLimitPopover.js +2 -4
- package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddSortPopover.js +12 -1
- package/dist/esm/components/ReportBuilder/FilterModal.d.ts +22 -0
- package/dist/esm/components/ReportBuilder/FilterModal.d.ts.map +1 -0
- package/dist/esm/components/ReportBuilder/FilterModal.js +552 -0
- package/dist/esm/components/ReportBuilder/ast.d.ts +2 -1
- package/dist/esm/components/ReportBuilder/ast.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ast.js +31 -5
- package/dist/esm/components/ReportBuilder/constants.d.ts +18 -3
- package/dist/esm/components/ReportBuilder/constants.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/constants.js +24 -3
- package/dist/esm/components/ReportBuilder/convert.d.ts +12 -15
- package/dist/esm/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/convert.js +324 -493
- package/dist/esm/components/ReportBuilder/convert.uspec.d.ts +2 -0
- package/dist/esm/components/ReportBuilder/convert.uspec.d.ts.map +1 -0
- package/dist/esm/components/ReportBuilder/convert.uspec.js +1152 -0
- package/dist/esm/components/ReportBuilder/operators.d.ts +24 -4
- package/dist/esm/components/ReportBuilder/operators.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/operators.js +32 -4
- package/dist/esm/components/ReportBuilder/ui.d.ts +20 -0
- package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ui.js +28 -3
- package/dist/esm/components/ReportBuilder/util.d.ts +3 -11
- package/dist/esm/components/ReportBuilder/util.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/util.js +16 -19
- package/dist/esm/components/UiComponents.d.ts +10 -7
- package/dist/esm/components/UiComponents.d.ts.map +1 -1
- package/dist/esm/components/UiComponents.js +9 -8
- package/dist/esm/components/selectUtils.d.ts +0 -1
- package/dist/esm/components/selectUtils.d.ts.map +1 -1
- package/dist/esm/components/selectUtils.js +0 -20
- package/dist/esm/hooks/index.d.ts +4 -4
- package/dist/esm/hooks/index.js +4 -4
- package/dist/esm/hooks/useAstToFilterTree.d.ts +11 -0
- package/dist/esm/hooks/useAstToFilterTree.d.ts.map +1 -0
- package/dist/esm/hooks/useAstToFilterTree.js +24 -0
- package/dist/esm/hooks/useDashboard.d.ts +1 -1
- package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
- package/dist/esm/hooks/useDashboard.js +23 -5
- package/dist/esm/hooks/useExport.d.ts.map +1 -1
- package/dist/esm/hooks/useExport.js +4 -2
- package/dist/esm/hooks/useOnClickOutside.js +5 -5
- package/dist/esm/hooks/useOnWindowResize.d.ts.map +1 -1
- package/dist/esm/hooks/useOnWindowResize.js +3 -3
- package/dist/esm/hooks/useQuill.d.ts +10 -27
- package/dist/esm/hooks/useQuill.d.ts.map +1 -1
- package/dist/esm/hooks/useQuill.js +114 -82
- package/dist/esm/hooks/useSelectOnKeyDown.d.ts.map +1 -1
- package/dist/esm/hooks/useSelectOnKeyDown.js +5 -5
- package/dist/esm/hooks/useTheme.js +1 -1
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotForm.js +9 -2
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts +2 -2
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotList.js +3 -3
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +68 -82
- package/dist/esm/lib/utils.js +2 -2
- package/dist/esm/models/Filter.d.ts +104 -4
- package/dist/esm/models/Filter.d.ts.map +1 -1
- package/dist/esm/models/Filter.js +90 -1
- package/dist/esm/models/Pagination.d.ts +10 -0
- package/dist/esm/models/Pagination.d.ts.map +1 -0
- package/dist/esm/models/Pagination.js +1 -0
- package/dist/esm/models/Report.d.ts +116 -0
- package/dist/esm/models/Report.d.ts.map +1 -0
- package/dist/esm/models/Report.js +1 -0
- package/dist/esm/utils/aggregate.js +1 -1
- package/dist/esm/utils/astFilterProcessing.d.ts +36 -0
- package/dist/esm/utils/astFilterProcessing.d.ts.map +1 -0
- package/dist/esm/utils/astFilterProcessing.js +8049 -0
- package/dist/esm/utils/astFilterProcessing.uspec.d.ts +2 -0
- package/dist/esm/utils/astFilterProcessing.uspec.d.ts.map +1 -0
- package/dist/esm/utils/astFilterProcessing.uspec.js +2729 -0
- package/dist/esm/utils/astProcessing.d.ts.map +1 -1
- package/dist/esm/utils/astProcessing.js +4 -3
- package/dist/esm/utils/axisFormatter.js +0 -71
- package/dist/esm/utils/color.js +9 -87
- package/dist/esm/utils/columnProcessing.d.ts +1 -0
- package/dist/esm/utils/columnProcessing.d.ts.map +1 -1
- package/dist/esm/utils/columnProcessing.js +6 -0
- package/dist/esm/utils/csv.d.ts.map +1 -1
- package/dist/esm/utils/dashboard.d.ts.map +1 -1
- package/dist/esm/utils/dashboard.js +4 -4
- package/dist/esm/utils/dataFetcher.d.ts +1 -1
- package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
- package/dist/esm/utils/dataFetcher.js +72 -5
- package/dist/esm/utils/dataProcessing.d.ts +8 -0
- package/dist/esm/utils/dataProcessing.d.ts.map +1 -0
- package/dist/esm/utils/dataProcessing.js +122 -0
- package/dist/esm/utils/dataProcessing.uspec.d.ts +2 -0
- package/dist/esm/utils/dataProcessing.uspec.d.ts.map +1 -0
- package/dist/esm/utils/dataProcessing.uspec.js +204 -0
- package/dist/esm/utils/dates.d.ts +2 -1
- package/dist/esm/utils/dates.d.ts.map +1 -1
- package/dist/esm/utils/dates.js +10 -2
- package/dist/esm/utils/error.d.ts +5 -0
- package/dist/esm/utils/error.d.ts.map +1 -0
- package/dist/esm/utils/error.js +8 -0
- package/dist/esm/utils/filterConstants.d.ts +34 -0
- package/dist/esm/utils/filterConstants.d.ts.map +1 -0
- package/dist/esm/utils/filterConstants.js +33 -0
- package/dist/esm/utils/filterProcessing.js +4 -4
- package/dist/esm/utils/logging.d.ts.map +1 -1
- package/dist/esm/utils/logging.js +1 -0
- package/dist/esm/utils/merge.js +0 -21
- package/dist/esm/utils/monacoConfig.d.ts +21 -0
- package/dist/esm/utils/monacoConfig.d.ts.map +1 -0
- package/dist/esm/utils/monacoConfig.js +319 -0
- package/dist/esm/utils/paginationProcessing.d.ts +5 -0
- package/dist/esm/utils/paginationProcessing.d.ts.map +1 -0
- package/dist/esm/utils/paginationProcessing.js +25 -0
- package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/esm/utils/pivotConstructor.js +67 -5
- package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/esm/utils/pivotProcessing.js +12 -6
- package/dist/esm/utils/queryConstructor.d.ts +4 -2
- package/dist/esm/utils/queryConstructor.d.ts.map +1 -1
- package/dist/esm/utils/queryConstructor.js +118 -58
- package/dist/esm/utils/queryConstructor.uspec.d.ts +2 -0
- package/dist/esm/utils/queryConstructor.uspec.d.ts.map +1 -0
- package/dist/esm/utils/queryConstructor.uspec.js +223 -0
- package/dist/esm/utils/report.d.ts +7 -0
- package/dist/esm/utils/report.d.ts.map +1 -0
- package/dist/esm/utils/report.ispec.d.ts +2 -0
- package/dist/esm/utils/report.ispec.d.ts.map +1 -0
- package/dist/esm/utils/report.ispec.js +46 -0
- package/dist/esm/utils/report.js +88 -0
- package/dist/esm/utils/schema.d.ts.map +1 -1
- package/dist/esm/utils/schema.js +35 -6
- package/dist/esm/utils/styles.d.ts +1 -1
- package/dist/esm/utils/styles.d.ts.map +1 -1
- package/dist/esm/utils/tableProcessing.d.ts +23 -8
- package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
- package/dist/esm/utils/tableProcessing.ispec.d.ts +2 -0
- package/dist/esm/utils/tableProcessing.ispec.d.ts.map +1 -0
- package/dist/esm/utils/tableProcessing.ispec.js +61 -0
- package/dist/esm/utils/tableProcessing.js +152 -37
- package/dist/esm/utils/textProcessing.js +3 -3
- package/dist/esm/utils/validation.d.ts +9 -0
- package/dist/esm/utils/validation.d.ts.map +1 -0
- package/dist/esm/utils/validation.js +20 -0
- package/dist/esm/utils/valueFormatter.d.ts.map +1 -1
- package/dist/esm/utils/valueFormatter.js +8 -4
- package/package.json +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.spec.d.ts +0 -2
- package/dist/cjs/internals/ReportBuilder/PivotModal.spec.d.ts.map +0 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.spec.js +0 -213
- package/dist/esm/internals/ReportBuilder/PivotModal.spec.d.ts +0 -2
- package/dist/esm/internals/ReportBuilder/PivotModal.spec.d.ts.map +0 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.spec.js +0 -211
package/dist/esm/ChartBuilder.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
/* eslint-disable no-unused-vars */
|
|
3
2
|
import { useEffect, useRef, useState, useContext, useMemo, } from 'react';
|
|
4
|
-
import { ClientContext, DashboardContext, DashboardFiltersContext, SchemaContext, ThemeContext, } from './Context';
|
|
3
|
+
import { ClientContext, DashboardContext, DashboardDataContext, DashboardFiltersContext, SchemaContext, ThemeContext, } from './Context';
|
|
5
4
|
import { getData, getDataFromCloud } from './utils/dataFetcher';
|
|
6
5
|
import { PivotModal, generatePivotTable, isDateField, } from './internals/ReportBuilder/PivotModal';
|
|
7
6
|
import { PivotCard } from './internals/ReportBuilder/PivotList';
|
|
@@ -16,6 +15,8 @@ import { convertColumnInfoToColumnInternal, convertFieldTypeToJSType, } from './
|
|
|
16
15
|
import { createTableNameToTableAliasMap, getColumnsByTableFromASTAndSchema, getSelectFromAST, } from './utils/astProcessing';
|
|
17
16
|
import { getSchemaInfoWithCustomFields } from './utils/schema';
|
|
18
17
|
import { getDateBucketFromRange } from './utils/dates';
|
|
18
|
+
import { validateReport } from './utils/validation';
|
|
19
|
+
import { QuillChartErrorWithAction } from './components/Chart/ChartError';
|
|
19
20
|
const CHART_TYPES = ['column', 'line', 'table', 'metric', 'bar', 'pie'];
|
|
20
21
|
const POSTGRES_DATE_TYPES = [
|
|
21
22
|
'timestamp',
|
|
@@ -50,18 +51,50 @@ function getPivotMetricOptions(pivot) {
|
|
|
50
51
|
];
|
|
51
52
|
}
|
|
52
53
|
}
|
|
53
|
-
function
|
|
54
|
+
export function createInitialFormData(columns) {
|
|
55
|
+
const firstNumberColumn = columns?.find((col) => numberFormatOptions.includes(col.format));
|
|
56
|
+
const formEmptyState = {
|
|
57
|
+
name: 'My Chart',
|
|
58
|
+
columns: columns.map((col) => {
|
|
59
|
+
return { ...col, label: snakeAndCamelCaseToTitleCase(col.label) };
|
|
60
|
+
}),
|
|
61
|
+
xAxisField: columns?.[0]?.field || '',
|
|
62
|
+
xAxisFormat: columns?.[0]?.format || '',
|
|
63
|
+
yAxisFields: [
|
|
64
|
+
{
|
|
65
|
+
field: firstNumberColumn?.field || columns?.[0]?.field || '',
|
|
66
|
+
label: '',
|
|
67
|
+
format: firstNumberColumn?.format || columns?.[0]?.field || '',
|
|
68
|
+
},
|
|
69
|
+
],
|
|
70
|
+
xAxisLabel: '',
|
|
71
|
+
chartType: firstNumberColumn ? 'line' : 'table',
|
|
72
|
+
pivot: null,
|
|
73
|
+
dateField: { table: '', field: '' },
|
|
74
|
+
template: false,
|
|
75
|
+
};
|
|
76
|
+
return formEmptyState;
|
|
77
|
+
}
|
|
78
|
+
function getChartTypeOptions(formData, dashboard) {
|
|
79
|
+
let viableCharts = CHART_TYPES;
|
|
80
|
+
if (dashboard.dateFilter && dashboard.dateFilter.comparison) {
|
|
81
|
+
viableCharts = viableCharts.filter((chart) => !['table', 'metric', 'bar', 'pie'].includes(chart));
|
|
82
|
+
}
|
|
54
83
|
if (formData.pivot && !formData.pivot.rowField) {
|
|
55
|
-
return
|
|
84
|
+
return viableCharts
|
|
85
|
+
.filter((elem) => elem === 'metric' || elem === 'table')
|
|
86
|
+
.map((elem) => ({
|
|
56
87
|
label: elem,
|
|
57
88
|
value: elem,
|
|
58
89
|
}));
|
|
59
90
|
}
|
|
60
91
|
else {
|
|
61
|
-
return
|
|
92
|
+
return viableCharts
|
|
93
|
+
.filter((elem) => !((formData.pivot && elem === 'metric') ||
|
|
62
94
|
(formData.pivot &&
|
|
63
95
|
formData.pivot.columnField &&
|
|
64
|
-
(elem === 'bar' || elem === 'pie'))))
|
|
96
|
+
(elem === 'bar' || elem === 'pie'))))
|
|
97
|
+
.map((elem) => ({ label: elem, value: elem }));
|
|
65
98
|
}
|
|
66
99
|
}
|
|
67
100
|
function getTablesHelper(ast, allTables) {
|
|
@@ -77,8 +110,9 @@ function getTablesHelper(ast, allTables) {
|
|
|
77
110
|
// With statement column references
|
|
78
111
|
if (ast.with) {
|
|
79
112
|
for (const withStmt of ast.with) {
|
|
80
|
-
|
|
81
|
-
|
|
113
|
+
const astFrom = withStmt.stmt.from ?? withStmt.stmt.ast.from;
|
|
114
|
+
if (astFrom) {
|
|
115
|
+
const withReferencedColumns = getColumnsByTableFromASTAndSchema(withStmt.stmt.ast ?? withStmt.stmt, allTables, tableAliasMap);
|
|
82
116
|
// @ts-ignore
|
|
83
117
|
Object.keys(withReferencedColumns).forEach((tableName) => {
|
|
84
118
|
if (referencedColumns[tableName]) {
|
|
@@ -105,7 +139,7 @@ function getTablesHelper(ast, allTables) {
|
|
|
105
139
|
}) || [],
|
|
106
140
|
};
|
|
107
141
|
});
|
|
108
|
-
|
|
142
|
+
const dateFields = allTables
|
|
109
143
|
.filter((table) => onlyReferenceTables.includes(table.displayName))
|
|
110
144
|
.map((table) => {
|
|
111
145
|
return {
|
|
@@ -120,7 +154,10 @@ function getTablesHelper(ast, allTables) {
|
|
|
120
154
|
return { referencedTablesAndColumns, dateFields };
|
|
121
155
|
}
|
|
122
156
|
async function getReferencedTables(client, sqlQuery, dbTables) {
|
|
123
|
-
const resp = await getDataFromCloud(client, `astify`, {
|
|
157
|
+
const resp = await getDataFromCloud(client, `astify`, {
|
|
158
|
+
query: sqlQuery,
|
|
159
|
+
useNewNodeSql: true,
|
|
160
|
+
});
|
|
124
161
|
if (resp.success === false) {
|
|
125
162
|
return getTablesHelper(getSelectFromAST({}), dbTables);
|
|
126
163
|
}
|
|
@@ -236,7 +273,7 @@ export function ChartBuilderWithModal(props) {
|
|
|
236
273
|
* ### Chart Builder API
|
|
237
274
|
* @see https://docs.quillsql.com/components/chart-builder
|
|
238
275
|
*/
|
|
239
|
-
export default function ChartBuilder({ TextInputComponent = QuillTextInput, SelectComponent = QuillSelectComponent, ButtonComponent = MemoizedButton, SecondaryButtonComponent = MemoizedSecondaryButton, HeaderComponent = MemoizedHeader, SubHeaderComponent = MemoizedSubHeader, LabelComponent = MemoizedLabel, DeleteButtonComponent = MemoizedDeleteButton, TextComponent = MemoizedText, PopoverComponent = MemoizedPopover, CardComponent = QuillCard, TableComponent = QuillTableComponent, ModalComponent, LoadingComponent = QuillLoadingComponent, ErrorMessageComponent = QuillErrorMessageComponent, ChartBuilderInputRowContainer = QuillChartBuilderInputRowContainer, ChartBuilderInputColumnContainer = QuillChartBuilderInputColumnContainer, PivotRowContainer = QuillPivotRowContainer, PivotColumnContainer = QuillPivotColumnContainer, FormContainer = QuillChartBuilderFormContainer, isOpen, isHorizontalView = true, pivot, setIsOpen, rows, columns, query, queryNoDateColumn, dateRange: dr, showTableFormatOptions = false, showDateFieldOptions = false, showAccessControlOptions = false, showDashboardDropdown = true, onAddToDashboardComplete, onDelete, report = undefined, recommendedPivots: rp = [], createdPivots: cp = [], destinationDashboard, dateColumn, buttonLabel, organizationName, pivotData, hideDeleteButton = false, hideSubmitButton = false, hideDateRangeFilter = false, initialUniqueValues, pivotRecommendationsEnabled = true, onSortChange, onPageChange, rowCount, isLoading, isComparison, onClickChartElement, }) {
|
|
276
|
+
export default function ChartBuilder({ TextInputComponent = QuillTextInput, SelectComponent = QuillSelectComponent, ButtonComponent = MemoizedButton, SecondaryButtonComponent = MemoizedSecondaryButton, HeaderComponent = MemoizedHeader, SubHeaderComponent = MemoizedSubHeader, LabelComponent = MemoizedLabel, DeleteButtonComponent = MemoizedDeleteButton, TextComponent = MemoizedText, PopoverComponent = MemoizedPopover, CardComponent = QuillCard, TableComponent = QuillTableComponent, ModalComponent = MemoizedModal, LoadingComponent = QuillLoadingComponent, ErrorMessageComponent = QuillErrorMessageComponent, ChartBuilderInputRowContainer = QuillChartBuilderInputRowContainer, ChartBuilderInputColumnContainer = QuillChartBuilderInputColumnContainer, PivotRowContainer = QuillPivotRowContainer, PivotColumnContainer = QuillPivotColumnContainer, FormContainer = QuillChartBuilderFormContainer, ErrorComponent = QuillChartErrorWithAction, onClickChartError, isOpen, isHorizontalView = true, pivot, setIsOpen, rows, columns, query, queryNoDateColumn, dateRange: dr, showTableFormatOptions = false, showDateFieldOptions = false, showAccessControlOptions = false, showDashboardDropdown = true, onAddToDashboardComplete, onDelete, report = undefined, recommendedPivots: rp = [], createdPivots: cp = [], destinationDashboard, dateColumn, buttonLabel, organizationName, pivotData, hideDeleteButton = false, hideSubmitButton = false, hideDateRangeFilter = false, initialUniqueValues, pivotRecommendationsEnabled = true, onSortChange, onPageChange, rowCount, isLoading, isComparison, onClickChartElement, }) {
|
|
240
277
|
const dateRange = dr;
|
|
241
278
|
const [client] = useContext(ClientContext);
|
|
242
279
|
const [theme] = useContext(ThemeContext);
|
|
@@ -244,6 +281,9 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
244
281
|
const [windowWidth, setWindowWidth] = useState(1200);
|
|
245
282
|
const [isSubmitting, setIsSubmitting] = useState(false);
|
|
246
283
|
const [pivotCardWidth, setPivotCardWidth] = useState(665);
|
|
284
|
+
const [chartTypes, setChartTypes] = useState(CHART_TYPES.map((type) => {
|
|
285
|
+
return { label: type, value: type };
|
|
286
|
+
}));
|
|
247
287
|
const [formWidth, setFormWidth] = useState(665);
|
|
248
288
|
const inputRef = useRef(null);
|
|
249
289
|
const selectRef = useRef(null);
|
|
@@ -253,6 +293,15 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
253
293
|
const deleteRef = useRef(null);
|
|
254
294
|
const modalPadding = 20;
|
|
255
295
|
const deleteButtonMargin = -12;
|
|
296
|
+
const validationHelper = (formData, dashboard, dateField, tables) => {
|
|
297
|
+
const issues = validateReport(formData, dashboard, dateField || defaultDateField, tables || allTables);
|
|
298
|
+
if (issues.length > 0) {
|
|
299
|
+
setFilterIssues(issues);
|
|
300
|
+
}
|
|
301
|
+
else {
|
|
302
|
+
setFilterIssues([]);
|
|
303
|
+
}
|
|
304
|
+
};
|
|
256
305
|
useEffect(() => {
|
|
257
306
|
if (schema) {
|
|
258
307
|
const newProcessedColumns = columns.map((col) => {
|
|
@@ -337,18 +386,14 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
337
386
|
const [dashboardOptions, setDashboardOptions] = useState([]);
|
|
338
387
|
const [defaultDashboardName, setDefaultDashboardName] = useState(destinationDashboard || report?.dashboardName || '');
|
|
339
388
|
const { dashboardFilters } = useContext(DashboardFiltersContext);
|
|
340
|
-
const
|
|
389
|
+
const { dashboardData } = useContext(DashboardDataContext);
|
|
341
390
|
const specificDashboardFilter = useMemo(() => {
|
|
342
391
|
return dashboardFilters.filter((f) => f && defaultDashboardName === f.dashboardName);
|
|
343
392
|
}, [dashboardFilters]);
|
|
344
|
-
const [dashboardFilters2, setDashboardFilters] = useState([]);
|
|
345
|
-
const [dashboardHasDateFilter, setDashboardHasDateFilter] = useState(false);
|
|
346
|
-
const [dashboardHasDateComparison, setDashboardHasDateComparison] = useState(false);
|
|
347
393
|
const [showFilterModal, setShowFilterModal] = useState(false);
|
|
348
394
|
const [filterIssues, setFilterIssues] = useState([]);
|
|
349
395
|
const [showPivotPopover, setShowPivotPopover] = useState(false);
|
|
350
396
|
const [isEdittingPivot, setIsEdittingPivot] = useState(false);
|
|
351
|
-
const [intialLoad, setInitialLoad] = useState(true);
|
|
352
397
|
const [selectedPivotIndex, setSelectedPivotIndex] = useState(-1);
|
|
353
398
|
const [tableName, setTableName] = useState(undefined);
|
|
354
399
|
const selectedTable = schema?.find((t) => t.displayName === tableName);
|
|
@@ -393,6 +438,9 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
393
438
|
template: false,
|
|
394
439
|
};
|
|
395
440
|
const updateDashboardFilters = async (dashboardName) => {
|
|
441
|
+
if (dashboardData && dashboardData[dashboardName]) {
|
|
442
|
+
return dashboardData[dashboardName];
|
|
443
|
+
}
|
|
396
444
|
const { queryEndpoint, queryHeaders, publicKey, customerId } = client;
|
|
397
445
|
if (queryEndpoint) {
|
|
398
446
|
const response = await fetch(queryEndpoint, {
|
|
@@ -408,15 +456,14 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
408
456
|
name: dashboardName,
|
|
409
457
|
clientId: publicKey,
|
|
410
458
|
databaseType: client.databaseType,
|
|
459
|
+
useNewNodeSql: true,
|
|
411
460
|
},
|
|
412
461
|
}),
|
|
413
462
|
credentials: 'omit', // If withCredentials is true, set to 'include'. Otherwise, set to 'omit'.
|
|
414
463
|
});
|
|
415
464
|
const responseData = (await response.json()).data;
|
|
416
465
|
if (responseData) {
|
|
417
|
-
|
|
418
|
-
setDashboardHasDateFilter(!!responseData.dateFilter);
|
|
419
|
-
setDashboardHasDateComparison(responseData.dateFilter?.comparison || false);
|
|
466
|
+
return responseData;
|
|
420
467
|
}
|
|
421
468
|
}
|
|
422
469
|
};
|
|
@@ -470,8 +517,14 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
470
517
|
async function getFormData() {
|
|
471
518
|
setLoadingFormData(true);
|
|
472
519
|
const curFormData = formData;
|
|
473
|
-
|
|
474
|
-
|
|
520
|
+
let dashNames = Object.keys(dashboardData).map((dashboard) => {
|
|
521
|
+
return dashboard;
|
|
522
|
+
}) ?? [];
|
|
523
|
+
if (dashNames.length === 0) {
|
|
524
|
+
const resp = await getDataFromCloud(client, `dashnames/${client.publicKey}/`, null, 'GET');
|
|
525
|
+
dashNames = resp.dashboardNames;
|
|
526
|
+
}
|
|
527
|
+
let dashboardOptions = dashNames
|
|
475
528
|
.filter((elem) => elem !== null)
|
|
476
529
|
.map((key) => ({ label: key, value: key }));
|
|
477
530
|
if (!dashboardOptions.length) {
|
|
@@ -484,11 +537,14 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
484
537
|
{ label: destinationDashboard, value: destinationDashboard },
|
|
485
538
|
];
|
|
486
539
|
}
|
|
487
|
-
|
|
488
|
-
|
|
540
|
+
let dashboardName = report?.dashboardName
|
|
541
|
+
? report.dashboardName
|
|
542
|
+
: dashboardOptions[0]?.label;
|
|
543
|
+
if (destinationDashboard) {
|
|
544
|
+
dashboardName = destinationDashboard;
|
|
545
|
+
}
|
|
546
|
+
const curDashboard = await updateDashboardFilters(dashboardName);
|
|
489
547
|
setDashboardOptions(dashboardOptions);
|
|
490
|
-
const dashboardName = destinationDashboard ??
|
|
491
|
-
(report ? report?.dashboardName : dashboardOptions[0]?.label);
|
|
492
548
|
curFormData.dashboardName = dashboardName;
|
|
493
549
|
setDefaultDashboardName(destinationDashboard ??
|
|
494
550
|
(report ? report?.dashboardName : dashboardOptions[0]?.label));
|
|
@@ -514,7 +570,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
514
570
|
const tableNames = result.referencedTablesAndColumns.map((table) => table.name);
|
|
515
571
|
setAllTables(tableNames);
|
|
516
572
|
let customFieldUsage = false;
|
|
517
|
-
for (
|
|
573
|
+
for (const table of tableNames) {
|
|
518
574
|
const tableInfo = curSchemaData.find((elem) => elem.name === table);
|
|
519
575
|
if (tableInfo?.customFieldInfo) {
|
|
520
576
|
customFieldUsage = true;
|
|
@@ -534,18 +590,22 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
534
590
|
result.dateFields[0]?.columns[0]?.field ||
|
|
535
591
|
'',
|
|
536
592
|
};
|
|
537
|
-
curFormData.dateField = dateField;
|
|
538
593
|
let isTemplate = curFormData.template;
|
|
539
594
|
if (customFieldUsage) {
|
|
540
595
|
isTemplate = false;
|
|
541
596
|
}
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
dashboardName: report
|
|
597
|
+
curFormData.dashboardName =
|
|
598
|
+
report && report.dashboardName
|
|
545
599
|
? report?.dashboardName
|
|
546
|
-
: dashboardOptions[0]?.label
|
|
547
|
-
|
|
548
|
-
|
|
600
|
+
: dashboardOptions[0]?.label;
|
|
601
|
+
curFormData.template = isTemplate;
|
|
602
|
+
if (!curFormData.dateField.field || !curFormData.dateField.table) {
|
|
603
|
+
if (dateField.field) {
|
|
604
|
+
curFormData.dateField = dateField;
|
|
605
|
+
}
|
|
606
|
+
}
|
|
607
|
+
setFormData(curFormData);
|
|
608
|
+
validationHelper(curFormData, curDashboard, curFormData.dateField ?? dateField, tableNames);
|
|
549
609
|
setLoadingFormData(false);
|
|
550
610
|
}
|
|
551
611
|
getFormData();
|
|
@@ -553,7 +613,6 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
553
613
|
const [selectedPivotTable, setSelectedPivotTable] = useState(pivotData || undefined);
|
|
554
614
|
const fetchPivotData = async (pivot, uniqueValues, overrideDateRange) => {
|
|
555
615
|
if (pivot && rows) {
|
|
556
|
-
setInitialLoad(false);
|
|
557
616
|
const dateFilter = report
|
|
558
617
|
? report.filtersApplied.find((filter) => {
|
|
559
618
|
return filter.filterType === 'date_range';
|
|
@@ -610,7 +669,8 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
610
669
|
});
|
|
611
670
|
}
|
|
612
671
|
}, [selectedPivotTable, formData.columns, formData.chartType, rows]);
|
|
613
|
-
const handleChange = (value, fieldName, index) => {
|
|
672
|
+
const handleChange = async (value, fieldName, index) => {
|
|
673
|
+
let updatedForm = { ...formData };
|
|
614
674
|
try {
|
|
615
675
|
// WE NEED TO REPROCESS THE PIVOT TABLE IF THE PIVOT COLUMN CHANGES
|
|
616
676
|
// WE NEED TO UPDATE BOTH VALUEFIELDTYPE AND COLUMN FIELD TYPES
|
|
@@ -624,14 +684,14 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
624
684
|
valueFieldType: value,
|
|
625
685
|
};
|
|
626
686
|
// @ts-ignore
|
|
627
|
-
|
|
628
|
-
return;
|
|
687
|
+
updatedForm.pivot = updatedPivot;
|
|
629
688
|
}
|
|
630
|
-
if (index !== undefined) {
|
|
689
|
+
else if (index !== undefined) {
|
|
631
690
|
// For dynamic array fields
|
|
632
691
|
const [field, subfield] = fieldName.split('.');
|
|
633
692
|
// @ts-ignore
|
|
634
693
|
const updatedArray = formData[field].map((item, i) => i === index ? { ...item, [subfield]: value } : item);
|
|
694
|
+
updatedForm = { ...formData, [field]: updatedArray };
|
|
635
695
|
setFormData({ ...formData, [field]: updatedArray });
|
|
636
696
|
}
|
|
637
697
|
else if (fieldName.includes('.')) {
|
|
@@ -641,19 +701,18 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
641
701
|
const subfieldTypeFieldName = subfield + 'Type';
|
|
642
702
|
if (value.length) {
|
|
643
703
|
const subFieldType = columns.find((columns) => columns.field === value).fieldType;
|
|
644
|
-
|
|
645
|
-
...
|
|
704
|
+
updatedForm = {
|
|
705
|
+
...updatedForm,
|
|
646
706
|
// @ts-ignore
|
|
647
707
|
[field]: {
|
|
648
|
-
...
|
|
708
|
+
...updatedForm[field],
|
|
649
709
|
[subfield]: value,
|
|
650
710
|
[subfieldTypeFieldName]: subFieldType,
|
|
651
711
|
},
|
|
652
|
-
}
|
|
653
|
-
return;
|
|
712
|
+
};
|
|
654
713
|
}
|
|
655
714
|
else {
|
|
656
|
-
|
|
715
|
+
updatedForm = {
|
|
657
716
|
...formData,
|
|
658
717
|
// @ts-ignore
|
|
659
718
|
[field]: {
|
|
@@ -661,38 +720,44 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
661
720
|
[subfield]: '',
|
|
662
721
|
[subfieldTypeFieldName]: '',
|
|
663
722
|
},
|
|
664
|
-
}
|
|
665
|
-
return;
|
|
723
|
+
};
|
|
666
724
|
}
|
|
667
725
|
}
|
|
668
|
-
if (field === 'dateField' &&
|
|
726
|
+
else if (field === 'dateField' &&
|
|
669
727
|
subfield === 'table' &&
|
|
670
728
|
!formData.dateField.field) {
|
|
671
729
|
const field = schema?.find((elem) => elem.name === value)
|
|
672
730
|
?.columns?.[0]?.name;
|
|
673
|
-
|
|
674
|
-
...formData,
|
|
731
|
+
updatedForm.dateField = {
|
|
675
732
|
// @ts-ignore
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
733
|
+
...updatedForm[field],
|
|
734
|
+
[subfield]: value,
|
|
735
|
+
field: field,
|
|
736
|
+
};
|
|
679
737
|
}
|
|
680
|
-
|
|
681
|
-
...
|
|
738
|
+
updatedForm = {
|
|
739
|
+
...updatedForm,
|
|
682
740
|
// @ts-ignore
|
|
683
|
-
[field]: { ...
|
|
684
|
-
}
|
|
741
|
+
[field]: { ...updatedForm[field], [subfield]: value },
|
|
742
|
+
};
|
|
685
743
|
}
|
|
686
744
|
else {
|
|
687
745
|
// For simple fields
|
|
688
|
-
|
|
746
|
+
updatedForm = { ...updatedForm, [fieldName]: value };
|
|
747
|
+
}
|
|
748
|
+
let dashboardName = updatedForm.dashboardName;
|
|
749
|
+
if (fieldName === 'dashboardName') {
|
|
750
|
+
dashboardName = value;
|
|
689
751
|
}
|
|
752
|
+
validationHelper(updatedForm, dashboardData[dashboardName || '']);
|
|
753
|
+
setChartTypes(getChartTypeOptions(updatedForm, dashboardData[dashboardName || '']));
|
|
690
754
|
}
|
|
691
755
|
catch (e) {
|
|
692
|
-
|
|
756
|
+
updatedForm = { ...updatedForm, [fieldName]: value };
|
|
693
757
|
}
|
|
758
|
+
setFormData(updatedForm);
|
|
694
759
|
};
|
|
695
|
-
const handleAddPivot = (pivot, uniqueValues, dateRange) => {
|
|
760
|
+
const handleAddPivot = async (pivot, uniqueValues, dateRange, pivotData) => {
|
|
696
761
|
const newPivotFormData = pivotFormData(pivot);
|
|
697
762
|
// Only keep the old chart type if the shapes of the pivots are the same
|
|
698
763
|
// since the valid chart types for some pivots might have changed (eg. going
|
|
@@ -702,12 +767,20 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
702
767
|
Boolean(formData.pivot?.columnField) === Boolean(pivot.columnField);
|
|
703
768
|
const isNewChartType = formData.chartType !== newPivotFormData.chartType;
|
|
704
769
|
const keepOldChartType = isNewChartType && isPivotSameShape;
|
|
770
|
+
if (pivotData) {
|
|
771
|
+
setSelectedPivotTable({
|
|
772
|
+
rows: pivotData.rows,
|
|
773
|
+
columns: pivotData.columns,
|
|
774
|
+
});
|
|
775
|
+
}
|
|
776
|
+
else {
|
|
777
|
+
await fetchPivotData(pivot, uniqueValues, dateRange);
|
|
778
|
+
}
|
|
705
779
|
setFormData((formData) => ({
|
|
706
780
|
...formData,
|
|
707
781
|
...newPivotFormData,
|
|
708
782
|
...(keepOldChartType && { chartType: formData.chartType }),
|
|
709
783
|
}));
|
|
710
|
-
fetchPivotData(pivot, uniqueValues, dateRange);
|
|
711
784
|
};
|
|
712
785
|
const handleDeletePivot = () => {
|
|
713
786
|
if (!formData.pivot) {
|
|
@@ -791,30 +864,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
791
864
|
setIsOpen(false);
|
|
792
865
|
setIsSubmitting(false);
|
|
793
866
|
};
|
|
794
|
-
const editChart = async (
|
|
795
|
-
if (!override) {
|
|
796
|
-
let dashboardDiscrepancyIssues = [];
|
|
797
|
-
if (dashboardHasDateComparison && formData.chartType === 'pie') {
|
|
798
|
-
dashboardDiscrepancyIssues.push(`The ${formData.dashboardName} dashboard is used for comparing date fields, you cannot add a pie chart to this dashboard.`);
|
|
799
|
-
}
|
|
800
|
-
if (dashboardHasDateFilter &&
|
|
801
|
-
((!defaultDateField.table && !defaultDateField.field) ||
|
|
802
|
-
(!formData.dateField.field && !formData.dateField.table))) {
|
|
803
|
-
dashboardDiscrepancyIssues.push(`The dashboard "${formData.dashboardName}" has a global date filter but this chart doesn't reference any tables with a date field.`);
|
|
804
|
-
}
|
|
805
|
-
dashboardFilters2.forEach((filter) => {
|
|
806
|
-
const table = allTables.find((elem) => elem === filter.table);
|
|
807
|
-
if (!table) {
|
|
808
|
-
dashboardDiscrepancyIssues.push(`The dashboard "${formData.dashboardName}" a global filter on "${filter.table}" "${filter.field}" but this chart doesn't reference "${filter.table}".`);
|
|
809
|
-
}
|
|
810
|
-
});
|
|
811
|
-
if (dashboardDiscrepancyIssues.length) {
|
|
812
|
-
setFilterIssues(dashboardDiscrepancyIssues);
|
|
813
|
-
setShowFilterModal(true);
|
|
814
|
-
setTriggeredEditChart(false);
|
|
815
|
-
return;
|
|
816
|
-
}
|
|
817
|
-
}
|
|
867
|
+
const editChart = async () => {
|
|
818
868
|
if (isSubmitting) {
|
|
819
869
|
setTriggeredEditChart(false);
|
|
820
870
|
return;
|
|
@@ -848,6 +898,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
848
898
|
? false
|
|
849
899
|
: formData.template,
|
|
850
900
|
customerId: customerId || '*',
|
|
901
|
+
useNewNodeSql: true,
|
|
851
902
|
};
|
|
852
903
|
// @ts-ignore
|
|
853
904
|
if (cloudBody['rows']) {
|
|
@@ -865,6 +916,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
865
916
|
databaseType: databaseType,
|
|
866
917
|
...cloudBody,
|
|
867
918
|
orgId: customerId || '*',
|
|
919
|
+
useNewNodeSql: true,
|
|
868
920
|
},
|
|
869
921
|
};
|
|
870
922
|
const searchParams = new URLSearchParams(customerId
|
|
@@ -934,12 +986,13 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
934
986
|
maxWidth: !isOpen ? '100%' : `calc(100% - ${formWidth}px - 20px)`, // width of left sidebar plus gap
|
|
935
987
|
}),
|
|
936
988
|
...(!isHorizontalView && isOpen && { width: formWidth }),
|
|
937
|
-
}, children: [((!isHorizontalView && windowWidth >= 1200) ||
|
|
989
|
+
}, children: [report.adminError || report.error ? (_jsx(ErrorComponent, { label: report.adminError || report.error, onClick: report.adminError && onClickChartError })) : (((!isHorizontalView && windowWidth >= 1200) ||
|
|
938
990
|
formData.chartType !== 'table') && (_jsx(Chart, { colors: theme.chartColors, config: {
|
|
939
991
|
...formData,
|
|
940
|
-
rows:
|
|
992
|
+
rows: rows,
|
|
941
993
|
pivotRows: selectedPivotTable?.rows || undefined,
|
|
942
994
|
pivotColumns: selectedPivotTable?.columns || undefined,
|
|
995
|
+
rowCount,
|
|
943
996
|
}, hideDateRangeFilter: hideDateRangeFilter, containerStyle: {
|
|
944
997
|
width: '100%',
|
|
945
998
|
height: formData.chartType === 'metric'
|
|
@@ -950,7 +1003,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
950
1003
|
: 'calc(100% - 10px)'
|
|
951
1004
|
: 400,
|
|
952
1005
|
...(isHorizontalView && { flexGrow: 1 }),
|
|
953
|
-
}, onClickChartElement: onClickChartElement })),
|
|
1006
|
+
}, onClickChartElement: onClickChartElement }))),
|
|
954
1007
|
// Make sure to display non-pivoted table when using pivot chart
|
|
955
1008
|
showTableFormatOptions &&
|
|
956
1009
|
(isHorizontalView || (!isOpen && windowWidth < 1200)) && (_jsx("div", { style: {
|
|
@@ -991,7 +1044,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
991
1044
|
})), width: 200 }) })), _jsx("div", { ref: selectRef, style: { display: 'flex', flexDirection: 'column' }, children: _jsx(SelectComponent, { label: "Chart type", value: formData.chartType, onChange: (e) => handleChange(e.target.value, 'chartType'),
|
|
992
1045
|
// filter out metric for all pivots
|
|
993
1046
|
// filter out bar and pie for row and column pivot
|
|
994
|
-
options:
|
|
1047
|
+
options: chartTypes, width: 200 }) })] }), _jsxs("div", { style: {
|
|
995
1048
|
display: 'flex',
|
|
996
1049
|
flexDirection: 'column',
|
|
997
1050
|
gap: 6,
|
|
@@ -1121,18 +1174,25 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
1121
1174
|
justifyContent: 'flex-end',
|
|
1122
1175
|
marginTop: 'auto',
|
|
1123
1176
|
gap: 10,
|
|
1124
|
-
}, children: [!hideDeleteButton && !isHorizontalView && report && (_jsx(SecondaryButtonComponent, { onClick: deleteChart, label: 'Delete' })), !hideSubmitButton && (
|
|
1125
|
-
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
|
|
1130
|
-
|
|
1131
|
-
},
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1177
|
+
}, children: [!hideDeleteButton && !isHorizontalView && report && (_jsx(SecondaryButtonComponent, { onClick: deleteChart, label: 'Delete' })), !hideSubmitButton && (_jsxs("div", { style: {
|
|
1178
|
+
display: 'flex',
|
|
1179
|
+
flexDirection: 'row',
|
|
1180
|
+
width: '100%',
|
|
1181
|
+
justifyContent: 'space-between',
|
|
1182
|
+
alignItems: 'center',
|
|
1183
|
+
gap: 6,
|
|
1184
|
+
}, children: [filterIssues.length === 0 ? (_jsx("div", {})) : (_jsx(ErrorMessageComponent, { errorMessage: filterIssues[0] || 'Dashbord - Report issues', containerStyle: { height: '100%' } })), _jsx(ButtonComponent, { onClick: () => {
|
|
1185
|
+
if (loadingFormData) {
|
|
1186
|
+
setTriggeredEditChart(true);
|
|
1187
|
+
}
|
|
1188
|
+
else {
|
|
1189
|
+
editChart();
|
|
1190
|
+
}
|
|
1191
|
+
}, disabled: filterIssues.length !== 0, label: buttonLabel
|
|
1192
|
+
? buttonLabel
|
|
1193
|
+
: report
|
|
1194
|
+
? 'Save changes'
|
|
1195
|
+
: 'Add to dashboard' })] }))] })] }))] }), _jsx(DashboardFilterModal, { isOpen: showFilterModal, setIsOpen: setShowFilterModal, issues: filterIssues, ButtonComponent: ButtonComponent, ModalComponent: ModalComponent })] }));
|
|
1136
1196
|
}
|
|
1137
1197
|
function SegmentedControl({ onChange, value, theme, organizationName, customFieldTableRef, }) {
|
|
1138
1198
|
return (_jsxs("div", { style: {
|
|
@@ -1207,7 +1267,7 @@ export function DashboardFilterModal({ isOpen, setIsOpen, issues, ModalComponent
|
|
|
1207
1267
|
boxSizing: 'border-box',
|
|
1208
1268
|
overflow: 'scroll',
|
|
1209
1269
|
maxHeight: 600,
|
|
1210
|
-
}, children: [issues.map((issue
|
|
1270
|
+
}, children: [issues.map((issue) => (_jsx("span", { style: { paddingTop: '10px' }, children: issue }, issue))), _jsx("div", { style: {
|
|
1211
1271
|
display: 'flex',
|
|
1212
1272
|
flexDirection: 'row',
|
|
1213
1273
|
justifyContent: 'flex-end',
|
|
@@ -22,6 +22,8 @@ export interface ChartEditorProps {
|
|
|
22
22
|
onAddToDashboardComplete?: (report: QuillReport) => void;
|
|
23
23
|
/** A callback function triggered when a chart element is clicked */
|
|
24
24
|
onClickChartElement?: (element: any) => void;
|
|
25
|
+
/** A callback function triggered when the chart error button is clicked */
|
|
26
|
+
onClickChartError?: (element: any) => void;
|
|
25
27
|
/** A callback that is fired when the item is deleted. */
|
|
26
28
|
onDelete?: () => void;
|
|
27
29
|
/** A select component. */
|
|
@@ -156,6 +158,16 @@ export interface ChartEditorProps {
|
|
|
156
158
|
ErrorMessageComponent?: (props: {
|
|
157
159
|
errorMessage: string;
|
|
158
160
|
}) => JSX.Element;
|
|
161
|
+
/**
|
|
162
|
+
* A component that displays when the chart errors.
|
|
163
|
+
*/
|
|
164
|
+
ErrorComponent?: (props: {
|
|
165
|
+
className?: string;
|
|
166
|
+
containerStyle?: React.CSSProperties;
|
|
167
|
+
label?: string;
|
|
168
|
+
onClick?: (element: any) => void;
|
|
169
|
+
ButtonComponent?: React.ComponentType<any>;
|
|
170
|
+
}) => JSX.Element;
|
|
159
171
|
/** The default dashboard to add the item to. */
|
|
160
172
|
destinationDashboard?: string;
|
|
161
173
|
/** The name of the current organization. */
|
|
@@ -193,5 +205,5 @@ export interface ChartEditorProps {
|
|
|
193
205
|
* ### Chart Editor API
|
|
194
206
|
* @see https://docs.quillsql.com/components/chart-editor
|
|
195
207
|
*/
|
|
196
|
-
export default function ChartEditor({ isOpen, reportId, isAdmin, destinationDashboard, chartBuilderTitle, chartBuilderButtonLabel, onAddToDashboardComplete, organizationName, isHorizontalView, onDelete, setIsOpen, SelectComponent, TextInputComponent, ButtonComponent, SecondaryButtonComponent, HeaderComponent, SubHeaderComponent, LabelComponent, TextComponent, DeleteButtonComponent, ModalComponent, CardComponent, PopoverComponent, LoadingComponent, TableComponent, ChartBuilderInputRowContainer, ChartBuilderInputColumnContainer, PivotRowContainer, PivotColumnContainer, ErrorMessageComponent, ChartBuilderFormContainer, hideDeleteButton, hideSubmitButton, onClickChartElement, }: ChartEditorProps): import("react/jsx-runtime").JSX.Element;
|
|
208
|
+
export default function ChartEditor({ isOpen, reportId, isAdmin, destinationDashboard, chartBuilderTitle, chartBuilderButtonLabel, onAddToDashboardComplete, organizationName, isHorizontalView, onDelete, setIsOpen, SelectComponent, TextInputComponent, ButtonComponent, SecondaryButtonComponent, HeaderComponent, SubHeaderComponent, LabelComponent, TextComponent, DeleteButtonComponent, ModalComponent, CardComponent, PopoverComponent, LoadingComponent, TableComponent, ChartBuilderInputRowContainer, ChartBuilderInputColumnContainer, PivotRowContainer, PivotColumnContainer, ErrorMessageComponent, ChartBuilderFormContainer, ErrorComponent, hideDeleteButton, hideSubmitButton, onClickChartElement, onClickChartError, }: ChartEditorProps): import("react/jsx-runtime").JSX.Element;
|
|
197
209
|
//# sourceMappingURL=ChartEditor.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartEditor.d.ts","sourceRoot":"","sources":["../../src/ChartEditor.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ChartEditor.d.ts","sourceRoot":"","sources":["../../src/ChartEditor.tsx"],"names":[],"mappings":"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"}
|