heartbeat-monitor/node_modules/next/dist/esm/client/components/use-reducer.js
Matt Bruce bed1169443 Initial commit: Heartbeat Monitor dashboard
- Full-featured monitoring dashboard for local web apps
- Real-time status tracking with uptime percentages
- Visual sparklines for status history
- Add/Edit/Delete apps dynamically
- Categories and color coding
- Auto-refresh every 30 seconds
- API endpoints for apps and status management
2026-02-18 11:16:01 -06:00

25 lines
713 B
JavaScript

import React, { use } from 'react';
import { useCallback } from 'react';
import { isThenable } from '../../shared/lib/is-thenable';
export function useUnwrapState(state) {
// reducer actions can be async, so sometimes we need to suspend until the state is resolved
if (isThenable(state)) {
const result = use(state);
return result;
}
return state;
}
export function useReducer(actionQueue) {
const [state, setState] = React.useState(actionQueue.state);
const dispatch = useCallback((action)=>{
actionQueue.dispatch(action, setState);
}, [
actionQueue
]);
return [
state,
dispatch
];
}
//# sourceMappingURL=use-reducer.js.map