mirror of
https://github.com/duckietm/Nitro-V3.git
synced 2026-06-20 07:26:19 +00:00
68 lines
2.8 KiB
TypeScript
68 lines
2.8 KiB
TypeScript
import { MysteryBoxKeysUpdateEvent } from '@nitrots/nitro-renderer';
|
|
import { FC, useState } from 'react';
|
|
import { FaChevronDown, FaChevronUp } from 'react-icons/fa';
|
|
import { ColorUtils, LocalizeText } from '../../../../api';
|
|
import { Flex, LayoutGridItem, Text } from '../../../../common';
|
|
import { useNitroEvent } from '../../../../hooks';
|
|
|
|
const colorMap = {
|
|
'purple': 9452386,
|
|
'blue': 3891856,
|
|
'green': 6459451,
|
|
'yellow': 10658089,
|
|
'lilac': 6897548,
|
|
'orange': 10841125,
|
|
'turquoise': 2661026,
|
|
'red': 10104881
|
|
};
|
|
|
|
export const MysteryBoxExtensionView: FC<{}> = props =>
|
|
{
|
|
const [ isOpen, setIsOpen ] = useState<boolean>(true);
|
|
const [ keyColor, setKeyColor ] = useState<string>('');
|
|
const [ boxColor, setBoxColor ] = useState<string>('');
|
|
|
|
useNitroEvent<MysteryBoxKeysUpdateEvent>(MysteryBoxKeysUpdateEvent.MYSTERY_BOX_KEYS_UPDATE, event =>
|
|
{
|
|
setKeyColor(event.keyColor);
|
|
setBoxColor(event.boxColor);
|
|
});
|
|
|
|
const getRgbColor = (color: string) =>
|
|
{
|
|
const colorInt = colorMap[color];
|
|
|
|
return ColorUtils.int2rgb(colorInt);
|
|
};
|
|
|
|
if(keyColor === '' && boxColor === '') return null;
|
|
|
|
return (
|
|
<div className="px-[5px] py-[6px] [box-shadow:inset_0_5px_#22222799,inset_0_-4px_#12121599] text-sm bg-[#1c1c20f2] rounded mysterybox-extension">
|
|
<div className="flex flex-col">
|
|
<Flex pointer alignItems="center" justifyContent="between" onClick={ event => setIsOpen(value => !value) }>
|
|
<Text variant="white">{ LocalizeText('mysterybox.tracker.title') }</Text>
|
|
{ isOpen && <FaChevronUp className="fa-icon" /> }
|
|
{ !isOpen && <FaChevronDown className="fa-icon" /> }
|
|
</Flex>
|
|
{ isOpen &&
|
|
<>
|
|
<Text variant="white">{ LocalizeText('mysterybox.tracker.description') }</Text>
|
|
<div className="flex items-center gap-2 justify-center">
|
|
<LayoutGridItem className="mysterybox-container">
|
|
<div className="box-image shrink-0" style={ { backgroundColor: getRgbColor(boxColor) } }>
|
|
<div className="chain-overlay-image" />
|
|
</div>
|
|
</LayoutGridItem>
|
|
<LayoutGridItem className="mysterybox-container">
|
|
<div className="key-image shrink-0" style={ { backgroundColor: getRgbColor(keyColor) } }>
|
|
<div className="key-overlay-image" />
|
|
</div>
|
|
</LayoutGridItem>
|
|
</div>
|
|
</> }
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|