feat(web): 试看搜索书籍后返回书架时提示是否加入书架

This commit is contained in:
Xwite 2024-09-30 20:02:54 +08:00
parent c88849b075
commit 797bfd94fd
3 changed files with 33 additions and 4 deletions

View File

@ -7,6 +7,7 @@ export const useBookStore = defineStore("book", {
connectStatus: "正在连接后端服务器……",
connectType: "",
newConnect: true,
/**@type {Array<{respondTime:number}>} */
searchBooks: [],
shelf: [],
catalog: [],

View File

@ -492,7 +492,7 @@ onMounted(() => {
bookAuthor: bookAuthor,
bookUrl: bookUrl,
index: chapterIndex,
chapterPos: chapterPos,
chapterPos: chapterPos
};
localStorage.setItem(bookUrl, JSON.stringify(book));
}
@ -532,6 +532,7 @@ onMounted(() => {
);
});
onUnmounted(() => {
window.removeEventListener("keyup", handleKeyPress);
window.removeEventListener("keydown", ignoreKeyPress);
@ -541,6 +542,31 @@ onUnmounted(() => {
readSettingsVisible.value = false;
popCataVisible.value = false;
scrollObserver?.disconnect();
scrollObserver = null;
});
onBeforeRouteLeave(async ()=> {
let bookUrl = sessionStorage.getItem("bookUrl");
let bookName = sessionStorage.getItem("bookName");
let isSeachBook = sessionStorage.getItem("isSeachBook");
var book = JSON.parse(localStorage.getItem(bookUrl));
//
if (isSeachBook) {
await ElMessageBox.confirm(
`是否将《${bookName}》放入书架?`,
"放入书架",
{
confirmButtonText: "确认",
cancelButtonText: "否",
type: "info"
}
).then(() => {
//
}).catch(()=>{
//
API.deleteBook(book);
})
}
});
</script>

View File

@ -211,18 +211,20 @@ const handleBookClick = async (book) => {
durChapterPos = 0,
} = book;
// searchBook
if (book.durChapterIndex === undefined) {
const isSeachBook = "respondTime" in book
if (isSeachBook) {
await API.saveBook(book);
}
toDetail(bookUrl, name, author, durChapterIndex, durChapterPos);
toDetail(bookUrl, name, author, durChapterIndex, durChapterPos, isSeachBook);
};
const toDetail = (bookUrl, bookName, bookAuthor, chapterIndex, chapterPos) => {
const toDetail = (bookUrl, bookName, bookAuthor, chapterIndex, chapterPos, isSeachBook) => {
if (bookName === "尚无阅读记录") return;
sessionStorage.setItem("bookUrl", bookUrl);
sessionStorage.setItem("bookName", bookName);
sessionStorage.setItem("bookAuthor", bookAuthor);
sessionStorage.setItem("chapterIndex", chapterIndex);
sessionStorage.setItem("chapterPos", chapterPos);
sessionStorage.setItem("isSeachBook", isSeachBook);
readingRecent.value = {
name: bookName,
author: bookAuthor,