feat(ui): add scan progress and error reporting to UI (#4094)
* feat(scanner): add LastScanError tracking to scanner status - Introduced LastScanErrorKey constant for error tracking. - Updated StatusInfo struct to include LastError field. - Modified scanner logic to store and retrieve last scan error. - Enhanced ScanStatus response to include error information. - Updated UI components to display last scan error when applicable. - Added tests to verify last scan error functionality. Signed-off-by: Deluan <deluan@navidrome.org> * feat(scanner): enhance scan status with type and elapsed time tracking - Added LastScanTypeKey and LastScanStartTimeKey constants for tracking scan type and start time. - Updated StatusInfo struct to include ScanType and ElapsedTime fields. - Implemented getScanInfo method to retrieve scan type, elapsed time, and last error. - Modified scanner logic to store scan type and start time during scans. - Enhanced ScanStatus response and UI components to display scan type and elapsed time. - Added formatShortDuration utility for better elapsed time representation. - Updated activity reducer to handle new scan status fields. Signed-off-by: Deluan <deluan@navidrome.org> * refactor(tests): consolidate controller status tests into a single file - Removed the old controller_status_test.go file. - Merged relevant tests into the new controller_test.go file for better organization and maintainability. - Ensured all existing test cases for controller status are preserved and functional. Signed-off-by: Deluan <deluan@navidrome.org> * Fix formatting issues * refactor(scanner): update getScanInfo method documentation --------- Signed-off-by: Deluan <deluan@navidrome.org>
This commit is contained in:
@@ -25,6 +25,26 @@ export const formatDuration = (d) => {
|
||||
return `${days > 0 ? days + ':' : ''}${f}`
|
||||
}
|
||||
|
||||
export const formatShortDuration = (ns) => {
|
||||
// Convert nanoseconds to seconds
|
||||
const seconds = ns / 1e9
|
||||
if (seconds < 1.0) {
|
||||
return '<1s'
|
||||
}
|
||||
|
||||
const hours = Math.floor(seconds / 3600)
|
||||
const minutes = Math.floor((seconds % 3600) / 60)
|
||||
const secs = Math.floor(seconds % 60)
|
||||
|
||||
if (hours > 0) {
|
||||
return `${hours}h${minutes}m`
|
||||
}
|
||||
if (minutes > 0) {
|
||||
return `${minutes}m${secs}s`
|
||||
}
|
||||
return `${secs}s`
|
||||
}
|
||||
|
||||
export const formatFullDate = (date, locale) => {
|
||||
const dashes = date.split('-').length - 1
|
||||
let options = {
|
||||
|
||||
@@ -1,4 +1,9 @@
|
||||
import { formatBytes, formatDuration, formatFullDate } from './formatters'
|
||||
import {
|
||||
formatBytes,
|
||||
formatDuration,
|
||||
formatFullDate,
|
||||
formatShortDuration,
|
||||
} from './formatters'
|
||||
|
||||
describe('formatBytes', () => {
|
||||
it('format bytes', () => {
|
||||
@@ -32,6 +37,33 @@ describe('formatDuration', () => {
|
||||
})
|
||||
})
|
||||
|
||||
describe('formatShortDuration', () => {
|
||||
// Convert seconds to nanoseconds for the tests
|
||||
const toNs = (seconds) => seconds * 1e9
|
||||
|
||||
it('formats less than a second', () => {
|
||||
expect(formatShortDuration(toNs(0.5))).toEqual('<1s')
|
||||
expect(formatShortDuration(toNs(0))).toEqual('<1s')
|
||||
})
|
||||
|
||||
it('formats seconds', () => {
|
||||
expect(formatShortDuration(toNs(1))).toEqual('1s')
|
||||
expect(formatShortDuration(toNs(59))).toEqual('59s')
|
||||
})
|
||||
|
||||
it('formats minutes and seconds', () => {
|
||||
expect(formatShortDuration(toNs(60))).toEqual('1m0s')
|
||||
expect(formatShortDuration(toNs(90))).toEqual('1m30s')
|
||||
expect(formatShortDuration(toNs(59 * 60 + 59))).toEqual('59m59s')
|
||||
})
|
||||
|
||||
it('formats hours and minutes', () => {
|
||||
expect(formatShortDuration(toNs(3600))).toEqual('1h0m')
|
||||
expect(formatShortDuration(toNs(3600 + 30 * 60))).toEqual('1h30m')
|
||||
expect(formatShortDuration(toNs(24 * 3600 - 1))).toEqual('23h59m')
|
||||
})
|
||||
})
|
||||
|
||||
describe('formatFullDate', () => {
|
||||
it('format dates', () => {
|
||||
expect(formatFullDate('2011', 'en-US')).toEqual('2011')
|
||||
|
||||
Reference in New Issue
Block a user