mirror of
https://github.com/billsonnn/nitro-react.git
synced 2024-11-26 15:40:51 +01:00
Inventory tabs selector
This commit is contained in:
parent
676af80e23
commit
cfd996f650
@ -1,14 +1,23 @@
|
|||||||
import { FC, useCallback, useState } from 'react';
|
import React, { FC, useCallback, useEffect, useState } from 'react';
|
||||||
import { InventoryEvent } from '../../events';
|
import { InventoryEvent } from '../../events';
|
||||||
import { DraggableWindow } from '../../hooks/draggable-window/DraggableWindow';
|
import { DraggableWindow } from '../../hooks/draggable-window/DraggableWindow';
|
||||||
import { useUiEvent } from '../../hooks/events/ui/ui-event';
|
import { useUiEvent } from '../../hooks/events/ui/ui-event';
|
||||||
import { LocalizeText } from '../../utils/LocalizeText';
|
import { LocalizeText } from '../../utils/LocalizeText';
|
||||||
import { InventoryMessageHandler } from './InventoryMessageHandler';
|
import { InventoryMessageHandler } from './InventoryMessageHandler';
|
||||||
import { InventoryViewProps } from './InventoryView.types';
|
import { IInventoryContext, InventoryViewProps } from './InventoryView.types';
|
||||||
|
import { InventoryTabsView } from './tabs/InventoryTabsView';
|
||||||
|
|
||||||
|
export const InventoryContext = React.createContext<IInventoryContext>(null);
|
||||||
|
|
||||||
export const InventoryView: FC<InventoryViewProps> = props =>
|
export const InventoryView: FC<InventoryViewProps> = props =>
|
||||||
{
|
{
|
||||||
const [ isVisible, setIsVisible ] = useState(false);
|
const [ isVisible, setIsVisible ] = useState(false);
|
||||||
|
const [ currentTab, setCurrentTab ] = useState<string>(null);
|
||||||
|
const [ tabs, setTabs ] = useState<string[]>([ 'inventory.furni', 'inventory.bots', 'inventory.furni.tab.pets', 'inventory.badges' ]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
setCurrentTab(tabs[0]);
|
||||||
|
}, [ tabs ]);
|
||||||
|
|
||||||
const onInventoryEvent = useCallback((event: InventoryEvent) =>
|
const onInventoryEvent = useCallback((event: InventoryEvent) =>
|
||||||
{
|
{
|
||||||
@ -32,7 +41,7 @@ export const InventoryView: FC<InventoryViewProps> = props =>
|
|||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<InventoryContext.Provider value={{ currentTab: currentTab, onSetCurrentTab: setCurrentTab }}>
|
||||||
<InventoryMessageHandler />
|
<InventoryMessageHandler />
|
||||||
{ isVisible && <DraggableWindow handle=".drag-handler">
|
{ isVisible && <DraggableWindow handle=".drag-handler">
|
||||||
<div className="nitro-inventory d-flex flex-column bg-primary border border-black shadow rounded">
|
<div className="nitro-inventory d-flex flex-column bg-primary border border-black shadow rounded">
|
||||||
@ -42,11 +51,9 @@ export const InventoryView: FC<InventoryViewProps> = props =>
|
|||||||
<i className="fas fa-times"></i>
|
<i className="fas fa-times"></i>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<div className="d-flex p-3">
|
<InventoryTabsView tabs={ tabs } />
|
||||||
content
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</DraggableWindow> }
|
</DraggableWindow> }
|
||||||
</>
|
</InventoryContext.Provider>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,8 @@
|
|||||||
export interface InventoryViewProps
|
export interface InventoryViewProps
|
||||||
|
{}
|
||||||
|
|
||||||
|
export interface IInventoryContext
|
||||||
{
|
{
|
||||||
|
currentTab: string;
|
||||||
|
onSetCurrentTab: (tab: string) => void;
|
||||||
}
|
}
|
||||||
|
18
src/views/inventory/tabs/InventoryTabsView.tsx
Normal file
18
src/views/inventory/tabs/InventoryTabsView.tsx
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { FC } from 'react';
|
||||||
|
import { InventoryTabsViewProps } from './InventoryTabsView.types';
|
||||||
|
import { InventoryTabView } from './tab/InventoryTabView';
|
||||||
|
|
||||||
|
export const InventoryTabsView: FC<InventoryTabsViewProps> = props =>
|
||||||
|
{
|
||||||
|
return (
|
||||||
|
<div className="p-3">
|
||||||
|
{ props.tabs &&
|
||||||
|
<div className="btn-group w-100">
|
||||||
|
{ props.tabs.map((tab, index) =>
|
||||||
|
{
|
||||||
|
return <InventoryTabView key={ index } tab={ tab } />
|
||||||
|
}) }
|
||||||
|
</div> }
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
4
src/views/inventory/tabs/InventoryTabsView.types.ts
Normal file
4
src/views/inventory/tabs/InventoryTabsView.types.ts
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
export interface InventoryTabsViewProps
|
||||||
|
{
|
||||||
|
tabs: string[];
|
||||||
|
}
|
18
src/views/inventory/tabs/tab/InventoryTabView.tsx
Normal file
18
src/views/inventory/tabs/tab/InventoryTabView.tsx
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import classNames from 'classnames';
|
||||||
|
import { FC, useContext } from 'react';
|
||||||
|
import { LocalizeText } from '../../../../utils/LocalizeText';
|
||||||
|
import { InventoryContext } from '../../InventoryView';
|
||||||
|
import { InventoryTabViewProps } from './InventoryTabView.types';
|
||||||
|
|
||||||
|
export const InventoryTabView: FC<InventoryTabViewProps> = props =>
|
||||||
|
{
|
||||||
|
const inventoryContext = useContext(InventoryContext);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<button type="button"
|
||||||
|
className={ 'btn btn-secondary btn-sm ' + classNames({ 'active': inventoryContext.currentTab === props.tab })}
|
||||||
|
onClick={ () => inventoryContext.onSetCurrentTab(props.tab) }>
|
||||||
|
{ LocalizeText(props.tab) }
|
||||||
|
</button>
|
||||||
|
);
|
||||||
|
}
|
4
src/views/inventory/tabs/tab/InventoryTabView.types.ts
Normal file
4
src/views/inventory/tabs/tab/InventoryTabView.types.ts
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
export interface InventoryTabViewProps
|
||||||
|
{
|
||||||
|
tab: string;
|
||||||
|
}
|
@ -6,7 +6,7 @@ export function NavigatorTabsView(props: NavigatorTabsViewProps): JSX.Element
|
|||||||
const { topLevelContext = null, topLevelContexts = null, setTopLevelContext = null } = props;
|
const { topLevelContext = null, topLevelContexts = null, setTopLevelContext = null } = props;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="d-flex flex-column p-3">
|
<div className="p-3">
|
||||||
{ topLevelContexts && topLevelContexts.length &&
|
{ topLevelContexts && topLevelContexts.length &&
|
||||||
<div className="btn-group w-100">
|
<div className="btn-group w-100">
|
||||||
{ topLevelContexts.map((context, index) =>
|
{ topLevelContexts.map((context, index) =>
|
||||||
|
Loading…
Reference in New Issue
Block a user