@import "../../imports/colours";
@import "../../imports/mixins/opacity";
@import "../../imports/mixins/border-box";

.user-hover-trigger {
    margin-left: 2px;

    &:hover,
    &:focus {
        text-decoration: none;
    }
}

.user-hover-info {
    min-height: 48px;
    position: relative;
    padding: 7px;
    // leaving room for the popup close button
    margin-right: 30px;
}

.user-hover-name {
    // leaving room for the slack integration link
    word-break: break-word;
    margin-right: 35px;
}

.user-hover-close {
    position: absolute;
    top: 12px;
    right: 10px;

    &:hover,
    &:focus {
        text-decoration: none;
    }
}

.user-hover-avatar {
    float: left;
    margin: 0 10px 0 0;
    height: 48px;
    width: 48px;
}

.user-hover-avatar img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
}

.user-hover-details {
    display: flex;
    flex-direction: column;
}

.user-hover-info h4 {
    font-size: 1.2em;
}

.user-hover-info ul {
    color: var(--ds-text, @jira-color-text);
    padding-top: 7px;
}

.user-hover-info .user-hover-section-wrapper {
    font-weight: normal;
    text-transform: inherit;
}

.user-hover-info .user-hover-section-wrapper a {
    padding-top: 7px;
    text-decoration: underline;
    color: var(--ds-text-subtle, @jira-color-subtle-text);
    font-size: 12px;
}

