@quillsql/react 2.11.2 → 2.11.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  /**
3
2
  * Quill Report Builder
4
3
  *
@@ -7,35 +6,29 @@
7
6
  * they can click a button and add that report to their dashboard or export it
8
7
  * as a CSV.
9
8
  */
10
- export default function ReportBuilder({ path, initialTableName, onAddToDashboardComplete, destinationDashboard, dashboardItem, organizationName, Button, SecondaryButton, TextInput, Select, Table, Popover, Tabs, Checkbox, Sidebar, Container, HandleButton, SelectColumn, DraggableColumn, ButtonLoadingState, TableLoadingState, SidebarHeading, SidebarSubHeading, FilterPopover, }: {
11
- path?: string | undefined;
12
- initialTableName?: string | undefined;
13
- onAddToDashboardComplete?: (() => undefined) | undefined;
14
- destinationDashboard?: undefined;
15
- dashboardItem?: undefined;
16
- organizationName?: string | undefined;
17
- Button?: (({ children, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
18
- SecondaryButton?: (({ children, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
19
- TextInput?: ((props: any) => import("react/jsx-runtime").JSX.Element) | undefined;
20
- Select?: (({ onChange, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
21
- Table?: (({ rows, columns, error, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
22
- Popover?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
23
- Tabs?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
24
- Checkbox?: (({ checked, onChange, style, ...props }: {
25
- [x: string]: any;
26
- checked: any;
27
- onChange: any;
28
- style?: {} | undefined;
29
- }) => import("react/jsx-runtime").JSX.Element) | undefined;
30
- Sidebar?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
31
- Container?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
32
- HandleButton?: (() => import("react/jsx-runtime").JSX.Element) | undefined;
33
- SelectColumn?: (({ label, selected, setSelected, children, }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
34
- DraggableColumn?: (({ label, children, onDelete }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
35
- ButtonLoadingState?: (() => import("react/jsx-runtime").JSX.Element) | undefined;
36
- TableLoadingState?: (() => import("react/jsx-runtime").JSX.Element) | undefined;
37
- SidebarHeading?: (({ label }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
38
- SidebarSubHeading?: (({ label }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
39
- FilterPopover?: (({ filterLabel, onClickDeleteFilter, popoverTitle, popoverChildren, isOpen, setIsOpen, }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
9
+ export default function ReportBuilder({ initialTableName, onAddToDashboardComplete, destinationDashboard, organizationName, Button, SecondaryButton, TextInput, Select, Table, Popover, Tabs, Checkbox, Sidebar, Container, HandleButton, SelectColumn, DraggableColumn, ButtonLoadingState, TableLoadingState, SidebarHeading, SidebarSubHeading, FilterPopover, admin, }: {
10
+ initialTableName: string;
11
+ onAddToDashboardComplete: () => void;
12
+ destinationDashboard?: string;
13
+ organizationName?: string;
14
+ Button?: any;
15
+ SecondaryButton?: any;
16
+ TextInput?: any;
17
+ Select?: any;
18
+ Table?: any;
19
+ Popover?: any;
20
+ Tabs?: any;
21
+ Checkbox?: any;
22
+ Sidebar?: any;
23
+ Container?: any;
24
+ HandleButton?: any;
25
+ SelectColumn?: any;
26
+ DraggableColumn?: any;
27
+ ButtonLoadingState?: any;
28
+ TableLoadingState?: any;
29
+ SidebarHeading?: any;
30
+ SidebarSubHeading?: any;
31
+ FilterPopover?: any;
32
+ admin?: boolean;
40
33
  }): import("react/jsx-runtime").JSX.Element;
41
34
  //# sourceMappingURL=ReportBuilder.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ReportBuilder.d.ts","sourceRoot":"","sources":["../../src/ReportBuilder.tsx"],"names":[],"mappings":";AAwGA;;;;;;;GAOG;AACH,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EACpC,IAAS,EACT,gBAAiC,EACjC,wBAA0C,EAC1C,oBAAgC,EAChC,aAAyB,EACzB,gBAAqB,EACrB,MAAoB,EACpB,eAAsC,EACtC,SAA0B,EAC1B,MAAoB,EACpB,KAA+B,EAC/B,OAAsB,EACtB,IAAgB,EAChB,QAA2B,EAC3B,OAAsB,EACtB,SAA2B,EAC3B,YAAgC,EAChC,YAAgC,EAChC,eAAsC,EACtC,kBAA4C,EAC5C,iBAA0C,EAC1C,cAAoC,EACpC,iBAA0C,EAC1C,aAAkC,GACnC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAA,2CAwhGA"}
1
+ {"version":3,"file":"ReportBuilder.d.ts","sourceRoot":"","sources":["../../src/ReportBuilder.tsx"],"names":[],"mappings":"AAwGA;;;;;;;GAOG;AACH,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EACpC,gBAAqB,EACrB,wBAA0C,EAC1C,oBAAgC,EAChC,gBAAqB,EACrB,MAAoB,EACpB,eAAsC,EACtC,SAA0B,EAC1B,MAAoB,EACpB,KAA+B,EAC/B,OAAsB,EACtB,IAAgB,EAChB,QAA2B,EAC3B,OAAsB,EACtB,SAA2B,EAC3B,YAAgC,EAChC,YAAgC,EAChC,eAAsC,EACtC,kBAA4C,EAC5C,iBAA0C,EAC1C,cAAoC,EACpC,iBAA0C,EAC1C,aAAkC,EAClC,KAAa,GACd,EAAE;IACD,gBAAgB,EAAE,MAAM,CAAC;IACzB,wBAAwB,EAAE,MAAM,IAAI,CAAC;IACrC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,MAAM,CAAC,EAAE,GAAG,CAAC;IACb,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,SAAS,CAAC,EAAE,GAAG,CAAC;IAChB,MAAM,CAAC,EAAE,GAAG,CAAC;IACb,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,IAAI,CAAC,EAAE,GAAG,CAAC;IACX,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,SAAS,CAAC,EAAE,GAAG,CAAC;IAChB,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,kBAAkB,CAAC,EAAE,GAAG,CAAC;IACzB,iBAAiB,CAAC,EAAE,GAAG,CAAC;IACxB,cAAc,CAAC,EAAE,GAAG,CAAC;IACrB,iBAAiB,CAAC,EAAE,GAAG,CAAC;IACxB,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,2CAuhGA"}
@@ -29,7 +29,7 @@ const AddColumnPopover_1 = __importDefault(require("./components/ReportBuilder/A
29
29
  * they can click a button and add that report to their dashboard or export it
30
30
  * as a CSV.
31
31
  */
32
- function ReportBuilder({ path = '', initialTableName = 'transactions', onAddToDashboardComplete = () => void null, destinationDashboard = undefined, dashboardItem = undefined, organizationName = '', Button = ui_1.QuillButton, SecondaryButton = ui_1.QuillSecondaryButton, TextInput = ui_1.QuillTextInput, Select = ui_1.QuillSelect, Table = ui_1.QuillReportBuilderTable, Popover = ui_1.QuillPopover, Tabs = ui_1.QuillTabs, Checkbox = UiComponents_1.MemoizedCheckbox, Sidebar = ui_1.QuillSidebar, Container = ui_1.CustomContainer, HandleButton = ui_1.QuillHandleButton, SelectColumn = ui_1.QuillSelectColumn, DraggableColumn = ui_1.QuillDraggableColumn, ButtonLoadingState = ui_1.QuillButtonLoadingState, TableLoadingState = ui_1.QuillTableLoadingState, SidebarHeading = ui_1.QuillSidebarHeading, SidebarSubHeading = ui_1.QuillSidebarSubHeading, FilterPopover = ui_1.QuillFilterPopover, }) {
32
+ function ReportBuilder({ initialTableName = '', onAddToDashboardComplete = () => void null, destinationDashboard = undefined, organizationName = '', Button = ui_1.QuillButton, SecondaryButton = ui_1.QuillSecondaryButton, TextInput = ui_1.QuillTextInput, Select = ui_1.QuillSelect, Table = ui_1.QuillReportBuilderTable, Popover = ui_1.QuillPopover, Tabs = ui_1.QuillTabs, Checkbox = UiComponents_1.MemoizedCheckbox, Sidebar = ui_1.QuillSidebar, Container = ui_1.CustomContainer, HandleButton = ui_1.QuillHandleButton, SelectColumn = ui_1.QuillSelectColumn, DraggableColumn = ui_1.QuillDraggableColumn, ButtonLoadingState = ui_1.QuillButtonLoadingState, TableLoadingState = ui_1.QuillTableLoadingState, SidebarHeading = ui_1.QuillSidebarHeading, SidebarSubHeading = ui_1.QuillSidebarSubHeading, FilterPopover = ui_1.QuillFilterPopover, admin = false, }) {
33
33
  const [aiPrompt, setAiPrompt] = (0, react_1.useState)('');
34
34
  const [errorMessage, setErrorMessage] = (0, react_1.useState)('');
35
35
  const [baseAst, setBaseAst] = (0, react_1.useState)(null);
@@ -611,11 +611,11 @@ function ReportBuilder({ path = '', initialTableName = 'transactions', onAddToDa
611
611
  };
612
612
  // Function to handle the deletion of expressions
613
613
  const handleDelete = (key) => {
614
- updateFormData([{ path: path + key, value: null }], { isDeletion: true });
614
+ updateFormData([{ path: key, value: null }], { isDeletion: true });
615
615
  };
616
616
  // Function to handle the insertion of expressions
617
617
  const handleInsertion = (value, op = 'OR', isCondition = undefined) => {
618
- updateFormData([{ path, value }], {
618
+ updateFormData([{ path: '', value }], {
619
619
  isInsertion: true,
620
620
  topLevelBinOp: op,
621
621
  isCondition,
@@ -625,13 +625,13 @@ function ReportBuilder({ path = '', initialTableName = 'transactions', onAddToDa
625
625
  const handleInsertVariant = (key, name = null) => {
626
626
  // note: if name, treat that as the name of the value to insert
627
627
  const callback = isPending ? updateActiveItem : updateFormData;
628
- callback([{ path: path + key, value: name }], { isAddVariant: true });
628
+ callback([{ path: key, value: name }], { isAddVariant: true });
629
629
  };
630
630
  // Function to handle the insertion of expr_list variants
631
631
  const handleDeleteVariant = (key, name = null) => {
632
632
  // note: if name, treat that as the name of the valeu to delete
633
633
  const callback = isPending ? updateActiveItem : updateFormData;
634
- callback([{ path: path + key, value: name }], { isDeleteVariant: true });
634
+ callback([{ path: key, value: name }], { isDeleteVariant: true });
635
635
  };
636
636
  const getColumnValueForColumnComparison = (node) => node.left.value ??
637
637
  node.left.column ??
@@ -2126,6 +2126,6 @@ function ReportBuilder({ path = '', initialTableName = 'transactions', onAddToDa
2126
2126
  whiteSpace: 'nowrap',
2127
2127
  }, children: errorMessage })), (0, jsx_runtime_1.jsx)("div", { style: { width: '100%' } }), (0, jsx_runtime_1.jsx)(SecondaryButton, { type: "button", onClick: () => copyToClipboard(activeQuery), children: isCopying ? '✅ Copied' : 'Copy SQL' }), (0, jsx_runtime_1.jsx)(Button, { onClick: () => {
2128
2128
  setIsChartBuilderOpen(true);
2129
- }, children: "Add to dashboard" })] })] }))] }), (0, jsx_runtime_1.jsx)("style", { children: `body{margin:0;}` }), (0, jsx_runtime_1.jsx)(ChartBuilder_1.default, { rows: applyFormatting({ rows, fields }, baseAst?.columns ?? []), columns: processColumnsForChartBuilder(Object.keys(rows[0] ?? {})), fields: fields, pivot: pivot, query: activeQuery, showTableFormatOptions: true, showDateFieldOptions: true, showAccessControlOptions: true, title: "Add to dashboard", isEditMode: false, isOpen: isChartBuilderOpen, setIsOpen: setIsChartBuilderOpen, onAddToDashboardComplete: onAddToDashboardComplete, destinationDashboard: destinationDashboard, dashboardItem: dashboardItem, organizationName: organizationName })] }));
2129
+ }, children: "Add to dashboard" })] })] }))] }), (0, jsx_runtime_1.jsx)("style", { children: `body{margin:0;}` }), (0, jsx_runtime_1.jsx)(ChartBuilder_1.default, { rows: applyFormatting({ rows, fields }, baseAst?.columns ?? []), columns: processColumnsForChartBuilder(Object.keys(rows[0] ?? {})), fields: fields, pivot: pivot, query: activeQuery, showTableFormatOptions: admin ? true : false, showDateFieldOptions: admin ? true : false, showAccessControlOptions: admin ? true : false, title: "Add to dashboard", isEditMode: false, isOpen: isChartBuilderOpen, setIsOpen: setIsChartBuilderOpen, onAddToDashboardComplete: onAddToDashboardComplete, destinationDashboard: destinationDashboard, organizationName: organizationName })] }));
2130
2130
  }
2131
2131
  exports.default = ReportBuilder;
@@ -1 +1 @@
1
- {"version":3,"file":"AddColumnPopover.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/AddColumnPopover.tsx"],"names":[],"mappings":"AAkBA,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,MAAM,EACN,kBAAkB,EAClB,qBAAqB,EACrB,eAAe,EACf,kBAAkB,EAClB,oBAAoB,EACpB,aAAa,EACb,YAAY,EACZ,OAAO,EACP,UAAU,EACV,KAAK,EACL,gBAAgB,EAChB,UAAU,EACV,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,eAAe,EACf,MAAM,EACN,YAAY,GACb,EAAE,GAAG,2CA4LL"}
1
+ {"version":3,"file":"AddColumnPopover.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/AddColumnPopover.tsx"],"names":[],"mappings":"AAoBA,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,MAAM,EACN,kBAAkB,EAClB,qBAAqB,EACrB,eAAe,EACf,kBAAkB,EAClB,oBAAoB,EACpB,aAAa,EACb,YAAY,EACZ,OAAO,EACP,UAAU,EACV,KAAK,EACL,gBAAgB,EAChB,UAAU,EACV,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,eAAe,EACf,MAAM,EACN,YAAY,GACb,EAAE,GAAG,2CAiML"}
@@ -5,7 +5,9 @@ const react_1 = require("react");
5
5
  const core_1 = require("@dnd-kit/core");
