Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add completion marker to daily challenge profile counter #11780

Merged
merged 10 commits into from
Jan 16, 2025

Conversation

bdach
Copy link
Contributor

@bdach bdach commented Jan 9, 2025

Implements #11597 for the website.

position: relative;

&--played-today {
border: 2px solid @osu-colour-lime-1;
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is 1px on the design file but I find that 1px looks terrible on the rounded corners:

1px 2px
1736414918 1736414351

Arguably even 2px looks not great. Maybe 3px even could be considered. cc @ppy/team-design

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the extra spacing between the day count box and the green border seems a bit weird?

also dunno if matters but the popup box covers the check mark a little bit

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the extra spacing between the day count box and the green border seems a bit weird?

I mean yeah maybe. I'm just following design direction here 🤷

also dunno if matters but the popup box covers the check mark a little bit

Yeah it does and was also unsure if it mattered. I guess maybe the design peoples can say?

Just for visual reference here's a screenshot:

1736416429

@@ -20,7 +40,7 @@
}

&__value-box {
border-radius: @border-radius-large;
border-radius: @border-radius-small;
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Adjusted as per mention in #11597:

also, the corner radius of that darker block is supposed to be 3px, it's 6px on osu-web rn for some reason.

@@ -122,26 +123,30 @@ export default class DailyChallenge extends React.Component<Props> {
return null;
}

const playedToday = this.props.stats.last_update != null && moment.utc(this.props.stats.last_update).isSame(Date.now(), 'day');
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this is gonna do timezones correctly:

https://momentjs.com/docs/#/query/is-same/

If the two moments have different timezones, the timezone of the first moment will be used for the comparison.

and it looked correct when I messed around with my timezone...

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yeah that seems correct (until someone complains it's not)

alternatively new Date(...).toISOString() spits out iso8601 string which has utc timezone and can then be sliced appropriately (not sure if better)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

and can then be sliced appropriately (not sure if better)

I uh... am not confident in my ability to do so, so I'd rather not if that's fine with you 😅

'users.show.daily_challenge.unit.day',
{ value: formatNumber(this.props.stats.playcount) },
)}
<div className='daily-challenge__content'>
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The reason for the existence of this div is that I need the ::before pseudo-element that is the check in the corner to be excluded from the flexbox, it takes space otherwise. If you have better ideas on how to implement this I'm open to changes.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

absolute-positioned element, which the element is, doesn't take space...?

Copy link
Contributor Author

@bdach bdach Jan 9, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Huh. I guess I must have not tried some particular combination of css incantations because it does look to be not required now??? I love css.

(If you haven't figured out by now my css knowledge is somewhere at the level of "throw stuff against wall until it looks close enough" 😅)

display: flex;
align-items: center;
padding: 3px;

&--played-today {
border: 2px solid @osu-colour-lime-1;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should only change the border-color in the modifier here with the rest border set in the base class (with transparent color) to have consistent positioning between played and not

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In the process of applying this I noticed that the border even if transparent was also stacking onto the existing 3px of padding (see screenshots below, with the border green colour changed to transparent to show the difference):

before after
1736948658 1736948639

which I didn't want to do and I don't think the design was going for, so I reduced the padding to 1px to compensate.

border-radius: 50%;
color: @osu-colour-lime-1;
content: @fa-var-check-circle;
font-size: 16px;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

there has been an attempt on marking icon-specific hard coded font-size - instead of using variable - with // icon size comment

Comment on lines 24 to 25
right: -8px;
top: -8px;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

-0.5em works here (or 0 with ±50% translate transform if feeling fancy)

@@ -122,26 +123,30 @@ export default class DailyChallenge extends React.Component<Props> {
return null;
}

const playedToday = this.props.stats.last_update != null && moment.utc(this.props.stats.last_update).isSame(Date.now(), 'day');
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yeah that seems correct (until someone complains it's not)

alternatively new Date(...).toISOString() spits out iso8601 string which has utc timezone and can then be sliced appropriately (not sure if better)

@nanaya
Copy link
Collaborator

nanaya commented Jan 16, 2025

wait, is it only for own profile page or for any users? the design file says it's only for own page but this pr is currently for everyone

&::before {
.fas();
background-color: @osu-colour-b6;
border-radius: 50%;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

while at it, this doesn't actually do anything, does this? The fa icon is already rounded and all

Copy link
Contributor Author

@bdach bdach Jan 16, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The fontawesome icon is rounded but it has a hollow interior where the tick is. So without some hackage the border will peek out of the hollow interior, thus the background-color + border-radius specs are supposed to cover up anything that's in the background (particularly the border).

Copy link
Collaborator

@nanaya nanaya Jan 16, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oh. So that also explained the weirdly subtle black outline... 🤔

I suppose an alternative would be to use normal check mark (b6 colored) coupled with circle background (lime-1 colored), centered using .center-content()

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah that's a fair shout. Adjusted further in bf0333a.

I also took the opportunity to resize the tick itself because for whatever reason when using the pre-baked fontawesome check-circle the check was much larger than it actually was in the figma. It should be there-or-thereabouts matching now.

@bdach
Copy link
Contributor Author

bdach commented Jan 16, 2025

wait, is it only for own profile page or for any users? the design file says it's only for own page but this pr is currently for everyone

Yeah that was a reading fail... Attempted to address this in 0600f1b. I shamelessly stole the code to do this from somewhere else, let me know if that is fine.

Comment on lines 18 to 19
.center-content();
.fas();
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the order is kinda important as both define display: 😬

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

whoops. and i'm out here just reordering stuff so that it's in alphabet order without double checking...

right: 0;
top: 0;
transform: translate(50%, -50%);
width: 16px;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can use $height so only need to define it once

@nanaya nanaya enabled auto-merge January 16, 2025 14:03
@nanaya nanaya merged commit d9f4860 into ppy:master Jan 16, 2025
3 checks passed
@bdach bdach deleted the daily-challenge-completion-marker branch January 16, 2025 14:38
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants