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

Switch to simpler looking loading spinner #19091

Closed
jancborchardt opened this issue Sep 16, 2015 · 88 comments · Fixed by #24491
Closed

Switch to simpler looking loading spinner #19091

jancborchardt opened this issue Sep 16, 2015 · 88 comments · Fixed by #24491

Comments

@jancborchardt
Copy link
Member

We should switch to a simpler spinner for the next version. The current one is very complex, has many parts, and the GIF is not optimized for HiDPI.

Similar to this maybe (of course better quality and scalable etc.):

Or the one of the new HTML5 player on https://twitch.tv

Ref owncloud/gallery#336 for previous discussion on the spinner. cc @owncloud/designers @oparoz

@oparoz
Copy link
Contributor

oparoz commented Sep 16, 2015

GIFs don't work well on all backgrounds and should never be used for a spinner where you don't control the environment It would be best to go with CSS.

I've never been a fan of the Android spinner, but I know picking a good one is time consuming.

@oparoz
Copy link
Contributor

oparoz commented Sep 16, 2015

A few more issues with GIFs: apps and users can't theme them. With CSS, you change the colour and you're in business.

@jancborchardt
Copy link
Member Author

@oparoz as said in another issue: GIFs can be themed – simply change the image in the theme.

It is correct though that there are issues with the background and the look, I don’t disagree with that. However, we should approach this properly with 9.0 and from core out, not Gallery going its own way for 8.2, essentially breaking themed loading spinners.

@oparoz
Copy link
Contributor

oparoz commented Sep 16, 2015

GIFs can be themed – simply change the image in the theme

Yes, but that means creating an entirely new spinner or having excellent Photoshop skills. You can't just set the colour via CSS.

@PVince81
Copy link
Contributor

There are also pure-CSS spinners (probably not working in IE8 but who cares)

@oparoz
Copy link
Contributor

oparoz commented Sep 16, 2015

probably not working in IE8 but who cares

You know who ;), Chinese users stuck on XP :)

@oparoz
Copy link
Contributor

oparoz commented Sep 23, 2015

And there is a big problem which needs to be solved in core for 9.0 regarding the spinner. They need to be applied to their own divs so that themes can't use high quality spinner. You have to get rid of all the spinners which are simply applied to large containers.

@oparoz
Copy link
Contributor

oparoz commented Oct 12, 2015

Use a DIV spinner, go to settings, make the window narrow, try to use the top-right menu. It doesn't work.
Just one of the examples of things which are currently broken when using a non-GIF spinner.

@jancborchardt
Copy link
Member Author

Played around a bit with a good-looking CSS spinner, here’s what we could start with:

.loading {
    position: relative;
    display: block;
    width: 48px;
    height: 48px;
    margin: 0 auto;
    border: 3px solid rgba(240, 240, 240, .25);
    border-left-color: rgba(180, 180, 180, .5);
    border-radius: 50%;
    -webkit-animation: loading-spin .5s infinite linear;
    animation: loading-spin .5s infinite linear;
}

@-webkit-keyframes loading-spin {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0);
    }
    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
@keyframes loading-spin {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0);
    }
    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

Anyone up for playing around with that @owncloud/designers?

@oparoz
Copy link
Contributor

oparoz commented Jan 6, 2016

Looking forward to testing this :)

@MorrisJobke
Copy link
Contributor

I would double the time (otherwise it looks a bit too fast). Beside that it looks really nice :)

@blackcrack
Copy link

should be able to have all in the themefolder
/theme/example/loader/loader.html
/theme/example/loader/loader.css
http://cssload.net/
to have a possible for change it easy out.
with other css designs.

best regards
Blacky

@Henni
Copy link
Contributor

Henni commented Jan 6, 2016

@jancborchardt I like your code sample, but would maybe slow it down like @MorrisJobke suggested.
This is what it looks like with an animation speed of 0.8 instead of 0.5:
http://codepen.io/Henni/pen/EPWOXK

@blackcrack
Copy link

