Make unread badge configurable

This commit is contained in:
Kolja Lampe
2016-07-15 13:04:14 +02:00
committed by Kolja Lampe
parent 6a99bdb72c
commit 51d828aa1a
6 changed files with 36 additions and 6 deletions

View File

@@ -7,6 +7,13 @@
#### Linux
- Added an option to make the taskbar icon flash on new messages
#### OS X
- Added an option to toggle the red dot icon for unread messages (default is on).
#### Windows
- Added an option to toogle the red dot icon for unread messages (default is on).
### Bug Fixes
@@ -53,7 +60,7 @@ Release date: 2016-07-18
- Ctrl+Tab or Alt+Command+Right (Menu Bar -> Window -> Select Next Team): Switch to the next window.
- Ctrl+Shift+Tab or Alt+Command+Left (Menu Bar -> Window -> Select Previous Team): Switch to the previous window.
- Right click on the tray item, to see an overview of all your teams. You can also select one and jump right into it.
- Added **Help** to the Menu Bar, which includes
- Added **Help** to the Menu Bar, which includes
- Link to [**Mattermost Docs**](docs.mattermost.com)
- Field to indicate the application version number.

View File

@@ -128,6 +128,8 @@ The Settings Page is available from the **File** menu under **Settings** (Click
- This option hides the window from the dock, if the window is closed
- **Toggle window visibility when clicking on the tray icon** (Windows)
- If checked, then a click on the system tray icon leads to a toggling of the minimized/maximized state of the window
- **Show the red badge for unread messages.** (Windows, OS X)
- If this is checked it will show the red dot on your task bar when you have unread messages.
## Menu Bar

View File

@@ -484,7 +484,7 @@ var showUnreadBadgeWindows = function(unreadCount, mentionCount) {
if (mentionCount > 0) {
const dataURL = badge.createDataURL(mentionCount.toString());
sendBadge(dataURL, 'You have unread mentions (' + mentionCount + ')');
} else if (unreadCount > 0) {
} else if (unreadCount > 0 && config.showUnreadBadge) {
const dataURL = badge.createDataURL('•');
sendBadge(dataURL, 'You have unread channels (' + unreadCount + ')');
} else {
@@ -495,7 +495,7 @@ var showUnreadBadgeWindows = function(unreadCount, mentionCount) {
var showUnreadBadgeOSX = function(unreadCount, mentionCount) {
if (mentionCount > 0) {
remote.app.dock.setBadge(mentionCount.toString());
} else if (unreadCount > 0) {
} else if (unreadCount > 0 && config.showUnreadBadge) {
remote.app.dock.setBadge('•');
} else {
remote.app.dock.setBadge('');
@@ -531,7 +531,6 @@ var showUnreadBadge = function(unreadCount, mentionCount) {
showUnreadBadgeOSX(unreadCount, mentionCount);
break;
case 'linux':
console.log(unreadCount);
showUnreadBadgeLinux(unreadCount, mentionCount);
break;
default:

View File

@@ -67,7 +67,8 @@ var SettingsPage = React.createClass({
toggleWindowOnTrayIconClick: this.state.toggleWindowOnTrayIconClick,
notifications: {
flashWindow: this.state.notifications.flashWindow
}
},
showUnreadBadge: this.state.showUnreadBadge
};
settings.writeFileSync(this.props.configFile, config);
if (process.platform === 'win32' || process.platform === 'linux') {
@@ -150,6 +151,11 @@ var SettingsPage = React.createClass({
}
});
},
handleShowUnreadBadge: function() {
this.setState({
showUnreadBadge: this.refs.showUnreadBadge.getChecked()
});
},
render: function() {
var teams_row = (
<Row>
@@ -192,6 +198,11 @@ var SettingsPage = React.createClass({
checked={ this.state.toggleWindowOnTrayIconClick } onChange={ this.handleChangeToggleWindowOnTrayIconClick } />);
}
if (process.platform === 'darwin' || process.platform === 'win32') {
options.push(<Input key="inputShowUnreadBadge" id="inputShowUnreadBadge" ref="showUnreadBadge" type="checkbox" label="Show red badge on taskbar icon to indicate unread messages. Regardless of this setting, mentions are always indicated with a red badge and item count on the taskbar icon."
checked={ this.state.showUnreadBadge } onChange={ this.handleShowUnreadBadge } />);
}
var options_row = (options.length > 0) ? (
<Row>
<Col md={ 12 }>

View File

@@ -30,7 +30,8 @@ var loadDefault = function(version) {
version: 1,
notifications: {
flashWindow: 0 // 0 = flash never, 1 = only when idle (after 10 seconds), 2 = always
}
},
showUnreadBadge: true
};
}
}

View File

@@ -180,5 +180,15 @@ describe('browser/settings.html', function() {
.isExisting('#notificationsRow').should.eventually.equal(expected)
});
});
describe('Show red icon for unread', function() {
it('should appear on darwin or win32', function() {
const expected = (process.platform === 'darwin' || process.platform === 'win32');
env.addClientCommands(this.app.client);
return this.app.client
.loadSettingsPage()
.isExisting('#inputShowUnreadBadge').should.eventually.equal(expected)
});
});
});
});