mirror of
https://github.com/billsonnn/nitro-react.git
synced 2024-11-27 08:00:51 +01:00
Update avatar editor
This commit is contained in:
parent
a5fcea1cd7
commit
67270ee093
BIN
src/assets/images/avatareditor/avatar-editor-spritesheet.png
Normal file
BIN
src/assets/images/avatareditor/avatar-editor-spritesheet.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 23 KiB |
Binary file not shown.
Before Width: | Height: | Size: 1.6 KiB |
@ -1,3 +1,217 @@
|
|||||||
|
.nitro-avatar-editor-spritesheet {
|
||||||
|
background: url('../../assets/images/avatareditor/avatar-editor-spritesheet.png') transparent no-repeat;
|
||||||
|
|
||||||
|
&.arrow-left-icon {
|
||||||
|
width: 28px;
|
||||||
|
height: 21px;
|
||||||
|
background-position: -226px -131px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.arrow-right-icon {
|
||||||
|
width: 28px;
|
||||||
|
height: 21px;
|
||||||
|
background-position: -226px -162px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.ca-icon {
|
||||||
|
width: 25px;
|
||||||
|
height: 25px;
|
||||||
|
background-position: -226px -61px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 25px;
|
||||||
|
height: 25px;
|
||||||
|
background-position: -226px -96px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.cc-icon {
|
||||||
|
width: 31px;
|
||||||
|
height: 29px;
|
||||||
|
background-position: -145px -5px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 31px;
|
||||||
|
height: 29px;
|
||||||
|
background-position: -145px -44px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.ch-icon {
|
||||||
|
width: 29px;
|
||||||
|
height: 24px;
|
||||||
|
background-position: -186px -39px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 29px;
|
||||||
|
height: 24px;
|
||||||
|
background-position: -186px -73px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.clear-icon {
|
||||||
|
width: 27px;
|
||||||
|
height: 27px;
|
||||||
|
background-position: -145px -157px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.cp-icon {
|
||||||
|
width: 30px;
|
||||||
|
height: 24px;
|
||||||
|
background-position: -145px -264px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 30px;
|
||||||
|
height: 24px;
|
||||||
|
background-position: -186px -5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
&.ea-icon {
|
||||||
|
width: 35px;
|
||||||
|
height: 16px;
|
||||||
|
background-position: -226px -193px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 35px;
|
||||||
|
height: 16px;
|
||||||
|
background-position: -226px -219px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.fa-icon {
|
||||||
|
width: 27px;
|
||||||
|
height: 20px;
|
||||||
|
background-position: -186px -137px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 27px;
|
||||||
|
height: 20px;
|
||||||
|
background-position: -186px -107px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.female-icon {
|
||||||
|
width: 18px;
|
||||||
|
height: 27px;
|
||||||
|
background-position: -186px -202px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 18px;
|
||||||
|
height: 27px;
|
||||||
|
background-position: -186px -239px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.ha-icon {
|
||||||
|
width: 25px;
|
||||||
|
height: 22px;
|
||||||
|
background-position: -226px -245px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 25px;
|
||||||
|
height: 22px;
|
||||||
|
background-position: -226px -277px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.he-icon {
|
||||||
|
width: 31px;
|
||||||
|
height: 27px;
|
||||||
|
background-position: -145px -83px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 31px;
|
||||||
|
height: 27px;
|
||||||
|
background-position: -145px -120px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.hr-icon {
|
||||||
|
width: 29px;
|
||||||
|
height: 25px;
|
||||||
|
background-position: -145px -194px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 29px;
|
||||||
|
height: 25px;
|
||||||
|
background-position: -145px -229px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.lg-icon {
|
||||||
|
width: 19px;
|
||||||
|
height: 20px;
|
||||||
|
background-position: -303px -45px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 19px;
|
||||||
|
height: 20px;
|
||||||
|
background-position: -303px -75px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.loading-icon {
|
||||||
|
width: 21px;
|
||||||
|
height: 25px;
|
||||||
|
background-position: -186px -167px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
&.male-icon {
|
||||||
|
width: 21px;
|
||||||
|
height: 21px;
|
||||||
|
background-position: -186px -276px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 21px;
|
||||||
|
height: 21px;
|
||||||
|
background-position: -272px -5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
&.sellable-icon {
|
||||||
|
width: 17px;
|
||||||
|
height: 15px;
|
||||||
|
background-position: -303px -105px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
&.sh-icon {
|
||||||
|
width: 37px;
|
||||||
|
height: 10px;
|
||||||
|
background-position: -303px -5px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 37px;
|
||||||
|
height: 10px;
|
||||||
|
background-position: -303px -25px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
&.spotlight {
|
||||||
|
width: 130px;
|
||||||
|
height: 305px;
|
||||||
|
background-position: -5px -5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
&.wa-icon {
|
||||||
|
width: 36px;
|
||||||
|
height: 18px;
|
||||||
|
background-position: -226px -5px;
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
width: 36px;
|
||||||
|
height: 18px;
|
||||||
|
background-position: -226px -33px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.nitro-avatar-editor {
|
.nitro-avatar-editor {
|
||||||
width: $avatar-editor-width;
|
width: $avatar-editor-width;
|
||||||
height: $avatar-editor-height;
|
height: $avatar-editor-height;
|
||||||
@ -37,13 +251,10 @@
|
|||||||
z-index: 4;
|
z-index: 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
.avatar-spotlight {
|
.spotlight {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: -10px;
|
top: -10px;
|
||||||
width: 100%;
|
|
||||||
height: 305px;
|
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
background: transparent url('../../assets/images/avatareditor/spotlight.png') no-repeat center;
|
|
||||||
opacity: 0.3;
|
opacity: 0.3;
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
z-index: 3;
|
z-index: 3;
|
||||||
|
@ -45,11 +45,11 @@ export const AvatarEditorFigurePreviewView: FC<AvatarEditorFigurePreviewViewProp
|
|||||||
return (
|
return (
|
||||||
<NitroLayoutFlexColumn className="figure-preview-container" overflow="hidden" position="relative">
|
<NitroLayoutFlexColumn className="figure-preview-container" overflow="hidden" position="relative">
|
||||||
<AvatarImageView figure={ figureData.getFigureString() } direction={ figureData.direction } scale={ 2 } />
|
<AvatarImageView figure={ figureData.getFigureString() } direction={ figureData.direction } scale={ 2 } />
|
||||||
<NitroLayoutBase className="avatar-spotlight" />
|
<NitroLayoutBase className="nitro-avatar-editor-spritesheet spotlight" />
|
||||||
<NitroLayoutBase className="avatar-shadow" />
|
<NitroLayoutBase className="avatar-shadow" />
|
||||||
<NitroLayoutBase className="arrow-container">
|
<NitroLayoutBase className="arrow-container">
|
||||||
<i className="icon arrow-left-icon" onClick={ event => rotateFigure(figureData.direction + 1) } />
|
<div className="nitro-avatar-editor-spritesheet arrow-left-icon" onClick={ event => rotateFigure(figureData.direction + 1) } />
|
||||||
<i className="icon arrow-right-icon" onClick={ event => rotateFigure(figureData.direction - 1) } />
|
<div className="nitro-avatar-editor-spritesheet arrow-right-icon" onClick={ event => rotateFigure(figureData.direction - 1) } />
|
||||||
</NitroLayoutBase>
|
</NitroLayoutBase>
|
||||||
</NitroLayoutFlexColumn>
|
</NitroLayoutFlexColumn>
|
||||||
);
|
);
|
||||||
|
@ -26,8 +26,8 @@ export const AvatarEditorFigureSetItemView: FC<AvatarEditorFigureSetItemViewProp
|
|||||||
return (
|
return (
|
||||||
<NitroCardGridItemView itemImage={ (partItem.isClear ? undefined : partItem.imageUrl) } itemActive={ partItem.isSelected } onClick={ event => onClick(partItem) }>
|
<NitroCardGridItemView itemImage={ (partItem.isClear ? undefined : partItem.imageUrl) } itemActive={ partItem.isSelected } onClick={ event => onClick(partItem) }>
|
||||||
{ partItem.isHC && <CurrencyIcon className="position-absolute end-1 bottom-1" type={ 'hc' } /> }
|
{ partItem.isHC && <CurrencyIcon className="position-absolute end-1 bottom-1" type={ 'hc' } /> }
|
||||||
{ partItem.isClear && <i className="icon clear-icon" /> }
|
{ partItem.isClear && <div className="nitro-avatar-editor-spritesheet clear-icon" /> }
|
||||||
{ partItem.isSellable && <i className="position-absolute icon sellable-icon end-1 bottom-1" /> }
|
{ partItem.isSellable && <div className="position-absolute nitro-avatar-editor-spritesheet sellable-icon end-1 bottom-1" /> }
|
||||||
</NitroCardGridItemView>
|
</NitroCardGridItemView>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -52,10 +52,10 @@ export const AvatarEditorModelView: FC<AvatarEditorModelViewProps> = props =>
|
|||||||
{ model.canSetGender &&
|
{ model.canSetGender &&
|
||||||
<>
|
<>
|
||||||
<NitroLayoutFlex className="justify-content-center align-items-center category-item cursor-pointer" onClick={ event => setGender(FigureData.MALE) }>
|
<NitroLayoutFlex className="justify-content-center align-items-center category-item cursor-pointer" onClick={ event => setGender(FigureData.MALE) }>
|
||||||
<i className={ `icon male-icon ${ (gender === FigureData.MALE) ? ' selected' : ''}` } />
|
<div className={ `nitro-avatar-editor-spritesheet male-icon ${ (gender === FigureData.MALE) ? ' selected' : ''}` } />
|
||||||
</NitroLayoutFlex>
|
</NitroLayoutFlex>
|
||||||
<NitroLayoutFlex className="justify-content-center align-items-center category-item cursor-pointer" onClick={ event => setGender(FigureData.FEMALE) }>
|
<NitroLayoutFlex className="justify-content-center align-items-center category-item cursor-pointer" onClick={ event => setGender(FigureData.FEMALE) }>
|
||||||
<i className={ `icon female-icon ${ (gender === FigureData.FEMALE) ? ' selected' : ''}` } />
|
<div className={ `nitro-avatar-editor-spritesheet female-icon ${ (gender === FigureData.FEMALE) ? ' selected' : ''}` } />
|
||||||
</NitroLayoutFlex>
|
</NitroLayoutFlex>
|
||||||
</> }
|
</> }
|
||||||
{ !model.canSetGender && model.categories && (model.categories.size > 0) && Array.from(model.categories.keys()).map(name =>
|
{ !model.canSetGender && model.categories && (model.categories.size > 0) && Array.from(model.categories.keys()).map(name =>
|
||||||
@ -64,7 +64,7 @@ export const AvatarEditorModelView: FC<AvatarEditorModelViewProps> = props =>
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<NitroLayoutFlex key={ name } className="justify-content-center align-items-center category-item cursor-pointer" onClick={ event => selectCategory(name) }>
|
<NitroLayoutFlex key={ name } className="justify-content-center align-items-center category-item cursor-pointer" onClick={ event => selectCategory(name) }>
|
||||||
<i className={ `icon ${ category.name }-icon ${ (activeCategory === category) ? ' selected' : ''}` } />
|
<div className={ `nitro-avatar-editor-spritesheet ${ category.name }-icon ${ (activeCategory === category) ? ' selected' : ''}` } />
|
||||||
</NitroLayoutFlex>
|
</NitroLayoutFlex>
|
||||||
);
|
);
|
||||||
})}
|
})}
|
||||||
|
Loading…
Reference in New Issue
Block a user