mirror of
https://github.com/cliffe/BreakEscape.git
synced 2026-02-21 11:18:08 +00:00
Add new functionality to open workstations in new tabs
- Introduced buttons in the Crypto and Lab Workstation title bars to allow users to open the respective workstations in new tabs. - Implemented JavaScript functions `openCryptoWorkstationInNewTab` and `openLabWorkstationInNewTab` to handle the new tab functionality. - Updated CSS styles for the new buttons to ensure proper positioning and visual appeal. - Made necessary imports and exports in helper files to integrate the new functionality across the application.
This commit is contained in:
@@ -82,6 +82,7 @@
|
||||
<div class="laptop-screen">
|
||||
<div class="title-bar">
|
||||
<span>Crypto Workstation</span>
|
||||
<button class="minigame-open-new-tab-button" onclick="openCryptoWorkstationInNewTab()" title="Open in new tab">↑</button>
|
||||
<button class="minigame-close-button" onclick="closeLaptop()">×</button>
|
||||
</div>
|
||||
<div id="cyberchef-container">
|
||||
@@ -97,6 +98,7 @@
|
||||
<div class="laptop-screen">
|
||||
<div class="title-bar">
|
||||
<span>Lab Sheet</span>
|
||||
<button class="minigame-open-new-tab-button" onclick="openLabWorkstationInNewTab()" title="Open in new tab">↑</button>
|
||||
<button class="minigame-close-button" onclick="closeLabWorkstation()">×</button>
|
||||
</div>
|
||||
<div id="lab-container">
|
||||
|
||||
@@ -16,3 +16,4 @@ class RemoveUniqueGameConstraint < ActiveRecord::Migration[7.0]
|
||||
name: 'index_games_on_player_and_mission_non_unique'
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@@ -76,6 +76,7 @@
|
||||
<div class="laptop-screen">
|
||||
<div class="title-bar">
|
||||
<span>Crypto Workstation</span>
|
||||
<button class="minigame-open-new-tab-button" onclick="openCryptoWorkstationInNewTab()" title="Open in new tab">↑</button>
|
||||
<button class="minigame-close-button" onclick="closeLaptop()">×</button>
|
||||
</div>
|
||||
<div id="cyberchef-container">
|
||||
|
||||
@@ -187,3 +187,4 @@
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -117,6 +117,7 @@ body {
|
||||
font-family: 'VT323', monospace;
|
||||
font-size: 18px;
|
||||
min-height: 25px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.title-bar .close-btn {
|
||||
@@ -138,6 +139,13 @@ body {
|
||||
background: #c0392b;
|
||||
}
|
||||
|
||||
/* Center minigame buttons vertically in title-bar */
|
||||
.title-bar .minigame-close-button {
|
||||
top: 50%;
|
||||
transform: translateY(-50%);
|
||||
right: 15px;
|
||||
}
|
||||
|
||||
#cyberchef-container {
|
||||
flex: 1;
|
||||
width: 100%;
|
||||
|
||||
@@ -185,6 +185,35 @@
|
||||
background: #a93226;
|
||||
}
|
||||
|
||||
/* Open in new tab button for workstations */
|
||||
.minigame-open-new-tab-button {
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
right: 50px;
|
||||
transform: translateY(-50%);
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
background: #3498db;
|
||||
color: white;
|
||||
border: 4px solid #2980b9;
|
||||
cursor: pointer;
|
||||
font-family: 'Press Start 2P', monospace !important;
|
||||
font-size: 18px;
|
||||
z-index: 10000;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
transition: background-color 0.3s ease;
|
||||
}
|
||||
|
||||
.minigame-open-new-tab-button:hover {
|
||||
background: #2980b9;
|
||||
}
|
||||
|
||||
.minigame-open-new-tab-button:active {
|
||||
background: #21618c;
|
||||
}
|
||||
|
||||
/* Progress bar styling for minigames */
|
||||
.minigame-progress-container {
|
||||
width: 100%;
|
||||
|
||||
@@ -193,3 +193,4 @@
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -224,3 +224,4 @@ export default window.hacktivityCable;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -44,4 +44,13 @@ export function closeLaptop() {
|
||||
window.game.input.mouse.enabled = true;
|
||||
window.game.input.keyboard.enabled = true;
|
||||
}
|
||||
}
|
||||
|
||||
// Open the crypto workstation iframe in a new tab
|
||||
export function openCryptoWorkstationInNewTab() {
|
||||
const cyberchefFrame = document.getElementById('cyberchef-frame');
|
||||
|
||||
if (cyberchefFrame && cyberchefFrame.src) {
|
||||
window.open(cyberchefFrame.src, '_blank');
|
||||
}
|
||||
}
|
||||
@@ -24,8 +24,8 @@ export function introduceScenario() {
|
||||
}
|
||||
|
||||
// Import crypto workstation functions
|
||||
import { createCryptoWorkstation, openCryptoWorkstation, closeLaptop } from './crypto-workstation.js';
|
||||
import { createLabWorkstation, openLabWorkstation, closeLabWorkstation } from './lab-workstation.js';
|
||||
import { createCryptoWorkstation, openCryptoWorkstation, closeLaptop, openCryptoWorkstationInNewTab } from './crypto-workstation.js';
|
||||
import { createLabWorkstation, openLabWorkstation, closeLabWorkstation, openLabWorkstationInNewTab } from './lab-workstation.js';
|
||||
|
||||
// Re-export for other modules that import from helpers.js
|
||||
export { createCryptoWorkstation };
|
||||
@@ -127,5 +127,7 @@ export function debounce(func, wait) {
|
||||
// Export functions to global scope for backward compatibility
|
||||
window.openCryptoWorkstation = openCryptoWorkstation;
|
||||
window.closeLaptop = closeLaptop;
|
||||
window.openCryptoWorkstationInNewTab = openCryptoWorkstationInNewTab;
|
||||
window.openLabWorkstation = openLabWorkstation;
|
||||
window.closeLabWorkstation = closeLabWorkstation;
|
||||
window.closeLabWorkstation = closeLabWorkstation;
|
||||
window.openLabWorkstationInNewTab = openLabWorkstationInNewTab;
|
||||
@@ -54,3 +54,12 @@ export function closeLabWorkstation() {
|
||||
}
|
||||
}
|
||||
|
||||
// Open the lab workstation iframe in a new tab
|
||||
export function openLabWorkstationInNewTab() {
|
||||
const labFrame = document.getElementById('lab-frame');
|
||||
|
||||
if (labFrame && labFrame.src) {
|
||||
window.open(labFrame.src, '_blank');
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user