playerPlayingState works properly in 10.4 now. It should work in 10.3/10.2 fine also...
[MenuTunes.git] / StatusWindowController.m
index 146c1a8..633c31c 100755 (executable)
@@ -1,14 +1,9 @@
-//
-//  StatusWindowController.m
-//  MenuTunes
-//
-//  Created by Matthew L. Judy on Thu Apr 17 2003.
-//  Copyright (c) 2003 NibFile.com. All rights reserved.
-//
-
 #import "StatusWindowController.h"
 #import "StatusWindow.h"
 #import "StatusWindowController.h"
 #import "StatusWindow.h"
+#import "PreferencesController.h"
+#import "MainController.h"
 
 
+#import <ITKit/ITTSWBackgroundView.h>
 #import <ITKit/ITWindowEffect.h>
 #import <ITKit/ITCutWindowEffect.h>
 #import <ITKit/ITDissolveWindowEffect.h>
 #import <ITKit/ITWindowEffect.h>
 #import <ITKit/ITCutWindowEffect.h>
 #import <ITKit/ITDissolveWindowEffect.h>
 #import <ITKit/ITSlideVerticallyWindowEffect.h>
 #import <ITKit/ITPivotWindowEffect.h>
 
 #import <ITKit/ITSlideVerticallyWindowEffect.h>
 #import <ITKit/ITPivotWindowEffect.h>
 
+static StatusWindowController *sharedController;
+
 @implementation StatusWindowController
 
 
 @implementation StatusWindowController
 
 
