think/packages/client/src/data/message.ts

81 lines
1.6 KiB
TypeScript
Raw Normal View History

2022-03-11 05:57:55 +00:00
import type { IMessage } from "@think/domains";
2022-02-20 11:51:55 +00:00
import { useState } from "react";
import useSWR from "swr";
import { HttpClient } from "services/HttpClient";
/**
*
* @returns
*/
export const useAllMessages = () => {
const [page, setPage] = useState(1);
const { data, error, mutate } = useSWR<{
data: Array<IMessage>;
total: number;
}>(`/message/all?page=${page}`, (url) => HttpClient.get(url), {
2022-03-11 05:57:55 +00:00
// refreshInterval: 200,
2022-02-20 11:51:55 +00:00
});
const loading = !data && !error;
return {
data,
loading,
error,
page,
setPage,
};
};
/**
*
* @returns
*/
export const useReadMessages = () => {
const [page, setPage] = useState(1);
const { data, error, mutate } = useSWR<{
data: Array<IMessage>;
total: number;
}>(`/message/read?page=${page}`, (url) => HttpClient.get(url), {
2022-03-11 05:57:55 +00:00
// refreshInterval: 200,
2022-02-20 11:51:55 +00:00
});
const loading = !data && !error;
return {
data,
loading,
error,
page,
setPage,
};
};
/**
*
* @returns
*/
export const useUnreadMessages = () => {
const [page, setPage] = useState(1);
const { data, error, mutate } = useSWR<{
data: Array<IMessage>;
total: number;
}>(`/message/unread?page=${page}`, (url) => HttpClient.get(url), {
2022-03-11 05:57:55 +00:00
// refreshInterval: 200,
2022-02-20 11:51:55 +00:00
});
const loading = !data && !error;
const readMessage = async (messageId) => {
const ret = await HttpClient.post(`/message/read/${messageId}`);
mutate();
return ret;
};
return {
data,
loading,
error,
page,
setPage,
readMessage,
};
};