Files
danbooru/app/javascript/src/javascripts/post_mode_menu.js
NamelessContributor 3b63174525 post_mode_menu: update preview link selector
Fixes the post-score link triggering the mode menu action as well as
all three score links getting the blue border on hover.
2022-03-09 10:01:09 +01:00

164 lines
5.0 KiB
JavaScript

import Post from './posts.js'
import Utility from './utility'
let PostModeMenu = {};
PostModeMenu.initialize = function() {
if ($("#c-posts").length || $("#c-favorites").length || $("#c-pools").length) {
this.initialize_selector();
this.initialize_preview_link();
this.initialize_edit_form();
this.initialize_tag_script_field();
this.initialize_shortcuts();
PostModeMenu.change();
}
}
PostModeMenu.initialize_shortcuts = function() {
Utility.keydown("1 2 3 4 5 6 7 8 9 0", "change_tag_script", PostModeMenu.change_tag_script);
}
PostModeMenu.show_notice = function(mode, tag_script_index = 0) {
if (mode === "add-fav") {
Utility.notice("Switched to favorite mode. Click a post to favorite it.");
} else if (mode === "remove-fav") {
Utility.notice("Switched to unfavorite mode. Click a post to unfavorite it.");
} else if (mode === "edit") {
Utility.notice("Switched to edit mode. Click a post to edit it.");
} else if (mode === "tag-script") {
Utility.notice(`Switched to tag script #${tag_script_index}. To switch tag scripts, use the number keys.`);
}
}
PostModeMenu.change_tag_script = function(e) {
if ($("#mode-box select").val() === "tag-script") {
var old_tag_script_id = localStorage.getItem("current_tag_script_id") || "1";
var keycode = e.which >= 96 ? e.which - 48 : e.which;
var new_tag_script_id = String.fromCharCode(keycode);
var new_tag_script = localStorage.getItem("tag-script-" + new_tag_script_id);
$("#tag-script-field").val(new_tag_script);
localStorage.setItem("current_tag_script_id", new_tag_script_id);
if (old_tag_script_id !== new_tag_script_id) {
PostModeMenu.show_notice("tag-script", new_tag_script_id);
}
e.preventDefault();
}
}
PostModeMenu.initialize_selector = function() {
let mode = localStorage.getItem("mode");
if (mode === null) {
localStorage.setItem("mode", "view");
$("#mode-box select").val("view");
} else {
$("#mode-box select").val(mode);
}
$("#mode-box select").on("change.danbooru", function(e) {
PostModeMenu.change();
$("#tag-script-field:visible").focus().select();
});
}
PostModeMenu.initialize_preview_link = function() {
$(document).on("click.danbooru", ".post-preview-container a", PostModeMenu.click);
}
PostModeMenu.initialize_edit_form = function() {
$("#quick-edit-div").hide();
$(document).on("click.danbooru", "#quick-edit-form button[name=cancel]", function(e) {
PostModeMenu.close_edit_form();
e.preventDefault();
});
$(document).on("click.danbooru", "#quick-edit-form input[type=submit]", async function(e) {
e.preventDefault();
let post_id = $("#quick-edit-form").attr("data-post-id");
await Post.update(post_id, "quick-edit", { post: { tag_string: $("#post_tag_string").val() }});
});
}
PostModeMenu.close_edit_form = function() {
$("#quick-edit-div").slideUp("fast");
$("#post_tag_string").data("uiAutocomplete").close();
}
PostModeMenu.initialize_tag_script_field = function() {
$("#tag-script-field").blur(function(e) {
var script = $(this).val();
if (script) {
var current_script_id = localStorage.getItem("current_tag_script_id");
localStorage.setItem("tag-script-" + current_script_id, script);
} else {
$("#mode-box select").val("view");
PostModeMenu.change();
}
});
}
PostModeMenu.change = function() {
$("#quick-edit-div").slideUp("fast");
var s = $("#mode-box select").val();
if (s === undefined) {
return;
}
$("body").attr("data-mode-menu-active", s !== "view");
$("body").attr("data-mode-menu", s);
localStorage.setItem("mode", s, 1);
if (s === "tag-script") {
var current_script_id = localStorage.getItem("current_tag_script_id");
if (!current_script_id) {
current_script_id = "1";
localStorage.setItem("current_tag_script_id", current_script_id);
}
var script = localStorage.getItem("tag-script-" + current_script_id);
$("#tag-script-field").val(script).show();
PostModeMenu.show_notice(s, current_script_id);
} else {
$("#tag-script-field").hide();
PostModeMenu.show_notice(s);
}
}
PostModeMenu.open_edit = function(post_id) {
var $post = $("#post_" + post_id);
$("#quick-edit-div").slideDown("fast");
$("#quick-edit-form").attr("data-post-id", post_id);
$("#post_tag_string").val($post.data("tags") + " ").focus().selectEnd();
}
PostModeMenu.click = function(e) {
var s = $("#mode-box select").val();
var post_id = $(e.target).closest("article").data("id");
if (s === "add-fav") {
Post.tag(post_id, "fav:me");
} else if (s === "remove-fav") {
Post.tag(post_id, "-fav:me");
} else if (s === "edit") {
PostModeMenu.open_edit(post_id);
} else if (s === "tag-script") {
var current_script_id = localStorage.getItem("current_tag_script_id");
var tag_script = localStorage.getItem("tag-script-" + current_script_id) ?? "";
Post.tag(post_id, tag_script);
} else {
return;
}
e.preventDefault();
}
$(function() {
PostModeMenu.initialize();
});
export default PostModeMenu