Skip to content

Commit

Permalink
bug report: revert pr #180 "fix: remove repetitive quota refresh inte…
Browse files Browse the repository at this point in the history
…rval"

bug report: revert pr #180 "fix: remove repetitive quota refresh interval"
  • Loading branch information
zmh-program authored Jun 2, 2024
2 parents f860a99 + 1b02fad commit f7200fc
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 31 deletions.
23 changes: 3 additions & 20 deletions app/src/components/home/SideBar.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
import { useTranslation } from "react-i18next";
import { useDispatch, useSelector } from "react-redux";
import auth, { selectAuthenticated, selectUsername } from "@/store/auth.ts";
import { selectAuthenticated, selectUsername } from "@/store/auth.ts";
import {
closeMarket,
selectCurrent,
selectHistory,
selectMaskItem,
useConversationActions,
} from "@/store/chat.ts";
import React, { useCallback, useRef, useState } from "react";
import React, { useRef, useState } from "react";
import { ConversationInstance } from "@/api/types.tsx";
import { useToast } from "@/components/ui/use-toast.ts";
import { extractMessage, filterMessage } from "@/utils/processor.ts";
Expand Down Expand Up @@ -46,9 +46,6 @@ import { goAuth } from "@/utils/app.ts";
import Avatar from "@/components/Avatar.tsx";
import { cn } from "@/components/ui/lib/utils.ts";
import { getNumberMemory } from "@/utils/memory.ts";
import { refreshSubscription } from "@/store/subscription.ts";
import { refreshQuota } from "@/store/quota.ts";
import { AppDispatch } from "@/store";

type Operation = {
target: ConversationInstance | null;
Expand Down Expand Up @@ -332,25 +329,11 @@ function SidebarConversationList({

function SidebarMenu() {
const username = useSelector(selectUsername);
const dispatch: AppDispatch = useDispatch();
const updateQuota = useCallback(() => {
dispatch(refreshQuota()); // 调用 refreshQuota 更新配额
}, [dispatch]);
const handleRefreshSubscription = async () => {
if (!auth) {
return;
}
await refreshSubscription(dispatch);
};
return (
<div className={`sidebar-menu`}>
<Separator orientation={`horizontal`} className={`mb-2`} />
<MenuBar className={`menu-bar`}>
<Button variant={`ghost`} className={`sidebar-wrapper`}
onClick={() => {
updateQuota();
handleRefreshSubscription();
}}>
<Button variant={`ghost`} className={`sidebar-wrapper`}>
<Avatar username={username} />
<span className={`username`}>{username}</span>
<MoreHorizontal className={`h-4 w-4`} />
Expand Down
7 changes: 5 additions & 2 deletions app/src/dialogs/QuotaDialog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,10 @@ function QuotaDialog() {
const dispatch = useDispatch();
useEffectAsync(async () => {
if (!auth) return;
await refreshQuota();
const task = setInterval(() => refreshQuota(dispatch), 5000);
await refreshQuota(dispatch);

return () => clearInterval(task);
}, [auth]);

return (
Expand Down Expand Up @@ -319,7 +322,7 @@ function QuotaDialog() {
}),
});
setRedeem("");
await refreshQuota();
await refreshQuota(dispatch);
} else {
toast({
title: t("buy.exchange-failed"),
Expand Down
3 changes: 3 additions & 0 deletions app/src/dialogs/SubscriptionDialog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,10 @@ function SubscriptionDialog() {
const dispatch = useDispatch();
useEffectAsync(async () => {
if (!auth) return;
const task = setInterval(() => refreshSubscription(dispatch), 10000);
await refreshSubscription(dispatch);

return () => clearInterval(task);
}, [auth]);

return (
Expand Down
15 changes: 6 additions & 9 deletions app/src/store/quota.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';
import { RootState } from "./index.ts";
import { createSlice } from "@reduxjs/toolkit";
import { AppDispatch, RootState } from "./index.ts";
import { getQuota } from "@/api/quota.ts";

export const quotaSlice = createSlice({
Expand Down Expand Up @@ -49,10 +49,7 @@ export const quotaValueSelector = (state: RootState): number =>
state.quota.quota;
export const quotaSelector = (state: RootState): number => state.quota.quota;

export const refreshQuota = createAsyncThunk(
'quota/refreshQuota',
async (_, { dispatch }) => {
const quota = await getQuota();
dispatch(setQuota(quota));
}
);
export const refreshQuota = async (dispatch: AppDispatch) => {
const quota = await getQuota();
dispatch(setQuota(quota));
};

0 comments on commit f7200fc

Please sign in to comment.