@DownPW itโs possible, yes, but you may inadvertently end up targeting other elements using the same class which of course isnโt desired.
Can you provide a link in DM for me to review?
@DownPW Youโre probably missing this
@keyframes rotate180 {
from {
transform: rotate(0deg);
}
to {
transform: rotate(180deg);
}
}
@keyframes rotate0 {
from {
transform: rotate(180deg);
}
to {
transform: rotate(0deg);
}
}
Without the keyframes
it will not work
@DownPW said in fading in /tags page:
.header .forum-logo, img.forum-logo.head {
max-height: 50px;
width: auto;
height: 30px;
margin-top: 9px;
max-width: 150px;
min-width: 32px;
display: inline-block;
animation-name: rotate180, rotate0;
animation-duration: 1000ms;
animation-delay: 0s, 1000ms;
animation-iteration-count: 1;
animation-timing-function: linear;
transition: transform 1000ms ease-in-out;
}
like this ? Because I have the effect but just at the refresh page and not on Mouse over
.header .forum-logo, img.forum-logo.head:hover {
max-height: 50px;
width: auto;
height: 30px;
margin-top: 9px;
max-width: 150px;
min-width: 32px;
display: inline-block;
animation-name: rotate180, rotate0;
animation-duration: 1000ms;
animation-delay: 0s, 1000ms;
animation-iteration-count: 1;
animation-timing-function: linear;
transition: transform 1000ms ease-in-out;
@keyframes rotate180 {
from {
transform: rotate(0deg);
}
to {
transform: rotate(180deg);
}
}
@keyframes rotate0 {
from {
transform: rotate(180deg);
}
to {
transform: rotate(0deg);
}
}
}
I have it !!!
@keyframes rotate180 {
from {
transform: rotate(0deg);
}
to {
transform: rotate(180deg);
}
}
@keyframes rotate0 {
from {
transform: rotate(180deg);
}
to {
transform: rotate(0deg);
}
}
.header .forum-logo:hover {
display: inline-block;
animation-name: rotate180, rotate0;
animation-duration: 1000ms;
animation-delay: 0s, 1000ms;
animation-iteration-count: 1;
animation-timing-function: linear;
transition: transform 1000ms ease-in-out;
}
@DownPW Yes, that was going to be my solution.
@phenomlab thanks for sharing, that looks very cool
@DownPW thanks for the codes, how should we edit it if we want a full turn? and keep turning as long as the mouse is hovered on?
@crazycells change 180
to 360
on the keyframes and set to time to infinite
on the animation, so an example would be
animation-iteration-count: infinite;
Donโt do this on mobile devices though as performance will be greatly impacted.
@phenomlab thanks
hmmm
Strange with the code I put above, as soon as I remove the mouse pointer from the logo, it returns to itโs original place and it cuts the animation.
How can we let the animation end even if we remove the mouse pointer from the logo ?
@DownPW said in fading in /tags page:
as soon as I remove the mouse pointer from the logo, it returns to itโs original place and it cuts the animation.
Yes, thatโs expected because you have the css set for hover
state meaning once you remove that state, the animation will stop
You need to refactor the css to achieve the effect the looking for. Personally, I wouldnโt go for a constantly spinning logo. If youโre as old as I am, youโll recall this being a thing in Internet Explorer 4 with the spinning globe on the right that was a constant presence and quite a distraction.
I also wouldnโt do this on any mobile devices as it can severely degrade the browser performance.
no no my god, not constantly animation !!
If I hover over the logo, the animation triggers as currently, continues and ends even if I remove the mouse from the logo.
Thatโs whatโs happening here on Sudonix.
@DownPW I see what you mean. The reason for this is that you are calling both rotate180
and rotate0
which are two separate effects.
animation-name: rotate180, rotate0;
You could remove rotate0
from this section and that will stop the animation as soon as the mouseLeave
event is triggered in the DOM
(in other words, as soon as you remove the hover)
animation-name: rotate180;
hmm not work
can you provide your CSS code and keyframe for I see it ?
On sudonix, the animation stop and restart when we leave the mouse over.
@DownPW itโs here
https://sudonix.com/post/3590
The exact CSS I have here is
@keyframes rotate180 {
from {
transform: rotate(0deg);
}
to {
transform: rotate(180deg);
}
}
@keyframes rotate0 {
from {
transform: rotate(180deg);
}
to {
transform: rotate(0deg);
}
}
.forum-logo:hover {
transform: rotate(180deg);
}
.hover {
transform: rotate(180deg);
}
The tags page looked better before, it does not look good when it is very โorderedโ. @phenomlab do you have any intention to change that page in harmony thema?
@crazycells I must admit, Iโve neglected the tags page somewhat, but I do agree with you - itโs pretty dull and could do with some magic.
@crazycells just for youโฆ
@phenomlab nice this looks very goodโฆ
On a side note, I have been just watching/listening Doc and Martyโs adventures in the background and then I see this
@phenomlab can you please share the CSS codes?
@crazycells Of courseโฆ You did ask me for these
.tags:not([component="topic/tags"]) a[href*="/tags/"] {
border: 1px solid var(--bs-border-color);
border-radius: 0.375rem;
margin: 8px;
width: 145px;
background: var(--bs-body-navbar);
}
/* SIBLING FADE: fade out siblings around a hovered item */
.tag-list { visibility: hidden; }
/* Prevents :hover from triggering in the gaps between items */
.tag-list > * { visibility: visible; }
/* Brings the child items back in, even though the parent is `hidden` */
.tag-list > * { transition: opacity 150ms linear 100ms, transform 150ms ease-in-out 100ms; }
/* Makes the fades smooth with a slight delay to prevent jumps as the mouse moves between items */
.tag-list:hover > * { opacity: 0.4; transform: scale(0.9); }
/* Fade out all items when the parent is hovered */
.tag-list > *:hover { opacity: 1; transform: scale(1); transition-delay: 0ms, 0ms; }
/* Fade in the currently hovered item */
.tags a[href*="/tags/"] .tag-item {
border-bottom: 4px solid var(--bs-border-color) !important;
}