diff --git a/src/auto-updater/index.js b/src/auto-updater/index.js index 178e806b..6be6aad8 100644 --- a/src/auto-updater/index.js +++ b/src/auto-updater/index.js @@ -28,6 +28,8 @@ const { addOnceProcEventHandler } = require('../window-event-manager') +const MENU_ITEM_IDS = require('../create-menu/menu.item.ids') + const isAutoUpdateDisabled = parseEnvValToBool(process.env.IS_AUTO_UPDATE_DISABLED) const fontsStyle = fs.readFileSync(path.join( @@ -219,8 +221,12 @@ const _switchMenuItem = (opts = {}) => { isCheckMenuItemDisabled, isInstallMenuItemVisible } = { ...opts } - const checkMenuItem = _getUpdateMenuItemById('CHECK_UPDATE_MENU_ITEM') - const installMenuItem = _getUpdateMenuItemById('INSTALL_UPDATE_MENU_ITEM') + const checkMenuItem = _getUpdateMenuItemById( + MENU_ITEM_IDS.CHECK_UPDATE_MENU_ITEM + ) + const installMenuItem = _getUpdateMenuItemById( + MENU_ITEM_IDS.INSTALL_UPDATE_MENU_ITEM + ) if ( !checkMenuItem || diff --git a/src/changelog-manager/manage-changelog.js b/src/changelog-manager/manage-changelog.js index a09f029f..5dc481b7 100644 --- a/src/changelog-manager/manage-changelog.js +++ b/src/changelog-manager/manage-changelog.js @@ -23,14 +23,21 @@ module.exports = async () => { return } - const isShown = await showChangelog({ version }) + const { + error, + isShown + } = await showChangelog({ version }) + + if (!isShown) { + return + } const isSaved = await configsKeeper .saveConfigs({ shownChangelogVer: version }) if ( isSaved && - isShown + !error ) { return } diff --git a/src/changelog-manager/show-changelog.js b/src/changelog-manager/show-changelog.js index ae362b47..ea0d265e 100644 --- a/src/changelog-manager/show-changelog.js +++ b/src/changelog-manager/show-changelog.js @@ -1,5 +1,6 @@ 'use strict' +const { Menu } = require('electron') const path = require('path') const parseChangelog = require('changelog-parser') const { rootPath } = require('electron-root-path') @@ -7,8 +8,17 @@ const { rootPath } = require('electron-root-path') const getDebugInfo = require('../helpers/get-debug-info') const showDocs = require('../show-docs') +const MENU_ITEM_IDS = require('../create-menu/menu.item.ids') + const changelogPath = path.join(rootPath, 'CHANGELOG.md') +const disableShowChangelogMenuItem = () => { + const menuItem = Menu.getApplicationMenu() + ?.getMenuItemById(MENU_ITEM_IDS.SHOW_CHANGE_LOG_MENU_ITEM) ?? {} + + menuItem.enabled = false +} + module.exports = async (params = {}) => { try { const version = params?.version ?? getDebugInfo()?.version @@ -23,7 +33,12 @@ module.exports = async (params = {}) => { !Array.isArray(mdEntries?.versions) || mdEntries?.versions.length === 0 ) { - return true + disableShowChangelogMenuItem() + + return { + error: null, + isShown: false + } } const mdEntry = mdEntries.versions @@ -33,7 +48,12 @@ module.exports = async (params = {}) => { !mdEntry?.title || !mdEntry?.body ) { - return true + disableShowChangelogMenuItem() + + return { + error: null, + isShown: false + } } const mdTitle = `# ${mdEntries.title}` @@ -45,10 +65,16 @@ module.exports = async (params = {}) => { mdDoc }) - return true - } catch (err) { - console.error(err) + return { + error: null, + isShown: true + } + } catch (error) { + console.error(error) - return false + return { + error, + isShown: false + } } } diff --git a/src/create-menu.js b/src/create-menu/index.js similarity index 79% rename from src/create-menu.js rename to src/create-menu/index.js index 3c5f237b..6537b876 100644 --- a/src/create-menu.js +++ b/src/create-menu/index.js @@ -5,23 +5,25 @@ const electron = require('electron') const { app, Menu } = electron const isMac = process.platform === 'darwin' -const exportDB = require('./export-db') -const importDB = require('./import-db') -const removeDB = require('./remove-db') -const restoreDB = require('./restore-db') -const backupDB = require('./backup-db') -const changeReportsFolder = require('./change-reports-folder') -const changeSyncFrequency = require('./change-sync-frequency') -const triggerElectronLoad = require('./trigger-electron-load') -const showAboutModalDialog = require('./show-about-modal-dialog') +const exportDB = require('../export-db') +const importDB = require('../import-db') +const removeDB = require('../remove-db') +const restoreDB = require('../restore-db') +const backupDB = require('../backup-db') +const changeReportsFolder = require('../change-reports-folder') +const changeSyncFrequency = require('../change-sync-frequency') +const triggerElectronLoad = require('../trigger-electron-load') +const showAboutModalDialog = require('../show-about-modal-dialog') const { checkForUpdates, quitAndInstall -} = require('./auto-updater') -const { manageNewGithubIssue } = require('./error-manager') -const showDocs = require('./show-docs') -const { showChangelog } = require('./changelog-manager') -const parseEnvValToBool = require('./helpers/parse-env-val-to-bool') +} = require('../auto-updater') +const { manageNewGithubIssue } = require('../error-manager') +const showDocs = require('../show-docs') +const { showChangelog } = require('../changelog-manager') +const parseEnvValToBool = require('../helpers/parse-env-val-to-bool') + +const MENU_ITEM_IDS = require('./menu.item.ids') const isAutoUpdateDisabled = parseEnvValToBool(process.env.IS_AUTO_UPDATE_DISABLED) @@ -137,20 +139,20 @@ module.exports = ({ submenu: [ { label: 'Open new GitHub issue', - id: 'REPORT_BUG_MENU_ITEM', + id: MENU_ITEM_IDS.REPORT_BUG_MENU_ITEM, click: manageNewGithubIssue }, { type: 'separator' }, { label: 'Check for updates', enabled: !isAutoUpdateDisabled, - id: 'CHECK_UPDATE_MENU_ITEM', + id: MENU_ITEM_IDS.CHECK_UPDATE_MENU_ITEM, click: checkForUpdates() }, { label: 'Quit and install updates', visible: false, - id: 'INSTALL_UPDATE_MENU_ITEM', + id: MENU_ITEM_IDS.INSTALL_UPDATE_MENU_ITEM, click: quitAndInstall() }, { type: 'separator' }, @@ -161,6 +163,7 @@ module.exports = ({ }, { label: 'Changelog', + id: MENU_ITEM_IDS.SHOW_CHANGE_LOG_MENU_ITEM, click: () => showChangelog() }, ...(isMac diff --git a/src/create-menu/menu.item.ids.js b/src/create-menu/menu.item.ids.js new file mode 100644 index 00000000..c9cbb151 --- /dev/null +++ b/src/create-menu/menu.item.ids.js @@ -0,0 +1,8 @@ +'use strict' + +module.exports = { + REPORT_BUG_MENU_ITEM: 'REPORT_BUG_MENU_ITEM', + CHECK_UPDATE_MENU_ITEM: 'CHECK_UPDATE_MENU_ITEM', + INSTALL_UPDATE_MENU_ITEM: 'INSTALL_UPDATE_MENU_ITEM', + SHOW_CHANGE_LOG_MENU_ITEM: 'SHOW_CHANGE_LOG_MENU_ITEM' +} diff --git a/src/error-manager/index.js b/src/error-manager/index.js index 5a82a4bf..976dc411 100644 --- a/src/error-manager/index.js +++ b/src/error-manager/index.js @@ -14,6 +14,8 @@ const openNewGithubIssue = require('./open-new-github-issue') const collectLogs = require('./collect-logs') const getDebugInfo = require('../helpers/get-debug-info') +const MENU_ITEM_IDS = require('../create-menu/menu.item.ids') + let _isLocked = false let _isIssueAutoManagerLocked = false let caughtError @@ -97,7 +99,7 @@ const _getReportBugMenuItem = () => { return {} } - return menu.getMenuItemById('REPORT_BUG_MENU_ITEM') || {} + return menu.getMenuItemById(MENU_ITEM_IDS.REPORT_BUG_MENU_ITEM) || {} } const _lockIssueManager = () => {