mirror of
https://github.com/billsonnn/nitro-react.git
synced 2024-11-22 22:30:52 +01:00
Update inventory to use useReducer
This commit is contained in:
parent
629205d096
commit
fece78897f
@ -1,50 +1,28 @@
|
||||
import { FurnitureListAddOrUpdateEvent, FurnitureListEvent, FurnitureListInvalidateEvent, FurnitureListItemParser, FurnitureListRemovedEvent, FurniturePostItPlacedEvent } from 'nitro-renderer';
|
||||
import { FC, useCallback } from 'react';
|
||||
import { CreateMessageHook } from '../../hooks/messages/message-event';
|
||||
import { useInventoryContext } from './context/InventoryContext';
|
||||
import { InventoryMessageHandlerProps } from './InventoryMessageHandler.types';
|
||||
import { FurnitureItem } from './utils/FurnitureItem';
|
||||
import { addFurnitureItem, getGroupItemForFurnitureId, mergeFragments, processFragment, removeItemById } from './utils/FurnitureUtilities';
|
||||
import { InventoryFurnitureActions } from './reducers/InventoryFurnitureReducer';
|
||||
import { mergeFragments } from './utils/FurnitureUtilities';
|
||||
|
||||
let furniMsgFragments: Map<number, FurnitureListItemParser>[] = null;
|
||||
|
||||
export const InventoryMessageHandler: FC<InventoryMessageHandlerProps> = props =>
|
||||
{
|
||||
const { setNeedsFurniUpdate = null, setGroupItems = null } = props;
|
||||
const { dispatchFurnitureState = null } = useInventoryContext();
|
||||
|
||||
const onFurnitureListAddOrUpdateEvent = useCallback((event: FurnitureListAddOrUpdateEvent) =>
|
||||
{
|
||||
const parser = event.getParser();
|
||||
|
||||
setGroupItems(prevValue =>
|
||||
{
|
||||
const newSet = [ ...prevValue ];
|
||||
|
||||
for(const item of parser.items)
|
||||
{
|
||||
const groupItem = getGroupItemForFurnitureId(newSet, item.itemId);
|
||||
|
||||
if(groupItem)
|
||||
{
|
||||
const furniture = groupItem.getItemById(item.itemId);
|
||||
|
||||
if(furniture)
|
||||
{
|
||||
furniture.update(item);
|
||||
|
||||
groupItem.hasUnseenItems = true;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
const furniture = new FurnitureItem(item);
|
||||
|
||||
addFurnitureItem(newSet, furniture, false);
|
||||
}
|
||||
}
|
||||
|
||||
return newSet;
|
||||
});
|
||||
}, [ setGroupItems ]);
|
||||
dispatchFurnitureState({
|
||||
type: InventoryFurnitureActions.ADD_OR_UPDATE_FURNITURE,
|
||||
payload: {
|
||||
parsers: parser.items
|
||||
}
|
||||
});
|
||||
}, [ dispatchFurnitureState ]);
|
||||
|
||||
const onFurnitureListEvent = useCallback((event: FurnitureListEvent) =>
|
||||
{
|
||||
@ -52,41 +30,37 @@ export const InventoryMessageHandler: FC<InventoryMessageHandlerProps> = props =
|
||||
|
||||
if(!furniMsgFragments) furniMsgFragments = new Array(parser.totalFragments);
|
||||
|
||||
const merged = mergeFragments(parser.fragment, parser.totalFragments, parser.fragmentNumber, furniMsgFragments);
|
||||
const fragment = mergeFragments(parser.fragment, parser.totalFragments, parser.fragmentNumber, furniMsgFragments);
|
||||
|
||||
if(!merged) return;
|
||||
if(!fragment) return;
|
||||
|
||||
setGroupItems(prevValue =>
|
||||
{
|
||||
return processFragment(prevValue, merged);
|
||||
});
|
||||
}, [ setGroupItems ]);
|
||||
dispatchFurnitureState({
|
||||
type: InventoryFurnitureActions.PROCESS_FRAGMENT,
|
||||
payload: { fragment }
|
||||
});
|
||||
}, [ dispatchFurnitureState ]);
|
||||
|
||||
const onFurnitureListInvalidateEvent = useCallback((event: FurnitureListInvalidateEvent) =>
|
||||
{
|
||||
setNeedsFurniUpdate(true);
|
||||
}, [ setNeedsFurniUpdate ]);
|
||||
dispatchFurnitureState({
|
||||
type: InventoryFurnitureActions.SET_NEEDS_UPDATE,
|
||||
payload: {
|
||||
flag: true
|
||||
}
|
||||
});
|
||||
}, [ dispatchFurnitureState ]);
|
||||
|
||||
const onFurnitureListRemovedEvent = useCallback((event: FurnitureListRemovedEvent) =>
|
||||
{
|
||||
const parser = event.getParser();
|
||||
|
||||
setGroupItems(prevValue =>
|
||||
{
|
||||
const newSet = [ ...prevValue ];
|
||||
|
||||
const groupItem = removeItemById(parser.itemId, newSet);
|
||||
|
||||
if(groupItem)
|
||||
{
|
||||
// set all seen
|
||||
|
||||
return newSet;
|
||||
}
|
||||
|
||||
return prevValue;
|
||||
});
|
||||
}, [ setGroupItems ]);
|
||||
dispatchFurnitureState({
|
||||
type: InventoryFurnitureActions.REMOVE_FURNITURE,
|
||||
payload: {
|
||||
itemId: parser.itemId
|
||||
}
|
||||
});
|
||||
}, [ dispatchFurnitureState ]);
|
||||
|
||||
const onFurniturePostItPlacedEvent = useCallback((event: FurniturePostItPlacedEvent) =>
|
||||
{
|
||||
|
@ -1,8 +1,3 @@
|
||||
import { Dispatch, SetStateAction } from 'react';
|
||||
import { GroupItem } from './utils/GroupItem';
|
||||
|
||||
export interface InventoryMessageHandlerProps
|
||||
{
|
||||
setNeedsFurniUpdate: Dispatch<SetStateAction<boolean>>;
|
||||
setGroupItems: Dispatch<SetStateAction<GroupItem[]>>;
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
.nitro-inventory {
|
||||
width: 475px;
|
||||
height: 300px;
|
||||
max-height: 300px;
|
||||
// height: 300px;
|
||||
// max-height: 300px;
|
||||
}
|
||||
|
||||
@import './views/InventoryViews';
|
||||
|
@ -1,15 +1,18 @@
|
||||
import classNames from 'classnames';
|
||||
import { IRoomSession, RoomPreviewer, RoomSessionEvent } from 'nitro-renderer';
|
||||
import { FC, useCallback, useEffect, useState } from 'react';
|
||||
import { IRoomSession, RoomEngineObjectEvent, RoomEngineObjectPlacedEvent, RoomPreviewer, RoomSessionEvent } from 'nitro-renderer';
|
||||
import { FC, useCallback, useEffect, useReducer, useState } from 'react';
|
||||
import { GetRoomEngine } from '../../api';
|
||||
import { InventoryEvent } from '../../events';
|
||||
import { DraggableWindow } from '../../hooks/draggable-window/DraggableWindow';
|
||||
import { useRoomEngineEvent } from '../../hooks/events/nitro/room/room-engine-event';
|
||||
import { useRoomSessionManagerEvent } from '../../hooks/events/nitro/session/room-session-manager-event';
|
||||
import { useUiEvent } from '../../hooks/events/ui/ui-event';
|
||||
import { LocalizeText } from '../../utils/LocalizeText';
|
||||
import { InventoryContextProvider } from './context/InventoryContext';
|
||||
import { InventoryMessageHandler } from './InventoryMessageHandler';
|
||||
import { InventoryTabs, InventoryViewProps } from './InventoryView.types';
|
||||
import { GroupItem } from './utils/GroupItem';
|
||||
import { initialInventoryFurniture, inventoryFurnitureReducer } from './reducers/InventoryFurnitureReducer';
|
||||
import { isObjectMoverRequested, setObjectMoverRequested } from './utils/FurnitureUtilities';
|
||||
import { InventoryFurnitureView } from './views/furniture/InventoryFurnitureView';
|
||||
|
||||
export const InventoryView: FC<InventoryViewProps> = props =>
|
||||
@ -18,12 +21,9 @@ export const InventoryView: FC<InventoryViewProps> = props =>
|
||||
|
||||
const [ isVisible, setIsVisible ] = useState(false);
|
||||
const [ currentTab, setCurrentTab ] = useState<string>(tabs[0]);
|
||||
|
||||
const [ roomSession, setRoomSession ] = useState<IRoomSession>(null);
|
||||
const [ needsFurniUpdate, setNeedsFurniUpdate ] = useState(true);
|
||||
const [ groupItem, setGroupItem ] = useState<GroupItem>(null);
|
||||
const [ groupItems, setGroupItems ] = useState<GroupItem[]>([]);
|
||||
const [ roomPreviewer, setRoomPreviewer ] = useState<RoomPreviewer>(null);
|
||||
const [ furnitureState, dispatchFurnitureState ] = useReducer(inventoryFurnitureReducer, initialInventoryFurniture);
|
||||
|
||||
const onInventoryEvent = useCallback((event: InventoryEvent) =>
|
||||
{
|
||||
@ -45,6 +45,17 @@ export const InventoryView: FC<InventoryViewProps> = props =>
|
||||
useUiEvent(InventoryEvent.HIDE_INVENTORY, onInventoryEvent);
|
||||
useUiEvent(InventoryEvent.TOGGLE_INVENTORY, onInventoryEvent);
|
||||
|
||||
const onRoomEngineObjectPlacedEvent = useCallback((event: RoomEngineObjectPlacedEvent) =>
|
||||
{
|
||||
if(!isObjectMoverRequested()) return;
|
||||
|
||||
setObjectMoverRequested(false);
|
||||
|
||||
if(!event._Str_4057) setIsVisible(true);
|
||||
}, []);
|
||||
|
||||
useRoomEngineEvent(RoomEngineObjectEvent.PLACED, onRoomEngineObjectPlacedEvent);
|
||||
|
||||
const onRoomSessionEvent = useCallback((event: RoomSessionEvent) =>
|
||||
{
|
||||
switch(event.type)
|
||||
@ -83,10 +94,8 @@ export const InventoryView: FC<InventoryViewProps> = props =>
|
||||
}
|
||||
|
||||
return (
|
||||
<>
|
||||
<InventoryMessageHandler
|
||||
setNeedsFurniUpdate={ setNeedsFurniUpdate }
|
||||
setGroupItems={ setGroupItems } />
|
||||
<InventoryContextProvider value={ { furnitureState, dispatchFurnitureState } }>
|
||||
<InventoryMessageHandler />
|
||||
{ isVisible && <DraggableWindow handle=".drag-handler">
|
||||
<div className="nitro-inventory d-flex flex-column">
|
||||
<div className="drag-handler d-flex align-items-center bg-primary border border-bottom-0 rounded-top px-3 py-1">
|
||||
@ -107,16 +116,11 @@ export const InventoryView: FC<InventoryViewProps> = props =>
|
||||
</ul>
|
||||
<div className="bg-light rounded-bottom border border-top-0 px-3 py-2 h-100 shadow overflow-hidden">
|
||||
{ (currentTab === InventoryTabs.FURNITURE ) && <InventoryFurnitureView
|
||||
needsFurniUpdate={ needsFurniUpdate }
|
||||
setNeedsFurniUpdate={ setNeedsFurniUpdate }
|
||||
groupItem={ groupItem }
|
||||
setGroupItem={ setGroupItem }
|
||||
groupItems={ groupItems }
|
||||
roomSession={ roomSession }
|
||||
roomPreviewer={ roomPreviewer } /> }
|
||||
</div>
|
||||
</div>
|
||||
</DraggableWindow> }
|
||||
</>
|
||||
</InventoryContextProvider>
|
||||
);
|
||||
}
|
||||
|
@ -2,8 +2,8 @@ import { createContext, FC, useContext } from 'react';
|
||||
import { IInventoryContext, InventoryContextProps } from './InventoryContext.types';
|
||||
|
||||
const InventoryContext = createContext<IInventoryContext>({
|
||||
currentTab: null,
|
||||
setCurrentTab: null,
|
||||
furnitureState: null,
|
||||
dispatchFurnitureState: null
|
||||
});
|
||||
|
||||
export const InventoryContextProvider: FC<InventoryContextProps> = props =>
|
||||
|
@ -1,9 +1,10 @@
|
||||
import { ProviderProps } from 'react';
|
||||
import { Dispatch, ProviderProps } from 'react';
|
||||
import { IInventoryFurnitureAction, IInventoryFurnitureState } from '../reducers/InventoryFurnitureReducer';
|
||||
|
||||
export interface IInventoryContext
|
||||
{
|
||||
currentTab: string;
|
||||
setCurrentTab: (tab: string) => void;
|
||||
furnitureState: IInventoryFurnitureState;
|
||||
dispatchFurnitureState: Dispatch<IInventoryFurnitureAction>;
|
||||
}
|
||||
|
||||
export interface InventoryContextProps extends ProviderProps<IInventoryContext>
|
||||
|
@ -1,14 +0,0 @@
|
||||
import { createContext, FC, useContext } from 'react';
|
||||
import { IInventoryFurnitureContext, InventoryFurnitureContextProps } from './InventoryFurnitureContext.types';
|
||||
|
||||
const InventoryFurnitureContext = createContext<IInventoryFurnitureContext>({
|
||||
setNeedsUpdate: null,
|
||||
setGroupItems: null
|
||||
});
|
||||
|
||||
export const InventoryFurnitureContextProvider: FC<InventoryFurnitureContextProps> = props =>
|
||||
{
|
||||
return <InventoryFurnitureContext.Provider value={ props.value }>{ props.children }</InventoryFurnitureContext.Provider>
|
||||
}
|
||||
|
||||
export const useInventoryFurnitureContext = () => useContext(InventoryFurnitureContext);
|
@ -1,13 +0,0 @@
|
||||
import { Dispatch, ProviderProps, SetStateAction } from 'react';
|
||||
import { GroupItem } from '../../utils/GroupItem';
|
||||
|
||||
export interface IInventoryFurnitureContext
|
||||
{
|
||||
setNeedsUpdate: Dispatch<SetStateAction<boolean>>;
|
||||
setGroupItems: Dispatch<SetStateAction<GroupItem[]>>;
|
||||
}
|
||||
|
||||
export interface InventoryFurnitureContextProps extends ProviderProps<IInventoryFurnitureContext>
|
||||
{
|
||||
|
||||
}
|
137
src/views/inventory/reducers/InventoryFurnitureReducer.tsx
Normal file
137
src/views/inventory/reducers/InventoryFurnitureReducer.tsx
Normal file
@ -0,0 +1,137 @@
|
||||
import { FurnitureListItemParser } from 'nitro-renderer';
|
||||
import { Reducer } from 'react';
|
||||
import { FurnitureItem } from '../utils/FurnitureItem';
|
||||
import { addFurnitureItem, processFragment, removeItemById } from '../utils/FurnitureUtilities';
|
||||
import { GroupItem } from '../utils/GroupItem';
|
||||
|
||||
export interface IInventoryFurnitureState
|
||||
{
|
||||
needsFurniUpdate: boolean;
|
||||
groupItem: GroupItem;
|
||||
groupItems: GroupItem[];
|
||||
}
|
||||
|
||||
export interface IInventoryFurnitureAction
|
||||
{
|
||||
type: string;
|
||||
payload: {
|
||||
flag?: boolean;
|
||||
groupItem?: GroupItem;
|
||||
parsers?: FurnitureListItemParser[];
|
||||
itemId?: number;
|
||||
fragment?: Map<number, FurnitureListItemParser>;
|
||||
}
|
||||
}
|
||||
|
||||
export class InventoryFurnitureActions
|
||||
{
|
||||
public static SET_NEEDS_UPDATE: string = 'IFA_SET_NEEDS_UPDATE';
|
||||
public static SET_GROUP_ITEM: string = 'IFA_SET_GROUP_ITEM';
|
||||
public static ADD_OR_UPDATE_FURNITURE: string = 'IFA_ADD_OR_UPDATE_FURNITURE';
|
||||
public static REMOVE_FURNITURE: string = 'IFA_REMOVE_FURNITURE';
|
||||
public static PROCESS_FRAGMENT: string = 'IFA_PROCESS_FRAGMENT';
|
||||
}
|
||||
|
||||
export const initialInventoryFurniture: IInventoryFurnitureState = {
|
||||
needsFurniUpdate: true,
|
||||
groupItem: null,
|
||||
groupItems: []
|
||||
}
|
||||
|
||||
export const inventoryFurnitureReducer: Reducer<IInventoryFurnitureState, IInventoryFurnitureAction> = (state, action) =>
|
||||
{
|
||||
switch(action.type)
|
||||
{
|
||||
case InventoryFurnitureActions.SET_NEEDS_UPDATE:
|
||||
return { ...state, needsFurniUpdate: (action.payload.flag || false) };
|
||||
case InventoryFurnitureActions.SET_GROUP_ITEM: {
|
||||
let groupItem = (action.payload.groupItem || state.groupItem || null);
|
||||
|
||||
let index = 0;
|
||||
|
||||
if(groupItem)
|
||||
{
|
||||
const foundIndex = state.groupItems.indexOf(groupItem);
|
||||
|
||||
if(foundIndex > -1) index = foundIndex;
|
||||
}
|
||||
|
||||
groupItem = (state.groupItems[index] || null);
|
||||
|
||||
return { ...state, groupItem };
|
||||
}
|
||||
case InventoryFurnitureActions.ADD_OR_UPDATE_FURNITURE: {
|
||||
const groupItems = [ ...state.groupItems ];
|
||||
|
||||
for(const item of action.payload.parsers)
|
||||
{
|
||||
let i = 0;
|
||||
let groupItem: GroupItem = null;
|
||||
|
||||
while(i < groupItems.length)
|
||||
{
|
||||
const group = groupItems[i];
|
||||
|
||||
let j = 0;
|
||||
|
||||
while(j < group.items.length)
|
||||
{
|
||||
const furniture = group.items[j];
|
||||
|
||||
if(furniture.id === item.itemId)
|
||||
{
|
||||
furniture.update(item);
|
||||
|
||||
const newFurniture = [ ...group.items ];
|
||||
|
||||
newFurniture[j] = furniture;
|
||||
|
||||
group.items = newFurniture;
|
||||
|
||||
groupItem = group;
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
j++
|
||||
}
|
||||
|
||||
if(groupItem) break;
|
||||
|
||||
i++;
|
||||
}
|
||||
|
||||
if(groupItem)
|
||||
{
|
||||
groupItem.hasUnseenItems = true;
|
||||
|
||||
groupItems[i] = Object.create(groupItem);
|
||||
}
|
||||
else
|
||||
{
|
||||
const furniture = new FurnitureItem(item);
|
||||
|
||||
addFurnitureItem(groupItems, furniture, false);
|
||||
}
|
||||
}
|
||||
|
||||
return { ...state, groupItems };
|
||||
}
|
||||
case InventoryFurnitureActions.REMOVE_FURNITURE: {
|
||||
const groupItems = [ ...state.groupItems ];
|
||||
|
||||
removeItemById(action.payload.itemId, groupItems);
|
||||
|
||||
return { ...state, groupItems };
|
||||
}
|
||||
case InventoryFurnitureActions.PROCESS_FRAGMENT: {
|
||||
const groupItems = [ ...state.groupItems ];
|
||||
|
||||
processFragment(groupItems, (action.payload.fragment || null));
|
||||
|
||||
return { ...state, groupItems };
|
||||
}
|
||||
default:
|
||||
return state;
|
||||
}
|
||||
}
|
@ -155,9 +155,7 @@ export function processFragment(set: GroupItem[], fragment: Map<number, Furnitur
|
||||
|
||||
const emptyExistingSet = (existingIds.length === 0);
|
||||
|
||||
const newSet = [ ...set ];
|
||||
|
||||
for(const id of removedIds) removeItemById(id, newSet);
|
||||
for(const id of removedIds) removeItemById(id, set);
|
||||
|
||||
for(const id of addedIds)
|
||||
{
|
||||
@ -167,10 +165,10 @@ export function processFragment(set: GroupItem[], fragment: Map<number, Furnitur
|
||||
|
||||
const item = new FurnitureItem(parser);
|
||||
|
||||
addFurnitureItem(newSet, item, true);
|
||||
addFurnitureItem(set, item, true);
|
||||
}
|
||||
|
||||
return newSet;
|
||||
return set;
|
||||
}
|
||||
|
||||
export function removeItemById(id: number, set: GroupItem[]): GroupItem
|
||||
|
@ -420,4 +420,9 @@ export class GroupItem
|
||||
{
|
||||
return this._items;
|
||||
}
|
||||
|
||||
public set items(items: FurnitureItem[])
|
||||
{
|
||||
this._items = items;
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,3 @@
|
||||
.item-container {
|
||||
height: 216px;
|
||||
max-height: 216px;
|
||||
overflow-y: auto;
|
||||
}
|
||||
|
||||
@import './item/InventoryFurnitureItemView';
|
||||
@import './results/InventoryFurnitureResultsView';
|
||||
@import './search/InventoryFurnitureSearchView';
|
||||
|
@ -4,45 +4,45 @@ import { GetRoomEngine } from '../../../../api';
|
||||
import { SendMessageHook } from '../../../../hooks/messages/message-event';
|
||||
import { LocalizeText } from '../../../../utils/LocalizeText';
|
||||
import { RoomPreviewerView } from '../../../room-previewer/RoomPreviewerView';
|
||||
import { useInventoryContext } from '../../context/InventoryContext';
|
||||
import { InventoryFurnitureActions } from '../../reducers/InventoryFurnitureReducer';
|
||||
import { FurniCategory } from '../../utils/FurniCategory';
|
||||
import { attemptItemPlacement } from '../../utils/FurnitureUtilities';
|
||||
import { InventoryFurnitureViewProps } from './InventoryFurnitureView.types';
|
||||
import { InventoryFurnitureItemView } from './item/InventoryFurnitureItemView';
|
||||
import { InventoryFurnitureResultsView } from './results/InventoryFurnitureResultsView';
|
||||
import { InventoryFurnitureSearchView } from './search/InventoryFurnitureSearchView';
|
||||
|
||||
export const InventoryFurnitureView: FC<InventoryFurnitureViewProps> = props =>
|
||||
{
|
||||
const { needsFurniUpdate = false, setNeedsFurniUpdate = null, groupItem = null, setGroupItem = null, groupItems = null, roomSession = null, roomPreviewer = null } = props;
|
||||
const { roomSession = null, roomPreviewer = null } = props;
|
||||
|
||||
console.log(props);
|
||||
const { furnitureState = null, dispatchFurnitureState = null } = useInventoryContext();
|
||||
const { needsFurniUpdate = false, groupItem = null, groupItems = [] } = furnitureState;
|
||||
|
||||
useEffect(() =>
|
||||
{
|
||||
if(needsFurniUpdate)
|
||||
{
|
||||
setNeedsFurniUpdate(false);
|
||||
dispatchFurnitureState({
|
||||
type: InventoryFurnitureActions.SET_NEEDS_UPDATE,
|
||||
payload: {
|
||||
flag: false
|
||||
}
|
||||
});
|
||||
|
||||
SendMessageHook(new FurnitureListComposer());
|
||||
}
|
||||
else
|
||||
{
|
||||
setGroupItem(prevValue =>
|
||||
{
|
||||
if(!groupItems || !groupItems.length) return null;
|
||||
|
||||
let index = 0;
|
||||
|
||||
if(prevValue)
|
||||
{
|
||||
const foundIndex = groupItems.indexOf(prevValue);
|
||||
|
||||
if(foundIndex > -1) index = foundIndex;
|
||||
}
|
||||
|
||||
return groupItems[index];
|
||||
});
|
||||
dispatchFurnitureState({
|
||||
type: InventoryFurnitureActions.SET_GROUP_ITEM,
|
||||
payload: {
|
||||
groupItem: null
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
}, [ needsFurniUpdate, setNeedsFurniUpdate, groupItems, setGroupItem ]);
|
||||
}, [ needsFurniUpdate, groupItems, dispatchFurnitureState ]);
|
||||
|
||||
useEffect(() =>
|
||||
{
|
||||
@ -97,18 +97,13 @@ export const InventoryFurnitureView: FC<InventoryFurnitureViewProps> = props =>
|
||||
return (
|
||||
<div className="row h-100">
|
||||
<div className="col col-7">
|
||||
<div className="row row-cols-5 g-0 item-container">
|
||||
{ groupItems && groupItems.length && groupItems.map((item, index) =>
|
||||
{
|
||||
return <InventoryFurnitureItemView key={ index } groupItem={ item } isActive={ groupItem === item } setGroupItem={ setGroupItem } />
|
||||
})
|
||||
}
|
||||
</div>
|
||||
<InventoryFurnitureSearchView />
|
||||
<InventoryFurnitureResultsView groupItems={ groupItems } />
|
||||
</div>
|
||||
<div className="d-flex flex-column col col-5 justify-space-between">
|
||||
<RoomPreviewerView roomPreviewer={ roomPreviewer } height={ 130 } />
|
||||
{ groupItem && <div className="flex-grow-1 py-2">
|
||||
<p className="fs-6 text-black">{ groupItem.name }</p>
|
||||
<RoomPreviewerView roomPreviewer={ roomPreviewer } height={ 140 } />
|
||||
{ groupItem && <div className="d-flex flex-column flex-grow-1">
|
||||
<p className="flex-grow-1 fs-6 text-black my-2">{ groupItem.name }</p>
|
||||
{ !!roomSession && <button type="button" className="btn btn-success" onClick={ event => attemptItemPlacement(groupItem) }>{ LocalizeText('inventory.furni.placetoroom') }</button> }
|
||||
</div> }
|
||||
</div>
|
||||
|
@ -1,14 +1,7 @@
|
||||
import { IRoomSession, RoomPreviewer } from 'nitro-renderer';
|
||||
import { Dispatch, SetStateAction } from 'react';
|
||||
import { GroupItem } from '../../utils/GroupItem';
|
||||
|
||||
export interface InventoryFurnitureViewProps
|
||||
{
|
||||
needsFurniUpdate: boolean;
|
||||
setNeedsFurniUpdate: Dispatch<SetStateAction<boolean>>;
|
||||
groupItem: GroupItem;
|
||||
setGroupItem: Dispatch<SetStateAction<GroupItem>>;
|
||||
groupItems: GroupItem[];
|
||||
roomSession: IRoomSession;
|
||||
roomPreviewer: RoomPreviewer;
|
||||
}
|
||||
|
@ -1,19 +1,25 @@
|
||||
.inventory-furniture-item {
|
||||
background-position: center;
|
||||
background-repeat: no-repeat;
|
||||
height: 50px;
|
||||
max-height: 50px;
|
||||
border-color: $muted !important;
|
||||
background-color: #CDD3D9;
|
||||
.inventory-furniture-item-container {
|
||||
height: 48px;
|
||||
max-height: 48px;
|
||||
|
||||
&.active {
|
||||
border-color: $white !important;
|
||||
background-color: #ECECEC;
|
||||
}
|
||||
|
||||
.badge {
|
||||
top: 3px;
|
||||
right: 3px;
|
||||
font-size: 10px;
|
||||
.inventory-furniture-item {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
background-position: center;
|
||||
background-repeat: no-repeat;
|
||||
border-color: $muted !important;
|
||||
background-color: #CDD3D9;
|
||||
overflow: hidden;
|
||||
|
||||
&.active {
|
||||
border-color: $white !important;
|
||||
background-color: #ECECEC;
|
||||
}
|
||||
|
||||
.badge {
|
||||
top: 2px;
|
||||
right: 2px;
|
||||
font-size: 8px;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,16 +1,48 @@
|
||||
import { FC } from 'react';
|
||||
import { MouseEventType } from 'nitro-renderer';
|
||||
import { FC, MouseEvent, useCallback, useState } from 'react';
|
||||
import { useInventoryContext } from '../../../context/InventoryContext';
|
||||
import { InventoryFurnitureActions } from '../../../reducers/InventoryFurnitureReducer';
|
||||
import { attemptItemPlacement } from '../../../utils/FurnitureUtilities';
|
||||
import { InventoryFurnitureItemViewProps } from './InventoryFurnitureItemView.types';
|
||||
|
||||
export const InventoryFurnitureItemView: FC<InventoryFurnitureItemViewProps> = props =>
|
||||
{
|
||||
const { groupItem = null, isActive = false, setGroupItem = null } = props;
|
||||
const { groupItem } = props;
|
||||
const { furnitureState, dispatchFurnitureState } = useInventoryContext();
|
||||
const [ isMouseDown, setMouseDown ] = useState(false);
|
||||
const isActive = (furnitureState.groupItem === groupItem);
|
||||
|
||||
const onMouseEvent = useCallback((event: MouseEvent) =>
|
||||
{
|
||||
switch(event.type)
|
||||
{
|
||||
case MouseEventType.MOUSE_DOWN:
|
||||
dispatchFurnitureState({
|
||||
type: InventoryFurnitureActions.SET_GROUP_ITEM,
|
||||
payload: {
|
||||
groupItem
|
||||
}
|
||||
});
|
||||
|
||||
setMouseDown(true);
|
||||
return;
|
||||
case MouseEventType.MOUSE_UP:
|
||||
setMouseDown(false);
|
||||
return;
|
||||
case MouseEventType.ROLL_OUT:
|
||||
if(!isMouseDown || !isActive) return;
|
||||
|
||||
attemptItemPlacement(groupItem);
|
||||
return;
|
||||
}
|
||||
}, [ isActive, isMouseDown, groupItem, dispatchFurnitureState ]);
|
||||
|
||||
const imageUrl = `url(${ groupItem.iconUrl })`;
|
||||
|
||||
return (
|
||||
<div className="col pe-1 pb-1">
|
||||
<div className={ 'position-relative border border-2 rounded inventory-furniture-item cursor-pointer ' + (isActive && 'active') } style={ { backgroundImage: imageUrl }} onClick={ event => setGroupItem(groupItem) }>
|
||||
<span className="position-absolute badge border bg-secondary p-1">{ groupItem.getUnlockedCount() }</span>
|
||||
<div className="col pe-1 pb-1 inventory-furniture-item-container">
|
||||
<div className={ 'position-relative border border-2 rounded inventory-furniture-item cursor-pointer ' + (isActive && 'active') } style={ { backgroundImage: imageUrl }} onMouseDown={ onMouseEvent } onMouseUp={ onMouseEvent } onMouseOut={ onMouseEvent }>
|
||||
<span className="position-absolute badge border bg-danger px-1 rounded-circle">{ groupItem.getUnlockedCount() }</span>
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
|
@ -1,9 +1,6 @@
|
||||
import { Dispatch, SetStateAction } from 'react';
|
||||
import { GroupItem } from '../../../utils/GroupItem';
|
||||
|
||||
export interface InventoryFurnitureItemViewProps
|
||||
{
|
||||
groupItem: GroupItem;
|
||||
isActive: boolean;
|
||||
setGroupItem: Dispatch<SetStateAction<GroupItem>>;
|
||||
}
|
||||
|
@ -0,0 +1,5 @@
|
||||
.item-container {
|
||||
height: 208px;
|
||||
max-height: 208px;
|
||||
overflow-y: auto;
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
import { FC } from 'react';
|
||||
import { InventoryFurnitureItemView } from '../item/InventoryFurnitureItemView';
|
||||
import { InventoryFurnitureResultsViewProps } from './InventoryFurnitureResultsView.types';
|
||||
|
||||
export const InventoryFurnitureResultsView: FC<InventoryFurnitureResultsViewProps> = props =>
|
||||
{
|
||||
const { groupItems = [] } = props;
|
||||
|
||||
return (
|
||||
<div className="row row-cols-5 g-0 item-container">
|
||||
{ groupItems && groupItems.length && groupItems.map((item, index) =>
|
||||
{
|
||||
return <InventoryFurnitureItemView key={ index } groupItem={ item } />
|
||||
})
|
||||
}
|
||||
</div>
|
||||
);
|
||||
}
|
@ -0,0 +1,6 @@
|
||||
import { GroupItem } from '../../../utils/GroupItem';
|
||||
|
||||
export interface InventoryFurnitureResultsViewProps
|
||||
{
|
||||
groupItems: GroupItem[];
|
||||
}
|
@ -0,0 +1,33 @@
|
||||
import { ChangeEvent, FC, FormEvent, useEffect, useState } from 'react';
|
||||
import { InventoryFurnitureSearchViewProps } from './InventoryFurnitureSearchView.types';
|
||||
|
||||
export const InventoryFurnitureSearchView: FC<InventoryFurnitureSearchViewProps> = props =>
|
||||
{
|
||||
const [ searchValue, setSearchValue ] = useState('');
|
||||
|
||||
function onChange(event: ChangeEvent<HTMLInputElement>): void
|
||||
{
|
||||
setSearchValue(event.target.value);
|
||||
}
|
||||
|
||||
function handleSubmit(event: FormEvent<HTMLFormElement>): void
|
||||
{
|
||||
event.preventDefault();
|
||||
}
|
||||
|
||||
useEffect(() =>
|
||||
{
|
||||
|
||||
}, [ searchValue ]);
|
||||
|
||||
return (
|
||||
<form className="d-flex mb-1" onSubmit={ handleSubmit }>
|
||||
<div className="d-flex flex-grow-1 me-1">
|
||||
<input type="text" className="form-control form-control-sm" placeholder="search" />
|
||||
</div>
|
||||
<div className="d-flex">
|
||||
<button type="submit" className="btn btn-primary btn-sm"><i className="fas fa-search"></i></button>
|
||||
</div>
|
||||
</form>
|
||||
);
|
||||
}
|
@ -0,0 +1,4 @@
|
||||
export interface InventoryFurnitureSearchViewProps
|
||||
{
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user