well, i did not know Jan's issue before, but i have send also an an sample ....
#21477 (comment)
and i guess, it's maybe nice possible's.. for replace a "heavy" gif or animated picture, because with png's it's possible too (animated png's) but with css3 it's just more clean and maybe also more nice.
and the speed can be adjusting by owner in the css-file and can be at first more slow .. imho, but the
themefile for it should be as a single file in htm (include ('$theme/loader/loader.htm') or $themeloader/loader.htm') ) and in the cssfile would also well placed by side of the htm,
as loader.css and should be by side of the theme as single possible imo,
for fast find and easy change and set up ..
best regards
Blacky

@oparoz
Copy link
Contributor

oparoz commented Jan 7, 2016

@blackcrack - Just add the CSS to your custom theme's CSS and it will replace the original spinner

@blackcrack
Copy link

well, some designer it's maybe happy if he must not search in the whole css files or something and it is clean to see which it is which .. i can, but not any it's so well like you and me where can do it.. by the way, i am do not only css i am also in php ;) but at moment i am in work with my laptop and this writing is it which I can now only do .. i have to concentrate to my job.. ;)
best regards
Blacky

@dominicrico
Copy link

Also would be good to put this into a pseudo element with an overlaying background so you can keep the original content of the element if you refresh or reload something via ajax.

@rullzer
Copy link
Contributor

rullzer commented Feb 15, 2016

Would also be good for #22350

@PVince81 PVince81 modified the milestones: 9.1-next, 9.0-current Feb 23, 2016
@prastut
Copy link
Contributor

prastut commented Mar 1, 2016

Catching up with the material trend http://codepen.io/prastutkumar/pen/grbKZZ
A little skeptical about it though. Opinions?

@jancborchardt
Copy link
Member Author

@prastut the Material Design spinner takes way too much attention because it’s so complex. A spinner is not supposed to do that. Also, it’s heavily branded and associated with Google/Android, so we will not use it.

If you’re up for improving the spinner, check out the code I posted at #19091 (comment) and feel free to implement it. :)

@MorrisJobke
Copy link
Contributor

@MorrisJobke so smil + css? Css only exclude firefox, and it's still used a lot! :/
I could try to work on the fallback.

Really? Firefox could not use any CSS transitions?

I would go the CSS way and still support the old background image based spinners
In my experience, this doesn't work, you see both at the same time.

Then we simply need to add them as a different class name ;) it is even a complete different concept. Fine with me.

@skjnldsv
Copy link
Contributor

skjnldsv commented Apr 20, 2016

We're loosing focus! :)

SMIL is working on all browsers except ie.
I suggest we go for it and wait for full css support. If you look at the support chart http://caniuse.com/#feat=svg-smil, we have at least 4 future chrome and firefox version that still support it. This should gives us plenty of time to change it when the time will come.

Either way, i'm currently working on a hack to have a svg with css AND smil combined that override the smil animation in case of css support, i'm very close to success. If so, we will use it because it will assure us a full compatibility and a smooth transition from smil abandon to full css support.

ref: https://bugzilla.mozilla.org/show_bug.cgi?id=908634

@jancborchardt
Copy link
Member Author

@skjnldsv yeah! Take charge and just go for it :) not so much discussion. If something doesn't work, we can still fix it going forward.

@skjnldsv
Copy link
Contributor

skjnldsv commented Apr 20, 2016

Ok, then we close this one, let's review #24107.

I tried to mix both of them, but the firefox bug is too much.

@oparoz
Copy link
Contributor

oparoz commented May 7, 2016

There is an alternative which would work in all browsers. Use a transparent PNG instead of a SVG.

It works because ownCloud uses a simple rotating spinner. Themes will have to patch ownCloud to use fancy CSS spinners.

@blackcrack
Copy link

blackcrack commented May 7, 2016

and therefore would be pretty well, if exist in the css

.spinner { }

and the html code a

<div class='spinner'> </div>

to have later the possible for more easy change out the spinner in themes.

best regards
Blacky

@skjnldsv
Copy link
Contributor

skjnldsv commented May 8, 2016

@oparoz and how will you make it spin?

