goober icon indicating copy to clipboard operation
goober copied to clipboard

background image is no work with base64 img

Open Ele-Lee opened this issue 2 years ago • 7 comments

"version": "2.1.10"

import { css } from 'goober';

const base64 =
  '';


const calssName = css`
  background-image: url(${base64});
`;

My base64 img url is right. I found that there is an extra colon in Chorme Dev Tool; image

In addition, it worked in the object syntax.

const calssName = css({
  backgroundImage: `url(${base64})`,
});

Ele-Lee avatar Jun 27 '22 11:06 Ele-Lee

Hey @Ele-Lee,

Thanks for opening this issue! Indeed this is a real issue with how the inner parser works for now. There's a workaround though, you can use the object syntax if that's possible:

const className = css({
  backgroundImage: `url(${base64})`
});

and this bypasses the css pair parsing. Would that make it work for your case?

cristianbote avatar Jun 27 '22 11:06 cristianbote

thanks. The object syntax is effective. This problem caused some confusion when using solid-styled-components. Hope goober be better and better

Ele-Lee avatar Jun 28 '22 05:06 Ele-Lee

I am running into the same issue, and don't have the option to use the object syntax as alternative at the moment. Is there no way to fix this within the parser?

monkeyphysics avatar Mar 22 '23 08:03 monkeyphysics

hey @monkeyphysics, not without a full parser refactor. Can I ask what's blocking the option of using the object syntax? Linting?

cristianbote avatar Mar 22 '23 09:03 cristianbote

My use case is a different background image for hover:

.item {
  background-image: url(${img-regular});

  &:hover {
    background-image: url(${img-hover});
  }
}

I've looked at the parser before to fix #375 and can dive in again, but forgot how I set it up so that I can use the source code of goober from /node_modules/. Any tips on setting this up so that I can make changes to the goober core in my project?

An ugly solution without touching the parser would be to restore the error after generating css by replacing the data:{mime};{encoding}:, pattern like so: css.replace(/(data:[a-z]+\/[a-z]+;[a-z0-9]+):,/, "$1,");

monkeyphysics avatar Mar 22 '23 10:03 monkeyphysics

Regarding your use case, if you want to you can still use the object syntax:

const Foo = styled('div')({
  ".item": {
    backgroundImage: `url(${img-regular})`,
    "&:hover": {
      backgroundImage: `url(${img-hover})`
    }
  }
});

In fact that's exactly what the parser does internally.

Any tips on setting this up so that I can make changes to the goober core in my project?

Depends on your setup really. Is it a nextjs project? If it's v13 you could use the transpile package option otherwise there is a next-transpile-package module.

cristianbote avatar Mar 22 '23 12:03 cristianbote

Thanks for this! Any consideration on the suggested regex replace?

monkeyphysics avatar Mar 22 '23 12:03 monkeyphysics