# Vue 3 + Vite Migration - Vue Dev Tools required in version 6 (currently only released as beta versions): - [ ] vite does not support env vars in `vite.config.js` from `.env` files - - - [ ] Documentation update - [ ] Add linting (ESLint) ? - [x] Update dialog is missing scan options - [ ] Performance with huge artists/albums/tracks list (no functional template supported any more) - [ ] Do not reload data, if using the index-nav - [x] PageAlbums - [ ] PageArtists - [ ] ... - [ ] Albums page is slow to load (because of the number of vue components?) - [ ] Evaluate virtual scroller - [x] JS error on Podacst page - Problem caused by the Slider component - Replace with plain html - [ ] vue-router scroll-behavior - [x] Index list not always hidden - [x] Check transitions - [ ] Page display is "jumpy" - Workaround is removing the page transition effect - [x] Index navigation "scroll up/down" button does not scroll down, if index is visible - [x] Use native intersection observer solves it in desktop mode - [x] Mobile view still broken - [x] Update to latest dependency versions (vite, vue, etc.) - [x] Index navigation is broken (jump to "A") - Change in `$router.push` syntax, hash has to be passed as a separate parameter instead of as part of the path - [x] `vue-range-slider` is not compatible with vue3 - replacement option: - [x] `@vueform/slider` for volume control - [x] track progress (now playing) - [x] track progress (podcasts) - [x] vue-router does not support navigation guards in mixins: - replace mixin with composition api? - Copied nav guards into each component - [x] vue-router link does not support `tag` and `active-class` properties: - [x] `vue-tiny-lazyload-img` does not support Vue 3 - No sign of interesst to add support - `v-lazy-image` () seems to be supported and popular - Works as a component instead of a directive - **DOES NOT** have a good error handling, if the (remote) image does not exist - `vue3-lazyload` () - Works as a directive - Easy replacement for `vue-tiny-lazyload-img` - [x] Top margin in pages is wrong (related to vue-router scroll behavior changes) - Solved by adding the correct margin to take the top navbar (and where shown the tabs) into account - [x] Mobile view seems to be broken - Looks like the cause of this was the broken router-link in bulma tabs component - [x] Changing sort option (artist albums view) does not work - [x] Replace unmaintained `vue-infinite-loading` dependency - Replace with `@ts-pro/vue-eternal-loading`: - [x] Replace `bulma-switch` with `@vueform/toggle`? - Update of `bulma-switch` (or `vite`) fixed the import of the sass file, no need to replace it now