Skip to content

Commit

Permalink
reduce duplication and refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
mattseddon committed Jan 15, 2024
1 parent 0a52fe9 commit 3d929f1
Show file tree
Hide file tree
Showing 5 changed files with 188 additions and 192 deletions.
69 changes: 7 additions & 62 deletions webview/src/experiments/components/App.tsx
Original file line number Diff line number Diff line change
@@ -1,53 +1,14 @@
import React, { useCallback } from 'react'
import { useDispatch } from 'react-redux'
import React from 'react'
import {
MessageToWebview,
MessageToWebviewType
} from 'dvc/src/webview/contract'
import { TableData } from 'dvc/src/experiments/webview/contract'
import Experiments from './Experiments'
import {
update,
updateSelectedBranches,
updateChanges,
updateCliError,
updateColumnOrder,
updateColumns,
updateColumnWidths,
updateFilters,
updateHasBranchesToSelect,
updateHasCheckpoints,
updateHasConfig,
updateHasMoreCommits,
updateHasRunningWorkspaceExperiment,
updateIsShowingMoreCommits,
updateRows,
updateSelectedForPlotsCount,
updateSorts,
updateShowOnlyChanged
} from '../state/tableDataSlice'
import { update } from '../state/tableDataSlice'
import { useVsCodeMessaging } from '../../shared/hooks/useVsCodeMessaging'
import { ExperimentsDispatch } from '../store'

const actionToDispatch = {
changes: updateChanges,
cliError: updateCliError,
columnOrder: updateColumnOrder,
columnWidths: updateColumnWidths,
columns: updateColumns,
filters: updateFilters,
hasBranchesToSelect: updateHasBranchesToSelect,
hasCheckpoints: updateHasCheckpoints,
hasConfig: updateHasConfig,
hasMoreCommits: updateHasMoreCommits,
hasRunningWorkspaceExperiment: updateHasRunningWorkspaceExperiment,
isShowingMoreCommits: updateIsShowingMoreCommits,
rows: updateRows,
selectedBranches: updateSelectedBranches,
selectedForPlotsCount: updateSelectedForPlotsCount,
showOnlyChanged: updateShowOnlyChanged,
sorts: updateSorts
} as const
import { dispatchAction } from '../../shared/dispatchAction'

