-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathexample_01.user.js
108 lines (96 loc) · 4.36 KB
/
example_01.user.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
// ==UserScript==
// @name Example-GUI
// @namespace HKR
// @match https://example.com/*
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_xmlhttpRequest
// @version 1.0
// @author HKR
// @description This is an example userscript made for UserGui
// @require https://github.com/AugmentedWeb/UserGui/raw/Release-1.0/usergui.js
// @run-at document-load
// ==/UserScript==
const Gui = new UserGui;
Gui.settings.window.title = "GUI Demo"; // set window title
Gui.settings.window.centered = true;
Gui.addPage("Main", `
<div class="rendered-form">
<div class="">
<h2 class="userscript-title" access="false" id="control-8281685">Site InnerText Changer</h2></div>
<div class=""><address class="userscript-address" access="false" id="control-6944086">This is an example GUI</address></div>
<div class="formbuilder-text form-group field-text-query-selector">
<label for="text-query-selector" class="formbuilder-text-label">Query Selector</label>
<input type="text" class="form-control" name="text-query-selector" access="false" id="text-query-selector">
</div>
<div class="formbuilder-textarea form-group field-text-new-value">
<label for="text-new-value" class="formbuilder-textarea-label">New Value</label>
<textarea type="textarea" class="form-control" name="text-new-value" access="false" id="text-new-value"></textarea>
</div>
<div class="formbuilder-button form-group field-button-change-value">
<button type="button" class="btn-success btn" name="button-change-value" access="false" style="success" id="button-change-value">Change value</button>
</div>
</div>
`);
Gui.addPage("Settings", `
<div class="rendered-form">
<div class="">
<h2 access="false" class="text-primary" id="control-274549">GUI Settings</h2></div>
<div class="formbuilder-radio-group form-group field-radio-group-background-color">
<label for="radio-group-background-color" class="formbuilder-radio-group-label">Primary Color</label>
<div class="radio-group">
<div class="formbuilder-radio">
<input name="radio-group-background-color" access="false" id="radio-group-background-color-1" value="black" type="radio">
<label for="radio-group-background-color-1">Black</label>
</div>
<div class="formbuilder-radio">
<input name="radio-group-background-color" access="false" id="radio-group-background-color-2" value="pink" type="radio">
<label for="radio-group-background-color-2">Pink</label>
</div>
<div class="formbuilder-radio">
<input name="radio-group-background-color" access="false" id="radio-group-background-color-3" value="green" type="radio">
<label for="radio-group-background-color-3">Green</label>
</div>
<div class="formbuilder-radio">
<input name="radio-group-background-color" access="false" id="radio-group-background-color-3" value="purple" type="radio">
<label for="radio-group-background-color-3">Purple</label>
</div>
</div>
</div>
<div class="formbuilder-button form-group field-button-save-config">
<button type="button" class="btn-success btn" name="button-save-config" access="false" style="success" id="button-save-config">Save</button>
</div>
</div>
`);
function changeSiteValues(querySelector, newValue) {
if(querySelector && newValue) {
[...document.querySelectorAll(querySelector)].forEach(elem => {
elem.innerText = newValue;
});
} else {
Gui.window.alert("Please input both values!");
}
}
function openGui() {
Gui.open(() => {
Gui.smartEvent("button-change-value", () => {
const querySelector = Gui.getValue("text-query-selector");
const newValue = Gui.getValue("text-new-value");
changeSiteValues(querySelector, newValue);
});
Gui.smartEvent("radio-group-background-color", () => {
const color = Gui.getData("radio-group-background-color");
Gui.setPrimaryColor(color);
});
Gui.smartEvent("button-save-config", () => {
Gui.saveConfig();
});
Gui.loadConfig();
});
}
const openBtn = document.createElement("button");
openBtn.innerText = "Open GUI";
openBtn.onclick = () => {
openGui();
}
document.querySelector("div").appendChild(openBtn);