Markury 90053b67c5 fix(wip): add fallback format support for unavailable tracks
Add support for selecting a fallback audio format if the requested
track format is unavailable. Users can now choose to fall back
to MP3_320, MP3_128, or the highest available format, or opt to fail
if the requested format is not found. The queue manager and downloader
now fetch fresh track data just-in-time, handle dz fallback
parameters, and ensure the correct track ID is used for decryption.
Settings UI and store are updated to allow configuring the fallback format.
2025-10-03 10:28:56 -04:00
2025-10-02 23:30:31 -04:00
2025-09-30 11:19:56 -04:00
2025-10-01 19:27:41 -04:00
2025-10-01 22:19:10 -04:00
2025-09-30 11:19:56 -04:00
2025-09-30 11:19:56 -04:00
2025-09-30 11:19:56 -04:00

Shark!

Desktop music management application written in Typescript.

Inspiration

Inspired by this post on X, and the functionality of Deemix, written from the ground up for Tauri's webwiew without the Node.js dependency. Instead it has much more specific dependencies :)

Tech Stack

Setup

Prerequisites

  • Bun installed
  • Rust toolchain (for Tauri)

Installation

bun install

Configuration

  1. Run the app: bun run tauri dev
  2. Go to Settings and configure:
    • Music folder (where downloads will be saved)
    • Playlists folder (for .m3u8 files)
    • Download settings (format, concurrency, overwrite behavior)

Development

# Run dev server (hot reload)
bun run tauri dev

# Build for production
bun run tauri build

# Type checking
bun run check

Architecture

src/
├── routes/              # SvelteKit pages
│   ├── library/         # Local library view
│   ├── services/        # Downloads and metadata services UI
│   ├── downloads/       # Download queue UI
│   └── settings/        # App settings
├── lib/
│   ├── services/        # Downloads and metadata services
│   ├── library/         # Library scanner, album/playlist loaders
│   ├── stores/          # Svelte stores (settings, auth, queue)
│   └── types/           # TypeScript type definitions
src-tauri/
├── capabilities/        # Tauri security permissions
└── tauri.conf.json      # Tauri configuration

License

This repo has been made source available. It is not licensed under a single open source license. Check upstream libraries for license details.

Description
No description provided
Readme 2.2 MiB
Languages
TypeScript 46.9%
Svelte 44%
Rust 8.6%
JavaScript 0.3%