-
Enable Auto Clicking via Mouse Hover
-
-
-
-
+
+
\ No newline at end of file
diff --git a/options/script.js b/options/script.js
new file mode 100644
index 0000000..f87d46d
--- /dev/null
+++ b/options/script.js
@@ -0,0 +1,138 @@
+function kl_add() {
+ var o = document.getElementById("al").options;
+ for (var i = 0; i < o.length; i++) {
+ if (o[i].selected) {
+ var opt = document.createElement("option");
+ opt.text = o[i].innerHTML;
+ opt.value = o[i].value;
+ var os = document.getElementById("sl").options;
+ var exists = false;
+ for (var i2 = 0; i2 < os.length; i2++) {
+ if (os[i2].value == o[i].value) {
+ exists = true;
+ }
+ }
+ if (!exists) {
+ document.getElementById("sl").options.add(opt);
+ }
+ }
+ }
+ kl_save();
+}
+
+function kl_save() {
+ var a = new Array();
+ var o = document.getElementById("sl").options;
+ for (var i = 0; i < o.length; i++) {
+ if (o[i].value != undefined) {
+ a.push({ value: o[i].value, name: o[i].innerHTML });
+ }
+ }
+ localStorage["keyboardLayoutsList"] = JSON.stringify(a);
+ localStorage["keyboardLayout1"] = a[0].value;
+ document.getElementById("changeEffect").className = "show";
+}
+
+function kl_load() {
+ if (localStorage["keyboardLayoutsList"] != undefined) {
+ var a = JSON.parse(localStorage["keyboardLayoutsList"]);
+ if (a.length > 0) {
+ document.getElementById("sl").removeChild(document.getElementById("sl").options[0]);
+ for (var i = 0; i < a.length; i++) {
+ var opt = document.createElement("option");
+ opt.text = a[i].name;
+ opt.value = a[i].value;
+ if (a[i].value != undefined) {
+ document.getElementById("sl").options.add(opt);
+ }
+ }
+ }
+ }
+}
+
+function kl_remove() {
+ var o = document.getElementById("sl").options;
+ if (o.length > 1) {
+ for (var i = 0; i < o.length; i++) {
+ if (o[i].selected) {
+ document.getElementById("sl").removeChild(o[i]);
+ }
+ }
+ }
+ kl_save();
+}
+
+window.addEventListener('load', function () {
+ document.body.className = "loaded";
+ kl_load();
+ document.getElementById("kl_remove").addEventListener("click", kl_remove, false);
+ document.getElementById("kl_add").addEventListener("click", kl_add, false);
+ var c = document.getElementsByClassName("setting");
+ for (var i = 0; i < c.length; i++) {
+ var sk = c[i].getAttribute("_setting");
+ if (c[i].getAttribute("type") == "checkbox") {
+ if ((localStorage[sk] == undefined) && (c[i].getAttribute("_default") != undefined)) {
+ localStorage[sk] = c[i].getAttribute("_default");
+ }
+ if (localStorage[sk] == "true") {
+ c[i].checked = true;
+ }
+ } if (c[i].getAttribute("type") == "range") {
+ if (localStorage[sk] == undefined) {
+ c[i].value = 0;
+ } else {
+ c[i].value = localStorage[sk];
+ }
+ } else {
+ c[i].value = localStorage[sk];
+ }
+ c[i].onchange = function () {
+ var skey = this.getAttribute("_setting");
+ if (this.getAttribute("type") == "checkbox") {
+ if ((localStorage[skey] == undefined) && (this.getAttribute("_default") != undefined)) {
+ localStorage[skey] = this.getAttribute("_default");
+ }
+ localStorage[skey] = this.checked ? "true" : "false";
+ } else {
+ localStorage[skey] = this.value;
+ }
+ document.getElementById("changeEffect").className = "show";
+ if (this.getAttribute("_changed") != undefined) {
+ callFunc(this.getAttribute("_changed"));
+ }
+ }
+ if (c[i].getAttribute("_changed") != undefined) {
+ callFunc(c[i].getAttribute("_changed"));
+ }
+ }
+}, false);
+
+function callFunc(callback) {
+ eval(callback)();
+}
+
+function slider_zoom() {
+ var v = document.getElementById("zoomLevel").value;
+ if (v < 0.3) { v = "Auto"; } else { v = (v * 100).toFixed(0) + "%"; }
+ document.getElementById("zoomLevelValue").innerHTML = v;
+}
+
+function checkbox_smallKeyboard() {
+ var s = document.getElementById("smallKeyboard").checked;
+ document.getElementById("zoomLevelLabel").style.display = s ? "none" : "block";
+}
+
+function checkbox_touchEvents() {
+ var s = document.getElementById("touchEvents").checked;
+ document.getElementById("autoTriggerPH").style.display = s ? "none" : "block";
+}
+
+function slider_autoTriggerAfter() {
+ var v = document.getElementById("autoTriggerAfter").value + " sec";
+ document.getElementById("autoTriggerAfterValue").innerHTML = v;
+}
+
+function checkbox_autoTrigger() {
+ var s = !document.getElementById("autoTrigger").checked;
+ document.getElementById("autoTriggerOnPH").style.display = s ? "none" : "block";
+}
diff --git a/options/styles.css b/options/styles.css
new file mode 100644
index 0000000..0fd8267
--- /dev/null
+++ b/options/styles.css
@@ -0,0 +1,261 @@
+body.loaded {
+ opacity: 1;
+}
+
+#page {
+ -webkit-transition: all 0.55s ease-out;
+ -webkit-transform: scale(0.9) translate3d(-230px, 0, 0);
+ min-width: 1000px;
+ padding: 30px;
+ padding-top: 80px;
+ padding-left: 60px;
+}
+
+body.loaded #page {
+ -webkit-transform: translate3d(0, 0, 0) perspective(800);
+}
+
+select::-webkit-scrollbar {
+ width: 5px;
+ height: 5px;
+}
+
+select::-webkit-scrollbar-track {
+ -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0);
+ -webkit-border-radius: 10px;
+ border-radius: 10px;
+ background-color: #eee;
+}
+
+select::-webkit-scrollbar-thumb {
+ -webkit-border-radius: 10px;
+ border-radius: 10px;
+ -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.8);
+ -webkit-transition: all 0.2s;
+ background-color: #666;
+}
+
+body {
+ font-family: 'Segoe UI', Tahoma, sans-serif;
+ color: #333;
+ background-color: #fefefe;
+ opacity: 0;
+ -webkit-transition: all 1.5s;
+}
+
+h1 {
+ background-color: #20509F;
+ position: fixed;
+ top: 0;
+ left: 0;
+ right: 0;
+ font-size: 24px;
+ padding: 12px;
+ padding-left: 70px;
+ color: #fff;
+ z-index: 10;
+}
+
+h1,
+h2 {
+ margin: 0;
+ font-weight: normal;
+ letter-spacing: -1px;
+}
+
+h2 {
+ font-size: 20px;
+ margin-bottom: 10px;
+ color: #555;
+ margin-top: 30px;
+}
+
+#options {
+ margin-top: 30px;
+ font-size: 14px;
+}
+
+#links a#footer {
+ position: absolute;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ border-top: 1px solid #BBB;
+ padding: 20px 30px;
+ font-size: 13px;
+ color: #222;
+ text-decoration: none;
+ border-bottom: 0;
+ margin-bottom: 0;
+}
+
+#links a#footer:hover {
+ background-color: #eee;
+}
+
+#links a#footer span {
+ background-image: url(https://xontab.com/res/images/logo/header.png);
+ background-repeat: no-repeat;
+ background-size: 50px;
+ height: 50px;
+ padding-left: 60px;
+ font-size: 23px;
+ margin-top: 12px;
+ padding-top: 8px;
+ text-decoration: none;
+ color: #20509F;
+ letter-spacing: -1px;
+ margin-left: 10px;
+ display: inline-block;
+}
+
+select,
+input[type='checkbox'],
+input[type='radio'] {
+ -webkit-appearance: none;
+ -webkit-user-select: none;
+ background-image: -webkit-linear-gradient(#ededed, #ededed 38%, #dedede);
+ border: 1px solid rgba(0, 0, 0, 0.25);
+ border-radius: 2px;
+ box-shadow: 0 1px 0 rgba(0, 0, 0, 0.08), inset 0 1px 2px rgba(255, 255, 255, 0.75);
+ color: #444;
+ font: inherit;
+ margin: 0 1px 0 0;
+ text-shadow: 0 1px 0 rgb(240, 240, 240);
+}
+
+select,
+select:hover,
+select:focus {
+ background: #fff;
+ box-shadow: inset 1px 1px 5px rgba(0, 0, 0, 0.1);
+ background-image: none !important;
+}
+
+:enabled:hover:-webkit-any( select, input[type='checkbox'], input[type='radio'], :-webkit-any( button, input[type='button'], input[type='submit']):not(.custom-appearance):not(.link-button)) {
+ background-image: -webkit-linear-gradient(#f0f0f0, #f0f0f0 38%, #e0e0e0);
+ border-color: rgba(0, 0, 0, 0.3);
+ box-shadow: 0 1px 0 rgba(0, 0, 0, 0.12), inset 0 1px 2px rgba(255, 255, 255, 0.95);
+ color: black;
+}
+
+input[type='checkbox']:checked::before {
+ -webkit-user-select: none;
+ background-image: url('');
+ background-size: 100% 100%;
+ content: '';
+ display: block;
+ height: 100%;
+ width: 100%;
+}
+
+input[type='checkbox'] {
+ bottom: 2px;
+ height: 13px;
+ position: relative;
+ vertical-align: middle;
+ width: 13px;
+}
+
+select {
+ border: 1px solid #999;
+ border-radius: 3px;
+}
+
+select,
+input,
+button {
+ -webkit-transition: all 0.3s;
+ outline: none;
+}
+
+select:focus,
+input:focus,
+button:active {
+ border: 1px solid #15C !important;
+}
+
+#links {
+ position: absolute;
+ top: 35px;
+ bottom: 0;
+ right: 0;
+ z-index: 1;
+ padding-right: 220px;
+ box-shadow: -3px 3px 3px rgba(0, 0, 0, 0.1);
+ padding-left: 25px;
+}
+
+#links iframe {
+ position: absolute;
+ right: 0;
+ top: 50px;
+ border: 0;
+}
+
+#links a {
+ display: inline-block;
+ text-decoration: none;
+ -webkit-transition: all 0.4s;
+ color: #888;
+ border-bottom: 1px solid #fff;
+ padding: 2px 5px;
+ margin: 5px 0;
+ font-size: 13px;
+}
+
+#links a:hover {
+ border-bottom: 1px solid #333;
+ color: #333;
+}
+
+select {
+ padding: 5px;
+}
+
+select.layout {
+ height: 200px;
+ width: 150px;
+}
+
+label {
+ padding: 7px 0;
+ display: block;
+}
+
+th {
+ font-size: 15px;
+ text-align: left;
+ font-weight: normal;
+ padding-top: 20px;
+}
+
+button {
+ -webkit-appearance: none;
+ -webkit-user-select: none;
+ background-image: -webkit-linear-gradient(#EDEDED, #EDEDED 38%, #DEDEDE);
+ border: 1px solid rgba(0, 0, 0, 0.25);
+ border-radius: 2px;
+ box-shadow: 0 1px 0 rgba(0, 0, 0, 0.08), inset 0 1px 2px rgba(255, 255, 255, 0.75);
+ color: #000;
+ font: inherit;
+ margin: 5px 10px;
+ text-shadow: 0 1px 0 #F0F0F0;
+ padding: 5px 10px;
+ -webkit-transition: all 0.4s;
+}
+
+#changeEffect {
+ -webkit-transition: all 0.4s;
+ font-size: 1px;
+ opacity: 0;
+}
+
+#changeEffect.show {
+ opacity: 1;
+ font-size: 14px;
+}
+
+button:active {
+ background-image: -webkit-linear-gradient(#e7e7e7, #e7e7e7 38%, #d7d7d7);
+}
diff --git a/script.js b/script.js
index 187504b..e93e01b 100644
--- a/script.js
+++ b/script.js
@@ -704,7 +704,7 @@ var virtualKeyboardChromeExtensionRequestRefresh = false;
function xk_settings_load_main(response) {
if (response.openedFirstTime == undefined) {
- window.open(chrome.extension.getURL("options.html"));
+ chrome.extension.sendRequest({ method: "createTab", url: chrome.extension.getURL("options.html") });
setting_set("openedFirstTime", "true");
}
if (response.smallKeyboard == "true") {