++ (StatusWindowController *)sharedController
+{
+    if ( ! sharedController ) {
+        sharedController = [[StatusWindowController alloc] init];
+    }
+    
+    return sharedController;
+}
+
+
 - (id)init
 {
     if ( ( self = [super init] ) ) {
 - (id)init
 {
     if ( ( self = [super init] ) ) {
-    
+        
         float exitDelay;
         float exitDelay;
-        int entryTag;
-        int exitTag;
+        NSString *entryClass;
+        NSString *exitClass;
+        NSArray  *classList = [ITWindowEffect effectClasses];
         float entrySpeed;
         float exitSpeed;
         float entrySpeed;
         float exitSpeed;
+               NSArray *screens = [NSScreen screens];
+               int screenIndex;
+        
+        NSData *colorData;
         
         ITWindowEffect *entryEffect;
         ITWindowEffect *exitEffect;
         
         ITWindowEffect *entryEffect;
         ITWindowEffect *exitEffect;
-
+        
         _window = [[StatusWindow sharedWindow] retain];
         df = [[NSUserDefaults standardUserDefaults] retain];
         _window = [[StatusWindow sharedWindow] retain];
         df = [[NSUserDefaults standardUserDefaults] retain];
-
+        
         exitDelay  = [df floatForKey:@"statusWindowVanishDelay"];
         exitDelay  = [df floatForKey:@"statusWindowVanishDelay"];
-        entryTag   = [df integerForKey:@"statusWindowAppearanceEffect"];
-        exitTag    = [df integerForKey:@"statusWindowVanishEffect"];
+        entryClass = [df stringForKey:@"statusWindowAppearanceEffect"];
+        exitClass  = [df stringForKey:@"statusWindowVanishEffect"];
         entrySpeed = [df floatForKey:@"statusWindowAppearanceSpeed"];
         exitSpeed  = [df floatForKey:@"statusWindowVanishSpeed"];
         entrySpeed = [df floatForKey:@"statusWindowAppearanceSpeed"];
         exitSpeed  = [df floatForKey:@"statusWindowVanishSpeed"];
-
+               
+               screenIndex = [df integerForKey:@"statusWindowScreenIndex"];
+               if (screenIndex >= [screens count]) {
+                       screenIndex = 0;
+               }
+               [_window setScreen:[screens objectAtIndex:screenIndex]];
+               
         [_window setExitMode:ITTransientStatusWindowExitAfterDelay];
         [_window setExitDelay:(exitDelay ? exitDelay : 4.0)];
         [_window setExitMode:ITTransientStatusWindowExitAfterDelay];
         [_window setExitDelay:(exitDelay ? exitDelay : 4.0)];
-
-        if ( entryTag == 2101 ) {
-            entryEffect = [[[ITDissolveWindowEffect alloc] initWithWindow:_window] autorelease];
-        } else if ( entryTag == 2102 ) {
-            entryEffect = [[[ITSlideVerticallyWindowEffect alloc] initWithWindow:_window] autorelease];
-        } else if ( entryTag == 2103 ) {
-            entryEffect = [[[ITSlideHorizontallyWindowEffect alloc] initWithWindow:_window] autorelease];
-        } else if ( entryTag == 2104 ) {
-            entryEffect = [[[ITPivotWindowEffect alloc] initWithWindow:_window] autorelease];
+        
+        [_window setHorizontalPosition:[df integerForKey:@"statusWindowHorizontalPosition"]];
+        [_window setVerticalPosition:[df integerForKey:@"statusWindowVerticalPosition"]];
+        
+        [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+        
+        if ( [classList containsObject:NSClassFromString(entryClass)] ) {
+            entryEffect = [[[NSClassFromString(entryClass) alloc] initWithWindow:_window] autorelease];
         } else {
             entryEffect = [[[ITCutWindowEffect alloc] initWithWindow:_window] autorelease];
         }
         } else {
             entryEffect = [[[ITCutWindowEffect alloc] initWithWindow:_window] autorelease];
         }
-
-        [_window setEntryEffect:entryEffect];
-
-        if ( exitTag == 2100 ) {
-            exitEffect = [[[ITCutWindowEffect alloc] initWithWindow:_window] autorelease];
-        } else if ( exitTag == 2102 ) {
-            exitEffect = [[[ITSlideVerticallyWindowEffect alloc] initWithWindow:_window] autorelease];
-        } else if ( exitTag == 2103 ) {
-            exitEffect = [[[ITSlideHorizontallyWindowEffect alloc] initWithWindow:_window] autorelease];
-        } else if ( exitTag == 2104 ) {
-            exitEffect = [[[ITPivotWindowEffect alloc] initWithWindow:_window] autorelease];
+        
+        if ( [classList containsObject:NSClassFromString(exitClass)] ) {
+            exitEffect = [[[NSClassFromString(exitClass) alloc] initWithWindow:_window] autorelease];
         } else {
             exitEffect = [[[ITDissolveWindowEffect alloc] initWithWindow:_window] autorelease];
         }
         } else {
             exitEffect = [[[ITDissolveWindowEffect alloc] initWithWindow:_window] autorelease];
         }
-
+        
+        [_window setEntryEffect:entryEffect];
         [_window setExitEffect:exitEffect];
         [_window setExitEffect:exitEffect];
-
+        
         [[_window entryEffect] setEffectTime:(entrySpeed ? entrySpeed : 0.8)];
         [[_window exitEffect]  setEffectTime:(exitSpeed  ? exitSpeed  : 0.8)];
         [[_window entryEffect] setEffectTime:(entrySpeed ? entrySpeed : 0.8)];
         [[_window exitEffect]  setEffectTime:(exitSpeed  ? exitSpeed  : 0.8)];
+        
+        [(ITTSWBackgroundView *)[_window contentView]setBackgroundMode:
+            (ITTSWBackgroundMode)[df integerForKey:@"statusWindowBackgroundMode"]];
+        
+        colorData = [df dataForKey:@"statusWindowBackgroundColor"];
+        
+        if ( colorData ) {
+            [(ITTSWBackgroundView *)[_window contentView] setBackgroundColor:
+                (NSColor *)[NSUnarchiver unarchiveObjectWithData:colorData]];
+        } else {
+            [(ITTSWBackgroundView *)[_window contentView] setBackgroundColor:[NSColor blueColor]];
+        }
     }
     
     return self;
     }
     
     return self;
     [super dealloc];
 }
 
     [super dealloc];
 }
 
-- (void)showSongWindowWithTitle:            (NSString *)title
-                          album:            (NSString *)album
-                         artist:            (NSString *)artist
-                           time:            (NSString *)time  // FLOW: Should probably be NSDate or something.
-                    trackNumber:                   (int)trackNumber
-                     trackTotal:                  (int)trackTotal
-                         rating:                   (int)rating
-                         source:(ITMTRemotePlayerSource)source
+- (void)showSongInfoWindowWithSource:(ITMTRemotePlayerSource)source
+                               title:            (NSString *)title
+                               album:            (NSString *)album
+                              artist:            (NSString *)artist
+                            composer:            (NSString *)composer
+                                time:            (NSString *)time  // FLOW: Should probably be NSDate or something.
+                               track:            (NSString *)track
+                              rating:                   (int)rating
+                           playCount:                   (int)playCount
+                               image:             (NSImage *)art
 {
 {
-    [_window setImage:[NSImage imageNamed:@"Library"]];
-    [_window setText:title];
+    NSImage  *image = nil;
+    NSString *text  = title;
+    
+    if ( art != nil ) {
+        image = art;
+    } else if ( source == ITMTRemoteLibrarySource ) {
+        image = [NSImage imageNamed:@"Library"];
+    } else if ( source == ITMTRemoteCDSource ) {
+        image = [NSImage imageNamed:@"CD"];
+    } else if ( source == ITMTRemoteRadioSource ) {
+        image = [NSImage imageNamed:@"Radio"];
+    } else if ( source == ITMTRemoteiPodSource ) {
+        image = [NSImage imageNamed:@"iPod"];
+    } else if ( source == ITMTRemoteGenericDeviceSource ) {
+        image = [NSImage imageNamed:@"MP3Player"];
+    } else if ( source == ITMTRemoteSharedLibrarySource ) {
+        image = [NSImage imageNamed:@"Library"];
+    }
+    
+    [_window setImage:image];
+    
+    if ( album ) {
+        text = [text stringByAppendingString:[@"\n" stringByAppendingString:album]];
+    }
+    if ( artist ) {
+        text = [text stringByAppendingString:[@"\n" stringByAppendingString:artist]];
+    }
+    if ( composer ) {
+        text = [text stringByAppendingString:[@"\n" stringByAppendingString:composer]];
+    }
+    if ( time ) {
+        text = [text stringByAppendingString:[@"\n" stringByAppendingString:time]];
+    }
+    if ( track ) {
+        text = [text stringByAppendingString:[@"\n" stringByAppendingString:track]];
+    }
+    if (playCount > -1) {
+        text = [text stringByAppendingString:[NSString stringWithFormat:@"\n%@: %i", NSLocalizedString(@"playCount", @"Play Count"), playCount]];
+    }
+    if ( rating > -1 ) {
+
+        NSString *ratingString = [NSString string];
+        NSString *emptyChar    = [NSString stringWithUTF8String:"☆"];
+        NSString *fullChar     = [NSString stringWithUTF8String:"★"];
+        int       i;
+        
+        for ( i = 1; i < 6; i++ ) {
+               
+            if ( rating >= i ) {
+                ratingString = [ratingString stringByAppendingString:fullChar];
+            } else {
+                ratingString = [ratingString stringByAppendingString:emptyChar];
+            }
+        }
+    
+        text = [text stringByAppendingString:[@"\n" stringByAppendingString:ratingString]];
+    }
+    
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildTextWindowWithString:text];
     [_window appear:self];
 }
 
     [_window appear:self];
 }
 
