Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings
/ start-ui-native Public template

πŸš€ Start UI [native] is an opinionated UI starter with βš›οΈ React Native, πŸš€ Expo, 🌿 Ficus UI, πŸ‘‹ Hey API & 🌴 Tanstack Form β€” From the 🐻 BearStudio Team

Notifications You must be signed in to change notification settings

BearStudio/start-ui-native

Repository files navigation

πŸš€ Start UI [native] is an opinionated native starter repository created & maintained by the BearStudio Team and other contributors. It represents our team's up-to-date stack that we use when creating native apps for our clients.

Technologies

βš™οΈ Node.js, 🟦 TypeScript, βš›οΈ React, πŸ“± React Native, πŸš€ Expo, πŸ” Better Auth, 🌿 Ficus UI, 🌴 Tanstack Form, 🌴 Tanstack Query, πŸ‘‹ Hey API

Requirements

Getting Started

pnpm create start-ui -t native myApp

That will scaffold a new folder with the latest version of πŸš€ Start UI [native] πŸŽ‰

Installation

cp .env.example .env # Setup your env variables
cp .vscode/settings.example.json .vscode/settings.json # (Optionnal) Setup your VS Code
pnpm install # Install dependencies

Environment variables

Tip

Using Expo Go, local development urls should not be localhost, use public IP instead

EXPO_PUBLIC_BASE_URL # Base URL of your server, usefull if you are using Start UI [web]
# OPTIONAL TO OVERRIDE
EXPO_PUBLIC_AUTH_URL # Better-auth url (default `${EXPO_PUBLIC_BASE_URL}/api/auth`)
EXPO_PUBLIC_OPENAPI_URL # OpenAPI contract URL (default `${EXPO_PUBLIC_BASE_URL}/openapi/app/schema`)

API SDK generation

pnpm gen:api

A new folder /src/lib/hey-api/generated will be created with stuff like to combine use Tanstack Query to fetch data, based on env variables.

For example

import { api } from '@/lib/hey-api/api';
useQuery(api.bookGetByIdOptions({ path: { id: props.bookId } }));

Run

Expo Go

pnpm dev

Local build

pnpm prebuild # To generate local builds
pnpm dev:ios # To run with local ios build
pnpm dev:android # To run with local android build

Storybook

Storybook is managed as a specific mode of the app that is launch apart in port 8083

pnpm storybook # To run app in storybook mode

Tip

You can open Storybook in another tab and switch between the app and Storybook by pressing i or a in each terminal.

Generate custom icons components from svg files

Put the custom svg files into the app/components/icons/svg-sources folder and then run the following command:

pnpm gen:icons

If you want to use the same set of custom duotone icons that Start UI is already using, checkout Phosphor

Warning

All svg icons should be svg files prefixed by icon- (example: icon-externel-link) with square size and filled with #000 color (will be replaced by currentColor).

EAS Preview

To be able to use previews on PR, you have to setup your project with EAS

  1. Setup Expo access token
  2. Add GitHub repository variables: https://github.com/xxx/xxx/settings/variables/actions
    • API_URL
    • AUTH_URL
    • OPENAPI_URL
  3. Setup Expo project: https://expo.dev/
    • Create your project
    • Get project's id
    • Set as EXPO_PROJECT_ID in app.config.ts
  4. Setup eas
    • eas login
    • eas init --id {projectid}
    • eas update:configure

About

πŸš€ Start UI [native] is an opinionated UI starter with βš›οΈ React Native, πŸš€ Expo, 🌿 Ficus UI, πŸ‘‹ Hey API & 🌴 Tanstack Form β€” From the 🐻 BearStudio Team

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Contributors 11

AltStyle γ«γ‚ˆγ£γ¦ε€‰ζ›γ•γ‚ŒγŸγƒšγƒΌγ‚Έ (->γ‚ͺγƒͺγ‚ΈγƒŠγƒ«) /