2023-08-06 21:29:26 -04:00
|
|
|
import { CollapsiblePanel, CollapsiblePanelProps } from './CollapsiblePanel'
|
2023-07-21 16:53:06 +10:00
|
|
|
import { v4 as uuidv4 } from 'uuid'
|
|
|
|
import { EngineCommand } from '../lang/std/engineConnection'
|
|
|
|
import { useState } from 'react'
|
|
|
|
import { ActionButton } from '../components/ActionButton'
|
|
|
|
import { faCheck } from '@fortawesome/free-solid-svg-icons'
|
2023-08-28 18:48:31 +10:00
|
|
|
import { isReducedMotion } from 'lang/util'
|
2023-09-14 08:51:23 +10:00
|
|
|
import { AstExplorer } from './AstExplorer'
|
2023-09-25 19:49:53 -07:00
|
|
|
import { engineCommandManager } from '../lang/std/engineConnection'
|
2023-07-21 16:53:06 +10:00
|
|
|
|
2023-08-02 15:41:59 +10:00
|
|
|
type SketchModeCmd = Extract<
|
2023-08-18 08:12:32 -07:00
|
|
|
Extract<EngineCommand, { type: 'modeling_cmd_req' }>['cmd'],
|
2023-08-02 15:41:59 +10:00
|
|
|
{ type: 'default_camera_enable_sketch_mode' }
|
|
|
|
>
|
2023-07-21 16:53:06 +10:00
|
|
|
|
2023-08-06 21:29:26 -04:00
|
|
|
export const DebugPanel = ({ className, ...props }: CollapsiblePanelProps) => {
|
2023-07-21 16:53:06 +10:00
|
|
|
const [sketchModeCmd, setSketchModeCmd] = useState<SketchModeCmd>({
|
2023-08-02 15:41:59 +10:00
|
|
|
type: 'default_camera_enable_sketch_mode',
|
2023-07-21 16:53:06 +10:00
|
|
|
origin: { x: 0, y: 0, z: 0 },
|
|
|
|
x_axis: { x: 1, y: 0, z: 0 },
|
|
|
|
y_axis: { x: 0, y: 1, z: 0 },
|
|
|
|
distance_to_plane: 100,
|
|
|
|
ortho: true,
|
2023-08-28 18:48:31 +10:00
|
|
|
animated: !isReducedMotion(),
|
2023-07-21 16:53:06 +10:00
|
|
|
})
|
|
|
|
if (!sketchModeCmd) return null
|
|
|
|
return (
|
2023-08-06 21:29:26 -04:00
|
|
|
<CollapsiblePanel
|
|
|
|
{...props}
|
2023-09-20 05:36:29 -04:00
|
|
|
className={
|
|
|
|
'!absolute overflow-hidden !h-auto bottom-5 right-5 ' + className
|
|
|
|
}
|
|
|
|
// header height, top-5, and bottom-5
|
|
|
|
style={{ maxHeight: 'calc(100% - 3rem - 1.25rem - 1.25rem)' }}
|
2023-08-06 21:29:26 -04:00
|
|
|
>
|
|
|
|
<section className="p-4 flex flex-col gap-4">
|
|
|
|
<Xyz
|
|
|
|
onChange={setSketchModeCmd}
|
|
|
|
pointKey="origin"
|
|
|
|
data={sketchModeCmd}
|
|
|
|
/>
|
|
|
|
<Xyz
|
|
|
|
onChange={setSketchModeCmd}
|
|
|
|
pointKey="x_axis"
|
|
|
|
data={sketchModeCmd}
|
|
|
|
/>
|
|
|
|
<Xyz
|
|
|
|
onChange={setSketchModeCmd}
|
|
|
|
pointKey="y_axis"
|
|
|
|
data={sketchModeCmd}
|
2023-07-21 16:53:06 +10:00
|
|
|
/>
|
2023-08-06 21:29:26 -04:00
|
|
|
<div className="flex">
|
|
|
|
<div className="pr-4">distance_to_plane</div>
|
|
|
|
<input
|
|
|
|
className="w-16 dark:bg-chalkboard-90"
|
|
|
|
type="number"
|
|
|
|
value={sketchModeCmd.distance_to_plane}
|
|
|
|
onChange={({ target }) => {
|
|
|
|
setSketchModeCmd({
|
|
|
|
...sketchModeCmd,
|
|
|
|
distance_to_plane: Number(target.value),
|
|
|
|
})
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
<div className="pr-4">ortho</div>
|
|
|
|
<input
|
|
|
|
className="w-16"
|
|
|
|
type="checkbox"
|
|
|
|
checked={sketchModeCmd.ortho}
|
2023-09-25 17:28:03 +10:00
|
|
|
onChange={(a) =>
|
2023-08-06 21:29:26 -04:00
|
|
|
setSketchModeCmd({
|
|
|
|
...sketchModeCmd,
|
|
|
|
ortho: a.target.checked,
|
|
|
|
})
|
2023-09-25 17:28:03 +10:00
|
|
|
}
|
2023-08-06 21:29:26 -04:00
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<ActionButton
|
2023-08-15 21:56:24 -04:00
|
|
|
Element="button"
|
2023-08-06 21:29:26 -04:00
|
|
|
onClick={() => {
|
2023-09-25 19:49:53 -07:00
|
|
|
engineCommandManager.sendSceneCommand({
|
2023-08-06 21:29:26 -04:00
|
|
|
type: 'modeling_cmd_req',
|
|
|
|
cmd: sketchModeCmd,
|
|
|
|
cmd_id: uuidv4(),
|
2023-07-21 16:53:06 +10:00
|
|
|
})
|
|
|
|
}}
|
2023-08-06 21:29:26 -04:00
|
|
|
className="hover:border-succeed-50"
|
|
|
|
icon={{
|
|
|
|
icon: faCheck,
|
|
|
|
bgClassName:
|
|
|
|
'bg-succeed-80 group-hover:bg-succeed-70 hover:bg-succeed-70',
|
|
|
|
iconClassName:
|
|
|
|
'text-succeed-20 group-hover:text-succeed-10 hover:text-succeed-10',
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
Send sketch mode command
|
|
|
|
</ActionButton>
|
2023-09-14 08:51:23 +10:00
|
|
|
<div style={{ height: '400px' }} className="overflow-y-auto">
|
|
|
|
<AstExplorer />
|
|
|
|
</div>
|
2023-08-06 21:29:26 -04:00
|
|
|
</section>
|
|
|
|
</CollapsiblePanel>
|
2023-07-21 16:53:06 +10:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
const Xyz = ({
|
|
|
|
pointKey,
|
|
|
|
data,
|
|
|
|
onChange,
|
|
|
|
}: {
|
|
|
|
pointKey: 'origin' | 'y_axis' | 'x_axis'
|
|
|
|
data: SketchModeCmd
|
|
|
|
onChange: (a: SketchModeCmd) => void
|
|
|
|
}) => {
|
|
|
|
if (!data) return null
|
|
|
|
return (
|
|
|
|
<div className="flex">
|
|
|
|
<div className="pr-4">{pointKey}</div>
|
|
|
|
{Object.entries(data[pointKey]).map(([axis, val]) => {
|
|
|
|
return (
|
|
|
|
<div key={axis} className="flex">
|
|
|
|
<div className="w-4">{axis}</div>
|
|
|
|
<input
|
2023-08-06 21:29:26 -04:00
|
|
|
className="w-16 dark:bg-chalkboard-90"
|
2023-07-21 16:53:06 +10:00
|
|
|
type="number"
|
|
|
|
value={val}
|
|
|
|
onChange={({ target }) => {
|
|
|
|
onChange({
|
|
|
|
...data,
|
|
|
|
[pointKey]: {
|
|
|
|
...data[pointKey],
|
|
|
|
[axis]: Number(target.value),
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
})}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|