diff --git a/Launcher/build.gradle b/Launcher/build.gradle index a1d73860..8c40adc7 100644 --- a/Launcher/build.gradle +++ b/Launcher/build.gradle @@ -39,7 +39,6 @@ dependencies { pack project(':LauncherAuthlib') bundle 'com.github.oshi:oshi-core:3.13.0' - bundle 'de.jensd:fontawesomefx:8.9' bundle 'org.apache.httpcomponents:httpclient:4.5.7' pack 'io.netty:netty-codec-http:4.1.36.Final' pack 'org.ow2.asm:asm-tree:7.1' diff --git a/Launcher/runtime/config.js b/Launcher/runtime/config.js index c5fa5bc1..d6433511 100644 --- a/Launcher/runtime/config.js +++ b/Launcher/runtime/config.js @@ -2,7 +2,7 @@ var config = { dir: "GravitLauncher", // Launcher directory title: "GravitLauncher", // Window title - icons: [ "favicon.png" ], // Window icon paths + icons: ["favicon.png"], // Window icon paths // Auth config linkText: "GravitLauncher", // Text for link under "Auth" button diff --git a/Launcher/runtime/dialog/dialog.js b/Launcher/runtime/dialog/dialog.js index 1c23beb4..1173456b 100644 --- a/Launcher/runtime/dialog/dialog.js +++ b/Launcher/runtime/dialog/dialog.js @@ -24,9 +24,9 @@ function initLauncher() { /* ======== init Login window======== */ function initLoginScene() { - loginPane.setOnMousePressed(function(event){ movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY())}); + loginPane.setOnMousePressed(function(event) { movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY()) }); loginPane.setOnMouseDragged(function(event) { - if(movePoint === null) { + if (movePoint === null) { return; } stage.setX(event.getScreenX() - movePoint.getX()); @@ -35,9 +35,9 @@ function initLoginScene() { var pane = loginPane.lookup("#bar"); bar = pane; - loginPane.lookup("#close").setOnAction(function(event){ javafx.application.Platform.exit()}); - loginPane.lookup("#hide").setOnAction(function(event){ stage.setIconified(true)}); - loginPane.lookup("#discord").setOnAction(function(){ openURL(config.discord); }); + loginPane.lookup("#close").setOnAction(function(event) { javafx.application.Platform.exit() }); + loginPane.lookup("#hide").setOnAction(function(event) { stage.setIconified(true) }); + loginPane.lookup("#discord").setOnAction(function() { openURL(config.discord); }); var pane = loginPane.lookup("#authPane"); authPane = pane; @@ -46,14 +46,14 @@ function initLoginScene() { loginPaneLayout = loginLayout; loginField = pane.lookup("#login"); - loginField.setOnMouseMoved(function(event){rootPane.fireEvent(event)}); + loginField.setOnMouseMoved(function(event) { rootPane.fireEvent(event) }); loginField.setOnAction(goAuth); if (settings.login !== null) { loginField.setText(settings.login); } passwordField = pane.lookup("#password"); - passwordField.setOnMouseMoved(function(event){rootPane.fireEvent(event)}); + passwordField.setOnMouseMoved(function(event) { rootPane.fireEvent(event) }); passwordField.setOnAction(goAuth); if (settings.rsaPassword !== null) { passwordField.getStyleClass().add("hasSaved"); @@ -74,9 +74,9 @@ function initLoginScene() { /* ======== init Menu window======== */ function initMenuScene() { - menuPane.setOnMousePressed(function(event){ movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY())}); + menuPane.setOnMousePressed(function(event) { movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY()) }); menuPane.setOnMouseDragged(function(event) { - if(movePoint === null) { + if (movePoint === null) { return; } @@ -86,9 +86,9 @@ function initMenuScene() { var pane = menuPane.lookup("#bar"); bar = pane; - pane.lookup("#close").setOnAction(function(event){ javafx.application.Platform.exit()}); - pane.lookup("#hide").setOnAction(function(event){ stage.setIconified(true)}); - pane.lookup("#discord").setOnAction(function(){ openURL(config.discord); }); + pane.lookup("#close").setOnAction(function(event) { javafx.application.Platform.exit() }); + pane.lookup("#hide").setOnAction(function(event) { stage.setIconified(true) }); + pane.lookup("#discord").setOnAction(function() { openURL(config.discord); }); pane.lookup("#settings").setOnAction(goSettings); pane.lookup("#goConsole").setOnAction(goConsole); @@ -105,10 +105,10 @@ function initMenuScene() { serverEntrance = pane.lookup("#serverentrance"); serverStatus = serverEntrance.lookup("#serverStatus"); serverLabel = serverEntrance.lookup("#serverLabel"); - serverEntrance.lookup("#clientLaunch").setOnAction(function(){ + serverEntrance.lookup("#clientLaunch").setOnAction(function() { doUpdate(profilesList[serverHolder.old], loginData.pp, loginData.accessToken); }); - pane.lookup("#logout").setOnAction(function(){ + pane.lookup("#logout").setOnAction(function() { setCurrentScene(loginScene); }); @@ -116,9 +116,9 @@ function initMenuScene() { /* ======== init Console window======== */ function initConsoleScene() { - consoleMenu.setOnMousePressed(function(event){ movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY())}); + consoleMenu.setOnMousePressed(function(event) { movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY()) }); consoleMenu.setOnMouseDragged(function(event) { - if(movePoint === null) { + if (movePoint === null) { return; } @@ -128,21 +128,21 @@ function initConsoleScene() { var pane = consoleMenu.lookup("#bar"); consoleBar = pane; - pane.lookup("#close").setOnAction(function(){ + pane.lookup("#close").setOnAction(function() { consoleStage.hide(); }); var text = consoleMenu.lookup("#textField"); var output = consoleMenu.lookup("#output"); var appendFunction = function(line) javafx.application.Platform.runLater(function() output.appendText(line)); - consoleMenu.lookup("#send").setOnAction(function(){ + consoleMenu.lookup("#send").setOnAction(function() { execCommand(text.getText()); - if (text.getText() == "clear") { - output.setText(""); - } + if (text.getText() == "clear") { + output.setText(""); + } text.setText(""); }); FunctionalBridge.addPlainOutput(function(string) { - appendFunction(string+"\n"); + appendFunction(string + "\n"); }) pane.lookup("#hide").setOnAction(function(event) { consoleStage.setIconified(true) }); @@ -153,9 +153,9 @@ function initConsoleScene() { /* ======== init Options window======== */ function initOptionsScene() { - optionsMenu.setOnMousePressed(function(event){ movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY())}); + optionsMenu.setOnMousePressed(function(event) { movePoint = new javafx.geometry.Point2D(event.getSceneX(), event.getSceneY()) }); optionsMenu.setOnMouseDragged(function(event) { - if(movePoint === null) { + if (movePoint === null) { return; } @@ -165,9 +165,9 @@ function initOptionsScene() { var pane = optionsMenu.lookup("#bar"); bar = pane; - pane.lookup("#close").setOnAction(function(event){ javafx.application.Platform.exit()}); - pane.lookup("#hide").setOnAction(function(event){ stage.setIconified(true)}); - pane.lookup("#back").setOnAction(function(){ + pane.lookup("#close").setOnAction(function(event) { javafx.application.Platform.exit() }); + pane.lookup("#hide").setOnAction(function(event) { stage.setIconified(true) }); + pane.lookup("#back").setOnAction(function() { setCurrentScene(menuScene); }); } @@ -202,29 +202,29 @@ function goAuth(event) { return; // No auth selected } - var rsaPassword = null; - var auth = authOptions.getSelectionModel().getSelectedItem(); - if (auth === null) { + var rsaPassword = null; + var auth = authOptions.getSelectionModel().getSelectedItem(); + if (auth === null) { return; - } - if (!passwordField.isDisable()) { - var password = passwordField.getText(); - if (password !== null && !password.isEmpty()) { - rsaPassword = settingsOverlay.setPassword(password); - } else if (settings.rsaPassword !== null) { - rsaPassword = settings.rsaPassword; - } else { - return; - } + } + if (!passwordField.isDisable()) { + var password = passwordField.getText(); + if (password !== null && !password.isEmpty()) { + rsaPassword = settingsOverlay.setPassword(password); + } else if (settings.rsaPassword !== null) { + rsaPassword = settings.rsaPassword; + } else { + return; + } - settings.rsaPassword = savePasswordBox.isSelected() ? rsaPassword : null; - } + settings.rsaPassword = savePasswordBox.isSelected() ? rsaPassword : null; + } - settings.login = login; - doAuth(login, rsaPassword, authTypes[auth]); - } + settings.login = login; + doAuth(login, rsaPassword, authTypes[auth]); +} - /* ======== Console ======== */ +/* ======== Console ======== */ function goConsole(event) { setConsoleCurrentScene(consoleScene); } @@ -267,7 +267,7 @@ function verifyLauncher(e) { authOptions.getSelectionModel().select(0); var sm = authOptions.getSelectionModel().selectedIndexProperty(); sm.addListener(new javafx.beans.value.ChangeListener({ - changed: function (observableValue, oldSelection, newSelection) { + changed: function(observableValue, oldSelection, newSelection) { settings.auth = authTypes[authOptions.getSelectionModel().getSelectedItem()]; } })); @@ -287,14 +287,18 @@ function verifyLauncher(e) { function doAuth(login, rsaPassword, auth_type) { processing.resetOverlay(); - overlay.show(processing.overlay, function (event) { + overlay.show(processing.overlay, function(event) { FunctionalBridge.getHWID.join(); - makeAuthRequest(login, rsaPassword, auth_type, function (result) { + makeAuthRequest(login, rsaPassword, auth_type, function(result) { FunctionalBridge.setAuthParams(result); - loginData = { pp: result.playerProfile , accessToken: result.accessToken, permissions: result.permissions, - auth_type: settings.auth}; + loginData = { + pp: result.playerProfile, + accessToken: result.accessToken, + permissions: result.permissions, + auth_type: settings.auth + }; - overlay.hide(0, function () { + overlay.hide(0, function() { setCurrentScene(menuScene); }); return result; @@ -355,10 +359,8 @@ function doUpdate(profile, pp, accessToken) { function doLaunchClient(assetDir, assetHDir, clientDir, clientHDir, profile, pp, accessToken) { processing.resetOverlay(); - overlay.swap(0, processing.overlay, function(event) - launchClient(assetHDir, clientHDir, profile, new ClientLauncherParams(settings.lastDigest, - assetDir, clientDir, pp, accessToken, settings.autoEnter, settings.fullScreen, settings.ram, 0, 0), doDebugClient) -); + overlay.swap(0, processing.overlay, function(event) launchClient(assetHDir, clientHDir, profile, new ClientLauncherParams(settings.lastDigest, + assetDir, clientDir, pp, accessToken, settings.autoEnter, settings.fullScreen, settings.ram, 0, 0), doDebugClient)); } function doDebugClient(process) { @@ -398,10 +400,10 @@ function updateProfilesList(profiles) { if (profile.getOptional() != null) profile.updateOptionalGraph(); index++; }); - LogHelper.debug("Load selected %d profile",settings.profile); - if(profiles.length > 0) { - if(settings.profile >= profiles.length) - settings.profile = profiles.length-1; + LogHelper.debug("Load selected %d profile", settings.profile); + if (profiles.length > 0) { + if (settings.profile >= profiles.length) + settings.profile = profiles.length - 1; serverHolder.set(serverList.getChildren().get(settings.profile)); } } @@ -412,11 +414,11 @@ function pingServer(btn) { var task = newTask(function() pingers[profile].ping()); task.setOnSucceeded(function(event) { var result = task.getValue(); - if(btn==serverHolder.old){ + if (btn == serverHolder.old) { setServerStatus(java.lang.String.format("%d из %d", result.onlinePlayers, result.maxPlayers)); } }); - task.setOnFailed(function(event){ if(btn==serverHolder.old){setServerStatus("Недоступен")}}); + task.setOnFailed(function(event) { if (btn == serverHolder.old) { setServerStatus("Недоступен") } }); startTask(task); } @@ -482,7 +484,7 @@ var overlay = { fade(overlay.current, delay, 1.0, 0.0, function(event) { dimPane.requestFocus(); - if(overlay.current==null){ + if (overlay.current == null) { overlay.show(newOverlay, onFinished); return; } @@ -504,13 +506,13 @@ var overlay = { var serverHolder = { old: null, - set: function(btn){ + set: function(btn) { pingServer(btn); serverLabel.setText(profilesList[btn]); serverDescription.setText(profilesList[btn].info); btn.setSelected(true); btn.setDisable(true); - if(serverHolder.old!=null){ + if (serverHolder.old != null) { serverHolder.old.setSelected(false); serverHolder.old.setDisable(false); } @@ -527,4 +529,4 @@ launcher.loadScript("dialog/overlay/update/update.js"); /* ======== Scenes scripts ======== */ launcher.loadScript("dialog/scenes/options/options.js"); -launcher.loadScript("dialog/scenes/console/console.js"); +launcher.loadScript("dialog/scenes/console/console.js"); \ No newline at end of file diff --git a/Launcher/runtime/dialog/images/icons/back.png b/Launcher/runtime/dialog/images/icons/back.png new file mode 100644 index 00000000..9c261d9f Binary files /dev/null and b/Launcher/runtime/dialog/images/icons/back.png differ diff --git a/Launcher/runtime/dialog/images/icons/close.png b/Launcher/runtime/dialog/images/icons/close.png new file mode 100644 index 00000000..b3ddaa56 Binary files /dev/null and b/Launcher/runtime/dialog/images/icons/close.png differ diff --git a/Launcher/runtime/dialog/images/icons/console.png b/Launcher/runtime/dialog/images/icons/console.png new file mode 100644 index 00000000..4da168ba Binary files /dev/null and b/Launcher/runtime/dialog/images/icons/console.png differ diff --git a/Launcher/runtime/dialog/images/icons/discord.png b/Launcher/runtime/dialog/images/icons/discord.png new file mode 100644 index 00000000..f55666a5 Binary files /dev/null and b/Launcher/runtime/dialog/images/icons/discord.png differ diff --git a/Launcher/runtime/dialog/images/icons/hide.png b/Launcher/runtime/dialog/images/icons/hide.png new file mode 100644 index 00000000..4cccaf23 Binary files /dev/null and b/Launcher/runtime/dialog/images/icons/hide.png differ diff --git a/Launcher/runtime/dialog/images/icons/list.png b/Launcher/runtime/dialog/images/icons/list.png new file mode 100644 index 00000000..be11c6fb Binary files /dev/null and b/Launcher/runtime/dialog/images/icons/list.png differ diff --git a/Launcher/runtime/dialog/images/icons/settings.png b/Launcher/runtime/dialog/images/icons/settings.png new file mode 100644 index 00000000..2811cd09 Binary files /dev/null and b/Launcher/runtime/dialog/images/icons/settings.png differ diff --git a/Launcher/runtime/dialog/overlay/debug/debug.css b/Launcher/runtime/dialog/overlay/debug/debug.css index 85f6905f..61a3ffe1 100644 --- a/Launcher/runtime/dialog/overlay/debug/debug.css +++ b/Launcher/runtime/dialog/overlay/debug/debug.css @@ -4,23 +4,23 @@ Button { } /* Outputs */ -#overlay > #output, -#background > #output { +#overlay>#output, +#background>#output { -fx-background-color: white; -fx-background-radius: 0; -fx-font-family: monospace; -fx-font-size: 8pt; } -#overlay > #output .content, -#background > #output .content { +#overlay>#output .content, +#background>#output .content { -fx-background-color: white; -fx-background-radius: 0; } /* Close button */ -#overlay > #copy, -#overlay > #action.close { +#overlay>#copy, +#overlay>#action.close { -fx-background-radius: 0; -fx-text-fill: white; -fx-background-position: center; @@ -29,17 +29,17 @@ #overlay > #action.close { -fx-pref-height: 25px; } -#overlay > #copy:hover, -#overlay > #copy:focused, -#overlay > #action.close:hover, -#overlay > #action.close:focused, -#overlay > #copy:pressed, -#overlay > #action.close:pressed { +#overlay>#copy:hover, +#overlay>#copy:focused, +#overlay>#action.close:hover, +#overlay>#action.close:focused, +#overlay>#copy:pressed, +#overlay>#action.close:pressed { -fx-background-color: #1568ce; } /* Kill button */ -#overlay > #action.kill { +#overlay>#action.kill { -fx-background-radius: 0; -fx-text-fill: white; -fx-background-position: center; @@ -48,9 +48,10 @@ #overlay > #action.kill { -fx-pref-height: 25px; } -#overlay > #action.kill:hover, -#overlay > #action.kill:focused, -#overlay > #action.kill:pressed { +#overlay>#action.kill:hover, +#overlay>#action.kill:focused, +#overlay>#action.kill:pressed { -fx-background-color: #DB5252; } + /*-- DrLeonardo Design --*/ \ No newline at end of file diff --git a/Launcher/runtime/dialog/overlay/debug/debug.js b/Launcher/runtime/dialog/overlay/debug/debug.js index 389b2475..0f67fb54 100644 --- a/Launcher/runtime/dialog/overlay/debug/debug.js +++ b/Launcher/runtime/dialog/overlay/debug/debug.js @@ -1,10 +1,13 @@ var debug = { - overlay: null, output: null, action: null, process: null, + overlay: null, + output: null, + action: null, + process: null, initOverlay: function() { debug.overlay = loadFXML("dialog/overlay/debug/debug.fxml"); - debug.overlay.lookup("#version").setText( + debug.overlay.lookup("#version").setText( java.lang.String.format( "%s | Java %s x%s", FunctionalBridge.getLauncherVersion(), @@ -22,7 +25,7 @@ var debug = { content.putString(debug.output.getText()); javafx.scene.input.Clipboard.getSystemClipboard(). - setContent(content); + setContent(content); }); debug.action = debug.overlay.lookup("#action"); @@ -47,8 +50,7 @@ var debug = { append: function(text) { //Experimental Feature - if(debug.output.getText().length() > 32000 /* Max length */) - { + if (debug.output.getText().length() > 32000 /* Max length */ ) { debug.output.deleteText(0, text.length()); } debug.output.appendText(text); @@ -79,7 +81,7 @@ function debugProcess(process) { var reader = IOHelper.newReader(process.getInputStream(), java.nio.charset.Charset.defaultCharset()); var appendFunction = function(line) - javafx.application.Platform.runLater(function() debug.append(line)); + javafx.application.Platform.runLater(function() debug.append(line)); for (var length = reader.read(buffer); length >= 0; length = reader.read(buffer)) { appendFunction(new java.lang.String(buffer, 0, length)); } @@ -97,4 +99,4 @@ function debugProcess(process) { }); startTask(task); -} +} \ No newline at end of file diff --git a/Launcher/runtime/dialog/overlay/processing/processing.css b/Launcher/runtime/dialog/overlay/processing/processing.css index 39c74e65..dc405dc0 100644 --- a/Launcher/runtime/dialog/overlay/processing/processing.css +++ b/Launcher/runtime/dialog/overlay/processing/processing.css @@ -1,11 +1,12 @@ /*-- DrLeonardo Design --*/ -#overlay > #description { +#overlay>#description { -fx-font-size: 12pt; -fx-text-fill: #fff; -fx-wrap-text: true; } -#overlay > #description.error { +#overlay>#description.error { -fx-text-fill: red; } + /*-- DrLeonardo Design --*/ \ No newline at end of file diff --git a/Launcher/runtime/dialog/overlay/processing/processing.js b/Launcher/runtime/dialog/overlay/processing/processing.js index cfff7bc6..f80d6074 100644 --- a/Launcher/runtime/dialog/overlay/processing/processing.js +++ b/Launcher/runtime/dialog/overlay/processing/processing.js @@ -1,6 +1,9 @@ var processing = { - overlay: null, spinner: null, description: null, - processingImage: null, errorImage: null, + overlay: null, + spinner: null, + description: null, + processingImage: null, + errorImage: null, initOverlay: function() { processing.overlay = loadFXML("dialog/overlay/processing/processing.fxml"); @@ -69,6 +72,7 @@ function makeLauncherRequest(callback) { task.updateMessage("Обновление лаунчера"); startTask(task); } + function makeProfilesRequest(callback) { var task = newRequestTask(new ProfilesRequest()); @@ -83,6 +87,7 @@ function makeProfilesRequest(callback) { task.updateMessage("Обновление профилей"); startTask(task); } + function makeAuthAvailabilityRequest(callback) { var task = newRequestTask(new GetAvailabilityAuthRequest()); @@ -98,6 +103,7 @@ function makeAuthAvailabilityRequest(callback) { task.updateMessage("Обновление способов авторизации"); startTask(task); } + function makeSetProfileRequest(profile, callback) { var task = newRequestTask(new SetProfileRequest(profile)); @@ -128,4 +134,4 @@ function launchClient(assetHDir, clientHDir, profile, params, callback) { processing.setTaskProperties(task, callback, null, true); task.updateMessage("Запуск выбранного клиента"); startTask(task); -} +} \ No newline at end of file diff --git a/Launcher/runtime/dialog/overlay/settings/settings.css b/Launcher/runtime/dialog/overlay/settings/settings.css index 544826aa..0e18cf86 100644 --- a/Launcher/runtime/dialog/overlay/settings/settings.css +++ b/Launcher/runtime/dialog/overlay/settings/settings.css @@ -1,14 +1,19 @@ /*-- DrLeonardo Design --*/ + #holder { - -fx-background-color: #fff; + -fx-background-color: #fff; } -#holder > #transferDialog { + +#holder>#transferDialog { -fx-background-color: rgba(0, 0, 0, 0.5); -fx-pref-width: 694px; -fx-pref-height: 425px; } + + /* Labels */ -#holder > #settingsTitle { + +#holder>#settingsTitle { -fx-font-size: 14pt; -fx-alignment: baseline-center; } @@ -19,30 +24,35 @@ #holder #dirChange { -fx-font-weight: bold; } + /* RAM slider */ -#holder > #ramSlider > .track { + +#holder>#ramSlider>.track { -fx-background-color: #909090; } -#holder > #ramSlider > .thumb { +#holder>#ramSlider>.thumb { -fx-background-color: #5fd97a; } -#holder > #ramSlider > .colored-track { +#holder>#ramSlider>.colored-track { -fx-background-color: #5fd97a; } -#holder > #ramSlider > .animated-thumb { +#holder>#ramSlider>.animated-thumb { -fx-background-color: #5fd97a; } -#holder > #ramSlider > .slider-value { +#holder>#ramSlider>.slider-value { -fx-fill: white; -fx-stroke: white; } + /* Dir options */ -#holder > #deleteDir, #cancelTransfer { + +#holder>#deleteDir, +#cancelTransfer { -fx-background-radius: 0; -fx-text-fill: white; -fx-background-position: center; @@ -51,23 +61,26 @@ #holder > #deleteDir, #cancelTransfer { -fx-pref-height: 25px; } -#holder > #deleteDir:hover,#cancelTransfer:hover, -#holder > #deleteDir:focused,#cancelTransfer:focused { +#holder>#deleteDir:hover, +#cancelTransfer:hover, +#holder>#deleteDir:focused, +#cancelTransfer:focused { -fx-background-color: #DB5252; } -#holder > #changeDir { +#holder>#changeDir { -fx-background-color: transparent; -fx-text-fill: #909090; -fx-background-radius: 0; } -#holder > #changeDir:focused, -#holder > #changeDir:pressed { +#holder>#changeDir:focused, +#holder>#changeDir:pressed { -fx-font-weight: bold; } -#holder > #apply,#applyTransfer{ +#holder>#apply, +#applyTransfer { -fx-background-color: #5fd97a; -fx-background-radius: 0; -fx-text-fill: white; @@ -75,8 +88,13 @@ #holder > #apply,#applyTransfer{ -fx-pref-width: 150px; -fx-pref-height: 25px; } -#holder > #apply:hover,#applyTransfer:hover, -#holder > #apply:focused,#applyTransfer:focused{ + +#holder>#apply:hover, +#applyTransfer:hover, +#holder>#apply:focused, +#applyTransfer:focused { -fx-background-color: #75e18c; } + + /*-- DrLeonardo Design --*/ \ No newline at end of file diff --git a/Launcher/runtime/dialog/overlay/settings/settings.fxml b/Launcher/runtime/dialog/overlay/settings/settings.fxml index 6d8f24db..b58950e2 100644 --- a/Launcher/runtime/dialog/overlay/settings/settings.fxml +++ b/Launcher/runtime/dialog/overlay/settings/settings.fxml @@ -1,10 +1,11 @@ + - - + + @@ -13,16 +14,22 @@ - + - - - - - - + + + + + + + + + + + + @@ -44,8 +51,20 @@ - - + + + + + + + + + + diff --git a/Launcher/runtime/dialog/overlay/settings/settings.js b/Launcher/runtime/dialog/overlay/settings/settings.js index 17090929..514b5739 100644 --- a/Launcher/runtime/dialog/overlay/settings/settings.js +++ b/Launcher/runtime/dialog/overlay/settings/settings.js @@ -1,7 +1,13 @@ var settingsOverlay = { -/* ===================== OVERLAY ===================== */ - overlay: null, ramLabel: null, dirLabel: null, transferDialog: null, - deleteDirPressedAgain: false, count: 0, + /* ===================== OVERLAY ===================== */ + overlay: null, + ramLabel: null, + dirLabel: null, + transferDialog: null, + deleteDirPressedAgain: false, + count: 0, + descLabel: null, + description: null, initOverlay: function() { settingsOverlay.overlay = loadFXML("dialog/overlay/settings/settings.fxml"); @@ -12,10 +18,12 @@ var settingsOverlay = { autoEnterBox.setSelected(settings.autoEnter); autoEnterBox.selectedProperty()["addListener(javafx.beans.value.ChangeListener)"]( function(o, ov, nv) settings.autoEnter = nv); + autoEnterBox.setOnMouseEntered(function() { + settingsOverlay.updateDesc(autoEnterBox.getText(), "Включение авто-входа означает что вы сразу после загрузки клиента попадете на сервер"); + }); settingsOverlay.dirLabel = holder.lookup("#dirLabel"); - settingsOverlay.dirLabel.setOnAction(function(event) - app.getHostServices().showDocument(settings.updatesDir.toUri())); + settingsOverlay.dirLabel.setOnAction(function(event) app.getHostServices().showDocument(settings.updatesDir.toUri())); settingsOverlay.updateDirLabel(); settingsOverlay.transferDialog = holder.lookup("#transferDialog"); @@ -33,15 +41,24 @@ var settingsOverlay = { } }); + this.descLabel = holder.lookup("#descLabel"); + this.description = holder.lookup("#description"); + var featureStore = holder.lookup("#featureStore"); featureStore.setSelected(settings.featureStore); featureStore.selectedProperty()["addListener(javafx.beans.value.ChangeListener)"]( function(o, ov, nv) settings.featureStore = nv); + featureStore.setOnMouseEntered(function() { + settingsOverlay.updateDesc(featureStore.getText(), "Используется для экономии вашего трафика, аналогичные файлы будут скопированы с других игровых клиентов"); + }); var fullScreenBox = holder.lookup("#fullScreen"); fullScreenBox.setSelected(settings.fullScreen); fullScreenBox.selectedProperty()["addListener(javafx.beans.value.ChangeListener)"]( function(o, ov, nv) settings.fullScreen = nv); + fullScreenBox.setOnMouseEntered(function() { + settingsOverlay.updateDesc(fullScreenBox.getText(), "Включение данной функции позволяет запустить игру сразу в полноэкранном режиме"); + }); settingsOverlay.ramLabel = holder.lookup("#ramLabel"); settingsOverlay.updateRAMLabel(); @@ -70,31 +87,42 @@ var settingsOverlay = { settingsOverlay.deleteUpdatesDir(); settingsOverlay.deleteDirPressedAgain = false; - settingsOverlay.count = settingsOverlay.count+1; - if(settingsOverlay.count>9){ - javafx.application.Platform.exit(); - } + settingsOverlay.count = settingsOverlay.count + 1; + if (settingsOverlay.count > 9) { + javafx.application.Platform.exit(); + } deleteDirButton.setText( - settingsOverlay.count>8?"Прощай :(": - (settingsOverlay.count>7?"Я умираю!": - (settingsOverlay.count>5?"DeathCry, спаси!": - (settingsOverlay.count>4?"Умоляю, перестань!": - (settingsOverlay.count>3?"Да хорош уже!":"Ещё раз") - )))); + settingsOverlay.count > 8 ? "Прощай :(" : + (settingsOverlay.count > 7 ? "Я умираю!" : + (settingsOverlay.count > 5 ? "DeathCry, спаси!" : + (settingsOverlay.count > 4 ? "Умоляю, перестань!" : + (settingsOverlay.count > 3 ? "Да хорош уже!" : "Ещё раз") + )))); }); var debugBox = settingsOverlay.overlay.lookup("#debug"); debugBox.setSelected(settings.debug); debugBox.selectedProperty()["addListener(javafx.beans.value.ChangeListener)"]( function(o, ov, nv) settings.debug = nv); + debugBox.setOnMouseEntered(function() { + settingsOverlay.updateDesc(debugBox.getText(), "Режим отладки позволяет просмотреть лог запуска и работы программы в реальном времени прямо из лаунчера, что упрощает поиск нужной информации"); + }); holder.lookup("#apply").setOnAction(function(event) overlay.hide(0, null)); }, + updateDesc: function(label, desc) { + //На случай если человек решил избавится от этой фишки + if (this.descLabel == null) return; + if (this.description == null) return; + + this.descLabel.setText(label); + this.description.setText(desc); + }, + transferCatalogDialog: function(newDir) { settingsOverlay.transferDialog.setVisible(true); - settingsOverlay.transferDialog.lookup("#cancelTransfer").setOnAction(function(event) - { + settingsOverlay.transferDialog.lookup("#cancelTransfer").setOnAction(function(event) { settings.updatesDir = newDir; DirBridge.dirUpdates = settings.updatesDir; settingsOverlay.updateDirLabel(); @@ -133,11 +161,11 @@ var settingsOverlay = { setRAM: function(ram) { - if (ram>762&&ram<1024){ - settings.ram = java.lang.Math["min(int,int)"](ram, FunctionalBridge.getJVMTotalMemory()); - }else{ - settings.ram = java.lang.Math["min(int,int)"](((ram / 256) | 0) * 256, FunctionalBridge.getJVMTotalMemory()); - } + if (ram > 762 && ram < 1024) { + settings.ram = java.lang.Math["min(int,int)"](ram, FunctionalBridge.getJVMTotalMemory()); + } else { + settings.ram = java.lang.Math["min(int,int)"](((ram / 256) | 0) * 256, FunctionalBridge.getJVMTotalMemory()); + } }, updateDirLabel: function() { @@ -148,9 +176,16 @@ LogHelper.debug("Dir: %s", DirBridge.dir); /* ====================== CLI PARAMS ===================== */ var cliParams = { - login: null, password: null, profile: -1, autoLogin: false, - updatesDir: null, autoEnter: null, fullScreen: null, ram: -1, - offline: false, featureStore: null, + login: null, + password: null, + profile: -1, + autoLogin: false, + updatesDir: null, + autoEnter: null, + fullScreen: null, + ram: -1, + offline: false, + featureStore: null, init: function(params) { var named = params.getNamed(); @@ -200,8 +235,7 @@ var cliParams = { if (cliParams.profile >= 0) { settings.profile = cliParams.profile; } - if (cliParams.updatesDir !== null) { - } + if (cliParams.updatesDir !== null) {} if (cliParams.autoEnter !== null) { settings.autoLogin = cliParams.autoEnter; } @@ -218,4 +252,4 @@ var cliParams = { settings.offline = cliParams.offline; } } -}; +}; \ No newline at end of file diff --git a/Launcher/runtime/dialog/overlay/update/update.css b/Launcher/runtime/dialog/overlay/update/update.css index 4035391a..0ec06064 100644 --- a/Launcher/runtime/dialog/overlay/update/update.css +++ b/Launcher/runtime/dialog/overlay/update/update.css @@ -6,16 +6,16 @@ #overlay { -fx-background-image: url('../../images/downloader/blured.jpg'); } -#overlay > #utitle { +#overlay>#utitle { -fx-alignment: top-left; } -#overlay > #description { +#overlay>#description { -fx-alignment: top-left; -fx-wrap-text: true; } -#overlay > #description.error { +#overlay>#description.error { -fx-text-fill: #CE5757; } @@ -29,15 +29,15 @@ .progress-bar { -fx-background-color: transparent; } -.progress-indicator{ - -fx-background-color: transparent ; +.progress-indicator { + -fx-background-color: transparent; } .progress-indicator .indicator { - -fx-background-color: transparent ; + -fx-background-color: transparent; } -.progress-bar > .bar { +.progress-bar>.bar { -fx-background-image: url("../../images/downloader/line.png"); -fx-background-color: transparent; -fx-background-insets: 0; @@ -45,9 +45,10 @@ .progress-bar > .bar { -fx-padding: 0; } -.progress-bar > .track { +.progress-bar>.track { -fx-background-color: transparent; -fx-background-insets: 0; -fx-background-radius: 3px; } + /*-- DrLeonardo Design --*/ \ No newline at end of file diff --git a/Launcher/runtime/dialog/overlay/update/update.js b/Launcher/runtime/dialog/overlay/update/update.js index 4996f7f8..92803cd5 100644 --- a/Launcher/runtime/dialog/overlay/update/update.js +++ b/Launcher/runtime/dialog/overlay/update/update.js @@ -1,5 +1,8 @@ var update = { - overlay: null, title: null, description: null, progress: null, + overlay: null, + title: null, + description: null, + progress: null, initOverlay: function() { update.overlay = loadFXML("dialog/overlay/update/update.fxml"); @@ -41,7 +44,7 @@ var update = { "Примерно осталось: %d:%02d:%02d%n", state.filePath, - state.getTotalDownloadedMiB() + 0.0, state.getTotalSizeMiB() + 0.0, + state.getTotalDownloadedMiB() + 0.0, state.getTotalSizeMiB() + 0.0, bps <= 0.0 ? 0.0 : bps / 1024.0, estimatedHH, estimatedMM, estimatedSS )); @@ -83,13 +86,13 @@ function offlineUpdateRequest(dirName, dir, matcher, digest) { /* Export functions */ function makeUpdateRequest(dirName, dir, matcher, digest, callback) { - var request = settings.offline ? { setStateCallback: function(stateCallback) { } } : - new UpdateRequest(dirName, dir, matcher, digest); - var task = settings.offline ? newTask(offlineUpdateRequest(dirName, dir, matcher, digest)) : - newRequestTask(request); + var request = settings.offline ? { setStateCallback: function(stateCallback) {} } : + new UpdateRequest(dirName, dir, matcher, digest); + var task = settings.offline ? newTask(offlineUpdateRequest(dirName, dir, matcher, digest)) : + newRequestTask(request); update.setTaskProperties(task, request, callback); task.updateMessage("Состояние: Хеширование"); task.updateProgress(-1, -1); startTask(task); -} +} \ No newline at end of file diff --git a/Launcher/runtime/dialog/scenes/console/console.fxml b/Launcher/runtime/dialog/scenes/console/console.fxml index 71843dd6..5e87be6a 100644 --- a/Launcher/runtime/dialog/scenes/console/console.fxml +++ b/Launcher/runtime/dialog/scenes/console/console.fxml @@ -1,54 +1,57 @@ + + - - - + + - + - - + + - + - + - + - - - + + + diff --git a/Launcher/runtime/dialog/scenes/mainmenu/mainmenu.fxml b/Launcher/runtime/dialog/scenes/mainmenu/mainmenu.fxml index c5dd660f..1f19607e 100644 --- a/Launcher/runtime/dialog/scenes/mainmenu/mainmenu.fxml +++ b/Launcher/runtime/dialog/scenes/mainmenu/mainmenu.fxml @@ -1,19 +1,19 @@ - - - + + + - + @@ -22,7 +22,7 @@ - @@ -51,10 +51,14 @@ - + - - - - - + + + + + diff --git a/Launcher/runtime/dialog/scenes/options/options.fxml b/Launcher/runtime/dialog/scenes/options/options.fxml index 4884c670..aa3b28a3 100644 --- a/Launcher/runtime/dialog/scenes/options/options.fxml +++ b/Launcher/runtime/dialog/scenes/options/options.fxml @@ -1,10 +1,11 @@ - - + + + @@ -13,7 +14,7 @@ - + @@ -38,21 +39,30 @@ - - - + + + diff --git a/Launcher/runtime/dialog/scenes/options/options.js b/Launcher/runtime/dialog/scenes/options/options.js index 98c28232..ed573704 100644 --- a/Launcher/runtime/dialog/scenes/options/options.js +++ b/Launcher/runtime/dialog/scenes/options/options.js @@ -5,7 +5,7 @@ var options = { LogHelper.debug("Loading options file"); try { tryWithResources(new HInput(IOHelper.newInput(options.file)), options.read); - } catch(e) { + } catch (e) { LogHelper.error(e); } }, @@ -14,7 +14,7 @@ var options = { LogHelper.debug("Saving options file"); try { tryWithResources(new HOutput(IOHelper.newOutput(options.file)), options.write); - } catch(e) { + } catch (e) { LogHelper.error(e); } }, @@ -24,33 +24,27 @@ var options = { if (magic != config.settingsMagic) { throw new java.io.IOException("options magic mismatch: " + java.lang.Integer.toString(magic, 16)); } - var profilesCount = input.readInt(); - LogHelper.debug("Load options. ProfilesCount %d",profilesCount); - for(var i = 0;i 1) + subLevel = modFile.subTreeLevel; + var testMod = new javafx.scene.control.CheckBox(modName); + testMod.getStyleClass().add("checkboxOpt"); + + if (subLevel > 1) + for (var i = 1; i < subLevel; i++) + testMod.setTranslateX(25 * i); + + testMod.setSelected(modFile.mark); + testMod.setOnAction(function(event) { + var isSelected = event.getSource().isSelected(); + if (isSelected) { + profile.markOptional(modFile); + LogHelper.debug("Selected mod %s", modFile.name); + } else { + profile.unmarkOptional(modFile); + LogHelper.debug("Unselected mod %s", modFile.name); + } + options.update(); }); - nodelist.forEach(function(node,i,arr) { - modlist.getChildren().remove(node); - }); - var profile = profilesList[serverHolder.old]; - var list = profile.getOptional(); - var checkBoxList = new java.util.ArrayList; - list.forEach(function(modFile) { - var modName = modFile.name, modDescription = "", subLevel = 1; - if(!modFile.visible) - { - LogHelper.debug("optionalMod %s hidden",modFile.name); - return; - } - - if(modFile.permissions != 0 && ((loginData.permissions.toLong() & modFile.permissions) == 0)) - { - LogHelper.debug("optionalMod %s permissions deny",modFile.name); - return; - } - if(modFile.info != null) - modDescription = modFile.info; - if(modFile.subTreeLevel != null && modFile.subTreeLevel > 1) - subLevel = modFile.subTreeLevel; - var testMod = new javafx.scene.control.CheckBox(modName); - testMod.getStyleClass().add("checkboxOpt"); - - if(subLevel > 1) - for(var i = 1; i < subLevel; i++) - testMod.setTranslateX(25*i); - - testMod.setSelected(modFile.mark); - testMod.setOnAction(function(event) { - var isSelected = event.getSource().isSelected(); - if(isSelected) - { - profile.markOptional(modFile); - LogHelper.debug("Selected mod %s", modFile.name); - } - else - { - profile.unmarkOptional(modFile); - LogHelper.debug("Unselected mod %s", modFile.name); - } - options.update(); - }); - testMod.setFocusTraversable(false); - checkBoxList.add(testMod); - testMod.getStyleClass().add("modname"); - if(modDescription != "") { - textDescr = new javafx.scene.text.Text(modDescription); - if(subLevel > 1) { - for(var i = 1; i < subLevel; i++){ - textDescr.setWrappingWidth(620-(25*i)); - textDescr.setTranslateX(25+(25*i)); - } - } else { - textDescr.setWrappingWidth(620); - textDescr.setTranslateX(25); - } - textDescr.setTextAlignment(javafx.scene.text.TextAlignment.JUSTIFY); - textDescr.getStyleClass().add("description-text"); - checkBoxList.add(textDescr); - } - sep = new javafx.scene.control.Separator(); - sep.getStyleClass().add("separator"); - checkBoxList.add(sep); - }); - modlist.getChildren().clear(); - modlist.getChildren().addAll(checkBoxList); + testMod.setFocusTraversable(false); + checkBoxList.add(testMod); + testMod.getStyleClass().add("modname"); + if (modDescription != "") { + textDescr = new javafx.scene.text.Text(modDescription); + if (subLevel > 1) { + for (var i = 1; i < subLevel; i++) { + textDescr.setWrappingWidth(620 - (25 * i)); + textDescr.setTranslateX(25 + (25 * i)); + } + } else { + textDescr.setWrappingWidth(620); + textDescr.setTranslateX(25); + } + textDescr.setTextAlignment(javafx.scene.text.TextAlignment.JUSTIFY); + textDescr.getStyleClass().add("description-text"); + checkBoxList.add(textDescr); + } + sep = new javafx.scene.control.Separator(); + sep.getStyleClass().add("separator"); + checkBoxList.add(sep); + }); + modlist.getChildren().clear(); + modlist.getChildren().addAll(checkBoxList); } -}; +}; \ No newline at end of file diff --git a/Launcher/runtime/dialog/servers.css b/Launcher/runtime/dialog/servers.css index 11d11a93..b0852e67 100644 --- a/Launcher/runtime/dialog/servers.css +++ b/Launcher/runtime/dialog/servers.css @@ -1,6 +1,6 @@ /*-- DrLeonardo Design --*/ - /* Server buttons */ + .server-button { -fx-font-weight: bold; -fx-font-size: 16pt; @@ -16,14 +16,14 @@ .server-button { } .server-button:selected { - -fx-effect: dropshadow(gaussian, rgba(23, 25, 29, 0.3), 15,0,0,3); + -fx-effect: dropshadow(gaussian, rgba(23, 25, 29, 0.3), 15, 0, 0, 3); } + /** server-button- **/ .server-button-Example { -fx-background-image: url('images/servers/example.png'); } - /*-- DrLeonardo Design --*/ \ No newline at end of file diff --git a/Launcher/runtime/dialog/styles.css b/Launcher/runtime/dialog/styles.css index 0091ec73..e613ab1d 100644 --- a/Launcher/runtime/dialog/styles.css +++ b/Launcher/runtime/dialog/styles.css @@ -1,6 +1,6 @@ /*-- Without jfoenix --*/ Button { - -fx-background-color: TRANSPARENT, TRANSPARENT, TRANSPARENT, TRANSPARENT; + -fx-background-color: TRANSPARENT, TRANSPARENT, TRANSPARENT, TRANSPARENT; -fx-background-radius: 3px; -fx-background-insets: 0px; } @@ -12,7 +12,7 @@ CheckBox .box-container { CheckBox .box, CheckBox:indeterminate .box, -CheckBox:indeterminate:selected .box{ +CheckBox:indeterminate:selected .box { -fx-pref-width: 18; -fx-pref-height: 18; @@ -27,11 +27,11 @@ CheckBox:indeterminate:selected .box{ CheckBox:selected .box { -fx-border-color: #5fd97a; - -fx-background-color: #5fd97a; + -fx-background-color: #5fd97a; } CheckBox .mark { - -fx-background-color: TRANSPARENT; + -fx-background-color: TRANSPARENT; } CheckBox:selected .mark { @@ -46,7 +46,7 @@ CheckBox:selected .mark { -fx-border-radius: 2; } -CheckBox .indeterminate-mark{ +CheckBox .indeterminate-mark { -fx-background-color: #5fd97a; -fx-background-radius: 2; -fx-border-width: 0; @@ -56,8 +56,11 @@ CheckBox .indeterminate-mark{ /*-- DrLeonardo Design --*/ -Button, CheckBox, ComboBox, RadioButton { - -fx-cursor: hand; +Button, +CheckBox, +ComboBox, +RadioButton { + -fx-cursor: hand; } @@ -69,20 +72,22 @@ #layout { -fx-pref-height: 450px; -fx-background-image: url('images/background.jpg'); } + #background { -fx-background-color: #fff; } + /** Labels **/ -#background > #settingsTitle { +#background>#settingsTitle { -fx-font-size: 14pt; -fx-alignment: baseline-center; } -#serverLabel{ +#serverLabel { -fx-text-fill: #323232; } -#serverStatus{ +#serverStatus { -fx-text-fill: #323232; -fx-pref-width: 120px; -fx-pref-height: 25px; @@ -90,17 +95,17 @@ #serverStatus{ /* Mask */ #mask { - -fx-effect: DropShadow( gaussian , rgba(255,255,255,0.5) , 0,0,0,1 ); + -fx-effect: DropShadow(gaussian, rgba(255, 255, 255, 0.5), 0, 0, 0, 1); } /** Errors **/ -#errormessage{ +#errormessage { -fx-background-color: transparent; -fx-text-alignment: center; -fx-text-fill: #CE5757; } -.error{ +.error { -fx-text-fill: #CE5757; } @@ -110,6 +115,7 @@ #bar { -fx-pref-width: 46px; -fx-pref-height: 450px; } + /** buttons in bar **/ #close { -fx-background-position: center; @@ -118,28 +124,35 @@ #close { -fx-pref-width: 46px; -fx-pref-height: 45px; } -#hide, #back, #goConsole, #settings, #discord { + +#hide, +#back, +#goConsole, +#settings, +#discord { -fx-background-position: center; -fx-background-radius: 0; -fx-pref-width: 46px; -fx-pref-height: 45px; } -#logout{ - -fx-text-fill:#323232; - -fx-font-size:12; - -fx-font-weight:normal; - -fx-border-color:#CE5757; - -fx-border-width:1; - -fx-background-color:transparent; - -fx-padding:0; +#logout { + -fx-text-fill: #323232; + -fx-font-size: 12; + -fx-font-weight: normal; + -fx-border-color: #CE5757; + -fx-border-width: 1; + -fx-background-color: transparent; + -fx-padding: 0; } + #logout:hover, -#logout:focus{ - -fx-text-fill:#ff6a5e; +#logout:focus { + -fx-text-fill: #ff6a5e; } -#logout:pressed{ - -fx-border-color:#cb4d43; + +#logout:pressed { + -fx-border-color: #cb4d43; } #send { @@ -151,7 +164,9 @@ #send { -fx-pref-height: 30px; } -#send:pressed { -fx-background-color: #d8d8d8; } +#send:pressed { + -fx-background-color: #d8d8d8; +} /* LoginMenu */ #authPane { @@ -176,18 +191,22 @@ .auth { -fx-text-fill: #ffffff; -fx-pref-width: 200px; -fx-pref-height: 45px; - -fx-effect: dropshadow(gaussian, rgba(23, 25, 29, 0.3), 15,0,0,3); + -fx-effect: dropshadow(gaussian, rgba(23, 25, 29, 0.3), 15, 0, 0, 3); } -.auth:hover, .auth:pressed { -fx-background-color: #75e18c; } +.auth:hover, +.auth:pressed { + -fx-background-color: #75e18c; +} -#password, #login { +#password, +#login { -fx-background-radius: 0; -fx-pref-width: 200px; -fx-pref-height: 30px; } -.text-input{ +.text-input { -fx-focus-color: transparent; -fx-background-repeat: no-repeat; -fx-text-fill: #909090; @@ -208,21 +227,26 @@ #link { -fx-pref-height: 17px; } -#link:hover, #link:pressed { -fx-opacity: 0.8; } +#link:hover, +#link:pressed { + -fx-opacity: 0.8; +} /** CheckBox & ComboBox**/ -#rememberchb{ +#rememberchb { -fx-font-size: 13; -fx-text-fill: #909090; -fx-pref-width: 145px; -fx-pref-height: 30px; } + #combologin { -fx-text-fill: #909090; -fx-prompt-text-fill: #909090; -fx-pref-width: 200px; -fx-pref-height: 30px; } + .combologin, .combologin { -fx-font-size: 13px; @@ -240,7 +264,7 @@ .combologin .list-cell { .combologin-popup .list-view { -fx-background-color: white, white; -fx-background-insets: 0, 1; - -fx-effect: dropshadow( three-pass-box , rgba(0,0,0,0.6) , 8, 0.0 , 0 , 0 ); + -fx-effect: dropshadow(three-pass-box, rgba(0, 0, 0, 0.6), 8, 0.0, 0, 0); } .combologin .list-cell:filled:selected .text, @@ -253,20 +277,18 @@ .combologin .arrow { -fx-background-color: #5fd97a; } -.combologin-popup .list-view .list-cell -{ +.combologin-popup .list-view .list-cell { -fx-background-color: white; } -.combologin-popup .list-view .list-cell:filled:selected, .combologin-popup .list-view .list-cell:filled:selected:hover -{ +.combologin-popup .list-view .list-cell:filled:selected, +.combologin-popup .list-view .list-cell:filled:selected:hover { -fx-background: -fx-accent; -fx-background-color: -fx-selection-bar; -fx-text-fill: #909090; } -.combologin-popup .list-view .list-cell:filled:hover -{ +.combologin-popup .list-view .list-cell:filled:hover { -fx-background-color: white; -fx-text-fill: #909090; } @@ -286,20 +308,24 @@ .serverentrance { } /** buttons **/ -.clientLaunch{ +.clientLaunch { -fx-font-weight: bold; -fx-font-size: 16pt; -fx-background-radius: 0; -fx-background-color: #5fd97a; -fx-text-fill: #ffffff; } -.clientSettings{ + +.clientSettings { -fx-background-position: center; -fx-background-color: #5fd97a; -fx-background-radius: 0; } -.clientLaunch:hover, .clientLaunch:pressed { -fx-background-color: #75e18c; } +.clientLaunch:hover, +.clientLaunch:pressed { + -fx-background-color: #75e18c; +} /* Scrolls */ .scroll-pane { @@ -340,11 +366,11 @@ .scroll-pane>.corner { } /* OptionsPane */ -#optionsPane > #modlist { +#optionsPane>#modlist { -fx-background-color: transparent; } -#optionsPane > #modlist > .viewport { +#optionsPane>#modlist>.viewport { -fx-background-color: transparent; } @@ -368,38 +394,42 @@ .separator *.line { -fx-border-width: 0 0 10 0; } -#serverlist{ - -fx-background-color: transparent; -} -#serverlist > .viewport { +#serverlist { -fx-background-color: transparent; } -#serverdesc{ - -fx-background-color: transparent; -} -#serverdesc > .viewport { +#serverlist>.viewport { -fx-background-color: transparent; } -#serverinfo{ - -fx-background-color: transparent; -} -#serverinfo > .viewport { +#serverdesc { -fx-background-color: transparent; } -#servercontainer{ +#serverdesc>.viewport { + -fx-background-color: transparent; +} + +#serverinfo { + -fx-background-color: transparent; +} + +#serverinfo>.viewport { + -fx-background-color: transparent; +} + +#servercontainer { -fx-background-color: transparent; -fx-pref-width: 282px; -fx-pref-height: 75px; } -.toggle-button:disabled{ +.toggle-button:disabled { -fx-opacity: 1.0; } -.heading{ +.heading { -fx-text-fill: #555555; } + /*-- DrLeonardo Design --*/ \ No newline at end of file diff --git a/Launcher/runtime/init.js b/Launcher/runtime/init.js index 9b1ccb43..b3d9a949 100644 --- a/Launcher/runtime/init.js +++ b/Launcher/runtime/init.js @@ -9,7 +9,8 @@ var LauncherApp = Java.extend(JSApplication, { settings = SettingsManager.settings; settingsManager.loadHDirStore(); cliParams.applySettings(); - }, start: function(primaryStage) { + }, + start: function(primaryStage) { stage = primaryStage; stage.initStyle(javafx.stage.StageStyle.TRANSPARENT); stage.setResizable(false); @@ -45,7 +46,8 @@ var LauncherApp = Java.extend(JSApplication, { setCurrentScene(loginScene); initLauncher(); - }, stop: function() { + }, + stop: function() { settingsManager.saveConfig(); settingsManager.saveHDirStore(); options.save(); @@ -82,7 +84,7 @@ function start(args) { if (config.jvm.enable) { switch (JVMHelper.OS_TYPE) { case JVMHelperOS.MUSTDIE: - jvmDirName = JVMHelper.OS_BITS === 32 ? config.jvm.jvmMustdie32Dir : + jvmDirName = JVMHelper.OS_BITS === 32 ? config.jvm.jvmMustdie32Dir : jvmDirName = JVMHelper.OS_BITS === 64 ? config.jvm.jvmMustdie64Dir : config.jvm.enable = false; break; default: