| | |
| | | class FrontendFavourites { |
| | | class Favourites { |
| | | constructor() { |
| | | // Initialize DataStore for queue persistence |
| | | this.store = new window.jvbStore({ |
| | | name: 'favourites', |
| | | storeName: 'favourites', |
| | | endpoint: 'favourites', |
| | | indexes: [ |
| | | {name: 'content', keyPath: 'content'}, |
| | | {name: 'listId', keyPath: 'listId'}, |
| | | ], |
| | | TTL: 86400000, |
| | | showLoading: false, |
| | | filters: { |
| | | user: jvbSettings.currentUser, |
| | | content: 'all', |
| | | order: 'desc', |
| | | orderby: 'date', |
| | | page: 1, |
| | | all: true, |
| | | } |
| | | }); |
| | | let store = window.jvbStore.register( |
| | | 'favourites', |
| | | { |
| | | storeName: 'favourites', |
| | | keyPath: 'id', |
| | | endpoint: 'favourites', |
| | | headers: { |
| | | 'X-Action-Nonce': window.auth.getNonce('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 = new window.jvbStore({ |
| | | name: 'favourites_lists', |
| | | storeName: 'lists', |
| | | keyPath: 'listId', |
| | | endpoint: 'favourites/lists', |
| | | TTL: 86400000, |
| | | }) |
| | | this.store = store.favourites; |
| | | |
| | | // 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) { |
| | |
| | | } |
| | | |
| | | }); |
| | | |
| | | this.store.fetch(); |
| | | } |
| | | |
| | | toggleFavourite(button) { |
| | | if (!jvbSettings.currentUser) { |
| | | if (!window.auth.getUser()) { |
| | | window.location.href = jvbSettings.redirect + '&action=register&type=favourites'; |
| | | return; |
| | | } |
| | |
| | | // Update button icon |
| | | button.innerHTML = jvbSettings.icons[button.classList.contains('favourited') ? 'heart-filled' : 'heart']; |
| | | |
| | | this.store.setItem(button.dataset.id, { |
| | | target_id: button.dataset.id, |
| | | action: action, |
| | | type: button.dataset.type, |
| | | artist: button.dataset.artist, |
| | | }); |
| | | window.debouncer.schedule( |
| | | `favourite-${button.dataset.id}`, |
| | | this.postFavourite({ |
| | | user: window.auth.getUser(), |
| | | target_id: button.dataset.id, |
| | | action: action, |
| | | type: button.dataset.type |
| | | }), |
| | | 100 |
| | | ); |
| | | |
| | | } |
| | | |
| | | async postFavourite(args) { |
| | | await window.auth.fetch( |
| | | `${jvbSettings.api}favourites`, |
| | | { |
| | | method: 'POST', |
| | | headers: { |
| | | 'X-Action-Nonce': window.auth.getNonce('favourites') |
| | | }, |
| | | body: args |
| | | } |
| | | ); |
| | | |
| | | if (args.action === 'add') { |
| | | await this.store.setItem(button.dataset.id, { |
| | | target_id: button.dataset.id, |
| | | action: action, |
| | | type: button.dataset.type, |
| | | }).then(()=>{}); |
| | | } else { |
| | | await this.store.delete(button.dataset.id).then(()=>{}); |
| | | } |
| | | } |
| | | |
| | | // async toggleFavourite(itemType, itemId) { |
| | |
| | | return this.store.get(favId) !== undefined; |
| | | } |
| | | } |
| | | |
| | | document.addEventListener('DOMContentLoaded', function() { |
| | | window.jvbFavourites = false; |
| | | if (jvbSettings.currentUser !== '') { |
| | | window.jvbFavourites = new FrontendFavourites(); |
| | | } |
| | | window.auth.subscribe((event) => { |
| | | if (event === 'auth-loaded') { |
| | | window.jvbFavourites = new Favourites(); |
| | | } |
| | | }); |
| | | }); |
| | | |
| | | |