@quillsql/react 2.9.1 → 2.9.3
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/AddToDashboardModal.d.ts +1 -0
- package/dist/AddToDashboardModal.d.ts.map +1 -1
- package/dist/AddToDashboardModal.js +152 -181
- package/dist/AddToDashboardModal.js.map +1 -1
- package/dist/BarList.d.ts +1 -0
- package/dist/BarList.js +36 -44
- package/dist/Chart.d.ts +5 -24
- package/dist/Chart.d.ts.map +1 -1
- package/dist/Chart.js +203 -802
- package/dist/Chart.js.map +1 -1
- package/dist/ChartBuilder.d.ts +1 -0
- package/dist/ChartBuilder.d.ts.map +1 -1
- package/dist/ChartBuilder.js +89 -91
- package/dist/ChartBuilder.js.map +1 -1
- package/dist/ChartEditor.d.ts +1 -0
- package/dist/ChartEditor.d.ts.map +1 -1
- package/dist/ChartEditor.js +23 -22
- package/dist/ChartEditor.js.map +1 -1
- package/dist/Context.d.ts +20 -0
- package/dist/Context.d.ts.map +1 -1
- package/dist/Context.js +82 -62
- package/dist/Context.js.map +1 -1
- package/dist/Dashboard.d.ts +4 -1
- package/dist/Dashboard.d.ts.map +1 -1
- package/dist/Dashboard.js +238 -336
- package/dist/Dashboard.js.map +1 -1
- package/dist/DateRangePicker/Calendar.d.ts +1 -0
- package/dist/DateRangePicker/Calendar.js +41 -46
- package/dist/DateRangePicker/DateRangePicker.d.ts +1 -0
- package/dist/DateRangePicker/DateRangePicker.js +32 -61
- package/dist/DateRangePicker/DateRangePickerButton.d.ts +1 -0
- package/dist/DateRangePicker/DateRangePickerButton.js +14 -17
- package/dist/DateRangePicker/dateRangePickerUtils.d.ts +1 -0
- package/dist/DateRangePicker/dateRangePickerUtils.js +76 -90
- package/dist/DateRangePicker/index.d.ts +1 -0
- package/dist/DateRangePicker/index.js +1 -9
- package/dist/PieChart.d.ts +1 -0
- package/dist/PieChart.js +35 -70
- package/dist/QuillProvider.d.ts +1 -0
- package/dist/QuillProvider.js +4 -7
- package/dist/ReportBuilder.d.ts +1 -0
- package/dist/ReportBuilder.js +120 -129
- package/dist/SQLEditor.d.ts +1 -0
- package/dist/SQLEditor.js +56 -65
- package/dist/SQLEditor.js.map +1 -1
- package/dist/Table.d.ts +1 -0
- package/dist/Table.d.ts.map +1 -1
- package/dist/Table.js +65 -65
- package/dist/Table.js.map +1 -1
- package/dist/TableChart.d.ts +1 -0
- package/dist/TableChart.js +17 -45
- package/dist/api/ServerClient.d.ts +30 -0
- package/dist/api/ServerClient.d.ts.map +1 -0
- package/dist/api/ServerClient.js +39 -0
- package/dist/api/ServerClient.js.map +1 -0
- package/dist/assets/ArrowDownHeadIcon.d.ts +1 -0
- package/dist/assets/ArrowDownHeadIcon.js +3 -6
- package/dist/assets/ArrowDownIcon.d.ts +1 -0
- package/dist/assets/ArrowDownIcon.js +3 -6
- package/dist/assets/ArrowDownRightIcon.d.ts +1 -0
- package/dist/assets/ArrowDownRightIcon.js +3 -6
- package/dist/assets/ArrowLeftHeadIcon.d.ts +1 -0
- package/dist/assets/ArrowLeftHeadIcon.js +3 -6
- package/dist/assets/ArrowRightHeadIcon.d.ts +1 -0
- package/dist/assets/ArrowRightHeadIcon.js +3 -6
- package/dist/assets/ArrowRightIcon.d.ts +1 -0
- package/dist/assets/ArrowRightIcon.js +3 -6
- package/dist/assets/ArrowUpHeadIcon.d.ts +1 -0
- package/dist/assets/ArrowUpHeadIcon.js +3 -6
- package/dist/assets/ArrowUpIcon.d.ts +1 -0
- package/dist/assets/ArrowUpIcon.js +3 -6
- package/dist/assets/ArrowUpRightIcon.d.ts +1 -0
- package/dist/assets/ArrowUpRightIcon.js +3 -6
- package/dist/assets/CalendarIcon.d.ts +1 -0
- package/dist/assets/CalendarIcon.js +3 -6
- package/dist/assets/CalendarNormalIcon.d.ts +1 -0
- package/dist/assets/CalendarNormalIcon.js +3 -6
- package/dist/assets/DoubleArrowLeftHeadIcon.d.ts +1 -0
- package/dist/assets/DoubleArrowLeftHeadIcon.js +3 -6
- package/dist/assets/DoubleArrowRightHeadIcon.d.ts +1 -0
- package/dist/assets/DoubleArrowRightHeadIcon.js +3 -6
- package/dist/assets/ExclamationFilledIcon.d.ts +1 -0
- package/dist/assets/ExclamationFilledIcon.js +3 -6
- package/dist/assets/FilterIcon.d.ts +1 -0
- package/dist/assets/FilterIcon.js +3 -6
- package/dist/assets/LoadingSpinner.d.ts +1 -0
- package/dist/assets/LoadingSpinner.js +3 -6
- package/dist/assets/RefreshIcon.d.ts +1 -0
- package/dist/assets/RefreshIcon.js +3 -6
- package/dist/assets/SearchIcon.d.ts +1 -0
- package/dist/assets/SearchIcon.js +3 -6
- package/dist/assets/UpLeftArrowsIcon.d.ts +1 -0
- package/dist/assets/UpLeftArrowsIcon.js +3 -6
- package/dist/assets/XCircleIcon.d.ts +1 -0
- package/dist/assets/XCircleIcon.js +3 -6
- package/dist/assets/XIcon.d.ts +1 -0
- package/dist/assets/XIcon.js +3 -6
- package/dist/assets/index.d.ts +1 -0
- package/dist/assets/index.js +21 -49
- package/dist/components/Banner/index.d.ts +1 -0
- package/dist/components/Banner/index.js +6 -10
- package/dist/components/BigModal/BigModal.d.ts +1 -0
- package/dist/components/BigModal/BigModal.js +13 -39
- package/dist/components/Chart/BarChart.d.ts +15 -0
- package/dist/components/Chart/BarChart.d.ts.map +1 -0
- package/dist/components/Chart/BarChart.js +57 -0
- package/dist/components/Chart/BarChart.js.map +1 -0
- package/dist/components/Chart/ChartTooltip.d.ts +29 -0
- package/dist/components/Chart/ChartTooltip.d.ts.map +1 -0
- package/dist/components/Chart/ChartTooltip.js +229 -0
- package/dist/components/Chart/ChartTooltip.js.map +1 -0
- package/dist/components/Chart/ChartTooltipFrame.d.ts +6 -0
- package/dist/components/Chart/ChartTooltipFrame.d.ts.map +1 -0
- package/dist/components/Chart/ChartTooltipFrame.js +12 -0
- package/dist/components/Chart/ChartTooltipFrame.js.map +1 -0
- package/dist/components/Chart/ChartTooltipGroup.d.ts +11 -0
- package/dist/components/Chart/ChartTooltipGroup.d.ts.map +1 -0
- package/dist/components/Chart/ChartTooltipGroup.js +23 -0
- package/dist/components/Chart/ChartTooltipGroup.js.map +1 -0
- package/dist/components/Chart/ChartTooltipRow.d.ts +8 -0
- package/dist/components/Chart/ChartTooltipRow.d.ts.map +1 -0
- package/dist/components/Chart/ChartTooltipRow.js +41 -0
- package/dist/components/Chart/ChartTooltipRow.js.map +1 -0
- package/dist/components/Chart/LineChart.d.ts +13 -0
- package/dist/components/Chart/LineChart.d.ts.map +1 -0
- package/dist/components/Chart/LineChart.js +68 -0
- package/dist/components/Chart/LineChart.js.map +1 -0
- package/dist/components/Dropdown/Dropdown.d.ts +1 -0
- package/dist/components/Dropdown/Dropdown.js +24 -53
- package/dist/components/Dropdown/DropdownItem.d.ts +1 -0
- package/dist/components/Dropdown/DropdownItem.js +9 -35
- package/dist/components/Dropdown/index.d.ts +1 -0
- package/dist/components/Dropdown/index.js +2 -11
- package/dist/components/Modal/Modal.d.ts +1 -0
- package/dist/components/Modal/Modal.js +13 -39
- package/dist/components/Modal/index.d.ts +1 -0
- package/dist/components/Modal/index.js +1 -9
- package/dist/components/QuillCard.d.ts +1 -0
- package/dist/components/QuillCard.js +8 -13
- package/dist/components/ReportBuilder/ColumnSelector.d.ts +24 -6
- package/dist/components/ReportBuilder/ColumnSelector.d.ts.map +1 -1
- package/dist/components/ReportBuilder/ColumnSelector.js +56 -8
- package/dist/components/ReportBuilder/ColumnSelector.js.map +1 -0
- package/dist/components/ReportBuilder/FiltersModal.d.ts +40 -0
- package/dist/components/ReportBuilder/FiltersModal.d.ts.map +1 -0
- package/dist/components/ReportBuilder/FiltersModal.js +273 -0
- package/dist/components/ReportBuilder/FiltersModal.js.map +1 -0
- package/dist/components/ReportBuilder/SortModal.d.ts +28 -0
- package/dist/components/ReportBuilder/SortModal.d.ts.map +1 -0
- package/dist/components/ReportBuilder/SortModal.js +41 -0
- package/dist/components/ReportBuilder/SortModal.js.map +1 -0
- package/dist/components/SqlTextEditor.d.ts +1 -0
- package/dist/components/SqlTextEditor.js +4 -11
- package/dist/components/UiComponents.d.ts +1 -0
- package/dist/components/UiComponents.js +37 -51
- package/dist/components/selectUtils.d.ts +1 -0
- package/dist/components/selectUtils.js +6 -17
- package/dist/contexts/BaseColorContext.d.ts +1 -0
- package/dist/contexts/BaseColorContext.js +3 -6
- package/dist/contexts/HoveredValueContext.d.ts +1 -0
- package/dist/contexts/HoveredValueContext.js +3 -6
- package/dist/contexts/RootStylesContext.d.ts +1 -0
- package/dist/contexts/RootStylesContext.js +3 -6
- package/dist/contexts/SelectedValueContext.d.ts +1 -0
- package/dist/contexts/SelectedValueContext.js +3 -6
- package/dist/contexts/index.d.ts +1 -0
- package/dist/contexts/index.js +4 -15
- package/dist/hooks/index.d.ts +1 -0
- package/dist/hooks/index.js +4 -15
- package/dist/hooks/useDashboard.d.ts +1 -0
- package/dist/hooks/useDashboard.js +10 -15
- package/dist/hooks/useInternalState.d.ts +1 -0
- package/dist/hooks/useInternalState.js +3 -6
- package/dist/hooks/useOnClickOutside.d.ts +1 -0
- package/dist/hooks/useOnClickOutside.js +3 -6
- package/dist/hooks/useOnWindowResize.d.ts +1 -0
- package/dist/hooks/useOnWindowResize.js +4 -7
- package/dist/hooks/useQuill.d.ts +3 -2
- package/dist/hooks/useQuill.d.ts.map +1 -1
- package/dist/hooks/useQuill.js +37 -28
- package/dist/hooks/useQuill.js.map +1 -1
- package/dist/hooks/useSelectOnKeyDown.d.ts +1 -0
- package/dist/hooks/useSelectOnKeyDown.js +4 -7
- package/dist/index.d.ts +1 -0
- package/dist/index.js +13 -33
- package/dist/internals/ReportBuilder/PivotList.d.ts +1 -0
- package/dist/internals/ReportBuilder/PivotList.js +14 -20
- package/dist/internals/ReportBuilder/PivotModal.d.ts +3 -2
- package/dist/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/internals/ReportBuilder/PivotModal.js +280 -115
- package/dist/internals/ReportBuilder/PivotModal.js.map +1 -1
- package/dist/internals/ReportBuilder/PivotModal.spec.d.ts +1 -0
- package/dist/internals/ReportBuilder/PivotModal.spec.js +70 -73
- package/dist/lib/font.d.ts +1 -0
- package/dist/lib/font.js +2 -6
- package/dist/lib/index.d.ts +1 -0
- package/dist/lib/index.js +3 -20
- package/dist/lib/inputTypes.d.ts +1 -0
- package/dist/lib/inputTypes.js +1 -3
- package/dist/lib/utils.d.ts +1 -0
- package/dist/lib/utils.js +8 -19
- package/dist/test-data/tables.d.ts.map +1 -1
- package/dist/test-data/tables.js +27 -585
- package/dist/test-data/tables.js.map +1 -0
- package/dist/utils/aggregate.d.ts +1 -0
- package/dist/utils/aggregate.js +28 -35
- package/dist/utils/ast.d.ts +18 -0
- package/dist/utils/ast.d.ts.map +1 -0
- package/dist/utils/ast.js +310 -0
- package/dist/utils/ast.js.map +1 -0
- package/dist/utils/axisFormatter.d.ts +1 -0
- package/dist/utils/axisFormatter.js +19 -24
- package/dist/utils/color.d.ts +13 -0
- package/dist/utils/color.d.ts.map +1 -0
- package/dist/utils/color.js +247 -0
- package/dist/utils/color.js.map +1 -0
- package/dist/utils/colorToHex.d.ts +1 -0
- package/dist/utils/colorToHex.js +1 -5
- package/dist/utils/crypto.d.ts +2 -0
- package/dist/utils/crypto.d.ts.map +1 -0
- package/dist/utils/crypto.js +6 -0
- package/dist/utils/crypto.js.map +1 -0
- package/dist/utils/dataFetcher.d.ts +1 -0
- package/dist/utils/dataFetcher.d.ts.map +1 -1
- package/dist/utils/dataFetcher.js +8 -9
- package/dist/utils/dataFetcher.js.map +1 -1
- package/dist/utils/dates.d.ts +10 -0
- package/dist/utils/dates.d.ts.map +1 -0
- package/dist/utils/dates.js +32 -0
- package/dist/utils/dates.js.map +1 -0
- package/dist/utils/downloadCSV.d.ts +1 -0
- package/dist/utils/downloadCSV.js +1 -6
- package/dist/utils/getDomain.d.ts +8 -0
- package/dist/utils/getDomain.d.ts.map +1 -0
- package/dist/utils/getDomain.js +28 -0
- package/dist/utils/getDomain.js.map +1 -0
- package/dist/utils/merge.d.ts +2 -0
- package/dist/utils/merge.d.ts.map +1 -0
- package/dist/utils/merge.js +45 -0
- package/dist/utils/merge.js.map +1 -0
- package/dist/utils/schema.d.ts +7 -2
- package/dist/utils/schema.d.ts.map +1 -1
- package/dist/utils/schema.js +13 -7
- package/dist/utils/schema.js.map +1 -0
- package/dist/utils/sorting.d.ts +5 -0
- package/dist/utils/sorting.d.ts.map +1 -0
- package/dist/utils/sorting.js +14 -0
- package/dist/utils/sorting.js.map +1 -0
- package/dist/utils/textFormatting.d.ts.map +1 -1
- package/dist/utils/textFormatting.js +0 -1
- package/dist/utils/textFormatting.js.map +1 -0
- package/dist/utils/valueFormatter.d.ts +1 -0
- package/dist/utils/valueFormatter.js +19 -24
- package/dist/utils/valueFormatterCSV.d.ts +1 -0
- package/dist/utils/valueFormatterCSV.js +19 -24
- package/package.json +2 -3
- package/dist/DateRangePicker/Calendar.js.map +0 -1
- package/dist/DateRangePicker/dateRangePickerUtils.js.map +0 -1
- package/dist/DateRangePicker/index.js.map +0 -1
- package/dist/PieChart.js.map +0 -1
- package/dist/QuillProvider.js.map +0 -1
- package/dist/assets/ArrowDownIcon.js.map +0 -1
- package/dist/assets/ArrowDownRightIcon.js.map +0 -1
- package/dist/assets/ArrowLeftHeadIcon.js.map +0 -1
- package/dist/assets/ArrowRightHeadIcon.js.map +0 -1
- package/dist/assets/ArrowRightIcon.js.map +0 -1
- package/dist/assets/ArrowUpHeadIcon.js.map +0 -1
- package/dist/assets/ArrowUpIcon.js.map +0 -1
- package/dist/assets/ArrowUpRightIcon.js.map +0 -1
- package/dist/assets/CalendarIcon.js.map +0 -1
- package/dist/assets/CalendarNormalIcon.js.map +0 -1
- package/dist/assets/DoubleArrowLeftHeadIcon.js.map +0 -1
- package/dist/assets/DoubleArrowRightHeadIcon.js.map +0 -1
- package/dist/assets/ExclamationFilledIcon.js.map +0 -1
- package/dist/assets/FilterIcon.js.map +0 -1
- package/dist/assets/LoadingSpinner.js.map +0 -1
- package/dist/assets/RefreshIcon.js.map +0 -1
- package/dist/assets/SearchIcon.js.map +0 -1
- package/dist/assets/UpLeftArrowsIcon.js.map +0 -1
- package/dist/assets/XCircleIcon.js.map +0 -1
- package/dist/assets/XIcon.js.map +0 -1
- package/dist/assets/index.js.map +0 -1
- package/dist/components/BigModal/BigModal.js.map +0 -1
- package/dist/components/Dropdown/Dropdown.js.map +0 -1
- package/dist/components/Dropdown/DropdownItem.js.map +0 -1
- package/dist/components/Dropdown/index.js.map +0 -1
- package/dist/components/Modal/Modal.js.map +0 -1
- package/dist/components/Modal/index.js.map +0 -1
- package/dist/components/QuillCard.js.map +0 -1
- package/dist/components/selectUtils.js.map +0 -1
- package/dist/contexts/BaseColorContext.js.map +0 -1
- package/dist/contexts/HoveredValueContext.js.map +0 -1
- package/dist/contexts/RootStylesContext.js.map +0 -1
- package/dist/contexts/SelectedValueContext.js.map +0 -1
- package/dist/contexts/index.js.map +0 -1
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/useDashboard.js.map +0 -1
- package/dist/hooks/useInternalState.js.map +0 -1
- package/dist/hooks/useOnClickOutside.js.map +0 -1
- package/dist/hooks/useOnWindowResize.js.map +0 -1
- package/dist/hooks/useSelectOnKeyDown.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/internals/ReportBuilder/PivotModal.spec.js.map +0 -1
- package/dist/lib/font.js.map +0 -1
- package/dist/lib/index.js.map +0 -1
- package/dist/lib/inputTypes.js.map +0 -1
- package/dist/lib/utils.js.map +0 -1
- package/dist/utils/aggregate.js.map +0 -1
- package/dist/utils/downloadCSV.js.map +0 -1
|
@@ -1,19 +1,37 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
interface
|
|
3
|
-
name: string;
|
|
4
|
-
fieldType: string;
|
|
2
|
+
export interface ColumnSelectorInfo {
|
|
5
3
|
tableName: string;
|
|
4
|
+
columns: {
|
|
5
|
+
name: string;
|
|
6
|
+
}[];
|
|
6
7
|
}
|
|
7
8
|
interface ColumnSelectorProps {
|
|
8
9
|
schemaInfo: any[];
|
|
9
10
|
theme: any;
|
|
11
|
+
selectedPivot: {
|
|
12
|
+
rowField: string;
|
|
13
|
+
rowFieldType: string;
|
|
14
|
+
columnField?: string;
|
|
15
|
+
valueField: string;
|
|
16
|
+
aggregationType: 'sum' | 'count' | 'average';
|
|
17
|
+
} | undefined;
|
|
10
18
|
PopoverComponent?: any;
|
|
11
19
|
ButtonComponent?: any;
|
|
20
|
+
SecondaryButtonComponent?: any;
|
|
12
21
|
parentRef?: React.MutableRefObject<undefined>;
|
|
13
|
-
|
|
14
|
-
|
|
22
|
+
columnSelectorInfo: ColumnSelectorInfo;
|
|
23
|
+
setColumnSelectorInfo: (columnSelectorInfo: ColumnSelectorInfo) => void;
|
|
15
24
|
customerFieldName: string;
|
|
25
|
+
ModalComponent: any;
|
|
26
|
+
isOpen: boolean;
|
|
27
|
+
setIsOpen: (isOpen: boolean) => void;
|
|
28
|
+
pivotColumns: {
|
|
29
|
+
label: any;
|
|
30
|
+
field: any;
|
|
31
|
+
}[];
|
|
32
|
+
setFilters: (filters: any) => void;
|
|
33
|
+
setStringFields: (fields: any) => void;
|
|
16
34
|
}
|
|
17
|
-
export default function ColumnSelector({ schemaInfo, theme, parentRef,
|
|
35
|
+
export default function ColumnSelector({ schemaInfo, theme, parentRef, columnSelectorInfo, PopoverComponent, ButtonComponent, SecondaryButtonComponent, setColumnSelectorInfo, customerFieldName, ModalComponent, isOpen, setIsOpen, pivotColumns, setFilters, setStringFields, }: ColumnSelectorProps): import("react/jsx-runtime").JSX.Element;
|
|
18
36
|
export {};
|
|
19
37
|
//# sourceMappingURL=ColumnSelector.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ColumnSelector.d.ts","sourceRoot":"","sources":["../../../src/components/ReportBuilder/ColumnSelector.tsx"],"names":[],"mappings":"AAAA,OAAO,KAMN,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"ColumnSelector.d.ts","sourceRoot":"","sources":["../../../src/components/ReportBuilder/ColumnSelector.tsx"],"names":[],"mappings":"AAAA,OAAO,KAMN,MAAM,OAAO,CAAC;AAUf,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CAC7B;AAQD,UAAU,mBAAmB;IAC3B,UAAU,EAAE,GAAG,EAAE,CAAC;IAClB,KAAK,EAAE,GAAG,CAAC;IACX,aAAa,EACT;QACE,QAAQ,EAAE,MAAM,CAAC;QACjB,YAAY,EAAE,MAAM,CAAC;QACrB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,UAAU,EAAE,MAAM,CAAC;QACnB,eAAe,EAAE,KAAK,GAAG,OAAO,GAAG,SAAS,CAAC;KAC9C,GACD,SAAS,CAAC;IACd,gBAAgB,CAAC,EAAE,GAAG,CAAC;IACvB,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,wBAAwB,CAAC,EAAE,GAAG,CAAC;IAC/B,SAAS,CAAC,EAAE,KAAK,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;IAC9C,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,qBAAqB,EAAE,CAAC,kBAAkB,EAAE,kBAAkB,KAAK,IAAI,CAAC;IACxE,iBAAiB,EAAE,MAAM,CAAC;IAC1B,cAAc,EAAE,GAAG,CAAC;IACpB,MAAM,EAAE,OAAO,CAAC;IAChB,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;IACrC,YAAY,EAAE;QAAE,KAAK,EAAE,GAAG,CAAC;QAAC,KAAK,EAAE,GAAG,CAAA;KAAE,EAAE,CAAC;IAC3C,UAAU,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;IACnC,eAAe,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,IAAI,CAAC;CACxC;AAED,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EACrC,UAAU,EACV,KAAK,EACL,SAAS,EACT,kBAAkB,EAClB,gBAAgB,EAChB,eAAe,EACf,wBAAwB,EACxB,qBAAqB,EACrB,iBAAiB,EACjB,cAAc,EACd,MAAM,EACN,SAAS,EACT,YAAY,EACZ,UAAU,EACV,eAAe,GAChB,EAAE,mBAAmB,2CAiNrB"}
|
|
@@ -2,14 +2,19 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
2
2
|
import { useEffect, useState, } from 'react';
|
|
3
3
|
import { MemoizedTextInput } from '../UiComponents';
|
|
4
4
|
import { formatColumnData, } from '../../utils/schema';
|
|
5
|
-
export default function ColumnSelector({ schemaInfo, theme, parentRef,
|
|
6
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
5
|
+
export default function ColumnSelector({ schemaInfo, theme, parentRef, columnSelectorInfo, PopoverComponent, ButtonComponent, SecondaryButtonComponent, setColumnSelectorInfo, customerFieldName, ModalComponent, isOpen, setIsOpen, pivotColumns, setFilters, setStringFields, }) {
|
|
7
6
|
const [allColumns, setAllCoumns] = useState([]);
|
|
8
7
|
const [searchQuery, setSearchQuery] = useState('');
|
|
8
|
+
const [selectableTables, setSelectableTables] = useState([]);
|
|
9
|
+
const [showPivotColumnRemovalMessage, setShowPivotColumnRemovalMessage] = useState(false);
|
|
10
|
+
// const modalRef = useRef<HTMLDivElement>(null);
|
|
11
|
+
// useOnClickOutside(modalRef, (e) => {
|
|
12
|
+
// // Exclude click on trigger button (e.g. Dropdown Button) from outside click handler
|
|
13
|
+
// setIsOpen(false);
|
|
14
|
+
// });
|
|
9
15
|
useEffect(() => {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
}, [schemaInfo]);
|
|
16
|
+
setAllCoumns(formatColumnData(schemaInfo, columnSelectorInfo, customerFieldName));
|
|
17
|
+
}, [schemaInfo, columnSelectorInfo]);
|
|
13
18
|
const updateSelectedColumns = (selectedColumn) => {
|
|
14
19
|
const currentAllColumns = [...allColumns];
|
|
15
20
|
// loop through all columns if selected column is found then toggle selected
|
|
@@ -41,7 +46,19 @@ export default function ColumnSelector({ schemaInfo, theme, parentRef, selectedT
|
|
|
41
46
|
column.selectable = selectable;
|
|
42
47
|
}
|
|
43
48
|
});
|
|
49
|
+
setSelectableTables(selectableTables);
|
|
44
50
|
setAllCoumns(currentAllColumns);
|
|
51
|
+
if (pivotColumns) {
|
|
52
|
+
let displayError = false;
|
|
53
|
+
pivotColumns.find((column) => {
|
|
54
|
+
currentAllColumns.forEach((col) => {
|
|
55
|
+
if (!col.selected && col.name === column.field) {
|
|
56
|
+
displayError = true;
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
setShowPivotColumnRemovalMessage(displayError);
|
|
61
|
+
}
|
|
45
62
|
};
|
|
46
63
|
const memoizedTextInputChange = (value) => {
|
|
47
64
|
const currentAllColumns = [...allColumns];
|
|
@@ -60,7 +77,25 @@ export default function ColumnSelector({ schemaInfo, theme, parentRef, selectedT
|
|
|
60
77
|
setSearchQuery(value);
|
|
61
78
|
setAllCoumns(currentAllColumns);
|
|
62
79
|
};
|
|
63
|
-
|
|
80
|
+
const unselectAll = () => {
|
|
81
|
+
const currentAllColumns = [...allColumns];
|
|
82
|
+
currentAllColumns.forEach((column) => {
|
|
83
|
+
column.selected = false;
|
|
84
|
+
column.selectable = true;
|
|
85
|
+
});
|
|
86
|
+
setAllCoumns(currentAllColumns);
|
|
87
|
+
};
|
|
88
|
+
return (_jsx(ModalComponent, { title: "Select columns", setIsOpen: setIsOpen, isOpen: isOpen, onClose: () => setIsOpen(false), children: _jsxs("div", { style: {
|
|
89
|
+
// maxHeight: 600,
|
|
90
|
+
overflowY: 'scroll',
|
|
91
|
+
maxHeight: '90vh',
|
|
92
|
+
minWidth: 600,
|
|
93
|
+
padding: 20,
|
|
94
|
+
}, children: [_jsxs("div", { style: {
|
|
95
|
+
display: 'flex',
|
|
96
|
+
flexDirection: 'row',
|
|
97
|
+
justifyContent: 'space-between',
|
|
98
|
+
}, children: [_jsx(MemoizedTextInput, { value: searchQuery, onChange: memoizedTextInputChange, placeholder: 'Search', id: 'quill-search-bar', style: { width: '72%' } }), _jsx(SecondaryButtonComponent, { label: 'Unselect All', onClick: unselectAll })] }), _jsx("br", {}), allColumns.map((column, index) => {
|
|
64
99
|
if (column.selectable && column.textFiltered) {
|
|
65
100
|
return (_jsxs("div", { style: {
|
|
66
101
|
display: 'flex',
|
|
@@ -71,7 +106,7 @@ export default function ColumnSelector({ schemaInfo, theme, parentRef, selectedT
|
|
|
71
106
|
updateSelectedColumns(column);
|
|
72
107
|
} }), _jsx("div", { style: { width: 6 } }), _jsx("div", { children: column.displayName })] }, column.name + index));
|
|
73
108
|
}
|
|
74
|
-
}), _jsx("div", { children: _jsx(ButtonComponent, { id: "custom-button", onClick: () => {
|
|
109
|
+
}), showPivotColumnRemovalMessage && (_jsx("div", { style: { color: 'red' }, children: "Warning: Removing the pivot columns will remove the pivot table" })), _jsx("br", {}), _jsx("div", { children: _jsx(ButtonComponent, { id: "custom-button", onClick: () => {
|
|
75
110
|
const selectedColumns = allColumns.reduce((acc, column) => {
|
|
76
111
|
if (column.selected) {
|
|
77
112
|
acc.push({
|
|
@@ -82,6 +117,19 @@ export default function ColumnSelector({ schemaInfo, theme, parentRef, selectedT
|
|
|
82
117
|
}
|
|
83
118
|
return acc;
|
|
84
119
|
}, []);
|
|
85
|
-
|
|
120
|
+
if (selectedColumns.length === 0) {
|
|
121
|
+
alert('Please select at least one column');
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
if (columnSelectorInfo.tableName !== selectableTables[0]) {
|
|
125
|
+
setFilters([]);
|
|
126
|
+
setStringFields({});
|
|
127
|
+
}
|
|
128
|
+
setColumnSelectorInfo({
|
|
129
|
+
tableName: selectableTables[0] ? selectableTables[0] : '',
|
|
130
|
+
columns: selectedColumns,
|
|
131
|
+
});
|
|
132
|
+
setIsOpen(false);
|
|
133
|
+
setShowPivotColumnRemovalMessage(false);
|
|
86
134
|
}, label: 'Select' }) })] }) }));
|
|
87
135
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ColumnSelector.js","sourceRoot":"","sources":["../../../src/components/ReportBuilder/ColumnSelector.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ButtonComponentProps, LabelProps, ModalComponentProps, TextInputComponentProps } from '../UiComponents';
|
|
3
|
+
interface ColumnSelectorInfo {
|
|
4
|
+
tableName: string;
|
|
5
|
+
columns: {
|
|
6
|
+
name: string;
|
|
7
|
+
}[];
|
|
8
|
+
}
|
|
9
|
+
interface FiltersModalProps {
|
|
10
|
+
setIsOpen: (isOpen: boolean) => void;
|
|
11
|
+
isOpen: boolean;
|
|
12
|
+
computedColumns: any[];
|
|
13
|
+
columnSelectorInfo: ColumnSelectorInfo;
|
|
14
|
+
data: any[];
|
|
15
|
+
selectedTable: {
|
|
16
|
+
displayName: string;
|
|
17
|
+
columns: {
|
|
18
|
+
name: string;
|
|
19
|
+
fieldType: string;
|
|
20
|
+
}[];
|
|
21
|
+
};
|
|
22
|
+
filters: any[];
|
|
23
|
+
stringFields: {
|
|
24
|
+
[type: string]: {
|
|
25
|
+
isLike: boolean;
|
|
26
|
+
value: string;
|
|
27
|
+
}[];
|
|
28
|
+
};
|
|
29
|
+
setFilters: (filters: any) => void;
|
|
30
|
+
setStringFields: (stringFields: any) => void;
|
|
31
|
+
theme: any;
|
|
32
|
+
TextInputComponent: (props: TextInputComponentProps) => JSX.Element;
|
|
33
|
+
LabelComponent: (props: LabelProps) => JSX.Element;
|
|
34
|
+
ButtonComponent: (props: ButtonComponentProps) => JSX.Element;
|
|
35
|
+
SecondaryButtonComponent: (props: ButtonComponentProps) => JSX.Element;
|
|
36
|
+
ModalComponent: (props: ModalComponentProps) => JSX.Element;
|
|
37
|
+
}
|
|
38
|
+
export default function FiltersModal({ setIsOpen, isOpen, columnSelectorInfo, selectedTable, filters, setFilters, theme, TextInputComponent, LabelComponent, ButtonComponent, ModalComponent, SecondaryButtonComponent, computedColumns, data, stringFields, setStringFields, }: FiltersModalProps): import("react/jsx-runtime").JSX.Element;
|
|
39
|
+
export {};
|
|
40
|
+
//# sourceMappingURL=FiltersModal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FiltersModal.d.ts","sourceRoot":"","sources":["../../../src/components/ReportBuilder/FiltersModal.tsx"],"names":[],"mappings":";AACA,OAAO,EACL,oBAAoB,EACpB,UAAU,EACV,mBAAmB,EACnB,uBAAuB,EACxB,MAAM,iBAAiB,CAAC;AAUzB,UAAU,kBAAkB;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE;QACP,IAAI,EAAE,MAAM,CAAC;KACd,EAAE,CAAC;CACL;AAED,UAAU,iBAAiB;IACzB,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;IACrC,MAAM,EAAE,OAAO,CAAC;IAChB,eAAe,EAAE,GAAG,EAAE,CAAC;IACvB,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,aAAa,EAAE;QACb,WAAW,EAAE,MAAM,CAAC;QACpB,OAAO,EAAE;YACP,IAAI,EAAE,MAAM,CAAC;YACb,SAAS,EAAE,MAAM,CAAC;SACnB,EAAE,CAAC;KACL,CAAC;IACF,OAAO,EAAE,GAAG,EAAE,CAAC;IACf,YAAY,EAAE;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG;YAAE,MAAM,EAAE,OAAO,CAAC;YAAC,KAAK,EAAE,MAAM,CAAA;SAAE,EAAE,CAAA;KAAE,CAAC;IACvE,UAAU,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;IACnC,eAAe,EAAE,CAAC,YAAY,EAAE,GAAG,KAAK,IAAI,CAAC;IAC7C,KAAK,EAAE,GAAG,CAAC;IACX,kBAAkB,EAAE,CAAC,KAAK,EAAE,uBAAuB,KAAK,GAAG,CAAC,OAAO,CAAC;IACpE,cAAc,EAAE,CAAC,KAAK,EAAE,UAAU,KAAK,GAAG,CAAC,OAAO,CAAC;IACnD,eAAe,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,GAAG,CAAC,OAAO,CAAC;IAC9D,wBAAwB,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,GAAG,CAAC,OAAO,CAAC;IACvE,cAAc,EAAE,CAAC,KAAK,EAAE,mBAAmB,KAAK,GAAG,CAAC,OAAO,CAAC;CAC7D;AA8CD,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,EACnC,SAAS,EACT,MAAM,EACN,kBAAkB,EAClB,aAAa,EACb,OAAO,EACP,UAAU,EACV,KAAK,EACL,kBAAkB,EAClB,cAAc,EACd,eAAe,EACf,cAAc,EACd,wBAAwB,EACxB,eAAe,EACf,IAAI,EACJ,YAAY,EACZ,eAAe,GAChB,EAAE,iBAAiB,2CAyGnB"}
|
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
3
|
+
import { DivCheckbox, getPostgresBasicType } from '../../ReportBuilder';
|
|
4
|
+
import { QuillDateRangePicker } from '../../Dashboard';
|
|
5
|
+
import { getRangeFromPreset, reportBuilderOptions, } from '../../DateRangePicker/dateRangePickerUtils';
|
|
6
|
+
import { deSnakeOrCamelCase } from '../../utils/textFormatting';
|
|
7
|
+
function getColumnStats({ name, fieldType, columnDetails, stringFields, }) {
|
|
8
|
+
if (fieldType === 'string') {
|
|
9
|
+
if (!stringFields || !stringFields[name]) {
|
|
10
|
+
return undefined;
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
return stringFields[name];
|
|
14
|
+
}
|
|
15
|
+
// let moreThanTwice = false;
|
|
16
|
+
// const freqMap = columnDetails.reduce((acc: any, row: any) => {
|
|
17
|
+
// if (row[name] in acc) {
|
|
18
|
+
// acc[row[name]] += 1;
|
|
19
|
+
// } else if (row[name] !== null && row[name] !== undefined) {
|
|
20
|
+
// acc[row[name]] = 1;
|
|
21
|
+
// }
|
|
22
|
+
// // Only display if a value appears more than twice
|
|
23
|
+
// if (acc[row[name]] > 2) {
|
|
24
|
+
// moreThanTwice = true;
|
|
25
|
+
// }
|
|
26
|
+
// return acc;
|
|
27
|
+
// }, {});
|
|
28
|
+
// // return an array of the top 6 most frequent values
|
|
29
|
+
// if (!moreThanTwice) {
|
|
30
|
+
// return undefined;
|
|
31
|
+
// }
|
|
32
|
+
// return Object.keys(freqMap)
|
|
33
|
+
// .sort((a, b) => freqMap[b] - freqMap[a])
|
|
34
|
+
// .slice(0, 6);
|
|
35
|
+
}
|
|
36
|
+
else if (fieldType === 'number') {
|
|
37
|
+
return { min: 'Start', max: 'End' };
|
|
38
|
+
}
|
|
39
|
+
return [];
|
|
40
|
+
}
|
|
41
|
+
export default function FiltersModal({ setIsOpen, isOpen, columnSelectorInfo, selectedTable, filters, setFilters, theme, TextInputComponent, LabelComponent, ButtonComponent, ModalComponent, SecondaryButtonComponent, computedColumns, data, stringFields, setStringFields, }) {
|
|
42
|
+
const [curFilters, setCurFilters] = useState(filters ? filters : []);
|
|
43
|
+
useEffect(() => {
|
|
44
|
+
setCurFilters(filters);
|
|
45
|
+
}, [filters]);
|
|
46
|
+
const addFilter = (newFilter) => {
|
|
47
|
+
if (!newFilter) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
const curFilter = curFilters.find((filter) => filter.column === newFilter.column);
|
|
51
|
+
if (curFilter && newFilter.selectedValues?.length === 0) {
|
|
52
|
+
setCurFilters((curFilters) => curFilters.filter((filter) => filter.column !== newFilter.column));
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
if (curFilter) {
|
|
56
|
+
setCurFilters((curFilters) => curFilters.map((filter) => {
|
|
57
|
+
if (filter.column === newFilter.column) {
|
|
58
|
+
return newFilter;
|
|
59
|
+
}
|
|
60
|
+
return filter;
|
|
61
|
+
}));
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
setCurFilters((curFilters) => [...curFilters, newFilter]);
|
|
65
|
+
};
|
|
66
|
+
return (_jsxs(ModalComponent, { theme: theme, title: "Filters", isOpen: isOpen, onClose: () => setIsOpen(false), setIsOpen: setIsOpen, children: [_jsx("div", { style: { padding: 25, overflow: 'scroll' }, children: selectedTable?.columns.map((column) => {
|
|
67
|
+
const curFilter = curFilters.find((filter) => filter.column === column.name);
|
|
68
|
+
const columnStats = getColumnStats({
|
|
69
|
+
name: column.name,
|
|
70
|
+
fieldType: getPostgresBasicType(column),
|
|
71
|
+
columnDetails: data,
|
|
72
|
+
stringFields,
|
|
73
|
+
});
|
|
74
|
+
if (!columnStats || deSnakeOrCamelCase(column.name).endsWith('ID')) {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
return (_jsx("div", { children: _jsx(FilterSection, { column: column, addFilter: addFilter, curFilter: curFilter, columnStats: columnStats, theme: theme, stringFields: stringFields, setStringFields: setStringFields, LabelComponent: LabelComponent, TextInputComponent: TextInputComponent, SecondaryButtonComponent: SecondaryButtonComponent, ButtonComponent: ButtonComponent }) }, column.name));
|
|
78
|
+
}) }), _jsx(ButtonComponent, { label: "Set Filters", onClick: () => {
|
|
79
|
+
// Check to make sure that each filter
|
|
80
|
+
const properFilters = curFilters.filter((filter) => {
|
|
81
|
+
if (filter.columnType === 'string' &&
|
|
82
|
+
filter.stringFilterValues.length === 0) {
|
|
83
|
+
return false;
|
|
84
|
+
}
|
|
85
|
+
else if (filter.columnType === 'number' &&
|
|
86
|
+
!filter.numberStart &&
|
|
87
|
+
!filter.numberEnd) {
|
|
88
|
+
return false;
|
|
89
|
+
}
|
|
90
|
+
else if (filter.columnType === 'date' &&
|
|
91
|
+
!filter.filterDateRange) {
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
94
|
+
return true;
|
|
95
|
+
});
|
|
96
|
+
setFilters(properFilters);
|
|
97
|
+
setIsOpen(false);
|
|
98
|
+
} })] }));
|
|
99
|
+
}
|
|
100
|
+
function FilterSection({ column, addFilter, curFilter, columnStats, theme, stringFields, setStringFields, LabelComponent, TextInputComponent, SecondaryButtonComponent, ButtonComponent, }) {
|
|
101
|
+
const filterType = getPostgresBasicType(column);
|
|
102
|
+
const [currentFilter, setCurrentFilter] = useState(curFilter);
|
|
103
|
+
useEffect(() => {
|
|
104
|
+
addFilter(currentFilter);
|
|
105
|
+
}, [currentFilter]);
|
|
106
|
+
if (filterType == 'string') {
|
|
107
|
+
return (_jsx(StringFilterSection, { column: column.name, filter: currentFilter, columnStats: columnStats, theme: theme, setCurrentFilter: setCurrentFilter, TextInputComponent: TextInputComponent, SecondaryButtonComponent: SecondaryButtonComponent, ButtonComponent: ButtonComponent, setStringFields: setStringFields, stringFields: stringFields }));
|
|
108
|
+
}
|
|
109
|
+
if (filterType == 'number') {
|
|
110
|
+
return (_jsx(NumberFilterSection, { column: column.name, filter: currentFilter, LabelComponent: LabelComponent, TextInputComponent: TextInputComponent, theme: theme, addFilter: addFilter, setCurrentFilter: setCurrentFilter }));
|
|
111
|
+
}
|
|
112
|
+
if (filterType == 'date') {
|
|
113
|
+
return (_jsx(DateFilterSection, { column: column.name, filter: currentFilter, setCurrentFilter: setCurrentFilter }));
|
|
114
|
+
}
|
|
115
|
+
return _jsx("div", { children: "You found a magical column, congrats" });
|
|
116
|
+
}
|
|
117
|
+
function StringFilterSection({ column, filter, columnStats, theme, stringFields, setStringFields, setCurrentFilter, TextInputComponent, SecondaryButtonComponent, ButtonComponent, }) {
|
|
118
|
+
const [showSearchBar, setShowSearchBar] = useState(false);
|
|
119
|
+
const [searchQuery, setSearchQuery] = useState('');
|
|
120
|
+
const modifyFilter = (field, checked) => {
|
|
121
|
+
if (checked) {
|
|
122
|
+
if (filter) {
|
|
123
|
+
setCurrentFilter({
|
|
124
|
+
...filter,
|
|
125
|
+
columnType: 'string',
|
|
126
|
+
stringFilterValues: [...filter.stringFilterValues, field],
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
setCurrentFilter({
|
|
131
|
+
column,
|
|
132
|
+
columnType: 'string',
|
|
133
|
+
stringFilterValues: [field],
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
if (filter) {
|
|
139
|
+
setCurrentFilter({
|
|
140
|
+
...filter,
|
|
141
|
+
columnType: 'string',
|
|
142
|
+
stringFilterValues: filter.stringFilterValues.filter((value) => value.value !== field.value),
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
};
|
|
147
|
+
return (_jsxs("div", { style: {
|
|
148
|
+
flex: 'flex',
|
|
149
|
+
flexDirection: 'column',
|
|
150
|
+
marginTop: '14px',
|
|
151
|
+
overflow: 'hidden',
|
|
152
|
+
minWidth: 600,
|
|
153
|
+
}, children: [_jsx("h1", { style: { fontSize: 18, fontWeight: 600, textAlign: 'left' }, children: deSnakeOrCamelCase(column) }), _jsx("div", { style: {
|
|
154
|
+
display: 'grid',
|
|
155
|
+
gridTemplateColumns: '1fr 1fr',
|
|
156
|
+
gridGap: '10px',
|
|
157
|
+
}, children: columnStats.map((value) => (_jsx("div", { style: {
|
|
158
|
+
display: 'flex',
|
|
159
|
+
flexDirection: 'row',
|
|
160
|
+
alignItems: 'center',
|
|
161
|
+
}, children: _jsxs("div", { style: {
|
|
162
|
+
display: 'flex',
|
|
163
|
+
flexDirection: 'row',
|
|
164
|
+
alignItems: 'center',
|
|
165
|
+
paddingTop: 6,
|
|
166
|
+
paddingBottom: 6,
|
|
167
|
+
}, children: [_jsx(DivCheckbox, { theme: theme, checked: filter?.stringFilterValues
|
|
168
|
+
? filter.stringFilterValues.some((stringFilter) => stringFilter.value === value.value)
|
|
169
|
+
: false, onChange: (checked) => {
|
|
170
|
+
modifyFilter(value, checked);
|
|
171
|
+
} }), _jsx("div", { style: {
|
|
172
|
+
marginLeft: 6,
|
|
173
|
+
display: 'block',
|
|
174
|
+
overflow: 'hidden',
|
|
175
|
+
textOverflow: 'ellipsis',
|
|
176
|
+
whiteSpace: 'nowrap',
|
|
177
|
+
color: theme?.primaryTextColor,
|
|
178
|
+
fontFamily: theme?.fontFamily,
|
|
179
|
+
maxWidth: 250,
|
|
180
|
+
}, children: _jsx("div", { style: {
|
|
181
|
+
marginLeft: 6,
|
|
182
|
+
display: 'block',
|
|
183
|
+
overflow: 'hidden',
|
|
184
|
+
textOverflow: 'ellipsis',
|
|
185
|
+
whiteSpace: 'nowrap',
|
|
186
|
+
color: theme?.primaryTextColor,
|
|
187
|
+
fontFamily: theme?.fontFamily,
|
|
188
|
+
}, children: value.value }) })] }, value.value) }, value.value))) }), !showSearchBar ? (_jsx(SecondaryButtonComponent, { label: `+ Add a ${deSnakeOrCamelCase(column)}`, onClick: () => setShowSearchBar(true) })) : (_jsxs("div", { style: {
|
|
189
|
+
display: 'flex',
|
|
190
|
+
flexDirection: 'row',
|
|
191
|
+
alignItems: 'center',
|
|
192
|
+
width: '100%',
|
|
193
|
+
gap: 12,
|
|
194
|
+
}, children: [_jsx(TextInputComponent, { id: "string-filter-search-bar", placeholder: `Add a ${deSnakeOrCamelCase(column)}`, value: searchQuery, onChange: setSearchQuery }), _jsx(SecondaryButtonComponent, { label: `Add ${deSnakeOrCamelCase(column)}`, onClick: () => {
|
|
195
|
+
modifyFilter({ isLike: true, value: searchQuery }, true);
|
|
196
|
+
setShowSearchBar(false);
|
|
197
|
+
setStringFields({
|
|
198
|
+
...stringFields,
|
|
199
|
+
[column]: [
|
|
200
|
+
...columnStats,
|
|
201
|
+
{ isLike: true, value: searchQuery },
|
|
202
|
+
],
|
|
203
|
+
});
|
|
204
|
+
setSearchQuery('');
|
|
205
|
+
} })] }))] }));
|
|
206
|
+
}
|
|
207
|
+
function NumberFilterSection({ column, filter, LabelComponent, TextInputComponent, setCurrentFilter, }) {
|
|
208
|
+
const modifyFilter = (value, startOrEnd) => {
|
|
209
|
+
setCurrentFilter({
|
|
210
|
+
...filter,
|
|
211
|
+
column,
|
|
212
|
+
columnType: 'number',
|
|
213
|
+
[startOrEnd]: value,
|
|
214
|
+
});
|
|
215
|
+
};
|
|
216
|
+
return (_jsxs("div", { children: [_jsx("h1", { style: { fontSize: 18, fontWeight: 600, textAlign: 'left' }, children: deSnakeOrCamelCase(column) }), _jsxs("div", { style: {
|
|
217
|
+
display: 'flex',
|
|
218
|
+
flexDirection: 'row',
|
|
219
|
+
alignItems: 'center',
|
|
220
|
+
// justifyContent: 'space-between',
|
|
221
|
+
}, children: [_jsxs("div", { style: {
|
|
222
|
+
display: 'flex',
|
|
223
|
+
flexDirection: 'column',
|
|
224
|
+
marginTop: '20px',
|
|
225
|
+
}, children: [_jsx(LabelComponent, { children: "Minimum" }), _jsx(TextInputComponent, { id: "min-input", value: filter?.numberStart ? filter.numberStart : '', placeholder: "Minimum", onChange: (value) => {
|
|
226
|
+
modifyFilter(value, 'numberStart');
|
|
227
|
+
} })] }), _jsx("div", { style: { width: 16 } }), _jsxs("div", { style: {
|
|
228
|
+
display: 'flex',
|
|
229
|
+
flexDirection: 'column',
|
|
230
|
+
marginTop: '20px',
|
|
231
|
+
}, children: [_jsx(LabelComponent, { children: "Maximum" }), _jsx(TextInputComponent, { id: "max-input", placeholder: "Maximum", value: filter?.numberEnd ? filter.numberEnd : '', onChange: (value) => modifyFilter(value, 'numberEnd') })] })] })] }));
|
|
232
|
+
}
|
|
233
|
+
function DateFilterSection({ column, filter, setCurrentFilter, }) {
|
|
234
|
+
const [dateRange, setDateRange] = useState(filter ? filter.filterDateRange : [null, null, null]);
|
|
235
|
+
return (_jsxs("div", { style: {
|
|
236
|
+
display: 'flex',
|
|
237
|
+
flexDirection: 'column',
|
|
238
|
+
marginTop: 20,
|
|
239
|
+
}, children: [_jsx("h1", { style: { fontSize: 18, fontWeight: 600, textAlign: 'left' }, children: deSnakeOrCamelCase(column) }), _jsx(QuillDateRangePicker, { dateRange: dateRange ? [dateRange[0], dateRange[1]] : [null, null], label: '', onChangeDateRange: (dateRange) => {
|
|
240
|
+
setDateRange([dateRange[0], dateRange[1], null]);
|
|
241
|
+
setCurrentFilter({
|
|
242
|
+
column,
|
|
243
|
+
columnType: 'date',
|
|
244
|
+
filterDateRange: [dateRange[0], dateRange[1], null],
|
|
245
|
+
});
|
|
246
|
+
}, preset: dateRange && dateRange.length === 3 && dateRange[2] !== null
|
|
247
|
+
? dateRange[2]
|
|
248
|
+
: '', selectedPreset: (dateRange && dateRange.length === 3 && dateRange[2]) || '', onChangePreset: (preset) => {
|
|
249
|
+
if (typeof preset === 'string') {
|
|
250
|
+
setDateRange(getRangeFromPreset(preset));
|
|
251
|
+
setCurrentFilter({
|
|
252
|
+
column,
|
|
253
|
+
columnType: 'date',
|
|
254
|
+
filterDateRange: getRangeFromPreset(preset),
|
|
255
|
+
});
|
|
256
|
+
return;
|
|
257
|
+
}
|
|
258
|
+
setDateRange([
|
|
259
|
+
preset?.startDate || null,
|
|
260
|
+
new Date(),
|
|
261
|
+
preset?.value || '',
|
|
262
|
+
]);
|
|
263
|
+
setCurrentFilter({
|
|
264
|
+
column,
|
|
265
|
+
columnType: 'date',
|
|
266
|
+
filterDateRange: [
|
|
267
|
+
preset?.startDate || null,
|
|
268
|
+
new Date(),
|
|
269
|
+
preset?.value || '',
|
|
270
|
+
],
|
|
271
|
+
});
|
|
272
|
+
}, presetOptions: reportBuilderOptions })] }));
|
|
273
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FiltersModal.js","sourceRoot":"","sources":["../../../src/components/ReportBuilder/FiltersModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { LabelProps } from 'recharts';
|
|
3
|
+
import { ButtonComponentProps, ModalComponentProps, SelectComponentProps } from '../UiComponents';
|
|
4
|
+
interface ColumnSelectorInfo {
|
|
5
|
+
tableName: string;
|
|
6
|
+
columns: {
|
|
7
|
+
name: string;
|
|
8
|
+
}[];
|
|
9
|
+
}
|
|
10
|
+
interface SortModalProps {
|
|
11
|
+
columnSelectorInfo: ColumnSelectorInfo;
|
|
12
|
+
pivotColumns: {
|
|
13
|
+
label: any;
|
|
14
|
+
field: any;
|
|
15
|
+
}[] | undefined;
|
|
16
|
+
sorts: any[];
|
|
17
|
+
setSorts: (filters: any) => void;
|
|
18
|
+
LabelComponent: (props: LabelProps) => JSX.Element;
|
|
19
|
+
ButtonComponent: (props: ButtonComponentProps) => JSX.Element;
|
|
20
|
+
ModalComponent: (props: ModalComponentProps) => JSX.Element;
|
|
21
|
+
SelectComponent: (props: SelectComponentProps) => JSX.Element;
|
|
22
|
+
isOpen: boolean;
|
|
23
|
+
setIsOpen: (isOpen: boolean) => void;
|
|
24
|
+
theme: any;
|
|
25
|
+
}
|
|
26
|
+
export default function SortModal({ columnSelectorInfo, sorts, pivotColumns, setSorts, SelectComponent, ModalComponent, ButtonComponent, setIsOpen, isOpen, theme, }: SortModalProps): import("react/jsx-runtime").JSX.Element;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=SortModal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SortModal.d.ts","sourceRoot":"","sources":["../../../src/components/ReportBuilder/SortModal.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EACL,oBAAoB,EACpB,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,iBAAiB,CAAC;AAGzB,UAAU,kBAAkB;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE;QACP,IAAI,EAAE,MAAM,CAAC;KACd,EAAE,CAAC;CACL;AAED,UAAU,cAAc;IACtB,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,YAAY,EACR;QACE,KAAK,EAAE,GAAG,CAAC;QACX,KAAK,EAAE,GAAG,CAAC;KACZ,EAAE,GACH,SAAS,CAAC;IACd,KAAK,EAAE,GAAG,EAAE,CAAC;IACb,QAAQ,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;IACjC,cAAc,EAAE,CAAC,KAAK,EAAE,UAAU,KAAK,GAAG,CAAC,OAAO,CAAC;IACnD,eAAe,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,GAAG,CAAC,OAAO,CAAC;IAC9D,cAAc,EAAE,CAAC,KAAK,EAAE,mBAAmB,KAAK,GAAG,CAAC,OAAO,CAAC;IAC5D,eAAe,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,GAAG,CAAC,OAAO,CAAC;IAC9D,MAAM,EAAE,OAAO,CAAC;IAChB,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;IACrC,KAAK,EAAE,GAAG,CAAC;CACZ;AAED,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,EAChC,kBAAkB,EAClB,KAAK,EACL,YAAY,EACZ,QAAQ,EACR,eAAe,EACf,cAAc,EACd,eAAe,EACf,SAAS,EACT,MAAM,EACN,KAAK,GACN,EAAE,cAAc,2CAkEhB"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
3
|
+
export default function SortModal({ columnSelectorInfo, sorts, pivotColumns, setSorts, SelectComponent, ModalComponent, ButtonComponent, setIsOpen, isOpen, theme, }) {
|
|
4
|
+
const [sortDirection, setSortDirection] = useState('');
|
|
5
|
+
const [selectedColumn, setSelectedColumn] = useState('');
|
|
6
|
+
const [sortableColumns, setSortableColumns] = useState([]);
|
|
7
|
+
useEffect(() => {
|
|
8
|
+
if (sorts.length > 0) {
|
|
9
|
+
setSortDirection(sorts[0].order);
|
|
10
|
+
setSelectedColumn(sorts[0].column);
|
|
11
|
+
}
|
|
12
|
+
}, [sorts]);
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
if (pivotColumns) {
|
|
15
|
+
const columns = pivotColumns.map((pivotColumn) => ({
|
|
16
|
+
column: pivotColumn.field,
|
|
17
|
+
}));
|
|
18
|
+
setSortableColumns(columns);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
const columns = columnSelectorInfo.columns.map((column) => ({
|
|
22
|
+
column: column.name,
|
|
23
|
+
}));
|
|
24
|
+
setSortableColumns(columns);
|
|
25
|
+
}
|
|
26
|
+
}, [pivotColumns, columnSelectorInfo]);
|
|
27
|
+
const updateSorts = () => {
|
|
28
|
+
setSorts([{ column: selectedColumn, order: sortDirection }]);
|
|
29
|
+
};
|
|
30
|
+
return (_jsx(ModalComponent, { theme: theme, title: "Filters", isOpen: isOpen, onClose: () => setIsOpen(false), setIsOpen: setIsOpen, children: _jsxs("div", { style: { padding: 20 }, children: [_jsx("h1", { children: "Sort Modal" }), _jsx(SelectComponent, { options: [
|
|
31
|
+
{ label: 'Select', value: '' },
|
|
32
|
+
...sortableColumns.map((column) => ({
|
|
33
|
+
label: column.column,
|
|
34
|
+
value: column.column,
|
|
35
|
+
})),
|
|
36
|
+
], onChange: setSelectedColumn, value: selectedColumn }), _jsx(SelectComponent, { options: [
|
|
37
|
+
{ label: 'Select', value: '' },
|
|
38
|
+
{ label: 'Ascending', value: 'asc' },
|
|
39
|
+
{ label: 'Descending', value: 'desc' },
|
|
40
|
+
], onChange: setSortDirection, value: sortDirection }), _jsx(ButtonComponent, { onClick: updateSorts, label: "Sort" })] }) }));
|
|
41
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SortModal.js","sourceRoot":"","sources":["../../../src/components/ReportBuilder/SortModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
7
|
-
const react_1 = __importDefault(require("@monaco-editor/react"));
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import MonacoEditor from '@monaco-editor/react';
|
|
8
3
|
function defineEditorTheme(monaco) {
|
|
9
4
|
monaco.editor.defineTheme('onedark', {
|
|
10
5
|
base: 'vs',
|
|
@@ -30,8 +25,8 @@ function setEditorTheme(editor, monaco) {
|
|
|
30
25
|
console.log('ERROR: ', e);
|
|
31
26
|
}
|
|
32
27
|
}
|
|
33
|
-
function SqlTextEditor({ containerStyle, value, setValue, }) {
|
|
34
|
-
return ((
|
|
28
|
+
export default function SqlTextEditor({ containerStyle, value, setValue, }) {
|
|
29
|
+
return (_jsx("div", { style: { ...containerStyle }, children: _jsx(MonacoEditor, { height: "224px", defaultLanguage: "pgsql", defaultValue: "", value: value, loading: _jsx("div", {}), options: {
|
|
35
30
|
wordWrap: 'on',
|
|
36
31
|
minimap: {
|
|
37
32
|
enabled: false,
|
|
@@ -41,5 +36,3 @@ function SqlTextEditor({ containerStyle, value, setValue, }) {
|
|
|
41
36
|
setValue(query);
|
|
42
37
|
}, beforeMount: (monaco) => defineEditorTheme(monaco), onMount: setEditorTheme }) }));
|
|
43
38
|
}
|
|
44
|
-
exports.default = SqlTextEditor;
|
|
45
|
-
//# sourceMappingURL=SqlTextEditor.js.map
|