Skip to content

Commit

Permalink
Finishing Date Added, adding File Size sorts
Browse files Browse the repository at this point in the history
  • Loading branch information
qcasey committed Jul 16, 2019
1 parent 99209b4 commit 4d6fcba
Show file tree
Hide file tree
Showing 6 changed files with 58 additions and 11 deletions.
4 changes: 3 additions & 1 deletion src/shared/types/interfaces.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,8 @@ export enum SortBy {
TITLE = 'title',
DURATION = 'duration',
GENRE = 'genre',
DATE_ADDED = 'date added'
DATE_ADDED = 'date added',
FILESIZE = 'filesize'
}

export enum SortOrder {
Expand Down Expand Up @@ -89,6 +90,7 @@ export interface Track {
};
year: number | null;
dateAdded: Date | null;
filesize: number | null; // in MB
}

export interface Playlist {
Expand Down
7 changes: 5 additions & 2 deletions src/ui/components/TrackRow/TrackRow.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -147,8 +147,11 @@ export default class TrackRow extends React.PureComponent<Props, State> {
<div className={`${styles.cell} ${cellStyles.cellAlbum}`}>
{ track.album }
</div>
<div className={`${styles.cell} ${cellStyles.cellGenre}`}>
{ track.genre.join(', ') }
<div className={`${styles.cell} ${cellStyles.cellDuration}`}>
{ track.filesize ? track.filesize.toString() + ' MB' : '-' }
</div>
<div className={`${styles.cell} ${cellStyles.cellDateAdded}`}>
{ track.dateAdded ? track.dateAdded.toLocaleString() : 'Unknown' }
</div>
</div>
);
Expand Down
2 changes: 1 addition & 1 deletion src/ui/components/TracksListHeader/TracksListHeader.css
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
}

.cell-track {
flex: 1;
width: calc(26% - 30px);
}

.cell-duration {
Expand Down
12 changes: 9 additions & 3 deletions src/ui/components/TracksListHeader/TracksListHeader.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -66,11 +66,17 @@ class TracksListHeader extends React.Component<Props> {
sortBy={enableSort ? SortBy.ALBUM : null}
icon={TracksListHeader.getIcon(sort, SortBy.ALBUM)}
/>
<TracksListHeaderCell
className={styles.cellDuration}
title='Filesize'
sortBy={enableSort ? SortBy.FILESIZE : null}
icon={TracksListHeader.getIcon(sort, SortBy.FILESIZE)}
/>
<TracksListHeaderCell
className={styles.cellGenre}
title='Genre'
sortBy={enableSort ? SortBy.GENRE : null}
icon={TracksListHeader.getIcon(sort, SortBy.GENRE)}
title='Date Added'
sortBy={enableSort ? SortBy.DATE_ADDED : null}
icon={TracksListHeader.getIcon(sort, SortBy.DATE_ADDED)}
/>
</div>
);
Expand Down
31 changes: 28 additions & 3 deletions src/ui/constants/sort-orders.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { Track, SortOrder, SortBy } from '../../shared/types/interfaces';
// the is far more resource/time impactful
const parseArtist = (t: Track): string => t.loweredMetas.artist.toString();
const parseGenre = (t: Track): string => t.loweredMetas.genre.toString();
const parseDateAdded = (t: Track): string => t.dateAdded ? t.dateAdded.getTime().toString() : '0';

// Declarations
const sortOrders = {
Expand Down Expand Up @@ -113,7 +114,7 @@ const sortOrders = {
],
[SortOrder.DSC]: [
[
parseGenre,
parseDateAdded,
parseArtist,
'year',
'loweredMetas.album',
Expand All @@ -126,7 +127,7 @@ const sortOrders = {
[SortBy.DATE_ADDED]: {
[SortOrder.ASC]: [
[
parseGenre,
parseDateAdded,
parseArtist,
'year',
'loweredMetas.album',
Expand All @@ -137,7 +138,31 @@ const sortOrders = {
],
[SortOrder.DSC]: [
[
parseGenre,
parseDateAdded,
parseArtist,
'year',
'loweredMetas.album',
'disk.no',
'track.no'
],
['desc']
]
},
[SortBy.FILESIZE]: {
[SortOrder.ASC]: [
[
'filesize',
parseArtist,
'year',
'loweredMetas.album',
'disk.no',
'track.no'
],
null
],
[SortOrder.DSC]: [
[
'filesize',
parseArtist,
'year',
'loweredMetas.album',
Expand Down
13 changes: 12 additions & 1 deletion src/ui/utils/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,15 @@ export const stripAccents = (str: string): string => {
return str.replace(reg, replacement).toLowerCase();
};

export const roundNumber = (num: number, scale: number): number => {
let arr = ('' + num).split('e');
let sig = '';
if (+arr[1] + scale > 0) {
sig = '+';
}
return +(Math.round(parseFloat(+arr[0] + 'e' + sig + (+arr[1] + scale))) + 'e-' + scale);
}

/**
* Remove duplicates (realpath) and useless children folders
*/
Expand Down Expand Up @@ -124,7 +133,8 @@ export const getDefaultMetadata = (): Track => ({
of: 0
},
year: null,
dateAdded: null
dateAdded: null,
filesize: null
});

export const parseMusicMetadata = (data: mmd.IAudioMetadata, trackPath: string): Partial<Track> => {
Expand Down Expand Up @@ -210,6 +220,7 @@ export const getMetadata = async (trackPath: string): Promise<Track> => {
}

metadata.dateAdded = new Date();
metadata.filesize = Math.round(stats.size / 1000000.0);

return metadata;
} catch (err) {
Expand Down

0 comments on commit 4d6fcba

Please sign in to comment.