mirror of
https://github.com/owntone/owntone-server.git
synced 2024-12-27 15:45:56 -05:00
72 lines
2.7 KiB
Markdown
72 lines
2.7 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).
|
||
|
|
||
|
## Screenshots
|
||
|
|
||
|
![Now playing](images/screenshot-now-playing.png){: class="zoom" }
|
||
|
![Queue](images/screenshot-queue.png){: class="zoom" }
|
||
|
![Music browse](images/screenshot-music-browse.png){: class="zoom" }
|
||
|
![Music artists](images/screenshot-music-artists.png){: class="zoom" }
|
||
|
![Music artist](images/screenshot-music-artist.png){: class="zoom" }
|
||
|
![Music albums](images/screenshot-music-albums.png){: class="zoom" }
|
||
|
![Music albums options](images/screenshot-music-albums-options.png){: class="zoom" }
|
||
|
![Music album](images/screenshot-music-album.png){: class="zoom" }
|
||
|
![Spotiy](images/screenshot-music-spotify.png){: class="zoom" }
|
||
|
![Audiobooks authors](images/screenshot-audiobooks-authors.png){: class="zoom" }
|
||
|
![Audiobooks](images/screenshot-audiobooks-books.png){: class="zoom" }
|
||
|
![Podcasts](images/screenshot-podcasts.png){: class="zoom" }
|
||
|
![Podcast](images/screenshot-podcast.png){: class="zoom" }
|
||
|
![Files](images/screenshot-files.png){: class="zoom" }
|
||
|
![Search](images/screenshot-search.png){: class="zoom" }
|
||
|
![Menu](images/screenshot-menu.png){: class="zoom" }
|
||
|
![Outputs](images/screenshot-outputs.png){: 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`.
|