diff --git a/.github/actions/setup-project/action.yml b/.github/actions/setup-project/action.yml index dcd7280..0822bec 100644 --- a/.github/actions/setup-project/action.yml +++ b/.github/actions/setup-project/action.yml @@ -10,15 +10,11 @@ inputs: description: Version of Node to install default: 20.x - with-webui: - description: If the setup should prepare the web UI - type: boolean - runs: using: composite steps: - name: ๐Ÿ— Setup Node - uses: oven-sh/setup-bun@v1 + uses: oven-sh/setup-bun@v2 with: bun-version: ${{ inputs.bun-version }} @@ -31,18 +27,12 @@ runs: run: bun install shell: bash - - name: ๐Ÿ“ฆ Install webui dependencies - if: ${{ inputs.with-webui == 'true' }} - run: bun install - working-directory: webui - shell: bash - - - name: โ™ป๏ธ Restore webui cache + - name: โ™ป๏ธ Restore Metro cache if: ${{ inputs.with-webui == 'true' }} uses: actions/cache@v4 with: - key: webui-metro-${{ runner.os }}-${{ github.sha }} + key: metro-${{ runner.os }}-${{ github.sha }} restore-keys: | - webui-metro-${{ runner.os }} + metro-${{ runner.os }} path: | - webui/node_modules/.cache/metro + packages/expo-atlas-ui/node_modules/.cache/metro diff --git a/.github/workflows/review.yml b/.github/workflows/review.yml index 46296a9..1c42314 100644 --- a/.github/workflows/review.yml +++ b/.github/workflows/review.yml @@ -12,7 +12,7 @@ concurrency: cancel-in-progress: true jobs: - core: + test: runs-on: ubuntu-latest steps: - name: ๐Ÿ— Setup repo @@ -21,19 +21,16 @@ jobs: - name: ๐Ÿ— Setup project uses: ./.github/actions/setup-project - - name: ๐Ÿšจ Lint core - run: bun run lint -- --max-warnings 0 + - name: ๐Ÿšจ Lint project + run: bun run lint - - name: ๐Ÿ“‹ Typecheck core + - name: ๐Ÿ“‹ Typecheck project run: bun run typecheck - - name: ๐Ÿงช Test core - run: bun test + - name: ๐Ÿงช Test project + run: bun run test - - name: ๐Ÿ‘ท Build core - run: bun run build - - webui: + ui: runs-on: ubuntu-latest steps: - name: ๐Ÿ— Setup repo @@ -41,19 +38,7 @@ jobs: - name: ๐Ÿ— Setup project uses: ./.github/actions/setup-project - with: - with-webui: true - - # Required for typechecking webui - - name: ๐Ÿ‘ท Build core - run: bun run build - - - name: ๐Ÿ“‹ Typecheck webui - run: bun run typecheck - working-directory: webui - - name: ๐Ÿ‘ท Build webui + - name: ๐Ÿ‘ท Build expo-atlas-ui run: bun run build - working-directory: webui - env: - EXPO_USE_FAST_RESOLVER: true # Use the faster Metro resolver in SDK 51 + working-directory: packages/expo-atlas-ui diff --git a/.gitignore b/.gitignore index dd05106..9000ad3 100644 --- a/.gitignore +++ b/.gitignore @@ -1,8 +1,10 @@ # Learn more https://docs.github.com/en/get-started/getting-started-with-git/ignoring-files # project -/build -/webui/dist +/apps/*/build +/apps/*/dist +/packages/*/build +/packages/*/dist # test fixtures *.temp.jsonl diff --git a/apps/example/.env b/apps/example/.env new file mode 100644 index 0000000..31f60df --- /dev/null +++ b/apps/example/.env @@ -0,0 +1,3 @@ +EXPO_USE_FAST_RESOLVER=true +EXPO_USE_METRO_WORKSPACE_ROOT=true +EXPO_UNSTABLE_ATLAS=true diff --git a/webui/.gitignore b/apps/example/.gitignore similarity index 100% rename from webui/.gitignore rename to apps/example/.gitignore diff --git a/apps/example/README.md b/apps/example/README.md new file mode 100644 index 0000000..cd4feb8 --- /dev/null +++ b/apps/example/README.md @@ -0,0 +1,50 @@ +# Welcome to your Expo app ๐Ÿ‘‹ + +This is an [Expo](https://expo.dev) project created with [`create-expo-app`](https://www.npmjs.com/package/create-expo-app). + +## Get started + +1. Install dependencies + + ```bash + npm install + ``` + +2. Start the app + + ```bash + npx expo start + ``` + +In the output, you'll find options to open the app in a + +- [development build](https://docs.expo.dev/develop/development-builds/introduction/) +- [Android emulator](https://docs.expo.dev/workflow/android-studio-emulator/) +- [iOS simulator](https://docs.expo.dev/workflow/ios-simulator/) +- [Expo Go](https://expo.dev/go), a limited sandbox for trying out app development with Expo + +You can start developing by editing the files inside the **app** directory. This project uses [file-based routing](https://docs.expo.dev/router/introduction). + +## Get a fresh project + +When you're ready, run: + +```bash +npm run reset-project +``` + +This command will move the starter code to the **app-example** directory and create a blank **app** directory where you can start developing. + +## Learn more + +To learn more about developing your project with Expo, look at the following resources: + +- [Expo documentation](https://docs.expo.dev/): Learn fundamentals, or go into advanced topics with our [guides](https://docs.expo.dev/guides). +- [Learn Expo tutorial](https://docs.expo.dev/tutorial/introduction/): Follow a step-by-step tutorial where you'll create a project that runs on Android, iOS, and the web. + +## Join the community + +Join our community of developers creating universal apps. + +- [Expo on GitHub](https://github.com/expo/expo): View our open source platform and contribute. +- [Discord community](https://chat.expo.dev): Chat with Expo users and ask questions. diff --git a/apps/example/app.json b/apps/example/app.json new file mode 100644 index 0000000..e81c20e --- /dev/null +++ b/apps/example/app.json @@ -0,0 +1,36 @@ +{ + "expo": { + "name": "example", + "slug": "example", + "version": "1.0.0", + "orientation": "portrait", + "icon": "./assets/images/icon.png", + "scheme": "myapp", + "userInterfaceStyle": "automatic", + "splash": { + "image": "./assets/images/splash.png", + "resizeMode": "contain", + "backgroundColor": "#ffffff" + }, + "ios": { + "supportsTablet": true + }, + "android": { + "adaptiveIcon": { + "foregroundImage": "./assets/images/adaptive-icon.png", + "backgroundColor": "#ffffff" + } + }, + "web": { + "bundler": "metro", + "output": "static", + "favicon": "./assets/images/favicon.png" + }, + "plugins": [ + "expo-router" + ], + "experiments": { + "typedRoutes": true + } + } +} diff --git a/apps/example/app/(tabs)/_layout.tsx b/apps/example/app/(tabs)/_layout.tsx new file mode 100644 index 0000000..22a49b6 --- /dev/null +++ b/apps/example/app/(tabs)/_layout.tsx @@ -0,0 +1,37 @@ +import { Tabs } from 'expo-router'; +import React from 'react'; + +import { TabBarIcon } from '@/components/navigation/TabBarIcon'; +import { Colors } from '@/constants/Colors'; +import { useColorScheme } from '@/hooks/useColorScheme'; + +export default function TabLayout() { + const colorScheme = useColorScheme(); + + return ( + + ( + + ), + }} + /> + ( + + ), + }} + /> + + ); +} diff --git a/apps/example/app/(tabs)/explore.tsx b/apps/example/app/(tabs)/explore.tsx new file mode 100644 index 0000000..e480218 --- /dev/null +++ b/apps/example/app/(tabs)/explore.tsx @@ -0,0 +1,102 @@ +import Ionicons from '@expo/vector-icons/Ionicons'; +import { StyleSheet, Image, Platform } from 'react-native'; + +import { Collapsible } from '@/components/Collapsible'; +import { ExternalLink } from '@/components/ExternalLink'; +import ParallaxScrollView from '@/components/ParallaxScrollView'; +import { ThemedText } from '@/components/ThemedText'; +import { ThemedView } from '@/components/ThemedView'; + +export default function TabTwoScreen() { + return ( + }> + + Explore + + This app includes example code to help you get started. + + + This app has two screens:{' '} + app/(tabs)/index.tsx and{' '} + app/(tabs)/explore.tsx + + + The layout file in app/(tabs)/_layout.tsx{' '} + sets up the tab navigator. + + + Learn more + + + + + You can open this project on Android, iOS, and the web. To open the web version, press{' '} + w in the terminal running this project. + + + + + For static images, you can use the @2x and{' '} + @3x suffixes to provide files for + different screen densities + + + + Learn more + + + + + Open app/_layout.tsx to see how to load{' '} + + custom fonts such as this one. + + + + Learn more + + + + + This template has light and dark mode support. The{' '} + useColorScheme() hook lets you inspect + what the user's current color scheme is, and so you can adjust UI colors accordingly. + + + Learn more + + + + + This template includes an example of an animated component. The{' '} + components/HelloWave.tsx component uses + the powerful react-native-reanimated library + to create a waving hand animation. + + {Platform.select({ + ios: ( + + The components/ParallaxScrollView.tsx{' '} + component provides a parallax effect for the header image. + + ), + })} + + + ); +} + +const styles = StyleSheet.create({ + headerImage: { + color: '#808080', + bottom: -90, + left: -35, + position: 'absolute', + }, + titleContainer: { + flexDirection: 'row', + gap: 8, + }, +}); diff --git a/apps/example/app/(tabs)/index.tsx b/apps/example/app/(tabs)/index.tsx new file mode 100644 index 0000000..324aeb7 --- /dev/null +++ b/apps/example/app/(tabs)/index.tsx @@ -0,0 +1,70 @@ +import { Image, StyleSheet, Platform } from 'react-native'; + +import { HelloWave } from '@/components/HelloWave'; +import ParallaxScrollView from '@/components/ParallaxScrollView'; +import { ThemedText } from '@/components/ThemedText'; +import { ThemedView } from '@/components/ThemedView'; + +export default function HomeScreen() { + return ( + + }> + + Welcome! + + + + Step 1: Try it + + Edit app/(tabs)/index.tsx to see changes. + Press{' '} + + {Platform.select({ ios: 'cmd + d', android: 'cmd + m' })} + {' '} + to open developer tools. + + + + Step 2: Explore + + Tap the Explore tab to learn more about what's included in this starter app. + + + + Step 3: Get a fresh start + + When you're ready, run{' '} + npm run reset-project to get a fresh{' '} + app directory. This will move the current{' '} + app to{' '} + app-example. + + + + ); +} + +const styles = StyleSheet.create({ + titleContainer: { + flexDirection: 'row', + alignItems: 'center', + gap: 8, + }, + stepContainer: { + gap: 8, + marginBottom: 8, + }, + reactLogo: { + height: 178, + width: 290, + bottom: 0, + left: 0, + position: 'absolute', + }, +}); diff --git a/apps/example/app/+html.tsx b/apps/example/app/+html.tsx new file mode 100644 index 0000000..8b92456 --- /dev/null +++ b/apps/example/app/+html.tsx @@ -0,0 +1,39 @@ +import { ScrollViewStyleReset } from 'expo-router/html'; +import { type PropsWithChildren } from 'react'; + +/** + * This file is web-only and used to configure the root HTML for every web page during static rendering. + * The contents of this function only run in Node.js environments and do not have access to the DOM or browser APIs. + */ +export default function Root({ children }: PropsWithChildren) { + return ( + + + + + + + {/* + Disable body scrolling on web. This makes ScrollView components work closer to how they do on native. + However, body scrolling is often nice to have for mobile web. If you want to enable it, remove this line. + */} + + + {/* Using raw CSS styles as an escape-hatch to ensure the background color never flickers in dark-mode. */} +