Skip to content
This repository has been archived by the owner on Dec 11, 2019. It is now read-only.

Commit

Permalink
Ensuring share context menu items are disabled when no windows are open
Browse files Browse the repository at this point in the history
Refactoring menu.js item attribute functions
  • Loading branch information
ryanml committed May 1, 2018
1 parent c70085d commit 99cba57
Show file tree
Hide file tree
Showing 5 changed files with 51 additions and 16 deletions.
38 changes: 31 additions & 7 deletions app/browser/menu.js
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@ const bookmarkUtil = require('../common/lib/bookmarkUtil')
const isDarwin = platformUtil.isDarwin()
const isLinux = platformUtil.isLinux()
const isWindows = platformUtil.isWindows()
const {templateUrls, excludedShareSites} = require('./share')
const {getAllRendererWindows} = require('./windows')

let appMenu = null
let closedFrames = new Immutable.OrderedMap()
Expand Down Expand Up @@ -596,21 +598,32 @@ const createMenu = (state) => {
}
}

const setMenuItemChecked = (state, label, checked) => {
// Update electron menu (Mac / Linux)
const setMenuItemAttribute = (state, label, key, value) => {
const systemMenuItem = menuUtil.getMenuItem(appMenu, label)
systemMenuItem.checked = checked
systemMenuItem[key] = value

// Update in-memory menu template (Windows)
if (isWindows) {
const oldTemplate = state.getIn(['menu', 'template'])
const newTemplate = menuUtil.setTemplateItemChecked(oldTemplate, label, checked)
const newTemplate = menuUtil.setTemplateItemAttribute(oldTemplate, label, key, value)
if (newTemplate) {
appActions.setMenubarTemplate(newTemplate)
}
}
}

const updateShareMenuItems = (state, enabled) => {
for (let key of Object.keys(templateUrls)) {
if (excludedShareSites.indexOf(key) > -1) {
continue
}
const siteName = menuUtil.extractSiteName(key)
const l10nId = key === 'email' ? 'emailPageLink' : 'sharePageLink'
const label = locale.translation(l10nId, {siteName: siteName})
setMenuItemAttribute(state, label, 'enabled', enabled)
}
}

const doAction = (state, action) => {
switch (action.actionType) {
case appConstants.APP_SET_STATE:
Expand All @@ -622,17 +635,28 @@ const doAction = (state, action) => {
const frame = frameStateUtil.getFrameByTabId(state, action.tabId)
if (frame) {
currentLocation = frame.location
setMenuItemChecked(state, locale.translation('bookmarkPage'), isCurrentLocationBookmarked(state))
setMenuItemAttribute(state, locale.translation('bookmarkPage'), 'checked', isCurrentLocationBookmarked(state))
}
break
}
case appConstants.APP_WINDOW_CLOSED:
case appConstants.APP_WINDOW_CREATED:
{
const windowCount = getAllRendererWindows().length
if (action.actionType === appConstants.APP_WINDOW_CLOSED && windowCount === 0) {
updateShareMenuItems(state, false)
} else if (action.actionType === appConstants.APP_WINDOW_CREATED && windowCount === 1) {
updateShareMenuItems(state, true)
}
break
}
case appConstants.APP_CHANGE_SETTING:
if (action.key === settings.SHOW_BOOKMARKS_TOOLBAR) {
// Update the checkbox next to "Bookmarks Toolbar" (Bookmarks menu)
setMenuItemChecked(state, locale.translation('bookmarksToolbar'), action.value)
setMenuItemAttribute(state, locale.translation('bookmarksToolbar'), 'checked', action.value)
}
if (action.key === settings.DEBUG_ALLOW_MANUAL_TAB_DISCARD) {
setMenuItemChecked(state, 'Allow manual tab discarding', action.value)
setMenuItemAttribute(state, 'Allow manual tab discarding', 'checked', action.value)
}
break
case windowConstants.WINDOW_UNDO_CLOSED_FRAME:
Expand Down
8 changes: 7 additions & 1 deletion app/browser/share.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,11 @@ const templateUrls = {
reddit: 'https://reddit.com/submit?url={url}&title={title}'
}

// Sites that are not currently in the File > Share context menu
const excludedShareSites = [
'digg'
]

const validateShareType = (shareType) =>
assert(templateUrls[shareType], 'The specified shareType is not recognized')

Expand Down Expand Up @@ -52,5 +57,6 @@ const simpleShareActiveTab = (state, windowId, shareType) => {

module.exports = {
simpleShareActiveTab,
templateUrls
templateUrls,
excludedShareSites
}
3 changes: 2 additions & 1 deletion app/common/commonMenu.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ const getSetting = require('../../js/settings').getSetting
const communityURL = 'https://community.brave.com/'
const isDarwin = process.platform === 'darwin'
const electron = require('electron')
const menuUtil = require('./lib/menuUtil')

const ensureAtLeastOneWindow = (frameOpts) => {
// Handle no new tab requested, but need a window
Expand Down Expand Up @@ -136,7 +137,7 @@ module.exports.printMenuItem = () => {
}

module.exports.simpleShareActiveTabMenuItem = (l10nId, type, accelerator) => {
const siteName = type.charAt(0).toUpperCase() + type.slice(1)
const siteName = menuUtil.extractSiteName(type)

return {
label: locale.translation(l10nId, {siteName: siteName}),
Expand Down
12 changes: 8 additions & 4 deletions app/common/lib/menuUtil.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,16 +67,20 @@ const getTemplateItem = (template, label) => {
return null
}

module.exports.extractSiteName = (type) => {
return type.charAt(0).toUpperCase() + type.slice(1)
}

/**
* Search a menu template and update the checked status
* Searches a menu template and updates a passed item key
*
* @return the new template OR null if no change was made (no update needed)
*/
module.exports.setTemplateItemChecked = (template, label, checked) => {
module.exports.setTemplateItemAttribute = (template, label, key, value) => {
const menu = template.toJS()
const menuItem = getTemplateItem(menu, label)
if (menuItem.checked !== checked) {
menuItem.checked = checked
if (menuItem[key] !== value) {
menuItem[key] = value
return makeImmutable(menu)
}
return null
Expand Down
6 changes: 3 additions & 3 deletions test/unit/app/common/lib/menuUtilTest.js
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ describe('menuUtil tests', function () {
})
})

describe('setTemplateItemChecked', function () {
describe('setTemplateItemAttribute', function () {
const defaultTemplate = Immutable.fromJS([
{
'label': 'Bookmarks',
Expand All @@ -113,11 +113,11 @@ describe('menuUtil tests', function () {
]
}
])
const newTemplate = menuUtil.setTemplateItemChecked(defaultTemplate, 'Bookmarks Toolbar', true)
const newTemplate = menuUtil.setTemplateItemAttribute(defaultTemplate, 'Bookmarks Toolbar', 'checked', true)
assert.deepEqual(newTemplate.toJS(), expectedTemplate.toJS())
})
it('returns null when no change is made', function () {
const newTemplate = menuUtil.setTemplateItemChecked(defaultTemplate, 'Bookmarks Toolbar', false)
const newTemplate = menuUtil.setTemplateItemAttribute(defaultTemplate, 'Bookmarks Toolbar', 'checked', false)
assert.equal(newTemplate, null)
})
})
Expand Down

0 comments on commit 99cba57

Please sign in to comment.