/*
Things to do:
-¥ Radio mode makes things act oddly
¥ Make preferences window pretty
¥ Hot Keys
- hot keys can't be set when NSBGOnly is on. The window is not key,
- going to need a different way of defining key combos
¥ Optimize
¥ Apple Events! Apple Events! Apple Events!
-¥ Upcoming songs menu items are disabled after launching iTunes and playing
*/
#import "MenuTunes.h"
[[statusItem _button] setAlternateImage:[NSImage imageNamed:@"selected_image"]];
[statusItem setHighlightMode:YES];
[statusItem setMenu:menu];
+ // Below line of code is for creating builds for Beta Testers
+ // [statusItem setToolTip:@"This Nontransferable Beta (Built on __DATE__) of iThink Software's MenuTunes is Registered to: Beta Tester (betatester@somedomain.com)."];
[statusItem retain];
// view = [[MenuTunesView alloc] initWithFrame:[[statusItem view] frame]];
// [statusItem setView:view];
if (index > -1) {
[menu removeItemAtIndex:index + 1];
-
- if (!isPlayingRadio) {
- if (didHaveAlbumName) {
- [menu removeItemAtIndex:index + 1];
- }
+ if (didHaveAlbumName) {
+ [menu removeItemAtIndex:index + 1];
}
}
if (!isPlayingRadio) {
[upcomingSongsMenu release];
upcomingSongsMenu = [[NSMenu alloc] initWithTitle:@""];
+ [upcomingSongsItem setSubmenu:upcomingSongsMenu];
+ [upcomingSongsItem setEnabled:YES];
for (i = curTrack + 1; i <= curTrack + numSongsInAdvance; i++) {
if (i <= numSongs) {
[upcomingSongsMenu addItem:songItem];
[songItem release];
} else {
- [upcomingSongsMenu addItemWithTitle:@"End of playlist." action:nil keyEquivalent:@""];
break;
}
}
- [upcomingSongsItem setSubmenu:upcomingSongsMenu];
- [upcomingSongsItem setEnabled:YES];
}
} else {
[upcomingSongsItem setSubmenu:nil];
- (void)timerUpdate
{
int pid;
-
if (GetProcessPID(&iTunesPSN, &pid) == noErr) {
int trackPlayingIndex = [[self runScriptAndReturnResult:@"return index of current track"] intValue];
if (trackPlayingIndex != curTrackIndex) {
+ bool wasPlayingRadio = isPlayingRadio;
isPlayingRadio = [[self runScriptAndReturnResult:@"return class of current playlist"] isEqualToString:@"radio tuner playlist"];
+ if (isPlayingRadio && !wasPlayingRadio) {
+ int i;
+ for (i = 0; i < [playlistMenu numberOfItems]; i++)
+ {
+ [[playlistMenu itemAtIndex:i] setState:NSOffState];
+ }
+ }
+ if (wasPlayingRadio) {
+ NSMenuItem *temp = [[NSMenuItem alloc] initWithTitle:@"" action:NULL keyEquivalent:@""];
+ [menu insertItem:temp atIndex:trackInfoIndex + 1];
+ [temp release];
+ }
[self updateMenu];
curTrackIndex = trackPlayingIndex;
}
-
+ else
+ {
+ int playlist = [[self runScriptAndReturnResult:@"return index of current playlist"] intValue];
+ if (playlist != curPlaylistIndex) {
+ bool wasPlayingRadio = isPlayingRadio;
+ isPlayingRadio = [[self runScriptAndReturnResult:@"return class of current playlist"] isEqualToString:@"radio tuner playlist"];
+ if (isPlayingRadio && !wasPlayingRadio) {
+ int i;
+ for (i = 0; i < [playlistMenu numberOfItems]; i++)
+ {
+ [[playlistMenu itemAtIndex:i] setState:NSOffState];
+ }
+ }
+ if (wasPlayingRadio) {
+ NSMenuItem *temp = [[NSMenuItem alloc] initWithTitle:@"" action:NULL keyEquivalent:@""];
+ [menu insertItem:temp atIndex:trackInfoIndex + 1];
+ [temp release];
+ }
+ [self updateMenu];
+ curTrackIndex = trackPlayingIndex;
+ curPlaylistIndex = playlist;
+ }
+ }
//Update Play/Pause menu item
if (playPauseMenuItem){
if ([[self runScriptAndReturnResult:@"return player state"] isEqualToString:@"playing"]) {
- (void)selectPlaylist:(id)sender
{
int playlist = [[sender representedObject] intValue];
- int curPlaylist = [[self runScriptAndReturnResult:@"return index of current playlist"] intValue];
- [[playlistMenu itemAtIndex:curPlaylist - 1] setState:NSOffState];
+ if (!isPlayingRadio) {
+ int curPlaylist = [[self runScriptAndReturnResult:@"return index of current playlist"] intValue];
+ [[playlistMenu itemAtIndex:curPlaylist - 1] setState:NSOffState];
+ }
[self runScriptAndReturnResult:[NSString stringWithFormat:@"play playlist %i", playlist]];
[[playlistMenu itemAtIndex:playlist - 1] setState:NSOnState];
- [self updateMenu];
}
- (void)selectEQPreset:(id)sender