Fixed field parameters.

This commit is contained in:
Mike Cao 2025-03-27 15:33:24 -07:00
parent 0f6cdf8b80
commit 7d2c361725
12 changed files with 90 additions and 88 deletions

View file

@ -45,13 +45,13 @@ export function Nav(props: any) {
<SideNavSection>
{links.map(({ href, label, icon }) => {
return (
<Link key={href} href={href}>
<Link key={href} href={href} role="button">
<SideNavItem label={label} icon={icon} isSelected={pathname.startsWith(href)} />
</Link>
);
})}
</SideNavSection>
<SideNavSection alignSelf="end"></SideNavSection>
<SideNavSection alignSelf="end">{``}</SideNavSection>
</SideNav>
);
}

View file

@ -11,9 +11,10 @@ export function FieldParameters() {
const { fields } = parameters || {};
const { fields: fieldOptions } = useFields();
const handleAdd = (value: { name: any }) => {
if (!fields.find(({ name }) => name === value.name)) {
updateReport({ parameters: { fields: fields.concat(value) } });
const handleAdd = (value: string) => {
if (!fields.find(({ name }) => name === value)) {
const field = fieldOptions.find(({ name }) => name === value);
updateReport({ parameters: { fields: fields.concat(field) } });
}
};
@ -21,30 +22,24 @@ export function FieldParameters() {
updateReport({ parameters: { fields: fields.filter(f => f.name !== name) } });
};
const AddButton = () => {
return (
<MenuTrigger>
<Button variant="quiet">
<Icon size="sm">
<Icons.Plus />
</Icon>
</Button>
<Popover placement="right top">
<FieldSelectForm
fields={fieldOptions.filter(({ name }) => !fields.find(f => f.name === name))}
onSelect={handleAdd}
showType={false}
/>
</Popover>
</MenuTrigger>
);
};
return (
<Column gap="3">
<Row justifyContent="space-between">
<Label>{formatMessage(labels.fields)}</Label>
<AddButton />
<MenuTrigger>
<Button variant="quiet">
<Icon size="sm">
<Icons.Plus />
</Icon>
</Button>
<Popover placement="right top">
<FieldSelectForm
fields={fieldOptions.filter(({ name }) => !fields.find(f => f.name === name))}
onSelect={handleAdd}
showType={false}
/>
</Popover>
</MenuTrigger>
</Row>
<ParameterList>
{fields.map(({ name }) => {

View file

@ -1,10 +1,9 @@
import { Menu, MenuItem, Text, MenuSection } from '@umami/react-zen';
import { Menu, MenuItem, Text, MenuSection, Row } from '@umami/react-zen';
import { useMessages } from '@/components/hooks';
import { Key } from 'react';
export interface FieldSelectFormProps {
fields?: any[];
onSelect?: (key: any) => void;
onSelect?: (value: any) => void;
showType?: boolean;
}
@ -12,13 +11,15 @@ export function FieldSelectForm({ fields = [], onSelect, showType = true }: Fiel
const { formatMessage, labels } = useMessages();
return (
<Menu onSelectionChange={key => onSelect(fields[key as any])}>
<Menu>
<MenuSection title={formatMessage(labels.fields)}>
{fields.map(({ name, label, type }: any, index: Key) => {
{fields.map(({ name, label, type }) => {
return (
<MenuItem key={index}>
<Text>{label || name}</Text>
{showType && type && <Text color="muted">{type}</Text>}
<MenuItem key={name} id={name} onAction={() => onSelect(name)}>
<Row alignItems="center" justifyContent="space-between">
<Text>{label || name}</Text>
{showType && type && <Text color="muted">{type}</Text>}
</Row>
</MenuItem>
);
})}

View file

@ -8,8 +8,8 @@ import {
Icon,
Popover,
MenuTrigger,
Focusable,
Text,
Pressable,
} from '@umami/react-zen';
import { FilterSelectForm } from '../[reportId]/FilterSelectForm';
import { ParameterList } from '../[reportId]/ParameterList';
@ -48,32 +48,26 @@ export function FilterParameters() {
close();
};
const AddButton = () => {
return (
<MenuTrigger>
<Button variant="quiet">
<Icon size="sm">
<Icons.Plus />
</Icon>
</Button>
<Popover placement="right top">
<FilterSelectForm
websiteId={websiteId}
fields={fields.filter(({ name }) => !filters.find(f => f.name === name))}
startDate={dateRange?.startDate}
endDate={dateRange?.endDate}
onChange={handleAdd}
/>
</Popover>
</MenuTrigger>
);
};
return (
<Column gap="3">
<Row justifyContent="space-between">
<Label>{formatMessage(labels.filters)}</Label>
<AddButton />
<MenuTrigger>
<Button variant="quiet">
<Icon size="sm">
<Icons.Plus />
</Icon>
</Button>
<Popover placement="right top">
<FilterSelectForm
websiteId={websiteId}
fields={fields.filter(({ name }) => !filters.find(f => f.name === name))}
startDate={dateRange?.startDate}
endDate={dateRange?.endDate}
onChange={handleAdd}
/>
</Popover>
</MenuTrigger>
</Row>
<ParameterList>
{filters.map(
@ -117,15 +111,15 @@ const FilterParameter = ({
return (
<MenuTrigger>
<Focusable>
<Row gap="3" alignItems="center">
<Pressable>
<Row role="button" gap="3" alignItems="center">
<Text>{label}</Text>
<Text size="2" transform="uppercase">
{operatorLabels[operator]}
</Text>
<Text weight="bold">{value}</Text>
</Row>
</Focusable>
</Pressable>
<Popover placement="right top">
{(close: any) => (
<FieldFilterEditForm

View file

@ -12,7 +12,7 @@ export function ParameterList({ children }: ParameterListProps) {
const { formatMessage, labels } = useMessages();
return (
<Column>
<Column gap="3">
{!children && <Empty message={formatMessage(labels.none)} />}
{children}
</Column>
@ -40,6 +40,7 @@ const Item = ({
border
borderRadius="2"
paddingLeft="3"
shadow="2"
>
{icon && <Icon>{icon}</Icon>}
<Text>{children}</Text>

View file

@ -1,4 +1,4 @@
import { Button, Icon, Icons, Box, MenuTrigger, Popover, Text } from '@umami/react-zen';
import { Button, Icon, Icons, MenuTrigger, Popover, Text } from '@umami/react-zen';
import { FilterSelectForm } from '@/app/(main)/reports/[reportId]/FilterSelectForm';
import { useFields, useMessages, useNavigation, useDateRange } from '@/components/hooks';
import { OPERATOR_PREFIXES } from '@/lib/constants';
@ -34,21 +34,19 @@ export function WebsiteFilterButton({
</Icon>
{showText && <Text>{formatMessage(labels.filter)}</Text>}
</Button>
<Popover placement="bottom end">
<Popover placement="bottom start">
{({ close }: any) => {
return (
<Box padding="3" backgroundColor="1">
<FilterSelectForm
websiteId={websiteId}
fields={fields}
startDate={startDate}
endDate={endDate}
onChange={value => {
handleAddFilter(value);
close();
}}
/>
</Box>
<FilterSelectForm
websiteId={websiteId}
fields={fields}
startDate={startDate}
endDate={endDate}
onChange={value => {
handleAddFilter(value);
close();
}}
/>
);
}}
</Popover>