From d8a0d5df3f085c6814e4761f147725c40dd2a636 Mon Sep 17 00:00:00 2001 From: MichaelRow Date: Sat, 26 Dec 2015 09:43:09 +0800 Subject: [PATCH] Deinit menu bar lyrics when disabled --- Lyrics/AppController.swift | 17 +++++++++++------ Lyrics/MenuBarLyrics.swift | 1 + 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/Lyrics/AppController.swift b/Lyrics/AppController.swift index 322b8bc..a99f79d 100644 --- a/Lyrics/AppController.swift +++ b/Lyrics/AppController.swift @@ -113,6 +113,7 @@ class AppController: NSObject { } deinit { + NSStatusBar.systemStatusBar().removeStatusItem(statusItem) NSNotificationCenter.defaultCenter().removeObserver(self) NSDistributedNotificationCenter.defaultCenter().removeObserver(self) } @@ -190,8 +191,9 @@ class AppController: NSObject { @IBAction func enableMenuBarLyrics(sender:AnyObject?) { if (sender as! NSMenuItem).state == NSOnState { - menuBarLyrics.displayLyrics(nil) + menuBarLyrics = nil } else { + menuBarLyrics = MenuBarLyrics() menuBarLyrics.displayLyrics(currentLyrics as String) } } @@ -426,7 +428,9 @@ class AppController: NSObject { self.currentLyrics = nil dispatch_async(dispatch_get_main_queue(), { () -> Void in self.lyricsWindow.displayLyrics(nil, secondLyrics: nil) - self.menuBarLyrics.displayLyrics(nil) + if self.menuBarLyrics != nil { + self.menuBarLyrics.displayLyrics(nil) + } }) } NSLog("iTunes Paused") @@ -679,7 +683,7 @@ class AppController: NSObject { self.lyricsWindow.displayLyrics(nil, secondLyrics: nil) }) } - if userDefaults.boolForKey(LyricsMenuBarLyricsEnabled) { + if menuBarLyrics != nil { menuBarLyrics.displayLyrics(nil) } } @@ -699,7 +703,7 @@ class AppController: NSObject { self.lyricsWindow.displayLyrics(self.currentLyrics, secondLyrics: secondLyrics) }) } - if userDefaults.boolForKey(LyricsMenuBarLyricsEnabled) { + if menuBarLyrics != nil { menuBarLyrics.displayLyrics(currentLyrics as String) } } @@ -715,7 +719,7 @@ class AppController: NSObject { self.lyricsWindow.displayLyrics(self.currentLyrics, secondLyrics: nil) }) } - if userDefaults.boolForKey(LyricsMenuBarLyricsEnabled) { + if menuBarLyrics != nil { menuBarLyrics.displayLyrics(currentLyrics as String) } } @@ -964,13 +968,14 @@ class AppController: NSObject { if isDesktopLyricsOn && isMenuBarLyricsOn { userDefaults.setBool(false, forKey: LyricsMenuBarLyricsEnabled) MessageWindowController.sharedMsgWindow.displayMessage(NSLocalizedString("DESKTOP_ON", comment: "")) - menuBarLyrics.displayLyrics(nil) + menuBarLyrics = nil } else if isDesktopLyricsOn && !isMenuBarLyricsOn { userDefaults.setBool(false, forKey: LyricsDesktopLyricsEnabled) userDefaults.setBool(true, forKey: LyricsMenuBarLyricsEnabled) MessageWindowController.sharedMsgWindow.displayMessage(NSLocalizedString("MENU_BAR_ON", comment: "")) lyricsWindow.displayLyrics(nil, secondLyrics: nil) + menuBarLyrics = MenuBarLyrics() menuBarLyrics.displayLyrics(currentLyrics as String) } else { diff --git a/Lyrics/MenuBarLyrics.swift b/Lyrics/MenuBarLyrics.swift index 1e27082..ca6818f 100644 --- a/Lyrics/MenuBarLyrics.swift +++ b/Lyrics/MenuBarLyrics.swift @@ -23,6 +23,7 @@ class MenuBarLyrics: NSObject { } deinit { + NSStatusBar.systemStatusBar().removeStatusItem(statusItem) NSLog("Deint StatusBarLyrics") }