Tons of new stuff. Made is compile now too :)
authorKent Sutherland <ksuther@ithinksw.com>
Thu, 8 May 2003 22:43:10 +0000 (22:43 +0000)
committerKent Sutherland <ksuther@ithinksw.com>
Thu, 8 May 2003 22:43:10 +0000 (22:43 +0000)
MainController.h
MainController.m
MenuController.h
MenuController.m

index 3db1655..8438c82 100755 (executable)
 #import <ITFoundation/ITFoundation.h>
 #import <ITMTRemote/ITMTRemote.h>
 
-
-@class StatusWindowController;
-
+@class StatusWindowController, MenuController;
 
 @interface MainController : NSObject
 {
     ITStatusItem   *statusItem;
     NSMutableArray *remoteArray;
     ITMTRemote     *currentRemote;
-
+    
     ITMTRemotePlayerRunningState  playerRunningState;
     ITMTRemotePlayerPlaylistClass latestPlaylistClass;
     
     //Used in updating the menu automatically
     NSTimer *refreshTimer;
-
     NSString *_latestSongIdentifier;
-
-    StatusWindowController *statusWindowController; //Shows track info and upcoming songs.
+    
+    StatusWindowController *statusWindowController; //Shows status windows
+    MenuController *menuController;
     NSUserDefaults *df;
 }
 + (MainController *)sharedController;
 
+- (void)menuClicked;
+
 //Methods called from MenuController by menu items
 - (void)playPause;
 - (void)nextSong;
index 475a23e..eb48f5a 100755 (executable)
@@ -1,7 +1,9 @@
 #import "NewMainController.h"
+#import "MenuController.h"
 #import "PreferencesController.h"
 #import "HotKeyCenter.h"
 #import "StatusWindowController.h"
+#import "StatusItemHack.h"
 
 @interface MainController(Private)
 - (ITMTRemote *)loadRemote;
@@ -32,6 +34,7 @@ static MainController *sharedController;
         
         remoteArray = [[NSMutableArray alloc] initWithCapacity:1];
         statusWindowController = [[StatusWindowController alloc] init];
+        menuController = [[MenuController alloc] init];
         df = [[NSUserDefaults standardUserDefaults] retain];
         [self setLatestSongIdentifier:@"0-0"];
     }
@@ -60,6 +63,7 @@ static MainController *sharedController;
         [[PreferencesController sharedPrefs] registerDefaults];
     }
     
+    [StatusItemHack install];
     statusItem = [[ITStatusItem alloc]
             initWithStatusBar:[NSStatusBar systemStatusBar]
             withLength:NSSquareStatusItemLength];
@@ -172,6 +176,12 @@ static MainController *sharedController;
 */
 }
 
+- (void)menuClicked
+{
+    [statusItem setMenu:[menuController menu]];
+    NSLog(@"The menu was clix0r3d, do something!");
+}
+
 //
 //
 // Menu Selectors
@@ -498,8 +508,9 @@ static MainController *sharedController;
     [currentRemote halt];
     [statusItem release];
     [statusWindowController release];
+    [menuController release];
     [super dealloc];
 }
 
 
-@end
+@end
\ No newline at end of file
index 8a5091f..c829533 100755 (executable)
@@ -39,6 +39,7 @@ typedef enum {
 @interface MenuController : NSObject
 {
     NSMutableArray *_menuLayout;
+    NSMenu *_currentMenu;
 }
 
 - (NSMenu *)menu;
index f434ccc..8077d29 100755 (executable)
@@ -7,23 +7,64 @@
 //
 
 #import "MenuController.h"
-#import "MainController.h"
+#import "NewMainController.h"
+#import "ITMTRemote.h"
 
 @implementation MenuController
 
 - (id)init
 {
     if ( (self = [super init]) ) {
-        _menuLayout = [[NSMutableArray alloc] initWithCapacity:
+        _menuLayout = [[NSMutableArray alloc] initWithCapacity:0];
     }
     return self;
 }
 
 - (NSMenu *)menu
 {
+    NSMenu *menu = [[NSMenu alloc] initWithTitle:@""];
+    NSArray *menuArray = [[NSUserDefaults standardUserDefaults] arrayForKey:@"menu"];
+    NSEnumerator *enumerator = [menuArray objectEnumerator];
+    NSString *nextObject;
+    ITMTRemote *currentRemote = [[MainController sharedController] currentRemote];
+    NSMenuItem *tempItem;
+    
+    //Get the current playlist, track index, etc.
+    int playlistIndex = [currentRemote currentPlaylistIndex];
+    int trackIndex = [currentRemote currentSongIndex];
+    
     // dynamically create menu from supplied data and layout information.
-    // ...
-    // right before returning the menu, set the created menu to instance variable _currentMenu.
+    while ( (nextObject = [enumerator nextObject]) ) {
+        if ([nextObject isEqualToString:@"Play/Pause"]) {
+            if ([currentRemote playerPlayingState] == ITMTRemotePlayerPlaying) {
+                tempItem = [menu addItemWithTitle:@"Pause"
+                        action:@selector(performMainMenuAction:)
+                        keyEquivalent:@""];
+                [tempItem setTag:MTMenuPlayPauseItem];
+                [tempItem setTarget:self];
+            } else {
+                tempItem = [menu addItemWithTitle:@"Play"
+                        action:@selector(performMainMenuAction:)
+                        keyEquivalent:@""];
+                [tempItem setTag:MTMenuPlayPauseItem];
+                [tempItem setTarget:self];
+            }
+        }
+        
+        if ([nextObject isEqualToString:@"Current Track Info"]) {
+            NSString *title = [currentRemote currentSongTitle];
+            [menu addItemWithTitle:@"Now Playing" action:NULL keyEquivalent:@""];
+            
+            if ([title length] > 0) {
+                [menu addItemWithTitle:[NSString stringWithFormat:@"    %@", title] action:nil keyEquivalent:@""];
+            }
+        }
+        //Do cool stuff here woo hehe gack yay! 0_o
+    }
+    
+    [_currentMenu release];
+    _currentMenu = menu;
+    return _currentMenu;
 }
 
 - (void)performMainMenuAction:(id)sender
 
 - (void)performEqualizerMenuAction:(id)sender
 {
-    [[MainController sharedController] selectEQItemAtIndex:[sender tag]]
+    [[MainController sharedController] selectEQPresetAtIndex:[sender tag]];
 }
 
 - (void)performUpcomingSongsMenuAction:(id)sender
 {
-    [[MainController sharedController] selectSongAtIndex:[sender tag]]
+    [[MainController sharedController] selectSongAtIndex:[sender tag]];
 }
 
 - (void)updateMenu
 
 - (BOOL)validateMenuItem:(id <NSMenuItem>)menuItem
 {
+    return YES;
 }
 
 - (NSString *)systemUIColor
     NSNumber *tmpNumber;
     if ( (tmpDict = [NSDictionary dictionaryWithContentsOfFile:[@"~/Library/Preferences/.GlobalPreferences.plist" stringByExpandingTildeInPath]]) ) {
         if ( (tmpNumber = [tmpDict objectForKey:@"AppleAquaColorVariant"]) ) {
-            if ( ([tmpNumber intValue == 1) ) {
+            if ( ([tmpNumber intValue] == 1) ) {
                 return @"Aqua";
             } else {
                 return @"Graphite";