mirror of
https://github.com/owntone/owntone-server.git
synced 2025-03-01 06:19:16 -05:00
78 lines
3.1 KiB
Markdown
78 lines
3.1 KiB
Markdown
# OwnTone 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/12aef/12aef1b7417a99aa8058eeb5637565595cb62063" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0f317/0f317653271aefda90d3c1200c1b6627a13f6eca" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4408e/4408e2775d313d9d2ea49d960f2bb8471b6c177b" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1f6a7/1f6a7077a129385f442a7d1d5315299e763e55bf" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6a205/6a205ceb54c89d50ab0824f4621a6b07bff6ebf5" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0598b/0598b73b1697994e787a387ccbc08a92a4664c1c" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/297b7/297b7dd7e16d79c6309abd4eba3c74ed341b1908" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0464f/0464f86de2b329c66dc74fab7b4650e2e619ac2f" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a3c56/a3c56d138737d0abcaa86fa447aea07c1e5bb146" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/bf00b/bf00b2ae0545deec81940d263f37085b304888e4" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ce1be/ce1be84b4f7a36d37b860125651ef1fe9d552931" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/86fd8/86fd8319ac375530212302b5b18002623a80e67c" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/100c8/100c81a413e55d2b765b83c83f1de08dd11b3678" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4be50/4be500a74dede7201117f34df699c866c11e4ab9" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3726e/3726e093d3e7c70ca66d69c52dcc02bf97a0a907" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/20999/20999af70854c367ddde3279abba46be7ee19cd1" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9521f/9521fff90a138179600fc34ba9f5d345c5560575" 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.
|
|
|
|
```
|
|
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)
|
|
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`.
|