Files
modeling-app/src/components/Providers/SystemIOProviderDesktop.tsx

51 lines
1.7 KiB
TypeScript
Raw Normal View History

2025-04-09 09:46:30 -05:00
import { PATHS } from '@src/lib/paths'
import { systemIOActor } from '@src/machines/appMachine'
import { useSelector } from '@xstate/react'
import { useEffect } from 'react'
import { useNavigate } from 'react-router-dom'
2025-04-14 11:56:28 -06:00
export const useRequestedProjectName = () =>
useSelector(systemIOActor, (state) => state.context.requestedProjectName)
export const useRequestedFileName = () =>
useSelector(systemIOActor, (state) => state.context.requestedFileName)
2025-04-14 11:56:28 -06:00
export const useProjectDirectoryPath = () =>
useSelector(systemIOActor, (state) => state.context.projectDirectoryPath)
2025-04-09 09:46:30 -05:00
export function SystemIOMachineLogicListener() {
const requestedProjectName = useRequestedProjectName()
const requestedFileName = useRequestedFileName()
const projectDirectoryPath = useProjectDirectoryPath()
const navigate = useNavigate()
// Handle global project name navigation
2025-04-09 09:46:30 -05:00
useEffect(() => {
2025-04-14 11:56:28 -06:00
if (!requestedProjectName.name) {
return
}
let projectPathWithoutSpecificKCLFile =
2025-04-14 11:56:28 -06:00
projectDirectoryPath +
window.electron.path.sep +
requestedProjectName.name
const requestedPath = `${PATHS.FILE}/${encodeURIComponent(
2025-04-14 11:56:28 -06:00
projectPathWithoutSpecificKCLFile
)}`
navigate(requestedPath)
}, [requestedProjectName])
// Handle global file name navigation
useEffect(() => {
if (!requestedFileName.file || !requestedFileName.project) {
return
}
const projectPath = window.electron.join(
projectDirectoryPath,
requestedFileName.project
)
2025-04-14 15:04:07 -06:00
const filePath = window.electron.join(projectPath, requestedFileName.file)
const requestedPath = `${PATHS.FILE}/${encodeURIComponent(filePath)}`
navigate(requestedPath)
}, [requestedFileName])
2025-04-09 09:46:30 -05:00
return null
}