mirror of
https://github.com/owntone/owntone-server.git
synced 2025-03-02 23:09:15 -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/1e0ed/1e0ed41098b1f103e3b522c85c6d17024af5f89c" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/736df/736dfe01f9889ebfe39316d35c6e6149d4165e8b" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/897a6/897a64c61fec3d68048ce7d7cec5eba6c458a267" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f990a/f990a6245582394d22f4de0d0644ca6860cc0c4a" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8c509/8c5090ff6c80c642ece9c8af8f63728897b58c1f" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/5349a/5349a54c7b8c2cdda0234ad8b773a448742fe0a0" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ddaae/ddaae1cf5c040eeaeed65ffd6682fd5a30750213" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a6634/a6634413a8ac19ccaee511150b3daf53d21beb96" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ebcc3/ebcc3bfa29fd20499494a93c6d06ed1a04015641" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3f928/3f92819061abd367bd080fd7d3c1992432b35c5d" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e280b/e280b330d6590ea93c3b09a5824225433c232ebb" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ffb60/ffb60a3093b76c36aa11cab11e95efc5cab6457a" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/57e49/57e497663b0660ee45dc960c09552d34c2b5ddd0" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0fab0/0fab00d56aac5ff82fae635c5b44bbc0d03cba51" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6bdff/6bdff22edf03a8d16431e86dade4b56ee30a42cc" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f101a/f101a904d54f8aa5aab45d3dd08d813505be07b0" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/82415/82415675e8c61bd2f95a0448f923bfc6e84d8959" 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`.
|