mirror of
https://github.com/ParadiseSS13/Paradise.git
synced 2026-01-03 22:22:31 +00:00
* [TGUI v6 Project] Remove `context` (#29086)
* [TGUI v6 Project] Remove `context`
* I forgot I had to do that.
* [TGUI v6 Project] Move to React (#29090)
* It compiles
* Last Inferno uses
* all works now
* Fixes
* [TGUI v6] Changes files extensions for interfaces from .js to .jsx, Deprecates Inferno State Hooks (#29094)
* Initial Commit
* Apply suggestions from code review
trust me bro
Co-authored-by: Aylong <69762909+AyIong@users.noreply.github.com>
Signed-off-by: Burzah <116982774+Burzah@users.noreply.github.com>
---------
Signed-off-by: Burzah <116982774+Burzah@users.noreply.github.com>
Co-authored-by: Aylong <69762909+AyIong@users.noreply.github.com>
* [TGUI v6] Replaces babel with swc, fixes realtive paths on a few files, new build (#29100)
* Initial commit
* Build
* webpack config and errors and rebuild
* export routingError, hopefully
* fix pda app routing
* pass current tab index to tab headers and content in nanobank
---------
Co-authored-by: warriorstar-orion <orion@snowfrost.garden>
* fix dna modifier bluescreen and library computer tabs (#29108)
* TGUI parity with TG
Need to fix a bunch of things...
* Implement TGUI payload chunking backend
https://github.com/tgstation/tgstation/pull/90295
* Filx chan bottom scroll. Again
* Fix TGchat focus
* Fix rounding
* Fix inputs
* Upgrade deps
* More fixes
* Fix chat lineHeight
* Fix NanoMap
* Update `tgui-core`
* fix autolathe
* fix airlock electronics
* fix intercom
* fix compost bin height
* Fix chat preferences
* Move to TSX without types :clueless:
* test tiny meet your new brother test tgui
* Fix RCD
* fix stackcraft
* fix up beakercontents
* Fix MODsuits
* fix seed extractor
* Merge branch 'tgui-v6' of github.com:ParadiseSS13/Paradise into tgui-v6
* fix holodeck
* fix cookbook pda app
* fix remaining useState args
* Fix DNAModifier
* Fix Sleeper
* Fix SupermatterMonitor
* Remove `vitest`
* Update dev-server
* Fix `IconStack`
* Correct margin
* bundles, please don't break
* prettier
* Revert "Remove `vitest`"
This reverts commit 0609006abb.
* Re-add tests
* Prettier
* fix maplint for test_tgui
* TGchat shine effect
* TGUI Rebuildo
* Fix broken tabs, search boxes, sortable tables, and others (#29450)
* Replace KitchenSink theme state with a React context
* Remove last usage of useLocalState
* Rebind unbound useState calls
* Build and update /tg/ui
* Reformat /tg/ui
* [ci skip]
---------
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
* Ports #29217 to tgui v6. Added tgui-setup to CI builds (#29787)
* Add tgui-setup to build scripts
* Fix CORS issue
* Build and update /tg/ui
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
* Add one missing word to comment
---------
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
* fix law manager
* Removes dangling references to `context` (#29793)
* Removes dangling references to `context`
* Build and update /tg/ui (#25)
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
---------
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
* fix messenger and atmos scanner
* swap out line break in examinate
* fix powermonitor
* Bump tgui-core from 3.1.5/3.1.4 to 4.3.4 (#29799)
* Bump tgui-core
* Build and update /tg/ui (#28)
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
---------
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
* Fixes additional examine text
* oopsie
* Small tgui v6 fixes (#29801)
* Remove flow
* Miscellaneous fixes
* Miscellaneous fixes
* Moved properties placed on the wrong element
* Migrate removed CSS attributes in JSX
* Build and update /tg/ui (#27)
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
---------
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
* fix carbon examine
* fix robot examine
* fix lint
* improve SMES appearance
* fix camera console name order
* more newline fixes
* fix boolean modal cancel not working
* fix random disabled access in RCD
* point tgui to correct passthrough verb names
* Fix missing 0 option for ERTs. (#29819)
* fix newlines in damage flavor
* Revert all changes related to newlines in DM
* fix the actual thing that was wrong with newlines
* fix ERT manager deny input
* [tgui-v6] Makes Agent Card UI more aesthethic, fixes input fields, fixes minimum age slider (#29832)
* agent card fixes and tweaks
* tgui bundle
* Reformat /tg/ui (#33) (#29838)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
* restore camera console list appearance
* fixed pai ui paths (#29867)
* /tg/ui fixes no. 3 (#29868)
* Remove IconStack styles that conflict with styles added in tgstation/tgui-core#203
* Fix minesweeper icon
* DNA Modifier fixes
* Fix alignment of icons in PDA games menu
* Expand chem dispenser
* Fix pAI interfaces
* Build and update /tg/ui
---------
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Toastical <20125180+Toastical@users.noreply.github.com>
* teleporter fix, bundle changes, test
* /tg/ui fixes no.4 (#29877)
* Fix translucent buttons
* Remove stories already present in tgui-core
* Make voting choices not transparent
* Build and update /tg/ui
* Fix size of set ringtone in PDA messenger
* Fix crew monitor highlight colors
* Fix ReagentsEditor search. Small style fixes
* tgui-say radio prefix has special color again
* Expand chameleon mask a little
* Fix search in chameleon mask
* Make list input modal slightly taller
* [ci skip]
* Build /tg/ui
---------
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
---------
Signed-off-by: Burzah <116982774+Burzah@users.noreply.github.com>
Co-authored-by: Aylong <69762909+AyIong@users.noreply.github.com>
Co-authored-by: warriorstar-orion <orion@snowfrost.garden>
Co-authored-by: Aylong <alexanderkitsa@gmail.com>
Co-authored-by: Arthri <41360489+Arthri@users.noreply.github.com>
Co-authored-by: Arthri <41360489+a@users.noreply.github.com>
Co-authored-by: /tg/ui Builder <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Charlie Nolan <funnyman3595@gmail.com>
Co-authored-by: Toastical <20125180+Toastical@users.noreply.github.com>
164 lines
3.5 KiB
JavaScript
164 lines
3.5 KiB
JavaScript
/**
|
|
* @file
|
|
* @copyright 2020 Aleksej Komarov
|
|
* @license MIT
|
|
*/
|
|
|
|
let socket;
|
|
const queue = [];
|
|
const subscribers = [];
|
|
|
|
function ensureConnection() {
|
|
if (process.env.NODE_ENV === 'production') return;
|
|
|
|
if (socket && socket.readyState !== WebSocket.CLOSED) return;
|
|
|
|
if (!window.WebSocket) return;
|
|
|
|
const DEV_SERVER_IP = process.env.DEV_SERVER_IP || '127.0.0.1';
|
|
|
|
socket = new WebSocket(`ws://${DEV_SERVER_IP}:3000`);
|
|
|
|
socket.onopen = () => {
|
|
// Empty the message queue
|
|
while (queue.length !== 0) {
|
|
const msg = queue.shift();
|
|
socket.send(msg);
|
|
}
|
|
};
|
|
|
|
socket.onmessage = (event) => {
|
|
const msg = JSON.parse(event.data);
|
|
for (let subscriber of subscribers) {
|
|
subscriber(msg);
|
|
}
|
|
};
|
|
|
|
window.onunload = () => socket?.close();
|
|
}
|
|
|
|
export function subscribe(fn) {
|
|
subscribers.push(fn);
|
|
}
|
|
|
|
function primitiveReviver(value) {
|
|
if (typeof value === 'number' && !Number.isFinite(value)) {
|
|
return {
|
|
__number__: String(value),
|
|
};
|
|
}
|
|
if (typeof value === 'undefined') {
|
|
return {
|
|
__undefined__: true,
|
|
};
|
|
}
|
|
return value;
|
|
}
|
|
|
|
/**
|
|
* A json serializer which handles circular references and other junk.
|
|
*/
|
|
function serializeObject(obj) {
|
|
let refs = [];
|
|
|
|
function objectReviver(key, value) {
|
|
if (typeof value !== 'object') {
|
|
return primitiveReviver(value);
|
|
}
|
|
|
|
if (value === null) {
|
|
return value;
|
|
}
|
|
// Circular reference
|
|
if (refs.includes(value)) {
|
|
return '[circular ref]';
|
|
}
|
|
refs.push(value);
|
|
// Error object
|
|
const isError = value instanceof Error || (value.code && value.message && value.message.includes('Error'));
|
|
if (isError) {
|
|
return {
|
|
__error__: true,
|
|
string: String(value),
|
|
stack: value.stack,
|
|
};
|
|
}
|
|
// Array
|
|
if (Array.isArray(value)) {
|
|
return value.map(primitiveReviver);
|
|
}
|
|
return value;
|
|
}
|
|
|
|
const json = JSON.stringify(obj, objectReviver);
|
|
refs = null;
|
|
return json;
|
|
}
|
|
|
|
export function sendMessage(msg) {
|
|
if (process.env.NODE_ENV === 'production') return;
|
|
|
|
const json = serializeObject(msg);
|
|
// Send message using WebSocket
|
|
if (!window.WebSocket) return;
|
|
|
|
ensureConnection();
|
|
if (socket.readyState === WebSocket.OPEN) {
|
|
socket.send(json);
|
|
} else {
|
|
// Keep only 100 latest messages in the queue
|
|
if (queue.length > 100) {
|
|
queue.shift();
|
|
}
|
|
queue.push(json);
|
|
}
|
|
}
|
|
|
|
export function sendLogEntry(level, ns, ...args) {
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
try {
|
|
sendMessage({
|
|
type: 'log',
|
|
payload: {
|
|
level,
|
|
ns: ns || 'client',
|
|
args,
|
|
},
|
|
});
|
|
} catch (err) {}
|
|
}
|
|
}
|
|
|
|
export function setupHotReloading() {
|
|
if (process.env.NODE_ENV === 'production' || !process.env.WEBPACK_HMR_ENABLED || !window.WebSocket) {
|
|
return;
|
|
}
|
|
if (!import.meta.webpackHot) return;
|
|
|
|
ensureConnection();
|
|
sendLogEntry(0, null, 'setting up hot reloading');
|
|
subscribe(({ type }) => {
|
|
sendLogEntry(0, null, 'received', type);
|
|
if (type !== 'hotUpdate') return;
|
|
|
|
const status = import.meta.webpackHot.status();
|
|
if (status !== 'idle') {
|
|
sendLogEntry(0, null, 'hot reload status:', status);
|
|
return;
|
|
}
|
|
|
|
import.meta.webpackHot
|
|
.check({
|
|
ignoreUnaccepted: true,
|
|
ignoreDeclined: true,
|
|
ignoreErrored: true,
|
|
})
|
|
.then((modules) => {
|
|
sendLogEntry(0, null, 'outdated modules', modules);
|
|
})
|
|
.catch((err) => {
|
|
sendLogEntry(0, null, 'reload error', err);
|
|
});
|
|
});
|
|
}
|