+- (IBAction)changeSharingSetting:(id)sender
+{
+ ITDebugLog(@"Changing sharing setting of tag %i.", [sender tag]);
+ if ( [sender tag] == 5010 ) {
+ BOOL state = SENDER_STATE;
+ [df setBool:state forKey:@"enableSharing"];
+ //Disable/enable the use of shared player options
+ [useSharedMenuTunesCheckbox setEnabled:!state];
+ [sharePasswordCheckbox setEnabled:!state];
+ [sharePasswordTextField setEnabled:!state];
+ [controller setServerStatus:state]; //Set server status
+ } else if ( [sender tag] == 5020 ) {
+ [df setBool:SENDER_STATE forKey:@"enableSharingPassword"];
+ } else if ( [sender tag] == 5030 ) {
+ [df setObject:[sender stringValue] forKey:@"sharingPassword"];
+ } else if ( [sender tag] == 5040 ) {
+ BOOL state = SENDER_STATE;
+ [df setBool:state forKey:@"useSharedPlayer"];
+ //Disable/enable the use of sharing options
+ [shareMenuTunesCheckbox setEnabled:!state];
+ [sharePasswordCheckbox setEnabled:!state];
+ [sharePasswordTextField setEnabled:!state];
+
+ if (state) {
+ [controller connectToServer];
+ } else {
+ [controller disconnectFromServer];
+ }
+ } else if ( [sender tag] == 5050 ) {
+ if ([sender clickedRow] > -1) {
+ //Set sharedPlayerHost
+ [df setObject:[[[[NetworkController sharedController] remoteServices] objectAtIndex:[sender clickedRow]] objectForKey:@"ip"] forKey:@"sharedPlayerHost"];
+ }
+ } else if ( [sender tag] == 5060 ) {
+ //Show selection sheet
+ [NSApp beginSheet:selectPlayerSheet modalForWindow:window modalDelegate:self didEndSelector:NULL contextInfo:nil];
+ } else if ( [sender tag] == 5100 ) {
+ //Change view
+ if ( ([sender indexOfItem:[sender selectedItem]] == 0) && ([selectPlayerBox contentView] != zeroConfView) ) {
+ NSRect frame = [selectPlayerSheet frame];
+ frame.origin.y -= 58;
+ frame.size.height = 273;
+ [selectPlayerSheet setFrame:frame display:YES animate:YES];
+ [selectPlayerBox setContentView:zeroConfView];
+ } else if ([selectPlayerBox contentView] != manualView) {
+ NSRect frame = [selectPlayerSheet frame];
+ frame.origin.y += 58;
+ frame.size.height = 215;
+ [selectPlayerSheet setFrame:frame display:YES animate:YES];
+ [selectPlayerBox setContentView:manualView];
+ }
+ } else if ( [sender tag] == 5110 ) {
+ //Cancel
+ [NSApp endSheet:selectPlayerSheet];
+ [selectPlayerSheet orderOut:nil];
+ if ([selectPlayerBox contentView] == manualView) {
+ [hostTextField setStringValue:[df stringForKey:@"sharedPlayerHost"]];
+ } else {
+ }
+ } else if ( [sender tag] == 5120 ) {
+ //OK, try to connect
+ [NSApp endSheet:selectPlayerSheet];
+ [selectPlayerSheet orderOut:nil];
+
+ if (![controller connectToServer]) {
+ NSRunAlertPanel(@"Connection error.", @"The MenuTunes server you attempted to connect to was not responding. MenuTunes will revert back to the local player.", @"OK", nil, nil);
+ } else {
+ [useSharedMenuTunesCheckbox setState:NSOnState];
+ }
+
+ if ([selectPlayerBox contentView] == manualView) {
+ [df setObject:[hostTextField stringValue] forKey:@"sharedPlayerHost"];
+ } else {
+ }
+ }
+ [df synchronize];
+}
+