mirror of
https://github.com/amiayweb/Hytale-F2P.git
synced 2026-02-26 13:51:46 -03:00
feat: Add option to toggle hardware acceleration for launcher #170
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -20,3 +20,4 @@ backend/patcher/
|
|||||||
# macOS Specific
|
# macOS Specific
|
||||||
.DS_Store
|
.DS_Store
|
||||||
*.zst.DS_Store
|
*.zst.DS_Store
|
||||||
|
bun.lock
|
||||||
|
|||||||
406
GUI/index.html
406
GUI/index.html
@@ -127,17 +127,20 @@
|
|||||||
<label class="form-label" data-i18n="install.gameBranch">Game Version</label>
|
<label class="form-label" data-i18n="install.gameBranch">Game Version</label>
|
||||||
<div class="radio-group">
|
<div class="radio-group">
|
||||||
<label class="radio-label">
|
<label class="radio-label">
|
||||||
<input type="radio" name="installBranch" value="release" class="custom-radio" checked>
|
<input type="radio" name="installBranch" value="release" class="custom-radio"
|
||||||
|
checked>
|
||||||
<span class="radio-text">
|
<span class="radio-text">
|
||||||
<i class="fas fa-check-circle mr-2"></i>
|
<i class="fas fa-check-circle mr-2"></i>
|
||||||
<span data-i18n="install.releaseVersion">Release (Stable)</span>
|
<span data-i18n="install.releaseVersion">Release (Stable)</span>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
<label class="radio-label">
|
<label class="radio-label">
|
||||||
<input type="radio" name="installBranch" value="pre-release" class="custom-radio">
|
<input type="radio" name="installBranch" value="pre-release"
|
||||||
|
class="custom-radio">
|
||||||
<span class="radio-text">
|
<span class="radio-text">
|
||||||
<i class="fas fa-flask mr-2"></i>
|
<i class="fas fa-flask mr-2"></i>
|
||||||
<span data-i18n="install.preReleaseVersion">Pre-Release (Experimental)</span>
|
<span data-i18n="install.preReleaseVersion">Pre-Release
|
||||||
|
(Experimental)</span>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
@@ -361,226 +364,247 @@
|
|||||||
|
|
||||||
<div class="settings-option">
|
<div class="settings-option">
|
||||||
<div class="settings-input-group">
|
<div class="settings-input-group">
|
||||||
<label class="settings-input-label" data-i18n="settings.gameBranch">Game Branch</label>
|
<label class="settings-input-label" data-i18n="settings.gameBranch">Game
|
||||||
|
Branch</label>
|
||||||
<div class="segmented-control">
|
<div class="segmented-control">
|
||||||
<input type="radio" id="branch-release" name="gameBranch" value="release" checked>
|
<input type="radio" id="branch-release" name="gameBranch"
|
||||||
<label for="branch-release" data-i18n="settings.branchRelease">Release</label>
|
value="release" checked>
|
||||||
<input type="radio" id="branch-pre-release" name="gameBranch" value="pre-release">
|
<label for="branch-release"
|
||||||
<label for="branch-pre-release" data-i18n="settings.branchPreRelease">Pre-Release</label>
|
data-i18n="settings.branchRelease">Release</label>
|
||||||
|
<input type="radio" id="branch-pre-release" name="gameBranch"
|
||||||
|
value="pre-release">
|
||||||
|
<label for="branch-pre-release"
|
||||||
|
data-i18n="settings.branchPreRelease">Pre-Release</label>
|
||||||
</div>
|
</div>
|
||||||
<p class="settings-hint">
|
<p class="settings-hint">
|
||||||
<i class="fas fa-info-circle"></i>
|
<i class="fas fa-info-circle"></i>
|
||||||
<span data-i18n="settings.branchHint">Switch between stable release and experimental pre-release versions</span>
|
<span data-i18n="settings.branchHint">Switch between stable release and
|
||||||
|
experimental pre-release versions</span>
|
||||||
</p>
|
</p>
|
||||||
<p class="settings-hint" style="color: #f39c12;">
|
<p class="settings-hint" style="color: #f39c12;">
|
||||||
<i class="fas fa-exclamation-triangle"></i>
|
<i class="fas fa-exclamation-triangle"></i>
|
||||||
<span data-i18n="settings.branchWarning">Changing branch will download and install a different game version</span>
|
<span data-i18n="settings.branchWarning">Changing branch will download
|
||||||
|
and install a different game version</span>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="settings-option">
|
<div class="settings-option">
|
||||||
<label class="settings-input-label" data-i18n="settings.gpuPreference">GPU
|
<label class="settings-input-label" data-i18n="settings.gpuPreference">GPU
|
||||||
Preference</label>
|
Preference</label>
|
||||||
<div class="segmented-control">
|
<div class="segmented-control">
|
||||||
<input type="radio" id="gpu-auto" name="gpuPreference" value="auto"
|
<input type="radio" id="gpu-auto" name="gpuPreference" value="auto" checked>
|
||||||
checked>
|
<label for="gpu-auto" data-i18n="settings.gpuAuto">Auto</label>
|
||||||
<label for="gpu-auto" data-i18n="settings.gpuAuto">Auto</label>
|
<input type="radio" id="gpu-integrated" name="gpuPreference"
|
||||||
<input type="radio" id="gpu-integrated" name="gpuPreference"
|
value="integrated">
|
||||||
value="integrated">
|
<label for="gpu-integrated"
|
||||||
<label for="gpu-integrated"
|
data-i18n="settings.gpuIntegrated">Integrated</label>
|
||||||
data-i18n="settings.gpuIntegrated">Integrated</label>
|
<input type="radio" id="gpu-dedicated" name="gpuPreference"
|
||||||
<input type="radio" id="gpu-dedicated" name="gpuPreference"
|
value="dedicated">
|
||||||
value="dedicated">
|
<label for="gpu-dedicated"
|
||||||
<label for="gpu-dedicated"
|
data-i18n="settings.gpuDedicated">Dedicated</label>
|
||||||
data-i18n="settings.gpuDedicated">Dedicated</label>
|
|
||||||
</div>
|
|
||||||
<p class="settings-hint">
|
|
||||||
<i class="fas fa-info-circle"></i>
|
|
||||||
<span data-i18n="settings.gpuHint">Select your preferred GPU (Linux:
|
|
||||||
affects DRI_PRIME)</span>
|
|
||||||
</p>
|
|
||||||
<div id="gpu-detection-info" class="gpu-detection-info"></div>
|
|
||||||
</div>
|
</div>
|
||||||
|
<p class="settings-hint">
|
||||||
|
<i class="fas fa-info-circle"></i>
|
||||||
|
<span data-i18n="settings.gpuHint">Select your preferred GPU (Linux:
|
||||||
|
affects DRI_PRIME)</span>
|
||||||
|
</p>
|
||||||
|
<div id="gpu-detection-info" class="gpu-detection-info"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="settings-section">
|
<div class="settings-section">
|
||||||
<h3 class="settings-section-title">
|
<h3 class="settings-section-title">
|
||||||
<i class="fas fa-fingerprint"></i>
|
<i class="fas fa-fingerprint"></i>
|
||||||
<span data-i18n="settings.account">Player UUID Management</span>
|
<span data-i18n="settings.account">Player UUID Management</span>
|
||||||
</h3>
|
</h3>
|
||||||
|
|
||||||
<div class="settings-option">
|
<div class="settings-option">
|
||||||
<div class="settings-input-group">
|
<div class="settings-input-group">
|
||||||
<label class="settings-input-label" data-i18n="settings.currentUUID">Current
|
<label class="settings-input-label" data-i18n="settings.currentUUID">Current
|
||||||
UUID</label>
|
UUID</label>
|
||||||
<div class="uuid-display-container">
|
<div class="uuid-display-container">
|
||||||
<input type="text" id="currentUuid" class="settings-input uuid-input"
|
<input type="text" id="currentUuid" class="settings-input uuid-input"
|
||||||
readonly data-i18n-placeholder="settings.uuidPlaceholder" />
|
readonly data-i18n-placeholder="settings.uuidPlaceholder" />
|
||||||
<button id="copyUuidBtn" class="uuid-btn copy-btn" title="Copy UUID">
|
<button id="copyUuidBtn" class="uuid-btn copy-btn" title="Copy UUID">
|
||||||
<i class="fas fa-copy"></i>
|
<i class="fas fa-copy"></i>
|
||||||
</button>
|
</button>
|
||||||
<button id="regenerateUuidBtn" class="uuid-btn regenerate-btn"
|
<button id="regenerateUuidBtn" class="uuid-btn regenerate-btn"
|
||||||
title="Generate New UUID">
|
title="Generate New UUID">
|
||||||
<i class="fas fa-sync-alt"></i>
|
<i class="fas fa-sync-alt"></i>
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<p class="settings-hint">
|
|
||||||
<i class="fas fa-info-circle"></i>
|
|
||||||
<span data-i18n="settings.uuidHint">Your unique player identifier for
|
|
||||||
this username</span>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="settings-option">
|
|
||||||
<div class="settings-button-group">
|
|
||||||
<button id="manageUuidsBtn" class="settings-action-btn">
|
|
||||||
<i class="fas fa-list"></i>
|
|
||||||
<div class="btn-content">
|
|
||||||
<div class="btn-title" data-i18n="settings.manageUUIDs">Manage All
|
|
||||||
UUIDs</div>
|
|
||||||
<div class="btn-description" data-i18n="settings.manageUUIDsDesc">
|
|
||||||
View and manage all player UUIDs</div>
|
|
||||||
</div>
|
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
<p class="settings-hint">
|
||||||
|
<i class="fas fa-info-circle"></i>
|
||||||
|
<span data-i18n="settings.uuidHint">Your unique player identifier for
|
||||||
|
this username</span>
|
||||||
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="settings-section">
|
<div class="settings-option">
|
||||||
<h3 class="settings-section-title">
|
<div class="settings-button-group">
|
||||||
<i class="fab fa-discord"></i>
|
<button id="manageUuidsBtn" class="settings-action-btn">
|
||||||
<span data-i18n="settings.discord">Discord Integration</span>
|
<i class="fas fa-list"></i>
|
||||||
</h3>
|
<div class="btn-content">
|
||||||
|
<div class="btn-title" data-i18n="settings.manageUUIDs">Manage All
|
||||||
<div class="settings-option">
|
UUIDs</div>
|
||||||
<label class="settings-checkbox">
|
<div class="btn-description" data-i18n="settings.manageUUIDsDesc">
|
||||||
<input type="checkbox" id="discordRPCCheck" checked />
|
View and manage all player UUIDs</div>
|
||||||
<span class="checkmark"></span>
|
|
||||||
<div class="checkbox-content">
|
|
||||||
<div class="checkbox-title" data-i18n="settings.enableRPC">Enable
|
|
||||||
Discord Rich Presence</div>
|
|
||||||
<div class="checkbox-description"
|
|
||||||
data-i18n="settings.discordDescription">Show your launcher activity
|
|
||||||
on Discord
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</label>
|
</button>
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="settings-section">
|
|
||||||
<h3 class="settings-section-title">
|
|
||||||
<i class="fas fa-window-close"></i>
|
|
||||||
<span data-i18n="settings.closeLauncher">Launcher Behavior</span>
|
|
||||||
</h3>
|
|
||||||
|
|
||||||
<div class="settings-option">
|
|
||||||
<label class="settings-checkbox">
|
|
||||||
<input type="checkbox" id="closeLauncherCheck" />
|
|
||||||
<span class="checkmark"></span>
|
|
||||||
<div class="checkbox-content">
|
|
||||||
<div class="checkbox-title" data-i18n="settings.closeOnStart">Close Launcher on game start</div>
|
|
||||||
<div class="checkbox-description" data-i18n="settings.closeOnStartDescription">
|
|
||||||
Automatically close the launcher after Hytale has launched
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="settings-section">
|
|
||||||
<h3 class="settings-section-title">
|
|
||||||
<i class="fas fa-coffee"></i>
|
|
||||||
<span data-i18n="settings.java">Java Runtime</span>
|
|
||||||
</h3>
|
|
||||||
|
|
||||||
<div class="settings-option">
|
|
||||||
<label class="settings-checkbox">
|
|
||||||
<input type="checkbox" id="customJavaCheck" />
|
|
||||||
<span class="checkmark"></span>
|
|
||||||
<div class="checkbox-content">
|
|
||||||
<div class="checkbox-title" data-i18n="settings.useCustomJava">Use
|
|
||||||
Custom Java Path</div>
|
|
||||||
<div class="checkbox-description" data-i18n="settings.javaDescription">
|
|
||||||
Override the bundled Java runtime with
|
|
||||||
your own installation</div>
|
|
||||||
</div>
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="customJavaOptions" class="custom-java-options" style="display: none;">
|
|
||||||
<div class="settings-input-group">
|
|
||||||
<label class="settings-input-label" data-i18n="settings.javaPath">Java
|
|
||||||
Executable Path</label>
|
|
||||||
<div class="settings-input-with-button">
|
|
||||||
<input type="text" id="customJavaPath" class="settings-input"
|
|
||||||
data-i18n-placeholder="settings.javaPathPlaceholder" readonly />
|
|
||||||
<button id="browseJavaBtn" class="settings-browse-btn">
|
|
||||||
<i class="fas fa-folder-open"></i>
|
|
||||||
<span data-i18n="settings.javaBrowse">Browse</span>
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<p class="settings-hint">
|
|
||||||
<i class="fas fa-info-circle"></i>
|
|
||||||
<span data-i18n="settings.javaHint">Select the Java installation folder
|
|
||||||
(supports Windows, Mac, Linux)</span>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="settings-section">
|
|
||||||
<h3 class="settings-section-title">
|
|
||||||
<i class="fas fa-language"></i>
|
|
||||||
<span data-i18n="settings.language">Language</span>
|
|
||||||
</h3>
|
|
||||||
|
|
||||||
<div class="settings-option">
|
|
||||||
<div class="settings-input-group">
|
|
||||||
<label class="settings-input-label"
|
|
||||||
data-i18n="settings.selectLanguage">Select Language</label>
|
|
||||||
<select id="languageSelect" class="settings-input">
|
|
||||||
<!-- Options populated by i18n.js -->
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="logs-page" class="page">
|
<div class="settings-section">
|
||||||
<div class="logs-container">
|
<h3 class="settings-section-title">
|
||||||
<div class="logs-header">
|
<i class="fab fa-discord"></i>
|
||||||
<h2 class="logs-title">
|
<span data-i18n="settings.discord">Discord Integration</span>
|
||||||
<i class="fas fa-terminal"></i>
|
</h3>
|
||||||
<span data-i18n="settings.logs">SYSTEM LOGS</span>
|
|
||||||
</h2>
|
<div class="settings-option">
|
||||||
<div class="logs-actions">
|
<label class="settings-checkbox">
|
||||||
<button class="logs-action-btn" onclick="copyLogs()">
|
<input type="checkbox" id="discordRPCCheck" checked />
|
||||||
<i class="fas fa-copy"></i> <span data-i18n="settings.logsCopy">Copy</span>
|
<span class="checkmark"></span>
|
||||||
</button>
|
<div class="checkbox-content">
|
||||||
<button class="logs-action-btn" onclick="refreshLogs()">
|
<div class="checkbox-title" data-i18n="settings.enableRPC">Enable
|
||||||
<i class="fas fa-sync-alt"></i> <span
|
Discord Rich Presence</div>
|
||||||
data-i18n="settings.logsRefresh">Refresh</span>
|
<div class="checkbox-description" data-i18n="settings.discordDescription">
|
||||||
</button>
|
Show your launcher activity
|
||||||
<button class="logs-action-btn" onclick="openLogsFolder()">
|
on Discord
|
||||||
<i class="fas fa-folder-open"></i> <span data-i18n="settings.logsFolder">Open
|
</div>
|
||||||
Folder</span>
|
</div>
|
||||||
</button>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div id="logsTerminal" class="logs-terminal">
|
|
||||||
<div class="text-gray-500 text-center mt-10" data-i18n="settings.logsLoading">Loading
|
<div class="settings-section">
|
||||||
logs...</div>
|
<h3 class="settings-section-title">
|
||||||
|
<i class="fas fa-window-close"></i>
|
||||||
|
<span data-i18n="settings.closeLauncher">Launcher Behavior</span>
|
||||||
|
</h3>
|
||||||
|
|
||||||
|
<div class="settings-option">
|
||||||
|
<label class="settings-checkbox">
|
||||||
|
<input type="checkbox" id="closeLauncherCheck" />
|
||||||
|
<span class="checkmark"></span>
|
||||||
|
<div class="checkbox-content">
|
||||||
|
<div class="checkbox-title" data-i18n="settings.closeOnStart">Close Launcher
|
||||||
|
on game start</div>
|
||||||
|
<div class="checkbox-description"
|
||||||
|
data-i18n="settings.closeOnStartDescription">
|
||||||
|
Automatically close the launcher after Hytale has launched
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="settings-option">
|
||||||
|
<label class="settings-checkbox">
|
||||||
|
<input type="checkbox" id="launcherHwAccelCheck" />
|
||||||
|
<span class="checkmark"></span>
|
||||||
|
<div class="checkbox-content">
|
||||||
|
<div class="checkbox-title" data-i18n="settings.hwAccel">Launcher Hardware
|
||||||
|
Acceleration</div>
|
||||||
|
<div class="checkbox-description" data-i18n="settings.hwAccelDescription">
|
||||||
|
Enable hardware acceleration for the launcher UI (Requires restart)
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="settings-section">
|
||||||
|
<h3 class="settings-section-title">
|
||||||
|
<i class="fas fa-coffee"></i>
|
||||||
|
<span data-i18n="settings.java">Java Runtime</span>
|
||||||
|
</h3>
|
||||||
|
|
||||||
|
<div class="settings-option">
|
||||||
|
<label class="settings-checkbox">
|
||||||
|
<input type="checkbox" id="customJavaCheck" />
|
||||||
|
<span class="checkmark"></span>
|
||||||
|
<div class="checkbox-content">
|
||||||
|
<div class="checkbox-title" data-i18n="settings.useCustomJava">Use
|
||||||
|
Custom Java Path</div>
|
||||||
|
<div class="checkbox-description" data-i18n="settings.javaDescription">
|
||||||
|
Override the bundled Java runtime with
|
||||||
|
your own installation</div>
|
||||||
|
</div>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="customJavaOptions" class="custom-java-options" style="display: none;">
|
||||||
|
<div class="settings-input-group">
|
||||||
|
<label class="settings-input-label" data-i18n="settings.javaPath">Java
|
||||||
|
Executable Path</label>
|
||||||
|
<div class="settings-input-with-button">
|
||||||
|
<input type="text" id="customJavaPath" class="settings-input"
|
||||||
|
data-i18n-placeholder="settings.javaPathPlaceholder" readonly />
|
||||||
|
<button id="browseJavaBtn" class="settings-browse-btn">
|
||||||
|
<i class="fas fa-folder-open"></i>
|
||||||
|
<span data-i18n="settings.javaBrowse">Browse</span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<p class="settings-hint">
|
||||||
|
<i class="fas fa-info-circle"></i>
|
||||||
|
<span data-i18n="settings.javaHint">Select the Java installation folder
|
||||||
|
(supports Windows, Mac, Linux)</span>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="settings-section">
|
||||||
|
<h3 class="settings-section-title">
|
||||||
|
<i class="fas fa-language"></i>
|
||||||
|
<span data-i18n="settings.language">Language</span>
|
||||||
|
</h3>
|
||||||
|
|
||||||
|
<div class="settings-option">
|
||||||
|
<div class="settings-input-group">
|
||||||
|
<label class="settings-input-label" data-i18n="settings.selectLanguage">Select
|
||||||
|
Language</label>
|
||||||
|
<select id="languageSelect" class="settings-input">
|
||||||
|
<!-- Options populated by i18n.js -->
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div id="logs-page" class="page">
|
||||||
|
<div class="logs-container">
|
||||||
|
<div class="logs-header">
|
||||||
|
<h2 class="logs-title">
|
||||||
|
<i class="fas fa-terminal"></i>
|
||||||
|
<span data-i18n="settings.logs">SYSTEM LOGS</span>
|
||||||
|
</h2>
|
||||||
|
<div class="logs-actions">
|
||||||
|
<button class="logs-action-btn" onclick="copyLogs()">
|
||||||
|
<i class="fas fa-copy"></i> <span data-i18n="settings.logsCopy">Copy</span>
|
||||||
|
</button>
|
||||||
|
<button class="logs-action-btn" onclick="refreshLogs()">
|
||||||
|
<i class="fas fa-sync-alt"></i> <span
|
||||||
|
data-i18n="settings.logsRefresh">Refresh</span>
|
||||||
|
</button>
|
||||||
|
<button class="logs-action-btn" onclick="openLogsFolder()">
|
||||||
|
<i class="fas fa-folder-open"></i> <span data-i18n="settings.logsFolder">Open
|
||||||
|
Folder</span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="logsTerminal" class="logs-terminal">
|
||||||
|
<div class="text-gray-500 text-center mt-10" data-i18n="settings.logsLoading">Loading
|
||||||
|
logs...</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</main>
|
</main>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -602,7 +626,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="progressOverlay" class="progress-overlay" style="display: none;">
|
<div id="progressOverlay" class="progress-overlay" style="display: none;">
|
||||||
<div class="progress-content">
|
<div class="progress-content">
|
||||||
<div class="progress-info">
|
<div class="progress-info">
|
||||||
<span id="progressText" data-i18n="progress.initializing">Initializing...</span>
|
<span id="progressText" data-i18n="progress.initializing">Initializing...</span>
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ let browseJavaBtn;
|
|||||||
let settingsPlayerName;
|
let settingsPlayerName;
|
||||||
let discordRPCCheck;
|
let discordRPCCheck;
|
||||||
let closeLauncherCheck;
|
let closeLauncherCheck;
|
||||||
|
let launcherHwAccelCheck;
|
||||||
let gpuPreferenceRadios;
|
let gpuPreferenceRadios;
|
||||||
let gameBranchRadios;
|
let gameBranchRadios;
|
||||||
|
|
||||||
@@ -165,6 +166,7 @@ function setupSettingsElements() {
|
|||||||
settingsPlayerName = document.getElementById('settingsPlayerName');
|
settingsPlayerName = document.getElementById('settingsPlayerName');
|
||||||
discordRPCCheck = document.getElementById('discordRPCCheck');
|
discordRPCCheck = document.getElementById('discordRPCCheck');
|
||||||
closeLauncherCheck = document.getElementById('closeLauncherCheck');
|
closeLauncherCheck = document.getElementById('closeLauncherCheck');
|
||||||
|
launcherHwAccelCheck = document.getElementById('launcherHwAccelCheck');
|
||||||
gpuPreferenceRadios = document.querySelectorAll('input[name="gpuPreference"]');
|
gpuPreferenceRadios = document.querySelectorAll('input[name="gpuPreference"]');
|
||||||
gameBranchRadios = document.querySelectorAll('input[name="gameBranch"]');
|
gameBranchRadios = document.querySelectorAll('input[name="gameBranch"]');
|
||||||
|
|
||||||
@@ -206,6 +208,10 @@ function setupSettingsElements() {
|
|||||||
closeLauncherCheck.addEventListener('change', saveCloseLauncher);
|
closeLauncherCheck.addEventListener('change', saveCloseLauncher);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (launcherHwAccelCheck) {
|
||||||
|
launcherHwAccelCheck.addEventListener('change', saveLauncherHwAccel);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// UUID event listeners
|
// UUID event listeners
|
||||||
if (copyUuidBtn) {
|
if (copyUuidBtn) {
|
||||||
@@ -391,6 +397,35 @@ async function loadCloseLauncher() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function saveLauncherHwAccel() {
|
||||||
|
try {
|
||||||
|
if (window.electronAPI && window.electronAPI.saveLauncherHardwareAcceleration && launcherHwAccelCheck) {
|
||||||
|
const enabled = launcherHwAccelCheck.checked;
|
||||||
|
await window.electronAPI.saveLauncherHardwareAcceleration(enabled);
|
||||||
|
|
||||||
|
const msg = window.i18n ? window.i18n.t('notifications.hwAccelSaved') : 'Setting saved. Please restart the launcher to apply changes.';
|
||||||
|
showNotification(msg, 'success');
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error saving hardware acceleration setting:', error);
|
||||||
|
const msg = window.i18n ? window.i18n.t('notifications.hwAccelSaveFailed') : 'Failed to save setting';
|
||||||
|
showNotification(msg, 'error');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function loadLauncherHwAccel() {
|
||||||
|
try {
|
||||||
|
if (window.electronAPI && window.electronAPI.loadLauncherHardwareAcceleration) {
|
||||||
|
const enabled = await window.electronAPI.loadLauncherHardwareAcceleration();
|
||||||
|
if (launcherHwAccelCheck) {
|
||||||
|
launcherHwAccelCheck.checked = enabled;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error loading hardware acceleration setting:', error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
async function savePlayerName() {
|
async function savePlayerName() {
|
||||||
try {
|
try {
|
||||||
@@ -507,6 +542,7 @@ async function loadAllSettings() {
|
|||||||
await loadCurrentUuid();
|
await loadCurrentUuid();
|
||||||
await loadDiscordRPC();
|
await loadDiscordRPC();
|
||||||
await loadCloseLauncher();
|
await loadCloseLauncher();
|
||||||
|
await loadLauncherHwAccel();
|
||||||
await loadGpuPreference();
|
await loadGpuPreference();
|
||||||
await loadVersionBranch();
|
await loadVersionBranch();
|
||||||
}
|
}
|
||||||
@@ -767,33 +803,33 @@ async function setCustomUuid() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function performSetCustomUuid(uuid) {
|
async function performSetCustomUuid(uuid) {
|
||||||
try {
|
try {
|
||||||
if (window.electronAPI && window.electronAPI.setUuidForUser) {
|
if (window.electronAPI && window.electronAPI.setUuidForUser) {
|
||||||
const username = getCurrentPlayerName();
|
const username = getCurrentPlayerName();
|
||||||
const result = await window.electronAPI.setUuidForUser(username, uuid);
|
const result = await window.electronAPI.setUuidForUser(username, uuid);
|
||||||
|
|
||||||
if (result.success) {
|
if (result.success) {
|
||||||
if (currentUuidDisplay) currentUuidDisplay.value = uuid;
|
if (currentUuidDisplay) currentUuidDisplay.value = uuid;
|
||||||
if (modalCurrentUuid) modalCurrentUuid.value = uuid;
|
if (modalCurrentUuid) modalCurrentUuid.value = uuid;
|
||||||
if (customUuidInput) customUuidInput.value = '';
|
if (customUuidInput) customUuidInput.value = '';
|
||||||
|
|
||||||
const msg = window.i18n ? window.i18n.t('notifications.uuidSetSuccess') : 'Custom UUID set successfully!';
|
const msg = window.i18n ? window.i18n.t('notifications.uuidSetSuccess') : 'Custom UUID set successfully!';
|
||||||
showNotification(msg, 'success');
|
showNotification(msg, 'success');
|
||||||
|
|
||||||
await loadAllUuids();
|
await loadAllUuids();
|
||||||
} else {
|
} else {
|
||||||
throw new Error(result.error || 'Failed to set custom UUID');
|
throw new Error(result.error || 'Failed to set custom UUID');
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} catch (error) {
|
|
||||||
console.error('Error setting custom UUID:', error);
|
|
||||||
const msg = window.i18n ? window.i18n.t('notifications.uuidSetFailed').replace('{error}', error.message) : `Failed to set custom UUID: ${error.message}`;
|
|
||||||
showNotification(msg, 'error');
|
|
||||||
}
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error setting custom UUID:', error);
|
||||||
|
const msg = window.i18n ? window.i18n.t('notifications.uuidSetFailed').replace('{error}', error.message) : `Failed to set custom UUID: ${error.message}`;
|
||||||
|
showNotification(msg, 'error');
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
window.copyUuid = async function(uuid) {
|
window.copyUuid = async function (uuid) {
|
||||||
try {
|
try {
|
||||||
if (navigator.clipboard) {
|
if (navigator.clipboard) {
|
||||||
await navigator.clipboard.writeText(uuid);
|
await navigator.clipboard.writeText(uuid);
|
||||||
@@ -807,7 +843,7 @@ window.copyUuid = async function(uuid) {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
window.deleteUuid = async function(username) {
|
window.deleteUuid = async function (username) {
|
||||||
try {
|
try {
|
||||||
const message = window.i18n ? window.i18n.t('confirm.deleteUuidMessage').replace('{username}', username) : `Are you sure you want to delete the UUID for "${username}"? This action cannot be undone.`;
|
const message = window.i18n ? window.i18n.t('confirm.deleteUuidMessage').replace('{username}', username) : `Are you sure you want to delete the UUID for "${username}"? This action cannot be undone.`;
|
||||||
const title = window.i18n ? window.i18n.t('confirm.deleteUuidTitle') : 'Delete UUID';
|
const title = window.i18n ? window.i18n.t('confirm.deleteUuidTitle') : 'Delete UUID';
|
||||||
@@ -834,21 +870,21 @@ window.deleteUuid = async function(username) {
|
|||||||
async function performDeleteUuid(username) {
|
async function performDeleteUuid(username) {
|
||||||
try {
|
try {
|
||||||
if (window.electronAPI && window.electronAPI.deleteUuidForUser) {
|
if (window.electronAPI && window.electronAPI.deleteUuidForUser) {
|
||||||
const result = await window.electronAPI.deleteUuidForUser(username);
|
const result = await window.electronAPI.deleteUuidForUser(username);
|
||||||
|
|
||||||
if (result.success) {
|
if (result.success) {
|
||||||
const msg = window.i18n ? window.i18n.t('notifications.uuidDeleteSuccess') : 'UUID deleted successfully!';
|
const msg = window.i18n ? window.i18n.t('notifications.uuidDeleteSuccess') : 'UUID deleted successfully!';
|
||||||
showNotification(msg, 'success');
|
showNotification(msg, 'success');
|
||||||
await loadAllUuids();
|
await loadAllUuids();
|
||||||
} else {
|
} else {
|
||||||
throw new Error(result.error || 'Failed to delete UUID');
|
throw new Error(result.error || 'Failed to delete UUID');
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} catch (error) {
|
|
||||||
console.error('Error deleting UUID:', error);
|
|
||||||
const msg = window.i18n ? window.i18n.t('notifications.uuidDeleteFailed').replace('{error}', error.message) : `Failed to delete UUID: ${error.message}`;
|
|
||||||
showNotification(msg, 'error');
|
|
||||||
}
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error deleting UUID:', error);
|
||||||
|
const msg = window.i18n ? window.i18n.t('notifications.uuidDeleteFailed').replace('{error}', error.message) : `Failed to delete UUID: ${error.message}`;
|
||||||
|
showNotification(msg, 'error');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function escapeHtml(text) {
|
function escapeHtml(text) {
|
||||||
|
|||||||
@@ -131,6 +131,8 @@
|
|||||||
"closeLauncher": "Launcher Behavior",
|
"closeLauncher": "Launcher Behavior",
|
||||||
"closeOnStart": "Close Launcher on game start",
|
"closeOnStart": "Close Launcher on game start",
|
||||||
"closeOnStartDescription": "Automatically close the launcher after Hytale has launched",
|
"closeOnStartDescription": "Automatically close the launcher after Hytale has launched",
|
||||||
|
"hwAccel": "Hardware Acceleration",
|
||||||
|
"hwAccelDescription": "Enable hardware acceleration for the launcher",
|
||||||
"gameBranch": "Game Branch",
|
"gameBranch": "Game Branch",
|
||||||
"branchRelease": "Release",
|
"branchRelease": "Release",
|
||||||
"branchPreRelease": "Pre-Release",
|
"branchPreRelease": "Pre-Release",
|
||||||
@@ -207,7 +209,9 @@
|
|||||||
"modsDownloadFailed": "Failed to download mod: {error}",
|
"modsDownloadFailed": "Failed to download mod: {error}",
|
||||||
"modsToggleFailed": "Failed to toggle mod: {error}",
|
"modsToggleFailed": "Failed to toggle mod: {error}",
|
||||||
"modsDeleteFailed": "Failed to delete mod: {error}",
|
"modsDeleteFailed": "Failed to delete mod: {error}",
|
||||||
"modsModNotFound": "Mod information not found"
|
"modsModNotFound": "Mod information not found",
|
||||||
|
"hwAccelSaved": "Hardware acceleration setting saved",
|
||||||
|
"hwAccelSaveFailed": "Failed to save hardware acceleration setting"
|
||||||
},
|
},
|
||||||
"confirm": {
|
"confirm": {
|
||||||
"defaultTitle": "Confirm action",
|
"defaultTitle": "Confirm action",
|
||||||
|
|||||||
@@ -166,13 +166,22 @@ function loadCloseLauncherOnStart() {
|
|||||||
return config.closeLauncherOnStart !== undefined ? config.closeLauncherOnStart : false;
|
return config.closeLauncherOnStart !== undefined ? config.closeLauncherOnStart : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function saveLauncherHardwareAcceleration(enabled) {
|
||||||
|
saveConfig({ launcherHardwareAcceleration: !!enabled });
|
||||||
|
}
|
||||||
|
|
||||||
|
function loadLauncherHardwareAcceleration() {
|
||||||
|
const config = loadConfig();
|
||||||
|
return config.launcherHardwareAcceleration !== undefined ? config.launcherHardwareAcceleration : true;
|
||||||
|
}
|
||||||
|
|
||||||
function saveModsToConfig(mods) {
|
function saveModsToConfig(mods) {
|
||||||
try {
|
try {
|
||||||
const config = loadConfig();
|
const config = loadConfig();
|
||||||
|
|
||||||
// Config migration handles structure, but mod saves must go to the ACTIVE profile.
|
// Config migration handles structure, but mod saves must go to the ACTIVE profile.
|
||||||
// Global installedMods is kept mainly for reference/migration.
|
// Global installedMods is kept mainly for reference/migration.
|
||||||
// The profile is the source of truth for enabled mods.
|
// The profile is the source of truth for enabled mods.
|
||||||
|
|
||||||
|
|
||||||
if (config.activeProfileId && config.profiles && config.profiles[config.activeProfileId]) {
|
if (config.activeProfileId && config.profiles && config.profiles[config.activeProfileId]) {
|
||||||
@@ -369,6 +378,11 @@ module.exports = {
|
|||||||
// Close Launcher export
|
// Close Launcher export
|
||||||
saveCloseLauncherOnStart,
|
saveCloseLauncherOnStart,
|
||||||
loadCloseLauncherOnStart,
|
loadCloseLauncherOnStart,
|
||||||
|
|
||||||
|
// Hardware Acceleration functions
|
||||||
|
saveLauncherHardwareAcceleration,
|
||||||
|
loadLauncherHardwareAcceleration,
|
||||||
|
|
||||||
// Version Management exports
|
// Version Management exports
|
||||||
saveVersionClient,
|
saveVersionClient,
|
||||||
loadVersionClient,
|
loadVersionClient,
|
||||||
|
|||||||
@@ -19,6 +19,12 @@ const {
|
|||||||
loadLanguage,
|
loadLanguage,
|
||||||
saveCloseLauncherOnStart,
|
saveCloseLauncherOnStart,
|
||||||
loadCloseLauncherOnStart,
|
loadCloseLauncherOnStart,
|
||||||
|
|
||||||
|
// Hardware Acceleration
|
||||||
|
saveLauncherHardwareAcceleration,
|
||||||
|
loadLauncherHardwareAcceleration,
|
||||||
|
|
||||||
|
|
||||||
saveModsToConfig,
|
saveModsToConfig,
|
||||||
loadModsFromConfig,
|
loadModsFromConfig,
|
||||||
getUuidForUser,
|
getUuidForUser,
|
||||||
@@ -134,6 +140,10 @@ module.exports = {
|
|||||||
saveCloseLauncherOnStart,
|
saveCloseLauncherOnStart,
|
||||||
loadCloseLauncherOnStart,
|
loadCloseLauncherOnStart,
|
||||||
|
|
||||||
|
// Hardware Acceleration functions
|
||||||
|
saveLauncherHardwareAcceleration,
|
||||||
|
loadLauncherHardwareAcceleration,
|
||||||
|
|
||||||
// GPU Preference functions
|
// GPU Preference functions
|
||||||
saveGpuPreference,
|
saveGpuPreference,
|
||||||
loadGpuPreference,
|
loadGpuPreference,
|
||||||
|
|||||||
26
main.js
26
main.js
@@ -3,9 +3,20 @@ require('dotenv').config({ path: path.join(__dirname, '.env') });
|
|||||||
const { app, BrowserWindow, ipcMain, dialog, shell } = require('electron');
|
const { app, BrowserWindow, ipcMain, dialog, shell } = require('electron');
|
||||||
const { autoUpdater } = require('electron-updater');
|
const { autoUpdater } = require('electron-updater');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const { launchGame, launchGameWithVersionCheck, installGame, saveUsername, loadUsername, saveChatUsername, loadChatUsername, saveChatColor, loadChatColor, saveJavaPath, loadJavaPath, saveInstallPath, loadInstallPath, saveDiscordRPC, loadDiscordRPC, saveLanguage, loadLanguage, saveCloseLauncherOnStart, loadCloseLauncherOnStart, isGameInstalled, uninstallGame, repairGame, getHytaleNews, handleFirstLaunchCheck, proposeGameUpdate, markAsLaunched } = require('./backend/launcher');
|
const { launchGame, launchGameWithVersionCheck, installGame, saveUsername, loadUsername, saveChatUsername, loadChatUsername, saveChatColor, loadChatColor, saveJavaPath, loadJavaPath, saveInstallPath, loadInstallPath, saveDiscordRPC, loadDiscordRPC, saveLanguage, loadLanguage, saveCloseLauncherOnStart, loadCloseLauncherOnStart, saveLauncherHardwareAcceleration, loadLauncherHardwareAcceleration, isGameInstalled, uninstallGame, repairGame, getHytaleNews, handleFirstLaunchCheck, proposeGameUpdate, markAsLaunched } = require('./backend/launcher');
|
||||||
const { retryPWRDownload } = require('./backend/managers/gameManager');
|
const { retryPWRDownload } = require('./backend/managers/gameManager');
|
||||||
|
|
||||||
|
// Handle Hardware Acceleration
|
||||||
|
try {
|
||||||
|
const hwEnabled = loadLauncherHardwareAcceleration();
|
||||||
|
if (!hwEnabled) {
|
||||||
|
console.log('Hardware acceleration disabled by user setting');
|
||||||
|
app.disableHardwareAcceleration();
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Failed to load hardware acceleration setting:', error);
|
||||||
|
}
|
||||||
|
|
||||||
const logger = require('./backend/logger');
|
const logger = require('./backend/logger');
|
||||||
const profileManager = require('./backend/managers/profileManager');
|
const profileManager = require('./backend/managers/profileManager');
|
||||||
|
|
||||||
@@ -241,8 +252,8 @@ function createWindow() {
|
|||||||
// Close application shortcuts
|
// Close application shortcuts
|
||||||
const isMac = process.platform === 'darwin';
|
const isMac = process.platform === 'darwin';
|
||||||
const quitShortcut = (isMac && input.meta && input.key.toLowerCase() === 'q') ||
|
const quitShortcut = (isMac && input.meta && input.key.toLowerCase() === 'q') ||
|
||||||
(!isMac && input.control && input.key.toLowerCase() === 'q') ||
|
(!isMac && input.control && input.key.toLowerCase() === 'q') ||
|
||||||
(!isMac && input.alt && input.key === 'F4');
|
(!isMac && input.alt && input.key === 'F4');
|
||||||
|
|
||||||
if (quitShortcut) {
|
if (quitShortcut) {
|
||||||
app.quit();
|
app.quit();
|
||||||
@@ -632,6 +643,15 @@ ipcMain.handle('load-close-launcher', () => {
|
|||||||
return loadCloseLauncherOnStart();
|
return loadCloseLauncherOnStart();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
ipcMain.handle('save-launcher-hw-accel', (event, enabled) => {
|
||||||
|
saveLauncherHardwareAcceleration(enabled);
|
||||||
|
return { success: true };
|
||||||
|
});
|
||||||
|
|
||||||
|
ipcMain.handle('load-launcher-hw-accel', () => {
|
||||||
|
return loadLauncherHardwareAcceleration();
|
||||||
|
});
|
||||||
|
|
||||||
ipcMain.handle('select-install-path', async () => {
|
ipcMain.handle('select-install-path', async () => {
|
||||||
|
|
||||||
const result = await dialog.showOpenDialog(mainWindow, {
|
const result = await dialog.showOpenDialog(mainWindow, {
|
||||||
|
|||||||
@@ -23,6 +23,11 @@ contextBridge.exposeInMainWorld('electronAPI', {
|
|||||||
loadLanguage: () => ipcRenderer.invoke('load-language'),
|
loadLanguage: () => ipcRenderer.invoke('load-language'),
|
||||||
saveCloseLauncher: (enabled) => ipcRenderer.invoke('save-close-launcher', enabled),
|
saveCloseLauncher: (enabled) => ipcRenderer.invoke('save-close-launcher', enabled),
|
||||||
loadCloseLauncher: () => ipcRenderer.invoke('load-close-launcher'),
|
loadCloseLauncher: () => ipcRenderer.invoke('load-close-launcher'),
|
||||||
|
|
||||||
|
// Harwadre Acceleration
|
||||||
|
saveLauncherHardwareAcceleration: (enabled) => ipcRenderer.invoke('save-launcher-hw-accel', enabled),
|
||||||
|
loadLauncherHardwareAcceleration: () => ipcRenderer.invoke('load-launcher-hw-accel'),
|
||||||
|
|
||||||
selectInstallPath: () => ipcRenderer.invoke('select-install-path'),
|
selectInstallPath: () => ipcRenderer.invoke('select-install-path'),
|
||||||
browseJavaPath: () => ipcRenderer.invoke('browse-java-path'),
|
browseJavaPath: () => ipcRenderer.invoke('browse-java-path'),
|
||||||
isGameInstalled: () => ipcRenderer.invoke('is-game-installed'),
|
isGameInstalled: () => ipcRenderer.invoke('is-game-installed'),
|
||||||
|
|||||||
Reference in New Issue
Block a user