|
|
@ -6,6 +6,8 @@ |
|
|
|
#import "ApplicationDelegate.h" |
|
|
|
#import "ApplicationDelegate.h" |
|
|
|
#import "CLTimezoneDataOperations.h" |
|
|
|
#import "CLTimezoneDataOperations.h" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
typedef void (^CompletionType)(void); |
|
|
|
|
|
|
|
|
|
|
|
@implementation MenubarController |
|
|
|
@implementation MenubarController |
|
|
|
|
|
|
|
|
|
|
|
@synthesize statusItemView = _statusItemView; |
|
|
|
@synthesize statusItemView = _statusItemView; |
|
|
@ -59,7 +61,7 @@ |
|
|
|
|
|
|
|
|
|
|
|
- (NSTextField *)setUpTextfieldForMenubar |
|
|
|
- (NSTextField *)setUpTextfieldForMenubar |
|
|
|
{ |
|
|
|
{ |
|
|
|
NSTextField *textField= [[NSTextField alloc] initWithFrame:NSMakeRect(0, 0, STATUS_ITEM_VIEW_WIDTH, 18)]; |
|
|
|
NSTextField *textField= [[NSTextField alloc] initWithFrame:NSMakeRect(0, 0, STATUS_ITEM_VIEW_WIDTH, 22)]; |
|
|
|
textField.backgroundColor = [NSColor whiteColor]; |
|
|
|
textField.backgroundColor = [NSColor whiteColor]; |
|
|
|
textField.bordered = NO; |
|
|
|
textField.bordered = NO; |
|
|
|
textField.textColor = [NSColor blackColor]; |
|
|
|
textField.textColor = [NSColor blackColor]; |
|
|
@ -75,18 +77,45 @@ |
|
|
|
|
|
|
|
|
|
|
|
- (void)setUpTimerForUpdatingMenubar |
|
|
|
- (void)setUpTimerForUpdatingMenubar |
|
|
|
{ |
|
|
|
{ |
|
|
|
self.menubarUpdateTimer = [NSTimer scheduledTimerWithTimeInterval:1.0 |
|
|
|
self.checkIfMenubarUpdatingWasCancelled = NO; |
|
|
|
target:self |
|
|
|
[self tryingSomethingHere]; |
|
|
|
selector:@selector(updateMenubar) |
|
|
|
|
|
|
|
userInfo:nil |
|
|
|
|
|
|
|
repeats:YES]; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
- (void)invalidateTimerForMenubar |
|
|
|
- (void)tryingSomethingHere |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//a block calling itself without the ARC retain warning |
|
|
|
|
|
|
|
__block CompletionType completionBlock = nil; |
|
|
|
|
|
|
|
__block __weak CompletionType weakCompletionBlock = nil; |
|
|
|
|
|
|
|
completionBlock = ^(void) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
double delayInSeconds = 1.0; |
|
|
|
|
|
|
|
dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC); |
|
|
|
|
|
|
|
dispatch_after(popTime, dispatch_get_main_queue(), ^(void){ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(!self.checkIfMenubarUpdatingWasCancelled) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
[self updateMenubar]; |
|
|
|
|
|
|
|
weakCompletionBlock = completionBlock; |
|
|
|
|
|
|
|
weakCompletionBlock(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
completionBlock(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- (void)stoppingTheMenubar |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
self.checkIfMenubarUpdatingWasCancelled = YES; |
|
|
|
[self.statusItemView setNeedsDisplay:YES]; |
|
|
|
[self.statusItemView setNeedsDisplay:YES]; |
|
|
|
[self.menubarUpdateTimer invalidate]; |
|
|
|
} |
|
|
|
self.menubarUpdateTimer = nil; |
|
|
|
|
|
|
|
|
|
|
|
- (void)invalidateTimerForMenubar |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
[self stoppingTheMenubar]; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
- (NSImage *)convertTextfieldRepresentationToImage:(NSTextField *)textField |
|
|
|
- (NSImage *)convertTextfieldRepresentationToImage:(NSTextField *)textField |
|
|
|