mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-11-28 10:06:08 -05:00
443 lines
9.9 KiB
Sass
443 lines
9.9 KiB
Sass
@import "app/styles/mixins"
|
|
|
|
$itemSlotSize: 55px
|
|
$itemSlotInnerWidth: $itemSlotSize - 4
|
|
$itemSlotGridHeight: 70px
|
|
|
|
.ui-effects-transfer
|
|
outline: 2px solid #28f
|
|
@include box-shadow(0 0 10px #28f)
|
|
z-index: 9001
|
|
|
|
#inventory-modal
|
|
|
|
//- Overall modal structure
|
|
.modal-dialog
|
|
margin: 30px auto 0 auto
|
|
width: 1017px
|
|
height: 660px
|
|
|
|
.modal-content
|
|
height: 100%
|
|
width: 100%
|
|
|
|
.modal-body
|
|
height: 450px
|
|
margin: 0
|
|
|
|
+user-select(none)
|
|
|
|
|
|
//- Background
|
|
|
|
#play-items-modal-narrow-bg
|
|
position: absolute
|
|
top: -69px
|
|
left: -8px
|
|
|
|
|
|
//- Gems count
|
|
|
|
#gems-count-container
|
|
position: absolute
|
|
left: 213px
|
|
top: 10px
|
|
width: 160px
|
|
height: 66px
|
|
@include rotate(5deg)
|
|
|
|
#gems-count
|
|
position: absolute
|
|
left: 75px
|
|
top: 17px
|
|
font-size: 25px
|
|
color: rgb(1,64,91)
|
|
|
|
|
|
//- Close modal button
|
|
|
|
#close-modal
|
|
position: absolute
|
|
left: 390px
|
|
top: 23px
|
|
width: 60px
|
|
height: 60px
|
|
color: white
|
|
text-align: center
|
|
font-size: 30px
|
|
padding-top: 7px
|
|
cursor: pointer
|
|
@include rotate(-3deg)
|
|
|
|
&:hover
|
|
color: yellow
|
|
|
|
|
|
//- Equipped area
|
|
|
|
#equipped
|
|
width: 330px
|
|
background: white
|
|
border: 3px solid black
|
|
position: absolute
|
|
left: 20px
|
|
top: 112px
|
|
height: 450px
|
|
overflow: hidden
|
|
|
|
#hero-image
|
|
@include filter(contrast(0%) brightness(0%))
|
|
opacity: 0.4
|
|
width: 225px
|
|
height: 410px
|
|
position: absolute
|
|
left: 10px
|
|
top: 20px
|
|
|
|
.item-slot
|
|
width: $itemSlotSize
|
|
height: $itemSlotSize
|
|
margin: 5px
|
|
background-color: rgba(255,255,255,0.4)
|
|
border: 2px dashed rgb(100,100,150)
|
|
position: relative
|
|
cursor: pointer
|
|
@include transition(0.5s ease)
|
|
|
|
//&.disabled
|
|
// opacity: 0.5
|
|
|
|
&.selected
|
|
.placeholder, img.item
|
|
border-color: rgb(81,153,236)
|
|
background-color: rgb(81,153,236)
|
|
@include box-shadow(0 0 10px rgb(81,153,236))
|
|
img.item
|
|
background: rgb(81,153,236)
|
|
|
|
&.should-equip
|
|
background-color: #8fa
|
|
outline: 2px solid #8af
|
|
@include box-shadow(2px 2px 4px black)
|
|
|
|
&.droppable
|
|
outline: 2px solid blue
|
|
@include box-shadow(4px 4px 6px black)
|
|
|
|
&.droppable-hover
|
|
outline: 4px solid blue
|
|
@include box-shadow(6px 6px 8px black)
|
|
|
|
.placeholder
|
|
width: 100%
|
|
height: 100%
|
|
background-size: cover
|
|
@include opacity(0.7)
|
|
background-image: url(/images/pages/game-menu/slot-icons.png)
|
|
|
|
|
|
// A terrible awful bit of styling, but will be gone or messed around with soon anyway
|
|
|
|
&[data-slot="misc-1"]
|
|
display: none // hiding for now
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px + ($itemSlotGridHeight * 3)
|
|
.placeholder
|
|
background-position: (-0 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="misc-0"]
|
|
display: none // hiding for now
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px + ($itemSlotGridHeight * 2)
|
|
.placeholder
|
|
background-position: (-4 * $itemSlotInnerWidth) 0px
|
|
|
|
|
|
&[data-slot="minion"]
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px + ($itemSlotGridHeight * 1)
|
|
.placeholder
|
|
background-position: (-1 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="programming-book"]
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px + ($itemSlotGridHeight * 4)
|
|
.placeholder
|
|
background-position: (-3 * $itemSlotInnerWidth) 0px
|
|
|
|
// Only for wizards...
|
|
//&[data-slot="spellbook"] .placeholder
|
|
// background-position: (-2 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="wrists"]
|
|
position: absolute
|
|
left: 20px
|
|
top: 20px + ($itemSlotGridHeight * 2.5)
|
|
.placeholder
|
|
background-position: (-5 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="left-ring"]
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px + ($itemSlotGridHeight * 2)
|
|
.placeholder
|
|
background-position: (-6 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="right-ring"]
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px + ($itemSlotGridHeight * 3)
|
|
.placeholder
|
|
background-position: (-7 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="torso"]
|
|
position: absolute
|
|
left: 90px
|
|
top: 20px + ($itemSlotGridHeight * 3)
|
|
.placeholder
|
|
background-position: (-8 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="feet"]
|
|
position: absolute
|
|
left: 90px
|
|
top: 20px + ($itemSlotGridHeight * 5)
|
|
.placeholder
|
|
background-position: (-9 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="neck"]
|
|
position: absolute
|
|
left: 90px
|
|
top: 20px + ($itemSlotGridHeight * 2)
|
|
.placeholder
|
|
background-position: (-10 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="waist"]
|
|
position: absolute
|
|
left: 90px
|
|
top: 20px + ($itemSlotGridHeight * 4)
|
|
.placeholder
|
|
background-position: (-11 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="eyes"]
|
|
position: absolute
|
|
left: 90px
|
|
top: 20px + $itemSlotGridHeight
|
|
.placeholder
|
|
background-position: (-12 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="head"]
|
|
position: absolute
|
|
left: 90px
|
|
top: 20px
|
|
.placeholder
|
|
background-position: (-13 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="pet"]
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px
|
|
.placeholder
|
|
background-position: (-14 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="gloves"]
|
|
position: absolute
|
|
left: 160px
|
|
top: 20px + ($itemSlotGridHeight * 2.5)
|
|
.placeholder
|
|
background-position: (-15 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="left-hand"]
|
|
position: absolute
|
|
left: 160px
|
|
top: 20px + ($itemSlotGridHeight * 3.5)
|
|
.placeholder
|
|
background-position: (-16 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="right-hand"]
|
|
position: absolute
|
|
left: 20px
|
|
top: 20px + ($itemSlotGridHeight * 3.5)
|
|
.placeholder
|
|
background-position: (-17 * $itemSlotInnerWidth) 0px
|
|
|
|
&[data-slot="flag"]
|
|
position: absolute
|
|
left: 250px
|
|
top: 20px + ($itemSlotGridHeight * 5)
|
|
.placeholder
|
|
background-position: (-2 * $itemSlotInnerWidth) 0px
|
|
|
|
img.item
|
|
position: absolute
|
|
left: -2px
|
|
top: -2px
|
|
|
|
width: $itemSlotSize
|
|
height: $itemSlotSize
|
|
border: 2px solid black
|
|
background-color: white
|
|
|
|
|
|
//- dragging styling
|
|
|
|
#equipped
|
|
|
|
&.droppable
|
|
outline: 2px solid blue
|
|
@include box-shadow(4px 4px 6px black)
|
|
|
|
&.droppable-hover
|
|
outline: 4px solid blue
|
|
@include box-shadow(6px 6px 8px black)
|
|
|
|
.draggable-item
|
|
width: $itemSlotSize * 1.2
|
|
height: $itemSlotSize * 1.2
|
|
|
|
|
|
//- Available equipment
|
|
|
|
&.Warrior #unequipped img.item:not(.Warrior), &.Ranger #unequipped img.item:not(.Ranger), &.Wizard #unequipped img.item:not(.Wizard)
|
|
// Our code hides and shows (modifies display), but we can be invisible this other way.
|
|
visibility: hidden
|
|
position: absolute
|
|
|
|
#unequipped
|
|
width: 222px
|
|
position: absolute
|
|
left: 370px
|
|
top: 112px
|
|
height: 450px
|
|
border: 3px solid black
|
|
padding: 9px 0 9px 9px
|
|
background-color: white
|
|
|
|
#double-click-hint
|
|
margin: 20px 0 70px
|
|
|
|
h4
|
|
clear: both
|
|
margin-bottom: 10px
|
|
margin-top: 20px
|
|
font-size: 24px
|
|
text-transform: uppercase
|
|
font-weight: bold
|
|
|
|
img.item
|
|
float: left
|
|
border: 1px solid black
|
|
margin: 3px
|
|
padding: 1px
|
|
width: 60px
|
|
height: 60px
|
|
cursor: pointer
|
|
|
|
&.active
|
|
background-color: rgb(81,153,236)
|
|
|
|
//.status-message .should-equip-message
|
|
// display: inline
|
|
|
|
&.should-equip
|
|
background-color: #8fa
|
|
outline: 2px solid #8af
|
|
@include box-shadow(4px 4px 6px black)
|
|
z-index: 1
|
|
|
|
//.status-message .should-equip-message
|
|
// display: inline
|
|
// font-weight: bold
|
|
|
|
&.equipped
|
|
background-color: #ff5
|
|
display: none
|
|
cursor: default
|
|
|
|
//.item-view
|
|
// cursor: default
|
|
//
|
|
//.status-message .equipped-message
|
|
// display: inline
|
|
|
|
&.restricted
|
|
background-color: rgba(255, 80, 67, 0.25)
|
|
cursor: default
|
|
|
|
//.item-view
|
|
// cursor: default
|
|
//
|
|
//.status-message .restricted-message
|
|
// display: inline
|
|
|
|
&.locked
|
|
cursor: default
|
|
//background-color: gray
|
|
|
|
&.silhouette
|
|
cursor: default
|
|
pointer-events: none
|
|
@include filter(contrast(25%) brightness(25%))
|
|
opacity: 0.5
|
|
|
|
|
|
//- Hero/Play buttons
|
|
|
|
#choose-hero-button, #play-level-button
|
|
top: 572px
|
|
position: absolute
|
|
background: url(/images/pages/play/modal/confirm-button.png)
|
|
width: 209px
|
|
height: 65px
|
|
background-size: 209px 65px
|
|
border: 0
|
|
|
|
&:disabled
|
|
opacity: 1
|
|
@include filter(grayscale(100%))
|
|
|
|
|
|
#choose-hero-button
|
|
left: 20px
|
|
|
|
#play-level-button
|
|
right: 414px
|
|
|
|
|
|
//- Item details. Non-specific item-details-view styling is in item-details-view.sass.
|
|
|
|
#item-details-view
|
|
|
|
#item-title
|
|
left: 698px
|
|
top: 56px
|
|
|
|
#item-details-body
|
|
left: 650px
|
|
|
|
#selected-item-unlock-button
|
|
left: 646px
|
|
|
|
|
|
//- Equip/unequip/extra
|
|
|
|
#item-details-extra
|
|
position: absolute
|
|
left: 644px
|
|
top: 589px
|
|
|
|
& > *
|
|
width: 338px
|
|
height: 50px
|
|
|
|
.alert
|
|
text-align: center
|
|
font-weight: bold
|
|
|
|
button
|
|
border: 3px solid rgb(46,46,46)
|
|
background: white
|
|
font-size: 16px
|