Added a tab to list download errors

Click on the error/warning sign to open it
This commit is contained in:
RemixDev 2020-06-16 17:27:16 +02:00
parent 26b3984a04
commit e21469307b
7 changed files with 90 additions and 13 deletions

File diff suppressed because one or more lines are too long

View file

@ -1190,6 +1190,21 @@
target="_blank">news channel</a> on Telegram. target="_blank">news channel</a> on Telegram.
</p> </p>
<br /> <br />
<h1>Bug Reports</h1>
<p>
If you have questions or problems with the app, search for a solution in the
<a href="https://www.reddit.com/r/deemix" target="_blank">subreddit</a> first and then, if you don't find anything
you can make a post with your issue on the subreddit.
</p>
<p>
Before reporting a bug make sure you're running the latest version of the app and that the thing you want
to report is acatually a bug and not something that's wrong only on your end.<br />
Make sure the bug is reproducible on another machines and also <b>DO NOT</b> report a bug if it's been already reported.
</p>
<p>
<b>DO NOT</b> open issues for asking questions, there is a subreddit for that.
</p>
<br />
<h2>Donations</h2> <h2>Donations</h2>
<h3>You want to contribute to this project? You can do that <b>in different ways!</b></h3> <h3>You want to contribute to this project? You can do that <b>in different ways!</b></h3>
<p> <p>
@ -1400,6 +1415,24 @@
</footer> </footer>
</div> </div>
<div id="errors_tab" class="main_tabcontent">
<h1>Errors for {{ title }}</h1>
<table>
<tr>
<th>ID</th>
<th>Artist</th>
<th>Title</th>
<th>Error</th>
</tr>
<tr v-for="error in errors">
<td>{{ error.data.id }}</td>
<td>{{ error.data.artist }}</td>
<td>{{ error.data.title }}</td>
<td>{{ error.message }}</td>
</tr>
</table>
</div>
</div> </div>
</section> </section>
</div> </div>

File diff suppressed because one or more lines are too long

View file

@ -0,0 +1,20 @@
import Vue from 'vue'
const ErrorsTab = new Vue({
data: () => ({
title: '',
errors: []
}),
methods: {
reset(){
this.title = ''
this.errors = []
},
showErrors(data){
this.title = data.artist+" - "+data.title
this.errors = data.errors
}
}
}).$mount('#errors_tab')
export default ErrorsTab

View file

