Random changes

This commit is contained in:
Bill 2022-02-01 01:58:28 -05:00
parent 8129bd3393
commit 55cb571290
6 changed files with 39 additions and 18 deletions

View File

@ -1,6 +1,7 @@
import { FC, useMemo } from 'react'; import { FC, useMemo } from 'react';
import { Base, BaseProps } from './Base'; import { Base, BaseProps } from './Base';
import { AlignItemType } from './types/AlignItemType'; import { AlignItemType } from './types/AlignItemType';
import { AlignSelfType } from './types/AlignSelfType';
import { JustifyContentType } from './types/JustifyContentType'; import { JustifyContentType } from './types/JustifyContentType';
import { SpacingType } from './types/SpacingType'; import { SpacingType } from './types/SpacingType';
@ -11,13 +12,14 @@ export interface FlexProps extends BaseProps<HTMLDivElement>
reverse?: boolean; reverse?: boolean;
gap?: SpacingType; gap?: SpacingType;
center?: boolean; center?: boolean;
alignSelf?: AlignSelfType;
alignItems?: AlignItemType; alignItems?: AlignItemType;
justifyContent?: JustifyContentType; justifyContent?: JustifyContentType;
} }
export const Flex: FC<FlexProps> = props => export const Flex: FC<FlexProps> = props =>
{ {
const { inline = false, column = undefined, reverse = false, gap = null, center = false, alignItems = null, justifyContent = null, classNames = [], ...rest } = props; const { inline = false, column = undefined, reverse = false, gap = null, center = false, alignSelf = null, alignItems = null, justifyContent = null, classNames = [], ...rest } = props;
const getClassNames = useMemo(() => const getClassNames = useMemo(() =>
{ {
@ -38,6 +40,8 @@ export const Flex: FC<FlexProps> = props =>
if(gap) newClassNames.push('gap-' + gap); if(gap) newClassNames.push('gap-' + gap);
if(alignSelf) newClassNames.push('align-self-' + alignSelf);
if(alignItems) newClassNames.push('align-items-' + alignItems); if(alignItems) newClassNames.push('align-items-' + alignItems);
if(justifyContent) newClassNames.push('justify-content-' + justifyContent); if(justifyContent) newClassNames.push('justify-content-' + justifyContent);
@ -47,7 +51,7 @@ export const Flex: FC<FlexProps> = props =>
if(classNames.length) newClassNames.push(...classNames); if(classNames.length) newClassNames.push(...classNames);
return newClassNames; return newClassNames;
}, [ inline, column, reverse, gap, center, alignItems, justifyContent, classNames ]); }, [ inline, column, reverse, gap, center, alignSelf, alignItems, justifyContent, classNames ]);
return <Base classNames={ getClassNames } { ...rest } />; return <Base classNames={ getClassNames } { ...rest } />;
} }

View File

@ -0,0 +1 @@
export type AlignSelfType = 'start' | 'end' | 'center' | 'baseline' | 'stretch';

View File

@ -0,0 +1,14 @@
import { NitroToolbarAnimateIconEvent } from '@nitrots/nitro-renderer';
import { GetRoomEngine } from '../../api';
export const CreateTransitionToIcon = (image: HTMLImageElement, fromElement: HTMLElement, icon: string) =>
{
const bounds = fromElement.getBoundingClientRect();
const x = (bounds.x + (bounds.width / 2));
const y = (bounds.y + (bounds.height / 2));
const event = new NitroToolbarAnimateIconEvent(image, x, y);
event.iconName = icon;
GetRoomEngine().events.dispatchEvent(event);
}

View File

