mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-28 13:59:18 -05:00
78 lines
3.2 KiB
Markdown
78 lines
3.2 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://[your_server_address_here]:3689](http://[your_server_address_here]: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/c8c83/c8c838b557e1dcd506a63ac41eb2cdcfbb524e95" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d2a78/d2a780c6fe75f2b0256cfafe66a80b052976eddf" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/57acc/57acc73634ec9c121e2a84c219139732fd7fcb7b" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7b2f3/7b2f3255b512970fa192dbfa269ae14edeba6391" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c9e6b/c9e6b70209343a85c4de3fa0e096e7d7588154ad" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b4126/b4126c9ecd075eae2f648958d7132d9eaef3abd5" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/40610/40610fe44745881c40fd07ee77fa2a75a8843fa2" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d9496/d949677e3ddce3140bec40daeb15404edbec96ee" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/56c9d/56c9d38c961eaeabf0d02c20be4d4bc3e83a2d33" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ec805/ec805a8c1858ef820470f7df57e76e8d1b5c854a" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/42439/42439f9529f910a10112299cabbee86194ecc6e1" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/cb2f6/cb2f6cece59aa9dbeabb2e05f4c75c136db91e75" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ec708/ec7082ab844ba7d9318bd4e8ff88684638ded916" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/251df/251dfa2a8f16672f0c1559acc10e640df8a146af" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a5210/a5210d8d21d2db7161c7556708fcdedb499079bf" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a5ef9/a5ef99c3ac475c986cb4b4634db4c249757c7b63" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ed59b/ed59b8e6193004ca7fd903edd36c246348899579" 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://[your_server_address_here]:3689](http://[your_server_address_here]: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`.
|