sharded-gotify/ui/src/stores/AppStore.ts

47 lines
1.6 KiB
TypeScript

import {BaseStore} from './BaseStore';
import axios from 'axios';
import * as config from '../config';
import {action} from 'mobx';
import {SnackReporter} from '../snack/SnackManager';
export class AppStore extends BaseStore<IApplication> {
public constructor(private readonly snack: SnackReporter) {
super();
}
protected requestItems = (): Promise<IApplication[]> => {
return axios
.get<IApplication[]>(`${config.get('url')}application`)
.then((response) => response.data);
};
protected requestDelete = (id: number): Promise<void> => {
return axios
.delete(`${config.get('url')}application/${id}`)
.then(() => this.snack('Application deleted'));
};
@action
public uploadImage = async (id: number, file: Blob): Promise<void> => {
const formData = new FormData();
formData.append('file', file);
await axios.post(`${config.get('url')}application/${id}/image`, formData, {
headers: {'content-type': 'multipart/form-data'},
});
await this.refresh();
this.snack('Application image updated');
};
@action
public create = async (name: string, description: string): Promise<void> => {
await axios.post(`${config.get('url')}application`, {name, description});
await this.refresh();
this.snack('Application created');
};
public getName = (id: number): string => {
const app = this.getByIDOrUndefined(id);
return id === -1 ? 'All Messages' : app !== undefined ? app.name : 'unknown';
};
}