@ -1,8 +1,7 @@
import { BadgeImageReadyEvent, NitroSprite, TextureUtils } from '@nitrots/nitro-renderer'; import { BadgeImageReadyEvent, NitroSprite, TextureUtils } from '@nitrots/nitro-renderer';
import { FC, useEffect, useMemo, useState } from 'react'; import { CSSProperties, FC, useEffect, useMemo, useState } from 'react';
import { GetSessionDataManager, LocalizeBadgeDescription, LocalizeBadgeName, LocalizeText } from '../../../api'; import { GetSessionDataManager, LocalizeBadgeDescription, LocalizeBadgeName, LocalizeText } from '../../../api';
import { BaseProps } from '../../../common/Base'; import { Base, BaseProps } from '../../../common/Base';
import { NitroLayoutBase } from '../../../layout/base';
import { BadgeInformationView } from './badge-info/BadgeInformationView'; import { BadgeInformationView } from './badge-info/BadgeInformationView';
export interface BadgeImageViewProps extends BaseProps<HTMLDivElement> export interface BadgeImageViewProps extends BaseProps<HTMLDivElement>
@ -17,7 +16,7 @@ export interface BadgeImageViewProps extends BaseProps<HTMLDivElement>
export const BadgeImageView: FC<BadgeImageViewProps> = props => export const BadgeImageView: FC<BadgeImageViewProps> = props =>
{ {
const { badgeCode = null, isGroup = false, showInfo = false, customTitle = null, isGrayscale = false, scale = 1, className = '', style = null, children = null, ...rest } = props; const { badgeCode = null, isGroup = false, showInfo = false, customTitle = null, isGrayscale = false, scale = 1, classNames = [], style = {}, children = null, ...rest } = props;
const [ badgeUrl, setBadgeUrl ] = useState<string>(''); const [ badgeUrl, setBadgeUrl ] = useState<string>('');
const [ isListening, setIsListening ] = useState<boolean>(true); const [ isListening, setIsListening ] = useState<boolean>(true);
@ -36,25 +35,27 @@ export const BadgeImageView: FC<BadgeImageViewProps> = props =>
return `scale-${ scaleName }`; return `scale-${ scaleName }`;
}, [ scale ]); }, [ scale ]);
const getClassName = useMemo(() => const getClassNames = useMemo(() =>
{ {
let newClassName = 'badge-image'; const newClassNames: string[] = [ 'badge-image' ];
if(isGrayscale) newClassName += ' grayscale'; if(isGrayscale) newClassNames.push('grayscale');
if((scale !== 1) && getScaleClass.length) newClassName += ` ${ getScaleClass }`; if((scale !== 1) && getScaleClass.length) newClassNames.push(getScaleClass);
if(className && className.length) newClassName += ' ' + className; if(classNames.length) newClassNames.push(...classNames);
return newClassName; return newClassNames;
}, [ className, isGrayscale, scale, getScaleClass ]); }, [ classNames, isGrayscale, scale, getScaleClass ]);
const getStyle = useMemo(() => const getStyle = useMemo(() =>
{ {
const newStyle = { ...style }; let newStyle: CSSProperties = {};
if(badgeUrl && badgeUrl.length) newStyle.backgroundImage = `url(${ badgeUrl })`; if(badgeUrl && badgeUrl.length) newStyle.backgroundImage = `url(${ badgeUrl })`;
if(Object.keys(style).length) newStyle = { ...newStyle, ...style };
return newStyle; return newStyle;
}, [ style, badgeUrl ]); }, [ style, badgeUrl ]);
@ -99,9 +100,9 @@ export const BadgeImageView: FC<BadgeImageViewProps> = props =>
}, [ badgeCode, isGroup, isListening ]); }, [ badgeCode, isGroup, isListening ]);
return ( return (
<NitroLayoutBase className={ getClassName } style={ getStyle }> <Base classNames={ getClassNames } style={ getStyle } { ...rest }>
{ showInfo && <BadgeInformationView title={ isGroup ? customTitle : LocalizeBadgeName(badgeCode) } description={ isGroup ? LocalizeText('group.badgepopup.body') : LocalizeBadgeDescription(badgeCode) } /> } { showInfo && <BadgeInformationView title={ isGroup ? customTitle : LocalizeBadgeName(badgeCode) } description={ isGroup ? LocalizeText('group.badgepopup.body') : LocalizeBadgeDescription(badgeCode) } /> }
{ children } { children }
</NitroLayoutBase> </Base>
); );
} }

View File

@ -1,6 +1,6 @@
.nitro-currency-icon { .nitro-currency-icon {
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;
width: 18px; width: 15px;
height: 17px; height: 15px;
} }

View File

@ -12,6 +12,7 @@
background-color: $light; background-color: $light;
background-repeat: no-repeat; background-repeat: no-repeat;
background-position: center; background-position: center;
overflow: hidden;
&.border-0 { &.border-0 {
&::after { &::after {