mirror of
				https://github.com/hibiken/asynqmon.git
				synced 2025-10-26 16:26:12 +08:00 
			
		
		
		
	Create usePolling custom hook
This commit is contained in:
		| @@ -1,4 +1,4 @@ | ||||
| import React, { useEffect, useState } from "react"; | ||||
| import React, { useCallback, useState } from "react"; | ||||
| import { connect, ConnectedProps } from "react-redux"; | ||||
| import { makeStyles } from "@material-ui/core/styles"; | ||||
| import Table from "@material-ui/core/Table"; | ||||
| @@ -28,6 +28,7 @@ import TablePaginationActions, { | ||||
| import { listPendingTasksAsync } from "../actions/tasksActions"; | ||||
| import { AppState } from "../store"; | ||||
| import { PendingTask } from "../api"; | ||||
| import { usePolling } from "../hooks"; | ||||
|  | ||||
| const useStyles = makeStyles({ | ||||
|   table: { | ||||
| @@ -74,14 +75,12 @@ function PendingTasksTable(props: Props & ReduxProps) { | ||||
|     setPage(0); | ||||
|   }; | ||||
|  | ||||
|   useEffect(() => { | ||||
|   const fetchData = useCallback(() => { | ||||
|     const pageOpts = { page: page + 1, size: pageSize }; | ||||
|     listPendingTasksAsync(queue, pageOpts); | ||||
|     const interval = setInterval(() => { | ||||
|       listPendingTasksAsync(queue, pageOpts); | ||||
|     }, pollInterval * 1000); | ||||
|     return () => clearInterval(interval); | ||||
|   }, [pollInterval, listPendingTasksAsync, queue, page, pageSize]); | ||||
|   }, [page, pageSize, queue, listPendingTasksAsync]); | ||||
|  | ||||
|   usePolling(fetchData, pollInterval); | ||||
|  | ||||
|   if (props.tasks.length === 0) { | ||||
|     return ( | ||||
|   | ||||
		Reference in New Issue
	
	Block a user