nitro-react/src/views/navigator/NavigatorView.tsx

111 lines
4.1 KiB
TypeScript
Raw Normal View History

2021-04-21 05:36:39 +02:00
import { NavigatorInitComposer, NavigatorSearchComposer, NavigatorSearchResultList, NavigatorTopLevelContext, RoomSessionEvent } from 'nitro-renderer';
2021-04-19 18:34:31 +02:00
import { MouseEvent, useCallback, useEffect, useState } from 'react';
import { NavigatorEvent } from '../../events';
import { DraggableWindow } from '../../hooks/draggable-window/DraggableWindow';
import { useRoomSessionManagerEvent } from '../../hooks/events/nitro/session/room-session-manager-event';
import { useUiEvent } from '../../hooks/events/ui/ui-event';
2021-04-21 05:36:39 +02:00
import { SendMessageHook } from '../../hooks/messages/message-event';
2021-04-19 18:34:31 +02:00
import { LocalizeText } from '../../utils/LocalizeText';
2021-04-21 05:36:39 +02:00
import { NavigatorMessageHandler } from './NavigatorMessageHandler';
2021-04-18 06:58:57 +02:00
import { NavigatorViewProps } from './NavigatorView.types';
2021-04-19 18:34:31 +02:00
import { NavigatorTabsView } from './tabs/NavigatorTabsView';
2021-04-18 06:58:57 +02:00
export function NavigatorView(props: NavigatorViewProps): JSX.Element
{
2021-04-19 18:34:31 +02:00
const [ isVisible, setIsVisible ] = useState(false);
const [ isLoaded, setIsLoaded ] = useState(false);
const [ isLoading, setIsLoading ] = useState(false);
const [ isSearching, setIsSearching ] = useState(false);
const [ topLevelContexts, setTopLevelContexts ] = useState<NavigatorTopLevelContext[]>(null);
const [ topLevelContext, setTopLevelContext ] = useState<NavigatorTopLevelContext>(null);
2021-04-21 05:36:39 +02:00
const [ searchResults, setSearchResults ] = useState<NavigatorSearchResultList[]>(null);
2021-04-19 18:34:31 +02:00
function hideNavigator(event: MouseEvent = null): void
{
if(event) event.preventDefault();
setIsVisible(false);
}
const onNavigatorEvent = useCallback((event: NavigatorEvent) =>
{
switch(event.type)
{
case NavigatorEvent.SHOW_NAVIGATOR:
setIsVisible(true);
return;
case NavigatorEvent.TOGGLE_NAVIGATOR:
setIsVisible(value => !value);
return;
}
}, []);
2021-04-18 06:58:57 +02:00
2021-04-19 18:34:31 +02:00
const onRoomSessionEvent = useCallback((event: RoomSessionEvent) =>
{
switch(event.type)
{
case RoomSessionEvent.CREATED:
setIsVisible(false);
return;
}
}, []);
const search = useCallback((value: string = null) =>
{
if(!topLevelContext) return;
2021-04-21 05:36:39 +02:00
setIsSearching(true);
2021-04-19 18:34:31 +02:00
sendSearch(topLevelContext.code, '');
}, [ topLevelContext ]);
function sendSearch(code: string, query: string): void
{
SendMessageHook(new NavigatorSearchComposer(code, query));
}
useEffect(() =>
{
if(!isVisible) return;
if(!isLoaded)
{
SendMessageHook(new NavigatorInitComposer());
setIsLoaded(true);
}
else
{
search();
}
}, [ isVisible, isLoaded, search ]);
2021-04-21 05:36:39 +02:00
useEffect(() =>
{
setIsSearching(false);
}, [ searchResults ]);
2021-04-19 18:34:31 +02:00
useUiEvent(NavigatorEvent.SHOW_NAVIGATOR, onNavigatorEvent);
useUiEvent(NavigatorEvent.TOGGLE_NAVIGATOR, onNavigatorEvent);
useRoomSessionManagerEvent(RoomSessionEvent.CREATED, onRoomSessionEvent);
2021-04-18 06:58:57 +02:00
return (
2021-04-21 05:36:39 +02:00
<>
<NavigatorMessageHandler setTopLevelContext={ setTopLevelContext } setTopLevelContexts={ setTopLevelContexts } setSearchResults={ setSearchResults } />
{ isVisible && <DraggableWindow handle=".drag-handler">
<div className="nitro-navigator d-flex flex-column bg-primary border border-black shadow rounded">
<div className="drag-handler d-flex justify-content-between align-items-center px-3 pt-3">
<div className="h6 m-0">{ LocalizeText((isLoading || isSearching) ? 'navigator.title.is.busy' : 'navigator.title') }</div>
<button type="button" className="close" onClick={ hideNavigator }>
<i className="fas fa-times"></i>
</button>
</div>
<NavigatorTabsView topLevelContext={ topLevelContext } topLevelContexts={ topLevelContexts } setTopLevelContext={ setTopLevelContext } />
2021-04-19 18:34:31 +02:00
</div>
2021-04-21 05:36:39 +02:00
</DraggableWindow> }
</>
2021-04-18 06:58:57 +02:00
);
}