Comments (4)
ping @braposo
from graphql-css.
Hey @lifeiscontent, thanks for your question! That's something I've been considering since the deprecation of glamorous so it's probably happening soon.
In the meantime you could always wrap the generated component with emotion, which I know isn't ideal but works.
import styled from "react-emotion";
const Text = gqlCSS(styles)(textStyles);
const StyledText = styled(Text)({
...yourStyles
});
from graphql-css.
@braposo I'd love to talk to you more about this concept you've put together.
One of the things I think would be really powerful here is to create an adapter for the initializer. e.g.
import GraphQLCSS from 'graphql-css';
import { css } from 'emotion';
const CSSQuery = new GraphQLCSS({ css });
const MyComp = (props) => (
<CSSQuery query={...} variables={...}>
{className => <div className={className} {...props} />}
</CSSQuery>
);
I think something like this would be super powerful. Because of a few things.
- It removes the need for an extra adapter into the react eco system (emotion, styled-components, etc).
- the query generates the className.
- you can use pure react components and the API stays the same for other Query components.
what do you think about something like this?
from graphql-css.
@lifeiscontent with the new v2 API you can now use getStyles
to make it work with emotion
.
import useGqlCSS, { gql } from "graphql-css";
import styled from "@emotion/styled";
...
const query = gql`
{
color: colors {
green
}
}
`;
const { getStyles } = useGqlCSS(styles);
const StyledComponent = styled.div(getStyles(query));
from graphql-css.
Related Issues (4)
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from graphql-css.