-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
84 changed files
with
23,597 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,216 @@ | ||
# launcher | ||
Lectron Minecraft Launcher | ||
<p align="center"><img src="./app/assets/images/icon.png" width="150px" height="150px" alt="aventium softworks"></p> | ||
|
||
<h1 align="center">lectron Launcher</h1> | ||
|
||
<em><h5 align="center">(formerly Electron Launcher)</h5></em> | ||
|
||
[<p align="center"><img src="https://img.shields.io/travis/lectron/lectronlauncher.svg?style=for-the-badge" alt="travis">](https://travis-ci.org/lectron/lectronlauncher) [<img src="https://img.shields.io/github/downloads/lectron/lectronlauncher/total.svg?style=for-the-badge" alt="downloads">](https://github.com/lectron/lectronlauncher/releases) <img src="https://forthebadge.com/images/badges/winter-is-coming.svg" height="28px" alt="stark"></p> | ||
|
||
<p align="center">Join modded servers without worrying about installing Java, Forge, or other mods. We'll handle that for you.</p> | ||
|
||
![Screenshot 1](https://i.imgur.com/6o7SmH6.png) | ||
![Screenshot 2](https://i.imgur.com/x3B34n1.png) | ||
|
||
## Features | ||
|
||
* 🔒 Full account management. | ||
* Add multiple accounts and easily switch between them. | ||
* Credentials are never stored and transmitted directly to Mojang. | ||
* 📂 Efficient asset management. | ||
* Receive client updates as soon as we release them. | ||
* Files are validated before launch. Corrupt or incorrect files will be redownloaded. | ||
* ☕ **Automatic Java validation.** | ||
* If you have an incompatible version of Java installed, we'll install the right one *for you*. | ||
* You do not need to have Java installed to run the launcher. | ||
* 📰 News feed natively built into the launcher. | ||
* ⚙️ Intuitive settings management, including a Java control panel. | ||
* Supports all of our servers. | ||
* Switch between server configurations with ease. | ||
* View the player count of the selected server. | ||
* Automatic updates. That's right, the launcher updates itself. | ||
* View the status of Mojang's services. | ||
|
||
This is not an exhaustive list. Download and install the launcher to gauge all it can do! | ||
|
||
#### Need Help? [Check the wiki.][wiki] | ||
|
||
#### Like the project? Leave a ⭐ star on the repository! | ||
|
||
## Downloads | ||
|
||
You can download from [GitHub Releases](https://github.com/lectron/lectronlauncher/releases) | ||
|
||
#### Latest Release | ||
|
||
[![](https://img.shields.io/github/release/lectron/lectronlauncher.svg?style=flat-square)](https://github.com/lectron/lectronlauncher/releases/latest) | ||
|
||
#### Latest Pre-Release | ||
[![](https://img.shields.io/github/release/lectron/lectronlauncher/all.svg?style=flat-square)](https://github.com/lectron/lectronlauncher/releases) | ||
|
||
**Supported Platforms** | ||
|
||
If you download from the [Releases](https://github.com/lectron/lectronlauncher/releases) tab, select the installer for your system. | ||
|
||
| Platform | File | | ||
| -------- | ---- | | ||
| Windows x64 | `lectronlauncher-setup-VERSION.exe` | | ||
| macOS | `lectronlauncher-VERSION.dmg` | | ||
| Linux x64 | `lectronlauncher-VERSION-x86_64.AppImage` | | ||
|
||
## Console | ||
|
||
To open the console, use the following keybind. | ||
|
||
```console | ||
ctrl + shift + i | ||
``` | ||
|
||
Ensure that you have the console tab selected. Do not paste anything into the console unless you are 100% sure of what it will do. Pasting the wrong thing can expose sensitive information. | ||
|
||
#### Export Output to a File | ||
|
||
If you want to export the console output, simply right click anywhere on the console and click **Save as..** | ||
|
||
![console example](https://i.imgur.com/T5e73jP.png) | ||
|
||
|
||
## Development | ||
|
||
### Getting Started | ||
|
||
**System Requirements** | ||
|
||
* [Node.js][nodejs] v12 | ||
|
||
--- | ||
|
||
**Clone and Install Dependencies** | ||
|
||
```console | ||
> git clone https://github.com/lectron/lectronlauncher.git | ||
> cd lectronlauncher | ||
> npm install | ||
``` | ||
|
||
--- | ||
|
||
**Launch Application** | ||
|
||
```console | ||
> npm start | ||
``` | ||
|
||
--- | ||
|
||
**Build Installers** | ||
|
||
To build for your current platform. | ||
|
||
```console | ||
> npm run dist | ||
``` | ||
|
||
Build for a specific platform. | ||
|
||
| Platform | Command | | ||
| ----------- | -------------------- | | ||
| Windows x64 | `npm run dist:win` | | ||
| macOS | `npm run dist:mac` | | ||
| Linux x64 | `npm run dist:linux` | | ||
|
||
Builds for macOS may not work on Windows/Linux and vice-versa. | ||
|
||
--- | ||
|
||
### Visual Studio Code | ||
|
||
All development of the launcher should be done using [Visual Studio Code][vscode]. | ||
|
||
Paste the following into `.vscode/launch.json` | ||
|
||
```JSON | ||
{ | ||
"version": "0.2.0", | ||
"configurations": [ | ||
{ | ||
"name": "Debug Main Process", | ||
"type": "node", | ||
"request": "launch", | ||
"cwd": "${workspaceFolder}", | ||
"runtimeExecutable": "${workspaceFolder}/node_modules/.bin/electron", | ||
"windows": { | ||
"runtimeExecutable": "${workspaceFolder}/node_modules/.bin/electron.cmd" | ||
}, | ||
"args": ["."], | ||
"console": "integratedTerminal", | ||
"protocol": "inspector" | ||
}, | ||
{ | ||
"name": "Debug Renderer Process", | ||
"type": "chrome", | ||
"request": "launch", | ||
"runtimeExecutable": "${workspaceFolder}/node_modules/.bin/electron", | ||
"windows": { | ||
"runtimeExecutable": "${workspaceFolder}/node_modules/.bin/electron.cmd" | ||
}, | ||
"runtimeArgs": [ | ||
"${workspaceFolder}/.", | ||
"--remote-debugging-port=9222" | ||
], | ||
"webRoot": "${workspaceFolder}" | ||
} | ||
] | ||
} | ||
``` | ||
|
||
This adds two debug configurations. | ||
|
||
#### Debug Main Process | ||
|
||
This allows you to debug Electron's [main process][mainprocess]. You can debug scripts in the [renderer process][rendererprocess] by opening the DevTools Window. | ||
|
||
#### Debug Renderer Process | ||
|
||
This allows you to debug Electron's [renderer process][rendererprocess]. This requires you to install the [Debugger for Chrome][chromedebugger] extension. | ||
|
||
Note that you **cannot** open the DevTools window while using this debug configuration. Chromium only allows one debugger, opening another will crash the program. | ||
|
||
--- | ||
|
||
### Note on Third-Party Usage | ||
|
||
You may use this software in your own project so long as the following conditions are met. | ||
|
||
* Credit is expressly given to the original authors (RLDevelopement). | ||
* Include a link to the original source on the launcher's About page. | ||
* Credit the authors and provide a link to the original source in any publications or download pages. | ||
* The source code remain **public** as a fork of this repository. | ||
|
||
We reserve the right to update these conditions at any time, please check back periodically. | ||
|
||
--- | ||
|
||
## Resources | ||
|
||
* [Wiki][wiki] | ||
* [Nebula (Create Distribution.json)][nebula] | ||
* [v2 Rewrite Branch (WIP)][v2branch] | ||
|
||
The best way to contact the developers is on Discord. | ||
|
||
[![discord](https://discordapp.com/api/guilds/211524927831015424/embed.png?style=banner3)][discord] | ||
|
||
--- | ||
|
||
### See you ingame. | ||
|
||
|
||
[nodejs]: https://nodejs.org/en/ 'Node.js' | ||
[vscode]: https://code.visualstudio.com/ 'Visual Studio Code' | ||
[mainprocess]: https://electronjs.org/docs/tutorial/application-architecture#main-and-renderer-processes 'Main Process' | ||
[rendererprocess]: https://electronjs.org/docs/tutorial/application-architecture#main-and-renderer-processes 'Renderer Process' | ||
[chromedebugger]: https://marketplace.visualstudio.com/items?itemName=msjsdiag.debugger-for-chrome 'Debugger for Chrome' | ||
[discord]: https://discord.gg/zNWUXdt 'Discord' | ||
[wiki]: https://github.com/lectron/lectronlauncher/wiki 'wiki' | ||
[nebula]: https://github.com/lectron/Nebula 'lectron/Nebula' | ||
[v2branch]: https://github.com/lectron/lectronlauncher/tree/ts-refactor 'v2 branch' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
<html lang="en" xmlns="http://www.w3.org/1999/xhtml"> | ||
<head> | ||
<meta charset="utf-8" http-equiv="Content-Security-Policy" content="script-src 'self' 'sha256-In6B8teKZQll5heMl9bS7CESTbGvuAt3VVV86BUQBDk='"/> | ||
<title>Lectron Launcher</title> | ||
<script src="./assets/js/scripts/uicore.js"></script> | ||
<script src="./assets/js/scripts/uibinder.js"></script> | ||
<link type="text/css" rel="stylesheet" href="./assets/css/launcher.css"> | ||
<style> | ||
body { | ||
/*background: url('assets/images/backgrounds/<%=bkid%>.jpg') no-repeat center center fixed;*/ | ||
transition: background-image 1s ease; | ||
background-image: url('assets/images/backgrounds/background.png'); | ||
background-size: cover; | ||
-webkit-user-select: none; | ||
} | ||
#main { | ||
display: none; | ||
height: calc(100% - 22px); | ||
background: linear-gradient(to top, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0) 100%); | ||
width: 100%; | ||
position: absolute; | ||
z-index: 10; | ||
} | ||
#main[overlay] { | ||
filter: blur(3px) contrast(0.9) brightness(1.0); | ||
} | ||
</style> | ||
</head> | ||
<body bkid="<%=bkid%>"> | ||
<%- include('frame') %> | ||
<div id="main"> | ||
<%- include('welcome') %> | ||
<%- include('login') %> | ||
<%- include('settings') %> | ||
<%- include('landing') %> | ||
</div> | ||
<%- include('overlay') %> | ||
<div id="loadingContainer"> | ||
<div id="loadingContent"> | ||
<div id="loadSpinnerContainer"> | ||
<img id="loadCenterImage" src="assets/images/icon.png"> | ||
</div> | ||
</div> | ||
</div> | ||
<script> | ||
// Load language | ||
for(let key of Object.keys(Lang.query('html'))){ | ||
document.getElementById(key).innerHTML = Lang.query(`html.${key}`) | ||
} | ||
</script> | ||
</body> | ||
</html> |
Oops, something went wrong.