.user-hover-info .time-zone-info {
    // keep the text from wrapping if it's too long
    overflow: hidden;
    white-space: nowrap;

    .user-hover-margin(@size: 2px) {
        margin-right: 2*@size;
        margin-top: @size;
    }

    // time of day sprite properties
    @spritePixels: 16px;
    @spriteUrl: "../../../images/time_of_day_sprite.png";
    .spriteElement(@hour) {
        background-position: @hour*@spritePixels*-1 0;
    }

    .user-time-text {
        .user-hover-margin();
        color: var(--ds-text, #666);
        font-size: 12px;
        display: inline-block;
        vertical-align: middle;
    }

    // adds the background image to the div
    .user-time-icon {
        background: url(@spriteUrl) no-repeat;
        background-color: transparent;
        display: inline-block;
        height: @spritePixels;
        vertical-align: middle;
        width: @spritePixels;
    }

    // one entry for each hour in the day
    .hour-of-day-00 {
        .spriteElement(0);
    }
    .hour-of-day-01 {
        .spriteElement(1);
    }
    .hour-of-day-02 {
        .spriteElement(2);
    }
    .hour-of-day-03 {
        .spriteElement(3);
    }
    .hour-of-day-04 {
        .spriteElement(4);
    }
    .hour-of-day-05 {
        .spriteElement(5);
    }
    .hour-of-day-06 {
        .spriteElement(6);
    }
    .hour-of-day-07 {
        .spriteElement(7);
    }
    .hour-of-day-08 {
        .spriteElement(8);
    }
    .hour-of-day-09 {
        .spriteElement(9);
    }
    .hour-of-day-10 {
        .spriteElement(10);
    }
    .hour-of-day-11 {
        .spriteElement(11);
    }
    .hour-of-day-12 {
        .spriteElement(12);
    }
    .hour-of-day-13 {
        .spriteElement(13);
    }
    .hour-of-day-14 {
        .spriteElement(14);
    }
    .hour-of-day-15 {
        .spriteElement(15);
    }
    .hour-of-day-16 {
        .spriteElement(16);
    }
    .hour-of-day-17 {
        .spriteElement(17);
    }
    .hour-of-day-18 {
        .spriteElement(18);
    }
    .hour-of-day-19 {
        .spriteElement(19);
    }
    .hour-of-day-20 {
        .spriteElement(20);
    }
    .hour-of-day-21 {
        .spriteElement(21);
    }
    .hour-of-day-22 {
        .spriteElement(22);
    }
    .hour-of-day-23 {
        .spriteElement(23);
    }

    .weekend {
        color: var(--ds-text-danger, #ff0000);
    }
}

.user-hover-buttons > ul {
    height: 28px;
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid var(--ds-border, @aui-border-color);
    background-color: var(--ds-surface, @aui-color-faint);
}

.user-hover-buttons > ul > li {
    float: left;
}

.user-hover-buttons > ul > li.empty {
    background-color: var(--ds-surface, #f7f7f7);
    display: block;
    height: 28px;
    margin: 0;
    padding: 0;
    width: 149px;
}

.user-hover-buttons ul ul {
    border-top: none;
}

a.user-hover.user-avatar,
span.user-hover.user-avatar {
    background-repeat: no-repeat;
    background-position: center left;
    padding: 2px 0 2px 19px;
    position: relative;
    display: inline-block;
}

.user-hover.user-avatar > .aui-avatar {
    position: absolute;
    left: 0;
    top: 5px;
}

/* JIRA Username + Avatar pattern */
.jira-user-name {
    .border-box();
    display: inline-block;
    position: relative;

    &.jira-user-avatar {
        padding-left: 21px; /* 16px width of the xsmall avatars + 5px spacing */

        .aui-avatar {
            left: 0;
            position: absolute;
            top: 0;
        }
        .aui-avatar-xsmall {
            margin-top: 2px; /* (20px line-height - 16px icon height) / 2 - positions the icon vertically assuming 20px line-height */
        }
    }

    .userAvatarSizing(@size) {
        line-height: @size;
        padding-left: @size+5; /* width of the avatar + 5px spacing */
    }
    &.jira-user-avatar-small {
        .userAvatarSizing(24px);
    }
    &.jira-user-avatar-medium {
        .userAvatarSizing(32px);
    }
    &.jira-user-avatar-large {
        .userAvatarSizing(48px);
    }
}

.user-hover-more {
    .border-box();
    background-color: var(--ds-surface-hovered, @aui-color-faint);
    color: var(--ds-text, @jira-color-text);
    display: block;
    height: 28px;
    line-height: 28px;
    text-align: center;
    width: 150px;

    &.aui-dd-link {
        position: relative;
        &::after {
            border: 4px solid transparent;
            border-top-color: var(--ds-border, @jira-color-text);
            content: "";
            height: 0;
            position: absolute;
            right: 8px;
            top: 11px;
            width: 0;
        }
        &:hover {
            &.aui-dd-link {
                &::after {
                    border-top-color: var(--ds-border, @aui-border-color);
                }
            }
        }
    }
    &:first-child {
        border-right: 1px solid var(--ds-border, @aui-border-color);
    }
}

.user-hover-buttons a.user-hover-more {
    color: var(--ds-text, @jira-color-text);
}

.user-hover-buttons a:hover {
    background-color: var(--jira-color-menuBackgroundColour, var(--ds-surface-hovered, @jira-dropdown-menuitem-background-focus-color));
    color: var(--jira-color-menuTxtColour, var(--ds-link-pressed, @jira-dropdown-menuitem-text-focus-color));
    text-decoration: none;
}

.hoverpopup {
    z-index: 1000;
    max-width: 360px;
}

.hoverpopup .spinner-hover {
    margin: 32px 16px 48px;
}

.hoverpopup-throb {
    background-color: var(--ds-surface, #fff);
    opacity: 0.9;
    padding: 6px;
}

.hoverpopup-data {
    position: relative;
    margin: 6px 6px 12px;
}

.hoverpopup dt {
    color: var(--ds-text-subtle, @jira-color-subtle-text);
    float: left;
    margin-bottom: 4px;
    padding-right: 8px;
    width: 70px;
    text-align: right;
}

.hoverpopup dd {
    color: var(--ds-text, @jira-color-text);
    margin-bottom: 4px;
}

.hoverpopup dd.block {
    padding-left: 74px;
    font-style: italic;
}

.hoverpopup h4,
.hoverpopup .user-hover-section-wrapper {
    margin-top: 0;
}

.hoverpopup-throbber-text {
    display: inline;
    left: 6px;
    position: relative;
    top: -2px;
}

#up-d-avatar .avatar_link:hover img {
    .opacity(1);
}

#up-d-avatar .avatar_link strong {
    display: block;
    left: 50px;
    top: auto;
    bottom: 5px;
    background-position: 3px -699px;
}

#up-d-avatar .avatar_link:hover strong {
    background-position: -22px -699px;
}

#user-hover-more-trigger {
    width: 150px;
    height: 28px;
    border-radius: 0;
}