Jake Vanderwerf
2026-01-04 eea4e21d9bd7b89f7124fa1acbe3347d68db6d90
assets/js/concise/FrontendFavourites.js
@@ -1,21 +1,35 @@
class FrontendFavourites {
   constructor() {
      // Initialize DataStore for queue persistence
      this.store = new window.jvbStore({
         name: 'favourites',
         endpoint: 'favourites',
         useIndexedDB: true,
         TTL: Infinity,
         showLoading: false,
         filters: {
            user: jvbSettings.currentUser,
            content: 'all',
            order: 'desc',
            orderby: 'date',
            page: 1,
            all: true,
         }
      });
      this.store = window.jvbStore.register(
         'favourites',
         {
            storeName: 'favourites',
            endpoint: 'favourites',
            indexes: [
               {name: 'content', keyPath: 'content'},
               {name: 'listId', keyPath: 'listId'},
            ],
            TTL: 6 * 60 * 1000,
            showLoading: false,
            filters: {
               user: window.auth.getUser(),
               content: 'all',
               order: 'desc',
               orderby: 'date',
               page: 1,
               all: true,
            }
         });
      this.listStore = window.jvbStore.register(
         'favourites_lists',
         {
            storeName: 'lists',
            keyPath: 'listId',
            endpoint: 'favourites/lists',
            TTL: 6 * 60 * 1000,
         });
      this.store.subscribe((event, data) => {
         switch (event) {
@@ -37,7 +51,7 @@
   }
   toggleFavourite(button) {
      if (!jvbSettings.currentUser) {
      if (!window.auth.getUser()) {
         window.location.href = jvbSettings.redirect + '&action=register&type=favourites';
         return;
      }
@@ -61,17 +75,115 @@
      });
   }
   isFavourited(content, id){
      if(!jvbSettings.currentUser){
         return false;
      }
      let item = this.store.getItem(id);
      return (item) ? item.action === 'add' : false;
   // async toggleFavourite(itemType, itemId) {
   //    const favId = `${this.userId}_${itemType}_${itemId}`;
   //    const existing = this.store.get(favId);
   //
   //    if (existing) {
   //       // Remove favorite
   //       await this.store.delete(favId);
   //
   //       // Queue for server deletion
   //       if (window.jvbQueue) {
   //          window.jvbQueue.addOperation({
   //             type: 'remove_favourite',
   //             endpoint: 'favourites',
   //             data: { favId }
   //          });
   //       }
   //
   //       return false; // Not favorited anymore
   //
   //    } else {
   //       // Add favorite
   //       const favourite = {
   //          id: favId,
   //          userId: this.userId,
   //          itemType,
   //          itemId,
   //          listId: 'default',
   //          timestamp: Date.now()
   //       };
   //
   //       await this.store.save(favourite);
   //
   //       // Queue for server save
   //       if (window.jvbQueue) {
   //          window.jvbQueue.addOperation({
   //             type: 'add_favourite',
   //             endpoint: 'favourites',
   //             data: favourite
   //          });
   //       }
   //
   //       return true; // Now favorited
   //    }
   // }
   // async createList(name, visibility = 'private') {
   //    const list = {
   //       listId: `list_${Date.now()}`,
   //       userId: this.userId,
   //       name,
   //       visibility,
   //       created: Date.now(),
   //       itemCount: 0
   //    };
   //
   //    await this.listsStore.save(list);
   //
   //    // Queue for server
   //    if (window.jvbQueue) {
   //       window.jvbQueue.addOperation({
   //          type: 'create_list',
   //          endpoint: 'favourite-lists',
   //          data: list
   //       });
   //    }
   //
   //    return list;
   // }
   //
   // async addToList(listId, itemType, itemId) {
   //    const favId = `${this.userId}_${itemType}_${itemId}_${listId}`;
   //
   //    const favourite = {
   //       id: favId,
   //       userId: this.userId,
   //       itemType,
   //       itemId,
   //       listId,
   //       timestamp: Date.now()
   //    };
   //
   //    await this.store.save(favourite);
   //
   //    // Update list count
   //    const list = this.listsStore.get(listId);
   //    if (list) {
   //       list.itemCount++;
   //       await this.listsStore.save(list);
   //    }
   //
   //    // Queue for server
   //    if (window.jvbQueue) {
   //       window.jvbQueue.addOperation({
   //          type: 'add_to_list',
   //          endpoint: 'favourites',
   //          data: favourite
   //       });
   //    }
   // }
   isFavourited(itemType, itemId) {
      const favId = `${this.userId}_${itemType}_${itemId}`;
      return this.store.get(favId) !== undefined;
   }
}
document.addEventListener('DOMContentLoaded', function() {
   window.jvbFavourites = false;
   if (jvbSettings.currentUser !== '') {
   if (window.auth.getUser() !== '') {
      window.jvbFavourites = new FrontendFavourites();
   }
});