-- (void)showUpcomingSongsWithTitles:(NSArray *)titleStrings
+- (void)showUpcomingSongsWindowWithTitles:(NSArray *)titleStrings
 {
 {
+//  NSString *bull = [NSString stringWithUTF8String:"‣ "];
+    NSString *bull = [NSString stringWithUTF8String:"♪ "];
+    NSString *end  = [@"\n" stringByAppendingString:bull];
+    [_window setImage:[NSImage imageNamed:@"Upcoming"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildTextWindowWithString:[bull stringByAppendingString:[titleStrings componentsJoinedByString:end]]];
+    [_window appear:self];
+}
 
 
+- (void)showVolumeWindowWithLevel:(float)level
+{
+    [_window setImage:[NSImage imageNamed:@"Volume"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildMeterWindowWithCharacter:[NSString stringWithUTF8String:"▊"]
+                                      size:18
+                                     count:10
+                                    active:( ceil(level * 100) / 10 )];
+    [_window appear:self];
 }
 
 }
 
-- (void)showVolumeWindowWithLevel:(int)level
+- (void)showRatingWindowWithRating:(float)rating
 {
 {
+    [_window setImage:[NSImage imageNamed:@"Rating"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildMeterWindowWithCharacter:[NSString stringWithUTF8String:"★"]
+                                      size:48
+                                     count:5
+                                    active:( ceil(rating * 100) / 20 )];
+    [_window appear:self];
+}
 
 
+- (void)showShuffleWindow:(BOOL)shuffle
+{
+    [_window setImage:[NSImage imageNamed:@"Shuffle"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildTextWindowWithString:( shuffle ? NSLocalizedString(@"shuffleOn", @"Shuffle On") : NSLocalizedString(@"shuffleOff", @"Shuffle Off"))];
+    [_window appear:self];
 }
 
 }
 
-- (void)showRatingWindowWithLevel:(int)level
+- (void)showRepeatWindowWithMode:(StatusWindowRepeatMode)mode
 {
 {
+    NSString *string = nil;
+    
+    if ( mode == StatusWindowRepeatNone ) {
+        string = NSLocalizedString(@"repeatOff", @"Repeat Off");
+    } else if ( mode == StatusWindowRepeatGroup ) {
+        string = NSLocalizedString(@"repeatPlaylist", @"Repeat Playlist");
+    } else if ( mode == StatusWindowRepeatTrack ) {
+        string = NSLocalizedString(@"repeatOneTrack", @"Repeat One Track");;
+    }
+    
+    [_window setImage:[NSImage imageNamed:@"Repeat"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildTextWindowWithString:string];
+    [_window appear:self];
+}
 
 
+- (void)showSetupQueryWindow
+{
+    NSString *message = NSLocalizedString(@"autolaunch_msg", @"Would you like MenuTunes to launch\nautomatically at startup?");
+
+    [_window setImage:[NSImage imageNamed:@"Setup"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildDialogWindowWithMessage:message
+                            defaultButton:NSLocalizedString(@"launch_at_startup", @"Launch at Startup")
+                          alternateButton:NSLocalizedString(@"launch_manually", @"Launch Manually")
+                                   target:[PreferencesController sharedPrefs]
+                            defaultAction:@selector(autoLaunchOK)
+                          alternateAction:@selector(autoLaunchCancel)];
+
+    [_window appear:self];
+    [_window setLocked:YES];
+}
+
+
+- (void)showRegistrationQueryWindow
+{
+    NSString *message = NSLocalizedString(@"trialexpired_msg", @"Your 7-day unlimited trial period has elapsed.\nYou must register to continue using MenuTunes.");
+
+    [_window setImage:[NSImage imageNamed:@"Register"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildDialogWindowWithMessage:message
+                            defaultButton:NSLocalizedString(@"registernow", @"Register Now")
+                          alternateButton:NSLocalizedString(@"quitmenutunes", @"Quit MenuTunes")
+                                   target:[MainController sharedController]
+                            defaultAction:@selector(registerNowOK)
+                          alternateAction:@selector(registerNowCancel)];
+
+    [_window appear:self];
+    [_window setLocked:YES];
+}
+
+- (void)showReconnectQueryWindow
+{
+    NSString *message = NSLocalizedString(@"sharedplayeravailable_msg", @"The selected shared player is available again.\nWould you like to reconnect to it?");
+    [_window setLocked:NO];
+    [_window setImage:[NSImage imageNamed:@"Setup"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildDialogWindowWithMessage:message
+                            defaultButton:NSLocalizedString(@"reconnect", @"Reconnect")
+                          alternateButton:NSLocalizedString(@"ignore", @"Ignore")
+                                   target:[MainController sharedController]
+                            defaultAction:@selector(reconnect)
+                          alternateAction:@selector(cancelReconnect)];
+
+    [_window appear:self];
+    [_window setLocked:YES];
 }
 
 }
 
-- (void)showShuffleWindowWithMode:(MTStatusWindowShuffleMode)mode
+- (void)showNetworkErrorQueryWindow
 {
 {
+    NSString *message = NSLocalizedString(@"sharedplayerunreachable_msg", @"The remote MenuTunes server is unreachable.\nMenuTunes will revert back to the local player.");
+
+    [_window setImage:[NSImage imageNamed:@"Setup"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildDialogWindowWithMessage:message
+                            defaultButton:@" OK "
+                          alternateButton:nil
+                                   target:[MainController sharedController]
+                            defaultAction:@selector(cancelReconnect)
+                          alternateAction:nil];
 
 
+    [_window appear:self];
+    [_window setLocked:YES];
 }
 
 }
 
-- (void)showLoopWindowWithMode:(MTStatusWindowLoopMode)mode
+- (void)showPreferencesUpdateWindow
 {
 {
+    NSString *message = NSLocalizedString(@"reconfigureprefs_msg", @"The new features in this version of MenuTunes\nrequire you to reconfigure your preferences.");
 
 
+    [_window setImage:[NSImage imageNamed:@"Setup"]];
+    [_window setSizing:(ITTransientStatusWindowSizing)[df integerForKey:@"statusWindowSizing"]];
+    [_window buildDialogWindowWithMessage:message
+                            defaultButton:NSLocalizedString(@"showpreferences", @"Show Preferences")
+                          alternateButton:@"OK"
+                                   target:[MainController sharedController]
+                            defaultAction:@selector(showPreferencesAndClose)
+                          alternateAction:@selector(cancelReconnect)];
+
+    [_window appear:self];
+    [_window setLocked:YES];
 }
 
 @end
\ No newline at end of file
 }
 
 @end
\ No newline at end of file