fix job name for printers (#4234)
Signed-off-by: Jess Frazelle <github@jessfraz.com> Co-authored-by: Paul Tagliamonte <paul@zoo.dev>
This commit is contained in:
@ -69,7 +69,7 @@ import { exportFromEngine } from 'lib/exportFromEngine'
|
|||||||
import { Models } from '@kittycad/lib/dist/types/src'
|
import { Models } from '@kittycad/lib/dist/types/src'
|
||||||
import toast from 'react-hot-toast'
|
import toast from 'react-hot-toast'
|
||||||
import { EditorSelection, Transaction } from '@codemirror/state'
|
import { EditorSelection, Transaction } from '@codemirror/state'
|
||||||
import { useNavigate, useSearchParams } from 'react-router-dom'
|
import { useLoaderData, useNavigate, useSearchParams } from 'react-router-dom'
|
||||||
import { letEngineAnimateAndSyncCamAfter } from 'clientSideScene/CameraControls'
|
import { letEngineAnimateAndSyncCamAfter } from 'clientSideScene/CameraControls'
|
||||||
import { getVarNameModal } from 'hooks/useToolbarGuards'
|
import { getVarNameModal } from 'hooks/useToolbarGuards'
|
||||||
import { err, reportRejection, trap } from 'lib/trap'
|
import { err, reportRejection, trap } from 'lib/trap'
|
||||||
@ -84,6 +84,7 @@ import {
|
|||||||
import { submitAndAwaitTextToKcl } from 'lib/textToCad'
|
import { submitAndAwaitTextToKcl } from 'lib/textToCad'
|
||||||
import { useFileContext } from 'hooks/useFileContext'
|
import { useFileContext } from 'hooks/useFileContext'
|
||||||
import { uuidv4 } from 'lib/utils'
|
import { uuidv4 } from 'lib/utils'
|
||||||
|
import { IndexLoaderData } from 'lib/types'
|
||||||
|
|
||||||
type MachineContext<T extends AnyStateMachine> = {
|
type MachineContext<T extends AnyStateMachine> = {
|
||||||
state: StateFrom<T>
|
state: StateFrom<T>
|
||||||
@ -116,6 +117,7 @@ export const ModelingMachineProvider = ({
|
|||||||
} = useSettingsAuthContext()
|
} = useSettingsAuthContext()
|
||||||
const navigate = useNavigate()
|
const navigate = useNavigate()
|
||||||
const { context, send: fileMachineSend } = useFileContext()
|
const { context, send: fileMachineSend } = useFileContext()
|
||||||
|
const { file } = useLoaderData() as IndexLoaderData
|
||||||
const token = auth?.context?.token
|
const token = auth?.context?.token
|
||||||
const streamRef = useRef<HTMLDivElement>(null)
|
const streamRef = useRef<HTMLDivElement>(null)
|
||||||
const persistedContext = useMemo(() => getPersistedContext(), [])
|
const persistedContext = useMemo(() => getPersistedContext(), [])
|
||||||
@ -409,12 +411,15 @@ export const ModelingMachineProvider = ({
|
|||||||
Make: ({ event }) => {
|
Make: ({ event }) => {
|
||||||
if (event.type !== 'Make') return
|
if (event.type !== 'Make') return
|
||||||
// Check if we already have an export intent.
|
// Check if we already have an export intent.
|
||||||
if (engineCommandManager.exportIntent) {
|
if (engineCommandManager.exportInfo) {
|
||||||
toast.error('Already exporting')
|
toast.error('Already exporting')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
// Set the export intent.
|
// Set the export intent.
|
||||||
engineCommandManager.exportIntent = ExportIntent.Make
|
engineCommandManager.exportInfo = {
|
||||||
|
intent: ExportIntent.Make,
|
||||||
|
name: file?.name || '',
|
||||||
|
}
|
||||||
|
|
||||||
// Set the current machine.
|
// Set the current machine.
|
||||||
machineManager.currentMachine = event.data.machine
|
machineManager.currentMachine = event.data.machine
|
||||||
@ -443,12 +448,16 @@ export const ModelingMachineProvider = ({
|
|||||||
},
|
},
|
||||||
'Engine export': ({ event }) => {
|
'Engine export': ({ event }) => {
|
||||||
if (event.type !== 'Export') return
|
if (event.type !== 'Export') return
|
||||||
if (engineCommandManager.exportIntent) {
|
if (engineCommandManager.exportInfo) {
|
||||||
toast.error('Already exporting')
|
toast.error('Already exporting')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
// Set the export intent.
|
// Set the export intent.
|
||||||
engineCommandManager.exportIntent = ExportIntent.Save
|
engineCommandManager.exportInfo = {
|
||||||
|
intent: ExportIntent.Save,
|
||||||
|
// This never gets used its only for make.
|
||||||
|
name: '',
|
||||||
|
}
|
||||||
|
|
||||||
const format = {
|
const format = {
|
||||||
...event.data,
|
...event.data,
|
||||||
|
@ -50,6 +50,11 @@ export enum ExportIntent {
|
|||||||
Make = 'make',
|
Make = 'make',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface ExportInfo {
|
||||||
|
intent: ExportIntent
|
||||||
|
name: string
|
||||||
|
}
|
||||||
|
|
||||||
type ClientMetrics = Models['ClientMetrics_type']
|
type ClientMetrics = Models['ClientMetrics_type']
|
||||||
|
|
||||||
interface WebRTCClientMetrics extends ClientMetrics {
|
interface WebRTCClientMetrics extends ClientMetrics {
|
||||||
@ -1354,7 +1359,7 @@ export class EngineCommandManager extends EventTarget {
|
|||||||
* export in progress. Otherwise it is an enum value of the intent.
|
* export in progress. Otherwise it is an enum value of the intent.
|
||||||
* Another export cannot be started if one is already in progress.
|
* Another export cannot be started if one is already in progress.
|
||||||
*/
|
*/
|
||||||
private _exportIntent: ExportIntent | null = null
|
private _exportInfo: ExportInfo | null = null
|
||||||
_commandLogCallBack: (command: CommandLog[]) => void = () => {}
|
_commandLogCallBack: (command: CommandLog[]) => void = () => {}
|
||||||
|
|
||||||
subscriptions: {
|
subscriptions: {
|
||||||
@ -1410,12 +1415,12 @@ export class EngineCommandManager extends EventTarget {
|
|||||||
(() => {}) as any
|
(() => {}) as any
|
||||||
kclManager: null | KclManager = null
|
kclManager: null | KclManager = null
|
||||||
|
|
||||||
set exportIntent(intent: ExportIntent | null) {
|
set exportInfo(info: ExportInfo | null) {
|
||||||
this._exportIntent = intent
|
this._exportInfo = info
|
||||||
}
|
}
|
||||||
|
|
||||||
get exportIntent() {
|
get exportInfo() {
|
||||||
return this._exportIntent
|
return this._exportInfo
|
||||||
}
|
}
|
||||||
|
|
||||||
start({
|
start({
|
||||||
@ -1607,7 +1612,7 @@ export class EngineCommandManager extends EventTarget {
|
|||||||
// because in all other cases we send JSON strings. But in the case of
|
// because in all other cases we send JSON strings. But in the case of
|
||||||
// export we send a binary blob.
|
// export we send a binary blob.
|
||||||
// Pass this to our export function.
|
// Pass this to our export function.
|
||||||
if (this.exportIntent === null || this.pendingExport === undefined) {
|
if (this.exportInfo === null || this.pendingExport === undefined) {
|
||||||
toast.error(
|
toast.error(
|
||||||
'Export intent was not set, but export data was received'
|
'Export intent was not set, but export data was received'
|
||||||
)
|
)
|
||||||
@ -1617,7 +1622,7 @@ export class EngineCommandManager extends EventTarget {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (this.exportIntent) {
|
switch (this.exportInfo.intent) {
|
||||||
case ExportIntent.Save: {
|
case ExportIntent.Save: {
|
||||||
exportSave(event.data, this.pendingExport.toastId).then(() => {
|
exportSave(event.data, this.pendingExport.toastId).then(() => {
|
||||||
this.pendingExport?.resolve(null)
|
this.pendingExport?.resolve(null)
|
||||||
@ -1625,21 +1630,22 @@ export class EngineCommandManager extends EventTarget {
|
|||||||
break
|
break
|
||||||
}
|
}
|
||||||
case ExportIntent.Make: {
|
case ExportIntent.Make: {
|
||||||
exportMake(event.data, this.pendingExport.toastId).then(
|
exportMake(
|
||||||
(result) => {
|
event.data,
|
||||||
if (result) {
|
this.exportInfo.name,
|
||||||
this.pendingExport?.resolve(null)
|
this.pendingExport.toastId
|
||||||
} else {
|
).then((result) => {
|
||||||
this.pendingExport?.reject('Failed to make export')
|
if (result) {
|
||||||
}
|
this.pendingExport?.resolve(null)
|
||||||
},
|
} else {
|
||||||
this.pendingExport?.reject
|
this.pendingExport?.reject('Failed to make export')
|
||||||
)
|
}
|
||||||
|
}, this.pendingExport?.reject)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Set the export intent back to null.
|
// Set the export intent back to null.
|
||||||
this.exportIntent = null
|
this.exportInfo = null
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1953,15 +1959,15 @@ export class EngineCommandManager extends EventTarget {
|
|||||||
return Promise.resolve(null)
|
return Promise.resolve(null)
|
||||||
} else if (cmd.type === 'export') {
|
} else if (cmd.type === 'export') {
|
||||||
const promise = new Promise<null>((resolve, reject) => {
|
const promise = new Promise<null>((resolve, reject) => {
|
||||||
if (this.exportIntent === null) {
|
if (this.exportInfo === null) {
|
||||||
if (this.exportIntent === null) {
|
if (this.exportInfo === null) {
|
||||||
toast.error('Export intent was not set, but export is being sent')
|
toast.error('Export intent was not set, but export is being sent')
|
||||||
console.error('Export intent was not set, but export is being sent')
|
console.error('Export intent was not set, but export is being sent')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const toastId = toast.loading(
|
const toastId = toast.loading(
|
||||||
this.exportIntent === ExportIntent.Save
|
this.exportInfo.intent === ExportIntent.Save
|
||||||
? EXPORT_TOAST_MESSAGES.START
|
? EXPORT_TOAST_MESSAGES.START
|
||||||
: MAKE_TOAST_MESSAGES.START
|
: MAKE_TOAST_MESSAGES.START
|
||||||
)
|
)
|
||||||
@ -1975,7 +1981,7 @@ export class EngineCommandManager extends EventTarget {
|
|||||||
resolve(passThrough)
|
resolve(passThrough)
|
||||||
},
|
},
|
||||||
reject: (reason: string) => {
|
reject: (reason: string) => {
|
||||||
this.exportIntent = null
|
this.exportInfo = null
|
||||||
reject(reason)
|
reject(reason)
|
||||||
},
|
},
|
||||||
commandId: command.cmd_id,
|
commandId: command.cmd_id,
|
||||||
|
@ -92,6 +92,7 @@ export const MAKE_TOAST_MESSAGES = {
|
|||||||
NO_MACHINE_API_IP: 'No machine api ip available',
|
NO_MACHINE_API_IP: 'No machine api ip available',
|
||||||
NO_CURRENT_MACHINE: 'No current machine available',
|
NO_CURRENT_MACHINE: 'No current machine available',
|
||||||
NO_MACHINE_ID: 'No machine id available',
|
NO_MACHINE_ID: 'No machine id available',
|
||||||
|
NO_NAME: 'No name provided',
|
||||||
ERROR_STARTING_PRINT: 'Error while starting print',
|
ERROR_STARTING_PRINT: 'Error while starting print',
|
||||||
SUCCESS: 'Started print successfully',
|
SUCCESS: 'Started print successfully',
|
||||||
}
|
}
|
||||||
|
@ -8,8 +8,15 @@ import { MAKE_TOAST_MESSAGES } from './constants'
|
|||||||
// Make files locally from an export call.
|
// Make files locally from an export call.
|
||||||
export async function exportMake(
|
export async function exportMake(
|
||||||
data: ArrayBuffer,
|
data: ArrayBuffer,
|
||||||
|
name: string,
|
||||||
toastId: string
|
toastId: string
|
||||||
): Promise<Response | null> {
|
): Promise<Response | null> {
|
||||||
|
if (name === '') {
|
||||||
|
console.error(MAKE_TOAST_MESSAGES.NO_NAME)
|
||||||
|
toast.error(MAKE_TOAST_MESSAGES.NO_NAME, { id: toastId })
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
if (machineManager.machineCount() === 0) {
|
if (machineManager.machineCount() === 0) {
|
||||||
console.error(MAKE_TOAST_MESSAGES.NO_MACHINES)
|
console.error(MAKE_TOAST_MESSAGES.NO_MACHINES)
|
||||||
toast.error(MAKE_TOAST_MESSAGES.NO_MACHINES, { id: toastId })
|
toast.error(MAKE_TOAST_MESSAGES.NO_MACHINES, { id: toastId })
|
||||||
@ -39,7 +46,7 @@ export async function exportMake(
|
|||||||
|
|
||||||
const params: components['schemas']['PrintParameters'] = {
|
const params: components['schemas']['PrintParameters'] = {
|
||||||
machine_id: machineId,
|
machine_id: machineId,
|
||||||
job_name: 'Exported Job', // TODO: make this the project name.
|
job_name: name,
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
console.log('params', params)
|
console.log('params', params)
|
||||||
|
Reference in New Issue
Block a user