From db0986e95f809aa1fd92d5ca15cb2283f8bbf244 Mon Sep 17 00:00:00 2001 From: Kyle Spearrin Date: Fri, 4 May 2018 13:16:12 -0400 Subject: [PATCH] some fixes for tray icon --- jslib | 2 +- src/app/accounts/settings.component.html | 30 +++++++++---------- src/app/accounts/settings.component.ts | 13 ++++---- src/desktopConstants.ts | 3 ++ src/images/icon.ico | Bin 0 -> 20221 bytes src/locales/en/messages.json | 8 ++--- src/main.ts | 5 +++- src/main/tray.main.ts | 36 +++++++++++++---------- src/services/desktopconstants.service.ts | 5 ---- 9 files changed, 55 insertions(+), 47 deletions(-) create mode 100644 src/desktopConstants.ts create mode 100644 src/images/icon.ico delete mode 100644 src/services/desktopconstants.service.ts diff --git a/jslib b/jslib index c29b53cd..c3dad8fd 160000 --- a/jslib +++ b/jslib @@ -1 +1 @@ -Subproject commit c29b53cdd62369de59f6ae483b78b9bcc67d9238 +Subproject commit c3dad8fd1ae862476ccc417b4d33eecd3edd61a9 diff --git a/src/app/accounts/settings.component.html b/src/app/accounts/settings.component.html index f76e9f6f..6577a3d9 100644 --- a/src/app/accounts/settings.component.html +++ b/src/app/accounts/settings.component.html @@ -22,16 +22,6 @@ {{'options' | i18n}}
-
-
- -
- {{'gaDesc' | i18n}} -
-
- {{'enableHideInTrayDesc' | i18n}} + {{'enableMinToTrayDesc' | i18n}} +
+
+
+ +
+ {{'gaDesc' | i18n}}
diff --git a/src/app/accounts/settings.component.ts b/src/app/accounts/settings.component.ts index 568cf00b..e4782c36 100644 --- a/src/app/accounts/settings.component.ts +++ b/src/app/accounts/settings.component.ts @@ -14,7 +14,8 @@ import { StateService } from 'jslib/abstractions/state.service'; import { StorageService } from 'jslib/abstractions/storage.service'; import { ConstantsService } from 'jslib/services/constants.service'; -import { DesktopConstantsService } from '../../services/desktopconstants.service'; + +import { DesktopConstants } from '../../desktopConstants'; @Component({ selector: 'app-settings', @@ -24,7 +25,7 @@ export class SettingsComponent implements OnInit { lockOption: number = null; disableGa: boolean = false; disableFavicons: boolean = false; - enableHideInTray: boolean = false; + enableMinToTray: boolean = false; locale: string; lockOptions: any[]; localeOptions: any[]; @@ -57,7 +58,7 @@ export class SettingsComponent implements OnInit { async ngOnInit() { this.lockOption = await this.storageService.get(ConstantsService.lockOptionKey); this.disableFavicons = await this.storageService.get(ConstantsService.disableFaviconKey); - this.enableHideInTray = await this.storageService.get(DesktopConstantsService.enableHideInTrayKey); + this.enableMinToTray = await this.storageService.get(DesktopConstants.enableMinimizeToTrayKey); this.locale = await this.storageService.get(ConstantsService.localeKey); const disableGa = await this.storageService.get(ConstantsService.disableGaKey); @@ -86,9 +87,9 @@ export class SettingsComponent implements OnInit { this.callAnalytics('Favicons', !this.disableFavicons); } - async saveHideInTray() { - await this.storageService.save(DesktopConstantsService.enableHideInTrayKey, this.enableHideInTray); - this.callAnalytics('HideInTray', this.enableHideInTray); + async saveMinToTray() { + await this.storageService.save(DesktopConstants.enableMinimizeToTrayKey, this.enableMinToTray); + this.callAnalytics('MinimizeToTray', this.enableMinToTray); } async saveLocale() { diff --git a/src/desktopConstants.ts b/src/desktopConstants.ts new file mode 100644 index 00000000..5ccf3921 --- /dev/null +++ b/src/desktopConstants.ts @@ -0,0 +1,3 @@ +export class DesktopConstants { + static readonly enableMinimizeToTrayKey: string = 'enableMinimizeToTray'; +} diff --git a/src/images/icon.ico b/src/images/icon.ico new file mode 100644 index 0000000000000000000000000000000000000000..1f5beb6ed2aae796a05f8c0558f3281058f31443 GIT binary patch literal 20221 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 { + return await this.storageService.get(DesktopConstants.enableMinimizeToTrayKey); + }); this.messagingService = new ElectronMainMessagingService(this.windowMain, (message) => { this.messagingMain.onMessage(message); diff --git a/src/main/tray.main.ts b/src/main/tray.main.ts index 5ed1a545..976ea4bb 100644 --- a/src/main/tray.main.ts +++ b/src/main/tray.main.ts @@ -1,34 +1,37 @@ import { Tray } from 'electron'; -import * as Path from 'path'; -import { Main } from '../main'; -import { DesktopConstantsService } from '../services/desktopconstants.service'; +import * as path from 'path'; + +import { WindowMain } from 'jslib/electron/window.main'; + +import { DesktopConstants } from '../desktopConstants'; export class TrayMain { private tray: Tray; private iconPath: string; - constructor(private main: Main) { + constructor(private windowMain: WindowMain, private appName: string, private minToTray: () => Promise) { if (process.platform === 'win32') { - this.iconPath = Path.join(__dirname, '../resources/icon.ico'); + this.iconPath = path.join(__dirname, '/images/icon.ico'); } else { - this.iconPath = Path.join(__dirname, '../resources/icon.png'); + this.iconPath = path.join(__dirname, '/images/icon.png'); } } init() { - this.main.windowMain.win.on('minimize', async (event: Event) => { - if (await this.main.storageService.get(DesktopConstantsService.enableHideInTrayKey)) { - event.preventDefault(); + this.windowMain.win.on('minimize', async (e: Event) => { + if (await this.minToTray()) { + e.preventDefault(); await this.handleHideEvent(); } }); - this.main.windowMain.win.on('show', async (event: Event) => { + + this.windowMain.win.on('show', async (e: Event) => { await this.handleShowEvent(); }); } private handleShowEvent() { - if (this.tray) { + if (this.tray != null) { this.tray.destroy(); this.tray = null; } @@ -36,13 +39,16 @@ export class TrayMain { private handleHideEvent() { this.tray = new Tray(this.iconPath); + this.tray.setToolTip(this.appName); + this.tray.on('click', () => { - if (this.main.windowMain.win.isVisible()) { - this.main.windowMain.win.hide(); + if (this.windowMain.win.isVisible()) { + this.windowMain.win.hide(); } else { - this.main.windowMain.win.show(); + this.windowMain.win.show(); } }); - this.main.windowMain.win.hide(); + + this.windowMain.win.hide(); } } diff --git a/src/services/desktopconstants.service.ts b/src/services/desktopconstants.service.ts deleted file mode 100644 index e29310f9..00000000 --- a/src/services/desktopconstants.service.ts +++ /dev/null @@ -1,5 +0,0 @@ -export class DesktopConstantsService { - static readonly enableHideInTrayKey: string = 'enableHideInTray'; - - readonly enableHideInTrayKey: string = DesktopConstantsService.enableHideInTrayKey; -}