mirror of
https://github.com/zulip/zulip-desktop.git
synced 2025-11-04 22:13:13 +00:00
committed by
Akash Nimare
parent
51e414a508
commit
2e70b515da
@@ -1,11 +1,11 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
const { app, dialog } = require('electron');
|
const { app, dialog, shell } = require('electron');
|
||||||
const { autoUpdater } = require('electron-updater');
|
const { autoUpdater } = require('electron-updater');
|
||||||
const isDev = require('electron-is-dev');
|
const isDev = require('electron-is-dev');
|
||||||
|
|
||||||
const ConfigUtil = require('./../renderer/js/utils/config-util.js');
|
const ConfigUtil = require('./../renderer/js/utils/config-util.js');
|
||||||
|
|
||||||
function appUpdater() {
|
function appUpdater(updateFromMenu = false) {
|
||||||
// Don't initiate auto-updates in development
|
// Don't initiate auto-updates in development
|
||||||
if (isDev) {
|
if (isDev) {
|
||||||
return;
|
return;
|
||||||
@@ -17,6 +17,8 @@ function appUpdater() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let updateAvailable = false;
|
||||||
|
|
||||||
// Create Logs directory
|
// Create Logs directory
|
||||||
const LogsDir = `${app.getPath('userData')}/Logs`;
|
const LogsDir = `${app.getPath('userData')}/Logs`;
|
||||||
|
|
||||||
@@ -30,6 +32,55 @@ function appUpdater() {
|
|||||||
// Handle auto updates for beta/pre releases
|
// Handle auto updates for beta/pre releases
|
||||||
autoUpdater.allowPrerelease = ConfigUtil.getConfigItem('betaUpdate') || false;
|
autoUpdater.allowPrerelease = ConfigUtil.getConfigItem('betaUpdate') || false;
|
||||||
|
|
||||||
|
const eventsListenerRemove = ['update-available', 'update-not-available'];
|
||||||
|
autoUpdater.on('update-available', info => {
|
||||||
|
if (updateFromMenu) {
|
||||||
|
dialog.showMessageBox({
|
||||||
|
message: `A new version ${info.version}, of Zulip Desktop is available`,
|
||||||
|
detail: 'The update will be downloaded in the background. You will be notified when it is ready to be installed.'
|
||||||
|
});
|
||||||
|
|
||||||
|
updateAvailable = true;
|
||||||
|
|
||||||
|
// This is to prevent removal of 'update-downloaded' and 'error' event listener.
|
||||||
|
eventsListenerRemove.forEach(event => {
|
||||||
|
autoUpdater.removeAllListeners(event);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
autoUpdater.on('update-not-available', () => {
|
||||||
|
if (updateFromMenu) {
|
||||||
|
dialog.showMessageBox({
|
||||||
|
message: 'No updates available',
|
||||||
|
detail: `You are running the latest version of Zulip Desktop.\nVersion: ${app.getVersion()}`
|
||||||
|
});
|
||||||
|
// Remove all autoUpdator listeners so that next time autoUpdator is manually called these
|
||||||
|
// listeners don't trigger multiple times.
|
||||||
|
autoUpdater.removeAllListeners();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
autoUpdater.on('error', error => {
|
||||||
|
if (updateFromMenu) {
|
||||||
|
const messageText = (updateAvailable) ? ('Unable to download the updates') : ('Unable to check for updates');
|
||||||
|
dialog.showMessageBox({
|
||||||
|
type: 'error',
|
||||||
|
buttons: ['Manual Download', 'Cancel'],
|
||||||
|
message: messageText,
|
||||||
|
detail: (error).toString() + `\n\nThe latest version of Zulip Desktop is available at -\nhttps://zulipchat.com/apps/.\n
|
||||||
|
Current Version: ${app.getVersion()}`
|
||||||
|
}, response => {
|
||||||
|
if (response === 0) {
|
||||||
|
shell.openExternal('https://zulipchat.com/apps/');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
// Remove all autoUpdator listeners so that next time autoUpdator is manually called these
|
||||||
|
// listeners don't trigger multiple times.
|
||||||
|
autoUpdater.removeAllListeners();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// Ask the user if update is available
|
// Ask the user if update is available
|
||||||
// eslint-disable-next-line no-unused-vars
|
// eslint-disable-next-line no-unused-vars
|
||||||
autoUpdater.on('update-downloaded', event => {
|
autoUpdater.on('update-downloaded', event => {
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ const path = require('path');
|
|||||||
const { app, shell, BrowserWindow, Menu, dialog } = require('electron');
|
const { app, shell, BrowserWindow, Menu, dialog } = require('electron');
|
||||||
|
|
||||||
const fs = require('fs-extra');
|
const fs = require('fs-extra');
|
||||||
|
const { appUpdater } = require('./autoupdater');
|
||||||
|
|
||||||
const ConfigUtil = require(__dirname + '/../renderer/js/utils/config-util.js');
|
const ConfigUtil = require(__dirname + '/../renderer/js/utils/config-util.js');
|
||||||
const DNDUtil = require(__dirname + '/../renderer/js/utils/dnd-util.js');
|
const DNDUtil = require(__dirname + '/../renderer/js/utils/dnd-util.js');
|
||||||
@@ -195,6 +196,11 @@ class AppMenu {
|
|||||||
AppMenu.sendAction('open-about');
|
AppMenu.sendAction('open-about');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}, {
|
||||||
|
label: `Check for Update`,
|
||||||
|
click() {
|
||||||
|
AppMenu.checkForUpdate();
|
||||||
|
}
|
||||||
}, {
|
}, {
|
||||||
type: 'separator'
|
type: 'separator'
|
||||||
}, {
|
}, {
|
||||||
@@ -302,6 +308,11 @@ class AppMenu {
|
|||||||
AppMenu.sendAction('open-about');
|
AppMenu.sendAction('open-about');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}, {
|
||||||
|
label: `Check for Update`,
|
||||||
|
click() {
|
||||||
|
AppMenu.checkForUpdate();
|
||||||
|
}
|
||||||
}, {
|
}, {
|
||||||
type: 'separator'
|
type: 'separator'
|
||||||
}, {
|
}, {
|
||||||
@@ -399,6 +410,9 @@ class AppMenu {
|
|||||||
win.webContents.send(action, ...params);
|
win.webContents.send(action, ...params);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static checkForUpdate() {
|
||||||
|
appUpdater(true);
|
||||||
|
}
|
||||||
static resetAppSettings() {
|
static resetAppSettings() {
|
||||||
const resetAppSettingsMessage = 'By proceeding you will be removing all connected organizations and preferences from Zulip.';
|
const resetAppSettingsMessage = 'By proceeding you will be removing all connected organizations and preferences from Zulip.';
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user