Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
thmsobrmlr committed Jul 26, 2024
1 parent b9aef14 commit 8dd502e
Showing 1 changed file with 20 additions and 30 deletions.
50 changes: 20 additions & 30 deletions frontend/src/scenes/insights/insightLogic.ts
Original file line number Diff line number Diff line change
Expand Up @@ -100,9 +100,9 @@ export const insightLogic = kea<insightLogicType>([
callback,
}),
setInsightMetadata: (
metadata: Partial<Pick<QueryBasedInsightModel, 'name' | 'description' | 'tags' | 'favorited'>>
metadataUpdate: Partial<Pick<QueryBasedInsightModel, 'name' | 'description' | 'tags' | 'favorited'>>
) => ({
metadata,
metadataUpdate,
}),
highlightSeries: (seriesIndex: number | null) => ({ seriesIndex }),
}),
Expand Down Expand Up @@ -145,60 +145,50 @@ export const insightLogic = kea<insightLogicType>([
dashboardsModel.actions.updateDashboardInsight(updatedInsight, removedDashboards)
return updatedInsight
},
setInsightMetadata: async ({ metadata }, breakpoint) => {
setInsightMetadata: async ({ metadataUpdate }, breakpoint) => {
console.debug('setInsightMetadata')
const editMode =
insightSceneLogic.isMounted() &&
insightSceneLogic.values.legacyInsight === values.legacyInsight &&
insightSceneLogic.values.queryBasedInsight === values.queryBasedInsight &&
insightSceneLogic.values.insightMode === ItemMode.Edit

if (editMode) {
return { ...values.legacyInsight, ...metadata }
return { ...values.legacyInsight, ...metadataUpdate }
}

const beforeUpdates = {}
for (const key of Object.keys(metadata)) {
for (const key of Object.keys(metadataUpdate)) {
beforeUpdates[key] = values.savedInsight[key]
}

// TODO: insightsApi.update
const response = await api.update(
`api/projects/${teamLogic.values.currentTeamId}/insights/${values.legacyInsight.id}`,
metadata
)
const response = await insightsApi.update(values.queryBasedInsight.id, metadataUpdate, {
writeAsQuery: values.queryBasedInsightSaving,
readAsQuery: false,
})
breakpoint()

// only update the fields that we changed
const updatedInsight = { ...values.legacyInsight } as InsightModel
for (const key of Object.keys(metadata)) {
updatedInsight[key] = response[key]
}
console.debug('response', response)

savedInsightsLogic.findMounted()?.actions.loadInsights()
dashboardsModel.actions.updateDashboardInsight(updatedInsight)
dashboardsModel.actions.updateDashboardInsight(response)
actions.loadTags()

lemonToast.success(`Updated insight`, {
button: {
label: 'Undo',
dataAttr: 'edit-insight-undo',
action: async () => {
const response = await api.update(
`api/projects/${teamLogic.values.currentTeamId}/insights/${values.queryBasedInsight.id}`,
beforeUpdates
)
// only update the fields that we changed
const revertedInsight = { ...values.legacyInsight } as InsightModel
for (const key of Object.keys(beforeUpdates)) {
revertedInsight[key] = response[key]
}
const response = await insightsApi.update(values.queryBasedInsight.id, beforeUpdates, {
writeAsQuery: values.queryBasedInsightSaving,
readAsQuery: false,
})
savedInsightsLogic.findMounted()?.actions.loadInsights()
dashboardsModel.actions.updateDashboardInsight(revertedInsight)
actions.setInsight(revertedInsight, { overrideFilter: false, fromPersistentApi: true })
dashboardsModel.actions.updateDashboardInsight(response)
actions.setInsight(response, { overrideFilter: false, fromPersistentApi: true })
lemonToast.success('Insight change reverted')
},
},
})
return updatedInsight
return response
},
},
],
Expand Down

0 comments on commit 8dd502e

Please sign in to comment.