cristianbote / goober

🥜 goober, a less than 1KB 🎉 css-in-js alternative with a familiar API
https://goober.rocks
MIT License
3.13k stars 118 forks source link

background image is no work with base64 img #467

Open Ele-Lee opened 2 years ago

Ele-Lee commented 2 years ago

"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})`,
});
cristianbote commented 2 years ago

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?

Ele-Lee commented 2 years ago

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

monkeyphysics commented 1 year ago

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?

cristianbote commented 1 year ago

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

monkeyphysics commented 1 year ago

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,");

cristianbote commented 1 year ago

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.

monkeyphysics commented 1 year ago

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