Skip to content

cloudwithax/swingatron-mobile

Repository files navigation

Swingatron Mobile

Swingatron is a modern mobile music and audio application built with React Native and Expo. It features a robust audio playback system, lyrics display, and comprehensive library management.

Features

  • Advanced Audio Playback: Seamless audio streaming and playback with background support.
  • Now Playing Interface: Rich player interface with cover art, controls, and visualizations.
  • Lyrics Integration: Real-time lyrics display for supported tracks.
  • Queue Management: Easy management of upcoming tracks.
  • Library Organization: Organize music with Folders and Favorites.
  • Stats & Insights: View listening statistics.
  • Modern UI/UX: Built with smooth animations (Reanimated) and blur effects.
  • Authentication: User account management.

Tech Stack

  • Framework: React Native & Expo (SDK 54)
  • Routing: Expo Router
  • State Management: Zustand
  • Networking: Axios
  • Audio: react-native-track-player (lock screen controls, notification player)
  • Storage: expo-secure-store, @react-native-async-storage/async-storage
  • Animations: react-native-reanimated
  • Styling: expo-linear-gradient, expo-blur, expo-font

Getting Started

Prerequisites

  • Node.js (LTS recommended)
  • Bun (Preferred package manager)
  • Expo Go app on your mobile device (for testing)

Installation

  1. Clone the repository:

    git clone <repository-url>
    cd swingatron/mobile
  2. Install dependencies:

    bun install

Running the App

Start the development server:

bun start
  • Scan the QR code with the Expo Go app (Android) or Camera app (iOS).
  • Press a to open in Android Emulator.
  • Press i to open in iOS Simulator.
  • Press w to open in web browser.

Scripts

  • bun start: Start the project with cache cleared.
  • bun run android: Run on Android device/emulator.
  • bun run ios: Run on iOS simulator.
  • bun run web: Run in web browser.
  • bun run lint: Run ESLint to check for code quality issues.

Project Structure

mobile/
├── app/                 # Expo Router pages and navigation
│   ├── (auth)/          # Authentication routes
│   ├── (tabs)/          # Main tab navigation
│   ├── nowplaying.tsx   # Player screen
│   └── ...
├── assets/              # Images, fonts, and other static assets
├── components/          # Reusable UI components
├── constants/           # App-wide constants (colors, theme)
├── hooks/               # Custom React hooks
├── src/                 # Core logic and services
└── ...

About

The most comprehensive player for Swing Music, now on mobile

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published