* 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: saving off logic, need a big cleanup because I hacked it together to get a POC * fix: extra business? * fix: merge conflict just added them back why dude * fix: more PR comments * fix: big ciruclar deps fix, commandBarActor in appActor * chore: writing e2e test, still need to fix 3 bugs * chore: adding more scenarios * fix: formatting * fix: fixing tsc errors * chore: deleting the old text to cad and using the new application level one, almost there * fix: prompt to edit works * fix: large push to get 1 text to cad command... the usage is a little buggy with delete and navigate within /file * fix: settings for highlight edges now works * chore: adding another e2e test * fix: cleaning up e2e tests and writing more of them * fix: tsc type * chore: more e2e improvements, unique project name in text to cad * chore: e2e tests should be good to go * fix: gotcha comment * fix: enabled web t2c, codespell fixes * fix: fixing merge conflcits?? * fix: t2c is back * Remove spaces in command bar test * fmt --------- Co-authored-by: Frank Noirot <frankjohnson1993@gmail.com> Co-authored-by: lee-at-zoo-corp <lee@zoo.dev>
84 lines
2.6 KiB
TypeScript
84 lines
2.6 KiB
TypeScript
import type { systemIOMachine } from '@src/machines/systemIO/systemIOMachine'
|
|
import type { ActorRefFrom } from 'xstate'
|
|
import type { Command, CommandArgumentOption } from '@src/lib/commandTypes'
|
|
import { SystemIOMachineEvents } from '@src/machines/systemIO/utils'
|
|
import { isDesktop } from '@src/lib/isDesktop'
|
|
|
|
export function createApplicationCommands({
|
|
systemIOActor,
|
|
}: {
|
|
systemIOActor: ActorRefFrom<typeof systemIOMachine>
|
|
}) {
|
|
const textToCADCommand: Command = {
|
|
name: 'Text-to-CAD',
|
|
description: 'Use the Zoo Text-to-CAD API to generate part starters.',
|
|
displayName: `Text to CAD`,
|
|
groupId: 'application',
|
|
needsReview: false,
|
|
icon: 'sparkles',
|
|
onSubmit: (record) => {
|
|
if (record) {
|
|
const requestedProjectName = record.newProjectName || record.projectName
|
|
const requestedPrompt = record.prompt
|
|
const isProjectNew = !!record.newProjectName
|
|
systemIOActor.send({
|
|
type: SystemIOMachineEvents.generateTextToCAD,
|
|
data: { requestedPrompt, requestedProjectName, isProjectNew },
|
|
})
|
|
}
|
|
},
|
|
args: {
|
|
method: {
|
|
inputType: 'options',
|
|
required: true,
|
|
skip: true,
|
|
options: isDesktop()
|
|
? [
|
|
{ name: 'New project', value: 'newProject' },
|
|
{ name: 'Existing project', value: 'existingProject' },
|
|
]
|
|
: [{ name: 'Overwrite', value: 'existingProject' }],
|
|
valueSummary(value) {
|
|
return isDesktop()
|
|
? value === 'newProject'
|
|
? 'New project'
|
|
: 'Existing project'
|
|
: 'Overwrite'
|
|
},
|
|
},
|
|
projectName: {
|
|
inputType: 'options',
|
|
required: (commandsContext) =>
|
|
isDesktop() &&
|
|
commandsContext.argumentsToSubmit.method === 'existingProject',
|
|
skip: true,
|
|
options: (_, context) => {
|
|
const { folders } = systemIOActor.getSnapshot().context
|
|
const options: CommandArgumentOption<string>[] = []
|
|
folders.forEach((folder) => {
|
|
options.push({
|
|
name: folder.name,
|
|
value: folder.name,
|
|
isCurrent: false,
|
|
})
|
|
})
|
|
return options
|
|
},
|
|
},
|
|
newProjectName: {
|
|
inputType: 'text',
|
|
required: (commandsContext) =>
|
|
isDesktop() &&
|
|
commandsContext.argumentsToSubmit.method === 'newProject',
|
|
skip: true,
|
|
},
|
|
prompt: {
|
|
inputType: 'text',
|
|
required: true,
|
|
},
|
|
},
|
|
}
|
|
|
|
return isDesktop() ? [textToCADCommand] : [textToCADCommand]
|
|
}
|