Skip to content

Commit

Permalink
feat: add height parsing and apply to indicators (#710)
Browse files Browse the repository at this point in the history
* feat: add height parsing and apply to indicators

gisce/webclient#1344

* feat: allow height for indicators in forms

* chore: remove console.log
  • Loading branch information
mguellsegarra authored Nov 27, 2024
1 parent 7ff7505 commit 1e573f9
Show file tree
Hide file tree
Showing 7 changed files with 62 additions and 45 deletions.
4 changes: 2 additions & 2 deletions src/widgets/custom/Indicator.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ const IndicatorInput = (props: IndicatorInputProps) => {

const GraphIndicatorInput = (props: IndicatorInputProps) => {
const { ooui } = props;
const { actionId } = ooui;
const { actionId, height } = ooui;

const { actionData, treeShortcut, loading, error, fetchData } =
useFormGraphData(actionId!);
Expand Down Expand Up @@ -133,7 +133,7 @@ const GraphIndicatorInput = (props: IndicatorInputProps) => {
context={context}
domain={domain}
limit={limit}
fixedHeight
fixedHeight={height}
/>
)}
</GraphCard>
Expand Down
6 changes: 4 additions & 2 deletions src/widgets/views/Graph/Graph.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import {
} from "@/context/ActionViewContext";
import { useNetworkRequest } from "@/hooks/useNetworkRequest";
import { CenteredSpinner } from "@/ui/CenteredSpinner";
import { GRAPH_DEFAULT_HEIGHT } from "./GraphChartComp";

export type GraphProps = {
view_id: number;
Expand All @@ -30,7 +31,7 @@ export type GraphProps = {
context: any;
limit?: number;
manualIds?: number[];
fixedHeight?: boolean;
fixedHeight?: number;
};

const GraphComp = (props: GraphProps, ref: any) => {
Expand Down Expand Up @@ -107,6 +108,7 @@ const GraphComp = (props: GraphProps, ref: any) => {
icon={indicator.icon!}
suffix={indicator.suffix!}
manualIds={manualIds}
fixedHeight={fixedHeight}
{...indicatorFieldopts}
/>
);
Expand All @@ -122,7 +124,7 @@ const GraphComp = (props: GraphProps, ref: any) => {
ooui={graphOoui as GraphChartOoui}
limit={limit}
manualIds={manualIds}
fixedHeight={fixedHeight}
fixedHeight={fixedHeight || GRAPH_DEFAULT_HEIGHT}
/>
);
}
Expand Down
2 changes: 1 addition & 1 deletion src/widgets/views/Graph/GraphChart.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ export type GraphChartProps = {
ooui: GraphChartOoui;
limit?: number;
manualIds?: number[];
fixedHeight?: boolean;
fixedHeight?: number;
};

export const GraphChart = ({
Expand Down
14 changes: 7 additions & 7 deletions src/widgets/views/Graph/GraphChartComp.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { GraphType, YAxisOpts } from "@gisce/ooui";

const { Text } = Typography;

const DEFAULT_HEIGHT = 400;
export const GRAPH_DEFAULT_HEIGHT = 400;

// Memoize each chart type
const MemoizedLine = memo(Line);
Expand All @@ -30,7 +30,7 @@ export type GraphCompProps = {
isStack: boolean;
numItems: number;
yAxisOpts?: YAxisOpts;
fixedHeight?: boolean;
fixedHeight?: number;
};

export const GraphChartComp = ({
Expand All @@ -40,7 +40,7 @@ export const GraphChartComp = ({
isStack,
numItems,
yAxisOpts,
fixedHeight = false,
fixedHeight,
}: GraphCompProps) => {
const { t } = useLocale();

Expand Down Expand Up @@ -138,7 +138,7 @@ export const GraphChartComp = ({
flex: 1,
padding: "1rem",
gap: "10px",
height: fixedHeight ? DEFAULT_HEIGHT : undefined,
height: fixedHeight,
}}
>
<div style={{ textAlign: "right" }}>
Expand Down Expand Up @@ -169,7 +169,7 @@ type GetGraphPropsType = GraphCompProps & {
height?: number;
pieItemValueFormatter?: any;
pieLabelFormatter?: any;
fixedHeight?: boolean;
fixedHeight?: number;
};

function getGraphProps(props: GetGraphPropsType) {
Expand All @@ -181,7 +181,7 @@ function getGraphProps(props: GetGraphPropsType) {
pieItemValueFormatter,
pieLabelFormatter,
yAxisOpts = { mode: "default" },
fixedHeight = false,
fixedHeight,
} = props;
let graphProps = { ...(GraphDefaults as any)[type] };

Expand All @@ -190,7 +190,7 @@ function getGraphProps(props: GetGraphPropsType) {
}

graphProps.data = data;
graphProps.height = fixedHeight ? DEFAULT_HEIGHT : undefined;
graphProps.height = fixedHeight;

if (type === "pie") {
graphProps.colorField = "x";
Expand Down
3 changes: 3 additions & 0 deletions src/widgets/views/Graph/GraphIndicator.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ export type GraphInidicatorProps = {
field?: string;
operator?: Operator;
manualIds?: number[];
fixedHeight?: number;
};

export const GraphIndicator = (props: GraphInidicatorProps) => {
Expand All @@ -35,6 +36,7 @@ export const GraphIndicator = (props: GraphInidicatorProps) => {
field,
operator,
manualIds,
fixedHeight,
} = props;
const [loading, setLoading] = useState(false);
const [value, setValue] = useState<number>();
Expand Down Expand Up @@ -213,6 +215,7 @@ export const GraphIndicator = (props: GraphInidicatorProps) => {
icon={icon}
suffix={suffix}
showPercent={showPercent}
fixedHeight={fixedHeight}
/>
);
};
71 changes: 41 additions & 30 deletions src/widgets/views/Graph/GraphIndicatorComp.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,23 @@ export type GraphIndicatorCompProps = {
icon?: string;
suffix?: string;
showPercent?: boolean;
fixedHeight?: number;
};

export const GraphIndicatorComp = (props: GraphIndicatorCompProps) => {
const [height, setHeight] = useState<number>(0);
const [width, setWidth] = useState<number>(0);

const { value, totalValue, percent, color, icon, suffix, showPercent } =
props;
const {
value,
totalValue,
percent,
color,
icon,
suffix,
showPercent,
fixedHeight,
} = props;

return (
<Measure
Expand All @@ -33,34 +42,36 @@ export const GraphIndicatorComp = (props: GraphIndicatorCompProps) => {
}}
>
{({ measureRef }) => {
if (showPercent) {
return (
<PercentageIndicator
value={value!}
total={totalValue!}
percent={percent!}
measureRef={measureRef}
height={height}
width={width}
color={color}
icon={icon}
suffix={suffix}
/>
);
} else {
return (
<CommonIndicator
value={value!}
total={totalValue}
measureRef={measureRef}
height={height}
width={width}
color={color}
icon={icon}
suffix={suffix}
/>
);
}
const content = showPercent ? (
<PercentageIndicator
value={value!}
total={totalValue!}
percent={percent!}
measureRef={measureRef}
height={fixedHeight || height}
width={width}
color={color}
icon={icon}
suffix={suffix}
/>
) : (
<CommonIndicator
value={value!}
total={totalValue}
measureRef={measureRef}
height={fixedHeight || height}
width={width}
color={color}
icon={icon}
suffix={suffix}
/>
);

return fixedHeight ? (
<div style={{ height: fixedHeight }}>{content}</div>
) : (
content
);
}}
</Measure>
);
Expand Down
7 changes: 4 additions & 3 deletions src/widgets/views/Graph/GraphServer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import {
} from "./useServerGraphData";
import { GraphIndicatorComp } from "./GraphIndicatorComp";
import { isNumber } from "./GraphDefaults";
import { GraphChartComp } from "./GraphChartComp";
import { GRAPH_DEFAULT_HEIGHT, GraphChartComp } from "./GraphChartComp";
import { CenteredSpinner } from "@/ui/CenteredSpinner";

export type GraphProps = {
Expand All @@ -20,7 +20,7 @@ export type GraphProps = {
domain: any;
context: any;
manualIds?: number[];
fixedHeight?: boolean;
fixedHeight?: number;
};

const GraphComp = (props: GraphProps, ref: any) => {
Expand Down Expand Up @@ -77,6 +77,7 @@ const GraphComp = (props: GraphProps, ref: any) => {
icon={icon}
suffix={suffix}
showPercent={isNumber(percent)}
fixedHeight={fixedHeight}
/>
);
}
Expand All @@ -92,7 +93,7 @@ const GraphComp = (props: GraphProps, ref: any) => {
isStack={chart.isStack}
numItems={chart.num_items}
yAxisOpts={chart.yAxisOpts}
fixedHeight={fixedHeight}
fixedHeight={fixedHeight || GRAPH_DEFAULT_HEIGHT}
/>
);
}
Expand Down

0 comments on commit 1e573f9

Please sign in to comment.