Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Save Kurotaku-sama/f5c1aec948c8e8157eee0efd95e7e2f3 to your computer and use it in GitHub Desktop.
Save Kurotaku-sama/f5c1aec948c8e8157eee0efd95e7e2f3 to your computer and use it in GitHub Desktop.
Adds an switch, if the switch is enabled and you click on a map marker, the script automatic clicks on the mark pin button
// ==UserScript==
// @name Genshin Impact Teyvat Interactive Map - Automate mark pins
// @name:de Genshin Impact Teyvat Interactive Map - Automatisches setzen der Markierung
// @namespace kurotaku.de
// @version 1.2.2
// @description Adds an switch, if the switch is enabled and you click on a map marker, the script automatic clicks on the mark pin button
// @description:de Fügt einen Schalter hinzu, wenn der Schalter aktiviert ist und Sie auf eine Kartenmarkierung klicken, klickt das Skript automatisch auf den Markierungsknopf
// @author Kurotaku
// @license MIT
// @match https://act.hoyolab.com/ys/app/interactive-map/index.html*
// @icon https://act.hoyolab.com/ys/app/interactive-map/mapicon.png
// @updateURL https://gist.github.com/Kurotaku-sama/f5c1aec948c8e8157eee0efd95e7e2f3/raw/Genshin%2520Impact%2520Teyvat%2520Interactive%2520Map%2520-%2520Automate%2520mark%2520pins.user.js
// @downloadURL https://gist.github.com/Kurotaku-sama/f5c1aec948c8e8157eee0efd95e7e2f3/raw/Genshin%2520Impact%2520Teyvat%2520Interactive%2520Map%2520-%2520Automate%2520mark%2520pins.user.js
// @require https://gist.github.com/Kurotaku-sama/9ebeb659500f6eee2f780344948e1e8f/raw/kuros_library.user.js
// @grant GM_getValue
// @grant GM_setValue
// ==/UserScript==
(async function() {
// Set the switch value if its the first time running the script
if(GM_getValue("one-click-mark-switch") === undefined)
GM_setValue("one-click-mark-switch", false);
// Wait till map is visible
wait_for_element('#user-guide-underground-map').then(async () => {
// Wait for the other sliders
wait_for_element('#user-guide-underground-map').then(async () => {
// Add the slider
let one_click_mark_switch = `<div id="k-one_click_mark" class="one_click_mark-switch k-one_click_mark"><div class="one_click_mark-switch__text">Automate mark pins</div> <div class="one_click_mark-switch__pic"></div></div>`;
document.querySelector("#user-guide-underground-map").insertAdjacentHTML('beforebegin', one_click_mark_switch);
document.querySelector("#k-one_click_mark").addEventListener("click", toggle_one_click_mark, false);
// Set switch image
refresh_switch("one-click-mark-switch", ".one_click_mark-switch__pic", "one_click_mark-switch__pic--active");
// Put on left side if panel is folded
wait_for_element('.filter-panel__fold').then(async () => {
document.querySelector(".filter-panel__fold").addEventListener("click", () => document.querySelector(".k-one_click_mark").classList.toggle("one_click_mark-switch--folded"), false);
document.querySelector(".filter-panel__icon").addEventListener("click", () => document.querySelector(".k-one_click_mark").classList.remove("one_click_mark-switch--folded"), false);
});
});
wait_for_element('.leaflet-marker-pane').then(async () => {
let container = document.querySelector(".leaflet-marker-pane");
container.addEventListener("click", async function() {
wait_for_element('.map-popup__switch--unmarked').then(async () => { // Wait till a "mark" button appears
await Sleep(250);
if(GM_getValue("one-click-mark-switch")) // If popup still has content and the switch is enabled
document.querySelector(".map-popup__switch--unmarked").click();
});
});
});
});
})();
function toggle_one_click_mark() {
GM_setValue("one-click-mark-switch",!GM_getValue("one-click-mark-switch"));
refresh_switch("one-click-mark-switch", ".one_click_mark-switch__pic", "one_click_mark-switch__pic--active");
}
function refresh_switch(value_name, selector, pictureclass) {
let switch_image_container = document.querySelector(selector);
if(GM_getValue(value_name))
switch_image_container.classList.add(pictureclass);
else if(!GM_getValue(value_name))
switch_image_container.classList.remove(pictureclass);
}
// Custom styles variable
let styles = `
.k-one_click_mark {
position: absolute;
left: 4.15rem;
bottom: 1.8rem;
}
.one_click_mark-switch {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
cursor: pointer;
}
.one_click_mark-switch--folded {
left: .21rem;
}
.one_click_mark-switch__text {
color: #ece5d8;
text-shadow: -1px 0 #3b4354,0 1px #3b4354,1px 0 #3b4354,0 -1px #3b4354;
font-size: .18rem;
margin-bottom: .04rem;
}
.one_click_mark-switch__pic {
width: .72rem;
height: .36rem;
background-image: url();
background-position: 50%;
background-repeat: no-repeat;
background-size: 100%;
}
.one_click_mark-switch__pic--active {
background-image: url();
}`;
// Insert custom Styles
let style_sheet = document.createElement("style");
style_sheet.innerText = styles;
document.head.appendChild(style_sheet);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment