Refactor Book model and related components for consistent property naming
- Replaced `id` with `bookId` in `BookProps` and updated corresponding references. - Added `tools` property to book-related components for tool management. - Removed unused `books` property from `User` model. - Added debug logs in `deleteBook` and `BookList` for troubleshooting.
This commit is contained in:
@@ -41,7 +41,7 @@ export interface SyncedBookTools {
|
||||
}
|
||||
|
||||
export interface BookProps {
|
||||
id: string;
|
||||
bookId: string;
|
||||
type: string;
|
||||
authorId: string;
|
||||
title: string;
|
||||
@@ -190,7 +190,7 @@ export default class Book {
|
||||
return await Promise.all(
|
||||
books.map(async (book: BookQuery): Promise<BookProps> => {
|
||||
return {
|
||||
id: book.book_id,
|
||||
bookId: book.book_id,
|
||||
type: book.type,
|
||||
authorId: book.author_id,
|
||||
title: System.decryptDataWithUserKey(book.title, userKey),
|
||||
@@ -254,7 +254,7 @@ export default class Book {
|
||||
book.getBookInfos(userId);
|
||||
const bookTools: BookToolsTable | null = BookRepo.fetchBookTools(userId, bookId, lang);
|
||||
return {
|
||||
id: book.getId(),
|
||||
bookId: book.getId(),
|
||||
type: book.getType(),
|
||||
authorId: book.getAuthorId(),
|
||||
title: book.getTitle(),
|
||||
|
||||
@@ -44,7 +44,6 @@ export interface UserInfoResponse {
|
||||
groupId: number;
|
||||
termsAccepted: boolean;
|
||||
guideTour: GuideTour[];
|
||||
books: BookSummary[];
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -105,7 +104,6 @@ export default class User {
|
||||
public static async returnUserInfos(userId: string): Promise<UserInfoResponse> {
|
||||
const user: User = new User(userId);
|
||||
await user.getUserInfos();
|
||||
const userBooks: BookProps[] = await Book.getBooks(userId);
|
||||
const guideTourStatus: GuideTour[] = [];
|
||||
return {
|
||||
id: user.getId(),
|
||||
@@ -118,13 +116,6 @@ export default class User {
|
||||
groupId: user.getGroupId(),
|
||||
termsAccepted: user.isTermsAccepted(),
|
||||
guideTour: guideTourStatus,
|
||||
books: userBooks.map((book: BookProps): BookSummary => {
|
||||
return {
|
||||
bookId: book.id,
|
||||
title: book.title,
|
||||
subTitle: book.subTitle,
|
||||
};
|
||||
})
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
@@ -260,6 +260,7 @@ export default class BookRepo {
|
||||
* @returns true if the deletion was successful
|
||||
*/
|
||||
public static deleteBook(userId: string, bookId: string, lang: 'fr' | 'en'): boolean {
|
||||
console.log(`Deleting book with ID ${bookId} for user ${userId}`)
|
||||
try {
|
||||
const db: Database = System.getDb();
|
||||
const query: string = 'DELETE FROM erit_books WHERE author_id=? AND book_id=?';
|
||||
|
||||
Reference in New Issue
Block a user