pickr
pickr copied to clipboard
Broken on Safari 14
What is the current behavior?
Save button doesn't function correctly and Button color not updating to reflect selection.
Please provide the steps to reproduce:
Use the demo https://simonwep.github.io/pickr/ on the latest version of Safari.
Your environment:
Version (see Pickr.version): 1.7.2
Used bundle (es5 or normal one): Both
Used theme (default is classic): All
Browser-version: Safari 14.0 (15610.1.28.1.9, 15610)
Operating-system: macOS 10.15.6 (19G2021)
I'm also experiencing this on the latest version of Safari
I don't own a mac nor have access to the latest Safari version (only v12) - You one of you describe what is happening in detail? Maybe there's an error message? Or is there a page where I can see all the changes from Safari 13 to Safari 14?
There are no errors, it appears the actual values work fine the issue is actually rendering. If I resize the browser window it shows the correct colours:
https://www.dropbox.com/s/45zzf88gcq68k7c/picker-safari-issue-2.mov?dl=0
Interestingly the Classic theme selection preview on the left hand side works fine:
data:image/s3,"s3://crabby-images/a94b1/a94b16596057ffd494f4726e2561f03fef205a72" alt="Screenshot 2020-09-24 at 10 48 36"
but it doesn't on Monolith:
data:image/s3,"s3://crabby-images/d3335/d3335f32feb7159af84a4576907c9edc23d899e0" alt="Screenshot 2020-09-24 at 10 48 50"
Clicking save on both only updates the button colour after resizing the browser (and other such interactions)
Ugh, that is really strange (and difficult to fix without safari) - at least I won't be able to fix that, I'll mark this issue maybe someone else could take a look at it :)
It works well on Safari version 13.1.2 (13609.3.5.1.5) BTW.
That is definitely a Safari related bug. I was able to at least update the color after saving with this method:
pickr.on('save', function(hsva, instance){
pickr.hide();
$input.focus();
});
But the problem still exists even on page load. The correct "default" color is not applied until the browser is either resized, or even when I toggle the console. I even tried $(window).trigger('resize')
after initialising, but without luck. It even works if I open it in Safari, open another window (any other app) and then return to Safari. Really strange.
I had this same issue. For me, the color text output in the bottom left was updating as I changed the slider, but the color block on the left wasn't. Same thing would happen when I clicked, sometimes, on two similar colors in the swatches.
When the update occurred, I looked and it seemed to be setting the active-color block's color style instead of the background-color for some reason.
I set an event listener:
pickr.on('change', pickrColorChange);
When the color change event happened, I'd grab the active color element and set the background color instead of the color:
function pickrColorChange(instance) {
const rgbaColorArray = instance.toRGBA();
var currentColorDisplayElement = document.querySelector('.pcr-current-color');
currentColorDisplayElement.style.backgroundColor = `rgb(${rgbaColorArray[0]}, ${rgbaColorArray[1]}, ${rgbaColorArray[2]})`;
}
I didn't need opacity (but that's an easy addition) and only had one instance ever, so this worked for my needs. You could model your solution around this if you need.
If it's setting the color style, maybe the solution here is to change the style being set from "color" to "background-color" in the color change method in Pickr? or both?
Thanks @fjaxyu for the inspiration. For anyone else that has multiple picker instances, here's how I fixed it with just two lines:
let button = instance.getRoot().button;
button.style.backgroundColor = button.style.color;
I placed this in the save event handler, but you should be able to use this anywhere that you have access to the Pickr instance.
@edwinfinch This works with all colors except #ffffff
. I had to put this in a init method because the problem occurs directly on page load for me.
.on('init', function(instance){
var button = instance.getRoot().button;
button.style.backgroundColor = instance._color.toHEXA().toString();
// button.style.backgroundColor = button.style.color;
});
data:image/s3,"s3://crabby-images/b6fa9/b6fa9282365f40869d74b6125458d06690dbb8da" alt="Screenshot 2020-11-16 at 08 22 07"
I tried a few things that came to mind, but was not able to get white working. Does it work for you with #ffffff
?
@MrMooky it does work for me so I won't be able to help you unfortunately.
@Simonwep why did you remove the bug label?
@edwinfinch I'd rather say that this is a safari-related bug where currentColor
does not update when color
should trigger a re-paint. It wouldn't be the first time Safari doesn't follow a spec or behaves in a weird way hence I would only call that a "browser-quirk", it's not a general bug. Changing color should change currentColor
and therefore background
. It's part of the spec:
The value of the ‘color’ property. The used value of the ‘currentColor’ keyword is the computed value of the ‘color’ property. If the ‘currentColor’ keyword is set on the ‘color’ property itself, it is treated as ‘color: inherit’.
Safari seems to ignore the computed part. What I found out with a friends laptop is that, if you resize the browser, the color does change. So Safari is missing a repaint cycle.
A fix would be using CSS variables, I'll take a look at this on the next weekend.
Still broken on Safari 14.0.3 (16610.4.3.1.7)
@MrMooky @swaterfall @caspii @edwinfinch
I just pushed an updated version with CSS Variables instead. Of course this means that IE11 support is completely gone but I never intented to support it anyways (and anyways, safari seems to be the new IE11). Since I don't have any device with safari on it, could you please verify if it's now working as expected?
@Simonwep I updated to this version and now color palettes are not visible. They still function, but are not previewed.
This is on Windows 10.
@Teraskull Huh, there are many browsers for windows 10, which one are you using?
Edge Chromium Version 91.0.838.3 (Official build) dev (64-bit)
Okay, it works on the stable version (89) so I don't consider this as a bug (this one is on edge and you're using a dev version, it's very likely that some things don't work there). After somebody tested it with a safari v13+ browser I'll release a new patch version and close this one.
@Simonwep My bad, I forgot to update the theme file as well, sorry for distraction :)
@Simonwep thanks for your efforts!
Here's what I'm seeing on Version 14.0.3 (16610.4.3.1.7)
data:image/s3,"s3://crabby-images/589aa/589aafd079773cfc5dc99ee6b06cd7a1370247a0" alt="image"
@caspii would you be able to figure out what's wrong with the swatches and color-preview? I can imagine it'd take me quite some time to figure it out without being able to test it...
@Simonwep unfortunately I'm not a frontend-crack, but here's what I've found out:
- The problem also exists on Chrome (Version 89.0.4389.114 (Official Build) (arm64))
- A CSS variable color is being applied to the
pcr-button
button, but it's not working. Even overwriting this property in dev tools with a normal (non-variable) does not cause the color to be applied to the button. - I can see the following problem in dev tools which may be related:
Yes, unfortunately broken on safari 14 both desktop and mobile.