1
0
Fork 0
mirror of https://github.com/NovaGM/Modules.git synced 2024-08-14 22:47:01 +00:00

Compare commits

..

No commits in common. "04e817908e7564a5bba01f82fa1ff77600143df6" and "4676a8d90e0e943afa40b9d46d3b22707dd6b2c8" have entirely different histories.

5 changed files with 5 additions and 126 deletions

View file

@ -1,11 +0,0 @@
{
"main": "index.js",
"name": "SnowflakeInfo",
"description": "Returns info about a given snowflake.",
"tags": ["commands"],
"authors": ["717352467280691331"],
"version": "1.0.0"
}

View file

@ -1,87 +0,0 @@
import { commands, internalMessage } from '@goosemod/patcher';
const discordEpoch = Number(1420070400000);
const idToBinary = (num) => {
let bin = '';
let high = parseInt(num.slice(0, -10)) || 0;
let low = parseInt(num.slice(-10));
try {
while (low > 0 || high > 0) {
bin = String(low & 1) + bin;
low = Math.floor(low / 2);
if (high > 0) {
low += 5000000000 * (high % 2);
high = Math.floor(high / 2);
}
}
} catch (e) {
console.error(e);
}
return bin;
};
export default {
goosemodHandlers: {
onImport: () => {
commands.add(
'echo',
"Prints out all of the message's text in an internal message.",
(args) => {
internalMessage(args.text[0].text);
console.log(args);
},
[
{
type: 3,
name: 'text',
description: 'Text to be printed in an internal message.',
required: true,
},
],
);
commands.add(
'snowflake',
'Returns info about a given snowflake.',
(args) => {
// Check if the supplied argument is actually a snowflake or not
if (!/\d{1,20}/.test(args.snowflake[0].text)) {
internalMessage('The provided argument is not a snowflake.');
} else {
const binary = idToBinary(args.snowflake[0].text).toString(2).padStart(64, '0');
const res = {
timestamp: parseInt(binary.substring(0, 42), 2) + discordEpoch,
workerID: parseInt(binary.substring(42, 47), 2),
processID: parseInt(binary.substring(47, 52), 2),
increment: parseInt(binary.substring(52, 64), 2),
binary: binary,
};
internalMessage(
`Snowflake info for \`${args.snowflake[0].text}\`\n\n` +
`**Timestamp**: ${new Date(res.timestamp).toUTCString()} (${res.timestamp})\n` +
`**Worker ID**: ${res.workerID}\n` +
`**Process ID**: ${res.processID}\n` +
`**Increment**: ${res.increment}\n` +
`**Binary**: ${res.binary}\n`,
);
}
},
[
{
type: 3,
name: 'snowflake',
description: 'Snowflake to decrypt.',
required: true,
},
],
);
},
onRemove: () => {
commands.remove('echo');
commands.remove('snowflake');
},
},
};

View file

@ -22,7 +22,8 @@ export function textInputField(text, subtext, placeholder, onApply, initialValue
inputEl.classList.add('inputDefault-_djjkz', 'input-cIJ7To');
inputEl.placeholder = placeholder;
inputEl.type = 'text';
inputEl.value = initialValue ? initialValue : '';
inputWrapEl.appendChild(inputEl);
// Button field
@ -46,16 +47,6 @@ export function textInputField(text, subtext, placeholder, onApply, initialValue
dividerEl.classList.add('divider-3573oO', 'dividerDefault-3rvLe-');
dividerEl.style.marginTop = subtext ? '20px' : '45px';
// Insertion checker
// A bit hacky...
// But works :)
let insertCheckId = setInterval(() => {
if (el.parentNode != null) {
inputEl.value = initialValue != undefined ? initialValue() : '';
clearInterval(insertCheckId);
}
}, 1000);
el.appendChild(textEl);
el.appendChild(buttonEl);
el.appendChild(inputWrapEl);

View file

@ -7,5 +7,5 @@
"authors": ["186496078273708033"],
"version": "1.1.0"
"version": "1.0.0"
}

View file

@ -6,7 +6,6 @@ import { textInputField } from './custom-settings.js';
let settingsPage = "Settings Experiment";
let settings;
let defaultSettings = {
inputText: "Default value"
};
export default {
@ -131,26 +130,13 @@ export default {
{
type: "custom",
element: textInputField(
"Text Input (static initial value)",
"Text Input",
"Prototype",
"Placeholder",
value => {
showToast(`Text Input: ${value}`);
},
() => "Preset value"
)
},
{
type: "custom",
element: textInputField(
"Text Input (loading from and saving to settings)",
"Prototype",
"Placeholder",
value => {
showToast(`Text Input: ${value}`);
settings.inputText = value;
},
() => settings.inputText
"Preset value"
)
}
]);