mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-09 09:47:28 +03:00
Fix mercure info loading in shlink-web-component
This commit is contained in:
parent
d49da185d3
commit
0169060de7
7 changed files with 22 additions and 37 deletions
|
@ -10,10 +10,6 @@ import { useSwipeable, useToggle } from '../src/utils/helpers/hooks';
|
||||||
import { useFeature } from './utils/features';
|
import { useFeature } from './utils/features';
|
||||||
import { useRoutesPrefix } from './utils/routesPrefix';
|
import { useRoutesPrefix } from './utils/routesPrefix';
|
||||||
|
|
||||||
type MainProps = {
|
|
||||||
loadMercureInfo: () => void;
|
|
||||||
};
|
|
||||||
|
|
||||||
export const Main = (
|
export const Main = (
|
||||||
TagsList: FC,
|
TagsList: FC,
|
||||||
ShortUrlsList: FC,
|
ShortUrlsList: FC,
|
||||||
|
@ -26,22 +22,17 @@ export const Main = (
|
||||||
Overview: FC,
|
Overview: FC,
|
||||||
EditShortUrl: FC,
|
EditShortUrl: FC,
|
||||||
ManageDomains: FC,
|
ManageDomains: FC,
|
||||||
): FC<MainProps> => ({ loadMercureInfo }) => {
|
): FC => () => {
|
||||||
const location = useLocation();
|
const location = useLocation();
|
||||||
const routesPrefix = useRoutesPrefix();
|
const routesPrefix = useRoutesPrefix();
|
||||||
const [sidebarVisible, toggleSidebar, showSidebar, hideSidebar] = useToggle();
|
const [sidebarVisible, toggleSidebar, showSidebar, hideSidebar] = useToggle();
|
||||||
useEffect(() => hideSidebar(), [location]);
|
useEffect(() => hideSidebar(), [location]);
|
||||||
|
|
||||||
// FIXME Re-load mercure info every time server changes
|
|
||||||
// useEffect(() => {
|
|
||||||
// loadMercureInfo();
|
|
||||||
// }, []);
|
|
||||||
|
|
||||||
const addDomainVisitsRoute = useFeature('domainVisits');
|
const addDomainVisitsRoute = useFeature('domainVisits');
|
||||||
const burgerClasses = classNames('menu-layout__burger-icon', { 'menu-layout__burger-icon--active': sidebarVisible });
|
const burgerClasses = classNames('menu-layout__burger-icon', { 'menu-layout__burger-icon--active': sidebarVisible });
|
||||||
const swipeableProps = useSwipeable(showSidebar, hideSidebar);
|
const swipeableProps = useSwipeable(showSidebar, hideSidebar);
|
||||||
|
|
||||||
// TODO Check if this is already wrapped by a router, and wrap otherwise
|
// FIXME Check if this is already wrapped by a router, and wrap otherwise
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
|
|
@ -24,15 +24,13 @@ let apiClientRef: ShlinkApiClient;
|
||||||
|
|
||||||
export const createShlinkWebComponent = (
|
export const createShlinkWebComponent = (
|
||||||
bottle: Bottle,
|
bottle: Bottle,
|
||||||
): FC<ShlinkWebComponentProps> => ({ routesPrefix = '', serverVersion, settings, apiClient }) => {
|
): FC<ShlinkWebComponentProps> => ({ serverVersion, apiClient, settings, routesPrefix = '' }) => {
|
||||||
const features = useFeatures(serverVersion);
|
const features = useFeatures(serverVersion);
|
||||||
const mainContent = useRef<ReactNode>();
|
const mainContent = useRef<ReactNode>();
|
||||||
const [theStore, setStore] = useState<Store | undefined>();
|
const [theStore, setStore] = useState<Store | undefined>();
|
||||||
|
|
||||||
// Set client on every re-render
|
|
||||||
apiClientRef = apiClient;
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
apiClientRef = apiClient;
|
||||||
bottle.value('apiClientFactory', () => apiClientRef);
|
bottle.value('apiClientFactory', () => apiClientRef);
|
||||||
|
|
||||||
// It's important to not try to resolve services before the API client has been registered, as many other services
|
// It's important to not try to resolve services before the API client has been registered, as many other services
|
||||||
|
@ -43,8 +41,8 @@ export const createShlinkWebComponent = (
|
||||||
setStore(store);
|
setStore(store);
|
||||||
|
|
||||||
// Load mercure info
|
// Load mercure info
|
||||||
store.dispatch(loadMercureInfo());
|
store.dispatch(loadMercureInfo(settings));
|
||||||
}, []);
|
}, [apiClient]);
|
||||||
|
|
||||||
return !theStore ? <></> : (
|
return !theStore ? <></> : (
|
||||||
<Provider store={theStore}>
|
<Provider store={theStore}>
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
import type Bottle from 'bottlejs';
|
import type Bottle from 'bottlejs';
|
||||||
import { Main } from '../Main';
|
import { Main } from '../Main';
|
||||||
import type { ConnectDecorator } from './index';
|
|
||||||
import { setUpStore } from './store';
|
import { setUpStore } from './store';
|
||||||
|
|
||||||
export const provideServices = (bottle: Bottle, connect: ConnectDecorator) => {
|
export const provideServices = (bottle: Bottle) => {
|
||||||
bottle.serviceFactory(
|
bottle.serviceFactory(
|
||||||
'Main',
|
'Main',
|
||||||
Main,
|
Main,
|
||||||
|
@ -19,7 +18,6 @@ export const provideServices = (bottle: Bottle, connect: ConnectDecorator) => {
|
||||||
'EditShortUrl',
|
'EditShortUrl',
|
||||||
'ManageDomains',
|
'ManageDomains',
|
||||||
);
|
);
|
||||||
bottle.decorator('Main', connect(null, ['loadMercureInfo']));
|
|
||||||
|
|
||||||
bottle.factory('store', setUpStore);
|
bottle.factory('store', setUpStore);
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import { createSlice } from '@reduxjs/toolkit';
|
import { createSlice } from '@reduxjs/toolkit';
|
||||||
import type { ShlinkApiClient, ShlinkMercureInfo } from '../../api-contract';
|
import type { ShlinkApiClient, ShlinkMercureInfo } from '../../api-contract';
|
||||||
import { createAsyncThunk } from '../../utils/redux';
|
import { createAsyncThunk } from '../../utils/redux';
|
||||||
|
import type { Settings } from '../../utils/settings';
|
||||||
|
|
||||||
const REDUCER_PREFIX = 'shlink/mercure';
|
const REDUCER_PREFIX = 'shlink/mercure';
|
||||||
|
|
||||||
|
@ -18,15 +19,13 @@ const initialState: MercureInfo = {
|
||||||
export const mercureInfoReducerCreator = (apiClientFactory: () => ShlinkApiClient) => {
|
export const mercureInfoReducerCreator = (apiClientFactory: () => ShlinkApiClient) => {
|
||||||
const loadMercureInfo = createAsyncThunk(
|
const loadMercureInfo = createAsyncThunk(
|
||||||
`${REDUCER_PREFIX}/loadMercureInfo`,
|
`${REDUCER_PREFIX}/loadMercureInfo`,
|
||||||
(): Promise<ShlinkMercureInfo> =>
|
({ realTimeUpdates }: Settings): Promise<ShlinkMercureInfo> => {
|
||||||
// FIXME Get settings here somehow, as they are only available via hook
|
if (realTimeUpdates && !realTimeUpdates.enabled) {
|
||||||
// const { settings } = getState();
|
throw new Error('Real time updates not enabled');
|
||||||
// if (!settings.realTimeUpdates.enabled) {
|
}
|
||||||
// throw new Error('Real time updates not enabled');
|
|
||||||
// }
|
|
||||||
|
|
||||||
apiClientFactory().mercureInfo()
|
return apiClientFactory().mercureInfo();
|
||||||
,
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
const { reducer } = createSlice({
|
const { reducer } = createSlice({
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import type { FC } from 'react';
|
import type { FC } from 'react';
|
||||||
import { useEffect } from 'react';
|
import { useEffect } from 'react';
|
||||||
|
import type { Settings } from '../../shlink-web-component';
|
||||||
import { ShlinkWebComponent } from '../../shlink-web-component';
|
import { ShlinkWebComponent } from '../../shlink-web-component';
|
||||||
import type { Settings } from '../../shlink-web-component/utils/settings';
|
|
||||||
import type { ShlinkApiClientBuilder } from '../api/services/ShlinkApiClientBuilder';
|
import type { ShlinkApiClientBuilder } from '../api/services/ShlinkApiClientBuilder';
|
||||||
import { isReachableServer } from '../servers/data';
|
import { isReachableServer } from '../servers/data';
|
||||||
import { withSelectedServer } from '../servers/helpers/withSelectedServer';
|
import { withSelectedServer } from '../servers/helpers/withSelectedServer';
|
||||||
|
|
|
@ -1,12 +1,10 @@
|
||||||
import type { PayloadAction } from '@reduxjs/toolkit';
|
import { createAction, createSlice } from '@reduxjs/toolkit';
|
||||||
import { createAction, createListenerMiddleware, createSlice } from '@reduxjs/toolkit';
|
|
||||||
import { memoizeWith, pipe } from 'ramda';
|
import { memoizeWith, pipe } from 'ramda';
|
||||||
|
import type { ShlinkHealth } from '../../../shlink-web-component/api-contract';
|
||||||
import type { ShlinkApiClientBuilder } from '../../api/services/ShlinkApiClientBuilder';
|
import type { ShlinkApiClientBuilder } from '../../api/services/ShlinkApiClientBuilder';
|
||||||
import type { ShlinkHealth } from '../../api/types';
|
|
||||||
import { createAsyncThunk } from '../../utils/helpers/redux';
|
import { createAsyncThunk } from '../../utils/helpers/redux';
|
||||||
import { versionToPrintable, versionToSemVer as toSemVer } from '../../utils/helpers/version';
|
import { versionToPrintable, versionToSemVer as toSemVer } from '../../utils/helpers/version';
|
||||||
import type { SelectedServer, ServerWithId } from '../data';
|
import type { SelectedServer, ServerWithId } from '../data';
|
||||||
import { isReachableServer } from '../data';
|
|
||||||
|
|
||||||
const REDUCER_PREFIX = 'shlink/selectedServer';
|
const REDUCER_PREFIX = 'shlink/selectedServer';
|
||||||
|
|
||||||
|
|
|
@ -1,23 +1,24 @@
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
import { FormGroup, Input } from 'reactstrap';
|
import { FormGroup, Input } from 'reactstrap';
|
||||||
|
import type { Settings } from '../../shlink-web-component';
|
||||||
import { FormText } from '../utils/forms/FormText';
|
import { FormText } from '../utils/forms/FormText';
|
||||||
import { LabeledFormGroup } from '../utils/forms/LabeledFormGroup';
|
import { LabeledFormGroup } from '../utils/forms/LabeledFormGroup';
|
||||||
import { useDomId } from '../utils/helpers/hooks';
|
import { useDomId } from '../utils/helpers/hooks';
|
||||||
import { SimpleCard } from '../utils/SimpleCard';
|
import { SimpleCard } from '../utils/SimpleCard';
|
||||||
import { ToggleSwitch } from '../utils/ToggleSwitch';
|
import { ToggleSwitch } from '../utils/ToggleSwitch';
|
||||||
import type { Settings } from './reducers/settings';
|
|
||||||
|
|
||||||
interface RealTimeUpdatesProps {
|
type RealTimeUpdatesProps = {
|
||||||
settings: Settings;
|
settings: Settings;
|
||||||
toggleRealTimeUpdates: (enabled: boolean) => void;
|
toggleRealTimeUpdates: (enabled: boolean) => void;
|
||||||
setRealTimeUpdatesInterval: (interval: number) => void;
|
setRealTimeUpdatesInterval: (interval: number) => void;
|
||||||
}
|
};
|
||||||
|
|
||||||
const intervalValue = (interval?: number) => (!interval ? '' : `${interval}`);
|
const intervalValue = (interval?: number) => (!interval ? '' : `${interval}`);
|
||||||
|
|
||||||
export const RealTimeUpdatesSettings = (
|
export const RealTimeUpdatesSettings = (
|
||||||
{ settings: { realTimeUpdates }, toggleRealTimeUpdates, setRealTimeUpdatesInterval }: RealTimeUpdatesProps,
|
{ settings, toggleRealTimeUpdates, setRealTimeUpdatesInterval }: RealTimeUpdatesProps,
|
||||||
) => {
|
) => {
|
||||||
|
const { realTimeUpdates = { enabled: true } } = settings;
|
||||||
const inputId = useDomId();
|
const inputId = useDomId();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
|
Loading…
Reference in a new issue