Files
modeling-app/src/hooks/useMenu.ts
Kevin Nadro 305d613d40 Nadro/adhoc/system io machine (#6352)
* chore: saving off skeleton

* fix: saving skeleton

* chore: skeleton for loading projects from project directory path

* chore: cleaning up useless state transition to be an on event direct to action state

* fix: new structure for web vs desktop vs react machine provider code

* chore: saving off skeleton

* fix: skeleton logic for react? going to move it from a string to obj.string

* fix: trying to prevent error element unmount on global react components. This is bricking JS state

* fix: we are so back

* chore: implemented navigating to specfic KCL file

* chore: implementing renaming project

* chore: deleting project

* fix: auto fixes

* fix: old debug/testing file oops

* chore: generic create new file

* chore: skeleton for web create file provide

* chore: basic machine vitest... need to figure out how to get window.electron implemented in vitest?

* chore: save off progress before deleting other project implementation, a few missing features still

* chore: trying a different init skeleton? most likely will migrate

* chore: first attempt of purging projects context provider

* chore: enabling toast for some machine state

* chore: enabling more toast success and error

* chore: writing read write state to the system io based on the project path

* fix: tsc fixes

* fix: use file system watcher, navigate to project after creation via the requestProjectName

* chore: open project command, hooks vs snapshot context helpers

* chore: implemented open and create project for e2e testing. They are hard coded in poor spot for now.

* fix: codespell fixes

* chore: implementing more project commands

* chore: PR improvements for root.tsx

* chore: leaving comment about new Router.tsx layout

* fix: removing debugging code

* fix: rewriting component for readability

* fix: improving web initialization

* chore: implementing import file from url which is not actually that?

* fix: clearing search params on import file from url

* fix: fixed two e2e tests, forgot needsReview when making new command

* fix: fixing some import from url business logic to pass e2e tests

* chore: script for diffing circular deps +/-

* fix: formatting

* fix: massive fix for circular depsga!

* fix: trying to fix some errors and auto fmt

* fix: updating deps

* fix: removing debugging code

* fix: big clean up

* fix: more deletion

* fix: tsc cleanup

* fix: TSC TSC TSC TSC!

* fix: typo fix

* fix: clear query params on web only, desktop not required

* fix: removing unused code

* fmt

* Bring back `trap` removed in merge

* Use explicit types instead of `any`s on arg configs

* Add project commands directly to command palette

* fix: deleting debugging code, from PR review

* fix: this got added back(?)

* fix: using referred type

* fix: more PR clean up

* fix: big block comment for xstate architecture decision

* fix: more pr comment fixes

* fix: merge conflict just added them back why dude

* fix: more PR comments

* fix: big ciruclar deps fix, commandBarActor in appActor

---------

Co-authored-by: Frank Noirot <frankjohnson1993@gmail.com>
2025-04-24 13:32:49 -05:00

96 lines
3.1 KiB
TypeScript

import { NetworkHealthState } from '@src/hooks/useNetworkStatus'
import { isDesktop } from '@src/lib/isDesktop'
import type { ToolbarModeName } from '@src/lib/toolbar'
import { reportRejection } from '@src/lib/trap'
import { useCommandBarState } from '@src/lib/singletons'
import type { MenuLabels, WebContentSendPayload } from '@src/menu/channels'
import { useEffect } from 'react'
export function useMenuListener(
callback: (data: WebContentSendPayload) => void
) {
useEffect(() => {
const onDesktop = isDesktop()
if (!onDesktop) {
// NO OP for web
return
}
const removeListener = window.electron.menuOn(callback)
return () => {
if (!onDesktop) {
// NO OP for web
return
}
removeListener()
}
}, [])
}
// Enable disable menu actions specifically based on if you are in the modeling mode of sketching or modeling.
// This is a similar behavior of the command bar which disables action if you are in sketch mode
export function useSketchModeMenuEnableDisable(
currentMode: ToolbarModeName,
overallState: NetworkHealthState,
isExecuting: boolean,
isStreamReady: boolean,
menus: { menuLabel: MenuLabels; commandName?: string; groupId?: string }[]
) {
const commandBarState = useCommandBarState()
const commands = commandBarState.context.commands
useEffect(() => {
const onDesktop = isDesktop()
if (!onDesktop) {
// NO OP for web
return
}
// Same exact logic as the command bar
const disableAllButtons =
(overallState !== NetworkHealthState.Ok &&
overallState !== NetworkHealthState.Weak) ||
isExecuting ||
!isStreamReady
// Enable or disable each menu based on the state of the application.
menus.forEach(({ menuLabel, commandName, groupId }) => {
// If someone goes wrong, disable all the buttons! Engine cannot take this request
if (disableAllButtons) {
window.electron.disableMenu(menuLabel).catch(reportRejection)
return
}
if (commandName && groupId) {
// If your menu is tied to a command bar action, see if the command exists in the command bar
const foundCommand = commands.find((command) => {
return command.name === commandName && command.groupId === groupId
})
if (!foundCommand) {
window.electron.disableMenu(menuLabel).catch(reportRejection)
} else {
if (currentMode === 'sketching') {
window.electron.disableMenu(menuLabel).catch(reportRejection)
} else if (currentMode === 'modeling') {
window.electron.enableMenu(menuLabel).catch(reportRejection)
}
}
} else {
// menu is not tied to a command bar, do the sketch mode check
if (currentMode === 'sketching') {
window.electron.disableMenu(menuLabel).catch(reportRejection)
} else if (currentMode === 'modeling') {
window.electron.enableMenu(menuLabel).catch(reportRejection)
}
}
})
return () => {
if (!onDesktop) {
// NO OP for web
return
}
}
}, [currentMode, commands])
}