mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-21 02:22:31 -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/08831/088316595e50552849ba1a297a4700c00609a147" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b0d10/b0d10c0507c72965a495be979d2c2fdefb425197" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f5cbb/f5cbb19e879859d1dd957f01aaa3ab1fc9f5d5d6" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6f64e/6f64e57f4a73660e4ef639a0a0c835ab66470f88" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/190a2/190a21a261335b29f3c98b3b7238e5b8e769b178" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0922d/0922d937d6a1777976294e2ab940ea32b83578ab" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1fb42/1fb42be3fb5e7e634a820b14a2281fcceef1da6a" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/68e80/68e80b3d955184b19550cc0f8c448e6226af8f39" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/927fd/927fd5595d855bf6536b26fecff734d9ba03ed6f" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/68c93/68c935dfec5be6ef7cd5d424dfc889a507fce295" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0d9f7/0d9f78cc6b1acfde4a5737fc662d2082fb800669" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0a3a5/0a3a553f5b512d292c9be78f0f8353ecbfaaca09" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/04e2b/04e2b7f8a57abdbe63e94344e10d12d0ec97bdf5" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8cb4a/8cb4ae2129fd5da2da845d1e95f4c6f045a666b6" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c34d9/c34d9036ee3761d65abaf8837d83c0077d8183ae" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b434d/b434da9ea447713a0cf5be2e27af2c693f887c96" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/015cd/015cd015846eabcf41ce4848f05b823f4cfc6f51" 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`.
|