6
6
  const sortable_1 = require("@dnd-kit/sortable");
7
7
  const utilities_1 = require("@dnd-kit/utilities");
8
+ const Context_1 = require("../../Context");
8
9
  function AddColumnPopover({ onSave, orderedColumnNames, setOrderedColumnNames, selectedColumns, setSelectedColumns, isSelectedAllColumns, clearAllState, nameToColumn, baseAst, setBaseAst, pivot, initialTableName, defaultAST, defaultTable, setPivot, TextInput, SelectColumn, SecondaryButton, Button, HandleButton, }) {
10
+ const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
9
11
  const [search, setSearch] = (0, react_1.useState)('');
10
12
  const sensors = (0, core_1.useSensors)((0, core_1.useSensor)(core_1.PointerSensor), (0, core_1.useSensor)(core_1.KeyboardSensor, {
11
13
  coordinateGetter: sortable_1.sortableKeyboardCoordinates,
@@ -52,8 +54,8 @@ function AddColumnPopover({ onSave, orderedColumnNames, setOrderedColumnNames, s
52
54
  overflowY: 'auto',
53
55
  maxWidth: '300px',
54
56
  }, children: [searchResults.map((value) => {
55
- return ((0, jsx_runtime_1.jsx)(SortableItem, { selectedColumns: selectedColumns, setSelectedColumns: setSelectedColumns, id: value, label: value.replace('.', ' '), SelectColumn: SelectColumn, HandleButton: HandleButton }, value));
56
- }), search.length > 0 && searchResults.length === 0 && ((0, jsx_runtime_1.jsx)("div", { children: "No results found" }))] }) }) }), (0, jsx_runtime_1.jsxs)("div", { style: {
57
+ return ((0, jsx_runtime_1.jsx)(SortableItem, { theme: theme, selectedColumns: selectedColumns, setSelectedColumns: setSelectedColumns, id: value, label: value.replace('.', ' '), SelectColumn: SelectColumn, HandleButton: HandleButton }, value));
58
+ }), search.length > 0 && searchResults.length === 0 && ((0, jsx_runtime_1.jsx)("div", { style: { fontFamily: theme?.fontFamily }, children: "No results found" }))] }) }) }), (0, jsx_runtime_1.jsxs)("div", { style: {
57
59
  display: 'flex',
58
60
  width: '100%',
59
61
  flexDirection: 'row',
@@ -106,7 +108,7 @@ function AddColumnPopover({ onSave, orderedColumnNames, setOrderedColumnNames, s
106
108
  }, children: "Save" })] })] }));
