The purpose of this project is to create a launcher for a personal Minecraft server, featuring mods, user authentication, a news feed, an interactive world map, and a user dashboard. The design is custom-made.
Project Benefits
This project enhances the user experience by integrating essential server functionalities into a single launcher, making it easier for players to manage and access server features.
How the Project Works
The project utilizes Node.js and Electron.js to create a desktop application that provides seamless access to server features, including mod management, user authentication, server news, and an interactive map.
An UX/UI design of launcher
data:image/s3,"s3://crabby-images/cebd3/cebd3fd2fd95683894d33a7fd34e32327d837365" alt="design"
Repository and Installation
- front-end repo: https://github.com/Fulldroper/mine-launcher-auth
- front-end post: /mine-launcher-auth
To install and run the project:
-
Clone the repository:
Terminal window git clone https://github.com/Fulldroper/mine-launchercd mine-launcher -
Install dependencies and start the launcher:
Terminal window npm installnpm start
Project Workflow
-
Setup Project: Initialize the project structure and dependencies.
Terminal window npm initnpm install -
Develop Main Interface: Create the main window and interface for the launcher.
const { app, BrowserWindow } = require('electron');function createWindow () {const win = new BrowserWindow({width: 800,height: 600,webPreferences: {preload: path.join(__dirname, 'preload.js')}});win.loadFile('index.html');}app.whenReady().then(() => {createWindow();app.on('activate', () => {if (BrowserWindow.getAllWindows().length === 0) createWindow();});});app.on('window-all-closed', () => {if (process.platform !== 'darwin') app.quit();}); -
Integrate Features: Implement the news feed, interactive map, and user dashboard.
<!DOCTYPE html><html><head><title>Minecraft Launcher</title></head><body><h1>Minecraft Launcher</h1><div id="news-feed"></div><div id="map"></div><div id="dashboard"></div></body></html>
Skills Gained
- Developing desktop applications using Electron.js
- Integrating game server features into a single interface
- Managing user authentication and server interaction