mirror of
https://github.com/DocNR/POWR.git
synced 2025-04-19 10:51:19 +00:00

- Create reusable NostrProfileLogin component for consistent UI across all screens - Fix profile feed error when not authenticated by conditionally calling useSocialFeed - Resolve hook ordering inconsistencies to prevent React errors - Improve feed loading state management during authentication transitions - Update all profile screens (overview, activity, progress, settings) to use shared component - Add proper error handling for profile data loading when not authenticated This change resolves the console error that appeared when accessing the profile tab while not logged in, while also providing a better user experience through consistent styling and messaging across all profile screens.
POWR - Cross-Platform Fitness Tracking App
POWR is a local-first fitness tracking application built with React Native and Expo, featuring integration with the Nostr protocol for decentralized social features and improved control of your fitness data.
Features
Current
- Exercise library management with local SQLite database
- Workout template creation
- Local-first data architecture with Nostr sync capability
- Cross-platform support (iOS, Android)
- Dark/light mode support
- Nostr authentication and event publishing
Planned
- Workout record and template sharing
- Enhanced social features
- Training programs
- Performance analytics
- Public/private workout sharing options
Getting Started
Prerequisites
- Node.js (v18 or later)
- npm or yarn
- EAS CLI (
npm install -g eas-cli
) - iOS Simulator (for iOS development)
- Android Studio (for Android development)
Installation
- Clone the repository
git clone https://github.com/docNR/powr.git
cd powr
- Install dependencies
npm install
- Install development client modules
npx expo install expo-dev-client expo-crypto expo-nip55
Development Using Expo Dev Client
POWR now uses Expo Dev Client for development instead of Expo Go. This allows us to use native modules required for Nostr integration.
- Configure EAS (if not already done)
eas build:configure
- Create a development build
# For Android
eas build --profile development --platform android
# For iOS
eas build --profile development --platform ios
- Start the development server with dev client
npx expo start --dev-client
- Install the build on your device and scan the QR code to connect
Project Structure
powr/
├── app/ # Main application code
│ ├── (tabs)/ # Tab-based navigation
│ ├── (workout)/ # Workout screens
│ └── _layout.tsx # Root layout
├── components/ # Shared components
│ ├── ui/ # UI components
│ ├── sheets/ # Bottom sheets
│ └── library/ # Library components
├── lib/ # Shared utilities
│ ├── db/ # Database services
│ ├── hooks/ # Custom React hooks
│ ├── stores/ # Zustand stores
│ └── mobile-signer.ts # Nostr signer implementation
├── types/ # TypeScript definitions
└── utils/ # Utility functions
Technology Stack
Core
- React Native
- Expo (with Dev Client)
- TypeScript
- SQLite (via expo-sqlite)
- Zustand (state management)
UI Components
- NativeWind/Tailwind
- React Navigation
- Lucide Icons
Nostr Integration
- NDK (Nostr Development Kit)
- Custom mobile signer implementation
- Local event caching
Database Architecture
POWR uses a SQLite database with a service-oriented architecture:
- Exercise data
- Workout templates
- Nostr event caching
- User profiles
Each domain has dedicated service classes for data operations.
Nostr Integration
POWR implements the Nostr protocol via NDK with:
- Secure key management using expo-secure-store
- Event publishing for exercises, templates, and workouts
- Profile discovery and following
- Custom event kinds for fitness data
Building for Production
# Build for iOS
eas build -p ios
# Build for Android
eas build -p android
Contributing
- Fork the repository
- Create a feature branch
- Commit your changes
- Push to the branch
- Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
Description
Cross-platform fitness tracking app built with React Native and Expo. Features local-first architecture with planned Nostr protocol integration for decentralized social features.
Languages
TypeScript
98.2%
Kotlin
1.1%
JavaScript
0.2%
Objective-C++
0.2%
Ruby
0.2%
Other
0.1%