refactor: generalize API library

This commit is contained in:
spiral 2022-02-01 15:24:45 -05:00
parent 6d2fa78767
commit e74b5e1c13
No known key found for this signature in database
GPG key ID: A6059F0CA0E1BD31
26 changed files with 229 additions and 487 deletions

View file

@ -4,13 +4,13 @@
import { toHTML } from 'discord-markdown';
import twemoji from 'twemoji';
import type Member from '../../api/member';
import type Group from '../../api/group';
import GroupEdit from './GroupEdit.svelte';
import Edit from './Edit.svelte';
import Privacy from './Privacy.svelte';
import ProxyTags from './ProxyTags.svelte';
import { Member, Group } from '../../api/types';
export let groups: Group[] = [];
export let member: Member;
export let isPublic: boolean = false;

View file

@ -4,8 +4,8 @@
import autosize from 'svelte-autosize';
import moment from 'moment';
import Member from '../../api/member';
import PKAPI from '../../api';
import { Member } from '../../api/types'
import api from '../../api';
let loading: boolean = false;
export let member: Member;
@ -13,7 +13,7 @@
let err: string[] = [];
let input = new Member({name: member.name, display_name: member.display_name, birthday: member.birthday, pronouns: member.pronouns, color: member.color, description: member.description, banner: member.banner, avatar_url: member.avatar_url});
let input: Member = {...member};
const dispatch = createEventDispatcher();
@ -54,9 +54,8 @@
if (err.length > 0) return;
loading = true;
const api = new PKAPI();
try {
let res = await api.patchMember({token: localStorage.getItem("pk-token"), id: member.id, data: data});
let res = await api().members(member.id).patch({data});
member = res;
err = [];
update();
@ -89,9 +88,8 @@
return;
}
loading = true;
const api = new PKAPI();
try {
await api.deleteMember({token: localStorage.getItem("pk-token"), id: member.id});
await api().members(member.id).delete();
deleteErr = null;
toggleDeleteModal();
loading = false;

View file

@ -1,9 +1,6 @@
<script lang="ts">
import type Group from "../../api/group";
import type Member from "../../api/member";
import { Row, Col, Button, Alert, ListGroup, ListGroupItem, Spinner } from 'sveltestrap';
import { createEventDispatcher } from 'svelte';
import PKAPI from '../../api';
import ListPagination from "../ListPagination.svelte";
import twemoji from "twemoji";
import Svelecte, { addFormatter } from 'svelecte';
@ -13,6 +10,9 @@
import FaFolderPlus from 'svelte-icons/fa/FaFolderPlus.svelte'
import FaFolderMinus from 'svelte-icons/fa/FaFolderMinus.svelte'
import { Member, Group } from '../../api/types';
import api from '../../api';
export let member: Member;
export let groups: Group[] = [];
let loading: boolean = false;
@ -69,13 +69,11 @@
dispatch("updateGroups", groups);
}
const api = new PKAPI();
async function submitAdd() {
let data = groupsToBeAdded;
try {
loading = true;
await api.postMemberGroups({token: localStorage.getItem("pk-token"), id: member.id, data: data, removing: false});
await api().members(member.id).groups.add.post({data});
groups.forEach(group => data.includes(group.uuid) && group.members.push(member.uuid));
updateGroups();
err = null;
@ -92,7 +90,7 @@
let data = groupsToBeRemoved;
try {
loading = true;
await api.postMemberGroups({token: localStorage.getItem("pk-token"), id: member.id, data: data, removing: true});
await api().members(member.id).groups.remove.post({data});
groups.forEach(group => {if (data.includes(group.uuid)) group.members = group.members.filter(m => m !== member.uuid)});
updateGroups();
err = null;

View file

@ -4,15 +4,15 @@
import { onMount } from 'svelte';
import FaSearch from 'svelte-icons/fa/FaSearch.svelte'
import { useParams } from 'svelte-navigator';
import type Member from '../../api/member';
import type Group from '../../api/group'
import PKAPI from '../../api';
import CardsHeader from '../CardsHeader.svelte';
import ListPagination from '../ListPagination.svelte';
import Svelecte, { addFormatter } from 'svelecte';
import FaLock from 'svelte-icons/fa/FaLock.svelte';
import Body from './Body.svelte';
import { Member, Group } from '../../api/types';
import api from '../../api';
export let isPublic: boolean;
export let list: Member[] = [];
@ -43,12 +43,10 @@
if (token || isPublic) fetchMembers();
});
const api = new PKAPI();
async function fetchMembers() {
listLoading = true;
try {
const res: Member[] = await api.getMemberList({token: !isPublic && token, id: isPublic && id});
const res: Member[] = await api().systems(isPublic ? id : "@me").members.get({ auth: !isPublic });
list = res;
listLoading = false;
} catch (error) {

View file

@ -1,9 +1,10 @@
<script lang="ts">
import Member from "../../api/member";
import PKAPI from "../../api";
import { createEventDispatcher } from "svelte";
import { Col, Row, Input, Label, Button, Alert, Spinner } from "sveltestrap";
import { Member } from '../../api/types';
import api from '../../api';
let loading: boolean;
export let privacyOpen: boolean;
export let member: Member;
@ -33,16 +34,15 @@
dispatch('update', member);
}
let input = new Member({privacy: member.privacy});
let input: Member = {privacy: member.privacy};
async function submit() {
let data = input;
err = null;
loading = true;
const api = new PKAPI();
try {
let res = await api.patchMember({token: localStorage.getItem("pk-token"), id: member.id, data: data});
let res = await api().members(member.id).patch({data});
member = res;
update();
loading = false;

View file

@ -1,9 +1,10 @@
<script lang="ts">
import Member from "../../api/member";
import PKAPI from "../../api";
import { createEventDispatcher } from "svelte";
import { Col, Row, Input, Label, Button, Alert, Spinner, InputGroup } from "sveltestrap";
import { Member } from '../../api/types';
import api from '../../api';
let loading: boolean;
export let proxyOpen: boolean;
export let member: Member;
@ -26,12 +27,11 @@
return;
}
let data = new Member({proxy_tags: input});
const api = new PKAPI();
let data: Member = {proxy_tags: input};
loading = true;
try {
let res = await api.patchMember({token: localStorage.getItem("pk-token"), data: data, id: member.id});
let res = await api().members(member.id).patch({data});
member = res;
err = null;
update();