mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2026-03-18 21:43:49 +00:00
Create useSelectedServer hook and use it where reset selected server is done
This commit is contained in:
@@ -1,7 +1,9 @@
|
||||
import { createAction, createSlice } from '@reduxjs/toolkit';
|
||||
import { memoizeWith } from '@shlinkio/data-manipulation';
|
||||
import type { ShlinkHealth } from '@shlinkio/shlink-web-component/api-contract';
|
||||
import { useCallback } from 'react';
|
||||
import type { ShlinkApiClientBuilder } from '../../api/services/ShlinkApiClientBuilder';
|
||||
import { useAppDispatch, useAppSelector } from '../../container/store';
|
||||
import { createAsyncThunk } from '../../utils/helpers/redux';
|
||||
import { versionToPrintable, versionToSemVer as toSemVer } from '../../utils/helpers/version';
|
||||
import type { SelectedServer, ServerWithId } from '../data';
|
||||
@@ -72,3 +74,19 @@ const { reducer } = createSlice({
|
||||
});
|
||||
|
||||
export const selectedServerReducer = reducer;
|
||||
|
||||
export const useSelectedServer = () => {
|
||||
const dispatch = useAppDispatch();
|
||||
const dispatchResetSelectedServer = useCallback(() => dispatch(resetSelectedServer()), [dispatch]);
|
||||
const dispatchSelectServer = useCallback(
|
||||
(options: SelectServerOptions) => dispatch(selectServer(options)),
|
||||
[dispatch],
|
||||
);
|
||||
const selectedServer = useAppSelector(({ selectedServer }) => selectedServer);
|
||||
|
||||
return {
|
||||
selectedServer,
|
||||
resetSelectedServer: dispatchResetSelectedServer,
|
||||
selectServer: dispatchSelectServer,
|
||||
};
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user