Move viewport state into openscad controller

This commit is contained in:
Kurt Hutten
2021-03-14 17:41:29 +11:00
parent 785025fca8
commit b6867fc8a8
4 changed files with 112 additions and 102 deletions

View File

@@ -2,35 +2,35 @@ let openScadBaseURL =
process.env.OPENSCAD_BASE_URL ||
'https://x2wvhihk56.execute-api.us-east-1.amazonaws.com/dev'
let lastCameraSettings = {
position: {
x: 200,
y: -20,
z: 140,
},
rotation: {
x: 55,
y: 3.8,
z: 84,
},
dist: 245,
}
let lastViewPortSize = 'INIT'
let lastCameraSettings = 'INIT'
export const render = async ({ code, settings }) => {
console.log('from render', settings)
const body = JSON.stringify({
settings: {
size: {
x: settings.viewerSize?.width,
y: settings.viewerSize?.height,
},
camera: settings.camera || lastCameraSettings,
},
file: code,
})
const size = settings.viewerSize
? {
x: Math.round(settings.viewerSize?.width),
y: Math.round(settings.viewerSize?.height),
}
: lastViewPortSize
const camera = settings.camera || lastCameraSettings
if (settings.camera) {
lastCameraSettings = settings.camera
}
if (settings.viewerSize) {
lastViewPortSize = size
}
if ([camera, size].includes('INIT')) {
return {
status: 'insufficient-preview-info',
}
}
const body = JSON.stringify({
settings: {
size,
camera,
},
file: code,
})
try {
const response = await fetch(openScadBaseURL + '/render', {
method: 'POST',
@@ -46,7 +46,7 @@ export const render = async ({ code, settings }) => {
"'main.scad'"
)
return {
isError: true,
status: 'error',
message: {
type: 'error',
message: cleanedErrorMessage,
@@ -55,6 +55,7 @@ export const render = async ({ code, settings }) => {
}
const data = await response.blob()
return {
status: 'healthy',
objectData: {
type: 'png',
data,
@@ -70,7 +71,7 @@ export const render = async ({ code, settings }) => {
// and in future I think we need timeouts differently as they maybe from a user trying to render something too complex
// or something with minkowski in it :/ either way something like "render timed out, try again or here are tips to reduce part complexity" with a link talking about $fn and minkowski etc
return {
isError: true,
status: 'error',
message: {
type: 'error',
message: 'network issue',

View File

@@ -71,11 +71,6 @@ export const useIdeState = () => {
...state,
layout: payload.message,
}
case 'setViewerSize':
return {
...state,
viewerSize: payload.message,
}
case 'setLoading':
return {
...state,
@@ -95,11 +90,12 @@ export const useIdeState = () => {
code: payload.code,
settings: {
camera: payload.camera,
viewerSize: state.viewerSize,
viewerSize: payload.viewerSize,
},
})
.then(({ objectData, message, isError }) => {
if (isError) {
.then(({ objectData, message, status }) => {
if (status === 'insufficient-preview-info') return
if (status === 'error') {
dispatch({
type: 'errorRender',
payload: { message },