mirror of
https://github.com/perfect-panel/ppanel-web.git
synced 2026-02-17 22:01:10 -05:00
🐛 fix: Add fetchTags method to NodesPage and ensure tags are fetched alongside nodes
This commit is contained in:
parent
1b715c5f8b
commit
a3c5e31094
@ -27,7 +27,7 @@ export default function NodesPage() {
|
|||||||
|
|
||||||
// Use our zustand store for server data
|
// Use our zustand store for server data
|
||||||
const { getServerName, getServerAddress, getProtocolPort } = useServer();
|
const { getServerName, getServerAddress, getProtocolPort } = useServer();
|
||||||
const { fetchNodes } = useNode();
|
const { fetchNodes, fetchTags } = useNode();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<ProTable<API.Node, { search: string }>
|
<ProTable<API.Node, { search: string }>
|
||||||
@ -55,6 +55,7 @@ export default function NodesPage() {
|
|||||||
toast.success(t('created'));
|
toast.success(t('created'));
|
||||||
ref.current?.refresh();
|
ref.current?.refresh();
|
||||||
fetchNodes();
|
fetchNodes();
|
||||||
|
fetchTags();
|
||||||
setLoading(false);
|
setLoading(false);
|
||||||
return true;
|
return true;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
@ -77,6 +78,7 @@ export default function NodesPage() {
|
|||||||
toast.success(v ? t('enabled_on') : t('enabled_off'));
|
toast.success(v ? t('enabled_on') : t('enabled_off'));
|
||||||
ref.current?.refresh();
|
ref.current?.refresh();
|
||||||
fetchNodes();
|
fetchNodes();
|
||||||
|
fetchTags();
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
),
|
),
|
||||||
@ -151,6 +153,7 @@ export default function NodesPage() {
|
|||||||
toast.success(t('updated'));
|
toast.success(t('updated'));
|
||||||
ref.current?.refresh();
|
ref.current?.refresh();
|
||||||
fetchNodes();
|
fetchNodes();
|
||||||
|
fetchTags();
|
||||||
setLoading(false);
|
setLoading(false);
|
||||||
return true;
|
return true;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
@ -169,6 +172,7 @@ export default function NodesPage() {
|
|||||||
toast.success(t('deleted'));
|
toast.success(t('deleted'));
|
||||||
ref.current?.refresh();
|
ref.current?.refresh();
|
||||||
fetchNodes();
|
fetchNodes();
|
||||||
|
fetchTags();
|
||||||
}}
|
}}
|
||||||
cancelText={t('cancel')}
|
cancelText={t('cancel')}
|
||||||
confirmText={t('confirm')}
|
confirmText={t('confirm')}
|
||||||
@ -185,6 +189,7 @@ export default function NodesPage() {
|
|||||||
toast.success(t('copied'));
|
toast.success(t('copied'));
|
||||||
ref.current?.refresh();
|
ref.current?.refresh();
|
||||||
fetchNodes();
|
fetchNodes();
|
||||||
|
fetchTags();
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
{t('copy')}
|
{t('copy')}
|
||||||
@ -202,6 +207,7 @@ export default function NodesPage() {
|
|||||||
toast.success(t('deleted'));
|
toast.success(t('deleted'));
|
||||||
ref.current?.refresh();
|
ref.current?.refresh();
|
||||||
fetchNodes();
|
fetchNodes();
|
||||||
|
fetchTags();
|
||||||
}}
|
}}
|
||||||
cancelText={t('cancel')}
|
cancelText={t('cancel')}
|
||||||
confirmText={t('confirm')}
|
confirmText={t('confirm')}
|
||||||
|
|||||||
@ -6,6 +6,10 @@ interface NodeState {
|
|||||||
nodes: API.Node[];
|
nodes: API.Node[];
|
||||||
tags: string[];
|
tags: string[];
|
||||||
|
|
||||||
|
// Loading states
|
||||||
|
loading: boolean;
|
||||||
|
loadingTags: boolean;
|
||||||
|
|
||||||
// Actions
|
// Actions
|
||||||
fetchNodes: () => Promise<void>;
|
fetchNodes: () => Promise<void>;
|
||||||
fetchTags: () => Promise<void>;
|
fetchTags: () => Promise<void>;
|
||||||
@ -24,23 +28,35 @@ export const useNodeStore = create<NodeState>((set, get) => ({
|
|||||||
// Initial state
|
// Initial state
|
||||||
nodes: [],
|
nodes: [],
|
||||||
tags: [],
|
tags: [],
|
||||||
|
loading: false,
|
||||||
|
loadingTags: false,
|
||||||
|
|
||||||
// Actions
|
// Actions
|
||||||
fetchNodes: async () => {
|
fetchNodes: async () => {
|
||||||
|
if (get().loading) return;
|
||||||
|
|
||||||
|
set({ loading: true });
|
||||||
try {
|
try {
|
||||||
const { data } = await filterNodeList({ page: 1, size: 999999999 });
|
const { data } = await filterNodeList({ page: 1, size: 999999999 });
|
||||||
set({ nodes: data?.data?.list || [] });
|
set({ nodes: data?.data?.list || [] });
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Handle error silently
|
// Handle error silently
|
||||||
|
} finally {
|
||||||
|
set({ loading: false });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
fetchTags: async () => {
|
fetchTags: async () => {
|
||||||
|
if (get().loadingTags) return;
|
||||||
|
|
||||||
|
set({ loadingTags: true });
|
||||||
try {
|
try {
|
||||||
const { data } = await queryNodeTag();
|
const { data } = await queryNodeTag();
|
||||||
set({ tags: data?.data?.tags || [] });
|
set({ tags: data?.data?.tags || [] });
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Handle error silently
|
// Handle error silently
|
||||||
|
} finally {
|
||||||
|
set({ loadingTags: false });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -88,16 +104,18 @@ export const useNode = () => {
|
|||||||
const store = useNodeStore();
|
const store = useNodeStore();
|
||||||
|
|
||||||
// Auto-fetch nodes and tags
|
// Auto-fetch nodes and tags
|
||||||
if (store.nodes.length === 0) {
|
if (store.nodes.length === 0 && !store.loading) {
|
||||||
store.fetchNodes();
|
store.fetchNodes();
|
||||||
}
|
}
|
||||||
if (store.tags.length === 0) {
|
if (store.tags.length === 0 && !store.loadingTags) {
|
||||||
store.fetchTags();
|
store.fetchTags();
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
nodes: store.nodes,
|
nodes: store.nodes,
|
||||||
tags: store.tags,
|
tags: store.tags,
|
||||||
|
loading: store.loading,
|
||||||
|
loadingTags: store.loadingTags,
|
||||||
fetchNodes: store.fetchNodes,
|
fetchNodes: store.fetchNodes,
|
||||||
fetchTags: store.fetchTags,
|
fetchTags: store.fetchTags,
|
||||||
getNodeById: store.getNodeById,
|
getNodeById: store.getNodeById,
|
||||||
|
|||||||
@ -5,6 +5,9 @@ interface ServerState {
|
|||||||
// Data
|
// Data
|
||||||
servers: API.Server[];
|
servers: API.Server[];
|
||||||
|
|
||||||
|
// Loading states
|
||||||
|
loading: boolean;
|
||||||
|
|
||||||
// Actions
|
// Actions
|
||||||
fetchServers: () => Promise<void>;
|
fetchServers: () => Promise<void>;
|
||||||
|
|
||||||
@ -20,14 +23,20 @@ interface ServerState {
|
|||||||
export const useServerStore = create<ServerState>((set, get) => ({
|
export const useServerStore = create<ServerState>((set, get) => ({
|
||||||
// Initial state
|
// Initial state
|
||||||
servers: [],
|
servers: [],
|
||||||
|
loading: false,
|
||||||
|
|
||||||
// Actions
|
// Actions
|
||||||
fetchServers: async () => {
|
fetchServers: async () => {
|
||||||
|
if (get().loading) return;
|
||||||
|
|
||||||
|
set({ loading: true });
|
||||||
try {
|
try {
|
||||||
const { data } = await filterServerList({ page: 1, size: 999999999 });
|
const { data } = await filterServerList({ page: 1, size: 999999999 });
|
||||||
set({ servers: data?.data?.list || [] });
|
set({ servers: data?.data?.list || [] });
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Handle error silently
|
// Handle error silently
|
||||||
|
} finally {
|
||||||
|
set({ loading: false });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -75,12 +84,13 @@ export const useServer = () => {
|
|||||||
const store = useServerStore();
|
const store = useServerStore();
|
||||||
|
|
||||||
// Auto-fetch servers
|
// Auto-fetch servers
|
||||||
if (store.servers.length === 0) {
|
if (store.servers.length === 0 && !store.loading) {
|
||||||
store.fetchServers();
|
store.fetchServers();
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
servers: store.servers,
|
servers: store.servers,
|
||||||
|
loading: store.loading,
|
||||||
fetchServers: store.fetchServers,
|
fetchServers: store.fetchServers,
|
||||||
getServerById: store.getServerById,
|
getServerById: store.getServerById,
|
||||||
getServerName: store.getServerName,
|
getServerName: store.getServerName,
|
||||||
|
|||||||
@ -5,6 +5,9 @@ interface SubscribeState {
|
|||||||
// Data
|
// Data
|
||||||
subscribes: API.SubscribeItem[];
|
subscribes: API.SubscribeItem[];
|
||||||
|
|
||||||
|
// Loading states
|
||||||
|
loading: boolean;
|
||||||
|
|
||||||
// Actions
|
// Actions
|
||||||
fetchSubscribes: () => Promise<void>;
|
fetchSubscribes: () => Promise<void>;
|
||||||
|
|
||||||
@ -16,14 +19,20 @@ interface SubscribeState {
|
|||||||
export const useSubscribeStore = create<SubscribeState>((set, get) => ({
|
export const useSubscribeStore = create<SubscribeState>((set, get) => ({
|
||||||
// Initial state
|
// Initial state
|
||||||
subscribes: [],
|
subscribes: [],
|
||||||
|
loading: false,
|
||||||
|
|
||||||
// Actions
|
// Actions
|
||||||
fetchSubscribes: async () => {
|
fetchSubscribes: async () => {
|
||||||
|
if (get().loading) return;
|
||||||
|
|
||||||
|
set({ loading: true });
|
||||||
try {
|
try {
|
||||||
const { data } = await getSubscribeList({ page: 1, size: 999999999 });
|
const { data } = await getSubscribeList({ page: 1, size: 999999999 });
|
||||||
set({ subscribes: data?.data?.list || [] });
|
set({ subscribes: data?.data?.list || [] });
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Handle error silently
|
// Handle error silently
|
||||||
|
} finally {
|
||||||
|
set({ loading: false });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -43,12 +52,13 @@ export const useSubscribe = () => {
|
|||||||
const store = useSubscribeStore();
|
const store = useSubscribeStore();
|
||||||
|
|
||||||
// Auto-fetch subscribes
|
// Auto-fetch subscribes
|
||||||
if (store.subscribes.length === 0) {
|
if (store.subscribes.length === 0 && !store.loading) {
|
||||||
store.fetchSubscribes();
|
store.fetchSubscribes();
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
subscribes: store.subscribes,
|
subscribes: store.subscribes,
|
||||||
|
loading: store.loading,
|
||||||
fetchSubscribes: store.fetchSubscribes,
|
fetchSubscribes: store.fetchSubscribes,
|
||||||
getSubscribeName: store.getSubscribeName,
|
getSubscribeName: store.getSubscribeName,
|
||||||
getSubscribeById: store.getSubscribeById,
|
getSubscribeById: store.getSubscribeById,
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user