Commit 4dbd02ca authored by Duhoux Pierre-Louis's avatar Duhoux Pierre-Louis

Add context menu to bookmark a scan

parent ef994a00
......@@ -550,7 +550,11 @@
"message": "Note : $1",
"description": "Text to display the note for a bookmark. $1 is the note"
},
"background_bookmark_menu": {
"message": "Bookmark this scan",
"description": "Context menu when right click on a scan"
},
"bookmark_popup_title": {
"message": "Bookmark",
"description": "Title of the bookmark popup"
......
import store from '../store';
import * as utils from '../amr/utils';
import i18n from '../amr/i18n';
import browser from "webextension-polyfill";
class HandleBookmarks {
constructor() {
this.context_ids = [];
}
handle(message, sender) {
switch (message.action) {
case "getBookmarkNote":
......@@ -17,7 +22,21 @@ class HandleBookmarks {
case "addUpdateBookmark":
this.addBookmark(message);
return Promise.resolve({});
case "createContextMenu": //TODO
case "createContextMenu":
let url = message.lstUrls[0];
if (this.context_ids.indexOf(url) < 0) {
this.context_ids.push(url);
let id = browser.contextMenus.create({
title: i18n("background_bookmark_menu"),
contexts: ["image"],
onclick: function (info, tab) {
browser.tabs.executeScript(tab.id, {
code: "clickOnBM(\"" + info.srcUrl + "\")"
});
},
targetUrlPatterns: [encodeURI(url), url]
});
}
return Promise.resolve({});
}
}
......
......@@ -15,7 +15,7 @@ import HandleKeys from './handlekeys';
/**
* Every mirror implementation ends by a call to registerMangaObject
* This function is defined here.
* This script is injected by background script if the default content script (testcontent.js)
* This script is injected by background script if the default content script (testcontent.js)
* found that the page could be a manga page.
* Once loaded, the mirror implementation is called and results in this function call
*/
......@@ -64,7 +64,32 @@ window["registerMangaObject"] = async function (mirrorName, object) {
HandleKeys.init();
}
// TODO stats perso
// TODO context menu for bookmarks and bookmarks
// TODO stats perso --> v2.0.3
});
}
/** Function called through executeScript when context menu button invoked */
window["clickOnBM"] = function(src) {
let imgScan = $(".spanForImg img[src='" + src + "']");
if (imgScan.size() === 0) {
imgScan = $(".spanForImg img[src='" + decodeURI(src) + "']");
}
pageData.curbookmark.type = "scan";
pageData.curbookmark.scanUrl = src;
pageData.curbookmark.scanName = imgScan.data("idScan");
if (imgScan.data("note") !== undefined) {
$("#noteAMR").val(imgScan.data("note"));
} else {
$("#noteAMR").val("");
}
if (imgScan.data("booked")) {
$("#delBtnAMR").show();
} else {
$("#delBtnAMR").hide();
}
navigation.showDialog();
}
\ No newline at end of file
......@@ -66,9 +66,44 @@ a.buttonAMR:active {
font-family:Verdana!important;
}
#bookmarkPop {
display:none;
z-index:10000001;
.amr-modal {
display: none;
vertical-align: middle;
position: relative;
z-index: 10000001;
max-width: 500px;
box-sizing: border-box;
width: 90%;
background: #fff;
padding: 15px 30px;
-webkit-border-radius: 8px;
-moz-border-radius: 8px;
-o-border-radius: 8px;
-ms-border-radius: 8px;
border-radius: 8px;
-webkit-box-shadow: 0 0 10px #000;
-moz-box-shadow: 0 0 10px #000;
-o-box-shadow: 0 0 10px #000;
-ms-box-shadow: 0 0 10px #000;
box-shadow: 0 0 10px #000;
text-align: left;
color: black;
}
.amr-modal td {
color: black;
}
.amr-modal a.close-modal {
position: absolute;
top: -12.5px;
right: -12.5px;
display: block;
width: 30px;
height: 30px;
text-indent: -9999px;
background-size: contain;
background-repeat: no-repeat;
background-position: center center;
background-image: url('');
}
#simplemodal-overlay {
......
......@@ -237,7 +237,7 @@ class Navigation {
*/
async writeNavigation(where, select) {
//create bookmark popup
let div = $("<div id='bookmarkPop' style='display:none;position: static;padding: 20px!important;'></div>"),
let div = $("<div id='bookmarkPop' style='display:none;'></div>"),
btn = $("<a id='saveBtnAMR' class='buttonAMR'>" + i18n("button_save") + "</a>");
$("<h3>" + i18n("bookmark_popup_title") + "</h3>").appendTo(div);
$("<div id='descEltAMR'></div>").appendTo(div);
......@@ -480,7 +480,9 @@ class Navigation {
mirrorImpl.get().mirrorName);
}
$("#bookmarkPop #descEltAMR").text(textDesc);
$("#bookmarkPop").modal();
$("#bookmarkPop").modal({
modalClass: "amr-modal"
});
}
}
export default (new Navigation) // singleton
\ No newline at end of file
......@@ -238,31 +238,6 @@ class Reading {
divNum.appendTo($(img).closest(".spanForImg"));
}
clickOnBM(src) {
let imgScan = $(".spanForImg img[src='" + src + "']");
if (imgScan.size() === 0) {
imgScan = $(".spanForImg img[src='" + decodeURI(src) + "']");
}
pageData.curbookmark.type = "scan";
pageData.curbookmark.scanUrl = src;
pageData.curbookmark.scanName = imgScan.data("idScan");
if (imgScan.data("note") !== undefined) {
$("#noteAMR").val(imgScan.data("note"));
} else {
$("#noteAMR").val("");
}
if (imgScan.data("booked")) {
$("#delBtnAMR").show();
} else {
$("#delBtnAMR").hide();
}
$("#bookmarkPop").modal({ focus: false, onShow: this.showDialog, zIndex: 10000000 });
}
onErrorImage(img) {
let reading = this;
$(img).css("margin-bottom", "50px");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment