mirror of
https://github.com/owntone/owntone-server.git
synced 2025-03-01 06:19:16 -05:00
76 lines
3.1 KiB
Markdown
76 lines
3.1 KiB
Markdown
# Web Interface
|
|
|
|
Mobile friendly player web interface for [OwnTone](http://owntone.github.io/owntone-server/) build
|
|
with [Vue.js](https://vuejs.org), [Bulma](http://bulma.io).
|
|
|
|
You can find the web interface at [http://owntone.local:3689](http://owntone.local:3689)
|
|
or alternatively at http://SERVER_ADDRESS:3689.
|
|
|
|
Use the web interface to control playback, trigger manual library rescans, pair
|
|
with remotes, select speakers, authenticate with Spotify, etc.
|
|
|
|
## Screenshots
|
|
|
|
data:image/s3,"s3://crabby-images/deef6/deef625506a18fc266c43b3f39aea42ef8b9ecb4" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ddcab/ddcabc6e548c0ee67247f70efa5499867cc8fc3c" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2de64/2de646d66c22a12c4356f22ebdeb60e51da0674f" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2da22/2da22fd434a117c425d9d26af9bfaffe8cfa85e3" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c789f/c789f33dadc8c5695205c59512cc0f44bb80425a" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/24a4d/24a4dc0da9c9c85ccd365239b1e12998ea835640" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1d7a9/1d7a92907d114c761f802d2be630ddb6d60a20d7" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/74ef2/74ef28dcb8abacf18eead150346c13c78991ba63" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/acc70/acc70c4bb48296e186e7e127917363b93e47aa42" alt="Spotify"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8757b/8757b4bbb85673cdcdd95dc81480f48c7163af7c" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/03816/03816e3784b4c56f9fe5fcce71c848579c6a1397" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d277e/d277e63bba639105e0f9788bbdb0e249ad570eaf" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9068f/9068f2a6fcdb85bdda4e3d9c1a04e8be13b5cc9e" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9a855/9a85565ce900dad92343153bc002e51b0b69bcba" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/14bac/14bacc95eb956277378f492fb3e7c6c8f881a97b" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d94d4/d94d4d43730e3c230ef6820e89bfaaebfd9fb5fa" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/209d2/209d2ac58784b96d56a69c7f2bb3ad217a46abf1" alt="Outputs"{: class="zoom" }
|
|
|
|
## Usage
|
|
|
|
You can find OwnTone's web interface at [http://owntone.local:3689](http://owntone.local:3689)
|
|
or alternatively at http://SERVER_ADDRESS:3689.
|
|
|
|
## Build Setup
|
|
|
|
The source is located in the `web-src` folder.
|
|
|
|
```bash
|
|
cd web-src
|
|
```
|
|
|
|
The web interface is built with [Vite](https://vitejs.dev/), makes use of Prettier for code formatting
|
|
and ESLint for code linting (the project was set up following the guide [ESLint and Prettier with Vite and Vue.js 3](https://vueschool.io/articles/vuejs-tutorials/eslint-and-prettier-with-vite-and-vue-js-3/)
|
|
|
|
```bash
|
|
# install dependencies
|
|
npm install
|
|
|
|
# Serve with hot reload at localhost:3000
|
|
# (assumes that OwnTone server is running on localhost:3689)
|
|
npm run serve
|
|
|
|
# Serve with hot reload at localhost:3000
|
|
# (with remote OwnTone server reachable under owntone.local:3689)
|
|
export VITE_OWNTONE_URL=http://owntone.local:3689 npm run serve
|
|
|
|
# Build for production with minification (will update web interface
|
|
# in "../htdocs")
|
|
npm run build
|
|
|
|
# Format code
|
|
npm run format
|
|
|
|
# Lint code (and fix errors that can be automatically fixed)
|
|
npm run lint
|
|
```
|
|
|
|
After running `npm run serve` the web interface is reachable at [localhost:3000](http://localhost:3000).
|
|
By default it expects **OwnTone** to be running at [localhost:3689](http://localhost:3689) and proxies all
|
|
JSON API calls to this location.
|
|
|
|
If the server is running at a different location you have to set the env variable `VITE_OWNTONE_URL`.
|