Skip to content

Commit

Permalink
Refactor: refactor contextProvider get to reduce re-fetch (#365)
Browse files Browse the repository at this point in the history
* refactor: refacotr contextProvider get to reduce re-fetch

Signed-off-by: tygao <[email protected]>

* doc: add changelog

Signed-off-by: tygao <[email protected]>

---------

Signed-off-by: tygao <[email protected]>
  • Loading branch information
raintygao authored Oct 29, 2024
1 parent 0f4e48a commit 5ac419e
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 11 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ Inspired from [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
- feat: Hide incompatible index patterns ([#354] (https://github.com/opensearch-project/dashboards-assistant/pull/354))
- feat: edit visualization with natural language in a dialog([#351](https://github.com/opensearch-project/dashboards-assistant/pull/351))
- fix: Update alerting DSL verify mechanism([#359](https://github.com/opensearch-project/dashboards-assistant/pull/359))
- fix: Refactor contextProvider get to reduce re-fetch([#365](https://github.com/opensearch-project/dashboards-assistant/pull/365))


### 📈 Features/Enhancements
Expand Down
26 changes: 15 additions & 11 deletions public/components/incontext_insight/generate_popover_body.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ export const GeneratePopoverBody: React.FC<{
}> = ({ incontextInsight, httpSetup, usageCollection, closePopover, getStartServices }) => {
const [summary, setSummary] = useState('');
const [insight, setInsight] = useState('');
const [contextObject, setContextObject] = useState<ContextObj | undefined>(undefined);
const [insightAvailable, setInsightAvailable] = useState(false);
const [showInsight, setShowInsight] = useState(false);
const [discoverLoading, setDiscoverLoading] = useState(false);
Expand All @@ -54,9 +55,9 @@ export const GeneratePopoverBody: React.FC<{

useEffect(() => {
const getMonitorType = async () => {
const context = await incontextInsight.contextProvider?.();
const monitorType = context?.additionalInfo?.monitorType;
const dsl = context?.additionalInfo?.dsl;
if (!contextObject) return;
const monitorType = contextObject?.additionalInfo?.monitorType;
const dsl = contextObject?.additionalInfo?.dsl;
// Only this two types from alerting contain DSL and index.
const isSupportedMonitorType =
monitorType === 'query_level_monitor' || monitorType === 'bucket_level_monitor';
Expand All @@ -77,7 +78,7 @@ export const GeneratePopoverBody: React.FC<{
setDisplayDiscoverButton(isSupportedMonitorType && hasTimeRangeFilter);
};
getMonitorType();
}, [incontextInsight, setDisplayDiscoverButton]);
}, [contextObject, setDisplayDiscoverButton]);

useEffectOnce(() => {
onGenerateSummary(
Expand All @@ -99,9 +100,11 @@ export const GeneratePopoverBody: React.FC<{
defaultMessage: 'Generate summary error',
})
);
// closePopover();
closePopover();
return;
}
// onGenerateSummary will get contextObj when mounted, use this returned value to set state to avoid re-fetch.
setContextObject(contextObj);
const contextContent = contextObj?.context || '';
const dataSourceId = contextObj?.dataSourceId;
const dataSourceQuery = dataSourceId ? { dataSourceId } : {};
Expand Down Expand Up @@ -153,12 +156,13 @@ export const GeneratePopoverBody: React.FC<{
reportMetric(usageCollection, metricAppName, 'generated', METRIC_TYPE.COUNT);
})
.catch((error) => {
console.error('Error generate summary:', error);
toasts.addDanger(
i18n.translate('assistantDashboards.incontextInsight.generateSummaryError', {
defaultMessage: 'Generate summary error',
})
);
// closePopover();
closePopover();
});
};

Expand Down Expand Up @@ -205,9 +209,9 @@ export const GeneratePopoverBody: React.FC<{
const handleNavigateToDiscover = async () => {
try {
setDiscoverLoading(true);
const context = await incontextInsight?.contextProvider?.();
const dsl = context?.additionalInfo?.dsl;
const indexName = context?.additionalInfo?.index;
if (!contextObject) return;
const dsl = contextObject?.additionalInfo?.dsl;
const indexName = contextObject?.additionalInfo?.index;
if (!dsl || !indexName) return;
const dslObject = JSON.parse(dsl);
const filters = dslObject?.query?.bool?.filter;
Expand All @@ -229,7 +233,7 @@ export const GeneratePopoverBody: React.FC<{
startDeps.data,
indexName,
timeFieldName,
context?.dataSourceId
contextObject?.dataSourceId
);
if (!indexPattern) return;
const query = await buildUrlQuery(
Expand All @@ -238,7 +242,7 @@ export const GeneratePopoverBody: React.FC<{
indexPattern,
dslObject,
timeRangeDSL,
context?.dataSourceId
contextObject?.dataSourceId
);
// Navigate to new discover with query built to populate, use new window to avoid discover search failed.
const discoverUrl = `data-explorer/discover#?${query}`;
Expand Down

0 comments on commit 5ac419e

Please sign in to comment.