const feedStore = (
data: MessageToWebview<TableData>,
Expand All @@ -56,30 +17,14 @@ const feedStore = (
if (data?.type !== MessageToWebviewType.SET_DATA) {
return
}
dispatch(update(!!data.data))
const stateUpdate = data?.data
dispatch(update(!!stateUpdate))

for (const key of Object.keys(data.data)) {
const tKey = key as keyof typeof data.data
const action = actionToDispatch[tKey]
const value = data.data[tKey]
if (!action) {
continue
}
dispatch(action(value as never))
}
dispatchAction('experiments', stateUpdate, dispatch)
}

export const App: React.FC<Record<string, unknown>> = () => {
const dispatch = useDispatch()

useVsCodeMessaging(
useCallback(
({ data }: { data: MessageToWebview<TableData> }) => {
feedStore(data, dispatch)
},
[dispatch]
)
)
useVsCodeMessaging(feedStore)

return <Experiments />
}
82 changes: 16 additions & 66 deletions webview/src/plots/components/App.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import React, { useCallback } from 'react'
import { useDispatch } from 'react-redux'
import React from 'react'
import {
PlotsData,
PlotsDataKeys,
Expand All @@ -8,30 +7,13 @@ import {
} from 'dvc/src/plots/webview/contract'
import { MessageToWebview } from 'dvc/src/webview/contract'
import { Plots } from './Plots'
import {
setCollapsed as setCustomPlotsCollapsed,
update as updateCustomPlots
} from './customPlots/customPlotsSlice'
import {
setCollapsed as setComparisonTableCollapsed,
updateShouldShowTooManyPlotsMessage as updateShouldShowTooManyImagesMessage,
update as updateComparisonTable
} from './comparisonTable/comparisonTableSlice'
import {
setCollapsed as setTemplatePlotsCollapsed,
updateShouldShowTooManyPlotsMessage as updateShouldShowTooManyTemplatesMessage,
update as updateTemplatePlots
} from './templatePlots/templatePlotsSlice'
import {
initialize,
updateCliError,
updateHasPlots,
updateHasUnselectedPlots,
updatePlotErrors,
updateSelectedRevisions
} from './webviewSlice'
import { setCollapsed as setCustomPlotsCollapsed } from './customPlots/customPlotsSlice'
import { setCollapsed as setComparisonTableCollapsed } from './comparisonTable/comparisonTableSlice'
import { setCollapsed as setTemplatePlotsCollapsed } from './templatePlots/templatePlotsSlice'
import { initialize } from './webviewSlice'
import { PlotsDispatch } from '../store'
import { useVsCodeMessaging } from '../../shared/hooks/useVsCodeMessaging'
import { dispatchAction } from '../../shared/dispatchAction'

const dispatchCollapsedSections = (
sections: SectionCollapsed,
Expand All @@ -46,60 +28,28 @@ const dispatchCollapsedSections = (
}
}

const actionToDispatch = {
[PlotsDataKeys.CLI_ERROR]: updateCliError,
[PlotsDataKeys.CUSTOM]: updateCustomPlots,
[PlotsDataKeys.COMPARISON]: updateComparisonTable,
[PlotsDataKeys.TEMPLATE]: updateTemplatePlots,
[PlotsDataKeys.HAS_PLOTS]: updateHasPlots,
[PlotsDataKeys.HAS_UNSELECTED_PLOTS]: updateHasUnselectedPlots,
[PlotsDataKeys.PLOT_ERRORS]: updatePlotErrors,
[PlotsDataKeys.SELECTED_REVISIONS]: updateSelectedRevisions,
[PlotsDataKeys.SHOW_TOO_MANY_TEMPLATE_PLOTS]:
updateShouldShowTooManyTemplatesMessage,
[PlotsDataKeys.SHOW_TOO_MANY_COMPARISON_IMAGES]:
updateShouldShowTooManyImagesMessage
} as const

export const feedStore = (
data: MessageToWebview<PlotsData>,
dispatch: PlotsDispatch
) => {
if (!data?.data) {
const stateUpdate = data?.data
if (!stateUpdate) {
return
}
dispatch(initialize())

const keys = Object.keys(data.data) as PlotsDataKeys[]
for (const key of keys) {
if (key === PlotsDataKeys.SECTION_COLLAPSED) {
dispatchCollapsedSections(
data.data[PlotsDataKeys.SECTION_COLLAPSED] as SectionCollapsed,
dispatch
)
continue
}

const action = actionToDispatch[key as keyof typeof actionToDispatch]
const value = data.data[key]
if (!action) {
continue
}
dispatch(action(value as never))
const keys = Object.keys(stateUpdate) as PlotsDataKeys[]
if (keys.includes(PlotsDataKeys.SECTION_COLLAPSED)) {
dispatchCollapsedSections(
stateUpdate[PlotsDataKeys.SECTION_COLLAPSED] as SectionCollapsed,
dispatch
)
}
dispatchAction('plots', stateUpdate, dispatch)
}

export const App = () => {
const dispatch = useDispatch()

useVsCodeMessaging(
useCallback(
({ data }: { data: MessageToWebview<PlotsData> }) => {
feedStore(data, dispatch)
},
[dispatch]
)
)
useVsCodeMessaging(feedStore)

return <Plots />
}
70 changes: 8 additions & 62 deletions webview/src/setup/components/App.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { SetupSection, SetupData } from 'dvc/src/setup/webview/contract'
import { MessageToWebview } from 'dvc/src/webview/contract'
import React, { useCallback } from 'react'
import React from 'react'
import { useDispatch, useSelector } from 'react-redux'
import { Dvc } from './dvc/Dvc'
import { Experiments } from './experiments/Experiments'
Expand All @@ -10,30 +10,10 @@ import { Remotes } from './remotes/Remotes'
import { useVsCodeMessaging } from '../../shared/hooks/useVsCodeMessaging'
import { TooltipIconType } from '../../shared/components/sectionContainer/InfoTooltip'
import { SetupDispatch, SetupState } from '../store'
import { initialize, updateSectionCollapsed } from '../state/webviewSlice'
import {
updateCanGitInitialize,
updateCliCompatible,
updateDvcCliDetails,
updateIsAboveLatestTestedVersion,
updateIsPythonEnvironmentGlobal,
updateIsPythonExtensionInstalled,
updateIsPythonExtensionUsed,
updateNeedsGitInitialized,
updateProjectInitialized,
updatePythonBinPath
} from '../state/dvcSlice'
import {
updateHasData as updateExperimentsHasData,
updateNeedsGitCommit
} from '../state/experimentsSlice'
import { updateRemoteList } from '../state/remoteSlice'
import {
updateIsStudioConnected,
updateSelfHostedStudioUrl,
updateShareLiveToStudio
} from '../state/studioSlice'
import { initialize } from '../state/webviewSlice'
import { updateShareLiveToStudio } from '../state/studioSlice'
import { setStudioShareExperimentsLive } from '../util/messages'
import { dispatchAction } from '../../shared/dispatchAction'

const getDvcStatusIcon = (
isDvcSetup: boolean,
Expand All @@ -56,44 +36,17 @@ const getStudioStatusIcon = (cliCompatible: boolean, isConnected: boolean) => {
return isConnected ? TooltipIconType.PASSED : TooltipIconType.WARNING
}

const actionToDispatch = {
canGitInitialize: updateCanGitInitialize,
cliCompatible: updateCliCompatible,
dvcCliDetails: updateDvcCliDetails,
hasData: updateExperimentsHasData,
isAboveLatestTestedVersion: updateIsAboveLatestTestedVersion,
isPythonEnvironmentGlobal: updateIsPythonEnvironmentGlobal,
isPythonExtensionInstalled: updateIsPythonExtensionInstalled,
isPythonExtensionUsed: updateIsPythonExtensionUsed,
isStudioConnected: updateIsStudioConnected,
needsGitCommit: updateNeedsGitCommit,
needsGitInitialized: updateNeedsGitInitialized,
projectInitialized: updateProjectInitialized,
pythonBinPath: updatePythonBinPath,
remoteList: updateRemoteList,
sectionCollapsed: updateSectionCollapsed,
selfHostedStudioUrl: updateSelfHostedStudioUrl,
shareLiveToStudio: updateShareLiveToStudio
} as const

export const feedStore = (
data: MessageToWebview<SetupData>,
dispatch: SetupDispatch
) => {
if (!data?.data) {
const stateUpdate = data?.data
if (!stateUpdate) {
return
}
dispatch(initialize())

for (const key of Object.keys(data.data)) {
const tKey = key as keyof typeof data.data
const action = actionToDispatch[tKey]
const value = data.data[tKey]
if (!action) {
continue
}
dispatch(action(value as never))
}
dispatchAction('setup', stateUpdate, dispatch)
}

export const App: React.FC = () => {
Expand All @@ -110,14 +63,7 @@ export const App: React.FC = () => {

const dispatch = useDispatch()

useVsCodeMessaging(
useCallback(
({ data }: { data: MessageToWebview<SetupData> }) => {
feedStore(data, dispatch)
},
[dispatch]
)
)
useVsCodeMessaging(feedStore)

const setShareLiveToStudio = (shouldShareLive: boolean) => {
dispatch(updateShareLiveToStudio(shouldShareLive))
Expand Down
Loading

0 comments on commit 3d929f1

Please sign in to comment.