@blackcrack we already have this! We have multiple class for the loader (loading, icon-loading, icon-loading-small...)

@oparoz
Copy link
Contributor

oparoz commented May 8, 2016

@skjnldsv CSS3 with :before?

@oparoz
Copy link
Contributor

oparoz commented May 8, 2016

@skjnldsv I initially thought the whole element could rotate, but that won't work of course, since in a lot of case the spinner is added as a background-image, so using :before should work, but then we'll end up with the same issues you've previously described with input fields.

@skjnldsv
Copy link
Contributor

skjnldsv commented May 8, 2016

:before is great, but look at #19091 (comment)
It exclude all elements that are auto-closed. SInce css doesn't allow :before or :after.

The best solution if we use aft/bef, is to use two elemnts with border-radius, and make one rotate. Best result and best compatibility.
A single rotating png isn't really beautiful. :/

EDIT: I was too slow! :)
@oparoz we could also do have a js monitoring all .loading classes changes, and calculate/add a div that contains the loading data? I really don't like this idea, but it could work!

@oparoz
Copy link
Contributor

oparoz commented May 8, 2016

we could also do have a js monitoring all .loading classes changes, and calculate/add a div that contains the loading data? I really don't like this idea, but it could work!

@skjnldsv That could work, but if using JS, why not simply use PNG sprites then?
http://codepen.io/sdholbs/pen/GyEDw

or even CSS only
https://jsfiddle.net/simurai/CGmCe/

@skjnldsv
Copy link
Contributor

skjnldsv commented May 8, 2016

Because sprites are very heavy for the browser to render when animated, and a lot more bigger size! :/

@oparoz
Copy link
Contributor

oparoz commented May 8, 2016

@skjnldsv - Reading Skimming through this thread, I don't think performance would be too much of an issue, it's not like there are dozens of spinner rotating at the same time. I also don't think it's going to be worse than animated SVGs.

Also, this PNG example is 1.4k (paste in the browser). Even if we want to include all 12 steps, that's 5.6k.



Having said that, we could still go with CSS only and use a gif for inputs since we have those for IE anyway.

@skjnldsv
Copy link
Contributor

skjnldsv commented May 8, 2016

Css only is a good idea. Lighter and easier to maintain.
Here we go: http://codepen.io/skjnldsv/pen/qZgPQQ

@oparoz
Copy link
Contributor

oparoz commented May 8, 2016

Looks good both on desktop and browser, no problem with speed.

@skjnldsv
Copy link
Contributor

skjnldsv commented May 8, 2016

Seems good to me too! I updated with differents examples.
Will work on it tomorrow. Too tired this evening! :(

@oparoz
Copy link
Contributor

oparoz commented May 8, 2016

Looks good, many thanks for the examples :)

@skjnldsv
Copy link
Contributor

skjnldsv commented May 8, 2016

I'm zombying on the codepen until I fall asleep. i will integrate it on oc tomorrow.

@skjnldsv
Copy link
Contributor

skjnldsv commented May 9, 2016

Done, please review!

@blackcrack
Copy link

@skjnldsv : it's maybe not bad, if be renamed ? into

/*spinner*/ 
.spinnerbig {} 
.spinnermedium {} 
.spinnersmall {} 

because, this name does more suitable ? .. also for the future, name it what it is .
and more easy for find.

best regards
Blacky

@skjnldsv
Copy link
Contributor

skjnldsv commented May 9, 2016

Why? Don't really think this is that much of a deal :)
and I think icon-loading, icon-loading-small, icon-loading-dark and icon-loading-small-dark are pretty convenient names already ;)

@blackcrack
Copy link

blackcrack commented May 9, 2016

it's spinn's and an icon is non spinning in normally case ;) s .. well, if you want search an specially icon, like an icon-loading instead a spinner, so, many fun g think about :) But, well you the Minion and the decisionmaker ;)
shy minion
best regards
Blacky

@lock
Copy link

lock bot commented Aug 4, 2019

This thread has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs.

@lock lock bot locked as resolved and limited conversation to collaborators Aug 4, 2019
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

10 participants