mirror of
https://github.com/dscalzi/HeliosLauncher.git
synced 2025-01-06 11:02:12 -08:00
Non functional code.
This commit is contained in:
parent
3d470d9a32
commit
2279cb05b7
@ -52,15 +52,15 @@
|
|||||||
},
|
},
|
||||||
"overrides": [
|
"overrides": [
|
||||||
{
|
{
|
||||||
"files": [ "app/assets/js/scripts/*.js" ],
|
"env": {
|
||||||
"rules": {
|
"browser": true,
|
||||||
"no-unused-vars": [
|
"node": false,
|
||||||
0
|
"jquery": true
|
||||||
],
|
},
|
||||||
"no-undef": [
|
"files": [
|
||||||
0
|
"app/assets/js/scripts/*.js",
|
||||||
|
"app/assets/js/renderer/*.js"
|
||||||
]
|
]
|
||||||
}
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
@ -2,8 +2,10 @@
|
|||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8" http-equiv="Content-Security-Policy" content="script-src 'self' 'sha256-In6B8teKZQll5heMl9bS7CESTbGvuAt3VVV86BUQBDk='"/>
|
<meta charset="utf-8" http-equiv="Content-Security-Policy" content="script-src 'self' 'sha256-In6B8teKZQll5heMl9bS7CESTbGvuAt3VVV86BUQBDk='"/>
|
||||||
<title><%= lang('app.title') %></title>
|
<title><%= lang('app.title') %></title>
|
||||||
<script src="./assets/js/scripts/uicore.js"></script>
|
<!-- TODO FIXME -->
|
||||||
<script src="./assets/js/scripts/uibinder.js"></script>
|
<script src="../node_modules/jquery/dist/jquery.min.js"></script>
|
||||||
|
<!-- <script type="module" src="./assets/js/scripts/uicore.js"></script>
|
||||||
|
<script type="module" src="./assets/js/scripts/uibinder.js"></script> -->
|
||||||
<link type="text/css" rel="stylesheet" href="./assets/css/launcher.css">
|
<link type="text/css" rel="stylesheet" href="./assets/css/launcher.css">
|
||||||
<style>
|
<style>
|
||||||
body {
|
body {
|
||||||
@ -25,6 +27,7 @@
|
|||||||
filter: blur(3px) contrast(0.9) brightness(1.0);
|
filter: blur(3px) contrast(0.9) brightness(1.0);
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
<script type="module" src="./assets/js/renderer/megascript.js"></script>
|
||||||
</head>
|
</head>
|
||||||
<body bkid="<%=bkid%>">
|
<body bkid="<%=bkid%>">
|
||||||
<%- include('frame') %>
|
<%- include('frame') %>
|
||||||
|
9
app/assets/@types/preloader.d.ts
vendored
Normal file
9
app/assets/@types/preloader.d.ts
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import { api } from '../js/preloader.js'
|
||||||
|
|
||||||
|
declare global {
|
||||||
|
interface Window {
|
||||||
|
api: typeof api
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export {};
|
@ -14,7 +14,7 @@ const { LoggerUtil } = require('helios-core')
|
|||||||
const { RestResponseStatus } = require('helios-core/common')
|
const { RestResponseStatus } = require('helios-core/common')
|
||||||
const { MojangRestAPI, mojangErrorDisplayable, MojangErrorCode } = require('helios-core/mojang')
|
const { MojangRestAPI, mojangErrorDisplayable, MojangErrorCode } = require('helios-core/mojang')
|
||||||
const { MicrosoftAuth, microsoftErrorDisplayable, MicrosoftErrorCode } = require('helios-core/microsoft')
|
const { MicrosoftAuth, microsoftErrorDisplayable, MicrosoftErrorCode } = require('helios-core/microsoft')
|
||||||
const { AZURE_CLIENT_ID } = require('./ipcconstants')
|
const { AZURE_CLIENT_ID } = require('../ipcconstants')
|
||||||
|
|
||||||
const log = LoggerUtil.getLogger('AuthManager')
|
const log = LoggerUtil.getLogger('AuthManager')
|
||||||
|
|
@ -9,7 +9,9 @@ const sysRoot = process.env.APPDATA || (process.platform == 'darwin' ? process.e
|
|||||||
|
|
||||||
const dataPath = path.join(sysRoot, '.helioslauncher')
|
const dataPath = path.join(sysRoot, '.helioslauncher')
|
||||||
|
|
||||||
const launcherDir = require('@electron/remote').app.getPath('userData')
|
const { app } = require('electron')
|
||||||
|
|
||||||
|
const launcherDir = app.getPath('userData')
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieve the absolute path of the launcher directory.
|
* Retrieve the absolute path of the launcher directory.
|
@ -6,7 +6,7 @@ const merge = require('lodash.merge')
|
|||||||
let lang
|
let lang
|
||||||
|
|
||||||
exports.loadLanguage = function(id){
|
exports.loadLanguage = function(id){
|
||||||
lang = merge(lang || {}, toml.parse(fs.readFileSync(path.join(__dirname, '..', 'lang', `${id}.toml`))) || {})
|
lang = merge(lang || {}, toml.parse(fs.readFileSync(path.join(__dirname, '..', '..', 'lang', `${id}.toml`))) || {})
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.query = function(id, placeHolders){
|
exports.query = function(id, placeHolders){
|
||||||
@ -41,3 +41,7 @@ exports.setupLanguage = function(){
|
|||||||
// Load Custom Language File for Launcher Customizer
|
// Load Custom Language File for Launcher Customizer
|
||||||
exports.loadLanguage('_custom')
|
exports.loadLanguage('_custom')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
exports.getLang = () => {
|
||||||
|
return lang
|
||||||
|
}
|
@ -1,67 +1,58 @@
|
|||||||
const {ipcRenderer} = require('electron')
|
const { contextBridge, ipcRenderer } = require('electron')
|
||||||
const fs = require('fs-extra')
|
|
||||||
const os = require('os')
|
|
||||||
const path = require('path')
|
|
||||||
|
|
||||||
const ConfigManager = require('./configmanager')
|
module.exports.api = {
|
||||||
const { DistroAPI } = require('./distromanager')
|
os: {
|
||||||
const LangLoader = require('./langloader')
|
totalmem: () => ipcRenderer.invoke('os.totalmem'),
|
||||||
const { LoggerUtil } = require('helios-core')
|
freemem: () => ipcRenderer.invoke('os.freemem')
|
||||||
// eslint-disable-next-line no-unused-vars
|
},
|
||||||
const { HeliosDistribution } = require('helios-core/common')
|
semver: {
|
||||||
|
prerelease: (version) => ipcRenderer.invoke('semver.prerelease', version)
|
||||||
const logger = LoggerUtil.getLogger('Preloader')
|
},
|
||||||
|
path: {
|
||||||
logger.info('Loading..')
|
join: (...args) => ipcRenderer.invoke('path.join', args)
|
||||||
|
},
|
||||||
// Load ConfigManager
|
app: {
|
||||||
ConfigManager.load()
|
isDev: () => ipcRenderer.invoke('app.isDev'),
|
||||||
|
getVersion: () => ipcRenderer.invoke('app.getVersion')
|
||||||
// Yuck!
|
},
|
||||||
// TODO Fix this
|
shell: {
|
||||||
DistroAPI['commonDir'] = ConfigManager.getCommonDirectory()
|
openExternal: (url) => ipcRenderer.invoke('shell.openExternal', url),
|
||||||
DistroAPI['instanceDir'] = ConfigManager.getInstanceDirectory()
|
openPath: (path) => ipcRenderer.invoke('shell.openPath', path),
|
||||||
|
},
|
||||||
// Load Strings
|
xwindow: {
|
||||||
LangLoader.setupLanguage()
|
close: () => ipcRenderer.invoke('xwindow.close'),
|
||||||
|
setProgressBar: (progress) => ipcRenderer.invoke('xwindow.setProgressBar', progress),
|
||||||
/**
|
toggleDevTools: () => {
|
||||||
*
|
console.log('%cThe console is dark and full of terrors.', 'color: white; -webkit-text-stroke: 4px #a02d2a; font-size: 60px; font-weight: bold')
|
||||||
* @param {HeliosDistribution} data
|
console.log('%cIf you\'ve been told to paste something here, you\'re being scammed.', 'font-size: 16px')
|
||||||
*/
|
console.log('%cUnless you know exactly what you\'re doing, close this window.', 'font-size: 16px')
|
||||||
function onDistroLoad(data){
|
return ipcRenderer.invoke('xwindow.toggleDevTools')
|
||||||
if(data != null){
|
},
|
||||||
|
minimize: () => ipcRenderer.invoke('xwindow.minimize'),
|
||||||
// Resolve the selected server if its value has yet to be set.
|
maximize: () => ipcRenderer.invoke('xwindow.maximize'),
|
||||||
if(ConfigManager.getSelectedServer() == null || data.getServerById(ConfigManager.getSelectedServer()) == null){
|
unmaximize: () => ipcRenderer.invoke('xwindow.unmaximize'),
|
||||||
logger.info('Determining default selected server..')
|
isMaximized: () => ipcRenderer.invoke('xwindow.isMaximized')
|
||||||
ConfigManager.setSelectedServer(data.getMainServer().rawServer.id)
|
},
|
||||||
ConfigManager.save()
|
process: {
|
||||||
}
|
platform: () => ipcRenderer.invoke('process.platform'),
|
||||||
|
arch: () => ipcRenderer.invoke('process.arch')
|
||||||
|
},
|
||||||
|
hc: {
|
||||||
|
type: () => ipcRenderer.invoke('hc.type')
|
||||||
|
},
|
||||||
|
AuthManager: {
|
||||||
|
addMojangAccount: (username, password) => ipcRenderer.invoke('AuthManager.addMojangAccount', username, password),
|
||||||
|
addMicrosoftAccount: (authCode) => ipcRenderer.invoke('AuthManager.addMicrosoftAccount', authCode),
|
||||||
|
removeMojangAccount: (uuid) => ipcRenderer.invoke('AuthManager.removeMojangAccount', uuid),
|
||||||
|
removeMicrosoftAccount: (uuid) => ipcRenderer.invoke('AuthManager.removeMicrosoftAccount', uuid),
|
||||||
|
validateSelected: () => ipcRenderer.invoke('AuthManager.validateSelected')
|
||||||
|
},
|
||||||
|
Lang: {
|
||||||
|
getLang: () => ipcRenderer.invoke('Lang.getLang')
|
||||||
|
},
|
||||||
|
AutoUpdater: {
|
||||||
|
port2: () => ipcRenderer.invoke('AutoUpdater.port2')
|
||||||
}
|
}
|
||||||
ipcRenderer.send('distributionIndexDone', data != null)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ensure Distribution is downloaded and cached.
|
contextBridge.exposeInMainWorld('api', module.exports.api)
|
||||||
DistroAPI.getDistribution()
|
|
||||||
.then(heliosDistro => {
|
|
||||||
logger.info('Loaded distribution index.')
|
|
||||||
|
|
||||||
onDistroLoad(heliosDistro)
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
logger.info('Failed to load an older version of the distribution index.')
|
|
||||||
logger.info('Application cannot run.')
|
|
||||||
logger.error(err)
|
|
||||||
|
|
||||||
onDistroLoad(null)
|
|
||||||
})
|
|
||||||
|
|
||||||
// Clean up temp dir incase previous launches ended unexpectedly.
|
|
||||||
fs.remove(path.join(os.tmpdir(), ConfigManager.getTempNativeFolder()), (err) => {
|
|
||||||
if(err){
|
|
||||||
logger.warn('Error while cleaning natives directory', err)
|
|
||||||
} else {
|
|
||||||
logger.info('Cleaned natives directory.')
|
|
||||||
}
|
|
||||||
})
|
|
30
app/assets/js/renderer/langrenderer.js
Normal file
30
app/assets/js/renderer/langrenderer.js
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
// HACK FIXME
|
||||||
|
|
||||||
|
let lang
|
||||||
|
|
||||||
|
export async function loadLanguage() {
|
||||||
|
lang = await window.api.Lang.getLang()
|
||||||
|
}
|
||||||
|
|
||||||
|
export function query(id, placeHolders){
|
||||||
|
let query = id.split('.')
|
||||||
|
let res = lang
|
||||||
|
for(let q of query){
|
||||||
|
res = res[q]
|
||||||
|
}
|
||||||
|
let text = res === lang ? '' : res
|
||||||
|
if (placeHolders) {
|
||||||
|
Object.entries(placeHolders).forEach(([key, value]) => {
|
||||||
|
text = text.replace(`{${key}}`, value)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return text
|
||||||
|
}
|
||||||
|
|
||||||
|
export function queryJS(id, placeHolders){
|
||||||
|
return query(`js.${id}`, placeHolders)
|
||||||
|
}
|
||||||
|
|
||||||
|
export function queryEJS(id, placeHolders){
|
||||||
|
return query(`ejs.${id}`, placeHolders)
|
||||||
|
}
|
3895
app/assets/js/renderer/megascript.js
Normal file
3895
app/assets/js/renderer/megascript.js
Normal file
File diff suppressed because it is too large
Load Diff
9
app/assets/js/renderer/views.js
Normal file
9
app/assets/js/renderer/views.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
// Mapping of each view to their container IDs.
|
||||||
|
export const VIEWS = {
|
||||||
|
landing: '#landingContainer',
|
||||||
|
loginOptions: '#loginOptionsContainer',
|
||||||
|
login: '#loginContainer',
|
||||||
|
settings: '#settingsContainer',
|
||||||
|
welcome: '#welcomeContainer',
|
||||||
|
waiting: '#waitingContainer'
|
||||||
|
}
|
@ -1,8 +1,10 @@
|
|||||||
/**
|
/**
|
||||||
* Script for landing.ejs
|
* Script for landing.ejs
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import { VIEWS } from './views.js'
|
||||||
|
|
||||||
// Requirements
|
// Requirements
|
||||||
const { URL } = require('url')
|
|
||||||
const {
|
const {
|
||||||
MojangRestAPI,
|
MojangRestAPI,
|
||||||
getServerStatus
|
getServerStatus
|
||||||
@ -85,7 +87,7 @@ function setLaunchPercentage(percent){
|
|||||||
* @param {number} percent Percentage (0-100)
|
* @param {number} percent Percentage (0-100)
|
||||||
*/
|
*/
|
||||||
function setDownloadPercentage(percent){
|
function setDownloadPercentage(percent){
|
||||||
remote.getCurrentWindow().setProgressBar(percent/100)
|
xwindow.setProgressBar(percent/100)
|
||||||
setLaunchPercentage(percent)
|
setLaunchPercentage(percent)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -402,7 +404,7 @@ async function downloadJava(effectiveJavaOptions, launchAfter = true) {
|
|||||||
|
|
||||||
// Extract
|
// Extract
|
||||||
// Show installing progress bar.
|
// Show installing progress bar.
|
||||||
remote.getCurrentWindow().setProgressBar(2)
|
xwindow.setProgressBar(2)
|
||||||
|
|
||||||
// Wait for extration to complete.
|
// Wait for extration to complete.
|
||||||
const eLStr = Lang.queryJS('landing.downloadJava.extractingJava')
|
const eLStr = Lang.queryJS('landing.downloadJava.extractingJava')
|
||||||
@ -420,7 +422,7 @@ async function downloadJava(effectiveJavaOptions, launchAfter = true) {
|
|||||||
const newJavaExec = await extractJdk(asset.path)
|
const newJavaExec = await extractJdk(asset.path)
|
||||||
|
|
||||||
// Extraction complete, remove the loading from the OS progress bar.
|
// Extraction complete, remove the loading from the OS progress bar.
|
||||||
remote.getCurrentWindow().setProgressBar(-1)
|
xwindow.setProgressBar(-1)
|
||||||
|
|
||||||
// Extraction completed successfully.
|
// Extraction completed successfully.
|
||||||
ConfigManager.setJavaExecutable(ConfigManager.getSelectedServer(), newJavaExec)
|
ConfigManager.setJavaExecutable(ConfigManager.getSelectedServer(), newJavaExec)
|
||||||
@ -533,7 +535,7 @@ async function dlAsync(login = true) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Remove download bar.
|
// Remove download bar.
|
||||||
remote.getCurrentWindow().setProgressBar(-1)
|
xwindow.setProgressBar(-1)
|
||||||
|
|
||||||
fullRepairModule.destroyReceiver()
|
fullRepairModule.destroyReceiver()
|
||||||
|
|
||||||
@ -554,7 +556,7 @@ async function dlAsync(login = true) {
|
|||||||
if(login) {
|
if(login) {
|
||||||
const authUser = ConfigManager.getSelectedAccount()
|
const authUser = ConfigManager.getSelectedAccount()
|
||||||
loggerLaunchSuite.info(`Sending selected account (${authUser.displayName}) to ProcessBuilder.`)
|
loggerLaunchSuite.info(`Sending selected account (${authUser.displayName}) to ProcessBuilder.`)
|
||||||
let pb = new ProcessBuilder(serv, versionData, forgeData, authUser, remote.app.getVersion())
|
let pb = new ProcessBuilder(serv, versionData, forgeData, authUser, app.getVersion())
|
||||||
setLaunchDetails(Lang.queryJS('landing.dlAsync.launchingGame'))
|
setLaunchDetails(Lang.queryJS('landing.dlAsync.launchingGame'))
|
||||||
|
|
||||||
// const SERVER_JOINED_REGEX = /\[.+\]: \[CHAT\] [a-zA-Z0-9_]{1,16} joined the game/
|
// const SERVER_JOINED_REGEX = /\[.+\]: \[CHAT\] [a-zA-Z0-9_]{1,16} joined the game/
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
/**
|
/**
|
||||||
* Script for login.ejs
|
* Script for login.ejs
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import { VIEWS } from './views.js'
|
||||||
|
|
||||||
// Validation Regexes.
|
// Validation Regexes.
|
||||||
const validUsername = /^[a-zA-Z0-9_]{1,16}$/
|
const validUsername = /^[a-zA-Z0-9_]{1,16}$/
|
||||||
const basicEmail = /^\S+@\S+\.\S+$/
|
const basicEmail = /^\S+@\S+\.\S+$/
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
import { VIEWS } from './views.js'
|
||||||
|
|
||||||
const loginOptionsCancelContainer = document.getElementById('loginOptionCancelContainer')
|
const loginOptionsCancelContainer = document.getElementById('loginOptionCancelContainer')
|
||||||
const loginOptionMicrosoft = document.getElementById('loginOptionMicrosoft')
|
const loginOptionMicrosoft = document.getElementById('loginOptionMicrosoft')
|
||||||
const loginOptionMojang = document.getElementById('loginOptionMojang')
|
const loginOptionMojang = document.getElementById('loginOptionMojang')
|
||||||
|
@ -2,6 +2,8 @@
|
|||||||
* Script for overlay.ejs
|
* Script for overlay.ejs
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import { VIEWS } from './views.js'
|
||||||
|
|
||||||
/* Overlay Wrapper Functions */
|
/* Overlay Wrapper Functions */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
// Requirements
|
|
||||||
const os = require('os')
|
|
||||||
const semver = require('semver')
|
|
||||||
|
|
||||||
const DropinModUtil = require('./assets/js/dropinmodutil')
|
import { VIEWS } from './views.js'
|
||||||
const { MSFT_OPCODE, MSFT_REPLY_TYPE, MSFT_ERROR } = require('./assets/js/ipcconstants')
|
|
||||||
|
import DropinModUtil from './assets/js/dropinmodutil'
|
||||||
|
import { MSFT_OPCODE, MSFT_REPLY_TYPE, MSFT_ERROR } from './assets/js/ipcconstants'
|
||||||
|
|
||||||
const settingsState = {
|
const settingsState = {
|
||||||
invalid: new Set()
|
invalid: new Set()
|
||||||
@ -64,13 +63,14 @@ function bindFileSelectors(){
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
const res = await remote.dialog.showOpenDialog(remote.getCurrentWindow(), options)
|
// TODO FIXME
|
||||||
if(!res.canceled) {
|
// const res = await remote.dialog.showOpenDialog(remote.getCurrentWindow(), options)
|
||||||
ele.previousElementSibling.value = res.filePaths[0]
|
// if(!res.canceled) {
|
||||||
if(isJavaExecSel) {
|
// ele.previousElementSibling.value = res.filePaths[0]
|
||||||
await populateJavaExecDetails(ele.previousElementSibling.value)
|
// if(isJavaExecSel) {
|
||||||
}
|
// await populateJavaExecDetails(ele.previousElementSibling.value)
|
||||||
}
|
// }
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -716,7 +716,7 @@ async function resolveModsForUI(){
|
|||||||
const distro = await DistroAPI.getDistribution()
|
const distro = await DistroAPI.getDistribution()
|
||||||
const servConf = ConfigManager.getModConfiguration(serv)
|
const servConf = ConfigManager.getModConfiguration(serv)
|
||||||
|
|
||||||
const modStr = parseModulesForUI(distro.getServerById(serv).modules, false, servConf.mods)
|
const modStr = await parseModulesForUI(distro.getServerById(serv).modules, false, servConf.mods)
|
||||||
|
|
||||||
document.getElementById('settingsReqModsContent').innerHTML = modStr.reqMods
|
document.getElementById('settingsReqModsContent').innerHTML = modStr.reqMods
|
||||||
document.getElementById('settingsOptModsContent').innerHTML = modStr.optMods
|
document.getElementById('settingsOptModsContent').innerHTML = modStr.optMods
|
||||||
@ -729,11 +729,13 @@ async function resolveModsForUI(){
|
|||||||
* @param {boolean} submodules Whether or not we are parsing submodules.
|
* @param {boolean} submodules Whether or not we are parsing submodules.
|
||||||
* @param {Object} servConf The server configuration object for this module level.
|
* @param {Object} servConf The server configuration object for this module level.
|
||||||
*/
|
*/
|
||||||
function parseModulesForUI(mdls, submodules, servConf){
|
async function parseModulesForUI(mdls, submodules, servConf){
|
||||||
|
|
||||||
let reqMods = ''
|
let reqMods = ''
|
||||||
let optMods = ''
|
let optMods = ''
|
||||||
|
|
||||||
|
const Type = await hc.type
|
||||||
|
|
||||||
for(const mdl of mdls){
|
for(const mdl of mdls){
|
||||||
|
|
||||||
if(mdl.rawModule.type === Type.ForgeMod || mdl.rawModule.type === Type.LiteMod || mdl.rawModule.type === Type.LiteLoader){
|
if(mdl.rawModule.type === Type.ForgeMod || mdl.rawModule.type === Type.LiteMod || mdl.rawModule.type === Type.LiteLoader){
|
||||||
@ -755,7 +757,7 @@ function parseModulesForUI(mdls, submodules, servConf){
|
|||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
${mdl.subModules.length > 0 ? `<div class="settingsSubModContainer">
|
${mdl.subModules.length > 0 ? `<div class="settingsSubModContainer">
|
||||||
${Object.values(parseModulesForUI(mdl.subModules, true, servConf[mdl.getVersionlessMavenIdentifier()])).join('')}
|
${Object.values(await parseModulesForUI(mdl.subModules, true, servConf[mdl.getVersionlessMavenIdentifier()])).join('')}
|
||||||
</div>` : ''}
|
</div>` : ''}
|
||||||
</div>`
|
</div>`
|
||||||
|
|
||||||
@ -779,7 +781,7 @@ function parseModulesForUI(mdls, submodules, servConf){
|
|||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
${mdl.subModules.length > 0 ? `<div class="settingsSubModContainer">
|
${mdl.subModules.length > 0 ? `<div class="settingsSubModContainer">
|
||||||
${Object.values(parseModulesForUI(mdl.subModules, true, conf.mods)).join('')}
|
${Object.values(await parseModulesForUI(mdl.subModules, true, conf.mods)).join('')}
|
||||||
</div>` : ''}
|
</div>` : ''}
|
||||||
</div>`
|
</div>`
|
||||||
|
|
||||||
@ -1403,8 +1405,7 @@ const settingsAboutChangelogButton = settingsTabAbout.getElementsByClassName('se
|
|||||||
|
|
||||||
// Bind the devtools toggle button.
|
// Bind the devtools toggle button.
|
||||||
document.getElementById('settingsAboutDevToolsButton').onclick = (e) => {
|
document.getElementById('settingsAboutDevToolsButton').onclick = (e) => {
|
||||||
let window = remote.getCurrentWindow()
|
xwindow.toggleDevTools()
|
||||||
window.toggleDevTools()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1444,7 +1445,7 @@ function populateVersionInformation(version, valueElement, titleElement, checkEl
|
|||||||
* Retrieve the version information and display it on the UI.
|
* Retrieve the version information and display it on the UI.
|
||||||
*/
|
*/
|
||||||
function populateAboutVersionInformation(){
|
function populateAboutVersionInformation(){
|
||||||
populateVersionInformation(remote.app.getVersion(), document.getElementById('settingsAboutCurrentVersionValue'), document.getElementById('settingsAboutCurrentVersionTitle'), document.getElementById('settingsAboutCurrentVersionCheck'))
|
populateVersionInformation(app.getVersion(), document.getElementById('settingsAboutCurrentVersionValue'), document.getElementById('settingsAboutCurrentVersionTitle'), document.getElementById('settingsAboutCurrentVersionCheck'))
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1455,7 +1456,7 @@ function populateReleaseNotes(){
|
|||||||
$.ajax({
|
$.ajax({
|
||||||
url: 'https://github.com/dscalzi/HeliosLauncher/releases.atom',
|
url: 'https://github.com/dscalzi/HeliosLauncher/releases.atom',
|
||||||
success: (data) => {
|
success: (data) => {
|
||||||
const version = 'v' + remote.app.getVersion()
|
const version = 'v' + app.getVersion()
|
||||||
const entries = $(data).find('entry')
|
const entries = $(data).find('entry')
|
||||||
|
|
||||||
for(let i=0; i<entries.length; i++){
|
for(let i=0; i<entries.length; i++){
|
||||||
@ -1537,7 +1538,7 @@ function populateSettingsUpdateInformation(data){
|
|||||||
} else {
|
} else {
|
||||||
settingsUpdateTitle.innerHTML = Lang.queryJS('settings.updates.latestVersionTitle')
|
settingsUpdateTitle.innerHTML = Lang.queryJS('settings.updates.latestVersionTitle')
|
||||||
settingsUpdateChangelogCont.style.display = 'none'
|
settingsUpdateChangelogCont.style.display = 'none'
|
||||||
populateVersionInformation(remote.app.getVersion(), settingsUpdateVersionValue, settingsUpdateVersionTitle, settingsUpdateVersionCheck)
|
populateVersionInformation(app.getVersion(), settingsUpdateVersionValue, settingsUpdateVersionTitle, settingsUpdateVersionCheck)
|
||||||
settingsUpdateButtonStatus(Lang.queryJS('settings.updates.checkForUpdatesButton'), false, () => {
|
settingsUpdateButtonStatus(Lang.queryJS('settings.updates.checkForUpdatesButton'), false, () => {
|
||||||
if(!isDev){
|
if(!isDev){
|
||||||
ipcRenderer.send('autoUpdateAction', 'checkForUpdate')
|
ipcRenderer.send('autoUpdateAction', 'checkForUpdate')
|
||||||
|
@ -2,27 +2,12 @@
|
|||||||
* Initialize UI functions which depend on internal modules.
|
* Initialize UI functions which depend on internal modules.
|
||||||
* Loaded after core UI functions are initialized in uicore.js.
|
* Loaded after core UI functions are initialized in uicore.js.
|
||||||
*/
|
*/
|
||||||
// Requirements
|
|
||||||
const path = require('path')
|
|
||||||
const { Type } = require('helios-distribution-types')
|
|
||||||
|
|
||||||
const AuthManager = require('./assets/js/authmanager')
|
import { VIEWS } from './views.js'
|
||||||
const ConfigManager = require('./assets/js/configmanager')
|
|
||||||
const { DistroAPI } = require('./assets/js/distromanager')
|
|
||||||
|
|
||||||
let rscShouldLoad = false
|
let rscShouldLoad = false
|
||||||
let fatalStartupError = false
|
let fatalStartupError = false
|
||||||
|
|
||||||
// Mapping of each view to their container IDs.
|
|
||||||
const VIEWS = {
|
|
||||||
landing: '#landingContainer',
|
|
||||||
loginOptions: '#loginOptionsContainer',
|
|
||||||
login: '#loginContainer',
|
|
||||||
settings: '#settingsContainer',
|
|
||||||
welcome: '#welcomeContainer',
|
|
||||||
waiting: '#waitingContainer'
|
|
||||||
}
|
|
||||||
|
|
||||||
// The currently shown view container.
|
// The currently shown view container.
|
||||||
let currentView
|
let currentView
|
||||||
|
|
||||||
@ -119,8 +104,7 @@ function showFatalStartupError(){
|
|||||||
Lang.queryJS('uibinder.startup.closeButton')
|
Lang.queryJS('uibinder.startup.closeButton')
|
||||||
)
|
)
|
||||||
setOverlayHandler(() => {
|
setOverlayHandler(() => {
|
||||||
const window = remote.getCurrentWindow()
|
xwindow.close()
|
||||||
window.close()
|
|
||||||
})
|
})
|
||||||
toggleOverlay(true)
|
toggleOverlay(true)
|
||||||
})
|
})
|
||||||
@ -145,9 +129,10 @@ function onDistroRefresh(data){
|
|||||||
*
|
*
|
||||||
* @param {Object} data The distro index object.
|
* @param {Object} data The distro index object.
|
||||||
*/
|
*/
|
||||||
function syncModConfigurations(data){
|
async function syncModConfigurations(data){
|
||||||
|
|
||||||
const syncedCfgs = []
|
const syncedCfgs = []
|
||||||
|
const Type = await hc.type
|
||||||
|
|
||||||
for(let serv of data.servers){
|
for(let serv of data.servers){
|
||||||
|
|
||||||
@ -439,7 +424,7 @@ document.addEventListener('readystatechange', async () => {
|
|||||||
ipcRenderer.on('distributionIndexDone', async (event, res) => {
|
ipcRenderer.on('distributionIndexDone', async (event, res) => {
|
||||||
if(res) {
|
if(res) {
|
||||||
const data = await DistroAPI.getDistribution()
|
const data = await DistroAPI.getDistribution()
|
||||||
syncModConfigurations(data)
|
await syncModConfigurations(data)
|
||||||
ensureJavaSettings(data)
|
ensureJavaSettings(data)
|
||||||
if(document.readyState === 'interactive' || document.readyState === 'complete'){
|
if(document.readyState === 'interactive' || document.readyState === 'complete'){
|
||||||
await showMainUI(data)
|
await showMainUI(data)
|
||||||
@ -462,5 +447,5 @@ async function devModeToggle() {
|
|||||||
const data = await DistroAPI.refreshDistributionOrFallback()
|
const data = await DistroAPI.refreshDistributionOrFallback()
|
||||||
ensureJavaSettings(data)
|
ensureJavaSettings(data)
|
||||||
updateSelectedServer(data.servers[0])
|
updateSelectedServer(data.servers[0])
|
||||||
syncModConfigurations(data)
|
await syncModConfigurations(data)
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
import { VIEWS } from './views.js'
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Core UI functions are initialized in this file. This prevents
|
* Core UI functions are initialized in this file. This prevents
|
||||||
* unexpected errors from breaking the core features. Specifically,
|
* unexpected errors from breaking the core features. Specifically,
|
||||||
@ -5,58 +7,41 @@
|
|||||||
* modules, excluding dependencies.
|
* modules, excluding dependencies.
|
||||||
*/
|
*/
|
||||||
// Requirements
|
// Requirements
|
||||||
const $ = require('jquery')
|
// const { ipcRenderer } = require('electron')
|
||||||
const {ipcRenderer, shell, webFrame} = require('electron')
|
const isDev = await window.api.app.isDev()
|
||||||
const remote = require('@electron/remote')
|
// const { LoggerUtil } = require('helios-core')
|
||||||
const isDev = require('./assets/js/isdev')
|
// const Lang = require('./assets/js/langloader')
|
||||||
const { LoggerUtil } = require('helios-core')
|
|
||||||
const Lang = require('./assets/js/langloader')
|
|
||||||
|
|
||||||
const loggerUICore = LoggerUtil.getLogger('UICore')
|
// const loggerUICore = LoggerUtil.getLogger('UICore')
|
||||||
const loggerAutoUpdater = LoggerUtil.getLogger('AutoUpdater')
|
// const loggerAutoUpdater = LoggerUtil.getLogger('AutoUpdater')
|
||||||
|
|
||||||
// Log deprecation and process warnings.
|
|
||||||
process.traceProcessWarnings = true
|
|
||||||
process.traceDeprecation = true
|
|
||||||
|
|
||||||
// Disable eval function.
|
// Disable eval function.
|
||||||
// eslint-disable-next-line
|
// eslint-disable-next-line
|
||||||
window.eval = global.eval = function () {
|
window.eval = function () {
|
||||||
throw new Error('Sorry, this app does not support window.eval().')
|
throw new Error('Sorry, this app does not support window.eval().')
|
||||||
}
|
}
|
||||||
|
|
||||||
// Display warning when devtools window is opened.
|
|
||||||
remote.getCurrentWebContents().on('devtools-opened', () => {
|
|
||||||
console.log('%cThe console is dark and full of terrors.', 'color: white; -webkit-text-stroke: 4px #a02d2a; font-size: 60px; font-weight: bold')
|
|
||||||
console.log('%cIf you\'ve been told to paste something here, you\'re being scammed.', 'font-size: 16px')
|
|
||||||
console.log('%cUnless you know exactly what you\'re doing, close this window.', 'font-size: 16px')
|
|
||||||
})
|
|
||||||
|
|
||||||
// Disable zoom, needed for darwin.
|
|
||||||
webFrame.setZoomLevel(0)
|
|
||||||
webFrame.setVisualZoomLevelLimits(1, 1)
|
|
||||||
|
|
||||||
// Initialize auto updates in production environments.
|
// Initialize auto updates in production environments.
|
||||||
let updateCheckListener
|
let updateCheckListener
|
||||||
if(!isDev){
|
if(!isDev){
|
||||||
ipcRenderer.on('autoUpdateNotification', (event, arg, info) => {
|
ipcRenderer.on('autoUpdateNotification', (event, arg, info) => {
|
||||||
switch(arg){
|
switch(arg){
|
||||||
case 'checking-for-update':
|
case 'checking-for-update':
|
||||||
loggerAutoUpdater.info('Checking for update..')
|
// loggerAutoUpdater.info('Checking for update..')
|
||||||
settingsUpdateButtonStatus(Lang.queryJS('uicore.autoUpdate.checkingForUpdateButton'), true)
|
settingsUpdateButtonStatus(Lang.queryJS('uicore.autoUpdate.checkingForUpdateButton'), true)
|
||||||
break
|
break
|
||||||
case 'update-available':
|
case 'update-available':
|
||||||
loggerAutoUpdater.info('New update available', info.version)
|
// loggerAutoUpdater.info('New update available', info.version)
|
||||||
|
|
||||||
if(process.platform === 'darwin'){
|
if(process.platform() === 'darwin'){
|
||||||
info.darwindownload = `https://github.com/dscalzi/HeliosLauncher/releases/download/v${info.version}/Helios-Launcher-setup-${info.version}${process.arch === 'arm64' ? '-arm64' : '-x64'}.dmg`
|
info.darwindownload = `https://github.com/dscalzi/HeliosLauncher/releases/download/v${info.version}/Helios-Launcher-setup-${info.version}${process.arch() === 'arm64' ? '-arm64' : '-x64'}.dmg`
|
||||||
showUpdateUI(info)
|
showUpdateUI(info)
|
||||||
}
|
}
|
||||||
|
|
||||||
populateSettingsUpdateInformation(info)
|
populateSettingsUpdateInformation(info)
|
||||||
break
|
break
|
||||||
case 'update-downloaded':
|
case 'update-downloaded':
|
||||||
loggerAutoUpdater.info('Update ' + info.version + ' ready to be installed.')
|
// loggerAutoUpdater.info('Update ' + info.version + ' ready to be installed.')
|
||||||
settingsUpdateButtonStatus(Lang.queryJS('uicore.autoUpdate.installNowButton'), false, () => {
|
settingsUpdateButtonStatus(Lang.queryJS('uicore.autoUpdate.installNowButton'), false, () => {
|
||||||
if(!isDev){
|
if(!isDev){
|
||||||
ipcRenderer.send('autoUpdateAction', 'installUpdateNow')
|
ipcRenderer.send('autoUpdateAction', 'installUpdateNow')
|
||||||
@ -65,7 +50,7 @@ if(!isDev){
|
|||||||
showUpdateUI(info)
|
showUpdateUI(info)
|
||||||
break
|
break
|
||||||
case 'update-not-available':
|
case 'update-not-available':
|
||||||
loggerAutoUpdater.info('No new update found.')
|
// loggerAutoUpdater.info('No new update found.')
|
||||||
settingsUpdateButtonStatus(Lang.queryJS('uicore.autoUpdate.checkForUpdatesButton'))
|
settingsUpdateButtonStatus(Lang.queryJS('uicore.autoUpdate.checkForUpdatesButton'))
|
||||||
break
|
break
|
||||||
case 'ready':
|
case 'ready':
|
||||||
@ -77,17 +62,17 @@ if(!isDev){
|
|||||||
case 'realerror':
|
case 'realerror':
|
||||||
if(info != null && info.code != null){
|
if(info != null && info.code != null){
|
||||||
if(info.code === 'ERR_UPDATER_INVALID_RELEASE_FEED'){
|
if(info.code === 'ERR_UPDATER_INVALID_RELEASE_FEED'){
|
||||||
loggerAutoUpdater.info('No suitable releases found.')
|
// loggerAutoUpdater.info('No suitable releases found.')
|
||||||
} else if(info.code === 'ERR_XML_MISSED_ELEMENT'){
|
} else if(info.code === 'ERR_XML_MISSED_ELEMENT'){
|
||||||
loggerAutoUpdater.info('No releases found.')
|
// loggerAutoUpdater.info('No releases found.')
|
||||||
} else {
|
} else {
|
||||||
loggerAutoUpdater.error('Error during update check..', info)
|
// loggerAutoUpdater.error('Error during update check..', info)
|
||||||
loggerAutoUpdater.debug('Error Code:', info.code)
|
// loggerAutoUpdater.debug('Error Code:', info.code)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
default:
|
default:
|
||||||
loggerAutoUpdater.info('Unknown argument', arg)
|
// loggerAutoUpdater.info('Unknown argument', arg)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -133,72 +118,62 @@ $(function(){
|
|||||||
loggerUICore.info('UICore Initialized');
|
loggerUICore.info('UICore Initialized');
|
||||||
})*/
|
})*/
|
||||||
|
|
||||||
document.addEventListener('readystatechange', function () {
|
// loggerUICore.info('UICore Initializing..')
|
||||||
if (document.readyState === 'interactive'){
|
|
||||||
loggerUICore.info('UICore Initializing..')
|
|
||||||
|
|
||||||
// Bind close button.
|
// Bind close button.
|
||||||
Array.from(document.getElementsByClassName('fCb')).map((val) => {
|
Array.from(document.getElementsByClassName('fCb')).map((val) => {
|
||||||
val.addEventListener('click', e => {
|
val.addEventListener('click', async e => {
|
||||||
const window = remote.getCurrentWindow()
|
await window.api.xwindow.close()
|
||||||
window.close()
|
})
|
||||||
})
|
})
|
||||||
})
|
|
||||||
|
|
||||||
// Bind restore down button.
|
// Bind restore down button.
|
||||||
Array.from(document.getElementsByClassName('fRb')).map((val) => {
|
Array.from(document.getElementsByClassName('fRb')).map((val) => {
|
||||||
val.addEventListener('click', e => {
|
val.addEventListener('click', async e => {
|
||||||
const window = remote.getCurrentWindow()
|
if(await window.api.xwindow.isMaximized()){
|
||||||
if(window.isMaximized()){
|
await window.api.xwindow.unmaximize()
|
||||||
window.unmaximize()
|
} else {
|
||||||
} else {
|
await window.api.xwindow.maximize()
|
||||||
window.maximize()
|
}
|
||||||
}
|
document.activeElement.blur()
|
||||||
document.activeElement.blur()
|
})
|
||||||
})
|
})
|
||||||
})
|
|
||||||
|
|
||||||
// Bind minimize button.
|
// Bind minimize button.
|
||||||
Array.from(document.getElementsByClassName('fMb')).map((val) => {
|
Array.from(document.getElementsByClassName('fMb')).map((val) => {
|
||||||
val.addEventListener('click', e => {
|
val.addEventListener('click', async e => {
|
||||||
const window = remote.getCurrentWindow()
|
console.log('hi')
|
||||||
window.minimize()
|
await window.api.xwindow.minimize()
|
||||||
document.activeElement.blur()
|
document.activeElement.blur()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
// Remove focus from social media buttons once they're clicked.
|
// Remove focus from social media buttons once they're clicked.
|
||||||
Array.from(document.getElementsByClassName('mediaURL')).map(val => {
|
Array.from(document.getElementsByClassName('mediaURL')).map(val => {
|
||||||
val.addEventListener('click', e => {
|
val.addEventListener('click', e => {
|
||||||
document.activeElement.blur()
|
document.activeElement.blur()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
} else if(document.readyState === 'complete'){
|
//266.01
|
||||||
|
//170.8
|
||||||
|
//53.21
|
||||||
|
// Bind progress bar length to length of bot wrapper
|
||||||
|
//const targetWidth = document.getElementById("launch_content").getBoundingClientRect().width
|
||||||
|
//const targetWidth2 = document.getElementById("server_selection").getBoundingClientRect().width
|
||||||
|
//const targetWidth3 = document.getElementById("launch_button").getBoundingClientRect().width
|
||||||
|
|
||||||
//266.01
|
document.getElementById('launch_details').style.maxWidth = 266.01
|
||||||
//170.8
|
document.getElementById('launch_progress').style.width = 170.8
|
||||||
//53.21
|
document.getElementById('launch_details_right').style.maxWidth = 170.8
|
||||||
// Bind progress bar length to length of bot wrapper
|
document.getElementById('launch_progress_label').style.width = 53.21
|
||||||
//const targetWidth = document.getElementById("launch_content").getBoundingClientRect().width
|
|
||||||
//const targetWidth2 = document.getElementById("server_selection").getBoundingClientRect().width
|
|
||||||
//const targetWidth3 = document.getElementById("launch_button").getBoundingClientRect().width
|
|
||||||
|
|
||||||
document.getElementById('launch_details').style.maxWidth = 266.01
|
|
||||||
document.getElementById('launch_progress').style.width = 170.8
|
|
||||||
document.getElementById('launch_details_right').style.maxWidth = 170.8
|
|
||||||
document.getElementById('launch_progress_label').style.width = 53.21
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}, false)
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Open web links in the user's default browser.
|
* Open web links in the user's default browser.
|
||||||
*/
|
*/
|
||||||
$(document).on('click', 'a[href^="http"]', function(event) {
|
$(document).on('click', 'a[href^="http"]', async (event) => {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
shell.openExternal(this.href)
|
await window.api.shell.openExternal(this.href)
|
||||||
})
|
})
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -206,9 +181,8 @@ $(document).on('click', 'a[href^="http"]', function(event) {
|
|||||||
* This will crash the program if you are using multiple
|
* This will crash the program if you are using multiple
|
||||||
* DevTools, for example the chrome debugger in VS Code.
|
* DevTools, for example the chrome debugger in VS Code.
|
||||||
*/
|
*/
|
||||||
document.addEventListener('keydown', function (e) {
|
document.addEventListener('keydown', async (e) => {
|
||||||
if((e.key === 'I' || e.key === 'i') && e.ctrlKey && e.shiftKey){
|
if((e.key === 'I' || e.key === 'i') && e.ctrlKey && e.shiftKey){
|
||||||
let window = remote.getCurrentWindow()
|
await window.api.xwindow.toggleDevTools()
|
||||||
window.toggleDevTools()
|
|
||||||
}
|
}
|
||||||
})
|
})
|
9
app/assets/js/scripts/views.js
Normal file
9
app/assets/js/scripts/views.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
// Mapping of each view to their container IDs.
|
||||||
|
export const VIEWS = {
|
||||||
|
landing: '#landingContainer',
|
||||||
|
loginOptions: '#loginOptionsContainer',
|
||||||
|
login: '#loginContainer',
|
||||||
|
settings: '#settingsContainer',
|
||||||
|
welcome: '#welcomeContainer',
|
||||||
|
waiting: '#waitingContainer'
|
||||||
|
}
|
@ -1,3 +1,5 @@
|
|||||||
|
import { VIEWS } from './views.js'
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Script for welcome.ejs
|
* Script for welcome.ejs
|
||||||
*/
|
*/
|
||||||
|
@ -216,5 +216,5 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="./assets/js/scripts/landing.js"></script>
|
<!-- <script type="module" src="./assets/js/scripts/landing.js"></script> -->
|
||||||
</div>
|
</div>
|
@ -61,5 +61,5 @@
|
|||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
<script src="./assets/js/scripts/login.js"></script>
|
<!-- <script type="module" src="./assets/js/scripts/login.js"></script> -->
|
||||||
</div>
|
</div>
|
@ -30,5 +30,5 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="./assets/js/scripts/loginOptions.js"></script>
|
<!-- <script type="module" src="./assets/js/scripts/loginOptions.js"></script> -->
|
||||||
</div>
|
</div>
|
@ -37,5 +37,5 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="./assets/js/scripts/overlay.js"></script>
|
<!-- <script type="module" src="./assets/js/scripts/overlay.js"></script> -->
|
||||||
</div>
|
</div>
|
@ -389,5 +389,5 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="./assets/js/scripts/settings.js"></script>
|
<!-- <script type="module" src="./assets/js/scripts/settings.js"></script> -->
|
||||||
</div>
|
</div>
|
@ -21,5 +21,5 @@
|
|||||||
</div>
|
</div>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<script src="./assets/js/scripts/welcome.js"></script>
|
<!-- <script type="module" src="./assets/js/scripts/welcome.js"></script> -->
|
||||||
</div>
|
</div>
|
218
index.js
218
index.js
@ -1,23 +1,104 @@
|
|||||||
const remoteMain = require('@electron/remote/main')
|
|
||||||
remoteMain.initialize()
|
|
||||||
|
|
||||||
// Requirements
|
// Requirements
|
||||||
const { app, BrowserWindow, ipcMain, Menu, shell } = require('electron')
|
const { app, BrowserWindow, ipcMain, Menu, shell } = require('electron')
|
||||||
const autoUpdater = require('electron-updater').autoUpdater
|
const autoUpdater = require('electron-updater').autoUpdater
|
||||||
const ejse = require('ejs-electron')
|
const ejse = require('ejs-electron')
|
||||||
const fs = require('fs')
|
const fs = require('fs-extra')
|
||||||
const isDev = require('./app/assets/js/isdev')
|
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
const semver = require('semver')
|
const semver = require('semver')
|
||||||
const { pathToFileURL } = require('url')
|
const { pathToFileURL } = require('url')
|
||||||
const { AZURE_CLIENT_ID, MSFT_OPCODE, MSFT_REPLY_TYPE, MSFT_ERROR, SHELL_OPCODE } = require('./app/assets/js/ipcconstants')
|
const { AZURE_CLIENT_ID, MSFT_OPCODE, MSFT_REPLY_TYPE, MSFT_ERROR, SHELL_OPCODE } = require('./app/assets/js/ipcconstants')
|
||||||
const LangLoader = require('./app/assets/js/langloader')
|
|
||||||
|
const { Type } = require('helios-distribution-types')
|
||||||
|
const { totalmem, freemem, tmpdir } = require('node:os')
|
||||||
|
const { prerelease } = require('semver')
|
||||||
|
const { addMojangAccount, addMicrosoftAccount, removeMojangAccount, removeMicrosoftAccount, validateSelected } = require('./app/assets/js/main/authmanager')
|
||||||
|
|
||||||
|
const ConfigManager = require('./app/assets/js/main/configmanager')
|
||||||
|
const { DistroAPI } = require('./app/assets/js/main/distromanager')
|
||||||
|
// eslint-disable-next-line no-unused-vars
|
||||||
|
const { HeliosDistribution } = require('helios-core/common')
|
||||||
|
const { LoggerUtil } = require('helios-core')
|
||||||
|
const { getLang, setupLanguage, queryEJS } = require('./app/assets/js/main/langloader')
|
||||||
|
|
||||||
|
const logger = LoggerUtil.getLogger('Preloader')
|
||||||
|
|
||||||
|
// Log deprecation and process warnings.
|
||||||
|
process.traceProcessWarnings = true
|
||||||
|
process.traceDeprecation = true
|
||||||
|
|
||||||
|
// Load ConfigManager
|
||||||
|
ConfigManager.load()
|
||||||
|
|
||||||
|
// Yuck!
|
||||||
|
// TODO Fix this
|
||||||
|
DistroAPI['commonDir'] = ConfigManager.getCommonDirectory()
|
||||||
|
DistroAPI['instanceDir'] = ConfigManager.getInstanceDirectory()
|
||||||
|
|
||||||
// Setup Lang
|
// Setup Lang
|
||||||
LangLoader.setupLanguage()
|
setupLanguage()
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {HeliosDistribution} data
|
||||||
|
*/
|
||||||
|
function onDistroLoad(data){
|
||||||
|
if(data != null){
|
||||||
|
|
||||||
|
// Resolve the selected server if its value has yet to be set.
|
||||||
|
if(ConfigManager.getSelectedServer() == null || data.getServerById(ConfigManager.getSelectedServer()) == null){
|
||||||
|
logger.info('Determining default selected server..')
|
||||||
|
ConfigManager.setSelectedServer(data.getMainServer().rawServer.id)
|
||||||
|
ConfigManager.save()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
win.webContents.send('distributionIndexDone', data != null)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure Distribution is downloaded and cached.
|
||||||
|
DistroAPI.getDistribution()
|
||||||
|
.then(heliosDistro => {
|
||||||
|
logger.info('Loaded distribution index.')
|
||||||
|
|
||||||
|
onDistroLoad(heliosDistro)
|
||||||
|
})
|
||||||
|
.catch(err => {
|
||||||
|
logger.info('Failed to load an older version of the distribution index.')
|
||||||
|
logger.info('Application cannot run.')
|
||||||
|
logger.error(err)
|
||||||
|
|
||||||
|
onDistroLoad(null)
|
||||||
|
})
|
||||||
|
|
||||||
|
// Clean up temp dir incase previous launches ended unexpectedly.
|
||||||
|
fs.remove(path.join(tmpdir(), ConfigManager.getTempNativeFolder()), (err) => {
|
||||||
|
if(err){
|
||||||
|
logger.warn('Error while cleaning natives directory', err)
|
||||||
|
} else {
|
||||||
|
logger.info('Cleaned natives directory.')
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const autoUpdateChannel = new MessageChannel()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ORIGINAL BELOW
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Setup auto updater.
|
// Setup auto updater.
|
||||||
function initAutoUpdater(event, data) {
|
function initAutoUpdater(data) {
|
||||||
|
|
||||||
if(data){
|
if(data){
|
||||||
autoUpdater.allowPrerelease = true
|
autoUpdater.allowPrerelease = true
|
||||||
@ -26,7 +107,7 @@ function initAutoUpdater(event, data) {
|
|||||||
// autoUpdater.allowPrerelease = true
|
// autoUpdater.allowPrerelease = true
|
||||||
}
|
}
|
||||||
|
|
||||||
if(isDev){
|
if(!app.isPackaged){
|
||||||
autoUpdater.autoInstallOnAppQuit = false
|
autoUpdater.autoInstallOnAppQuit = false
|
||||||
autoUpdater.updateConfigPath = path.join(__dirname, 'dev-app-update.yml')
|
autoUpdater.updateConfigPath = path.join(__dirname, 'dev-app-update.yml')
|
||||||
}
|
}
|
||||||
@ -34,22 +115,77 @@ function initAutoUpdater(event, data) {
|
|||||||
autoUpdater.autoDownload = false
|
autoUpdater.autoDownload = false
|
||||||
}
|
}
|
||||||
autoUpdater.on('update-available', (info) => {
|
autoUpdater.on('update-available', (info) => {
|
||||||
event.sender.send('autoUpdateNotification', 'update-available', info)
|
autoUpdateChannel.port1.postMessage(['autoUpdateNotification', 'update-available', info])
|
||||||
})
|
})
|
||||||
autoUpdater.on('update-downloaded', (info) => {
|
autoUpdater.on('update-downloaded', (info) => {
|
||||||
event.sender.send('autoUpdateNotification', 'update-downloaded', info)
|
autoUpdateChannel.port1.postMessage(['autoUpdateNotification', 'update-downloaded', info])
|
||||||
})
|
})
|
||||||
autoUpdater.on('update-not-available', (info) => {
|
autoUpdater.on('update-not-available', (info) => {
|
||||||
event.sender.send('autoUpdateNotification', 'update-not-available', info)
|
autoUpdateChannel.port1.postMessage(['autoUpdateNotification', 'update-not-available', info])
|
||||||
})
|
})
|
||||||
autoUpdater.on('checking-for-update', () => {
|
autoUpdater.on('checking-for-update', () => {
|
||||||
event.sender.send('autoUpdateNotification', 'checking-for-update')
|
autoUpdateChannel.port1.postMessage(['autoUpdateNotification', 'checking-for-update'])
|
||||||
})
|
})
|
||||||
autoUpdater.on('error', (err) => {
|
autoUpdater.on('error', (err) => {
|
||||||
event.sender.send('autoUpdateNotification', 'realerror', err)
|
autoUpdateChannel.port1.postMessage(['autoUpdateNotification', 'realerror', err])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
// all on autoupdatechannel
|
||||||
|
[
|
||||||
|
command,
|
||||||
|
arg1,
|
||||||
|
arg2,
|
||||||
|
...
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
autoUpdateChannel.port1.on('message', (event) => {
|
||||||
|
const command = event[0]
|
||||||
|
switch(command) {
|
||||||
|
case 'initAutoUpdater':
|
||||||
|
console.log('Initializing auto updater.')
|
||||||
|
initAutoUpdater(event[1])
|
||||||
|
autoUpdateChannel.port1.postMessage([
|
||||||
|
'autoUpdateNotification',
|
||||||
|
'ready'
|
||||||
|
])
|
||||||
|
break
|
||||||
|
case 'checkForUpdate':
|
||||||
|
// TODO Test that error is passed properly
|
||||||
|
autoUpdater.checkForUpdates()
|
||||||
|
.catch(err => {
|
||||||
|
autoUpdateChannel.port1.postMessage([
|
||||||
|
'autoUpdateNotification',
|
||||||
|
'realerror',
|
||||||
|
err
|
||||||
|
])
|
||||||
|
})
|
||||||
|
break
|
||||||
|
case 'allowPrereleaseChange':
|
||||||
|
if(!event[1]){
|
||||||
|
const preRelComp = semver.prerelease(app.getVersion())
|
||||||
|
if(preRelComp != null && preRelComp.length > 0){
|
||||||
|
autoUpdater.allowPrerelease = true
|
||||||
|
} else {
|
||||||
|
autoUpdater.allowPrerelease = event[1]
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
autoUpdater.allowPrerelease = event[1]
|
||||||
|
}
|
||||||
|
break
|
||||||
|
case 'installUpdateNow':
|
||||||
|
autoUpdater.quitAndInstall()
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
console.log('Unknown command', command)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
// Open channel to listen for update actions.
|
// Open channel to listen for update actions.
|
||||||
ipcMain.on('autoUpdateAction', (event, arg, data) => {
|
ipcMain.on('autoUpdateAction', (event, arg, data) => {
|
||||||
switch(arg){
|
switch(arg){
|
||||||
@ -84,10 +220,6 @@ ipcMain.on('autoUpdateAction', (event, arg, data) => {
|
|||||||
break
|
break
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
// Redirect distribution index event from preloader to renderer.
|
|
||||||
ipcMain.on('distributionIndexDone', (event, res) => {
|
|
||||||
event.sender.send('distributionIndexDone', res)
|
|
||||||
})
|
|
||||||
|
|
||||||
// Handle trash item.
|
// Handle trash item.
|
||||||
ipcMain.handle(SHELL_OPCODE.TRASH_ITEM, async (event, ...args) => {
|
ipcMain.handle(SHELL_OPCODE.TRASH_ITEM, async (event, ...args) => {
|
||||||
@ -234,15 +366,18 @@ function createWindow() {
|
|||||||
webPreferences: {
|
webPreferences: {
|
||||||
preload: path.join(__dirname, 'app', 'assets', 'js', 'preloader.js'),
|
preload: path.join(__dirname, 'app', 'assets', 'js', 'preloader.js'),
|
||||||
nodeIntegration: true,
|
nodeIntegration: true,
|
||||||
contextIsolation: false
|
contextIsolation: true
|
||||||
},
|
},
|
||||||
backgroundColor: '#171614'
|
backgroundColor: '#171614'
|
||||||
})
|
})
|
||||||
remoteMain.enable(win.webContents)
|
|
||||||
|
// Disable zoom, needed for darwin.
|
||||||
|
win.webContents.setZoomLevel(0)
|
||||||
|
win.webContents.setVisualZoomLevelLimits(1, 1)
|
||||||
|
|
||||||
const data = {
|
const data = {
|
||||||
bkid: Math.floor((Math.random() * fs.readdirSync(path.join(__dirname, 'app', 'assets', 'images', 'backgrounds')).length)),
|
bkid: Math.floor((Math.random() * fs.readdirSync(path.join(__dirname, 'app', 'assets', 'images', 'backgrounds')).length)),
|
||||||
lang: (str, placeHolders) => LangLoader.queryEJS(str, placeHolders)
|
lang: (str, placeHolders) => queryEJS(str, placeHolders)
|
||||||
}
|
}
|
||||||
Object.entries(data).forEach(([key, val]) => ejse.data(key, val))
|
Object.entries(data).forEach(([key, val]) => ejse.data(key, val))
|
||||||
|
|
||||||
@ -341,8 +476,47 @@ function getPlatformIcon(filename){
|
|||||||
return path.join(__dirname, 'app', 'assets', 'images', `${filename}.${ext}`)
|
return path.join(__dirname, 'app', 'assets', 'images', `${filename}.${ext}`)
|
||||||
}
|
}
|
||||||
|
|
||||||
app.on('ready', createWindow)
|
app.whenReady().then(() => {
|
||||||
app.on('ready', createMenu)
|
|
||||||
|
ipcMain.handle('os.totalmem', () => totalmem())
|
||||||
|
ipcMain.handle('os.freemem', () => freemem())
|
||||||
|
|
||||||
|
ipcMain.handle('semver.prerelease', (version) => prerelease(version))
|
||||||
|
|
||||||
|
ipcMain.handle('path.join', (...args) => path.join(args))
|
||||||
|
|
||||||
|
ipcMain.handle('app.isDev', () => !app.isPackaged)
|
||||||
|
ipcMain.handle('app.getVersion', () => app.getVersion())
|
||||||
|
|
||||||
|
ipcMain.handle('shell.openExternal', (url) => shell.openExternal(url))
|
||||||
|
ipcMain.handle('shell.openPath', (path) => shell.openPath(path))
|
||||||
|
|
||||||
|
ipcMain.handle('xwindow.close', () => win.close())
|
||||||
|
ipcMain.handle('xwindow.setProgressBar', (progress) => win.setProgressBar(progress))
|
||||||
|
ipcMain.handle('xwindow.toggleDevTools', () => win.webContents.toggleDevTools())
|
||||||
|
ipcMain.handle('xwindow.minimize', () => win.minimize())
|
||||||
|
ipcMain.handle('xwindow.maximize', () => win.maximize())
|
||||||
|
ipcMain.handle('xwindow.unmaximize', () => win.unmaximize())
|
||||||
|
ipcMain.handle('xwindow.isMaximized', () => win.isMaximized())
|
||||||
|
|
||||||
|
ipcMain.handle('process.platform', () => process.platform)
|
||||||
|
ipcMain.handle('process.arch', () => process.arch)
|
||||||
|
|
||||||
|
ipcMain.handle('hc.type', () => Type)
|
||||||
|
|
||||||
|
ipcMain.handle('AuthManager.addMojangAccount', async (username, password) => await addMojangAccount(username, password))
|
||||||
|
ipcMain.handle('AuthManager.addMicrosoftAccount', async (authCode) => await addMicrosoftAccount(authCode))
|
||||||
|
ipcMain.handle('AuthManager.removeMojangAccount', async (uuid) => await removeMojangAccount(uuid))
|
||||||
|
ipcMain.handle('AuthManager.removeMicrosoftAccount', async (uuid) => await removeMicrosoftAccount(uuid))
|
||||||
|
ipcMain.handle('AuthManager.validateSelected', async () => await validateSelected())
|
||||||
|
|
||||||
|
ipcMain.handle('Lang.getLang', () => getLang())
|
||||||
|
|
||||||
|
ipcMain.handle('AutoUpdater.port2', () => autoUpdateChannel.port2)
|
||||||
|
|
||||||
|
createWindow()
|
||||||
|
createMenu()
|
||||||
|
})
|
||||||
|
|
||||||
app.on('window-all-closed', () => {
|
app.on('window-all-closed', () => {
|
||||||
// On macOS it is common for applications and their menu bar
|
// On macOS it is common for applications and their menu bar
|
||||||
|
Loading…
Reference in New Issue
Block a user