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

Updated Module Settings Experiment

This commit is contained in:
フズキ 2021-03-25 14:42:24 +01:00
parent e1667e6865
commit 04e817908e
No known key found for this signature in database
GPG key ID: AD7750AB4625F1DD
3 changed files with 28 additions and 5 deletions

View file

@ -22,7 +22,6 @@ export function textInputField(text, subtext, placeholder, onApply, initialValue
inputEl.classList.add('inputDefault-_djjkz', 'input-cIJ7To'); inputEl.classList.add('inputDefault-_djjkz', 'input-cIJ7To');
inputEl.placeholder = placeholder; inputEl.placeholder = placeholder;
inputEl.type = 'text'; inputEl.type = 'text';
inputEl.value = initialValue ? initialValue : '';
inputWrapEl.appendChild(inputEl); inputWrapEl.appendChild(inputEl);
@ -47,6 +46,16 @@ export function textInputField(text, subtext, placeholder, onApply, initialValue
dividerEl.classList.add('divider-3573oO', 'dividerDefault-3rvLe-'); dividerEl.classList.add('divider-3573oO', 'dividerDefault-3rvLe-');
dividerEl.style.marginTop = subtext ? '20px' : '45px'; 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(textEl);
el.appendChild(buttonEl); el.appendChild(buttonEl);
el.appendChild(inputWrapEl); el.appendChild(inputWrapEl);

View file

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

View file

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