Files
memberApp/src/vueLib/tables/workspaces/WorkspaceTable.ts
2026-02-19 10:49:12 +01:00

79 lines
1.9 KiB
TypeScript

import { appApi } from 'src/boot/axios';
import { ref, computed } from 'vue';
import { useNotify } from 'src/vueLib/general/useNotify';
import { i18n } from 'boot/lang';
import type { Workspaces } from 'src/vueLib/models/workspaces';
// import { useUserStore } from 'src/vueLib/login/userStore';
// import { useLogin } from 'src/vueLib/login/useLogin';
export const workspaces = ref<Workspaces>([]);
export function useWorkspaceTable() {
const pagination = ref({
sortBy: 'name',
descending: false,
page: 1,
rowsPerPage: 20,
});
const columns = computed(() => [
{
name: 'name',
align: 'left' as const,
label: i18n.global.t('name'),
field: 'name',
sortable: true,
},
{
name: 'description',
align: 'left' as const,
label: i18n.global.t('description'),
field: 'description',
style: 'width: 120px; max-width: 120px;',
},
{ name: 'option', align: 'center' as const, label: '', field: 'option', icon: 'option' },
]);
const { NotifyResponse } = useNotify();
const loading = ref(false);
// const userStore = useUserStore();
// const login = useLogin();
//updates user list from database
async function updateWorkspaces() {
loading.value = true;
await appApi
.get('workspaces?id=0')
.then((resp) => {
if (resp.data === null) {
workspaces.value = [];
return;
}
workspaces.value = resp.data as Workspaces;
if (workspaces.value === null) {
workspaces.value = [];
return;
}
})
.catch((err) => {
NotifyResponse(err, 'error');
})
.finally(() => {
loading.value = false;
});
await appApi
.post('users/update', { id: 1, workspaces: workspaces.value })
.catch((err) => NotifyResponse(err, 'error'));
}
return {
workspaces,
pagination,
columns,
loading,
updateWorkspaces,
};
}