2019-01-28 06:45:00 +08:00
|
|
|
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
|
|
|
|
// See the LICENCE file in the repository root for full licence text.
|
2019-01-11 08:12:19 +08:00
|
|
|
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using osu.Framework.Allocation;
|
2019-03-06 15:09:21 +08:00
|
|
|
|
using osu.Framework.Bindables;
|
2019-01-11 08:12:19 +08:00
|
|
|
|
using osu.Framework.Extensions.Color4Extensions;
|
|
|
|
|
using osu.Framework.Graphics;
|
|
|
|
|
using osu.Framework.Graphics.Containers;
|
|
|
|
|
using osu.Framework.Graphics.Shapes;
|
|
|
|
|
using osu.Framework.Graphics.Sprites;
|
|
|
|
|
using osu.Framework.Graphics.Textures;
|
|
|
|
|
using osu.Game.Graphics;
|
|
|
|
|
using osu.Game.Graphics.Containers;
|
|
|
|
|
using osu.Game.Graphics.Sprites;
|
|
|
|
|
using osu.Game.Graphics.UserInterface;
|
|
|
|
|
using osu.Game.Online.API;
|
|
|
|
|
using osu.Game.Online.Chat;
|
|
|
|
|
using osu.Game.Users;
|
|
|
|
|
using osuTK;
|
|
|
|
|
using osuTK.Graphics;
|
|
|
|
|
|
|
|
|
|
namespace osu.Game.Overlays.Profile.Header
|
|
|
|
|
{
|
|
|
|
|
public class CenterHeaderContainer : Container
|
|
|
|
|
{
|
|
|
|
|
public readonly BindableBool DetailsVisible = new BindableBool();
|
|
|
|
|
|
|
|
|
|
private OsuSpriteText followerText;
|
|
|
|
|
private ProfileHeaderButton messageButton;
|
|
|
|
|
private OsuSpriteText levelBadgeText;
|
|
|
|
|
|
|
|
|
|
private Bar levelProgressBar;
|
|
|
|
|
private OsuSpriteText levelProgressText;
|
|
|
|
|
|
|
|
|
|
private ProfileHeader.OverlinedInfoContainer hiddenDetailGlobal, hiddenDetailCountry;
|
|
|
|
|
|
|
|
|
|
[Resolved(CanBeNull = true)]
|
|
|
|
|
private ChannelManager channelManager { get; set; }
|
|
|
|
|
|
|
|
|
|
[Resolved(CanBeNull = true)]
|
|
|
|
|
private UserProfileOverlay userOverlay { get; set; }
|
|
|
|
|
|
|
|
|
|
[Resolved(CanBeNull = true)]
|
|
|
|
|
private ChatOverlay chatOverlay { get; set; }
|
|
|
|
|
|
|
|
|
|
[Resolved]
|
|
|
|
|
private APIAccess apiAccess { get; set; }
|
|
|
|
|
|
|
|
|
|
private User user;
|
2019-03-06 15:30:56 +08:00
|
|
|
|
|
2019-01-11 08:12:19 +08:00
|
|
|
|
public User User
|
|
|
|
|
{
|
|
|
|
|
get => user;
|
|
|
|
|
set
|
|
|
|
|
{
|
2019-03-06 15:30:56 +08:00
|
|
|
|
if (user == value)
|
|
|
|
|
return;
|
|
|
|
|
|
2019-01-11 08:12:19 +08:00
|
|
|
|
user = value;
|
2019-03-06 15:30:56 +08:00
|
|
|
|
|
2019-01-11 08:12:19 +08:00
|
|
|
|
updateDisplay();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[BackgroundDependencyLoader]
|
|
|
|
|
private void load(OsuColour colours, TextureStore textures)
|
|
|
|
|
{
|
|
|
|
|
Container<Drawable> hiddenDetailContainer, expandedDetailContainer;
|
|
|
|
|
SpriteIcon expandButtonIcon;
|
|
|
|
|
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new Box
|
|
|
|
|
{
|
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
|
|
|
|
Colour = colours.CommunityUserGrayGreenDark
|
|
|
|
|
},
|
|
|
|
|
new FillFlowContainer
|
|
|
|
|
{
|
|
|
|
|
AutoSizeAxes = Axes.X,
|
|
|
|
|
RelativeSizeAxes = Axes.Y,
|
|
|
|
|
Direction = FillDirection.Horizontal,
|
|
|
|
|
Padding = new MarginPadding { Vertical = 10 },
|
|
|
|
|
Margin = new MarginPadding { Left = UserProfileOverlay.CONTENT_X_MARGIN },
|
|
|
|
|
Spacing = new Vector2(10, 0),
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new ProfileHeaderButton
|
|
|
|
|
{
|
|
|
|
|
RelativeSizeAxes = Axes.Y,
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new FillFlowContainer
|
|
|
|
|
{
|
|
|
|
|
AutoSizeAxes = Axes.Both,
|
|
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
|
Origin = Anchor.CentreLeft,
|
|
|
|
|
Direction = FillDirection.Horizontal,
|
|
|
|
|
Padding = new MarginPadding { Right = 10 },
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new SpriteIcon
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
|
Origin = Anchor.CentreLeft,
|
|
|
|
|
Icon = FontAwesome.fa_user,
|
|
|
|
|
FillMode = FillMode.Fit,
|
|
|
|
|
Size = new Vector2(50, 14)
|
|
|
|
|
},
|
|
|
|
|
followerText = new OsuSpriteText
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
|
Origin = Anchor.CentreLeft,
|
2019-03-06 15:09:21 +08:00
|
|
|
|
Font = OsuFont.GetFont(weight: FontWeight.Bold)
|
2019-01-11 08:12:19 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
messageButton = new ProfileHeaderButton
|
|
|
|
|
{
|
|
|
|
|
Alpha = 0,
|
|
|
|
|
RelativeSizeAxes = Axes.Y,
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new SpriteIcon
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.CentreLeft,
|
|
|
|
|
Origin = Anchor.CentreLeft,
|
|
|
|
|
Icon = FontAwesome.fa_envelope,
|
|
|
|
|
FillMode = FillMode.Fit,
|
|
|
|
|
Size = new Vector2(50, 14)
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
new Container
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.CentreRight,
|
|
|
|
|
Origin = Anchor.CentreRight,
|
|
|
|
|
RelativeSizeAxes = Axes.Y,
|
|
|
|
|
Padding = new MarginPadding { Vertical = 10 },
|
|
|
|
|
Width = UserProfileOverlay.CONTENT_X_MARGIN,
|
|
|
|
|
Child = new ProfileHeaderButton
|
|
|
|
|
{
|
|
|
|
|
RelativeSizeAxes = Axes.Y,
|
|
|
|
|
Anchor = Anchor.Centre,
|
|
|
|
|
Origin = Anchor.Centre,
|
|
|
|
|
Action = DetailsVisible.Toggle,
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
expandButtonIcon = new SpriteIcon
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.Centre,
|
|
|
|
|
Origin = Anchor.Centre,
|
|
|
|
|
Size = new Vector2(20),
|
|
|
|
|
Icon = FontAwesome.fa_chevron_up,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
new Container
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.CentreRight,
|
|
|
|
|
Origin = Anchor.CentreRight,
|
|
|
|
|
AutoSizeAxes = Axes.Both,
|
|
|
|
|
Margin = new MarginPadding { Right = UserProfileOverlay.CONTENT_X_MARGIN },
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new ProfileHeader.HasTooltipContainer
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.CentreRight,
|
|
|
|
|
Origin = Anchor.CentreRight,
|
|
|
|
|
Size = new Vector2(40),
|
|
|
|
|
TooltipText = "Level",
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new Sprite
|
|
|
|
|
{
|
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
|
|
|
|
Texture = textures.Get("Profile/levelbadge"),
|
|
|
|
|
Colour = colours.Yellow,
|
|
|
|
|
},
|
|
|
|
|
levelBadgeText = new OsuSpriteText
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.Centre,
|
|
|
|
|
Origin = Anchor.Centre,
|
2019-03-06 15:30:56 +08:00
|
|
|
|
Font = OsuFont.GetFont(size: 20)
|
2019-01-11 08:12:19 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
expandedDetailContainer = new ProfileHeader.HasTooltipContainer
|
|
|
|
|
{
|
|
|
|
|
TooltipText = "Progress to next level",
|
|
|
|
|
Anchor = Anchor.CentreRight,
|
|
|
|
|
Origin = Anchor.CentreRight,
|
|
|
|
|
Width = 200,
|
|
|
|
|
Height = 6,
|
|
|
|
|
Margin = new MarginPadding { Right = 50 },
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
new CircularContainer
|
|
|
|
|
{
|
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
|
|
|
|
Masking = true,
|
|
|
|
|
Child = levelProgressBar = new Bar
|
|
|
|
|
{
|
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
|
|
|
|
BackgroundColour = Color4.Black,
|
|
|
|
|
Direction = BarDirection.LeftToRight,
|
|
|
|
|
AccentColour = colours.Yellow
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
levelProgressText = new OsuSpriteText
|
|
|
|
|
{
|
|
|
|
|
Anchor = Anchor.BottomRight,
|
|
|
|
|
Origin = Anchor.TopRight,
|
2019-03-06 15:09:21 +08:00
|
|
|
|
Font = OsuFont.GetFont(size: 12, weight: FontWeight.Bold)
|
2019-01-11 08:12:19 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
hiddenDetailContainer = new FillFlowContainer
|
|
|
|
|
{
|
|
|
|
|
Direction = FillDirection.Horizontal,
|
|
|
|
|
Anchor = Anchor.CentreRight,
|
|
|
|
|
Origin = Anchor.CentreRight,
|
|
|
|
|
Width = 200,
|
|
|
|
|
AutoSizeAxes = Axes.Y,
|
|
|
|
|
Alpha = 0,
|
|
|
|
|
Spacing = new Vector2(10, 0),
|
|
|
|
|
Margin = new MarginPadding { Right = 50 },
|
|
|
|
|
Children = new[]
|
|
|
|
|
{
|
|
|
|
|
hiddenDetailGlobal = new ProfileHeader.OverlinedInfoContainer
|
|
|
|
|
{
|
|
|
|
|
Title = "Global Ranking",
|
|
|
|
|
LineColour = colours.Yellow
|
|
|
|
|
},
|
|
|
|
|
hiddenDetailCountry = new ProfileHeader.OverlinedInfoContainer
|
|
|
|
|
{
|
|
|
|
|
Title = "Country Ranking",
|
|
|
|
|
LineColour = colours.Yellow
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2019-03-06 15:09:21 +08:00
|
|
|
|
DetailsVisible.ValueChanged += visible =>
|
|
|
|
|
{
|
|
|
|
|
expandButtonIcon.Icon = visible.NewValue ? FontAwesome.fa_chevron_down : FontAwesome.fa_chevron_up;
|
|
|
|
|
hiddenDetailContainer.Alpha = visible.NewValue ? 1 : 0;
|
|
|
|
|
expandedDetailContainer.Alpha = visible.NewValue ? 0 : 1;
|
|
|
|
|
};
|
2019-01-11 08:12:19 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void updateDisplay()
|
|
|
|
|
{
|
|
|
|
|
followerText.Text = user.FollowerCount?.Length > 0 ? user.FollowerCount[0].ToString("#,##0") : "0";
|
|
|
|
|
|
|
|
|
|
if (!user.PMFriendsOnly && apiAccess.LocalUser.Value.Id != user.Id)
|
|
|
|
|
{
|
|
|
|
|
messageButton.Show();
|
|
|
|
|
messageButton.Action = () =>
|
|
|
|
|
{
|
|
|
|
|
channelManager?.OpenPrivateChannel(user);
|
|
|
|
|
userOverlay?.Hide();
|
|
|
|
|
chatOverlay?.Show();
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
messageButton.Hide();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
levelBadgeText.Text = user.Statistics?.Level.Current.ToString() ?? "0";
|
|
|
|
|
levelProgressBar.Length = user.Statistics?.Level.Progress / 100f ?? 0;
|
|
|
|
|
levelProgressText.Text = user.Statistics?.Level.Progress.ToString("0'%'");
|
|
|
|
|
|
|
|
|
|
hiddenDetailGlobal.Content = user?.Statistics?.Ranks.Global?.ToString("#,##0") ?? "-";
|
|
|
|
|
hiddenDetailCountry.Content = user?.Statistics?.Ranks.Country?.ToString("#,##0") ?? "-";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private class ProfileHeaderButton : OsuHoverContainer
|
|
|
|
|
{
|
|
|
|
|
private readonly Box background;
|
|
|
|
|
private readonly Container content;
|
|
|
|
|
|
|
|
|
|
protected override Container<Drawable> Content => content;
|
|
|
|
|
|
|
|
|
|
protected override IEnumerable<Drawable> EffectTargets => new[] { background };
|
|
|
|
|
|
|
|
|
|
public ProfileHeaderButton()
|
|
|
|
|
{
|
|
|
|
|
HoverColour = Color4.Black.Opacity(0.75f);
|
|
|
|
|
IdleColour = Color4.Black.Opacity(0.7f);
|
|
|
|
|
AutoSizeAxes = Axes.X;
|
|
|
|
|
|
|
|
|
|
base.Content.Add(new CircularContainer
|
|
|
|
|
{
|
|
|
|
|
Masking = true,
|
|
|
|
|
AutoSizeAxes = Axes.X,
|
|
|
|
|
RelativeSizeAxes = Axes.Y,
|
|
|
|
|
Children = new Drawable[]
|
|
|
|
|
{
|
|
|
|
|
background = new Box
|
|
|
|
|
{
|
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
|
|
|
|
},
|
|
|
|
|
content = new Container
|
|
|
|
|
{
|
|
|
|
|
AutoSizeAxes = Axes.X,
|
|
|
|
|
RelativeSizeAxes = Axes.Y,
|
|
|
|
|
Padding = new MarginPadding { Horizontal = 10 },
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|