2023-02-12 23:13:04 +01:00
|
|
|
import { defineStore } from 'pinia'
|
|
|
|
import {apiWrapper} from "../helpers/fetch-wrapper";
|
|
|
|
import {notify} from "@kyvg/vue3-notification";
|
|
|
|
import {interfaceStore} from "./interfaces";
|
2023-06-23 19:24:59 +02:00
|
|
|
import { freshPeer } from '@/helpers/models';
|
2023-02-12 23:13:04 +01:00
|
|
|
|
|
|
|
const baseUrl = `/peer`
|
|
|
|
|
|
|
|
export const peerStore = defineStore({
|
|
|
|
id: 'peers',
|
|
|
|
state: () => ({
|
|
|
|
peers: [],
|
2023-06-23 19:24:59 +02:00
|
|
|
peer: freshPeer(),
|
|
|
|
prepared: freshPeer(),
|
2023-02-12 23:13:04 +01:00
|
|
|
filter: "",
|
|
|
|
pageSize: 10,
|
|
|
|
pageOffset: 0,
|
|
|
|
pages: [],
|
|
|
|
fetching: false,
|
|
|
|
}),
|
|
|
|
getters: {
|
|
|
|
Find: (state) => {
|
|
|
|
return (id) => state.peers.find((p) => p.Identifier === id)
|
|
|
|
},
|
|
|
|
Count: (state) => state.peers.length,
|
2023-06-20 21:27:34 +02:00
|
|
|
Prepared: (state) => {console.log("STATE:", state.prepared); return state.prepared},
|
2023-02-12 23:13:04 +01:00
|
|
|
FilteredCount: (state) => state.Filtered.length,
|
|
|
|
All: (state) => state.peers,
|
|
|
|
Filtered: (state) => {
|
|
|
|
if (!state.filter) {
|
|
|
|
return state.peers
|
|
|
|
}
|
|
|
|
return state.peers.filter((p) => {
|
|
|
|
return p.DisplayName.includes(state.filter) || p.Identifier.includes(state.filter)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
FilteredAndPaged: (state) => {
|
|
|
|
return state.Filtered.slice(state.pageOffset, state.pageOffset + state.pageSize)
|
|
|
|
},
|
|
|
|
isFetching: (state) => state.fetching,
|
|
|
|
hasNextPage: (state) => state.pageOffset < (state.FilteredCount - state.pageSize),
|
|
|
|
hasPrevPage: (state) => state.pageOffset > 0,
|
|
|
|
currentPage: (state) => (state.pageOffset / state.pageSize)+1,
|
|
|
|
},
|
|
|
|
actions: {
|
|
|
|
afterPageSizeChange() {
|
|
|
|
// reset pageOffset to avoid problems with new page sizes
|
|
|
|
this.pageOffset = 0
|
|
|
|
this.calculatePages()
|
|
|
|
},
|
|
|
|
calculatePages() {
|
|
|
|
let pageCounter = 1;
|
|
|
|
this.pages = []
|
|
|
|
for (let i = 0; i < this.FilteredCount; i+=this.pageSize) {
|
|
|
|
this.pages.push(pageCounter++)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
gotoPage(page) {
|
|
|
|
this.pageOffset = (page-1) * this.pageSize
|
|
|
|
|
|
|
|
this.calculatePages()
|
|
|
|
},
|
|
|
|
nextPage() {
|
|
|
|
this.pageOffset += this.pageSize
|
|
|
|
|
|
|
|
this.calculatePages()
|
|
|
|
},
|
|
|
|
previousPage() {
|
|
|
|
this.pageOffset -= this.pageSize
|
|
|
|
|
|
|
|
this.calculatePages()
|
|
|
|
},
|
|
|
|
setPeers(peers) {
|
|
|
|
this.peers = peers
|
|
|
|
this.calculatePages()
|
|
|
|
this.fetching = false
|
|
|
|
},
|
2023-06-23 19:24:59 +02:00
|
|
|
setPeer(peer) {
|
|
|
|
this.peer = peer
|
|
|
|
this.fetching = false
|
|
|
|
},
|
2023-06-20 21:27:34 +02:00
|
|
|
setPreparedPeer(peer) {
|
|
|
|
this.prepared = peer;
|
|
|
|
},
|
|
|
|
async PreparePeer(interfaceId) {
|
2023-06-23 19:24:59 +02:00
|
|
|
return apiWrapper.get(`${baseUrl}/iface/${encodeURIComponent(interfaceId)}/prepare`)
|
2023-06-20 21:27:34 +02:00
|
|
|
.then(this.setPreparedPeer)
|
|
|
|
.catch(error => {
|
2023-06-23 19:24:59 +02:00
|
|
|
this.prepared = freshPeer()
|
2023-06-20 21:27:34 +02:00
|
|
|
console.log("Failed to load prepared peer: ", error)
|
|
|
|
notify({
|
|
|
|
title: "Backend Connection Failure",
|
|
|
|
text: "Failed to load prepared peer!",
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
2023-06-23 19:24:59 +02:00
|
|
|
async LoadPeer(id) {
|
|
|
|
this.fetching = true
|
|
|
|
return apiWrapper.get(`${baseUrl}/${encodeURIComponent(id)}`)
|
|
|
|
.then(this.setPeer)
|
|
|
|
.catch(error => {
|
|
|
|
this.setPeers([])
|
|
|
|
console.log("Failed to load peer: ", error)
|
|
|
|
notify({
|
|
|
|
title: "Backend Connection Failure",
|
|
|
|
text: "Failed to load peer!",
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
async DeletePeer(id) {
|
|
|
|
this.fetching = true
|
|
|
|
return apiWrapper.delete(`${baseUrl}/${encodeURIComponent(id)}`)
|
|
|
|
.then(() => {
|
|
|
|
this.peers = this.peers.filter(p => p.Identifier !== id)
|
|
|
|
this.fetching = false
|
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
this.fetching = false
|
|
|
|
console.log(error)
|
|
|
|
throw new Error(error)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
async UpdatePeer(id, formData) {
|
|
|
|
this.fetching = true
|
|
|
|
return apiWrapper.put(`${baseUrl}/${encodeURIComponent(id)}`, formData)
|
|
|
|
.then(peer => {
|
|
|
|
let idx = this.peers.findIndex((p) => p.Identifier === id)
|
|
|
|
this.peers[idx] = peer
|
|
|
|
this.fetching = false
|
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
this.fetching = false
|
|
|
|
console.log(error)
|
|
|
|
throw new Error(error)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
async CreatePeer(interfaceId, formData) {
|
|
|
|
this.fetching = true
|
|
|
|
return apiWrapper.post(`${baseUrl}/iface/${encodeURIComponent(interfaceId)}/new`, formData)
|
|
|
|
.then(peer => {
|
|
|
|
this.peers.push(peer)
|
|
|
|
this.fetching = false
|
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
this.fetching = false
|
|
|
|
console.log(error)
|
|
|
|
throw new Error(error)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
async LoadPeers(interfaceId) {
|
|
|
|
// if no interfaceId is given, use the currently selected interface
|
|
|
|
if (!interfaceId) {
|
|
|
|
interfaceId = interfaceStore().GetSelected.Identifier
|
|
|
|
if (!interfaceId) {
|
|
|
|
return // no interface, nothing to load
|
|
|
|
}
|
2023-02-12 23:13:04 +01:00
|
|
|
}
|
|
|
|
this.fetching = true
|
|
|
|
|
2023-06-23 19:24:59 +02:00
|
|
|
return apiWrapper.get(`${baseUrl}/iface/${encodeURIComponent(interfaceId)}/all`)
|
2023-02-12 23:13:04 +01:00
|
|
|
.then(this.setPeers)
|
|
|
|
.catch(error => {
|
|
|
|
this.setPeers([])
|
|
|
|
console.log("Failed to load peers: ", error)
|
|
|
|
notify({
|
|
|
|
title: "Backend Connection Failure",
|
|
|
|
text: "Failed to load peers!",
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|