@adaptabletools/adaptable
Version:
Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements
109 lines (108 loc) • 5.84 kB
JavaScript
import * as React from 'react';
import { useDispatch } from 'react-redux';
import { Box, Flex } from 'rebass';
import { ExpressionEditor } from '../../components/ExpressionEditor';
import { NamedQueryContext, } from '../../components/ExpressionEditor/NamedQueryContext';
import SimpleButton from '../../components/SimpleButton';
import * as NamedQueryRedux from '../../Redux/ActionsReducers/NamedQueryRedux';
import { PopupShowForm } from '../../Redux/ActionsReducers/PopupRedux';
import { GridFilterModuleId } from '../../Utilities/Constants/ModuleConstants';
import { IsNotNullOrEmpty, IsNullOrEmpty } from '../../Utilities/Extensions/StringExtensions';
import Helper from '../../Utilities/Helpers/Helper';
import { useAdaptable } from '../AdaptableContext';
import { useGridFilterOptionsForExpressionEditorProps } from './useGridFilterOptionsForExpressionEditor';
export const GridFilterExpressionEditor = (props) => {
const dispatch = useDispatch();
const { api } = useAdaptable();
const [namedQuery, setNamedQuery] = React.useState(null);
const [expression, setExpression] = React.useState(props.expression);
const isExpressionValid = api.internalApi
.getQueryLanguageService()
.validateBoolean(expression, GridFilterModuleId).isValid;
const isExistingNamedQuery = Helper.objectExists(api.namedQueryApi.getNamedQueries().find((q) => q.BooleanExpression == expression));
const initialData = React.useMemo(() => api.internalApi.getQueryPreviewData(), []);
const namedQueryValidationError = namedQuery
? api.namedQueryApi.isValidNamedQuery(namedQuery).message
: '';
const hasNamedQueryError = IsNotNullOrEmpty(namedQueryValidationError);
const onRunQuery = (expression) => {
api.filterApi.gridFilterApi.setGridFilterExpression(expression);
};
const onAddNamedQuery = (namedQuery) => dispatch(NamedQueryRedux.NamedQueryAdd(namedQuery));
const handleSaveQuery = () => {
dispatch(PopupShowForm({
Id: 'save_query_form',
Form: {
title: 'Save as Named Query',
fields: [
{
name: 'name',
label: 'Name',
fieldType: 'text',
},
],
buttons: [
{
label: 'Cancel',
buttonStyle: {
variant: 'text',
tone: 'none',
},
},
{
label: 'Save',
buttonStyle: {
variant: 'raised',
tone: 'accent',
},
disabled: (button, context) => {
if (context.formData.name === '') {
return true;
}
const testQuery = {
Name: context.formData.name,
BooleanExpression: expression,
};
const namedQueryValidationResult = api.namedQueryApi.isValidNamedQuery(testQuery);
if (!namedQueryValidationResult.valid) {
return true;
}
},
onClick: (button, context) => {
onAddNamedQuery({
Name: context.formData.name,
BooleanExpression: expression,
});
},
},
],
},
}));
};
const expressionEditorProps = useGridFilterOptionsForExpressionEditorProps();
const actionsDisabled = !isExpressionValid || IsNullOrEmpty(expression) || hasNamedQueryError || isExistingNamedQuery;
return (React.createElement(NamedQueryContext.Provider, { value: {
namedQuery: namedQuery,
setNamedQuery: (newQuery) => {
setNamedQuery(newQuery);
},
} },
React.createElement(Flex, { height: "100%", flexDirection: "column" },
React.createElement(ExpressionEditor, { ...expressionEditorProps, type: 'boolean', module: GridFilterModuleId, value: expression, onChange: (expression) => setExpression(expression), initialData: initialData, columns: api.columnApi.getQueryableColumns(), fields: api.expressionApi.internalApi.getAvailableFields(), namedQueries: api.namedQueryApi.getNamedQueries(), api: api }),
React.createElement(Flex, { flexDirection: "row", padding: 1, alignItems: "center" },
props.onDismiss && (React.createElement(SimpleButton, { margin: 1, variant: "text", "data-name": "action-close", onClick: () => {
props.onDismiss();
} }, "CLOSE")),
React.createElement(Box, { flex: 1 }),
React.createElement(SimpleButton, { disabled: actionsDisabled, onClick: handleSaveQuery, icon: "save" }, "Save Query"),
React.createElement(SimpleButton, { variant: "raised", tone: "accent", "data-name": "action-run", margin: 1, icon: "play", onClick: () => {
if (namedQuery) {
onAddNamedQuery({
Name: namedQuery.Name,
BooleanExpression: expression,
});
}
onRunQuery(expression);
props?.onDismiss?.();
}, disabled: actionsDisabled }, "Apply Grid Filter")))));
};