import { useState, useEffect } from 'react' import { create } from 'react-modal-promise' import { toolTips, useStore } from '../../useStore' import { Value } from '../../lang/wasm' import { getNodePathFromSourceRange, getNodeFromPath, } from '../../lang/queryAst' import { TransformInfo, getTransformInfos, transformAstSketchLines, } from '../../lang/std/sketchcombos' import { SetAngleLengthModal } from '../SetAngleLengthModal' import { createBinaryExpressionWithUnary, createIdentifier, createVariableDeclaration, } from '../../lang/modifyAst' import { removeDoubleNegatives } from '../AvailableVarsHelpers' import { normaliseAngle } from '../../lib/utils' import { updateCursors } from '../../lang/util' const getModalInfo = create(SetAngleLengthModal as any) type ButtonType = 'setAngle' | 'setLength' const buttonLabels: Record = { setAngle: 'Set Angle', setLength: 'Set Length', } export const SetAngleLength = ({ angleOrLength, }: { angleOrLength: ButtonType }) => { const { guiMode, selectionRanges, ast, programMemory, updateAst, setCursor } = useStore((s) => ({ guiMode: s.guiMode, ast: s.ast, updateAst: s.updateAst, selectionRanges: s.selectionRanges, programMemory: s.programMemory, setCursor: s.setCursor, })) const [enableAngLen, setEnableAngLen] = useState(false) const [transformInfos, setTransformInfos] = useState() useEffect(() => { if (!ast) return const paths = selectionRanges.codeBasedSelections.map(({ range }) => getNodePathFromSourceRange(ast, range) ) const nodes = paths.map( (pathToNode) => getNodeFromPath(ast, pathToNode, 'CallExpression').node ) const isAllTooltips = nodes.every( (node) => node?.type === 'CallExpression' && toolTips.includes(node.callee.name as any) ) const theTransforms = getTransformInfos(selectionRanges, ast, angleOrLength) setTransformInfos(theTransforms) const _enableHorz = isAllTooltips && theTransforms.every(Boolean) setEnableAngLen(_enableHorz) }, [guiMode, selectionRanges]) if (guiMode.mode !== 'sketch') return null return ( ) }