import {ref, inject, computed, onBeforeUnmount} from 'vue'; import {router} from '@inertiajs/vue3'; import useQueueEvents from './useQueueEvents.js'; export function useIndex(props, siteName) { const axios = inject('axios'); const {startListener, stopListener} = useQueueEvents(siteName, () => reload(false)); const rawProps = JSON.parse(JSON.stringify(props)); const inner = { data: ref(rawProps.data), meta: ref(rawProps.meta), }; function toFilterString(data) { return btoa(encodeURIComponent(JSON.stringify(data))); } const filterString = computed(() => toFilterString(inner.meta.value.filter)); function reload(resetPage = true, withMeta = true, data) { var data = { filter: filterString.value, page: resetPage ? 1 : inner.meta.value.current_page, ...data, }; router.visit(window.location.pathname, { data, preserveState: true, only: ['data'], onSuccess: (page) => { inner.data.value = page.props.data.data; if (withMeta) { inner.meta.value = { ...inner.meta.value, ...page.props.data.meta, }; } }, }); } function reloadPage(page) { reload(false, true, {page: page}); } function can(permission) { return inner.meta.value.can[permission]; } function getFilter(value) { return inner.meta.value.filter[value]; } function setFilter(key, value) { inner.meta.value.filter[key] = value; reload(true); } function requestCallback(successMessage, failureMessage) { return { onSuccess: () => { this.$success(successMessage); reload(false); }, onFailure: () => { this.$error(failureMessage); reload(false); }, preserveState: true, }; } startListener(); onBeforeUnmount(() => stopListener()); return { data: inner.data, reload, can, getFilter, setFilter, requestCallback, meta: inner.meta, filterString, router, toFilterString, reloadPage, axios, }; } const indexProps = { data: { default: () => { return {data: [], meta: {}}; }, type: Object, }, }; export {indexProps};