107
109
  }
108
110
  exports.default = AddColumnPopover;
109
- const SortableItem = ({ id, label, setSelectedColumns, selectedColumns, SelectColumn, HandleButton, }) => {
111
+ const SortableItem = ({ id, label, setSelectedColumns, theme, selectedColumns, SelectColumn, HandleButton, }) => {
110
112
  const { attributes, listeners, setNodeRef, transform, transition } = (0, sortable_1.useSortable)({ id: id });
111
113
  const style = {
112
114
  transform: utilities_1.CSS.Transform.toString(transform),
@@ -1 +1 @@
1
- {"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/ui.tsx"],"names":[],"mappings":";AAeA;;;;;GAKG;AAEH,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CA2BtD,CAAC;AAEF,eAAO,MAAM,oBAAoB,2BAA4B,GAAG,4CA2B/D,CAAC;AAEF,eAAO,MAAM,cAAc,UAAW,GAAG,4CAuBxC,CAAC;AAEF,eAAO,MAAM,uBAAuB,uCAKjC,GAAG,4CAiBL,CAAC;AAEF,eAAO,MAAM,QAAQ,sGA2DpB,CAAC;AAGF,eAAO,MAAM,mBAAmB,cAAe,GAAG,4CAEjD,CAAC;AAGF,eAAO,MAAM,sBAAsB,cAAe,GAAG,4CAEpD,CAAC;AAGF,eAAO,MAAM,YAAY,sGAgBxB,CAAC;AAGF,eAAO,MAAM,eAAe,sGAsB3B,CAAC;AAEF,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CAUtD,CAAC;AAEF,wBAAgB,eAAe,CAAC,EAC9B,OAAO,EACP,QAAQ,EACR,KAAU,EACV,OAAO,EACP,MAAM,GACP,EAAE,GAAG,2CA6CL;AAED,eAAO,MAAM,YAAY,sGA8BxB,CAAC;AAGF,eAAO,MAAM,iBAAiB,+CAsE7B,CAAC;AAEF,eAAO,MAAM,iBAAiB,gDAK3B,GAAG,4CAyCL,CAAC;AAGF,eAAO,MAAM,oBAAoB,kCAAmC,GAAG,4CAuCtE,CAAC;AAGF,eAAO,MAAM,uBAAuB,+CAEnC,CAAC;AAGF,eAAO,MAAM,sBAAsB,+CAMlC,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;GAG/B,CAAC;AAEF,eAAO,MAAM,SAAS,sGAIrB,CAAC;AAEF,eAAO,MAAM,WAAW,8DAMrB,GAAG,4CAwBL,CAAC;AAEF,eAAO,MAAM,kBAAkB,4FAO5B,GAAG,4CAqBL,CAAC;AAEF,eAAO,MAAM,UAAU,sTAuBpB,GAAG,4CAqFL,CAAC;AAEF,eAAO,MAAM,gBAAgB,oDAK1B,GAAG,4CAeL,CAAC"}
1
+ {"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/ui.tsx"],"names":[],"mappings":";AAeA;;;;;GAKG;AAEH,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CA2BtD,CAAC;AAEF,eAAO,MAAM,oBAAoB,2BAA4B,GAAG,4CA2B/D,CAAC;AAEF,eAAO,MAAM,cAAc,UAAW,GAAG,4CAuBxC,CAAC;AAEF,eAAO,MAAM,uBAAuB,uCAKjC,GAAG,4CAiBL,CAAC;AAEF,eAAO,MAAM,QAAQ,sGAoEpB,CAAC;AAGF,eAAO,MAAM,mBAAmB,cAAe,GAAG,4CAEjD,CAAC;AAGF,eAAO,MAAM,sBAAsB,cAAe,GAAG,4CAEpD,CAAC;AAGF,eAAO,MAAM,YAAY,sGAgBxB,CAAC;AAGF,eAAO,MAAM,eAAe,sGAsB3B,CAAC;AAEF,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CAUtD,CAAC;AAEF,wBAAgB,eAAe,CAAC,EAC9B,OAAO,EACP,QAAQ,EACR,KAAU,EACV,OAAO,EACP,MAAM,GACP,EAAE,GAAG,2CAiDL;AAED,eAAO,MAAM,YAAY,sGAkCxB,CAAC;AAGF,eAAO,MAAM,iBAAiB,+CAwE7B,CAAC;AAEF,eAAO,MAAM,iBAAiB,gDAK3B,GAAG,4CA6CL,CAAC;AAGF,eAAO,MAAM,oBAAoB,kCAAmC,GAAG,4CAkDtE,CAAC;AAGF,eAAO,MAAM,uBAAuB,+CAEnC,CAAC;AAGF,eAAO,MAAM,sBAAsB,+CAMlC,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;GAG/B,CAAC;AAEF,eAAO,MAAM,SAAS,sGAIrB,CAAC;AAEF,eAAO,MAAM,WAAW,8DAMrB,GAAG,4CAwBL,CAAC;AAEF,eAAO,MAAM,kBAAkB,4FAO5B,GAAG,4CAqBL,CAAC;AAEF,eAAO,MAAM,UAAU,sTAuBpB,GAAG,4CAqFL,CAAC;AAEF,eAAO,MAAM,gBAAgB,oDAK1B,GAAG,4CAeL,CAAC"}
@@ -94,7 +94,8 @@ exports.QuillTag = (0, react_1.forwardRef)(({ label, onClick, children, onClickD
94
94
  width: '100%',
95
95
  padding: '4px 8px',
96
96
  alignItems: 'center',
97
- backgroundColor: 'white',
97
+ backgroundColor: theme?.backgroundColor || 'white',
98
+ fontFamily: theme?.fontFamily,
98
99
  fontSize: 14,
99
100
  }, ref: forwardedRef, onClick: onClick, children: [label ?? children, !hideDelete && ((0, jsx_runtime_1.jsx)("div", { style: {
100
101
  marginLeft: 'auto',
@@ -102,7 +103,12 @@ exports.QuillTag = (0, react_1.forwardRef)(({ label, onClick, children, onClickD
102
103
  display: 'flex',
103
104
  flexDirection: 'column',
104
105
  justifyContent: 'center',
105
- }, children: (0, jsx_runtime_1.jsx)("button", { onClick: onClickDelete, style: { margin: -4 }, children: (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: (0, jsx_runtime_1.jsx)("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) }) }))] }));
106
+ }, children: (0, jsx_runtime_1.jsx)("button", { onClick: onClickDelete, style: {
107
+ margin: -4,
108
+ border: 'none',
109
+ backgroundColor: theme?.backgroundColor || 'white',
110
+ fontFamily: theme?.fontFamily,
111
+ }, children: (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: (0, jsx_runtime_1.jsx)("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) }) }))] }));
106
112
  });
107
113
  // A heading element in the sidebar (eg. "Filters")
108
114
  const QuillSidebarHeading = ({ label }) => ((0, jsx_runtime_1.jsx)(UiComponents_1.MemoizedHeader, { children: label }));
@@ -146,6 +152,7 @@ const QuillSelect = ({ onChange, ...props }) => {
146
152
  exports.QuillSelect = QuillSelect;
147
153
  function MemoizedPopover({ onClose, children, style = {}, trigger, isOpen, }) {
148
154
  const modalRef = (0, react_1.useRef)(null);
155
+ const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
149
156
  (0, react_1.useEffect)(() => {
150
157
  const listener = (event) => {
151
158
  if (modalRef?.current && !modalRef?.current?.contains(event.target)) {
@@ -158,10 +165,12 @@ function MemoizedPopover({ onClose, children, style = {}, trigger, isOpen, }) {
158
165
  };
159
166
  }, [modalRef, onClose]);
160
167
  return ((0, jsx_runtime_1.jsxs)("div", { children: [trigger, isOpen && ((0, jsx_runtime_1.jsx)("div", { id: "quill-popover-modal", ref: modalRef, style: { position: 'relative' }, children: (0, jsx_runtime_1.jsx)("div", { style: {
161
- background: 'white',
168
+ background: theme?.backgroundColor || 'white',
162
169
  position: 'absolute',
163
170
  boxShadow: '0px 1px 12px 0px rgba(56, 65, 81, 0.1)',
164
- border: '1px solid #e7e7e7',
171
+ border: theme
172
+ ? `${theme.borderWidth || 1}px solid ${theme.borderColor || '#e7e7e7'}`
173
+ : '1px solid #e7e7e7',
165
174
  boxSizing: 'content-box',
166
175
  zIndex: 999,
167
176
  top: 12,
@@ -173,16 +182,20 @@ function MemoizedPopover({ onClose, children, style = {}, trigger, isOpen, }) {
173
182
  }
174
183
  exports.MemoizedPopover = MemoizedPopover;
175
184
  exports.QuillPopover = (0, react_1.forwardRef)(({ children, trigger, isOpen, onClose = () => { }, title = undefined }, ref) => {
185
+ const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
176
186
  return ((0, jsx_runtime_1.jsxs)(MemoizedPopover, { isOpen: isOpen, onClose: onClose, trigger: trigger, parentRef: ref, ref: ref, children: [title && ((0, jsx_runtime_1.jsx)("h1", { style: {
177
187
  fontWeight: '600',
178
188
  fontSize: 18,
179
189
  margin: 0,
180
190
  textAlign: 'left',
181
191
  paddingBottom: 12,
192
+ color: theme?.primaryTextColor,
193
+ fontFamily: theme?.fontFamily,
182
194
  }, children: title })), children] }));
183
195
  });
184
196
  // The six-dot grab-handle icon.
185
197
  const QuillHandleButton = () => {
198
+ const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
186
199
  return ((0, jsx_runtime_1.jsxs)("div", { style: {
187
200
  display: 'flex',
188
201
  gap: 2,
@@ -226,6 +239,7 @@ const QuillHandleButton = () => {
226
239
  };
227
240
  exports.QuillHandleButton = QuillHandleButton;
228
241
  const QuillSelectColumn = ({ label, selected, setSelected, children, }) => {
242
+ const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
229
243
  return ((0, jsx_runtime_1.jsxs)("div", { title: label, style: {
230
244
  boxShadow: '0px 1px 4px #e2e8f005',
231
245
  paddingTop: 4,
@@ -235,7 +249,7 @@ const QuillSelectColumn = ({ label, selected, setSelected, children, }) => {
235
249
  borderRadius: 4,
236
250
  display: 'flex',
237
251
  alignItems: 'center',
238
- backgroundColor: 'white',
252
+ backgroundColor: theme?.backgroundColor || 'white',
239
253
  }, children: [(0, jsx_runtime_1.jsx)("div", { children: children }), (0, jsx_runtime_1.jsxs)("label", { style: {
240
254
  display: 'flex',
241
255
  gap: 2,
@@ -248,6 +262,8 @@ const QuillSelectColumn = ({ label, selected, setSelected, children, }) => {
248
262
  whiteSpace: 'nowrap',
249
263
  textOverflow: 'ellipsis',
250
264
  overflow: 'hidden',
265
+ fontFamily: theme?.fontFamily,
266
+ color: theme?.primaryTextColor,
251
267
  }, children: label })] })] }));
252
268
  };
253
269
  exports.QuillSelectColumn = QuillSelectColumn;
@@ -260,7 +276,7 @@ const QuillDraggableColumn = ({ label, children, onDelete }) => {
260
276
  borderRadius: 6,
261
277
  display: 'flex',
262
278
  alignItems: 'center',
263
- backgroundColor: 'white',
279
+ backgroundColor: theme?.backgroundColor || 'white',
264
280
  }, children: [(0, jsx_runtime_1.jsx)("div", { children: children }), (0, jsx_runtime_1.jsx)("div", { style: {
265
281
  marginLeft: 2,
266
282
  marginRight: 'auto',
@@ -268,7 +284,15 @@ const QuillDraggableColumn = ({ label, children, onDelete }) => {
268
284
  display: 'block',
269
285
  whiteSpace: 'nowrap',
270
286
  textOverflow: 'ellipsis',
271
- }, children: label }), (0, jsx_runtime_1.jsx)("button", { onClick: onDelete, style: { paddingRight: 8, margin: -4 }, children: (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: (0, jsx_runtime_1.jsx)("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) })] }));
287
+ fontFamily: theme?.fontFamily,
288
+ }, children: label }), (0, jsx_runtime_1.jsx)("button", { onClick: onDelete, style: {
289
+ paddingRight: 8,
290
+ margin: -4,
291
+ fontFamily: theme?.fontFamily,
292
+ backgroundColor: theme?.backgroundColor || 'white',
293
+ border: 'none',
294
+ outline: 'none',
295
+ }, children: (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: (0, jsx_runtime_1.jsx)("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) })] }));
272
296
  };
273
297
  exports.QuillDraggableColumn = QuillDraggableColumn;
274
298
  // Three dots animated bouncing
@@ -1 +1 @@
1
- {"version":3,"file":"UiComponents.d.ts","sourceRoot":"","sources":["../../../src/components/UiComponents.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"UiComponents.d.ts","sourceRoot":"","sources":["../../../src/components/UiComponents.tsx"],"names":[],"mappings":"AACA,OAAO,KAAwC,MAAM,OAAO,CAAC;AAK7D,MAAM,WAAW,MAAM;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,GAAG,CAAC;CACZ;AAED,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,OAAO,EAAE,GAAG,EAAE,CAAC;IACf,cAAc,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IACrC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,IAAI,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,GAAG,CAAC,OAAO,CAAC;IACrC,0BAA0B,CAAC,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,GAAG,CAAC,OAAO,CAAC;IAC1E,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,GAAG,CAAC;IACd,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;IACrC,KAAK,CAAC,EAAE,GAAG,CAAC;CACb;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,GAAG,CAAC;CACf;AAED,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,GAAG,CAAC;CACf;AAED,MAAM,WAAW,SAAS;IACxB,QAAQ,EAAE,GAAG,CAAC;CACf;AAED,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,KAAK,EAAE,GAAG,CAAC;CACZ;AAED,eAAO,MAAM,cAAc,iDAMxB,uBAAuB,4CA0BzB,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;;;6CAgC7B,CAAC;AAEF,eAAO,MAAM,cAAc;;;;6CAgC1B,CAAC;AAEF,eAAO,MAAM,uBAAuB;;;6CA6BnC,CAAC;AAEF,eAAO,MAAM,cAAc;;;;;;6CAqE1B,CAAC;AAEF,eAAO,MAAM,cAAc;;6CAkB1B,CAAC;AAEF,eAAO,MAAM,aAAa;;6CAazB,CAAC;AAEF,eAAO,MAAM,gBAAgB;;;;;6CAa5B,CAAC;AAEF,eAAO,MAAM,YAAY;;;;6CAgDxB,CAAC;AAEF,eAAO,MAAM,YAAY;;6CAYxB,CAAC;AAsBF,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,GAAG,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,CAAC,EAAE,GAAG,CAAC;IAChB,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;CACtC;AAED,wBAAgB,eAAe,CAAC,EAC9B,OAAO,EACP,SAAS,EACT,QAAQ,EACR,KAAU,EACV,OAAO,EACP,WAAkB,EAClB,MAAM,EACN,KAAK,EACL,SAAS,GACV,EAAE,qBAAqB,2CA2DvB;AAED,wBAAgB,aAAa,CAAC,EAC5B,MAAM,EACN,OAAO,EACP,SAAS,EACT,KAAK,EACL,QAAQ,EACR,KAAK,GACN;;;;;;;CAAA,kDA2FA;AAED,eAAO,MAAM,oBAAoB;;;6CA0BhC,CAAC;AAEF,eAAO,MAAM,cAAc,+CAwD1B,CAAC"}
@@ -127,19 +127,24 @@ const MemoizedSelect = ({ value, onChange, options, disabled = false, style = {}
127
127
  }, "aria-hidden": "true" })] }));
128
128
  };
129
129
  exports.MemoizedSelect = MemoizedSelect;
130
- const MemoizedHeader = ({ children }) => ((0, jsx_runtime_1.jsx)("h1", { style: {
131
- fontSize: 16,
132
- fontWeight: 600,
133
- color: '#384151',
134
- userSelect: 'none',
135
- margin: 0,
136
- padding: 0,
137
- }, children: children }));
130
+ const MemoizedHeader = ({ children }) => {
131
+ const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
132
+ return ((0, jsx_runtime_1.jsx)("h1", { style: {
133
+ fontSize: 16,
134
+ fontWeight: 600,
135
+ fontFamily: theme?.fontFamily,
136
+ color: theme?.primaryTextColor || '#384151',
137
+ userSelect: 'none',
138
+ margin: 0,
139
+ padding: 0,
140
+ }, children: children }));
141
+ };
138
142
  exports.MemoizedHeader = MemoizedHeader;
139
143
  const MemoizedLabel = ({ children }) => ((0, jsx_runtime_1.jsx)("h1", { style: {
140
144
  fontSize: 14,
141
145
  fontWeight: 600,
142
- color: '#575E6A',
146
+ fontFamily: theme?.fontFamily,
147
+ color: theme?.secondaryTextColor || '#575E6A',
143
148
  userSelect: 'none',
144
149
  paddingBottom: 5,
145
150
  }, children: children }));
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  /**
3
2
  * Quill Report Builder
4
3
  *
@@ -7,35 +6,29 @@
7
6
  * they can click a button and add that report to their dashboard or export it
8
7
  * as a CSV.
9
8
  */
10
- export default function ReportBuilder({ path, initialTableName, onAddToDashboardComplete, destinationDashboard, dashboardItem, organizationName, Button, SecondaryButton, TextInput, Select, Table, Popover, Tabs, Checkbox, Sidebar, Container, HandleButton, SelectColumn, DraggableColumn, ButtonLoadingState, TableLoadingState, SidebarHeading, SidebarSubHeading, FilterPopover, }: {
11
- path?: string | undefined;
12
- initialTableName?: string | undefined;
13
- onAddToDashboardComplete?: (() => undefined) | undefined;
14
- destinationDashboard?: undefined;
15
- dashboardItem?: undefined;
16
- organizationName?: string | undefined;
17
- Button?: (({ children, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
18
- SecondaryButton?: (({ children, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
19
- TextInput?: ((props: any) => import("react/jsx-runtime").JSX.Element) | undefined;
20
- Select?: (({ onChange, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
21
- Table?: (({ rows, columns, error, ...props }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
22
- Popover?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
23
- Tabs?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
24
- Checkbox?: (({ checked, onChange, style, ...props }: {
25
- [x: string]: any;
26
- checked: any;
27
- onChange: any;
28
- style?: {} | undefined;
29
- }) => import("react/jsx-runtime").JSX.Element) | undefined;
30
- Sidebar?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
31
- Container?: import("react").ForwardRefExoticComponent<Omit<any, "ref"> & import("react").RefAttributes<unknown>> | undefined;
32
- HandleButton?: (() => import("react/jsx-runtime").JSX.Element) | undefined;
33
- SelectColumn?: (({ label, selected, setSelected, children, }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
34
- DraggableColumn?: (({ label, children, onDelete }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
35
- ButtonLoadingState?: (() => import("react/jsx-runtime").JSX.Element) | undefined;
36
- TableLoadingState?: (() => import("react/jsx-runtime").JSX.Element) | undefined;
37
- SidebarHeading?: (({ label }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
38
- SidebarSubHeading?: (({ label }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
39
- FilterPopover?: (({ filterLabel, onClickDeleteFilter, popoverTitle, popoverChildren, isOpen, setIsOpen, }: any) => import("react/jsx-runtime").JSX.Element) | undefined;
9
+ export default function ReportBuilder({ initialTableName, onAddToDashboardComplete, destinationDashboard, organizationName, Button, SecondaryButton, TextInput, Select, Table, Popover, Tabs, Checkbox, Sidebar, Container, HandleButton, SelectColumn, DraggableColumn, ButtonLoadingState, TableLoadingState, SidebarHeading, SidebarSubHeading, FilterPopover, admin, }: {
10
+ initialTableName: string;
11
+ onAddToDashboardComplete: () => void;
12
+ destinationDashboard?: string;
13
+ organizationName?: string;
14
+ Button?: any;
15
+ SecondaryButton?: any;
16
+ TextInput?: any;
17
+ Select?: any;
18
+ Table?: any;
19
+ Popover?: any;
20
+ Tabs?: any;
21
+ Checkbox?: any;
22
+ Sidebar?: any;
23
+ Container?: any;
24
+ HandleButton?: any;
25
+ SelectColumn?: any;
26
+ DraggableColumn?: any;
27
+ ButtonLoadingState?: any;
28
+ TableLoadingState?: any;
29
+ SidebarHeading?: any;
30
+ SidebarSubHeading?: any;
31
+ FilterPopover?: any;
32
+ admin?: boolean;
40
33
  }): import("react/jsx-runtime").JSX.Element;
41
34
  //# sourceMappingURL=ReportBuilder.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ReportBuilder.d.ts","sourceRoot":"","sources":["../../src/ReportBuilder.tsx"],"names":[],"mappings":";AAwGA;;;;;;;GAOG;AACH,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EACpC,IAAS,EACT,gBAAiC,EACjC,wBAA0C,EAC1C,oBAAgC,EAChC,aAAyB,EACzB,gBAAqB,EACrB,MAAoB,EACpB,eAAsC,EACtC,SAA0B,EAC1B,MAAoB,EACpB,KAA+B,EAC/B,OAAsB,EACtB,IAAgB,EAChB,QAA2B,EAC3B,OAAsB,EACtB,SAA2B,EAC3B,YAAgC,EAChC,YAAgC,EAChC,eAAsC,EACtC,kBAA4C,EAC5C,iBAA0C,EAC1C,cAAoC,EACpC,iBAA0C,EAC1C,aAAkC,GACnC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAA,2CAwhGA"}
1
+ {"version":3,"file":"ReportBuilder.d.ts","sourceRoot":"","sources":["../../src/ReportBuilder.tsx"],"names":[],"mappings":"AAwGA;;;;;;;GAOG;AACH,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EACpC,gBAAqB,EACrB,wBAA0C,EAC1C,oBAAgC,EAChC,gBAAqB,EACrB,MAAoB,EACpB,eAAsC,EACtC,SAA0B,EAC1B,MAAoB,EACpB,KAA+B,EAC/B,OAAsB,EACtB,IAAgB,EAChB,QAA2B,EAC3B,OAAsB,EACtB,SAA2B,EAC3B,YAAgC,EAChC,YAAgC,EAChC,eAAsC,EACtC,kBAA4C,EAC5C,iBAA0C,EAC1C,cAAoC,EACpC,iBAA0C,EAC1C,aAAkC,EAClC,KAAa,GACd,EAAE;IACD,gBAAgB,EAAE,MAAM,CAAC;IACzB,wBAAwB,EAAE,MAAM,IAAI,CAAC;IACrC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,MAAM,CAAC,EAAE,GAAG,CAAC;IACb,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,SAAS,CAAC,EAAE,GAAG,CAAC;IAChB,MAAM,CAAC,EAAE,GAAG,CAAC;IACb,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,IAAI,CAAC,EAAE,GAAG,CAAC;IACX,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,SAAS,CAAC,EAAE,GAAG,CAAC;IAChB,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,kBAAkB,CAAC,EAAE,GAAG,CAAC;IACzB,iBAAiB,CAAC,EAAE,GAAG,CAAC;IACxB,cAAc,CAAC,EAAE,GAAG,CAAC;IACrB,iBAAiB,CAAC,EAAE,GAAG,CAAC;IACxB,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,2CAuhGA"}
@@ -24,7 +24,7 @@ import AddColumnPopover from './components/ReportBuilder/AddColumnPopover';
24
24
  * they can click a button and add that report to their dashboard or export it
25
25
  * as a CSV.
26
26
  */
27
- export default function ReportBuilder({ path = '', initialTableName = 'transactions', onAddToDashboardComplete = () => void null, destinationDashboard = undefined, dashboardItem = undefined, organizationName = '', Button = QuillButton, SecondaryButton = QuillSecondaryButton, TextInput = QuillTextInput, Select = QuillSelect, Table = QuillReportBuilderTable, Popover = QuillPopover, Tabs = QuillTabs, Checkbox = MemoizedCheckbox, Sidebar = QuillSidebar, Container = CustomContainer, HandleButton = QuillHandleButton, SelectColumn = QuillSelectColumn, DraggableColumn = QuillDraggableColumn, ButtonLoadingState = QuillButtonLoadingState, TableLoadingState = QuillTableLoadingState, SidebarHeading = QuillSidebarHeading, SidebarSubHeading = QuillSidebarSubHeading, FilterPopover = QuillFilterPopover, }) {
27
+ export default function ReportBuilder({ initialTableName = '', onAddToDashboardComplete = () => void null, destinationDashboard = undefined, organizationName = '', Button = QuillButton, SecondaryButton = QuillSecondaryButton, TextInput = QuillTextInput, Select = QuillSelect, Table = QuillReportBuilderTable, Popover = QuillPopover, Tabs = QuillTabs, Checkbox = MemoizedCheckbox, Sidebar = QuillSidebar, Container = CustomContainer, HandleButton = QuillHandleButton, SelectColumn = QuillSelectColumn, DraggableColumn = QuillDraggableColumn, ButtonLoadingState = QuillButtonLoadingState, TableLoadingState = QuillTableLoadingState, SidebarHeading = QuillSidebarHeading, SidebarSubHeading = QuillSidebarSubHeading, FilterPopover = QuillFilterPopover, admin = false, }) {
28
28
  const [aiPrompt, setAiPrompt] = useState('');
29
29
  const [errorMessage, setErrorMessage] = useState('');
30
30
  const [baseAst, setBaseAst] = useState(null);
@@ -606,11 +606,11 @@ export default function ReportBuilder({ path = '', initialTableName = 'transacti
606
606
  };
607
607
  // Function to handle the deletion of expressions
608
608
  const handleDelete = (key) => {
609
- updateFormData([{ path: path + key, value: null }], { isDeletion: true });
609
+ updateFormData([{ path: key, value: null }], { isDeletion: true });
610
610
  };
611
611
  // Function to handle the insertion of expressions
612
612
  const handleInsertion = (value, op = 'OR', isCondition = undefined) => {
613
- updateFormData([{ path, value }], {
613
+ updateFormData([{ path: '', value }], {
614
614
  isInsertion: true,
615
615
  topLevelBinOp: op,
616
616
  isCondition,
@@ -620,13 +620,13 @@ export default function ReportBuilder({ path = '', initialTableName = 'transacti
620
620
  const handleInsertVariant = (key, name = null) => {
621
621
  // note: if name, treat that as the name of the value to insert
622
622
  const callback = isPending ? updateActiveItem : updateFormData;
623
- callback([{ path: path + key, value: name }], { isAddVariant: true });
623
+ callback([{ path: key, value: name }], { isAddVariant: true });
624
624
  };
625
625
  // Function to handle the insertion of expr_list variants
626
626
  const handleDeleteVariant = (key, name = null) => {
627
627
  // note: if name, treat that as the name of the valeu to delete
628
628
  const callback = isPending ? updateActiveItem : updateFormData;
629
- callback([{ path: path + key, value: name }], { isDeleteVariant: true });
629
+ callback([{ path: key, value: name }], { isDeleteVariant: true });
630
630
  };
631
631
  const getColumnValueForColumnComparison = (node) => node.left.value ??
632
632
  node.left.column ??
@@ -2121,5 +2121,5 @@ export default function ReportBuilder({ path = '', initialTableName = 'transacti
2121
2121
  whiteSpace: 'nowrap',
2122
2122
  }, children: errorMessage })), _jsx("div", { style: { width: '100%' } }), _jsx(SecondaryButton, { type: "button", onClick: () => copyToClipboard(activeQuery), children: isCopying ? '✅ Copied' : 'Copy SQL' }), _jsx(Button, { onClick: () => {
2123
2123
  setIsChartBuilderOpen(true);
2124
- }, children: "Add to dashboard" })] })] }))] }), _jsx("style", { children: `body{margin:0;}` }), _jsx(ChartBuilder, { rows: applyFormatting({ rows, fields }, baseAst?.columns ?? []), columns: processColumnsForChartBuilder(Object.keys(rows[0] ?? {})), fields: fields, pivot: pivot, query: activeQuery, showTableFormatOptions: true, showDateFieldOptions: true, showAccessControlOptions: true, title: "Add to dashboard", isEditMode: false, isOpen: isChartBuilderOpen, setIsOpen: setIsChartBuilderOpen, onAddToDashboardComplete: onAddToDashboardComplete, destinationDashboard: destinationDashboard, dashboardItem: dashboardItem, organizationName: organizationName })] }));
2124
+ }, children: "Add to dashboard" })] })] }))] }), _jsx("style", { children: `body{margin:0;}` }), _jsx(ChartBuilder, { rows: applyFormatting({ rows, fields }, baseAst?.columns ?? []), columns: processColumnsForChartBuilder(Object.keys(rows[0] ?? {})), fields: fields, pivot: pivot, query: activeQuery, showTableFormatOptions: admin ? true : false, showDateFieldOptions: admin ? true : false, showAccessControlOptions: admin ? true : false, title: "Add to dashboard", isEditMode: false, isOpen: isChartBuilderOpen, setIsOpen: setIsChartBuilderOpen, onAddToDashboardComplete: onAddToDashboardComplete, destinationDashboard: destinationDashboard, organizationName: organizationName })] }));
2125
2125
  }
@@ -1 +1 @@
1
- {"version":3,"file":"AddColumnPopover.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/AddColumnPopover.tsx"],"names":[],"mappings":"AAkBA,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,MAAM,EACN,kBAAkB,EAClB,qBAAqB,EACrB,eAAe,EACf,kBAAkB,EAClB,oBAAoB,EACpB,aAAa,EACb,YAAY,EACZ,OAAO,EACP,UAAU,EACV,KAAK,EACL,gBAAgB,EAChB,UAAU,EACV,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,eAAe,EACf,MAAM,EACN,YAAY,GACb,EAAE,GAAG,2CA4LL"}
1
+ {"version":3,"file":"AddColumnPopover.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/AddColumnPopover.tsx"],"names":[],"mappings":"AAoBA,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,MAAM,EACN,kBAAkB,EAClB,qBAAqB,EACrB,eAAe,EACf,kBAAkB,EAClB,oBAAoB,EACpB,aAAa,EACb,YAAY,EACZ,OAAO,EACP,UAAU,EACV,KAAK,EACL,gBAAgB,EAChB,UAAU,EACV,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,eAAe,EACf,MAAM,EACN,YAAY,GACb,EAAE,GAAG,2CAiML"}
@@ -1,9 +1,11 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useState } from 'react';
2
+ import { useContext, useState } from 'react';
3
3
  import { DndContext, closestCenter, KeyboardSensor, PointerSensor, useSensor, useSensors, } from '@dnd-kit/core';
4
4
  import { arrayMove, SortableContext, sortableKeyboardCoordinates, verticalListSortingStrategy, useSortable, } from '@dnd-kit/sortable';
5
5
  import { CSS as DND_CSS } from '@dnd-kit/utilities';
6
+ import { ThemeContext } from '../../Context';
6
7
  export default function AddColumnPopover({ onSave, orderedColumnNames, setOrderedColumnNames, selectedColumns, setSelectedColumns, isSelectedAllColumns, clearAllState, nameToColumn, baseAst, setBaseAst, pivot, initialTableName, defaultAST, defaultTable, setPivot, TextInput, SelectColumn, SecondaryButton, Button, HandleButton, }) {
8
+ const [theme] = useContext(ThemeContext);
7
9
  const [search, setSearch] = useState('');
8
10
  const sensors = useSensors(useSensor(PointerSensor), useSensor(KeyboardSensor, {
9
11
  coordinateGetter: sortableKeyboardCoordinates,
@@ -50,8 +52,8 @@ export default function AddColumnPopover({ onSave, orderedColumnNames, setOrdere
50
52
  overflowY: 'auto',
51
53
  maxWidth: '300px',
52
54
  }, children: [searchResults.map((value) => {
53
- return (_jsx(SortableItem, { selectedColumns: selectedColumns, setSelectedColumns: setSelectedColumns, id: value, label: value.replace('.', ' '), SelectColumn: SelectColumn, HandleButton: HandleButton }, value));
54
- }), search.length > 0 && searchResults.length === 0 && (_jsx("div", { children: "No results found" }))] }) }) }), _jsxs("div", { style: {
55
+ return (_jsx(SortableItem, { theme: theme, selectedColumns: selectedColumns, setSelectedColumns: setSelectedColumns, id: value, label: value.replace('.', ' '), SelectColumn: SelectColumn, HandleButton: HandleButton }, value));
56
+ }), search.length > 0 && searchResults.length === 0 && (_jsx("div", { style: { fontFamily: theme?.fontFamily }, children: "No results found" }))] }) }) }), _jsxs("div", { style: {
55
57
  display: 'flex',
56
58
  width: '100%',
57
59
  flexDirection: 'row',
@@ -103,7 +105,7 @@ export default function AddColumnPopover({ onSave, orderedColumnNames, setOrdere
103
105
  onSave();
104
106
  }, children: "Save" })] })] }));
105
107
  }
106
- const SortableItem = ({ id, label, setSelectedColumns, selectedColumns, SelectColumn, HandleButton, }) => {
108
+ const SortableItem = ({ id, label, setSelectedColumns, theme, selectedColumns, SelectColumn, HandleButton, }) => {
107
109
  const { attributes, listeners, setNodeRef, transform, transition } = useSortable({ id: id });
108
110
  const style = {
109
111
  transform: DND_CSS.Transform.toString(transform),
@@ -1 +1 @@
1
- {"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/ui.tsx"],"names":[],"mappings":";AAeA;;;;;GAKG;AAEH,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CA2BtD,CAAC;AAEF,eAAO,MAAM,oBAAoB,2BAA4B,GAAG,4CA2B/D,CAAC;AAEF,eAAO,MAAM,cAAc,UAAW,GAAG,4CAuBxC,CAAC;AAEF,eAAO,MAAM,uBAAuB,uCAKjC,GAAG,4CAiBL,CAAC;AAEF,eAAO,MAAM,QAAQ,sGA2DpB,CAAC;AAGF,eAAO,MAAM,mBAAmB,cAAe,GAAG,4CAEjD,CAAC;AAGF,eAAO,MAAM,sBAAsB,cAAe,GAAG,4CAEpD,CAAC;AAGF,eAAO,MAAM,YAAY,sGAgBxB,CAAC;AAGF,eAAO,MAAM,eAAe,sGAsB3B,CAAC;AAEF,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CAUtD,CAAC;AAEF,wBAAgB,eAAe,CAAC,EAC9B,OAAO,EACP,QAAQ,EACR,KAAU,EACV,OAAO,EACP,MAAM,GACP,EAAE,GAAG,2CA6CL;AAED,eAAO,MAAM,YAAY,sGA8BxB,CAAC;AAGF,eAAO,MAAM,iBAAiB,+CAsE7B,CAAC;AAEF,eAAO,MAAM,iBAAiB,gDAK3B,GAAG,4CAyCL,CAAC;AAGF,eAAO,MAAM,oBAAoB,kCAAmC,GAAG,4CAuCtE,CAAC;AAGF,eAAO,MAAM,uBAAuB,+CAEnC,CAAC;AAGF,eAAO,MAAM,sBAAsB,+CAMlC,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;GAG/B,CAAC;AAEF,eAAO,MAAM,SAAS,sGAIrB,CAAC;AAEF,eAAO,MAAM,WAAW,8DAMrB,GAAG,4CAwBL,CAAC;AAEF,eAAO,MAAM,kBAAkB,4FAO5B,GAAG,4CAqBL,CAAC;AAEF,eAAO,MAAM,UAAU,sTAuBpB,GAAG,4CAqFL,CAAC;AAEF,eAAO,MAAM,gBAAgB,oDAK1B,GAAG,4CAeL,CAAC"}
1
+ {"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../../../src/components/ReportBuilder/ui.tsx"],"names":[],"mappings":";AAeA;;;;;GAKG;AAEH,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CA2BtD,CAAC;AAEF,eAAO,MAAM,oBAAoB,2BAA4B,GAAG,4CA2B/D,CAAC;AAEF,eAAO,MAAM,cAAc,UAAW,GAAG,4CAuBxC,CAAC;AAEF,eAAO,MAAM,uBAAuB,uCAKjC,GAAG,4CAiBL,CAAC;AAEF,eAAO,MAAM,QAAQ,sGAoEpB,CAAC;AAGF,eAAO,MAAM,mBAAmB,cAAe,GAAG,4CAEjD,CAAC;AAGF,eAAO,MAAM,sBAAsB,cAAe,GAAG,4CAEpD,CAAC;AAGF,eAAO,MAAM,YAAY,sGAgBxB,CAAC;AAGF,eAAO,MAAM,eAAe,sGAsB3B,CAAC;AAEF,eAAO,MAAM,WAAW,2BAA4B,GAAG,4CAUtD,CAAC;AAEF,wBAAgB,eAAe,CAAC,EAC9B,OAAO,EACP,QAAQ,EACR,KAAU,EACV,OAAO,EACP,MAAM,GACP,EAAE,GAAG,2CAiDL;AAED,eAAO,MAAM,YAAY,sGAkCxB,CAAC;AAGF,eAAO,MAAM,iBAAiB,+CAwE7B,CAAC;AAEF,eAAO,MAAM,iBAAiB,gDAK3B,GAAG,4CA6CL,CAAC;AAGF,eAAO,MAAM,oBAAoB,kCAAmC,GAAG,4CAkDtE,CAAC;AAGF,eAAO,MAAM,uBAAuB,+CAEnC,CAAC;AAGF,eAAO,MAAM,sBAAsB,+CAMlC,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;GAG/B,CAAC;AAEF,eAAO,MAAM,SAAS,sGAIrB,CAAC;AAEF,eAAO,MAAM,WAAW,8DAMrB,GAAG,4CAwBL,CAAC;AAEF,eAAO,MAAM,kBAAkB,4FAO5B,GAAG,4CAqBL,CAAC;AAEF,eAAO,MAAM,UAAU,sTAuBpB,GAAG,4CAqFL,CAAC;AAEF,eAAO,MAAM,gBAAgB,oDAK1B,GAAG,4CAeL,CAAC"}
@@ -84,7 +84,8 @@ export const QuillTag = forwardRef(({ label, onClick, children, onClickDelete, h
84
84
  width: '100%',
85
85
  padding: '4px 8px',
86
86
  alignItems: 'center',
87
- backgroundColor: 'white',
87
+ backgroundColor: theme?.backgroundColor || 'white',
88
+ fontFamily: theme?.fontFamily,
88
89
  fontSize: 14,
89
90
  }, ref: forwardedRef, onClick: onClick, children: [label ?? children, !hideDelete && (_jsx("div", { style: {
90
91
  marginLeft: 'auto',
@@ -92,7 +93,12 @@ export const QuillTag = forwardRef(({ label, onClick, children, onClickDelete, h
92
93
  display: 'flex',
93
94
  flexDirection: 'column',
94
95
  justifyContent: 'center',
95
- }, children: _jsx("button", { onClick: onClickDelete, style: { margin: -4 }, children: _jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: _jsx("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) }) }))] }));
96
+ }, children: _jsx("button", { onClick: onClickDelete, style: {
97
+ margin: -4,
98
+ border: 'none',
99
+ backgroundColor: theme?.backgroundColor || 'white',
100
+ fontFamily: theme?.fontFamily,
101
+ }, children: _jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: _jsx("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) }) }))] }));
96
102
  });
97
103
  // A heading element in the sidebar (eg. "Filters")
98
104
  export const QuillSidebarHeading = ({ label }) => (_jsx(MemoizedHeader, { children: label }));
@@ -133,6 +139,7 @@ export const QuillSelect = ({ onChange, ...props }) => {
133
139
  };
134
140
  export function MemoizedPopover({ onClose, children, style = {}, trigger, isOpen, }) {
135
141
  const modalRef = useRef(null);
142
+ const [theme] = useContext(ThemeContext);
136
143
  useEffect(() => {
137
144
  const listener = (event) => {
138
145
  if (modalRef?.current && !modalRef?.current?.contains(event.target)) {
@@ -145,10 +152,12 @@ export function MemoizedPopover({ onClose, children, style = {}, trigger, isOpen
145
152
  };
146
153
  }, [modalRef, onClose]);
147
154
  return (_jsxs("div", { children: [trigger, isOpen && (_jsx("div", { id: "quill-popover-modal", ref: modalRef, style: { position: 'relative' }, children: _jsx("div", { style: {
148
- background: 'white',
155
+ background: theme?.backgroundColor || 'white',
149
156
  position: 'absolute',
150
157
  boxShadow: '0px 1px 12px 0px rgba(56, 65, 81, 0.1)',
151
- border: '1px solid #e7e7e7',
158
+ border: theme
159
+ ? `${theme.borderWidth || 1}px solid ${theme.borderColor || '#e7e7e7'}`
160
+ : '1px solid #e7e7e7',
152
161
  boxSizing: 'content-box',
153
162
  zIndex: 999,
154
163
  top: 12,
@@ -159,16 +168,20 @@ export function MemoizedPopover({ onClose, children, style = {}, trigger, isOpen
159
168
  }, children: children }) }))] }));
160
169
  }
161
170
  export const QuillPopover = forwardRef(({ children, trigger, isOpen, onClose = () => { }, title = undefined }, ref) => {
171
+ const [theme] = useContext(ThemeContext);
162
172
  return (_jsxs(MemoizedPopover, { isOpen: isOpen, onClose: onClose, trigger: trigger, parentRef: ref, ref: ref, children: [title && (_jsx("h1", { style: {
163
173
  fontWeight: '600',
164
174
  fontSize: 18,
165
175
  margin: 0,
166
176
  textAlign: 'left',
167
177
  paddingBottom: 12,
178
+ color: theme?.primaryTextColor,
179
+ fontFamily: theme?.fontFamily,
168
180
  }, children: title })), children] }));
169
181
  });
170
182
  // The six-dot grab-handle icon.
171
183
  export const QuillHandleButton = () => {
184
+ const [theme] = useContext(ThemeContext);
172
185
  return (_jsxs("div", { style: {
173
186
  display: 'flex',
174
187
  gap: 2,
@@ -211,6 +224,7 @@ export const QuillHandleButton = () => {
211
224
  } })] })] }));
212
225
  };
213
226
  export const QuillSelectColumn = ({ label, selected, setSelected, children, }) => {
227
+ const [theme] = useContext(ThemeContext);
214
228
  return (_jsxs("div", { title: label, style: {
215
229
  boxShadow: '0px 1px 4px #e2e8f005',
216
230
  paddingTop: 4,
@@ -220,7 +234,7 @@ export const QuillSelectColumn = ({ label, selected, setSelected, children, }) =
220
234
  borderRadius: 4,
221
235
  display: 'flex',
222
236
  alignItems: 'center',
223
- backgroundColor: 'white',
237
+ backgroundColor: theme?.backgroundColor || 'white',
224
238
  }, children: [_jsx("div", { children: children }), _jsxs("label", { style: {
225
239
  display: 'flex',
226
240
  gap: 2,
@@ -233,6 +247,8 @@ export const QuillSelectColumn = ({ label, selected, setSelected, children, }) =
233
247
  whiteSpace: 'nowrap',
234
248
  textOverflow: 'ellipsis',
235
249
  overflow: 'hidden',
250
+ fontFamily: theme?.fontFamily,
251
+ color: theme?.primaryTextColor,
236
252
  }, children: label })] })] }));
237
253
  };
238
254
  // A draggable card with a grab-handle and a column name
@@ -244,7 +260,7 @@ export const QuillDraggableColumn = ({ label, children, onDelete }) => {
244
260
  borderRadius: 6,
245
261
  display: 'flex',
246
262
  alignItems: 'center',
247
- backgroundColor: 'white',
263
+ backgroundColor: theme?.backgroundColor || 'white',
248
264
  }, children: [_jsx("div", { children: children }), _jsx("div", { style: {
249
265
  marginLeft: 2,
250
266
  marginRight: 'auto',
@@ -252,7 +268,15 @@ export const QuillDraggableColumn = ({ label, children, onDelete }) => {
252
268
  display: 'block',
253
269
  whiteSpace: 'nowrap',
254
270
  textOverflow: 'ellipsis',
255
- }, children: label }), _jsx("button", { onClick: onDelete, style: { paddingRight: 8, margin: -4 }, children: _jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: _jsx("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) })] }));
271
+ fontFamily: theme?.fontFamily,
272
+ }, children: label }), _jsx("button", { onClick: onDelete, style: {
273
+ paddingRight: 8,
274
+ margin: -4,
275
+ fontFamily: theme?.fontFamily,
276
+ backgroundColor: theme?.backgroundColor || 'white',
277
+ border: 'none',
278
+ outline: 'none',
279
+ }, children: _jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: theme?.secondaryButtonColor || 'currentColor', style: { width: 16, height: 16 }, children: _jsx("path", { d: "M6.28 5.22a.75.75 0 0 0-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 1 0 1.06 1.06L10 11.06l3.72 3.72a.75.75 0 1 0 1.06-1.06L11.06 10l3.72-3.72a.75.75 0 0 0-1.06-1.06L10 8.94 6.28 5.22Z" }) }) })] }));
256
280
  };
257
281
  // Three dots animated bouncing
258
282
  export const QuillButtonLoadingState = () => {
@@ -1 +1 @@
1
- {"version":3,"file":"UiComponents.d.ts","sourceRoot":"","sources":["../../../src/components/UiComponents.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"UiComponents.d.ts","sourceRoot":"","sources":["../../../src/components/UiComponents.tsx"],"names":[],"mappings":"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"}
@@ -119,18 +119,23 @@ export const MemoizedSelect = ({ value, onChange, options, disabled = false, sty
119
119
  color: '#6C727F',
120
120
  }, "aria-hidden": "true" })] }));
121
121
  };
122
- export const MemoizedHeader = ({ children }) => (_jsx("h1", { style: {
123
- fontSize: 16,
124
- fontWeight: 600,
125
- color: '#384151',
126
- userSelect: 'none',
127
- margin: 0,
128
- padding: 0,
129
- }, children: children }));
122
+ export const MemoizedHeader = ({ children }) => {
123
+ const [theme] = useContext(ThemeContext);
124
+ return (_jsx("h1", { style: {
125
+ fontSize: 16,
126
+ fontWeight: 600,
127
+ fontFamily: theme?.fontFamily,
128
+ color: theme?.primaryTextColor || '#384151',
129
+ userSelect: 'none',
130
+ margin: 0,
131
+ padding: 0,
132
+ }, children: children }));
133
+ };
130
134
  export const MemoizedLabel = ({ children }) => (_jsx("h1", { style: {
131
135
  fontSize: 14,
132
136
  fontWeight: 600,
133
- color: '#575E6A',
137
+ fontFamily: theme?.fontFamily,
138
+ color: theme?.secondaryTextColor || '#575E6A',
134
139
  userSelect: 'none',
135
140
  paddingBottom: 5,
136
141
  }, children: children }));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@quillsql/react",
3
- "version": "2.11.2",
3
+ "version": "2.11.4",
4
4
  "exports": {
5
5
  ".": {
6
6
  "import": "./dist/esm/index.js",