import { ONBOARDING_PROJECT_NAME, OnboardingButtons, onboardingPaths, useDismiss, useNextClick, } from '.' import { useGlobalStateContext } from 'hooks/useGlobalStateContext' import { Themes, getSystemTheme } from 'lib/theme' import { bracket } from 'lib/exampleKcl' import { PROJECT_ENTRYPOINT, createNewProject, getNextProjectIndex, getProjectsInDir, interpolateProjectNameWithIndex, } from 'lib/tauriFS' import { isTauri } from 'lib/isTauri' import { useNavigate } from 'react-router-dom' import { paths } from 'Router' import { useEffect } from 'react' import { kclManager } from 'lang/KclSinglton' import { sep } from '@tauri-apps/api/path' function OnboardingWithNewFile() { const navigate = useNavigate() const dismiss = useDismiss() const next = useNextClick(onboardingPaths.INDEX) const { settings: { context: { defaultDirectory }, }, } = useGlobalStateContext() async function createAndOpenNewProject() { const projects = await getProjectsInDir(defaultDirectory) const nextIndex = await getNextProjectIndex( ONBOARDING_PROJECT_NAME, projects ) const name = interpolateProjectNameWithIndex( ONBOARDING_PROJECT_NAME, nextIndex ) const newFile = await createNewProject( defaultDirectory + sep + name, bracket ) navigate( `${paths.FILE}/${encodeURIComponent( newFile.path + sep + PROJECT_ENTRYPOINT )}${paths.ONBOARDING.INDEX}` ) } return (
{!isTauri() ? ( <>

Replaying onboarding resets your code

We see you have some of your own code written in this project. Please save it somewhere else before continuing the onboarding.

{ kclManager.setCodeAndExecute(bracket) next() }} nextText="Overwrite code and continue" /> ) : ( <>

Would you like to create a new project?

You have some content in this project that we don't want to overwrite. If you would like to create a new project, please click the button below.

{ void createAndOpenNewProject() kclManager.setCode(bracket, false) dismiss() }} nextText="Make a new project" /> )}
) } export default function Introduction() { const { settings: { state: { context: { theme }, }, }, } = useGlobalStateContext() const getLogoTheme = () => theme === Themes.Light || (theme === Themes.System && getSystemTheme() === Themes.Light) ? '-dark' : '' const dismiss = useDismiss() const next = useNextClick(onboardingPaths.CAMERA) const isStarterCode = kclManager.code === '' || kclManager.code === bracket useEffect(() => { if (kclManager.code === '') kclManager.setCode(bracket) }, []) return isStarterCode ? (

KittyCAD Modeling App Alpha

Welcome to KittyCAD Modeling App! This is a hardware design tool that lets you edit visually, with code, or both. It's powered by the first API created for anyone to build hardware design tools. The 3D view is not running on your computer, but is instead being streamed to you from a remote GPU as video.

This is an alpha release, so you will encounter bugs and missing features. You can read our{' '} expectations for alpha users here . Please give us feedback on your experience! We are trying to release as early as possible to get feedback from users like you.

) : ( ) }