+- (void)showCurrentTrackInfoHotKey
+{
+ //If we're already visible and the setting says so, vanish instead of displaying again.
+ if ([df boolForKey:@"ToggleTrackInfoWithHotKey"] && [statusWindowController currentStatusWindowType] == StatusWindowTrackInfoType && [[StatusWindow sharedWindow] visibilityState] == ITWindowVisibleState) {
+ ITDebugLog(@"Track window is already visible, hiding track window.");
+ [self invalidateStatusWindowUpdateTimer];
+ [[StatusWindow sharedWindow] vanish:nil];
+ return;
+ }
+ [self showCurrentTrackInfo];
+}
+
+- (void)showCurrentAlbumArtHotKey
+{
+ //If we're already visible and the setting says so, vanish instead of displaying again.
+ if ([df boolForKey:@"ToggleTrackInfoWithHotKey"] && [statusWindowController currentStatusWindowType] == StatusWindowAlbumArtType && [[StatusWindow sharedWindow] visibilityState] == ITWindowVisibleState) {
+ ITDebugLog(@"Art window is already visible, hiding track window.");
+ [[StatusWindow sharedWindow] vanish:nil];
+ return;
+ }
+ [self showCurrentAlbumArt];
+}
+
+- (void)showCurrentAlbumArt
+{
+ NSImage *art = nil;
+ NS_DURING
+ art = [[self currentRemote] currentSongAlbumArt];
+ NS_HANDLER
+ [self networkError:localException];
+ NS_ENDHANDLER
+
+ if (art) {
+ NSSize oldSize = [art size], newSize;
+ if (oldSize.width > 300 && oldSize.height > 300) {
+ if (oldSize.width > oldSize.height) {
+ newSize = NSMakeSize(300, oldSize.height * (300.0f / oldSize.width));
+ } else {
+ newSize = NSMakeSize(oldSize.width * (300.0f / oldSize.height), 300);
+ }
+ } else {
+ newSize = oldSize;
+ }
+
+ art = [[[[NSImage alloc] initWithData:[art TIFFRepresentation]] autorelease] imageScaledSmoothlyToSize:newSize];
+
+ [statusWindowController showAlbumArtWindowWithImage:art];
+ } else {
+ NSString *string = nil;
+ NS_DURING
+ if ([[self currentRemote] currentSongTitle]) {
+ string = NSLocalizedString(@"noAlbumArt", @"No art for current song.");
+ } else {
+ string = NSLocalizedString(@"noSongPlaying", @"No song is playing.");
+ }
+ NS_HANDLER
+ [self networkError:localException];
+ NS_ENDHANDLER
+ //Show the no song playing window if there is no album art or no track is playing
+ [statusWindowController showAlbumArtWindowWithErrorText:string];
+ }
+}
+