@ -1,6 +1,7 @@
import $ from 'jquery' import $ from 'jquery'
import { socket } from './socket.js' import { socket } from './socket.js'
import { toast } from './toasts.js' import { toast } from './toasts.js'
import { showErrors } from './tabs.js'
/* ===== Locals ===== */ /* ===== Locals ===== */
const tabMinWidth = 250 const tabMinWidth = 250
@ -145,19 +146,26 @@ function addToQueue(queueItem, current = false) {
$('#bar_' + queueItem.uuid).css('width', queueItem.progress + '%') $('#bar_' + queueItem.uuid).css('width', queueItem.progress + '%')
if (queueItem.failed >= 1 && $('#download_' + queueItem.uuid + ' .queue_failed').length == 0) { if (queueItem.failed >= 1 && $('#download_' + queueItem.uuid + ' .queue_failed').length == 0) {
$('#download_' + queueItem.uuid + ' .download_info_status').append( $('#download_' + queueItem.uuid + ' .download_info_status').append(
`<span class="secondary-text inline-flex"><span class="download_slim_separator">(</span><span class="queue_failed">${queueItem.failed}</span><i class="material-icons">error_outline</i><span class="download_slim_separator">)</span></span>` `<span class="secondary-text inline-flex"><span class="download_slim_separator">(</span><span class="queue_failed_button inline-flex"><span class="queue_failed">${queueItem.failed}</span><i class="material-icons">error_outline</i></span><span class="download_slim_separator">)</span></span>`
) )
} }
if (queueItem.downloaded + queueItem.failed == queueItem.size) { if (queueItem.downloaded + queueItem.failed == queueItem.size) {
let result_icon = $('#download_' + queueItem.uuid).find('.queue_icon') let result_icon = $('#download_' + queueItem.uuid).find('.queue_icon')
if (queueItem.failed == 0) { if (queueItem.failed == 0) {
result_icon.text('done') result_icon.text('done')
} else if (queueItem.failed == queueItem.size) { } else {
let failed_button = $('#download_' + queueItem.uuid).find('.queue_failed_button')
result_icon.addClass('clickable')
failed_button.addClass('clickable')
result_icon.bind('click', {item:queueItem}, showErrors)
failed_button.bind('click', {item:queueItem}, showErrors)
if (queueItem.failed >= queueItem.size) {
result_icon.text('error') result_icon.text('error')
} else { } else {
result_icon.text('warning') result_icon.text('warning')
} }
} }
}
if (!queueItem.init) toast(`${queueItem.title} added to queue`, 'playlist_add_check') if (!queueItem.init) toast(`${queueItem.title} added to queue`, 'playlist_add_check')
} }
@ -247,11 +255,19 @@ function finishDownload(uuid) {
let result_icon = $('#download_' + uuid).find('.queue_icon') let result_icon = $('#download_' + uuid).find('.queue_icon')
if (queueList[uuid].failed == 0) { if (queueList[uuid].failed == 0) {
result_icon.text('done') result_icon.text('done')
} else if (queueList[uuid].failed >= queueList[uuid].size) { } else {
let failed_button = $('#download_' + uuid).find('.queue_failed_button')
result_icon.addClass('clickable')
failed_button.addClass('clickable')
result_icon.bind('click', {item:queueList[uuid]}, showErrors)
failed_button.bind('click', {item:queueList[uuid]}, showErrors)
if (queueList[uuid].failed >= queueList[uuid].size) {
result_icon.text('error') result_icon.text('error')
} else { } else {
result_icon.text('warning') result_icon.text('warning')
} }
}
let index = queue.indexOf(uuid) let index = queue.indexOf(uuid)
if (index > -1) { if (index > -1) {
queue.splice(index, 1) queue.splice(index, 1)
@ -307,11 +323,12 @@ function updateQueue(update) {
$('#download_' + uuid + ' .queue_downloaded').text(queueList[uuid].downloaded + queueList[uuid].failed) $('#download_' + uuid + ' .queue_downloaded').text(queueList[uuid].downloaded + queueList[uuid].failed)
if (queueList[uuid].failed == 1 && $('#download_' + uuid + ' .queue_failed').length == 0) { if (queueList[uuid].failed == 1 && $('#download_' + uuid + ' .queue_failed').length == 0) {
$('#download_' + uuid + ' .download_info_status').append( $('#download_' + uuid + ' .download_info_status').append(
`<span class="secondary-text inline-flex"><span class="download_slim_separator">(</span><span class="queue_failed">1</span> <i class="material-icons">error_outline</i><span class="download_slim_separator">)</span></span>` `<span class="secondary-text inline-flex"><span class="download_slim_separator">(</span><span class="queue_failed_button inline-flex"><span class="queue_failed">1</span> <i class="material-icons">error_outline</i></span><span class="download_slim_separator">)</span></span>`
) )
} else { } else {
$('#download_' + uuid + ' .queue_failed').text(queueList[uuid].failed) $('#download_' + uuid + ' .queue_failed').text(queueList[uuid].failed)
} }
queueList[uuid].errors.push({message: update.error, data: update.data})
} }
if (progress) { if (progress) {
queueList[uuid].progress = progress queueList[uuid].progress = progress

View file

@ -4,6 +4,7 @@ import LinkAnalyzerTab from './components/link-analyzer-tab.js'
import HomeTab from './components/home-tab.js' import HomeTab from './components/home-tab.js'
import ChartsTab from './components/charts-tab.js' import ChartsTab from './components/charts-tab.js'
import FavoritesTab from './components/favorites-tab.js' import FavoritesTab from './components/favorites-tab.js'
import ErrorsTab from './components/errors-tab.js'
import { socket } from './socket.js' import { socket } from './socket.js'
import SettingsTab from './components/settings-tab.js' import SettingsTab from './components/settings-tab.js'
import MainSearch from './components/main-search.js' import MainSearch from './components/main-search.js'
@ -45,6 +46,11 @@ export function showView(viewType, event) {
showTab(viewType, id) showTab(viewType, id)
} }
export function showErrors(event){
ErrorsTab.showErrors(event.data.item)
changeTab(event.target, 'main', 'errors_tab')
}
function analyzeLink(link) { function analyzeLink(link) {
LinkAnalyzerTab.reset() LinkAnalyzerTab.reset()
socket.emit('analyzeLink', link) socket.emit('analyzeLink', link)
@ -286,5 +292,6 @@ export default {
init, init,
changeTab, changeTab,
showView, showView,
analyzeLink analyzeLink,
showErrors
} }

View file

@ -192,7 +192,7 @@ a:visited {
} }
.clickable { .clickable {
cursor: pointer; cursor: pointer !important;
} }
.toastify { .toastify {